:root{
  --blue:#1A60AC; --blue-dark:#134d8a; --blue-700:#0f3f72;
  --carbon:#414042; --carbon-900:#2c2b2c;
  --amber:#F7941D; --amber-dark:#d97c08;
  --blue-200:#9BC7EB; --blue-100:#D0E5F4;
  --bg:#EFF3F8; --surface:#FFFFFF; --surface-2:#F7F9FC;
  --border:#E1E7F0; --border-2:#D5DEEA;
  --text:#2A2D34; --text-muted:#6B7280; --text-faint:#9AA3B2;
  --ok:#1E7A45; --okbg:#E7F3EC;
  --warn:#B26A00; --warnbg:#FBEFD9;
  --radius:10px; --shadow:0 1px 3px rgba(20,40,70,.07),0 6px 20px rgba(20,40,70,.05);
  --sidebar:236px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Lato',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:inherit}
.mono-chip{background:#fff;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;
  font-weight:900;letter-spacing:.02em;color:var(--blue);line-height:1}

/* ---------- LOGIN ---------- */
#login{position:fixed;inset:0;background:linear-gradient(135deg,#1A60AC 0%,#0f3f72 100%);
  display:flex;align-items:center;justify-content:center;z-index:50;padding:24px}
#login .panel{background:#fff;border-radius:16px;width:100%;max-width:404px;padding:38px 34px 30px;
  box-shadow:0 24px 60px rgba(8,28,55,.35)}
