
: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.jpg?v=20260416') 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}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE — Sistema completo
   Breakpoints: 768px tablet | 640px phone-lg | 480px phone | 375px phone-sm
   Estrategia: desktop → tablet → phone (graceful degradation)
═══════════════════════════════════════════════════════════════════ */

/* ── Utilidades responsive reutilizables ─────────────────────────── */
.r-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.r-scroll::-webkit-scrollbar{display:none}
.r-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.r-stack{display:flex;flex-wrap:wrap;gap:8px}
.r-hide-sm{} /* visible por defecto */
.r-full-sm{} /* sin efecto por defecto */
.r-col-sm{} /* sin efecto por defecto */
.touch-target{min-height:44px;min-width:44px}

/* ── Tipografía base mejorada para móvil ─────────────────────────── */
.fi2 label,.fi label{font-size:11px} /* nunca < 11px */
.sec-label{font-size:11px}

/* ── Modales — contenedor responsive universal ───────────────────── */
.modal-resp-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.5);
  display:flex;align-items:center;justify-content:center;
  padding:16px;z-index:1000;overflow-y:auto;
}
.modal-resp-box{
  background:var(--surface);border-radius:var(--rl);
  padding:24px;width:100%;max-width:520px;
  box-shadow:var(--shl);animation:fadeUp .22s ease;
  max-height:calc(100dvh - 32px);overflow-y:auto;
}

/* ── Barra de filtros — siempre se envuelve en móvil ─────────────── */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center}
.filter-bar input[type=search],
.filter-bar input[type=text]{flex:2;min-width:0}
.filter-bar select{flex:1;min-width:120px}

/* ── Tabla con scroll horizontal ─────────────────────────────────── */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r)}
.table-scroll table{min-width:520px}

/* ══════════ TABLET (≤ 768px) ══════════ */
@media(max-width:768px){
  .main-content{padding:16px;max-width:100%}
  .form-grid{grid-template-columns:1fr 1fr}
  .colab-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
  .kpi-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}
  .dkpi-val{font-size:22px}
  .tipo-grid{grid-template-columns:repeat(3,1fr)}
}

/* ══════════ PHONE-LG (≤ 640px) ══════════ */
@media(max-width:640px){

  /* — Topbar — */
  .topbar{padding:0 10px;gap:6px;height:52px}
  .topbar-logo-wrap{padding:2px 6px;height:38px}
  .topbar-logo{height:30px}
  .topbar-name,.topbar-name *{display:none}
  #user-name-label{display:none}
  .topbar-nav{
    gap:2px;
    /* scroll horizontal con indicador de fade derecho */
    -webkit-mask-image:linear-gradient(to right,black 80%,transparent 100%);
    mask-image:linear-gradient(to right,black 80%,transparent 100%);
  }
  .tnav{font-size:11px;padding:5px 9px;border-radius:5px}
  .user-pill{padding:3px 8px 3px 4px;gap:5px;font-size:11px}
  .btn-logout{font-size:10px;padding:3px 6px}

  /* — Main — */
  .main-content{padding:10px}
  .page-header{flex-direction:column;align-items:flex-start;gap:8px}
  .page-header .btn,.page-header .btn-primary{width:100%;min-height:44px;justify-content:center}
  .page-title{font-size:16px}

  /* — Cards — */
  .card{padding:12px}
  .card-sm{padding:10px 12px}

  /* — Formularios — */
  .form-grid{grid-template-columns:1fr}
  .full{grid-column:1}
  .perfil-row{grid-template-columns:1fr}
  input[type=text],input[type=tel],input[type=email],
  input[type=password],input[type=date],textarea,select{
    font-size:16px; /* evita zoom automático en iOS */
    min-height:44px;padding:10px 12px;
  }

  /* — Botones touch-friendly — */
  .btn{min-height:40px}
  .btn-sm{min-height:34px;padding:5px 10px}

  /* — Tipo grid entrega — */
  .tipo-grid{grid-template-columns:repeat(3,1fr)}

  /* — Modales — */
  .modal-overlay{padding:10px}
  .modal-box{padding:18px 14px;border-radius:var(--rl) var(--rl) 0 0;margin-top:auto;max-height:92dvh}
  .modal-footer{flex-wrap:wrap;gap:8px}
  .modal-footer button{flex:1;min-height:44px;justify-content:center}

  /* — Toast más grande — */
  .toast{font-size:13px;padding:11px 20px;bottom:max(16px, env(safe-area-inset-bottom, 16px))}

  /* — KPI grids — */
  .kpi-grid{grid-template-columns:repeat(2,1fr) !important}
  .kpi-v{font-size:18px}
  .dkpi-val{font-size:20px}

  /* — Colab grid — */
  .colab-grid{grid-template-columns:1fr}

  /* — Pasos — */
  .plbl{font-size:9px}
  .pasos{gap:4px}

  /* — Tablas — */
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.tbl{min-width:480px}

  /* — Filtros almacén — */
  .alm-filtros{flex-wrap:wrap !important;gap:6px}
  .alm-filtros .btn-sm{font-size:10px;padding:5px 8px}
  .alm-card-btns{flex-direction:column !important}
  .alm-card-btns .btn{width:100%;justify-content:center}
  .alm-guide{grid-template-columns:repeat(2,1fr) !important}

  /* — Editor cotización — */
  .cot-editor-header{flex-direction:column !important;align-items:stretch !important}
  .cot-editor-header > div:last-child{display:flex;flex-direction:column;gap:8px}
  .cot-editor-header .btn{width:100%;min-height:44px;font-size:14px;justify-content:center}
  #cots-nueva-btn{width:100%;min-height:44px}

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

  /* — Utilidades — */
  .r-hide-sm{display:none !important}
  .r-full-sm{width:100% !important;min-width:0 !important;flex:none !important}
  .r-col-sm{flex-direction:column !important;align-items:stretch !important}
  .r-col-sm > *{width:100% !important}
}

