
:root {
  --bg:#EEEEED; --surface:#FFFFFF; --s2:#E8E8E6; --s3:#D5D6D2;
  --border:rgba(47,46,51,0.11); --border2:rgba(47,46,51,0.24);
  --text:#2F2E33; --muted:#5E5D63; --hint:#9A9A9F;
  --accent:#3A5199; --adim:rgba(58,81,153,0.08); --alight:#ECEEFC;
  --blue:#3A5199; --bdim:rgba(58,81,153,0.12);
  --green:#1A7A3A; --gdim:rgba(26,122,58,0.10);
  --amber:#C07000; --amdim:rgba(192,112,0,0.10);
  --purple:#6B3DC7; --pdim:rgba(107,61,199,0.10);
  --red:#C0392B; --rdim:rgba(192,57,43,0.10);
  --teal:#4A6BC7; --tdim:rgba(74,107,199,0.15);
  --coral:#3A5199; --codim:rgba(58,81,153,0.12);
  --sic:#2F2E33; --sic-teal:#3A5199; --sic-teal-dim:rgba(58,81,153,0.14);
  --mono:'DM Mono',monospace; --sans:'Bricolage Grotesque',sans-serif;
  --r:9px; --rl:14px; --rxl:20px;
  --sh:0 1px 3px rgba(47,46,51,0.07),0 2px 12px rgba(47,46,51,0.05);
  --shl:0 4px 24px rgba(47,46,51,0.13);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5}
input,select,textarea,button{font-family:var(--sans)}

/* ── UTILIDADES ── */
.hidden{display:none!important}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
.anim{animation:fadeUp .25s ease both}