#login .brandrow{display:flex;align-items:center;gap:12px;margin-bottom:4px}
#login .mono-chip{width:46px;height:46px;font-size:21px;box-shadow:inset 0 0 0 1px #e6eef7}
#login h1{font-size:18px;font-weight:900;color:var(--carbon);line-height:1.15}
#login .descr{font-size:11px;color:var(--blue);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-top:1px}
#login .lede{color:var(--text-muted);font-size:13px;margin:20px 0 18px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12px;font-weight:700;color:var(--carbon);margin-bottom:5px}
.field input{width:100%;padding:10px 12px;border:1px solid var(--border-2);border-radius:8px;font-size:14px;background:var(--surface-2)}
.field input:focus{outline:none;border-color:var(--blue);background:#fff}
.demo-note{font-size:11.5px;color:var(--text-faint);text-align:center;margin:8px 0 14px}
.role-pick{display:grid;gap:8px}
.role-btn{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:11px 13px;border:1px solid var(--border-2);
  border-radius:9px;background:#fff;transition:.12s}
.role-btn:hover{border-color:var(--blue);background:#F5F9FE;transform:translateY(-1px)}
.role-btn .rb-ic{width:30px;height:30px;border-radius:7px;background:var(--blue-100);color:var(--blue-700);
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.role-btn .rb-t{font-weight:700;font-size:13px;color:var(--carbon)}
.role-btn .rb-s{font-size:11.5px;color:var(--text-muted)}
.login-foot{text-align:center;font-size:10.5px;color:var(--text-faint);margin-top:18px}

/* ---------- SHELL ---------- */
#app{display:none;min-height:100vh}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar);background:var(--carbon-900);
  color:#cfd2d7;display:flex;flex-direction:column;z-index:30}
.sb-brand{padding:17px 18px 15px;display:flex;align-items:center;gap:11px;border-bottom:1px solid rgba(255,255,255,.08)}
.sb-brand .mono-chip{width:38px;height:38px;font-size:17px}
.sb-brand .bt{font-size:13.5px;font-weight:900;color:#fff;line-height:1.1}
.sb-brand .bs{font-size:9px;color:var(--blue-200);font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-top:2px}
.sb-nav{flex:1;overflow-y:auto;padding:10px 10px 16px}
.sb-group{margin-top:14px}
.sb-group:first-child{margin-top:4px}
.sb-glabel{font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#7f838c;padding:0 9px 5px}
.sb-item{display:flex;align-items:center;gap:10px;padding:8px 9px;border-radius:7px;font-size:13px;color:#c4c8cf;
  width:100%;text-align:left;border-left:2.5px solid transparent;transition:.1s;position:relative}
.sb-item:hover{background:rgba(255,255,255,.06);color:#fff}
.sb-item.active{background:rgba(26,96,172,.22);color:#fff;border-left-color:var(--amber)}
.sb-item .ic{width:17px;height:17px;flex-shrink:0;opacity:.85}
.sb-item .ph{margin-left:auto;font-size:9px;font-weight:700;color:#8b8f98;background:rgba(255,255,255,.07);
  padding:1px 6px;border-radius:20px}
.sb-item.active .ph{color:var(--amber);background:rgba(247,148,29,.14)}
.sb-foot{padding:11px 16px;border-top:1px solid rgba(255,255,255,.08);font-size:10px;color:#7f838c}

.main{margin-left:var(--sidebar);min-height:100vh;display:flex;flex-direction:column}
.topbar{height:58px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;
  padding:0 26px;gap:16px;position:sticky;top:0;z-index:20}
.tb-title{font-size:16px;font-weight:900;color:var(--carbon)}
.tb-sub{font-size:12px;color:var(--text-muted);font-weight:400;margin-left:2px}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.role-switch{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-muted)}
.role-switch select{font-family:inherit;font-size:12.5px;font-weight:700;color:var(--carbon);padding:6px 9px;
  border:1px solid var(--border-2);border-radius:7px;background:var(--surface-2)}
.role-switch select:focus{outline:none;border-color:var(--blue)}
.user-chip{display:flex;align-items:center;gap:9px}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;font-size:13px;
  display:flex;align-items:center;justify-content:center}
.user-chip .un{font-size:12.5px;font-weight:700;color:var(--carbon);line-height:1.1}
.user-chip .ur{font-size:10.5px;color:var(--text-muted)}
.logout{font-size:11.5px;color:var(--text-muted);padding:6px 10px;border:1px solid var(--border-2);border-radius:7px}
.logout:hover{border-color:var(--blue);color:var(--blue)}
.content{padding:24px 26px 40px;flex:1}

/* role banner */
.rolebanner{display:flex;align-items:center;gap:9px;background:var(--warnbg);border:1px solid #f0dcb0;
  color:var(--warn);font-size:12.5px;padding:9px 13px;border-radius:9px;margin-bottom:18px}
.rolebanner svg{flex-shrink:0}

/* page header */
.pagehead{margin-bottom:18px}
.pagehead h2{font-size:20px;font-weight:900;color:var(--carbon)}
.pagehead .ph-sub{color:var(--text-muted);font-size:13px;margin-top:2px}
.spine-tag{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;color:var(--amber-dark);
  background:#FDF1DD;border:1px solid #f6dcae;padding:2px 9px;border-radius:20px;vertical-align:middle;margin-left:8px}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:13px;margin-bottom:20px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 15px;box-shadow:var(--shadow)}
.kpi .k-l{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}
.kpi .k-v{font-size:23px;font-weight:900;color:var(--carbon);margin-top:6px;line-height:1}
.kpi .k-s{font-size:11px;color:var(--text-faint);margin-top:5px}
.kpi.accent{border-top:3px solid var(--amber)}
.kpi.blue{border-top:3px solid var(--blue)}

/* cards grid */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-h{padding:13px 16px 0;font-size:13.5px;font-weight:900;color:var(--carbon);display:flex;align-items:center;justify-content:space-between}
.card-h .ch-s{font-size:11px;font-weight:400;color:var(--text-muted)}
.card-b{padding:14px 16px 16px}

/* bars */
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.bar-row:last-child{margin-bottom:0}
.bar-lab{width:118px;font-size:12px;color:var(--carbon);font-weight:700;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:20px;background:var(--surface-2);border-radius:5px;overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:5px;transition:width .6s cubic-bezier(.2,.7,.3,1)}
.bar-val{width:104px;text-align:right;font-size:12px;font-weight:700;color:var(--carbon);flex-shrink:0}
.bar-cnt{font-size:11px;color:var(--text-faint);font-weight:400}

/* concentration */
.conc{display:flex;align-items:center;gap:16px}
.donut{width:108px;height:108px;flex-shrink:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;position:relative}
.donut .hole{width:74px;height:74px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut .hole b{font-size:21px;font-weight:900;color:var(--carbon);line-height:1}
.donut .hole span{font-size:9.5px;color:var(--text-muted);margin-top:2px}
.conc-list{flex:1}
.conc-list .cl{display:flex;justify-content:space-between;font-size:12px;padding:4px 0;border-bottom:1px dashed var(--border)}
.conc-list .cl:last-child{border-bottom:none}
.conc-list .cl b{font-weight:700;color:var(--carbon)}
.conc-list .cl span{color:var(--text-muted)}

/* table */
.tablecard{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.toolbar{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.toolbar .srch{flex:1;min-width:180px;position:relative}
.toolbar .srch input{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--border-2);border-radius:8px;font-size:13px;background:var(--surface-2)}
.toolbar .srch input:focus{outline:none;border-color:var(--blue);background:#fff}
.toolbar .srch svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-faint)}
.seg-chips{display:flex;gap:6px}
.chip{font-size:11.5px;font-weight:700;padding:6px 11px;border-radius:20px;border:1px solid var(--border-2);
  color:var(--text-muted);background:#fff;transition:.1s}
.chip:hover{border-color:var(--blue)}
.chip.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.toolbar select{font-family:inherit;font-size:12.5px;padding:7px 9px;border:1px solid var(--border-2);border-radius:8px;background:#fff;color:var(--carbon)}
table{width:100%;border-collapse:collapse}
thead th{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:700;
  text-align:left;padding:10px 16px;background:var(--surface-2);border-bottom:1px solid var(--border)}
thead th.num{text-align:right}
tbody td{padding:11px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text)}
tbody td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:700}
tbody tr{cursor:pointer;transition:.08s}
tbody tr:hover{background:#F5F9FE}
tbody tr:last-child td{border-bottom:none}
.cli-name{font-weight:700;color:var(--carbon)}
.cli-sub{font-size:11px;color:var(--text-faint);font-weight:400}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:5px}
.b-A{background:#FDF1DD;color:var(--amber-dark)}
.b-B{background:#E3EEF9;color:var(--blue-700)}
.b-C{background:#EDF1F6;color:#5b6675}
.st{font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px}
.st-activo{background:var(--okbg);color:var(--ok)}
.st-suspendido{background:#FBEAEA;color:#A23A3A}
.tick{color:var(--ok);font-weight:700}
.dash{color:var(--text-faint)}
.tablefoot{padding:10px 16px;font-size:11.5px;color:var(--text-muted);background:var(--surface-2)}

/* drawer */
.drawer-bg{position:fixed;inset:0;background:rgba(20,35,60,.34);z-index:40;opacity:0;pointer-events:none;transition:.18s}
.drawer-bg.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:430px;max-width:92vw;background:#fff;z-index:41;
  transform:translateX(100%);transition:.22s cubic-bezier(.3,.8,.3,1);overflow-y:auto;box-shadow:-12px 0 40px rgba(8,28,55,.18)}
.drawer.open{transform:translateX(0)}
.dr-head{padding:20px 22px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff}
.dr-head .dr-x{position:absolute;top:16px;right:18px;width:30px;height:30px;border-radius:7px;color:var(--text-muted);
  display:flex;align-items:center;justify-content:center}
.dr-head .dr-x:hover{background:var(--surface-2)}
.dr-head h3{font-size:17px;font-weight:900;color:var(--carbon);padding-right:34px;line-height:1.2}
.dr-head .dr-meta{display:flex;gap:8px;margin-top:9px;align-items:center}
.dr-body{padding:18px 22px 30px}
.dr-sec{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);
  margin:20px 0 9px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.dr-sec:first-child{margin-top:0}
.dr-row{display:flex;justify-content:space-between;gap:14px;padding:7px 0;font-size:13px}
.dr-row .dl{color:var(--text-muted);flex-shrink:0}
.dr-row .dv{color:var(--carbon);font-weight:700;text-align:right}
.dr-row .dv.todo{color:var(--amber-dark);background:#FDF1DD;font-size:11px;padding:1px 8px;border-radius:5px;font-weight:700}
.dr-empty{font-size:12.5px;color:var(--text-faint);background:var(--surface-2);border:1px dashed var(--border-2);
  border-radius:8px;padding:12px;text-align:center}
.dr-empty b{color:var(--text-muted)}

/* placeholder module */
.ph-wrap{max-width:680px;margin:30px auto;text-align:center;padding:40px 30px;background:#fff;border:1px solid var(--border);
  border-radius:14px;box-shadow:var(--shadow)}
.ph-ic{width:62px;height:62px;border-radius:15px;background:var(--blue-100);color:var(--blue-700);
  display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}
.ph-wrap h2{font-size:22px;font-weight:900;color:var(--carbon)}
.ph-badge{display:inline-block;font-size:11px;font-weight:700;color:var(--amber-dark);background:#FDF1DD;
  border:1px solid #f6dcae;padding:3px 11px;border-radius:20px;margin:10px 0 14px}
.ph-desc{color:var(--text-muted);font-size:14px;max-width:480px;margin:0 auto 18px;line-height:1.6}
.ph-src{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--carbon);background:var(--surface-2);
  border:1px solid var(--border);border-radius:9px;padding:9px 15px}
.ph-src b{color:var(--blue)}
.noaccess{max-width:460px;margin:60px auto;text-align:center;padding:36px;background:#fff;border:1px solid var(--border);border-radius:14px}
.noaccess .ph-ic{background:#FBEAEA;color:#A23A3A}

@media (max-width:920px){
  .kpis{grid-template-columns:repeat(2,1fr)} .grid2{grid-template-columns:1fr}
  .sidebar{transform:translateX(-100%);transition:.2s} .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
}


/* ---------- Login real: error + cambio de clave ---------- */
.login-err{background:#FBEAEA;color:#A23A3A;border:1px solid #f0c9c9;font-size:12.5px;
  padding:9px 12px;border-radius:8px;margin:0 0 12px;display:none}
.login-err.show{display:block}
#login .btn-primary{width:100%;padding:11px;background:var(--blue);color:#fff;font-weight:700;font-size:14px;
  border-radius:8px;transition:.12s;margin-top:4px}
#login .btn-primary:hover{background:var(--blue-dark)}
#login .btn-primary:disabled{opacity:.6;cursor:default}
.login-hint{font-size:11px;color:var(--text-faint);text-align:center;margin-top:14px}
#cambio{position:fixed;inset:0;background:linear-gradient(135deg,#1A60AC 0%,#0f3f72 100%);
  display:none;align-items:center;justify-content:center;z-index:55;padding:24px}
#cambio.show{display:flex}
#cambio .panel{background:#fff;border-radius:16px;width:100%;max-width:404px;padding:34px 32px;
  box-shadow:0 24px 60px rgba(8,28,55,.35)}
#cambio h1{font-size:18px;font-weight:900;color:var(--carbon);margin-bottom:4px}
#cambio p.sub{font-size:13px;color:var(--text-muted);margin-bottom:18px}
