:root{
  --bg:#081320; --bg2:#0c1d30; --panel:#0f2438; --panel2:#13314a;
  --line:#1d3a54; --line-soft:#16314880;
  --ink:#e8f1f8; --ink-soft:#9fb8cc; --mute:#5f7e98;
  --signal:#1fb6c9; --signal-dim:#15808f; --signal-glow:#1fb6c955;
  --safe:#2ed47a; --amber:#f0a93c; --alert:#ef5a52; --violet:#8b9cf0;
  --grad:linear-gradient(135deg,#1fb6c9,#1786c4);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);
  line-height:1.45;-webkit-font-smoothing:antialiased;letter-spacing:.1px}
.mono{font-family:'SF Mono',ui-monospace,'Cascadia Code','Consolas',monospace;font-variant-numeric:tabular-nums}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 var(--signal-glow)}50%{opacity:.5;box-shadow:0 0 0 5px transparent}}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes scan{from{background-position:0 0}to{background-position:0 -28px}}
.live{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--safe);animation:pulse 2s infinite}

/* ===== LOGIN ===== */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden;background:transparent}
.login-card{position:relative;background:linear-gradient(180deg,#0f2740,#0c1f33);border:1px solid var(--line);
  border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.55);width:100%;max-width:410px;padding:38px 36px;animation:rise .55s ease}
.lc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mk{width:42px;height:42px;border-radius:11px;background:var(--grad);display:grid;place-items:center;
  box-shadow:0 6px 20px var(--signal-glow);position:relative;flex-shrink:0}
