:root{--bg:#0f172a;--panel:#111827;--card:#1f2937;--ink:#e5e7eb;--mut:#9ca3af;--ok:#22c55e;--warn:#f59e0b;--danger:#ef4444}
    :root[data-theme="light"]{
      --bg:#f8fafc; --panel:#e5e7eb; --card:#ffffff; --ink:#0f172a; --mut:#475569;
      --ok:#16a34a; --warn:#d97706; --danger:#dc2626;
    }

    *{box-sizing:border-box}
    .preloading #loginView,
.preloading #app{display:none}
#globalLoader{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:8px;
  background:var(--bg);
  color:var(--mut);
  z-index:2000;
  font-size:14px;
}
.gl-spinner{
  width:32px;
  height:32px;
  border-radius:999px;
  border:3px solid rgba(148,163,184,0.4);
  border-top-color:var(--ok);
  animation:glspin 0.8s linear infinite;
}
@keyframes glspin{
  to{transform:rotate(360deg)}
}
body.loaded #globalLoader{display:none}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
    header{background:var(--panel);color:#fff;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
    .wrap{display:flex;min-height:calc(100dvh - 48px)}
    .sidebar{width:220px;background:var(--panel);border-right:1px solid #273244;padding:10px}
    .nav-item{padding:10px;border-radius:8px;cursor:pointer;color:#cbd5e1}
    .nav-item:hover{background:#0b1220}
    .nav-item.active{background:#0b1220;border:1px solid #334155}
    .main{flex:1;padding:16px}
    .card{background:var(--card);padding:16px;border-radius:10px;margin:12px 0}
    input,select,button,textarea{padding:10px;border-radius:8px;border:1px solid #334155;background:#0b1220;color:#e5e7eb}
    :root[data-theme="light"] input,
    :root[data-theme="light"] select,
    :root[data-theme="light"] button,
    :root[data-theme="light"] textarea{
      background:#f1f5f9;
      color:#0f172a;
      border-color:#cbd5e1;
    }

    :root[data-theme="light"] header{
      background:#0f172a;
      color:#f9fafb;
    }
    :root[data-theme="light"] .sidebar{
      background:#ffffff;
      border-right:1px solid #cbd5e1;
    }
    :root[data-theme="light"] .nav-item{
      color:#0f172a;
    }
    :root[data-theme="light"] .nav-item:hover{
      background:#e5e7eb;
    }
    :root[data-theme="light"] .nav-item.active{
      background:#0f172a;
      color:#f9fafb;
      border-color:#0f172a;
    }
    .card{
      border:1px solid #111827;
    }
    :root[data-theme="light"] .card{
      border-color:#e2e8f0;
      box-shadow:0 10px 25px rgba(15,23,42,.05);
    }
    button{cursor:pointer}
    .badge{padding:6px 10px;border-radius:999px;border:1px solid #334155;background:#0b1220;color:#93c5fd;font-size:12px}
    :root[data-theme="light"] .badge{background:#eef2ff;color:#1e3a8a;border-color:#c7d2fe}
    .hidden{display:none}
    table{width:100%;border-collapse:collapse}
    th,td{padding:8px;border-bottom:1px solid #334155;text-align:left;font-size:13px}
    thead th{background:#0f172a;position:sticky;top:0}
    :root[data-theme="light"] thead th{background:#e2e8f0;color:#0f172a}
    .grid{display:grid;gap:12px}
    .cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
    .cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
    .cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
    @media(max-width:900px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3,.cols-2{grid-template-columns:1fr}.sidebar{width:200px}}
    .kpi{display:flex;flex-direction:column;gap:6px}
    .kpi .big{font-size:24px;font-weight:700}


/* ===== KPI Pro Cards (para Dashboard) ===== */
.kpi-procard{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}
.kpi-procard::before{
  content:"";position:absolute;inset:-40px -60px auto auto;width:220px;height:220px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.14), rgba(255,255,255,0) 60%);
  transform:rotate(18deg);pointer-events:none;
}
.kpi-procard::after{
  content:"";position:absolute;inset:auto -80px -120px auto;width:260px;height:260px;
  background:radial-gradient(circle at 30% 30%, rgba(56,189,248,.12), rgba(56,189,248,0) 62%);
  transform:rotate(-10deg);pointer-events:none;
}
.kpi-pro-head{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.kpi-pro-left{display:flex;align-items:center;gap:12px;min-width:0}
.kpi-pro-icon{
  width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.6px;font-size:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.kpi-pro-name{font-weight:800;white-space:normal;overflow:visible;text-overflow:clip;line-height:1.15}
.kpi-pro-meta{opacity:.75;font-size:12px;margin-top:2px}
.kpi-pro-badge{
  position:relative;flex:0 0 auto;
  min-width:46px;height:34px;padding:0 12px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;font-size:16px;letter-spacing:.3px;
  background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.35);color:#bbf7d0;
}
.kpi-pro-badge--warn{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.35);color:#fde68a}
.kpi-pro-foot{position:relative;margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.kpi-pro-chipline{
  display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid rgba(148,163,184,.18);
  opacity:.9;font-size:12px
}
.kpi-pro-chipline--warn{background:rgba(245,158,11,.10);border-color:rgba(245,158,11,.28);color:#fde68a}
.kpi-pro-value{position:relative;font-size:44px;font-weight:900;line-height:1;margin-top:14px}
.kpi-pro-note{position:relative;opacity:.72;font-size:12px;margin-top:8px}
@media(max-width:900px){
  .kpi-pro-value{font-size:40px}
}


/* --- KPI Pro tweaks (títulos en una línea + chips a la izquierda) --- */
.kpi-pro-left--tight{gap:10px}
.kpi-pro-left--tight .kpi-pro-icon{width:34px;height:34px;border-radius:10px;font-size:11px}
.kpi-pro-txt{min-width:0;display:flex;flex-direction:column}
.kpi-pro-name--single{white-space:nowrap;overflow:visible;text-overflow:clip}
.kpi-pro-meta-row{display:flex;align-items:center;gap:10px;margin-top:2px;flex-wrap:nowrap}
.kpi-pro-meta-row .kpi-pro-meta{margin-top:0}
.kpi-pro-meta-row .kpi-pro-chipline{padding:6px 10px;font-size:12px}
.kpi-pro-chipline--muted{background:rgba(255,255,255,.04);border-color:rgba(148,163,184,.16);opacity:.9}
@media(max-width:900px){
  .kpi-pro-name--single{font-size:15px}
}

:root[data-theme="light"] .kpi-pro-icon{background:rgba(15,23,42,.06);border-color:rgba(15,23,42,.10)}
:root[data-theme="light"] .kpi-pro-badge{color:#14532d}
:root[data-theme="light"] .kpi-pro-badge--warn{color:#7c2d12}
:root[data-theme="light"] .kpi-pro-chipline{background:rgba(15,23,42,.04);border-color:rgba(15,23,42,.10)}
:root[data-theme="light"] .kpi-pro-chipline--warn{color:#7c2d12;border-color:rgba(124,45,18,.22);background:rgba(124,45,18,.06)}

.kpi-chipcard{display:flex;align-items:flex-start;justify-content:flex-start}
.kpi-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.25)}
.kpi-chip-text{font-weight:700}
.kpi-chip-meta{opacity:.75;font-size:12px}
.kpi-chip-badge{min-width:34px;height:28px;padding:0 10px;border-radius:999px;display:inline-flex;
  align-items:center;justify-content:center;font-weight:800;letter-spacing:.2px;
  background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.35);color:#bbf7d0}
.kpi-chip--warn .kpi-chip-badge{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.35);color:#fde68a}

:root[data-theme="light"] .kpi-chip{background:rgba(15,23,42,.06);border-color:rgba(15,23,42,.12)}
:root[data-theme="light"] .kpi-chip-badge{color:#14532d}
:root[data-theme="light"] .kpi-chip--warn .kpi-chip-badge{color:#7c2d12}

    .icc-progress{margin-top:6px;background:#1e293b;border-radius:999px;overflow:hidden;height:6px}
.icc-progress-bar{height:100%;width:0%;background:var(--ok);transition:width .15s linear}
.preview{max-height:220px;overflow:auto;border:1px solid #334155;margin-top:8px}
    #toastBox{position:fixed;right:12px;bottom:12px;z-index:9999;display:flex;flex-direction:column;gap:8px}
    .toast{border:1px solid #334155;background:#0b1220;color:#e5e7eb;padding:10px 12px;border-radius:10px;box-shadow:0 10px 20px rgba(0,0,0,.25);animation:slidein .15s ease-out}
    .toast.ok{border-color:var(--ok)} .toast.warn{border-color:var(--warn)} .toast.danger{border-color:var(--danger)}
    @keyframes slidein{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
    .flash{animation:flashbg 1.6s ease-out 1}
    @keyframes flashbg{0%{background:rgba(34,197,94,.25)}100%{background:transparent}}
  
#modalBox input,
#modalBox select{
  background:#2a2a2a;
  color:#f0f0f0;
  border:1px solid #444;
  border-radius:6px;
  padding:6px 8px;
}
#modalBox label{
  color:#ddd;
}


.role-admin { background:#1e3a8a; color:#fff !important; }
.role-dist  { background:#166534; color:#fff !important; }
.role-vend  { background:#374151; color:#fff !important; }


    .pass-hints{
      margin-top:4px;
      font-size:11px;
      color:var(--mut);
      display:flex;
      flex-wrap:wrap;
      gap:4px 6px;
    }
    .pass-hints div{
      margin:0;
      padding:2px 6px;
      border-radius:999px;
      background:rgba(255,255,255,0.03);
    }
    .pass-hints div.ok{
      color:var(--ok);
      background:rgba(46,204,113,0.12);
    }
    .pass-hints div.bad{
      color:var(--mut);
      opacity:0.75;
    }

    .branch-filter{
      display:flex;
      flex-wrap:wrap;
      align-items:center;
      gap:6px;
    }
    .branch-filter-label{
      font-size:11px;
      color:var(--mut);
      margin-right:4px;
    }
    .branch-chips{
      display:flex;
      flex-wrap:wrap;
      gap:6px;
    }
    .branch-chip{
      border:none;
      outline:none;
      padding:4px 10px;
      border-radius:999px;
      background:rgba(255,255,255,0.03);
      color:var(--mut);
      font-size:11px;
      cursor:pointer;
      transition:background 0.15s ease,color 0.15s ease,transform 0.08s ease;
    }
    .branch-chip:hover{
      transform:translateY(-1px);
      background:rgba(148,163,184,0.25);
    }
    .branch-chip.active{
      background:var(--ok);
      color:#0b1120;
      font-weight:500;
    }

    .user-toolbar{
      margin-bottom:10px;
      display:flex;
      gap:8px;
      flex-wrap:wrap;
      align-items:center;
      justify-content:space-between;
    }
    .user-toolbar-info{
      font-size:12px;
      color:var(--mut);
    }
    .user-filters{
      display:flex;
      flex-wrap:wrap;
      align-items:center;
      gap:8px;
    }
    .user-filter{
      display:flex;
      flex-direction:column;
      gap:2px;
      font-size:11px;
      color:var(--mut);
    }
    .user-filter-label{
      font-size:11px;
      color:var(--mut);
    }
    .user-select{
      min-width:160px;
      padding:4px 8px;
      font-size:12px;
      border-radius:999px;
      border:none;
      background:rgba(15,23,42,0.85);
      color:var(--ink);
      outline:none;
    }
    .user-select:focus{
      box-shadow:0 0 0 1px rgba(148,163,184,0.8);
    }
    .user-search{
      display:flex;
      align-items:center;
      gap:4px;
      padding:2px 8px;
      border-radius:999px;
      background:rgba(15,23,42,0.85);
    }
    .user-search-icon{
      font-size:12px;
      color:var(--mut);
    }
    .user-search-input{
      border:none;
      outline:none;
      background:transparent;
      font-size:12px;
      color:var(--ink);
      min-width:120px;
    }

    .user-branch-dropdown{
      position:relative;
    }
    .user-branch-trigger{
      display:flex;
      align-items:center;
      gap:4px;
      padding:4px 10px;
      border-radius:999px;
      background:rgba(15,23,42,0.85);
      border:none;
      cursor:pointer;
      font-size:12px;
      color:var(--ink);
    }
    .user-branch-trigger:hover{
      background:rgba(30,64,175,0.85);
    }
    .user-branch-icon{
      font-size:13px;
    }
    .user-branch-caret{
      font-size:9px;
      opacity:0.7;
    }
    .user-branch-menu{
      position:absolute;
      right:0;
      top:100%;
      margin-top:4px;
      background:#020617;
      border-radius:12px;
      padding:6px;
      box-shadow:0 10px 30px rgba(15,23,42,0.8);
      min-width:190px;
      display:none;
      z-index:40;
    }
    .user-branch-menu.open{
      display:block;
    }
    .user-branch-option{
      width:100%;
      text-align:left;
      border:none;
      background:transparent;
      padding:6px 8px;
      border-radius:8px;
      font-size:12px;
      color:var(--ink);
      cursor:pointer;
    }
    .user-branch-option:hover{
      background:rgba(148,163,184,0.25);
    }
    .user-branch-option.active{
      background:var(--ok);
      color:#0b1120;
      font-weight:500;
    }

    
    .table-responsive{
      width:100%;
      overflow:auto;
    }
    .table-responsive table{
      width:100%;
      min-width:640px;
    }

.mobile-only{display:none;}

    @media (max-width:768px){
      .wrap{
        flex-direction:column;
      }
      header{
        position:sticky;
        top:0;
        z-index:50;
      }
      .sidebar{
        position:fixed;
        top:90px;
        left:0;
        bottom:0;
        z-index:40;
        max-width:80vw;
        width:220px;
        padding-top:12px;
        transform:translateX(-100%);
        transition:transform .2s ease-out, box-shadow .2s ease-out;
        box-shadow:0 0 0 rgba(0,0,0,0);
      }
      .sidebar.open{
        transform:translateX(0);
        box-shadow:0 10px 25px rgba(15,23,42,.5);
      }
      .main{
        padding:12px;
      }
      table{
        font-size:12px;
      }
      th,td{
        padding:6px;
      }
      .preview{
        max-height:none;
      }
      .mobile-only{
        display:inline-flex;
      }
    }

    @media (min-width:769px){
      .sidebar{
        position:static;

        box-shadow:none;
      }
    }

/* Mejora visual: estatus del número en recarga individual */
.sim-status{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:6px 0 0 2px;
  padding:4px 10px;
  border-radius:999px;
  font-size:0.75rem;
  border:1px solid #1f2937;
  background:rgba(15,23,42,0.85);
  color:var(--mut);
}
:root[data-theme="light"] .sim-status{
  background:#f1f5f9;
  border-color:#cbd5f5;
}
.sim-status::before{
  content:'';
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--mut);
  box-shadow:0 0 0 2px rgba(148,163,184,0.4);
}
.sim-status--ok{
  color:var(--ok);
  background:rgba(34,197,94,0.12);
  border-color:rgba(34,197,94,0.55);
}
.sim-status--ok::before{
  background:var(--ok);
  box-shadow:0 0 0 2px rgba(34,197,94,0.45);
}
.sim-status--danger{
  color:var(--danger);
  background:rgba(239,68,68,0.12);
  border-color:rgba(239,68,68,0.55);
}
.sim-status--danger::before{
  background:var(--danger);
  box-shadow:0 0 0 2px rgba(239,68,68,0.45);
}
.sim-status--muted{
  color:var(--mut);
}


/* Notificación visual tipo banner para recargas programadas ejecutadas */
.recarga-notif-container{
  position:fixed;
  top:70px;
  left:50%;
  transform:translateX(-50%);
  z-index:1300;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
  pointer-events:none;
}
.recarga-notif-card{
  pointer-events:auto;
  max-width:720px;
  width:min(720px, 100% - 24px);
  padding:10px 16px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(15,23,42,0.98);
  box-shadow:0 18px 45px rgba(0,0,0,0.55);
  color:var(--fg);
  font-size:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  transition:opacity .20s ease, transform .20s ease;
}
:root[data-theme="light"] .recarga-notif-card{
  background:#f8fafc;
}
.recarga-notif-card.ok{
  border-color:rgba(34,197,94,0.85);
}
.recarga-notif-card.warn{
  border-color:rgba(234,179,8,0.9);
}
.recarga-notif-card.danger{
  border-color:rgba(239,68,68,0.95);
}
.recarga-notif-toprow{
  display:flex;
  align-items:center;
  gap:10px;
}
.recarga-notif-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:600;
}
.recarga-notif-icon.ok{
  background:rgba(34,197,94,0.20);
}
.recarga-notif-icon.warn{
  background:rgba(234,179,8,0.22);
}
.recarga-notif-icon.danger{
  background:rgba(239,68,68,0.22);
}
.recarga-notif-body{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.recarga-notif-title{
  font-weight:600;
  font-size:13px;
}
.recarga-notif-sub{
  font-size:11px;
  color:var(--mut);
}
.recarga-notif-status{
  font-size:11px;
}
.recarga-notif-date,
.recarga-notif-prog{
  font-size:11px;
  color:var(--mut);
}
.recarga-notif-footer{
  margin-top:2px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:6px;
  font-size:11px;
}
.recarga-notif-hint{
  color:var(--mut);
}
.recarga-notif-btn-close{
  border:none;
  background:transparent;
  color:var(--mut);
  cursor:pointer;
  font-size:11px;
  padding:2px 4px;
}
.recarga-notif-btn-close:hover{
  opacity:0.8;
}
@media (max-width:768px){
  .recarga-notif-container{
    top:60px;
    left:0;
    right:0;
    transform:none;
    align-items:stretch;
  }
  .recarga-notif-card{
    width:auto;
    max-width:100%;
    border-radius:0 0 14px 14px;
  }
}


    @keyframes spin{
      from{transform:rotate(0deg);}
      to{transform:rotate(360deg);}
    }
    @keyframes pulseBar{
      0%{transform:translateX(-60%);}
      50%{transform:translateX(-10%);}
      100%{transform:translateX(100%);}
    }

    @keyframes barStripe{
      0%{background-position:0 0;}
      100%{background-position:68px 0;}
    }

.hidden{display:none!important;} #modalBox{
  background:#1e1e1e;
  color:#f0f0f0;
  border-radius:12px;
  padding:20px;
  box-shadow:0 8px 30px rgba(0,0,0,.6);
  max-width:520px;
  min-width:280px;
}
.role-admin { background:#1e3a8a; color:#fff !important; }
.role-dist  { background:#166534; color:#fff !important; }
.role-vend  { background:#374151; color:#fff !important; }


/* Mejora visual: estatus del número en recarga individual */
.sim-status{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:6px 0 0 2px;
  padding:4px 10px;
  border-radius:999px;
  font-size:0.75rem;
  border:1px solid #1f2937;
  background:rgba(15,23,42,0.85);
  color:var(--mut);
}
:root[data-theme="light"] .sim-status{
  background:#f1f5f9;
  border-color:#cbd5f5;
}
.sim-status::before{
  content:'';
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--mut);
  box-shadow:0 0 0 2px rgba(148,163,184,0.4);
}
.sim-status--ok{
  color:var(--ok);
  background:rgba(34,197,94,0.12);
  border-color:rgba(34,197,94,0.55);
}
.sim-status--ok::before{
  background:var(--ok);
  box-shadow:0 0 0 2px rgba(34,197,94,0.45);
}
.sim-status--danger{
  color:var(--danger);
  background:rgba(239,68,68,0.12);
  border-color:rgba(239,68,68,0.55);
}
.sim-status--danger::before{
  background:var(--danger);
  box-shadow:0 0 0 2px rgba(239,68,68,0.45);
}
.sim-status--muted{
  color:var(--mut);
}


/* Filas de stock según estado (vencida / vendida-activada) */
.card table tr.sim-row-vencida{
  background:rgba(239,68,68,0.40) !important;
}
.card table tr.sim-row-vendida{
  background:rgba(37,99,235,0.35) !important;
}
:root[data-theme="light"] .card table tr.sim-row-vencida{
  background:rgba(248,113,113,0.35) !important;
}
:root[data-theme="light"] .card table tr.sim-row-vendida{
  background:rgba(59,130,246,0.30) !important;
}

/* ===== Conectividad Xtreme (Dashboard / Recarga individual) ===== */
.xtreme-card{position:relative;overflow:hidden}
.xtreme-header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.xtreme-header-left{display:flex;align-items:center;gap:10px}
.xtreme-wave{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:#60a5fa}
.xtreme-title{font-size:16px;font-weight:650;letter-spacing:0.2px}
.xtreme-status-line{margin-top:10px;display:flex;align-items:center;gap:10px}
.xtreme-check{width:28px;height:28px;border-radius:999px;border:2px solid var(--mut);display:flex;align-items:center;justify-content:center;font-weight:900;line-height:1}
.xtreme-status-text{font-size:22px;font-weight:750}
.xtreme-meta{margin-top:10px;font-size:13px;color:var(--mut);display:flex;flex-direction:column;gap:6px}
.xtreme-k{color:var(--mut)}
.xtreme-v{color:var(--ink)}
.xtreme-updated{margin-top:8px;font-size:11px;color:var(--mut);opacity:0.85}

.xtreme-card[data-level="ok"] .xtreme-check{border-color:var(--ok);color:var(--ok)}
.xtreme-card[data-level="ok"] .xtreme-status-text{color:var(--ink)}

.xtreme-card[data-level="degraded"] .xtreme-check{border-color:var(--warn);color:var(--warn)}
.xtreme-card[data-level="degraded"] .xtreme-status-text{color:var(--warn)}

.xtreme-card[data-level="down"] .xtreme-check{border-color:var(--danger);color:var(--danger)}
.xtreme-card[data-level="down"] .xtreme-status-text{color:var(--danger)}

/* micro indicador en recarga individual */
.xtreme-inline{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid #334155;background:#0b1220;color:var(--ink);font-size:12px;white-space:nowrap}
:root[data-theme="light"] .xtreme-inline{background:#f1f5f9;border-color:#cbd5e1}
.xtreme-inline-dot{width:10px;height:10px;border-radius:999px;background:var(--mut)}
.xtreme-inline[data-level="ok"] .xtreme-inline-dot{background:var(--ok)}
.xtreme-inline[data-level="degraded"] .xtreme-inline-dot{background:var(--warn)}
.xtreme-inline[data-level="down"] .xtreme-inline-dot{background:var(--danger)}

/* layout top dashboard: coloca conectividad encima de vendedor */
.dash-top{grid-template-rows:auto auto}
@media(min-width:901px){
  .dash-top .dash-kpi-contador{grid-column:1;grid-row:1/3}
  .dash-top .dash-kpi-30{grid-column:2;grid-row:1/3}
  .dash-top .dash-ws{grid-column:3/5;grid-row:1}
  .dash-top .dash-best{grid-column:3;grid-row:2}
  .dash-top .dash-worst{grid-column:4;grid-row:2}
}
@media(max-width:900px){
  .dash-top .dash-ws{grid-column:1/-1}
}

.kpi-pro-icon--small{font-size:12px;letter-spacing:0.2px}

.kpi-pro-left{min-width:0}
.kpi-pro-left > div{min-width:0}


/* ===== Login polish ===== */
#loginView.login-card{
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:22px;
  box-shadow:0 18px 50px rgba(0,0,0,.35);
  position:relative;
  overflow:hidden;
}
#loginView.login-card:before{
  content:'';
  position:absolute;
  inset:-2px;
  background:radial-gradient(600px 200px at 20% 0%, rgba(59,130,246,.18), transparent 60%),
             radial-gradient(600px 200px at 80% 0%, rgba(34,197,94,.14), transparent 60%);
  pointer-events:none;
}
#loginView.login-card > *{ position:relative; }
#loginView .login-header{
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:12px;
}
#loginView .login-logo{
  width:46px;height:46px;
  border-radius:14px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 8px 18px rgba(0,0,0,.25);
}
#loginView .login-title{ margin:0; font-size:20px; letter-spacing:.2px; }
#loginView .login-subtitle{ color:var(--mut); font-size:12px; margin-top:2px; }
#loginView .login-session{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
  margin-left:auto;
}
#loginView #loginSessionHours{ min-width:160px; }
@media (max-width:700px){
  #loginView.login-card{ max-width:520px; }
  #loginView .login-session{ width:100%; margin-left:0; }
}


/* ===== Modal 2FA (login) ===== */
#modal.modal-variant-twofa{
  background: rgba(2, 6, 23, 0.72) !important;
  backdrop-filter: blur(10px);
}

#modalBox.modal-variant-twofa{
  width: min(520px, 92vw) !important;
  max-width: 520px !important; /* sobreescribe inline max-width:90% */
  min-width: 320px !important;
  padding: 18px 20px 16px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(2, 6, 23, 0.96));
  box-shadow: 0 18px 50px rgba(0,0,0,0.55);
}

#modalBox.modal-variant-twofa > div:first-child{
  margin-bottom: 14px !important; /* header inline */
  padding-bottom: 12px !important;
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}

#modalBox.modal-variant-twofa h3{
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0.3px;
}

.twofa-wrap{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.twofa-top{
  display: flex;
  gap: 12px;
  align-items: center;
}

.twofa-icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  border: 1px solid rgba(59, 130, 246, 0.30);
  background: rgba(59, 130, 246, 0.14);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex: 0 0 auto;
  box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.06);
}

.twofa-msg{
  color: #e5e7eb;
  line-height: 1.4;
  font-size: 14px;
}

.twofa-muted{
  color: #94a3b8;
}

.twofa-meta{
  margin-top: 8px;
  color: #94a3b8;
  font-size: 13px;
}

.twofa-code{
  display: flex;
  gap: 10px;
  justify-content: center;
  padding: 2px 0 0;
}

/* Reforzamos estilos de inputs vs #modalBox input */
#modalBox.modal-variant-twofa input.twofa-digit{
  width: 54px !important;
  height: 60px !important;
  border-radius: 16px !important;
  text-align: center;
  font-size: 24px !important;
  font-weight: 800 !important;
  border: 1px solid rgba(148, 163, 184, 0.28) !important;
  background: rgba(15, 23, 42, 0.55) !important;
  color: #f8fafc !important;
  outline: none;
  padding: 0 !important;
  box-shadow: inset 0 -10px 25px rgba(0,0,0,0.25);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

#modalBox.modal-variant-twofa input.twofa-digit:focus{
  border-color: rgba(59, 130, 246, 0.65) !important;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.16), inset 0 -10px 25px rgba(0,0,0,0.25);
  transform: translateY(-1px);
}

/* separación visual 3+3 */
.twofa-code input.twofa-digit:nth-child(3){
  margin-right: 10px;
}

.twofa-hint{
  margin-top: -2px;
  color: #94a3b8;
  font-size: 12px;
}

.twofa-actions{
  display: flex;
  gap: 10px;
  justify-content: space-between;
  align-items: center;
  margin-top: 2px;
}

.twofa-btn{
  font-size: 12px;
  padding: 9px 14px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(15, 23, 42, 0.40);
  color: #e2e8f0;
  cursor: pointer;
}

.twofa-btn:hover{
  filter: brightness(1.08);
}

.twofa-btn-primary{
  background: rgba(59, 130, 246, 0.22);
  border-color: rgba(59, 130, 246, 0.35);
  color: #dbeafe;
}

.twofa-btn-primary:hover{
  background: rgba(59, 130, 246, 0.28);
}

@media (max-width: 520px){
  #modalBox.modal-variant-twofa{
    width: min(480px, 94vw) !important;
    padding: 16px 16px 14px !important;
  }
  .twofa-code{ gap: 8px; }
  #modalBox.modal-variant-twofa input.twofa-digit{
    width: 44px !important;
    height: 54px !important;
    border-radius: 14px !important;
    font-size: 22px !important;
  }
  .twofa-code input.twofa-digit:nth-child(3){ margin-right: 8px; }
}


/* Force trust checkbox visible (cache-safe) */
#modalBox.modal-variant-twofa .twofa-trust{ display:flex !important; }
#modalBox.modal-variant-twofa #twofaTrustDevice{ display:inline-block !important; }



/* =====================================================================
   UI Refresh (v20260105_ui01)
   - Nuevo shell (topbar + sidebar)
   - Login renovado
   - Paleta y componentes más modernos
   ===================================================================== */

:root{
  /* paleta */
  --bg:#070b14;
  --panel:#0b1220;
  --card:rgba(15,23,42,0.82);
  --ink:#e5e7eb;
  --mut:rgba(226,232,240,0.72);
  --accent:#38bdf8;
  --accent2:#22c55e;

  --fg:var(--ink);
  --border:rgba(148,163,184,0.16);
  --border2:rgba(148,163,184,0.22);
  --shadow:0 18px 60px rgba(0,0,0,0.55);
  --shadowSoft:0 14px 32px rgba(0,0,0,0.35);
  --radius:16px;
  --radius2:22px;
  --topbar-h:64px;

  --ok:#22c55e;
  --warn:#f59e0b;
  --danger:#ef4444;
}
:root[data-theme="light"]{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --card:#ffffff;
  --ink:#0b1220;
  --mut:rgba(30,41,59,0.72);
  --accent:#2563eb;
  --accent2:#16a34a;

  --fg:var(--ink);
  --border:rgba(15,23,42,0.12);
  --border2:rgba(15,23,42,0.18);
  --shadow:0 18px 50px rgba(15,23,42,0.12);
  --shadowSoft:0 12px 26px rgba(15,23,42,0.10);
}

body{
  background:
    radial-gradient(1200px 800px at 12% 8%, rgba(56,189,248,0.12), rgba(56,189,248,0) 60%),
    radial-gradient(900px 700px at 88% 18%, rgba(34,197,94,0.10), rgba(34,197,94,0) 62%),
    var(--bg);
  color:var(--ink);
}

/* ===== Loader ===== */
#globalLoader{
  background:
    radial-gradient(1200px 800px at 12% 8%, rgba(56,189,248,0.14), rgba(56,189,248,0) 60%),
    radial-gradient(900px 700px at 88% 18%, rgba(34,197,94,0.12), rgba(34,197,94,0) 62%),
    var(--bg);
}
.gl-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:4px}
.gl-logo{width:56px;height:56px;border-radius:18px;object-fit:cover;box-shadow:var(--shadowSoft);border:1px solid var(--border2)}
.gl-title{font-weight:900;font-size:18px;letter-spacing:0.2px}
.gl-sub{font-size:12px;color:var(--mut)}
.gl-detail{font-size:12px;opacity:.85;max-width:520px;text-align:center}

/* ===== Topbar ===== */
.topbar{
  position:sticky;
  top:0;
  z-index:60;
  height:var(--topbar-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  background:rgba(2,6,23,0.72);
  color:var(--ink);
  backdrop-filter:blur(14px);
}
:root[data-theme="light"] .topbar{background:rgba(255,255,255,0.85)}

.topbar-left,.topbar-right{display:flex;align-items:center;gap:10px;min-width:0}

.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand-logo{width:36px;height:36px;border-radius:12px;object-fit:cover;border:1px solid var(--border2);box-shadow:var(--shadowSoft)}
.brand-title{font-weight:900;line-height:1}
.brand-subtitle{font-size:12px;color:var(--mut);line-height:1.1}

.crumb{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid var(--border);
  background:rgba(15,23,42,0.40);color:var(--mut);max-width:42vw}
:root[data-theme="light"] .crumb{background:rgba(15,23,42,0.04)}
.crumb-dot{width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 3px rgba(56,189,248,0.16)}
.crumb-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:700;color:var(--ink)}

.topbar-search{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(15,23,42,0.40);
}
:root[data-theme="light"] .topbar-search{background:rgba(15,23,42,0.04)}
.search-ic{color:var(--mut);font-size:13px}
.search-input{border:none !important;outline:none !important;background:transparent !important;padding:0 !important;height:auto !important;min-width:160px;color:var(--ink)}
.search-input::placeholder{color:rgba(148,163,184,0.78)}

.icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(15,23,42,0.40);
  color:var(--ink);
  cursor:pointer;
  transition:transform .08s ease, background .15s ease, border-color .15s ease;
}
:root[data-theme="light"] .icon-btn{background:rgba(15,23,42,0.04)}
.icon-btn:hover{transform:translateY(-1px);border-color:var(--border2)}
.icon-btn:active{transform:translateY(0px)}

.user-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(15,23,42,0.40);
  color:var(--ink);
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:320px;
}
:root[data-theme="light"] .user-pill{background:rgba(15,23,42,0.04)}

/* Cuando no hay sesión, ocultamos cosas de app pero dejamos tema */
body:not(.authed) .topbar-search,
body:not(.authed) .user-pill,
body:not(.authed) .btn.btn-ghost{
  display:none;
}

/* ===== App shell ===== */
.wrap{min-height:calc(100dvh - var(--topbar-h));}
.app-shell{display:grid;grid-template-columns:280px 1fr;gap:14px;padding:14px}

.sidebar{
  width:auto;
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:linear-gradient(180deg, rgba(15,23,42,0.86), rgba(2,6,23,0.70));
  box-shadow:var(--shadowSoft);
  padding:12px;
  overflow:hidden;
}
:root[data-theme="light"] .sidebar{background:linear-gradient(180deg,#fff,#fff)}

.sidebar .sb-brand{display:flex;align-items:center;gap:10px;padding:10px 10px 12px;border-bottom:1px dashed var(--border);margin-bottom:10px}
.sidebar .sb-brand img{width:36px;height:36px;border-radius:12px;object-fit:cover;border:1px solid var(--border2)}
.sidebar .sb-brand .sb-name{font-weight:900;line-height:1}
.sidebar .sb-brand .sb-sub{font-size:12px;color:var(--mut);line-height:1.1}

.sidebar .sb-user{margin-top:10px;padding:10px;border-radius:14px;border:1px solid var(--border);background:rgba(15,23,42,0.40);display:flex;flex-direction:column;gap:4px}
:root[data-theme="light"] .sidebar .sb-user{background:rgba(15,23,42,0.04)}
.sidebar .sb-user .sb-user-name{font-weight:800;font-size:13px}
.sidebar .sb-user .sb-user-meta{font-size:12px;color:var(--mut)}

.sidebar .sb-nav{display:flex;flex-direction:column;gap:6px;margin-top:10px}

.nav-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  color:rgba(226,232,240,0.88);
  border:1px solid transparent;
  background:rgba(15,23,42,0.18);
  transition:transform .08s ease, background .15s ease, border-color .15s ease;
}
:root[data-theme="light"] .nav-item{color:#0b1220;background:rgba(15,23,42,0.03)}

.nav-item:hover{transform:translateY(-1px);background:rgba(56,189,248,0.10);border-color:rgba(56,189,248,0.18)}
.nav-item.active{
  background:linear-gradient(180deg, rgba(56,189,248,0.16), rgba(34,197,94,0.10));
  border-color:rgba(56,189,248,0.26);
}

.nav-ic{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:14px;
  border:1px solid var(--border);
  background:rgba(2,6,23,0.55);
}
:root[data-theme="light"] .nav-ic{background:#fff}
.nav-svg{width:18px;height:18px;fill:currentColor;opacity:0.95}
.nav-label{display:flex;flex-direction:column;gap:2px;min-width:0}
.nav-title{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.15}
.nav-sub{font-size:11px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.nav-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:20px;
  height:20px;
  padding:0 7px;
  border-radius:999px;
  border:1px solid rgba(56,189,248,0.22);
  background:rgba(56,189,248,0.14);
  color:var(--ink);
  font-weight:800;
  font-size:11px;
  margin-left:auto;
}
:root[data-theme="light"] .nav-badge{
  background:rgba(37,99,235,0.12);
  border-color:rgba(37,99,235,0.22);
}

/* Colapsado (desktop) */
.sidebar.collapsed{padding:10px}
.sidebar.collapsed .sb-brand .sb-name,
.sidebar.collapsed .sb-brand .sb-sub,
.sidebar.collapsed .sb-user,
.sidebar.collapsed .nav-label,
.sidebar.collapsed .nav-badge{display:none !important}
.sidebar.collapsed .sb-brand{justify-content:center}
.sidebar.collapsed .sb-brand img{width:40px;height:40px;border-radius:16px}

/* Main */
.main{padding:0}
.content{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:linear-gradient(180deg, rgba(15,23,42,0.55), rgba(2,6,23,0.40));
  box-shadow:var(--shadowSoft);
  padding:14px;
  min-height:calc(100dvh - var(--topbar-h) - 28px);
}
:root[data-theme="light"] .content{background:linear-gradient(180deg,#fff,#fff)}

.view{animation:fadein .18s ease-out 1}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ===== Components ===== */
.card{
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:none;
}

input,select,button,textarea{
  border:1px solid var(--border2);
  background:rgba(2,6,23,0.58);
  color:var(--ink);
}
:root[data-theme="light"] input,
:root[data-theme="light"] select,
:root[data-theme="light"] button,
:root[data-theme="light"] textarea{
  background:#ffffff;
  color:#0b1220;
}
input:focus,select:focus,textarea:focus{
  outline:none;
  box-shadow:0 0 0 3px rgba(56,189,248,0.16);
  border-color:rgba(56,189,248,0.45);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--border2);
  background:rgba(15,23,42,0.50);
  color:var(--ink);
  cursor:pointer;
  transition:transform .08s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform:translateY(-1px);border-color:rgba(56,189,248,0.32)}
.btn:active{transform:translateY(0)}

.btn-primary{
  border-color:rgba(56,189,248,0.35);
  background:linear-gradient(180deg, rgba(56,189,248,0.26), rgba(34,197,94,0.16));
}
:root[data-theme="light"] .btn-primary{background:linear-gradient(180deg, rgba(37,99,235,0.14), rgba(22,163,74,0.10))}

.btn-ghost{
  background:transparent;
  border-color:var(--border);
}

.badge{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(15,23,42,0.40);
  color:rgba(226,232,240,0.92);
  font-size:12px;
}
:root[data-theme="light"] .badge{background:rgba(15,23,42,0.04);color:#0b1220}

.select-pill{height:40px;border-radius:999px;padding:8px 12px}

/* ===== Layout / Page ===== */
.page{display:flex;flex-direction:column;gap:14px}
.page-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;
  padding:8px 2px;
}
.page-head-left{min-width:0}
.page-title{font-size:28px;font-weight:900;letter-spacing:-0.6px;line-height:1.1}
.page-sub{margin-top:6px;color:var(--mut);font-size:13px;line-height:1.35}
.page-head-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.btn-sm{padding:8px 12px;border-radius:12px;font-size:12px}
.select-sm{height:34px;border-radius:12px;padding:6px 10px;font-size:12px}

.section-mini-title{font-size:12px;color:var(--mut);margin:0 0 8px 2px}

/* ===== Navigation groups ===== */
.nav-group{margin:10px 8px 0}
.nav-group-head{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 10px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(15,23,42,0.28);
  color:var(--ink);
  cursor:pointer;
}
:root[data-theme="light"] .nav-group-head{background:rgba(15,23,42,0.03)}
.nav-group-left{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}
.nav-group-title{font-weight:800;font-size:13px;letter-spacing:-0.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-group-hint{font-size:11px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-group-caret{opacity:.8}
.nav-group-items{margin-top:8px;display:flex;flex-direction:column;gap:8px}
.nav-group.is-collapsed .nav-group-items{display:none}
.nav-group.is-collapsed .nav-group-caret{transform:rotate(-90deg)}

/* Nav badge (noticias) */
.nav-badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:20px;height:20px;padding:0 6px;
  border-radius:999px;
  background:rgba(56,189,248,0.20);
  border:1px solid rgba(56,189,248,0.35);
  font-size:12px;font-weight:800;
}

/* ===== KPI Cards ===== */
.kpi-grid{gap:12px}
.kpi2{padding:14px}
.kpi2-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.kpi2-label{font-size:12px;color:var(--mut);font-weight:700}
.kpi2-chip{font-size:11px;color:var(--mut);border:1px solid var(--border);border-radius:999px;padding:6px 10px;background:rgba(2,6,23,0.32)}
:root[data-theme="light"] .kpi2-chip{background:rgba(15,23,42,0.03)}
.kpi2-value{margin-top:10px;font-size:26px;font-weight:900;letter-spacing:-0.6px;line-height:1}
.kpi2-ok{border-color:rgba(34,197,94,0.35);box-shadow:0 0 0 1px rgba(34,197,94,0.10), var(--shadowSoft)}
.kpi2-warn{border-color:rgba(245,158,11,0.35);box-shadow:0 0 0 1px rgba(245,158,11,0.10), var(--shadowSoft)}
.kpi2-muted{border-color:var(--border);}

/* ===== Filter bar ===== */
.filterbar{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 12px;
  border-bottom:1px solid var(--border);
}
.filterbar-left{color:var(--mut);font-size:12px}
.filterbar-right{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

/* ===== Pill ===== */
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;border-radius:999px;
  border:1px solid var(--border);
  font-size:12px;color:var(--ink);
  background:rgba(15,23,42,0.24);
}
:root[data-theme="light"] .pill{background:rgba(15,23,42,0.03)}
.pill-ok{border-color:rgba(34,197,94,0.35);background:rgba(34,197,94,0.10)}
.pill-warn{border-color:rgba(245,158,11,0.35);background:rgba(245,158,11,0.10)}
.pill-danger{border-color:rgba(239,68,68,0.35);background:rgba(239,68,68,0.10)}

/* ===== Dashboard Hero ===== */
.dash-hero{gap:12px}
.hero{background:linear-gradient(180deg, rgba(56,189,248,0.10), rgba(2,6,23,0.30))}
:root[data-theme="light"] .hero{background:linear-gradient(180deg, rgba(37,99,235,0.10), rgba(255,255,255,0.80))}
.hero-wide{grid-column: span 2}
.hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.hero-title{font-size:18px;font-weight:900;letter-spacing:-0.4px}
.hero-sub{margin-top:4px;color:var(--mut);font-size:12px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:12px}

/* Tablas */
.table-responsive{border-radius:var(--radius);border:1px solid var(--border);overflow:auto}
.table-responsive table{min-width:720px}

table{border-collapse:separate;border-spacing:0 6px}
th,td{border-bottom:none}

thead th{
  position:sticky;
  top:0;
  z-index:2;
  background:rgba(2,6,23,0.85);
  color:rgba(226,232,240,0.92);
  border-bottom:1px solid var(--border);
}
:root[data-theme="light"] thead th{background:#f1f5f9;color:#0b1220}

tbody tr{background:rgba(15,23,42,0.35)}
:root[data-theme="light"] tbody tr{background:#ffffff}

tbody tr:hover{background:rgba(56,189,248,0.10)}

tbody td:first-child, thead th:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}

tbody td:last-child, thead th:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}

/* Toast */
.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.toast-msg{flex:1}
.toast-close{
  width:26px;height:26px;border-radius:10px;
  border:1px solid var(--border);
  background:transparent;
  color:var(--ink);
  cursor:pointer;
}
.toast-close:hover{background:rgba(148,163,184,0.12)}

/* ===== Auth (login) ===== */
.auth{padding:18px 14px}
.auth-shell{
  width:min(1080px, 100%);
  margin:10px auto 24px;
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:14px;
}
.auth-hero-card{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:linear-gradient(180deg, rgba(15,23,42,0.62), rgba(2,6,23,0.50));
  box-shadow:var(--shadow);
  padding:22px;
  min-height:360px;
}
:root[data-theme="light"] .auth-hero-card{background:linear-gradient(180deg,#ffffff,#ffffff)}

.auth-hero-logo img{width:54px;height:54px;border-radius:18px;border:1px solid var(--border2);object-fit:cover;box-shadow:var(--shadowSoft)}
.auth-hero-card h1{margin:14px 0 6px;font-size:34px;letter-spacing:-0.6px}
.auth-hero-card p{margin:0;color:var(--mut);line-height:1.5}
.auth-highlights{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.auth-pill{padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(15,23,42,0.40);font-size:12px}
:root[data-theme="light"] .auth-pill{background:rgba(15,23,42,0.04)}
.auth-foot{margin-top:18px;font-size:12px;color:var(--mut)}

.auth-card{padding:18px 18px 16px}
.auth-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.auth-actions{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.auth-session{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.auth-tip{margin-top:14px;padding:12px;border-radius:14px;border:1px dashed var(--border2);background:rgba(15,23,42,0.22);color:var(--mut);font-size:12px;display:flex;align-items:flex-start;gap:10px}
:root[data-theme="light"] .auth-tip{background:rgba(15,23,42,0.03)}
.auth-tip .dot{width:10px;height:10px;border-radius:999px;background:var(--accent);margin-top:3px;box-shadow:0 0 0 4px rgba(56,189,248,0.14)}

/* Responsive */
.desktop-only{display:inline-flex}
.mobile-only{display:none}

.sidebar-backdrop{display:none}

@media (max-width:980px){
  .crumb{display:none}
  .app-shell{grid-template-columns:260px 1fr}
}

@media (max-width:768px){
  .desktop-only{display:none}
  .mobile-only{display:inline-flex}

  .auth-shell{grid-template-columns:1fr}
  .auth-hero{display:none}

  .app-shell{grid-template-columns:1fr;gap:10px;padding:10px}

  .sidebar{
    position:fixed;
    top:calc(var(--topbar-h) + 10px);
    left:10px;
    bottom:10px;
    z-index:80;
    width:min(320px, 84vw);
    transform:translateX(-120%);
    transition:transform .18s ease-out;
  }
  .sidebar.open{transform:translateX(0)}

  .sidebar-backdrop{
    position:fixed;
    inset:0;
    z-index:70;
    background:rgba(2,6,23,0.55);
    backdrop-filter:blur(2px);
    display:none;
  }
  .sidebar-backdrop.show{display:block}

  .content{min-height:calc(100dvh - var(--topbar-h) - 20px)}
  .topbar{height:auto;min-height:var(--topbar-h);flex-wrap:wrap}
  .topbar-search{width:100%}
  .search-input{min-width:0;width:100%}
}