/* ═══════════════════════════════════════════════
   LOGIN
═══════════════════════════════════════════════ */
#login-screen {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:url('../img/Fondo.svg') center center / cover no-repeat;
  padding:24px;
}
/* Overlay de video de bienvenida */
#login-video-overlay {
  position:fixed; inset:0; z-index:9999;
  background:#fff;
  display:none; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s ease;
}
#login-video-overlay.visible { opacity:1; }
#login-video-overlay video {
  max-width:100%; max-height:100vh;
  object-fit:contain;
}
.login-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--rxl); padding:40px 36px; width:100%; max-width:400px;
  box-shadow:var(--shl);
}
.login-logo {
  width:140px; height:72px; margin-bottom:22px;
  display:flex; align-items:center;
}
.login-logo img { width:100%; height:100%; object-fit:contain; }
.login-title{font-size:22px;font-weight:600;margin-bottom:4px}
.login-sub{font-size:13px;color:var(--muted);margin-bottom:28px}
.fi{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fi label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.fi input,.fi select{
  font-size:13px;color:var(--text);background:var(--s2);
  border:1px solid var(--border2);border-radius:var(--r);
  padding:9px 12px;outline:none;transition:border-color .15s;width:100%;
}
.fi input:focus,.fi select:focus{border-color:var(--blue);background:var(--surface)}
.btn-login{
  width:100%;padding:12px;border-radius:var(--r);font-size:14px;font-weight:600;
  background:#2F2E33;color:#D5D6D2;border:none;cursor:pointer;
  transition:all .15s;margin-top:6px;letter-spacing:.03em;
}
.btn-login:hover{background:#3A5199;color:#fff}
.btn-login:active{transform:scale(.98)}
.login-hint{font-size:11px;color:var(--hint);margin-top:16px;line-height:1.6}

/* ═══════════════════════════════════════════════
   SHELL PRINCIPAL
═══════════════════════════════════════════════ */
#app{display:none;flex-direction:column;min-height:100vh}
#app.visible{display:flex}

.topbar {
  position:sticky;top:0;z-index:200;height:56px;
  background:#2F2E33;border-bottom:2px solid #3A5199;
  display:flex;align-items:center;padding:0 20px;gap:12px;
  box-shadow:0 2px 16px rgba(47,46,51,0.40);
}
.topbar-logo{
  height:36px;width:auto;flex-shrink:0;object-fit:contain;
}
.topbar-logo-wrap{
  background:#fff;border-radius:8px;padding:3px 8px;
  display:flex;align-items:center;height:42px;flex-shrink:0;
}
.topbar-name{font-size:13px;font-weight:600;color:#D5D6D2;letter-spacing:.02em}
.topbar-nav{display:flex;gap:2px;margin-left:8px;flex:1;overflow-x:auto;scrollbar-width:none}
.topbar-nav::-webkit-scrollbar{display:none}
.tnav{
  font-size:12px;font-weight:500;padding:5px 12px;border-radius:6px;
  border:none;background:transparent;cursor:pointer;color:rgba(213,214,210,0.65);
  transition:all .15s;white-space:nowrap;
}
.tnav.on{background:rgba(58,81,153,0.30);color:#D5D6D2}
.tnav:hover:not(.on){background:rgba(255,255,255,0.07);color:#D5D6D2}
.topbar-right{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}
.user-pill{
  display:flex;align-items:center;gap:7px;font-size:12px;color:#D5D6D2;
  background:rgba(58,81,153,0.22);border:1px solid rgba(58,81,153,0.42);
  border-radius:20px;padding:4px 12px 4px 6px;
}
.user-av{
  width:22px;height:22px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:600;color:#fff;
}
.btn-logout{
  font-size:11px;color:rgba(213,214,210,0.60);background:transparent;
  border:none;cursor:pointer;padding:4px 8px;border-radius:6px;
  transition:background .15s;
}
.btn-logout:hover{background:rgba(213,214,210,0.08);color:#D5D6D2}

.main-content{flex:1;padding:24px;max-width:1280px;margin:0 auto;width:100%}
.view{display:none}
.view.on{display:block;animation:fadeUp .2s ease}

/* ═══════════════════════════════════════════════
   COMPONENTES COMUNES
═══════════════════════════════════════════════ */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.page-title{font-size:18px;font-weight:600}
.page-sub{font-size:12px;color:var(--muted);margin-top:2px}

.sec-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.sec-label::after{content:'';flex:1;height:1px;background:var(--border)}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:18px;box-shadow:var(--sh)}
.card-sm{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:13px 15px}

.badge{display:inline-block;font-family:var(--mono);font-size:9px;font-weight:500;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.b-reparto   {background:rgba(58,81,153,0.10);color:#2A3B78;border:1px solid rgba(58,81,153,0.28)}
.b-recolecta {background:var(--gdim);color:var(--green);border:1px solid rgba(26,122,58,.2)}
.b-paqueteria{background:rgba(58,81,153,0.07);color:#2A3B78;border:1px solid rgba(58,81,153,0.22)}
.b-proveedor {background:var(--pdim);color:var(--purple);border:1px solid rgba(107,61,199,.2)}
.b-espera    {background:var(--rdim);color:var(--red);border:1px solid rgba(192,57,43,.2)}

.status-badge{display:inline-block;font-family:var(--mono);font-size:9px;font-weight:500;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.st-borrador   {background:var(--s2);color:var(--muted);border:1px solid var(--border2)}
.st-facturado  {background:rgba(58,81,153,0.10);color:#2A3B78;border:1px solid rgba(58,81,153,0.30)}
.st-recibido   {background:rgba(58,81,153,0.14);color:#223070;border:1px solid rgba(58,81,153,0.35)}
.st-preparando {background:rgba(47,46,51,0.08);color:#2F2E33;border:1px solid rgba(47,46,51,0.22)}
.st-listo      {background:rgba(47,46,51,0.14);color:#1A1A1D;border:1px solid rgba(47,46,51,0.30)}
.st-ruta       {background:rgba(58,81,153,0.18);color:#1D2B60;border:1px solid rgba(58,81,153,0.40)}
.st-entregado  {background:rgba(26,122,58,0.10);color:#0D4A20;border:1px solid rgba(26,122,58,0.30)}
.st-espera     {background:rgba(192,57,43,0.10);color:#7D1A0F;border:1px solid rgba(192,57,43,0.30)}

.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--r);font-size:13px;font-weight:600;
  border:1.5px solid;cursor:pointer;transition:all .15s;letter-spacing:.01em;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:#3A5199;border-color:#3A5199;color:#fff}
.btn-primary:hover{background:#2D3F7D;border-color:#2D3F7D}
.btn-outline{background:transparent;border-color:var(--border2);color:var(--text)}
.btn-outline:hover{background:var(--s2)}
.btn-blue{background:var(--bdim);border-color:var(--blue);color:var(--blue)}
.btn-green{background:var(--gdim);border-color:var(--green);color:var(--green)}
.btn-amber{background:var(--amdim);border-color:var(--amber);color:var(--amber)}
.btn-red{background:var(--rdim);border-color:var(--red);color:var(--red)}
.btn-purple{background:var(--pdim);border-color:var(--purple);color:var(--purple)}
.btn-sm{padding:5px 11px;font-size:11px}
.btn:disabled{opacity:.35;pointer-events:none}

input[type=text],input[type=tel],input[type=email],input[type=password],input[type=date],textarea,select{
  font-family:var(--sans);font-size:13px;color:var(--text);
  background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--r);padding:8px 11px;outline:none;
  transition:border-color .15s;width:100%;
}
input:focus,textarea:focus,select:focus{border-color:var(--blue)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer}
textarea{resize:vertical;min-height:64px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.full{grid-column:1/-1}
.fi2{display:flex;flex-direction:column;gap:4px}
.fi2 label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}

/* MODAL */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.5);backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;z-index:500;padding:20px;
}
.modal-overlay.open{display:flex;animation:fadeIn .2s ease}
.modal-box{
  background:var(--surface);border-radius:var(--rxl);
  padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;
  animation:fadeUp .25s ease;box-shadow:var(--shl);
}
.modal-title{font-size:17px;font-weight:600;margin-bottom:4px}
.modal-sub{font-size:12px;color:var(--muted);margin-bottom:20px}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}

/* TOAST */
.toast{
  position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--text);color:var(--surface);font-size:12px;font-weight:600;
  padding:9px 18px;border-radius:20px;z-index:999;transition:transform .3s;
  white-space:nowrap;pointer-events:none;
}
.toast.on{transform:translateX(-50%) translateY(0)}

/* TABLA */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--hint);font-weight:500;padding:0 12px 10px 0;text-align:left;border-bottom:1px solid var(--border)}
.tbl td{padding:10px 12px 10px 0;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border:none}
.tbl tr:hover td{background:rgba(47,46,51,.025)}

/* ═══════════════════════════════════════════════
   DASHBOARD KPI CARDS
═══════════════════════════════════════════════ */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:20px}
.kpi{background:var(--s2);border-radius:var(--r);padding:14px}
.kpi-l{font-size:11px;color:var(--muted);margin-bottom:5px}
.kpi-v{font-size:22px;font-weight:600;line-height:1;margin-bottom:3px}
.kpi-s{font-size:11px}
.kpi-s.up{color:var(--green)} .kpi-s.dn{color:var(--red)} .kpi-s.neu{color:var(--muted)}

.dkpi{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:16px 18px;box-shadow:var(--sh);position:relative;overflow:hidden;
}
.dkpi::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
}
.dkpi-ocean::after  {background:#3A5199}
.dkpi-cyan::after   {background:#7B8BC4}
.dkpi-dark::after   {background:#2F2E33}
.dkpi-green::after  {background:#1A7A3A}
.dkpi-red::after    {background:#C0392B}
.dkpi-purple::after {background:#6B3DC7}
.dkpi-pale::after   {background:#D5D6D2}
.dkpi-icon{font-size:20px;margin-bottom:8px;line-height:1}
.dkpi-val{font-size:26px;font-weight:700;line-height:1;color:var(--text);margin-bottom:4px}
.dkpi-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:3px}
.dkpi-sub{font-size:11px;color:var(--hint)}

/* DROP ZONE */
.drop-zone{
  border:2px dashed var(--border2);border-radius:var(--rl);
  padding:28px 20px;text-align:center;cursor:pointer;
  transition:all .2s;background:var(--surface);position:relative;overflow:hidden;
}
.drop-zone:hover,.drop-zone.over{border-color:var(--blue);background:var(--alight)}
.drop-zone.done{border-style:solid;border-color:var(--green);background:rgba(26,122,58,.04)}
.drop-zone input{position:absolute;inset:0;opacity:0;cursor:pointer}

/* TIPO ENTREGA BOTONES */
.tipo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:4px}
.tbtn{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 6px;border-radius:var(--r);border:1.5px solid var(--border2);
  background:var(--surface);cursor:pointer;transition:all .15s;
}
.tbtn:hover{background:var(--s2)}
.tbtn .tico{font-size:20px}
.tbtn .tlbl{font-size:9px;font-weight:600;text-align:center;line-height:1.3;color:var(--muted)}
.tbtn.sel-reparto   {border-color:#3A5199;background:rgba(58,81,153,0.10)} .tbtn.sel-reparto .tlbl{color:#3A5199}
.tbtn.sel-recolecta {border-color:var(--green);background:var(--gdim)}     .tbtn.sel-recolecta .tlbl{color:var(--green)}
.tbtn.sel-paqueteria{border-color:#7B8BC4;background:rgba(58,81,153,0.08)} .tbtn.sel-paqueteria .tlbl{color:#3A5199}
.tbtn.sel-proveedor {border-color:var(--purple);background:var(--pdim)}    .tbtn.sel-proveedor .tlbl{color:var(--purple)}
.tbtn.sel-espera    {border-color:var(--red);background:var(--rdim)}        .tbtn.sel-espera .tlbl{color:var(--red)}

.cond{display:none}
.cond.on{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.cond.one{grid-template-columns:1fr}

/* FOTO AREA */
.foto-area{border:1.5px dashed var(--border2);border-radius:var(--rl);padding:18px;text-align:center;cursor:pointer;transition:border-color .2s}
.foto-area:active,.foto-area.hf{border-color:var(--green);border-style:solid}
.foto-area .fi-icon{font-size:24px;margin-bottom:6px}
.foto-area .fi-lbl{font-size:11px;color:var(--muted)}
.foto-preview{width:100%;border-radius:8px;display:none;max-height:120px;object-fit:cover}
.foto-area.hf .foto-preview{display:block}
.foto-area.hf .fi-icon,.foto-area.hf .fi-lbl{display:none}

/* PASOS */
.pasos{display:flex;align-items:center;margin-bottom:14px}
.paso{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}
.paso::after{content:'';position:absolute;top:7px;left:50%;width:100%;height:1px;background:var(--border2);z-index:0}
.paso:last-child::after{display:none}
.pdot{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--border2);background:var(--surface);z-index:1;transition:all .3s;flex-shrink:0}
.plbl{font-size:8px;color:var(--muted);text-align:center;line-height:1.2}
.paso.done .pdot{background:#1A7A3A;border-color:#1A7A3A}
.paso.done .plbl{color:var(--green)}
.paso.active .pdot{background:rgba(58,81,153,0.15);border-color:#3A5199}
.paso.active .plbl{color:#3A5199}
.paso.espera-s .pdot{background:var(--rdim);border-color:var(--red)}
.paso.espera-s .plbl{color:var(--red)}

/* ALERTAS */
.alerta{display:flex;align-items:flex-start;gap:9px;padding:9px 12px;border-radius:var(--r);margin-bottom:7px;font-size:12px}
.alerta-danger{background:rgba(192,57,43,.08);color:#7D1A0F;border:1px solid rgba(192,57,43,.2)}
.alerta-warn{background:rgba(192,112,0,.08);color:#7D4A00;border:1px solid rgba(192,112,0,.2)}
.alerta-ok{background:rgba(26,122,58,.08);color:#0D4A20;border:1px solid rgba(26,122,58,.2)}
.alerta-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0;margin-top:4px}

/* CHART WRAPPER */
.cw{position:relative;width:100%}

/* ═══════════════════════════════════════════════
   PERFIL COLABORADOR
═══════════════════════════════════════════════ */
.colab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.colab-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);
  padding:20px;box-shadow:var(--sh);transition:box-shadow .2s;
}
.colab-card:hover{box-shadow:var(--shl)}
.colab-avatar{
  width:52px;height:52px;border-radius:50%;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:700;color:#fff;flex-shrink:0;
}
.colab-avatar img{width:100%;height:100%;object-fit:cover}
.colab-name{font-size:15px;font-weight:600;margin-bottom:2px}
.colab-role{font-size:11px;color:var(--muted)}
.colab-stat{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:10px 14px;background:var(--s2);border-radius:var(--r);flex:1;
}
.colab-stat-val{font-size:18px;font-weight:700;font-family:var(--mono);color:var(--text)}
.colab-stat-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-top:2px}

.perfil-section{margin-bottom:20px}
.perfil-section-title{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);margin-bottom:10px;padding-bottom:6px;
  border-bottom:2px solid var(--adim);display:flex;align-items:center;gap:7px;
}
.perfil-row{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}
.perfil-field{padding:6px 0}
.perfil-field-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--hint);margin-bottom:2px}
.perfil-field-val{font-size:13px;color:var(--text);font-weight:500}

@media(max-width:720px){
  .tipo-grid{grid-template-columns:repeat(3,1fr)}
  .form-grid{grid-template-columns:1fr}
  .full{grid-column:1}
  .main-content{padding:14px}
  .perfil-row{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════
   RESPONSIVE MOBILE — Almacén y general
═══════════════════════════════════════════════ */
@media(max-width:640px){
  /* Topbar */
  .topbar{padding:0 12px;gap:8px}
  .topbar-logo-wrap{flex-shrink:0}
  .topbar-logo{width:32px;height:32px}
  .tnav{font-size:11px;padding:6px 10px}
  #user-name-label{display:none}

  /* Main content */
  .main-content{padding:10px}
  .page-header{flex-direction:column;align-items:flex-start;gap:10px}
  .page-header > div:last-child{align-self:stretch}

  /* Cards */
  .card{padding:12px 14px}

  /* Almacén — guía de estados: 2 columnas */
  .alm-guide{grid-template-columns:repeat(2,1fr) !important}

  /* KPI grid almacén: 3 columnas */
  .kpi-grid{grid-template-columns:repeat(3,1fr) !important}

  /* Filtros almacén: wrap */
  .alm-filtros{flex-wrap:wrap;gap:6px}
  .alm-filtros .btn-sm{font-size:10px;padding:5px 8px}

  /* Tarjetas almacén — acciones en columna */
  .alm-card-btns{flex-direction:column !important}
  .alm-card-btns .btn{width:100%;text-align:center}

  /* Pasos: más compactos */
  .pasos{gap:6px}
  .plbl{font-size:9px}

  /* Tabla responsive: scroll horizontal */
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.tbl{min-width:520px}

  /* Modal más compacto */
  .modal-box{padding:20px 16px;margin:16px}
  .modal-footer{flex-direction:column;gap:8px}
  .modal-footer button{width:100%}

  /* Gerente analítica */
  .ga-vendedores-grid{grid-template-columns:1fr !important}
}