.brand .mk svg{width:24px;height:24px}
.brand .nm{font-size:15px;font-weight:800;letter-spacing:.5px;line-height:1.1}
.brand .nm small{display:block;font-size:10.5px;font-weight:500;color:var(--signal);letter-spacing:2px;margin-top:1px}
.status-pill{display:flex;align-items:center;gap:7px;font-size:10.5px;color:var(--ink-soft);
  border:1px solid var(--line);padding:5px 10px;border-radius:20px;background:#0a1c2e}
.login-card h2{font-size:19px;font-weight:700;letter-spacing:-.3px;margin-bottom:5px}
.login-card .sub{color:var(--mute);font-size:13px;margin-bottom:26px}
.field{margin-bottom:14px}
.field label{display:block;font-size:10.5px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;text-transform:uppercase;letter-spacing:1px}
.field input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:14px;
  background:#0a1b2c;color:var(--ink);transition:.15s}
.field input::placeholder{color:#456}
.field input:focus{outline:none;border-color:var(--signal);box-shadow:0 0 0 3px var(--signal-glow)}
.btn{width:100%;padding:13px;border:none;border-radius:10px;background:var(--grad);color:#02141a;
  font-size:14px;font-weight:800;letter-spacing:.3px;cursor:pointer;transition:.15s;margin-top:8px}
.btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.err{color:var(--alert);font-size:12.5px;margin-top:10px;min-height:15px;font-weight:600}
.hint{margin-top:22px;padding:14px;background:#0a1c2e;border:1px solid var(--line);border-radius:10px;font-size:11.5px;color:var(--ink-soft)}
.hint b{color:var(--signal);text-transform:uppercase;letter-spacing:1px;font-size:10.5px}
.hint .row{display:flex;justify-content:space-between;margin-top:7px}
.hint code{font-family:'SF Mono',monospace;background:#0f2740;padding:1px 7px;border-radius:5px;border:1px solid var(--line);color:var(--ink)}

/* ===== APP ===== */
#app{display:none}
.topbar{background:linear-gradient(180deg,#0c2034,#0a1929);border-bottom:1px solid var(--line);
  padding:0 22px;height:62px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:60;backdrop-filter:blur(8px)}
.tb-left{display:flex;align-items:center;gap:13px}
.tb-left .mk{width:34px;height:34px;border-radius:9px;background:var(--grad);display:grid;place-items:center}
.tb-left .mk svg{width:19px;height:19px}
.tb-left .nm{font-size:13.5px;font-weight:800;letter-spacing:.4px;line-height:1.15}
.tb-left .nm small{display:block;font-size:9.5px;color:var(--signal);letter-spacing:1.5px;font-weight:500}
.tb-right{display:flex;align-items:center;gap:13px;font-size:13px}
.tb-status{display:flex;align-items:center;gap:7px;font-size:10.5px;color:var(--ink-soft);
  border:1px solid var(--line);padding:5px 11px;border-radius:20px}
.who{color:var(--ink-soft);font-size:12.5px}
.chip{padding:5px 12px;border-radius:7px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px}
.chip.admin{background:#f0a93c22;color:var(--amber);border:1px solid #f0a93c44}
.chip.supervisor{background:#1fb6c922;color:var(--signal);border:1px solid #1fb6c944}
.chip.cliente{background:#2ed47a22;color:var(--safe);border:1px solid #2ed47a44}
.logout{background:none;border:1px solid var(--line);color:var(--ink-soft);padding:6px 13px;border-radius:8px;cursor:pointer;font-size:12px;transition:.15s}
.logout:hover{border-color:var(--alert);color:var(--alert)}

.wrap{max-width:1240px;margin:0 auto;padding:26px 22px 70px}
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.pagehead h2{font-size:24px;font-weight:800;letter-spacing:-.5px}
.pagehead .ey{font-size:10.5px;font-weight:700;color:var(--signal);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:5px}
.pagehead p{color:var(--mute);font-size:13px;margin-top:3px}
.range-label{display:inline-flex;align-items:center;gap:7px;margin-top:9px;font-size:12px;color:var(--ink-soft);
  background:#0f2740;border:1px solid var(--line);padding:6px 12px;border-radius:8px}
.range-label b{color:var(--signal)}
.report-tag{font-size:11px;color:var(--ink-soft);border:1px solid var(--line);padding:7px 13px;border-radius:9px;background:var(--panel)}
.report-tag b{color:var(--signal)}
.datebar{display:flex;flex-direction:column;gap:9px;align-items:flex-end}
.date-presets{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.date-btn{padding:7px 13px;border:1px solid var(--line);background:var(--panel);color:var(--ink-soft);
  border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;transition:.15s;white-space:nowrap}
.date-btn:hover{border-color:var(--signal);color:var(--ink)}
.date-btn.on{background:var(--grad);color:#02141a;border-color:transparent;font-weight:800}
.date-range{display:flex;align-items:center;gap:8px}
.date-inp{padding:6px 10px;border:1px solid var(--line);background:#0a1b2c;color:var(--ink);
  border-radius:8px;font-size:12px;font-family:inherit;color-scheme:dark}
.date-inp:focus{outline:none;border-color:var(--signal);box-shadow:0 0 0 3px var(--signal-glow)}
.date-sep{color:var(--mute);font-size:13px}

/* KPI as control readouts */
.kpis{display:grid;gap:14px;margin-bottom:24px}
.alert-panel{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;position:relative;padding-top:34px}
.ap-head{position:absolute;top:0;left:0;display:flex;align-items:center;gap:8px;font-size:11.5px;
  font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:1px}
.ap-card{background:linear-gradient(180deg,#16202e,#111c29);border:1px solid var(--line);border-radius:13px;
  padding:16px 18px;cursor:pointer;transition:.15s;position:relative;overflow:hidden}
.ap-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.ap-bad::before{background:var(--alert)}.ap-warn::before{background:var(--amber)}.ap-ok::before{background:var(--safe)}
.ap-card:hover{transform:translateY(-2px);border-color:var(--signal)}
.ap-on{border-color:var(--signal);box-shadow:0 0 0 2px var(--signal-glow)}
.ap-v{font-size:30px;font-weight:800;font-family:'SF Mono',monospace;letter-spacing:-1px;line-height:1}
.ap-bad .ap-v{color:var(--alert)}.ap-warn .ap-v{color:var(--amber)}.ap-ok .ap-v{color:var(--safe)}
.ap-l{font-size:13px;font-weight:700;color:var(--ink);margin-top:7px}
.ap-s{font-size:11px;color:var(--mute);margin-top:2px}
.ap-note{grid-column:1/-1;font-size:11px;color:var(--ink-soft);background:#0a1b2c;border:1px solid var(--line-soft);
  border-radius:9px;padding:9px 13px;line-height:1.5}
.ap-note b{color:var(--signal);font-family:'SF Mono',monospace}
.mon-note{margin-top:10px;padding:9px 13px;background:#0a1b2c;border:1px solid var(--line-soft);border-radius:9px;font-size:11px;color:var(--ink-soft);line-height:1.5}
.mon-note b{color:var(--ink)}
.am-seg{margin-bottom:16px}
.am-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.am-lbl{font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:7px}
.am-dot{width:10px;height:10px;border-radius:3px}
.am-n{font-family:'SF Mono',monospace;font-weight:800;font-size:15px;color:var(--ink)}
.am-n small{color:var(--mute);font-weight:600;font-size:12px}
.am-bar{height:10px;background:#0a1b2c;border-radius:5px;overflow:hidden;margin-bottom:5px}
.am-fill{height:100%;border-radius:5px;transition:width .9s cubic-bezier(.2,.8,.2,1)}
.am-tz{font-size:11.5px;color:var(--ink-soft)}
.am-note{margin-top:6px;padding:9px 12px;background:#0a1b2c;border:1px solid var(--line-soft);border-radius:8px;font-size:11px;color:var(--ink-soft);line-height:1.5}
.bt-leg{display:inline-flex;flex-wrap:wrap;gap:4px 10px;align-items:center;margin-top:6px}
.bt-leg-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:3px;vertical-align:middle}
.seal-big{padding:20px;border-radius:11px;text-align:center;border:1px solid var(--line);background:#0c1f33;transition:.15s}
.seal-warn{border-left:4px solid var(--amber)}.seal-ok{border-left:4px solid var(--safe)}
.seal-big[onclick]:hover{border-color:var(--signal);background:#10283e}
.seal-v{font-size:42px;font-weight:800;font-family:'SF Mono',monospace;letter-spacing:-2px;color:var(--amber)}
.seal-ok .seal-v{color:var(--safe)}
.seal-l{font-size:12.5px;color:var(--ink-soft);margin-top:4px}
.seal-go{font-size:12px;color:var(--signal);font-weight:700;margin-top:10px}
.mon-row{display:flex;align-items:center;gap:14px;padding:11px 13px;border:1px solid var(--line);border-radius:10px;
  margin-bottom:9px;cursor:pointer;transition:.15s;background:#0c1f33}
.mon-row:hover{border-color:var(--signal);background:#10283e}
.mon-on{border-color:var(--signal);box-shadow:0 0 0 2px var(--signal-glow)}
.mon-eff{flex-shrink:0;width:62px;height:54px;border:1.5px solid;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-family:'SF Mono',monospace;font-size:22px;font-weight:800;letter-spacing:-1px}
.mon-eff small{font-size:11px;font-weight:600;margin-left:1px}
.mon-mid{flex:1;min-width:0}
.mon-name{font-size:13.5px;font-weight:700;color:var(--ink)}
.mon-meta{font-size:11.5px;color:var(--ink-soft);margin:3px 0 6px}
.mon-track{height:6px;background:#0a1b2c;border-radius:4px;overflow:hidden}
.mon-fill{height:100%;border-radius:4px;transition:width .9s cubic-bezier(.2,.8,.2,1)}
.mon-go{flex-shrink:0;font-size:12px;color:var(--signal);font-weight:700}
.manual-tag{display:inline-block;padding:1px 7px;border-radius:5px;font-size:9.5px;font-weight:800;
  background:#f0a93c22;color:var(--amber);border:1px solid #f0a93c44;letter-spacing:.5px}
.cb-u{font-size:11.5px;color:var(--ink-soft)}
.cb-auto{font-size:11px;color:var(--mute);font-style:italic}
.code-row{display:flex;align-items:center;gap:14px;padding:12px 13px;border:1px solid var(--line);border-radius:10px;
  margin-bottom:9px;cursor:pointer;transition:.15s;background:#0c1f33}
.code-row:hover{border-color:var(--signal);background:#10283e}
.code-on{border-color:var(--signal);box-shadow:0 0 0 2px var(--signal-glow)}
.code-tag{font-family:'SF Mono',monospace;font-weight:800;font-size:13px;color:var(--amber);background:#f0a93c1a;
  border:1px solid #f0a93c44;border-radius:7px;padding:7px 11px;flex-shrink:0;min-width:64px;text-align:center}
.code-info{flex:1;min-width:0}
.code-t{font-size:13px;font-weight:700;color:var(--ink)}
.code-n{color:var(--mute);font-weight:600;font-size:12px}
.code-a{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
.code-go{font-size:12px;color:var(--signal);font-weight:700;flex-shrink:0}
.code-pill{display:inline-block;font-family:'SF Mono',monospace;font-size:10px;font-weight:800;color:var(--amber);
  background:#f0a93c1a;border:1px solid #f0a93c44;border-radius:5px;padding:1px 6px;cursor:help}
.kpis-4{grid-template-columns:repeat(4,1fr)}
.kpis-3{grid-template-columns:repeat(3,1fr)}
.kpi{position:relative;background:linear-gradient(180deg,var(--panel),#0c1f33);border:1px solid var(--line);
  border-radius:13px;padding:17px 18px;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--signal)}
.kpi.good::before{background:var(--safe)}.kpi.warn::before{background:var(--amber)}.kpi.bad::before{background:var(--alert)}
.kpi .lab{font-size:10.5px;font-weight:700;color:var(--mute);text-transform:uppercase;letter-spacing:1px}
.kpi .val{font-size:31px;font-weight:800;letter-spacing:-1px;margin-top:8px;font-variant-numeric:tabular-nums;font-family:'SF Mono',monospace}
.kpi .meta{font-size:11.5px;color:var(--ink-soft);margin-top:4px}
.kpi.good .val{color:var(--safe)}.kpi.warn .val{color:var(--amber)}.kpi.bad .val{color:var(--alert)}

.grid2{display:grid;grid-template-columns:1.12fr .88fr;gap:16px;margin-bottom:16px}
.card{background:linear-gradient(180deg,var(--panel),#0c1f33);border:1px solid var(--line);border-radius:13px;padding:20px}
.card-h{display:flex;align-items:center;gap:9px;margin-bottom:3px}
.card-h h3{font-size:13.5px;font-weight:700;letter-spacing:.2px}
.card-h .ic{width:7px;height:7px;border-radius:2px;background:var(--signal)}
.card .csub{font-size:11.5px;color:var(--mute);margin-bottom:17px}

.bar-row{display:flex;align-items:center;gap:11px;margin-bottom:10px}
.inc-clk{cursor:pointer;border-radius:7px;padding:3px 5px;margin-left:-5px;margin-right:-5px;transition:background .15s}
.inc-clk:hover{background:#13314a}
.inc-active{background:#15384f}
.inc-active .nm{color:var(--signal);font-weight:700}
.filter-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:11px 20px;background:#13314a;border-bottom:1px solid var(--line);flex-wrap:wrap}
.co-legend{display:flex;flex-wrap:wrap;gap:8px 18px;padding:10px 13px;margin-bottom:14px;
  background:#0a1b2c;border:1px solid var(--line-soft);border-radius:9px;font-size:11px;color:var(--mute)}
.lg-it{display:inline-flex;align-items:center;gap:6px}
.lg-it b{color:var(--ink-soft);font-weight:700}
.lg-bar{display:inline-block;width:22px;height:9px;border-radius:3px;background:linear-gradient(90deg,var(--signal),#1786c4)}
.lg-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin:0 1px 0 4px}
.lg-hint{color:#456}
.co-example{margin-bottom:14px;padding:9px 13px;background:#0f2740;border-left:3px solid var(--signal);
  border-radius:0 8px 8px 0;font-size:11.5px;color:var(--ink-soft)}
.co-example b{color:var(--signal);font-family:'SF Mono',monospace}
.co-more{margin-top:8px;width:100%;padding:9px;background:#0a1b2c;border:1px solid var(--line);
  color:var(--signal);border-radius:8px;cursor:pointer;font-size:12px;font-weight:700;letter-spacing:.3px;transition:.15s}
.co-more:hover{background:#13314a;border-color:var(--signal)}
.co-scroll{max-height:340px;overflow-y:auto;padding-right:6px}
.co-scroll::-webkit-scrollbar{width:7px}.co-scroll::-webkit-scrollbar-thumb{background:#1d3a54;border-radius:4px}
.fb-txt{font-size:12.5px;color:var(--ink-soft)}.fb-txt b{color:var(--signal)}
.fb-clear{background:none;border:1px solid var(--line);color:var(--ink-soft);padding:5px 11px;
  border-radius:7px;cursor:pointer;font-size:11.5px;transition:.15s}
.fb-clear:hover{border-color:var(--alert);color:var(--alert)}
.bar-row .nm{width:34%;font-size:12px;color:var(--ink-soft);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;background:#0a1b2c;border:1px solid var(--line-soft);border-radius:6px;height:24px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px 0 0 5px;min-width:3px;transition:width 1s cubic-bezier(.2,.8,.2,1)}
.bar-val{width:74px;flex-shrink:0;font-size:12px;font-family:'SF Mono',monospace;color:var(--ink-soft);text-align:left;white-space:nowrap}
.bar-val b{color:var(--ink);font-weight:700}

.donut-wrap{display:flex;align-items:center;gap:20px}
.donut{width:148px;height:148px;flex-shrink:0}
.legend{flex:1}
.leg-item{display:flex;align-items:center;gap:9px;margin-bottom:10px;font-size:12.5px;color:var(--ink-soft)}
.leg-item .sw{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.leg-item .lc{margin-left:auto;font-weight:800;font-family:'SF Mono',monospace;color:var(--ink)}

.tablecard{background:linear-gradient(180deg,var(--panel),#0c1f33);border:1px solid var(--line);border-radius:13px;overflow:hidden}
.tablecard .th{padding:18px 20px 15px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:11px;border-bottom:1px solid var(--line)}
.tablecard .th h3{font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:9px}
.search{padding:9px 13px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#0a1b2c;color:var(--ink);min-width:230px}
.search::placeholder{color:#456}
.search:focus{outline:none;border-color:var(--signal);box-shadow:0 0 0 3px var(--signal-glow)}
.tbl-scroll{overflow:auto;max-height:480px}
table{width:100%;border-collapse:collapse;font-size:12px}
thead th{position:sticky;top:0;background:#0d2236;text-align:left;padding:11px 14px;font-weight:700;color:var(--ink-soft);
  font-size:10px;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;z-index:2;border-bottom:1px solid var(--line)}
tbody td{padding:10px 14px;border-top:1px solid var(--line-soft);white-space:nowrap;color:var(--ink-soft)}
tbody tr:hover{background:#10283e}
.tag{display:inline-block;padding:2px 10px;border-radius:20px;font-size:10.5px;font-weight:800}
.tag.yes{background:#2ed47a1c;color:var(--safe);border:1px solid #2ed47a3a}
.tag.no{background:#ef5a521c;color:var(--alert);border:1px solid #ef5a523a}
.ds{display:inline-flex;align-items:center;gap:6px;font-size:11.5px}
.ds .d{width:7px;height:7px;border-radius:50%}
.ds.normal .d{background:var(--safe)}.ds.security .d{background:var(--alert)}
.ds.corridor .d{background:var(--amber)}.ds.departure .d{background:var(--signal)}
.rmk{display:inline-block;padding:2px 9px;border-radius:6px;font-size:10px;font-weight:700;background:#f0a93c1c;color:var(--amber);border:1px solid #f0a93c33}
.bt-cell{font-weight:700;font-family:'SF Mono',monospace}.bt-low{color:var(--alert)}.bt-mid{color:var(--amber)}.bt-ok{color:var(--ink-soft)}
.empty{padding:48px 20px;text-align:center;color:var(--mute);font-size:13px}
.foot{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--mute);font-size:11px;margin-top:28px;text-align:center;flex-wrap:wrap}
.foot b{color:var(--ink-soft)}

/* ===== RESPONSIVE ===== */
html,body{overflow-x:hidden}

@media(max-width:1100px){
  .alert-panel{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:860px){
  .kpis{grid-template-columns:1fr 1fr}
  .grid2{grid-template-columns:1fr}
  .alert-panel{grid-template-columns:1fr 1fr}
  .datebar{align-items:stretch}
  .date-presets{justify-content:flex-start}
  .bar-row .nm{width:30%}
  .bar-val{width:62px}
  .tb-status{display:none}
}

@media(max-width:640px){
  .topbar{height:auto;min-height:56px;padding:10px 14px;flex-wrap:wrap;gap:8px}
  .tb-left{flex:1;min-width:0}
  .tb-left .nm small{display:none}
  .tb-right{width:100%;gap:6px;flex-wrap:wrap;justify-content:flex-end}
  .who{display:none}
  .chip{display:none}
  .logout{padding:5px 10px;font-size:11px}
  .wrap{padding:16px 12px 60px}
  .pagehead{flex-direction:column;align-items:flex-start;gap:10px}
  .pagehead h2{font-size:21px}
  .datebar{width:100%}
  .date-range{flex-wrap:wrap;gap:6px}
  .date-inp{flex:1;min-width:110px}
  .date-sep{display:none}
  .tablecard .th{flex-direction:column;align-items:flex-start}
  .search{min-width:0;width:100%}
  .filter-bar{flex-direction:column;align-items:flex-start}
  #auditModal{padding:16px 10px}
}

@media(max-width:480px){
  .login-card{padding:26px 18px}
  .kpis{grid-template-columns:1fr 1fr}
  .kpi{padding:14px 13px}
  .kpi .val{font-size:24px}
  .kpi .lab{font-size:9.5px}
  .alert-panel{grid-template-columns:1fr}
  .ap-v{font-size:24px}
  .grid2{grid-template-columns:1fr}
  .donut-wrap{flex-direction:column;align-items:center;gap:14px}
  .donut{width:130px;height:130px}
  .co-legend{display:none}
  .co-example{display:none}
  .bar-row .nm{width:26%;font-size:11px}
  .bar-val{width:52px;font-size:11px}
  .mon-eff{width:50px;height:44px;font-size:18px}
  .card{padding:16px 14px}
  .tbl-scroll{max-height:360px}
  tbody td{padding:9px 10px;font-size:11.5px}
  thead th{padding:9px 10px}
}

@media(max-width:360px){
  .kpis{grid-template-columns:1fr}
  .logout{padding:4px 8px;font-size:10.5px}
}

/* ===== CARGA DE EXCEL ===== */
#uploadSection{margin-top:24px}
.upload-body{padding:4px 0}
.upload-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;margin-bottom:16px}
.upload-field label{display:block;font-size:10.5px;font-weight:700;color:var(--ink-soft);margin-bottom:6px;text-transform:uppercase;letter-spacing:1px}
.upload-field input[type=date]{padding:10px 13px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#0a1b2c;color:var(--ink);font-family:inherit;color-scheme:dark}
.upload-field input[type=date]:focus{outline:none;border-color:var(--signal);box-shadow:0 0 0 3px var(--signal-glow)}
.drop-zone{border:2px dashed var(--line);border-radius:11px;padding:28px 20px;text-align:center;cursor:pointer;transition:.15s;color:var(--ink-soft);font-size:13px;position:relative;background:#0a1b2c08}
.drop-zone:hover{border-color:var(--signal);color:var(--ink)}
.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.drop-zone .dz-ico{font-size:28px;margin-bottom:8px;opacity:.5}
.drop-zone span{color:var(--signal);font-weight:700}
.upload-preview{margin-top:14px;padding:13px 16px;background:#0f2438;border:1px solid var(--line);border-radius:9px;font-size:12.5px;color:var(--ink-soft)}
.upload-preview b{color:var(--ink)}
.upload-msg{margin-top:12px;font-size:13px;font-weight:600;min-height:18px;padding:10px 14px;border-radius:9px;display:none}
.upload-msg.info{display:block;color:var(--signal);background:var(--signal-glow);border:1px solid var(--signal-dim)}
.upload-msg.error{display:block;color:var(--alert);background:#ef5a5215;border:1px solid #ef5a5244}
.upload-msg.success{display:block;color:var(--safe);background:#2ed47a15;border:1px solid #2ed47a44}
.upload-btn{margin-top:14px;padding:11px 24px;border:none;border-radius:9px;background:var(--grad);color:#02141a;font-size:13px;font-weight:800;cursor:pointer;transition:.15s;display:none}
.upload-btn:hover{filter:brightness(1.1)}
