/*
  Kandu · UX upgrade (touch-first)
  - Botones grandes (una mano)
  - Colores por estado (verde/amarillo/rojo)
  - Jerarquía visual: menos texto, más acción
*/

body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#020617;color:#e5e7eb;}
a{color:#22c55e;text-decoration:none;}a:hover{text-decoration:underline;}
.layout{display:flex;min-height:100vh;}
.sidebar{width:230px;background:#020617;border-right:1px solid rgba(148,163,184,.3);padding:16px 14px;display:flex;flex-direction:column;}
.brand{display:flex;align-items:center;gap:10px;margin-bottom:20px;}
.brand-logo{width:42px;height:42px;border-radius:999px;background:radial-gradient(circle at 20% 20%,#22d3ee,#1d4ed8);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;}
.brand-text{display:flex;flex-direction:column;}
.brand-title{font-size:12px;font-weight:600;}
.brand-subtitle{font-size:12px;color:#9ca3af;}
.menu{display:flex;flex-direction:column;gap:6px;}
.menu-item{border:none;background:transparent;color:#e5e7eb;text-align:left;padding:12px 12px;border-radius:12px;cursor:pointer;font-size:14px;line-height:1.1;}
.menu-item span.emoji{margin-right:8px;}
.menu-item:hover{background:rgba(148,163,184,.18);}
.menu-item.active{background:linear-gradient(90deg,#22c55e,#16a34a);color:#fff;}
.main{flex:1;padding:18px 22px 24px 22px;display:flex;flex-direction:column;}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.topbar-left h1{margin:0;font-size:20px;}
.topbar-left p{margin:2px 0 0 0;font-size:12px;color:#9ca3af;}
.topbar-right{display:flex;align-items:center;gap:8px;}
.chip{padding:4px 10px;border-radius:999px;font-size:12px;}
.chip-outline{border:1px solid #4b5563;}
.chip-success{background:#16a34a;}
.btn{
  pointer-events:auto;

  border-radius:14px;
  border:none;
  background:#1f2937;
  color:#e5e7eb;
  padding:12px 14px;
  font-size:14px;
  font-weight:800;
  min-height:52px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.btn:focus{outline:none;box-shadow:0 0 0 3px rgba(34,197,94,.22);}
.btn:disabled{opacity:.65;cursor:not-allowed;}
.btn-primary{background:linear-gradient(90deg,#22c55e,#16a34a);}
.btn-outline{background:transparent;border:1px solid rgba(148,163,184,.45);}
.btn-sm{padding:4px 10px;font-size:12px;}
.btn-sm{min-height:34px;border-radius:999px;gap:6px;}
.btn-block{width:100%;}
.btn-lg{min-height:60px;font-size:14px;border-radius:16px;}
.btn:hover{opacity:.9;}

/* Variantes */
.btn-danger{background:rgba(248,113,113,.18);border:1px solid rgba(248,113,113,.35);color:#f87171;}
.btn-success{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.35);color:#4ade80;}
.btn-warning{background:rgba(245,158,11,.18);border:1px solid rgba(245,158,11,.45);color:#fde68a;}
.btn-success:disabled{opacity:.85;cursor:default;}
.view{display:none;}
.view.active{display:block;}
.cards-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:14px;}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.semaforo{display:flex;flex-direction:column;gap:10px;}
.semaforo-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:14px;border:1px solid rgba(148,163,184,.25);background:rgba(2,6,23,.55);}
.semaforo-left{display:flex;align-items:center;gap:10px;}
.semaforo-dot{width:10px;height:10px;border-radius:999px;background:#6b7280;box-shadow:0 0 0 3px rgba(107,114,128,.12);}
.semaforo-dot.green{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.15);}
.semaforo-dot.yellow{background:#facc15;box-shadow:0 0 0 3px rgba(250,204,21,.12);}
.semaforo-dot.red{background:#f87171;box-shadow:0 0 0 3px rgba(248,113,113,.12);}
.muted{color:#6b7280;margin-left:6px;}
.mini-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.segmented{display:flex;gap:6px;}
.segmented-btn{border-radius:14px;border:1px solid rgba(148,163,184,.25);background:transparent;color:#e5e7eb;padding:10px 14px;font-size:12px;min-height:44px;cursor:pointer;}
.segmented-btn.active{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.35);color:#4ade80;}
.badge.bronce{background:rgba(156,163,175,.18);color:#e5e7eb;border:1px solid rgba(156,163,175,.25);}
.badge.plata{background:rgba(96,165,250,.12);color:#60a5fa;border:1px solid rgba(96,165,250,.25);}
.badge.oro{background:rgba(250,204,21,.12);color:#facc15;border:1px solid rgba(250,204,21,.25);}
.card{background:#020617;border-radius:16px;padding:14px 16px;box-shadow:0 18px 40px rgba(15,23,42,.9);border:1px solid rgba(148,163,184,.25);}
.kpi{display:flex;flex-direction:column;gap:2px;}
.card-label{font-size:12px;color:#9ca3af;}
.card-value{font-size:24px;font-weight:600;}
.card-caption{font-size:12px;color:#6b7280;}
.tip{margin-top:10px;font-size:12px;color:#9ca3af;}
.table{width:100%;border-collapse:collapse;font-size:12px;}
.table th,.table td{text-align:left;padding:6px 8px;border-bottom:1px solid rgba(55,65,81,.7);}
.table td.right{white-space:normal;}
.table td.right .btn{min-height:44px;font-size:12px;padding:10px 12px;border-radius:14px;margin:2px 4px 2px 0;}
.table th{color:#9ca3af;font-weight:500;font-size:12px;}
.badge{padding:2px 8px;border-radius:999px;font-size:11px;}
.badge.ok{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.35);}
.badge.warn{background:rgba(245,158,11,.18);color:#fde68a;border:1px solid rgba(245,158,11,.45);}
.badge.danger{background:rgba(239,68,68,.18);color:#fecaca;border:1px solid rgba(239,68,68,.45);}
.badge-azul{background:rgba(59,130,246,.15);color:#60a5fa;}
.badge-verde{background:rgba(34,197,94,.15);color:#4ade80;}
.badge-amarillo{background:rgba(250,204,21,.12);color:#facc15;}
.badge-rojo{background:rgba(248,113,113,.12);color:#f87171;}
.badge-n1{background:rgba(234,179,8,.15);color:#facc15;}
.badge-n2{background:rgba(249,115,22,.15);color:#fb923c;}
.badge-n3{background:rgba(248,113,113,.15);color:#f87171;}
.form-card{margin-bottom:14px;}
.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
label{display:flex;flex-direction:column;font-size:12px;gap:4px;}
input,select,textarea{background:#020617;border-radius:12px;border:1px solid rgba(148,163,184,.4);padding:12px 12px;color:#e5e7eb;font-size:14px;min-height:44px;}
input:focus,select:focus,textarea:focus{outline:none;border-color:#22c55e;}
textarea{resize:vertical;}
.input{min-width:200px;}
.form-actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap;}
.form-actions .btn{flex:1;min-width:160px;}
@media (max-width:600px){
  .form-actions{flex-direction:column;}
  .form-actions .btn{width:100%;}
}
.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.list{padding-left:18px;margin:0;}
.list li{margin-bottom:4px;}
.login-page{display:flex;min-height:100vh;align-items:center;justify-content:center;background:#020617;}
.login-card{background:#020617;border-radius:18px;padding:22px 24px 20px 24px;width:100%;max-width:380px;border:1px solid rgba(148,163,184,.4);box-shadow:0 18px 40px rgba(15,23,42,.9);}
.login-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.login-header h1{margin:0;font-size:16px;}
.login-header p{margin:0;font-size:12px;color:#9ca3af;}
.login-footer{margin-top:10px;font-size:11px;color:#9ca3af;}
.error{margin-top:6px;font-size:12px;color:#f97316;}
.rep-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.rep-header h1{margin:0;font-size:16px;}
.rep-header p{margin:2px 0 0 0;font-size:12px;color:#9ca3af;}
.badge-small{font-size:11px;padding:2px 8px;border-radius:999px;background:rgba(34,197,94,.1);color:#4ade80;}

.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.6);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2000;
}
.modal-inner{
  background:#0f172a;
  padding:24px;
  border-radius:16px;
  max-width:360px;
  width:90%;
  text-align:center;
  box-shadow:0 20px 40px rgba(0,0,0,.5);
}
#qr-container{
  margin:16px auto;
}
#qr-container img{
  max-width:260px;
  border-radius:12px;
}
.badge-n1{
  background:#f59e0b;
  color:#020617;
}
.badge-n2{
  background:#ef4444;
  color:white;
}


.repartidor-form{
  margin-bottom:16px;
  padding:12px 14px;
  border-radius:12px;
  background:rgba(15,23,42,0.6);
}
.repartidor-form h4{
  margin:0 0 8px;
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.form-group{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.form-group input{
  padding:6px 8px;
  border-radius:8px;
  border:1px solid rgba(148,163,184,0.4);
  background:#020617;
  color:#e5e7eb;
}
.form-group-button{
  align-self:end;
}
.form-group-button .btn{
  width:100%;
}
@media (max-width:900px){
  .form-grid{
    grid-template-columns:1fr 1fr;
  }
}

/* Mobile: navegación rápida y botones cómodos */
@media (max-width:900px){
  .layout{flex-direction:column;}
  .sidebar{
    width:auto;
    border-right:none;
    border-bottom:1px solid rgba(148,163,184,.25);
    padding:12px 12px;
  }
  .brand{margin-bottom:12px;}
  .menu{flex-direction:row;gap:8px;overflow-x:auto;padding-bottom:6px;}
  .menu-item{white-space:nowrap;padding:12px 12px;border-radius:14px;}
  .main{padding:12px 12px 20px;}
  .cards-row{grid-template-columns:repeat(2,minmax(0,1fr));}
  .grid-2{grid-template-columns:1fr;}
}



/* Estados de ciclo de consumo */
.badge-normal{
  background:rgba(34,197,94,.12);
  color:#4ade80;
}
.badge-por-vencer{
  background:rgba(250,204,21,.12);
  color:#facc15;
}
.badge-critico{
  background:rgba(248,113,113,.15);
  color:#f87171;
}
.badge-perdido{
  background:rgba(148,163,184,.18);
  color:#e5e7eb;
}


/* Banner grande para mostrar el nombre del cliente en Logística de despacho */
.cliente-banner{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(34,197,94,.15);
  border:1px solid #22c55e;
  color:#bbf7d0;
  font-size:12px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.cliente-banner-label{
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.cliente-banner-nombre{
  font-weight:700;
  font-size:14px;
}
.cliente-banner-id{
  color:#a7f3d0;
  font-size:12px;
}


.view-inner{min-height:75vh;}


/* Badges estados (alertas) */
.badge-success{background:rgba(16,185,129,.18);border:1px solid rgba(16,185,129,.5);color:#a7f3d0;}
.badge-warning{background:rgba(245,158,11,.18);border:1px solid rgba(245,158,11,.5);color:#fde68a;}
.badge-orange{background:rgba(249,115,22,.18);border:1px solid rgba(249,115,22,.55);color:#fed7aa;}
.badge-danger{background:rgba(239,68,68,.18);border:1px solid rgba(239,68,68,.5);color:#fecaca;}
.badge-dark{background:rgba(148,163,184,.14);border:1px solid rgba(148,163,184,.45);color:#e2e8f0;}

.badge-morado{ background:#6c5ce7; color:#fff; }
.badge-rojo{ background:#c0392b; color:#fff; }
/* Kandu: asegurar clic en menú */
.sidebar, .menu, .menu-item, .menu * { pointer-events: auto !important; }

/* vistas: solo la activa recibe clic y se muestra */
.view { display:none; pointer-events:none; }
.view.active { display:block; pointer-events:auto; }


/* Botones verdes (inicio/finalizar) */
.chip-green{
  background:#22c55e;
  border:1px solid rgba(34,197,94,.45);
  color:#06260f;
  font-weight:800;
}
.chip-green:hover{filter:brightness(1.05);}
.chip-green:active{transform:translateY(1px);}


/* --- Kandu: semáforo visual para "Clientes por contactar" --- */
.badge{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:12px;
  border:1px solid rgba(0,0,0,.08);
  white-space:nowrap;
}
.badge-green{ background:#e8fff0; color:#0f7a2a; }
.badge-yellow{ background:#fff7db; color:#8a6a00; }
.badge-red{ background:#ffe8e8; color:#9b111e; }
.badge-gray{ background:#f2f2f2; color:#555; }

.table td .btn.btn-sm{
  padding:6px 10px;
  border-radius:10px;
  font-weight:800;
}


/* Inline field alerts (validación final) */
.field-alert{
  margin-top:6px;
  padding:8px 10px;
  border-radius:12px;
  font-size:12px;
  font-weight:700;
  background:rgba(239,68,68,.12);
  border:1px solid rgba(239,68,68,.35);
  color:#fecaca;
}


/* ====== STATUS CHIP ====== */
.status-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  font-weight:800;
  font-size:12px;
  letter-spacing:.3px;
  text-transform:uppercase;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  backdrop-filter: blur(6px);
  white-space:nowrap;
}

.status-dot{
  width:10px; height:10px;
  border-radius:50%;
  box-shadow:0 0 0 3px rgba(255,255,255,.06);
}

.status-note{
  margin-top:6px;
  font-size:12px;
  opacity:.82;
  line-height:1.2;
}

.status-meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:6px;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:3px 8px;
  border-radius:999px;
  font-size:11px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  opacity:.92;
}

/* ====== VARIANTS ====== */
.st-critical{ background:rgba(255, 58, 58, .16); border-color:rgba(255,58,58,.35); }
.st-critical .status-dot{ background:#ff3a3a; box-shadow:0 0 0 3px rgba(255,58,58,.18); }

.st-urgent{ background:rgba(255, 145, 0, .16); border-color:rgba(255,145,0,.35); }
.st-urgent .status-dot{ background:#ff9100; box-shadow:0 0 0 3px rgba(255,145,0,.18); }

.st-warning{ background:rgba(255, 214, 0, .14); border-color:rgba(255,214,0,.35); }
.st-warning .status-dot{ background:#ffd600; box-shadow:0 0 0 3px rgba(255,214,0,.18); }

.st-ok{ background:rgba(0, 200, 83, .14); border-color:rgba(0,200,83,.35); }
.st-ok .status-dot{ background:#00c853; box-shadow:0 0 0 3px rgba(0,200,83,.18); }

.st-learning{ background:rgba(123, 97, 255, .14); border-color:rgba(123,97,255,.35); }
.st-learning .status-dot{ background:#7b61ff; box-shadow:0 0 0 3px rgba(123,97,255,.18); }

tr.row-critical{
  outline:1px solid rgba(255,58,58,.25);
  background:rgba(255,58,58,.05);
}


/* ===== Reabastecer Modal (PRO) ===== */
.modal{ position:fixed; inset:0; background:rgba(0,0,0,.55); display:none; align-items:center; justify-content:center; padding:18px; z-index:9999; }
.modal.show{ display:flex; }
.modal-card{ width:min(860px, 96vw); background:#0f172a; border:1px solid rgba(255,255,255,.08); border-radius:14px; box-shadow:0 12px 34px rgba(0,0,0,.35); overflow:hidden; }
.modal-head{ display:flex; align-items:center; justify-content:space-between; padding:14px 14px; border-bottom:1px solid rgba(255,255,255,.08); }
.modal-title{ font-weight:700; font-size:16px; }
.modal-body{ padding:14px; }
.reb-grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap:14px; }
@media (max-width: 720px){ .reb-grid{ grid-template-columns:1fr; } }
.reb-info{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:12px; line-height:1.45; }
.reb-flags{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.reb-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }

/* ===== Status chips (ajustes solicitados) ===== */
.status-chip.st-blue{ border-color: rgba(59,130,246,.55); }
.status-chip.st-blue .status-dot{ background: #3b82f6; }

.status-chip.st-urgent{ border-color: rgba(249,115,22,.55); }
.status-chip.st-urgent .status-dot{ background: #f97316; }

.status-chip.st-critical{ border-color: rgba(239,68,68,.55); }
.status-chip.st-critical .status-dot{ background: #ef4444; }

.status-chip.st-learning{ border-color: rgba(168,85,247,.55); }
.status-chip.st-learning .status-dot{ background: #a855f7; }

.status-chip.st-contacted{ border-color: rgba(234,179,8,.55); }
.status-chip.st-contacted .status-dot{ background: #eab308; }

.status-chip.st-done{ border-color: rgba(34,197,94,.55); }
.status-chip.st-done .status-dot{ background: #22c55e; }
.status-chip.st-reb{ border-color: rgba(34,197,94,.35); }
.status-chip.st-reb .status-dot{ background: #22c55e; }

.status-chip.st-muted{ opacity:.9; border-color: rgba(255,255,255,.16); }
.pill-ok{ border-color: rgba(34,197,94,.55) !important; }


/* ===== Modal Premium (Eliminar cliente) ===== */
.modal-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
  display:flex; align-items:center; justify-content:center;
  z-index:9999;
  opacity:0;
  transition: opacity .18s ease;
}
.modal-overlay.hidden{ display:none; }
.modal-overlay.show{ opacity:1; }
.modal-box{
  width:min(460px, 92vw);
  background: rgba(14, 20, 34, .98);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:18px 18px 16px;
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  transform: translateY(10px) scale(.99);
  transition: transform .18s ease, opacity .18s ease;
}
.modal-overlay.show .modal-box{ transform: translateY(0) scale(1); }
.modal-actions{ display:flex; justify-content:flex-end; gap:10px; margin-top:16px; }



/* =========================================================
   Kandu · Visual polish pass (premium)
   - Background gradient + subtle noise
   - Glass cards, softer shadows, smoother motion
   - Better tables, inputs, spacing, mobile
   ========================================================= */
:root{
  --bg0:#020617;
  --bg1:#0b1224;
  --card:rgba(2,6,23,.72);
  --stroke:rgba(148,163,184,.28);
  --stroke2:rgba(148,163,184,.18);
  --txt:#e5e7eb;
  --muted:#9ca3af;
  --good:#22c55e;
  --warn:#f59e0b;
  --bad:#f87171;
  --shadow: 0 18px 48px rgba(0,0,0,.45);
}

/* Background that feels "app" not "website" */
body{
  background:
    radial-gradient(1200px 800px at 12% 0%, rgba(34,197,94,.18), transparent 55%),
    radial-gradient(900px 700px at 88% 12%, rgba(34,211,238,.14), transparent 55%),
    radial-gradient(900px 700px at 70% 95%, rgba(29,78,216,.14), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1) 70%, var(--bg0));
  color:var(--txt);
}

.layout{gap:0;}
.sidebar{
  background:rgba(2,6,23,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-right:1px solid var(--stroke);
}
.brand-logo{
  box-shadow:0 10px 28px rgba(34,211,238,.18), 0 12px 36px rgba(29,78,216,.18);
}
.menu-item{
  transition: transform .10s ease, background .15s ease, opacity .15s ease;
}
.menu-item:active{transform:scale(.98);}
.menu-item.active{
  box-shadow:0 10px 28px rgba(34,197,94,.18);
}

/* Top bar */
.topbar{position:sticky; top:0; z-index:5; padding:10px 0; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);}
.topbar:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(2,6,23,.78), rgba(2,6,23,.35));
  border-bottom:1px solid var(--stroke2);
  z-index:-1;
}

/* Cards */
.card{
  background:var(--card) !important;
  border:1px solid var(--stroke) !important;
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .12s ease, box-shadow .18s ease;
}
.card:hover{transform: translateY(-1px); box-shadow: 0 22px 60px rgba(0,0,0,.55);}

/* Inputs */
input, select, textarea{
  background:rgba(15,23,42,.55) !important;
  border:1px solid var(--stroke) !important;
  border-radius:14px !important;
}
input:focus, select:focus, textarea:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(34,197,94,.18) !important;
  border-color: rgba(34,197,94,.55) !important;
}

/* Buttons feel more tactile */
.btn{transition: transform .10s ease, opacity .15s ease, box-shadow .18s ease;}
.btn:active{transform:scale(.98);}
.btn-primary{box-shadow:0 14px 30px rgba(34,197,94,.18);}
.btn-outline{backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);}

/* Tables: clearer, more premium */
.table-wrap{
  background:rgba(2,6,23,.55);
  border:1px solid var(--stroke);
  border-radius:18px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
table{border-collapse:separate; border-spacing:0;}
thead th{
  position:sticky; top:0;
  background:rgba(2,6,23,.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom:1px solid var(--stroke2);
}
tbody tr:nth-child(2n){background:rgba(148,163,184,.06);}
tbody tr:hover{background:rgba(34,197,94,.08);}

/* Modal polish */
.modal-card{
  background:rgba(2,6,23,.78) !important;
  border:1px solid var(--stroke) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.62);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

/* Mobile: sidebar to bottom-nav style feel */
@media (max-width: 920px){
  .sidebar{width:86px}
  .brand-text{display:none}
  .menu-item{padding:12px 10px; font-size:12px}
  .menu-item span.emoji{margin-right:0}
}
@media (max-width: 560px){
  .main{padding:14px 12px 18px 12px}
  .topbar-left h1{font-size:18px}
}


/* ===========================
   Kandu · Premium UI v19
   - Fondo elegante + "glass"
   - Sidebar móvil con overlay
   - Botones icono + tema claro/oscuro
   =========================== */

:root{
  --bg:#020617;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --surface:rgba(2,6,23,.55);
  --surface2:rgba(15,23,42,.65);
  --border:rgba(148,163,184,.25);
  --accent:#22c55e;
  --accent2:#16a34a;
  --danger:#ef4444;
  --shadow:0 18px 45px rgba(0,0,0,.35);
  --shadowSoft:0 10px 25px rgba(0,0,0,.22);
}

html[data-theme="light"]{
  --bg:#f8fafc;
  --text:#0f172a;
  --muted:#475569;
  --surface:rgba(255,255,255,.72);
  --surface2:#ffffff;
  --border:rgba(15,23,42,.12);
  --shadow:0 18px 45px rgba(2,6,23,.12);
  --shadowSoft:0 10px 25px rgba(2,6,23,.08);
}

body{
  background:var(--bg) !important;
  color:var(--text) !important;
}

/* fondo "premium": blobs + grid sutil */
body::before{
  content:"";
  position:fixed;
  inset:-20vh -20vw;
  z-index:-2;
  background:
    radial-gradient(1200px 700px at 20% 10%, rgba(34,197,94,.18), transparent 60%),
    radial-gradient(900px 600px at 80% 20%, rgba(34,211,238,.12), transparent 60%),
    radial-gradient(900px 600px at 60% 85%, rgba(29,78,216,.16), transparent 60%);
  filter:saturate(1.05);
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(to right, rgba(148,163,184,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(148,163,184,.06) 1px, transparent 1px);
  background-size: 44px 44px;
  opacity:.28;
  pointer-events:none;
}

/* barra superior más “app” */
.topbar{
  position:sticky;
  top:0;
  z-index:5;
  padding:12px 12px;
  margin:-6px -6px 14px -6px;
  border-radius:18px;
  background:linear-gradient(180deg, var(--surface2), rgba(255,255,255,0));
  backdrop-filter: blur(10px);
  border:1px solid var(--border);
  box-shadow: var(--shadowSoft);
}

/* icon buttons */
.iconbtn{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  transition: transform .12s ease, background .12s ease;
}
.iconbtn:hover{ transform: translateY(-1px); background:var(--surface2); }
.iconbtn:active{ transform: translateY(0px) scale(.98); }
.mobile-only{ display:none; }

/* sidebar glass */
.sidebar{
  background:linear-gradient(180deg, var(--surface2), rgba(255,255,255,0)) !important;
  backdrop-filter: blur(12px);
}
.menu-item{
  border:1px solid transparent;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.menu-item:hover{
  transform: translateY(-1px);
  border-color: var(--border);
}
.menu-item.active{
  background:linear-gradient(90deg, var(--accent), var(--accent2)) !important;
}

/* cards más premium */
.card, .table-wrap, .semaforo-item{
  background:var(--surface) !important;
  border:1px solid var(--border) !important;
  box-shadow: var(--shadowSoft);
}
.card:hover{ box-shadow: var(--shadow); transform: translateY(-1px); transition: .15s ease; }

/* tablas: header sticky + hover suave */
table thead th{
  position:sticky;
  top:0;
  background:var(--surface2);
  backdrop-filter: blur(10px);
  z-index:2;
}
tbody tr:hover{ background:rgba(148,163,184,.12) !important; }

/* overlay + sidebar móvil */
.sidebar-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(2,6,23,.55);
  backdrop-filter: blur(2px);
  z-index:20;
}
@media (max-width: 900px){
  .mobile-only{ display:inline-flex; }
  .layout{ position:relative; }
  .sidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    z-index:30;
    width:min(86vw, 290px);
    transform: translateX(-105%);
    transition: transform .18s ease;
    box-shadow: var(--shadow);
  }
  body.sidebar-open .sidebar{ transform: translateX(0); }
  body.sidebar-open .sidebar-overlay{ display:block; }
  .main{ padding:14px; }
  .cards-row{ grid-template-columns:repeat(2,minmax(0,1fr)) !important; }
}

/* botones: sensación táctil */
.btn{
  background:var(--surface2) !important;
  border:1px solid var(--border) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  transition: transform .12s ease, box-shadow .12s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadowSoft); }
.btn:active{ transform: translateY(0) scale(.99); }
.btn-primary{
  background:linear-gradient(90deg, var(--accent), var(--accent2)) !important;
  border:none !important;
}
.btn-danger{ background:linear-gradient(90deg,#ef4444,#b91c1c) !important; border:none !important; }
a{ color: var(--accent) !important; }

/* inputs más pro */
input, select, textarea{
  background:var(--surface2) !important;
  border:1px solid var(--border) !important;
  color:var(--text) !important;
}
input:focus, select:focus, textarea:focus{
  outline:none;
  box-shadow: 0 0 0 3px rgba(34,197,94,.18);
}


/* --- v20 Premium dashboard additions --- */
.hero{
  display:flex; gap:14px; align-items:center; justify-content:space-between;
  padding:14px 14px 6px 14px;
}
.hero-title{font-weight:800; letter-spacing:.2px; font-size:18px;}
.hero-sub{color:rgba(229,231,235,.72); font-size:12.5px; margin-top:2px;}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end;}
.spark-card{margin-top:10px;}
.sparkline{
  display:flex; align-items:flex-end; gap:6px; height:72px; padding:10px 6px 2px 6px;
}
.sparkline .bar{
  flex:1; border-radius:10px; background:rgba(34,197,94,.18);
  border:1px solid rgba(34,197,94,.25);
  box-shadow:0 10px 30px rgba(0,0,0,.15);
  transform-origin:bottom;
  animation:barUp .55s ease-out both;
}
@keyframes barUp{from{transform:scaleY(.2); opacity:.35;} to{transform:scaleY(1); opacity:1;}}
/* nicer kpi */
.card.kpi{position:relative; overflow:hidden;}
.card.kpi:before{
  content:""; position:absolute; inset:-2px;
  background:radial-gradient(700px 200px at 20% 0%, rgba(34,197,94,.22), transparent 60%),
             radial-gradient(700px 200px at 80% 0%, rgba(59,130,246,.18), transparent 60%);
  opacity:.9; pointer-events:none;
}
.card.kpi > *{position:relative;}
.table thead th{position:sticky; top:0; background:rgba(2,6,23,.92); backdrop-filter:blur(8px); z-index:2;}
.table tbody tr:hover{background:rgba(255,255,255,.03);}
@media (max-width:720px){
  .hero{align-items:flex-start; flex-direction:column;}
  .hero-actions{justify-content:flex-start;}
}


/* ===== Modal (pro) ===== */
.modal-backdrop{
  position:fixed; inset:0;
  display:none;
  align-items:center; justify-content:center;
  padding:18px;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  z-index: 9999;
}
.modal-backdrop.show{ display:flex; }

.modal{
  width:min(560px, 100%);
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(10,14,26,.92);
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
  overflow:hidden;
  transform: translateY(8px) scale(.98);
  opacity:0;
  animation: modalIn .18s ease forwards;
}
@keyframes modalIn{
  to{ transform: translateY(0) scale(1); opacity:1; }
}
.modal-head{
  display:flex; align-items:flex-start; justify-content:space-between;
  padding:16px 16px 10px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.modal-kicker{ font-size:12px; opacity:.75; }
.modal-title{ margin:2px 0 0 0; font-size:18px; }
.modal-body{ padding:14px 16px; }
.modal-text{ margin:0 0 12px 0; line-height:1.35; opacity:.95; }
.danger-note{ display:inline-block; margin-left:6px; color:#f87171; font-weight:600; }
.modal-confirm{ display:flex; flex-direction:column; gap:8px; }
.modal-label{ font-size:13px; opacity:.85; }
.modal-input{ font-size:16px; letter-spacing:.5px; }
.modal-help{ font-size:12px; opacity:.65; }
.modal-actions{
  display:flex; gap:10px; justify-content:flex-end;
  padding:12px 16px 16px 16px;
  border-top:1px solid rgba(255,255,255,.08);
}
.modal-shake{ animation: shake .28s ease; }
@keyframes shake{
  0%,100%{ transform: translateX(0); }
  20%{ transform: translateX(-8px); }
  40%{ transform: translateX(8px); }
  60%{ transform: translateX(-6px); }
  80%{ transform: translateX(6px); }
}

/* Danger button (strong) */
.btn-danger-strong{
  background: linear-gradient(135deg, rgba(248,113,113,.95), rgba(239,68,68,.85));
  border:1px solid rgba(255,255,255,.14);
  color:#0b1020;
  font-weight:800;
  box-shadow: 0 10px 24px rgba(239,68,68,.25);
}
.btn-danger-strong:disabled{ opacity:.55; filter:saturate(.7); cursor:not-allowed; box-shadow:none; }
.btn-danger-strong:not(:disabled):hover{ transform: translateY(-1px); }


/* ===== FIX v22: Modal RESET inventario no debe dejar la página borrosa =====
   Antes: .modal tenía position:fixed + display:none (regla genérica) y el backdrop mostraba blur sin mostrar la caja.
   Ahora: cuando el backdrop está en .show, mostramos la caja y la hacemos position:relative. */
.modal-backdrop .modal{ display:none; }
.modal-backdrop.show .modal{
  display:block;
  position:relative;
  inset:auto;
  margin:0 auto;
}



/* Mini tabla dashboard */
.mini-table-wrap{ overflow:auto; border-radius:14px; border:1px solid rgba(255,255,255,.08); }
.table.mini th, .table.mini td{ padding:10px 12px; font-size:12.5px; }
.table.mini thead th{ position: sticky; top: 0; z-index: 1; backdrop-filter: blur(10px); }
.badge{ display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; font-weight:700; font-size:12px; border:1px solid rgba(255,255,255,.12); }
.badge.red{ background: rgba(255,59,59,.14); }
.badge.orange{ background: rgba(255,159,10,.14); }
.badge.blue{ background: rgba(0,122,255,.14); }
.badge .dot{ width:8px; height:8px; border-radius:999px; background: currentColor; opacity:.9; }


.brand-logo img{width:100%;height:100%;object-fit:cover;border-radius:999px;display:block;}



/* ==========================================================
   Kandu · Futuristic UI Pack (2026) — overrides only
   Goal: glassmorphism + neon accents + better hierarchy
   ========================================================== */

:root{
  --bg0:#020617;
  --bg1:#030b1e;
  --card:rgba(8, 14, 28, .60);
  --stroke:rgba(148,163,184,.20);
  --stroke2:rgba(56,189,248,.28);
  --text:#e5e7eb;
  --muted:rgba(229,231,235,.72);
  --accent:#22c55e;         /* verde marca */
  --accent2:#38bdf8;        /* cian neon */
  --danger:#ef4444;
  --radius:18px;
  --blur:16px;
}

/* background: deep space + subtle stars */
html,body{height:100%;}
body{
  background:
    radial-gradient(1200px 700px at 10% 10%, rgba(56,189,248,.14), transparent 60%),
    radial-gradient(900px 600px at 85% 20%, rgba(34,197,94,.12), transparent 55%),
    radial-gradient(800px 800px at 50% 90%, rgba(99,102,241,.10), transparent 60%),
    linear-gradient(180deg, var(--bg0), #000 120%);
  color:var(--text);
}

body::before{
  content:"";
  position:fixed; inset:0;
  background-image:
    radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity:.18;
  pointer-events:none;
  mix-blend-mode:screen;
}

body::after{
  content:"";
  position:fixed; inset:-20%;
  background:
    radial-gradient(closest-side at 30% 30%, rgba(56,189,248,.10), transparent 60%),
    radial-gradient(closest-side at 70% 70%, rgba(34,197,94,.08), transparent 60%);
  filter: blur(30px);
  animation: kanduFloat 18s ease-in-out infinite alternate;
  pointer-events:none;
  opacity:.9;
}
@keyframes kanduFloat{
  from{ transform: translate3d(-1%, -1%, 0) scale(1); }
  to{ transform: translate3d(1.2%, 1.2%, 0) scale(1.04); }
}

/* typography */
h1,h2,h3{letter-spacing:-.02em;}
.topbar-left h1{font-size:28px; margin:0;}
.topbar-left p{margin:6px 0 0; color:var(--muted);}

/* sidebar: glass + neon active */
.sidebar{
  background: linear-gradient(180deg, rgba(8,14,28,.72), rgba(8,14,28,.50));
  border-right:1px solid rgba(56,189,248,.14);
  backdrop-filter: blur(var(--blur));
}
.brand{padding:18px 16px;}
.brand-title{font-weight:800; letter-spacing:-.02em;}
.brand-subtitle{color:var(--muted);}
.menu-item{
  border:1px solid transparent;
  border-radius:14px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.menu-item:hover{
  transform: translateY(-1px);
  border-color: rgba(56,189,248,.20);
  background: rgba(56,189,248,.08);
}
.menu-item.active{
  background: linear-gradient(90deg, rgba(34,197,94,.18), rgba(56,189,248,.10));
  border-color: rgba(34,197,94,.22);
  position:relative;
}
.menu-item.active::before{
  content:"";
  position:absolute;
  left:-10px; top:10px; bottom:10px;
  width:4px; border-radius:999px;
  background: linear-gradient(180deg, var(--accent), var(--accent2));
  box-shadow: 0 0 18px rgba(56,189,248,.35);
}

/* main container */
.main{background:transparent;}
.topbar{
  background: rgba(8,14,28,.45);
  border:1px solid rgba(148,163,184,.14);
  border-radius: var(--radius);
  backdrop-filter: blur(var(--blur));
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
}

/* cards: glass + neon edge */
.card{
  background: var(--card) !important;
  border-radius: var(--radius) !important;
  border: 1px solid rgba(148,163,184,.16) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.55) !important;
  backdrop-filter: blur(var(--blur));
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(900px 220px at 20% 0%, rgba(56,189,248,.12), transparent 60%);
  pointer-events:none;
}
.card:hover{
  border-color: rgba(56,189,248,.22) !important;
  box-shadow: 0 28px 90px rgba(0,0,0,.62) !important;
}

/* inputs */
input, select, textarea{
  border-radius: 14px !important;
  border: 1px solid rgba(148,163,184,.18) !important;
  background: rgba(2,6,23,.55) !important;
  color: var(--text) !important;
}
input:focus, select:focus, textarea:focus{
  outline:none !important;
  border-color: rgba(56,189,248,.45) !important;
  box-shadow: 0 0 0 4px rgba(56,189,248,.14) !important;
}
label{color:rgba(229,231,235,.82);}

/* buttons: gradients + glow */
.btn{
  border-radius: 16px !important;
  border: 1px solid rgba(148,163,184,.18) !important;
}
.btn-primary, .btn-success{
  background: linear-gradient(180deg, rgba(34,197,94,.95), rgba(22,163,74,.95)) !important;
  border-color: rgba(34,197,94,.35) !important;
  box-shadow: 0 16px 40px rgba(34,197,94,.18);
}
.btn-primary:hover, .btn-success:hover{
  filter: brightness(1.05);
  box-shadow: 0 18px 55px rgba(34,197,94,.22), 0 0 20px rgba(56,189,248,.10);
  transform: translateY(-1px);
}
.btn-outline{
  background: rgba(8,14,28,.35) !important;
  border-color: rgba(56,189,248,.22) !important;
}
.btn-outline:hover{
  background: rgba(56,189,248,.10) !important;
  box-shadow: 0 0 18px rgba(56,189,248,.14);
}
.btn-danger{
  background: linear-gradient(180deg, rgba(239,68,68,.92), rgba(185,28,28,.92)) !important;
  border-color: rgba(239,68,68,.35) !important;
  box-shadow: 0 16px 40px rgba(239,68,68,.14);
}

/* tables */
table{
  border-collapse: separate !important;
  border-spacing: 0 10px !important;
}
thead th{
  color: rgba(229,231,235,.80) !important;
}
tbody tr{
  background: rgba(8,14,28,.50) !important;
  border: 1px solid rgba(148,163,184,.12) !important;
}
tbody tr:hover{
  background: rgba(56,189,248,.08) !important;
  border-color: rgba(56,189,248,.22) !important;
}

/* status chips */
.badge, .chip{
  border-radius: 999px !important;
  border: 1px solid rgba(148,163,184,.16) !important;
  background: rgba(2,6,23,.45) !important;
}

/* reduce "flat" look for sections */
.section-title{font-weight:800; letter-spacing:-.02em;}
