*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,Arial,sans-serif;background:var(--bg);color:var(--text);--bg:#eef1f6;--text:#1f2937;--card:#ffffff;--line:#eef1f6;--muted:#6b7280;--inbg:#f9fafb;--pos:#15803d;--neg:#b91c1c;--warn:#b45309;--side1:#0b2a4a;--side2:#0e4f5e;--accent:#2dd4bf;--accent2:#22d3ee;--ink:#0b2a4a;--g-pink:linear-gradient(135deg,#ec4899,#be185d);--g-purple:linear-gradient(135deg,#8b5cf6,#6d28d9);--g-amber:linear-gradient(135deg,#f59e0b,#d97706);--g-blue:linear-gradient(135deg,#38bdf8,#0284c7);--g-teal:linear-gradient(135deg,#2dd4bf,#0f766e);--g-red:linear-gradient(135deg,#fb7185,#be123c)}
.app{display:flex;min-height:100vh}
aside{width:220px;background:linear-gradient(180deg,var(--side1),var(--side2));color:#fff;flex:0 0 220px;padding:18px 0;position:sticky;top:12px;height:calc(100vh - 24px);align-self:flex-start;overflow-y:auto;display:flex;flex-direction:column}
aside .logo{display:flex;align-items:center;gap:10px;padding:0 16px 14px;font-size:18px;font-weight:600;border-bottom:1px solid rgba(255,255,255,.12)}
aside .logo .logo-img{width:36px;height:36px;flex:0 0 36px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}
aside .logo .logo-name{font-size:14px;line-height:1.2;font-weight:700}
.userbox{margin-top:auto;padding:12px 14px 2px;border-top:1px solid rgba(255,255,255,.12)}
.userbox .ub-user{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.userbox .ub-av{width:31px;height:31px;flex:0 0 31px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#06343a}
.userbox .ub-meta{min-width:0}
.userbox .ub-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.userbox .ub-role{font-size:10px;color:rgba(255,255,255,.55)}
.userbox .ub-tag{display:flex;align-items:center;gap:7px;font-size:11px;color:rgba(255,255,255,.7);margin-bottom:9px}
.userbox .ub-badge{font-size:10px;font-weight:800;letter-spacing:.5px;background:#2dd4bf;color:#06343a;padding:2px 7px;border-radius:5px}
.userbox .ub-btn{display:block;width:100%;text-align:center;box-sizing:border-box;font-size:12px;font-weight:700;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);color:#fff;cursor:pointer;text-decoration:none}
.userbox .ub-btn:hover{background:rgba(255,255,255,.16)}
nav a{display:flex;align-items:center;gap:10px;padding:12px 18px;color:#cfe3ee;text-decoration:none;font-size:14px;cursor:pointer;border-left:3px solid transparent}
nav a:hover{background:rgba(255,255,255,.07)}
nav a.active{background:rgba(255,255,255,.12);color:#fff;border-left:3px solid var(--accent);font-weight:600}
main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:var(--card);border-bottom:1px solid var(--line);padding:12px 22px;display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;position:sticky;top:0;z-index:20}
.topbar h1{font-size:23px;font-weight:700;color:var(--ink);margin-right:auto;padding:3px 0 3px 13px;border-left:5px solid var(--accent);line-height:1.15;letter-spacing:.2px}
.slicer{display:flex;flex-direction:column;gap:2px}
.slicer label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.slicer input[type=date]{font-size:13px;padding:5px 8px;border:1px solid var(--line);border-radius:7px;background:var(--inbg);color:var(--text);min-width:104px}
.btn{font-size:12px;padding:6px 12px;border:1px solid var(--line);border-radius:7px;background:var(--card);color:var(--text);cursor:pointer;height:32px}.btn:hover{background:rgba(120,140,170,.15)}
#corte{background:var(--side1);color:#fff;border-color:var(--side1)}#corte:hover{background:var(--side2)}
.ms{position:relative;display:inline-block}
.ms-btn{font-size:13px;padding:6px 9px;border:1px solid var(--line);border-radius:7px;background:var(--inbg);color:var(--text);cursor:pointer;min-width:130px;text-align:left}
.ms-btn:after{content:'▾';float:right;color:#94a3b8;margin-left:6px}
.ms-panel{position:absolute;z-index:40;top:108%;left:0;background:var(--card);border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.16);padding:6px;max-height:300px;overflow:auto;min-width:230px;display:none}
.ms-panel.open{display:block}
.ms-it{display:flex;align-items:center;gap:7px;padding:4px 8px;font-size:13px;border-radius:6px;cursor:pointer;white-space:nowrap}
.ms-it:hover{background:rgba(120,140,170,.15)}
.content{padding:20px 22px;flex:1}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:18px}
.kpi{border-radius:16px;padding:18px 20px;color:#fff;box-shadow:0 6px 16px rgba(0,0,0,.08)}
.kpi .lab{font-size:13px;opacity:.92}.kpi .val{font-size:27px;font-weight:700;margin-top:6px}.kpi .sub{font-size:12px;opacity:.9;margin-top:4px}
.pink{background:var(--g-pink)}.purple{background:var(--g-purple)}
.amber{background:var(--g-amber)}.blue{background:var(--g-blue)}
.teal{background:var(--g-teal)}.red{background:var(--g-red)}
.grid{display:grid;gap:16px}.g2{grid-template-columns:1fr 1fr}@media(max-width:900px){.g2{grid-template-columns:1fr}}
.card{background:var(--card);border-radius:14px;padding:16px 18px;box-shadow:0 2px 10px rgba(0,0,0,.05);margin-bottom:16px}
.card h3{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:12px}
.chartbox{position:relative;width:100%;height:300px}.chartbox.tall{height:380px}
table.t{width:100%;border-collapse:collapse;font-size:13px}
table.t th{text-align:left;color:var(--muted);font-weight:600;padding:7px 8px;border-bottom:2px solid var(--line);font-size:11px;text-transform:uppercase}
table.t td{padding:7px 8px;border-bottom:1px solid var(--line)}table.t td.num{text-align:center;font-variant-numeric:tabular-nums}table.t th.num{text-align:center}
.pill{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}
.pill.ok{background:#dcfce7;color:#166534}.pill.warn{background:#fef9c3;color:#854d0e}.pill.bad{background:#fee2e2;color:#991b1b}
.muted{color:var(--muted);font-size:12px}
.tcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}
.tcard{border-radius:14px;padding:16px;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.08)}
.tcard .nm{font-size:14px;font-weight:600}.tcard .big{font-size:22px;font-weight:700;margin:6px 0}
.tctr th,.tctr td{text-align:center !important}
.tctr th:first-child,.tctr td:first-child{text-align:left !important}
.scrollt{max-height:380px;overflow:auto}
.dl{width:100%;border-collapse:collapse;font-size:13px}
.dl td{padding:6px 8px;border-bottom:1px solid var(--line)}.dl td:last-child{text-align:right;font-weight:600}
.gbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:14px;font-size:13px;color:#374151;font-weight:600}
.gbtn,.pbtn{font-size:12px;padding:5px 11px;border:1px solid var(--line);border-radius:7px;background:var(--inbg);color:var(--text);cursor:pointer}
.gbtn:hover,.pbtn:hover{background:rgba(120,140,170,.15)}
.gbtn.on,.pbtn.on{background:var(--ink);color:var(--card);border-color:var(--ink)}
.pgroup{display:flex;gap:4px;flex-wrap:wrap}
.leg{margin-top:8px;font-size:12px;max-height:190px;overflow:auto}
.leg-it{display:flex;align-items:center;gap:7px;padding:3px 0}
.leg-it .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.leg-it b{margin-left:auto}.leg-it i{font-style:normal;color:#6b7280;width:50px;text-align:right}
.cal-wrap{display:flex;flex-wrap:wrap;gap:16px}
.cal-month{width:210px}
.cal-tit{font-weight:600;color:var(--ink);font-size:13px;margin-bottom:5px}
.cal-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px}
.cal-dows span{font-size:10px;color:#94a3b8;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-cell{height:25px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px}
.cal-cell.empty{background:transparent}
.drill-bg{position:fixed;inset:0;background:rgba(15,23,42,.45);display:none;z-index:100;align-items:center;justify-content:center}
.drill-bg.open{display:flex}
.drill-box{background:var(--card);border-radius:14px;width:min(860px,94vw);max-height:86vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.drill-head{display:flex;align-items:flex-start;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--line)}
.drill-t{font-size:16px;font-weight:700;color:var(--ink)}
.drill-x{border:none;background:#f1f5f9;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:14px}
.drill-x:hover{background:#e2e8f0}
.drill-body{padding:12px 20px;overflow:auto}
.clk{cursor:pointer}
.hint{font-size:11px;color:#94a3b8;font-weight:400}

.stmx{border-collapse:collapse;font-size:11px}
.stmx .sth{padding:3px 4px;color:#6b7280;font-weight:600;text-align:center;white-space:nowrap;border:none}
.stmx .stname{position:sticky;left:0;background:var(--card);white-space:nowrap;font-weight:600;font-size:12px;padding:4px 10px 4px 2px;z-index:2}
.stc{width:30px;min-width:30px;height:24px;border:2px solid #fff;cursor:pointer;border-radius:4px}
.e-subido{background:#16a34a}.e-disponible{background:#f59e0b}.e-futuro{background:#e2e8f0}.e-na{background:#f6f8fb}
.e-vacio{background:#a7f3d0}
.stc.e-na{cursor:default}
.stwrap{overflow-x:auto;padding-bottom:6px}
.lg{display:inline-block;width:13px;height:13px;border-radius:3px;vertical-align:middle;margin-right:2px}
.cfg-grid{display:flex;flex-direction:column;gap:2px;max-height:420px;overflow:auto}
.cfg-it{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:7px;cursor:pointer;font-size:13px}
.cfg-it:hover{background:rgba(120,140,170,.15)}.cfg-it span{flex:1}.cfg-it b{color:var(--ink)}
.btn.on{background:#0f766e;color:#fff;border-color:#0f766e}
.tg{display:inline-block;padding:1px 7px;border-radius:9px;font-size:11px;font-weight:600}.tg-t{background:#dbeafe;color:#1e40af}.tg-c{background:#fef3c7;color:#92400e}.card.desc{border-left:4px solid var(--accent)}
body.t-oceano{--bg:#e9f1fb;--side1:#0c2d6b;--side2:#1d4ed8;--accent:#38bdf8;--accent2:#0ea5e9;--ink:#0c2d6b;--g-pink:linear-gradient(135deg,#818cf8,#4f46e5);--g-purple:linear-gradient(135deg,#6366f1,#4338ca);--g-amber:linear-gradient(135deg,#38bdf8,#1d4ed8);--g-blue:linear-gradient(135deg,#38bdf8,#0284c7);--g-teal:linear-gradient(135deg,#22d3ee,#0891b2);--g-red:linear-gradient(135deg,#fb7185,#be123c)}
body.t-ocaso{--bg:#f7eef6;--side1:#4a1d52;--side2:#9333ea;--accent:#f59e0b;--accent2:#fbbf24;--ink:#6b21a8;--g-pink:linear-gradient(135deg,#ec4899,#be185d);--g-purple:linear-gradient(135deg,#a855f7,#7e22ce);--g-amber:linear-gradient(135deg,#f59e0b,#d97706);--g-blue:linear-gradient(135deg,#c084fc,#9333ea);--g-teal:linear-gradient(135deg,#f0abfc,#c026d3);--g-red:linear-gradient(135deg,#fb7185,#be123c)}
body.t-grafito{--bg:#eef1f5;--side1:#1e293b;--side2:#334155;--accent:#38bdf8;--accent2:#0ea5e9;--ink:#1e293b;--g-pink:linear-gradient(135deg,#475569,#1e293b);--g-purple:linear-gradient(135deg,#6366f1,#4338ca);--g-amber:linear-gradient(135deg,#f59e0b,#b45309);--g-blue:linear-gradient(135deg,#64748b,#334155);--g-teal:linear-gradient(135deg,#0ea5e9,#0369a1);--g-red:linear-gradient(135deg,#fb7185,#be123c)}
.thgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:10px}
.thopt{border:2px solid var(--line);border-radius:12px;padding:10px;cursor:pointer;text-align:center}
.thopt:hover{border-color:var(--accent)}
.thopt.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
.thsw{display:flex;gap:4px;justify-content:center;margin-bottom:7px}
.thsw span{width:22px;height:22px;border-radius:6px;display:inline-block}
.thname{font-size:13px;font-weight:600;color:var(--ink)}
body.t-noche{--pos:#4ade80;--neg:#f87171;--warn:#fbbf24;--bg:#0f172a;--card:#1e293b;--text:#e2e8f0;--line:#334155;--muted:#94a3b8;--inbg:#334155;--ink:#e2e8f0;--side1:#0b1220;--side2:#1e293b;--accent:#38bdf8;--accent2:#22d3ee}
body.t-carbon{--pos:#4ade80;--neg:#f87171;--warn:#fbbf24;--bg:#18181b;--card:#27272a;--text:#e4e4e7;--line:#3f3f46;--muted:#a1a1aa;--inbg:#3f3f46;--ink:#e4e4e7;--side1:#09090b;--side2:#27272a;--accent:#22d3ee;--accent2:#06b6d4}
.tgrp{display:flex;flex-direction:column;gap:3px;padding-left:14px;border-left:2px solid var(--line);justify-content:flex-end}
.tgrp.first{border-left:none;padding-left:0}
.glab{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-weight:700;padding-left:2px}
.trow{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap}
.btn-mode{font-size:13px;font-weight:700;padding:0 18px;height:32px;border-radius:9px;border:2px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer}
.btn-mode.on{background:var(--accent);color:#fff}
.btn-reset{color:var(--muted)}
.ms-hd{display:flex;gap:6px;padding:2px 6px 6px;border-bottom:1px solid var(--line);margin-bottom:4px;font-size:11px}
.ms-act{color:var(--accent);cursor:pointer;font-weight:600}
.acc-dev{background:rgba(22,163,184,.12)}.acc-dev td{color:var(--text)}.acc-f{font-size:11px;color:#16a3b8;font-style:italic}.acc-h{font-weight:700;margin:12px 0 5px;color:var(--ink);font-size:13px}
.pbar{height:9px;background:rgba(120,140,170,.22);border-radius:5px;overflow:hidden;min-width:90px}.pbar span{display:block;height:100%;border-radius:5px}
.navsec{font-size:9px;text-transform:uppercase;letter-spacing:.7px;color:rgba(255,255,255,.45);padding:13px 18px 4px;font-weight:700}.kpi.clk{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;position:relative}
.kpi.clk:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(0,0,0,.20)}
.kpi.clk:after{content:'⊕ ver';position:absolute;top:10px;right:12px;font-size:10px;opacity:.6;font-weight:600}
.gauge-wrap{position:relative;height:150px}
.gauge-txt{position:absolute;left:0;right:0;top:54%;text-align:center;font-size:26px;font-weight:700;color:var(--ink)}
.gauge-sub{position:absolute;left:0;right:0;top:80%;text-align:center;font-size:12px;color:var(--muted)}
@media(max-width:760px){
 .app{flex-direction:column}
 aside{width:auto;flex:none;position:static;height:auto;top:0;padding:8px 0;overflow:visible}
 aside .logo{padding:0 14px 8px;font-size:15px}
 aside nav{display:flex;flex-wrap:wrap;gap:3px;padding:6px 8px}
 .navsec{width:100%;padding:7px 10px 1px}
 nav a{padding:7px 10px;font-size:12px;border-left:none;border-radius:8px;background:rgba(255,255,255,.06)}
 nav a.active{border-left:none;background:rgba(255,255,255,.20)}
 .topbar{padding:8px 12px;position:static;gap:8px}
 .topbar h1{font-size:17px;width:100%;margin:0 0 4px;padding-left:10px}
 .content{padding:12px 11px}
 .kpis{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:12px}
 .kpi{padding:13px 14px;border-radius:13px}
 .kpi .val{font-size:20px}.kpi.clk:after{top:7px;right:9px}
 .g2{grid-template-columns:1fr}
 .chartbox{height:250px}.chartbox.tall{height:300px}
 table.t{font-size:11.5px}table.t th{font-size:10px;padding:5px 5px}table.t td{padding:5px 5px}
 .card{padding:13px 13px}.card h3{font-size:14px}
 .tgrp{flex-wrap:wrap}
 .slicer input[type=date]{min-width:92px}
}
@media print{
 aside,.tgrp,.gbar,.ms,#drill,.btn{display:none!important}
 .app{display:block}main{display:block}.content{padding:0}
 .topbar{position:static;border:none;padding:0 0 10px}
 .card,.kpi{box-shadow:none!important;break-inside:avoid;page-break-inside:avoid}
 .kpi{color:#0b2a4a!important;background:#eef2f7!important;border:1px solid #cbd5e1}
 .kpi .lab,.kpi .val,.kpi .sub{color:#0b2a4a!important;opacity:1}
 .kpi.clk:after{display:none}
 body{background:#fff;color:#000}
 .chartbox{height:260px}
}
