:root{--brand:#544595;--brand-d:#352963;--accent:#F3930D;--danger:#c7312b;--stable:#8a94a6;--ink:#25233a;--muted:#67667a;--line:#e5e1ef;--bg:#f7f5fb}
*{box-sizing:border-box}
body{margin:0;font-family:"Nunito Sans",system-ui,Arial,sans-serif;color:var(--ink);background:#fff}
.wrap{max-width:1220px;margin:0 auto;padding:0 20px}
.top{background:linear-gradient(135deg,#544595,#874088);color:#fff}
.top-in{display:grid;grid-template-columns:220px minmax(0,1fr);gap:28px;align-items:end;padding:24px 20px 32px}
.top img{width:100%;max-height:92px;object-fit:contain;background:#fff;border-radius:8px;padding:7px 10px}
.nav-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.nav-actions a.nav-back{border:0;border-radius:9px;padding:11px 16px;color:var(--brand);text-decoration:none;font-weight:900;font-size:.95rem;background:#fff;box-shadow:0 3px 10px rgba(0,0,0,.18)}
.nav-actions a.nav-back:hover{background:#f3eefb;transform:translateY(-1px)}
.eyebrow{margin:0 0 8px;font-size:.78rem;font-weight:900;text-transform:uppercase}
h1{margin:0 0 8px;font-size:clamp(2rem,4.5vw,4.3rem);line-height:1.02;font-weight:900}
.top p:last-child{margin:0;max-width:780px;line-height:1.5;opacity:.94}
.summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:22px 0}
.kpi,.dept-card,.panel{border:1px solid var(--line);border-radius:8px;background:#fff}
.kpi{padding:14px}.kpi b{display:block;color:var(--brand);font-size:1.55rem;line-height:1}.kpi span{display:block;margin-top:7px;color:var(--muted);font-size:.8rem}
.controls{position:sticky;top:0;z-index:500;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;background:rgba(255,255,255,.96);padding:12px 0;border-bottom:1px solid var(--line)}
label{display:grid;gap:5px}label span{font-size:.72rem;font-weight:900;text-transform:uppercase;color:var(--brand)}
select,input{width:100%;min-height:42px;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font:inherit;font-weight:700;background:#fff;color:var(--ink)}
.dept-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:18px 0}.dept-strip.is-hidden{display:none}
.dept-card{padding:12px;text-align:left;cursor:pointer;font:inherit;color:var(--ink);border-left:5px solid var(--brand)}
.dept-card:hover,.dept-card.active{background:var(--bg)}.dept-card h3{margin:0;color:var(--brand);font-size:.98rem}.dept-card p{margin:4px 0 0;color:var(--muted);font-size:.78rem}.dept-card b{color:var(--brand)}
.workbench{display:grid;grid-template-columns:minmax(420px,1.15fr) minmax(360px,.85fr);gap:20px;margin:20px 0}
.panel{padding:14px;border-top:3px solid var(--brand)}
.panel-head{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:10px}.panel h2{margin:0;color:var(--brand);font-size:1.08rem}.panel p{margin:3px 0 0;color:var(--muted);font-size:.83rem}
button{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--brand);font:inherit;font-weight:900;padding:8px 10px;cursor:pointer}
.map-modes{display:flex;gap:3px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:3px;flex-wrap:wrap}
.map-modes button{border:0;background:transparent;color:var(--muted);padding:6px 10px;font-size:.8rem;font-weight:800;border-radius:7px}
.map-modes button.active{background:var(--brand);color:#fff}
.maplg{background:#fff;padding:7px 9px;border-radius:8px;box-shadow:0 1px 6px rgba(0,0,0,.22);font-size:.72rem;line-height:1.7;color:#444;max-width:210px}
.maplg b{display:block;margin-bottom:2px;color:var(--brand);font-size:.74rem}
.maplg span{display:inline-flex;align-items:center;margin-right:9px;white-space:nowrap}
.maplg i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:4px}
#map{height:590px;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.mun-list{max-height:590px;overflow:auto;display:grid;gap:8px;padding-right:4px}
.mun-item{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;border:1px solid var(--line);border-left-width:5px;border-radius:8px;background:#fff;padding:11px;text-align:left;font:inherit;cursor:pointer}
.mun-item.ganada{border-left-color:var(--brand)}.mun-item.disputa{border-left-color:var(--accent)}.mun-item.adversa{border-left-color:var(--stable)}.mun-item:hover,.mun-item.active{background:var(--bg)}
.mun-item h3{margin:0;font-size:.96rem}.mun-item p{margin:2px 0 0;color:var(--muted);font-size:.78rem}.mun-item b{color:var(--brand);white-space:nowrap}
.detail{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:20px;margin:26px 0;border-top:3px solid var(--brand);padding-top:14px}
.detail h2{margin:0;color:var(--brand);font-size:2rem}.detail-text{margin-top:14px;border:1px solid var(--line);border-left:5px solid var(--brand);border-radius:8px;background:var(--bg);padding:14px;line-height:1.55}
.metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metrics div{border:1px solid var(--line);border-radius:8px;padding:12px}.metrics b{display:block;color:var(--brand);font-size:1.25rem}.metrics span{color:var(--muted);font-size:.78rem}
#puestoMap{height:410px;border:1px solid var(--line);border-radius:8px;margin-top:14px}
.charts{display:grid;grid-template-columns:1fr;gap:20px;margin:26px 0}.chart-frame{height:560px;position:relative}.charts canvas{width:100%;height:100%!important}.age-panel{min-height:660px}
.chart-read{margin-top:12px;border:1px solid var(--line);border-left:5px solid var(--brand);border-radius:8px;background:var(--bg);padding:13px 14px;line-height:1.45;color:var(--ink)}
.chart-read h3{margin:0 0 5px;color:var(--brand);font-size:1rem}.chart-read p{margin:5px 0 0;color:var(--muted);font-size:.9rem}
.rank-list{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:8px}.rank-list li{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;border-bottom:1px dashed var(--line);padding-bottom:8px;font-size:.9rem}.rank-list b{color:var(--brand);white-space:nowrap}
.loss{color:var(--accent)}.loss-strong{color:var(--danger)}.gain{color:var(--brand)}.stable{color:var(--stable)}
.foot{background:var(--brand-d);color:#d7d2ea;margin-top:28px;padding:20px 0;font-size:.84rem;line-height:1.45}.foot b{color:#fff}
@media(max-width:980px){.top-in,.workbench,.detail,.charts{grid-template-columns:1fr}.summary,.dept-strip,.controls{grid-template-columns:repeat(2,minmax(0,1fr))}#map,.mun-list{height:500px;max-height:500px}}
@media(max-width:640px){.summary,.dept-strip,.controls,.metrics{grid-template-columns:1fr}.top-in{padding-top:18px}}