/* ══════════ PHONE-SM (≤ 480px) ══════════ */
@media(max-width:480px){
  .main-content{padding:8px}
  .card{padding:10px}
  .kpi-grid{grid-template-columns:repeat(2,1fr) !important}
  .tnav{font-size:10px;padding:4px 8px}
  .tipo-grid{grid-template-columns:repeat(2,1fr)}
  .tbtn .tico{font-size:18px}
}

/* ══════════ LOGIN — teclado móvil ══════════ */
@media(max-width:640px){
  #login-screen{
    background:url('../img/fondo-movil.svg') center center / cover no-repeat;
    align-items:flex-end;    /* card en la parte inferior */
    padding:0 0 0;
    min-height:100dvh;        /* viewport dinámico: se recalcula cuando aparece el teclado */
    overflow-y:auto;
  }
  #login-screen .login-card{
    border-radius:24px 24px 0 0;
    max-width:100%;
    padding:28px 22px max(env(safe-area-inset-bottom,16px),28px);
    border-bottom:none;
    width:100%;
  }
  /* El teclado reduce el viewport → el scroll sube la card */
  #login-screen .login-card input:focus{
    scroll-margin-top:80px;
  }
}

/* ── DARK MODE ALMACÉN (OLED optimized) ── */
.alm-dark-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 10px;
}
.alm-action-btn {
  width: 100%;
  min-height: 56px;
  font-size: 16px;
  font-weight: 700;
  border-radius: 12px;
  border: none;
  cursor: pointer;
  margin-top: 12px;
  letter-spacing: .01em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.alm-action-btn.amber { background: #b07000; color: #fff; }
.alm-action-btn.green { background: #1a6e3a; color: #fff; }
.alm-action-btn.blue  { background: #1751a8; color: #fff; }
.alm-action-btn.red   { background: #8a1c0e; color: #fff; }
.alm-action-btn.teal  { background: #0a5e4e; color: #fff; }
.alm-action-btn:disabled { opacity: .35; pointer-events: none; }
.alm-hub-btn {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  min-height: 64px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 0 20px;
  cursor: pointer;
  margin-bottom: 12px;
  text-align: left;
  position: relative;
}
.alm-hub-btn-icon { font-size: 28px; flex-shrink: 0; }
.alm-hub-btn-text { flex: 1; }
.alm-hub-btn-title { font-size: 16px; font-weight: 700; color: var(--text); }
.alm-hub-btn-sub   { font-size: 12px; color: var(--muted); margin-top: 2px; }
.alm-hub-btn-arrow { font-size: 18px; color: #9ca3af; }
.alm-scroll-pills {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 6px;
  margin-bottom: 20px;
  scrollbar-width: none;
}
.alm-scroll-pills::-webkit-scrollbar { display: none; }
.alm-pill {
  flex-shrink: 0;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 40px;
  padding: 12px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  min-width: 80px;
  cursor: pointer;
}
.alm-pill-icon  { font-size: 20px; }
.alm-pill-count { font-size: 22px; font-weight: 700; line-height: 1; }
.alm-pill-label { font-size: 10px; color: var(--muted); text-align: center; white-space: nowrap; }
.alm-filter-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  margin-bottom: 14px;
  scrollbar-width: none;
}
.alm-filter-row::-webkit-scrollbar { display: none; }
.alm-filter-btn {
  flex-shrink: 0;
  padding: 8px 18px;
  border-radius: 40px;
  border: 1px solid #e5e7eb;
  background: #f3f4f6;
  color: #374151;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
.alm-filter-btn.active { background: #1751a8; border-color: #1751a8; color: #fff; }
