: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; }

