
:root{--bg:#0b1020;--card:#121937;--muted:#94a3b8;--text:#e2e8f0;--accent:#60a5fa;}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Noto Sans',sans-serif}
a{color:var(--accent);text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:24px}
.header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}
.brand{font-weight:800;font-size:20px;letter-spacing:.5px}
.nav a{margin-right:14px;color:var(--muted)}
.card{background:var(--card);border-radius:16px;padding:20px;box-shadow:0 8px 30px rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.06)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.grid-4{grid-column:span 4}
.grid-6{grid-column:span 6}
.grid-12{grid-column:span 12}
@media(max-width:900px){.grid-4,.grid-6{grid-column:span 12}}
.h1{font-size:28px;font-weight:800;margin:0 0 8px}
.h2{font-size:20px;font-weight:700;margin:0 0 6px}
.p{color:var(--muted);margin:0 0 12px}
.kpi{display:flex;gap:16px;flex-wrap:wrap}
.kpi .box{flex:1 1 160px;background:rgba(255,255,255,.04);padding:14px;border-radius:12px;border:1px solid rgba(255,255,255,.06)}
.kpi .num{font-weight:800;font-size:24px}
.input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);color:var(--text);outline:none}
.table{width:100%;border-collapse:collapse;border-spacing:0}
.table th,.table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left}
.tag{display:inline-block;background:rgba(96,165,250,.15);color:#cfe7ff;padding:4px 8px;border-radius:999px;font-size:12px;border:1px solid rgba(96,165,250,.35)}
.footer{color:var(--muted);font-size:12px;margin-top:24px;text-align:center}
.badge{background:#1f2937;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:6px 8px;color:#cbd5e1;font-size:12px}
.searchbar{display:flex;gap:10px}
button{background:var(--accent);color:#0b1020;border:none;border-radius:10px;padding:10px 14px;font-weight:700;cursor:pointer}
button.ghost{background:transparent;color:var(--text);border:1px solid rgba(255,255,255,.15)}
.small{font-size:12px;color:var(--muted)}
.code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace; font-size:12px;color:#cbd5e1;background:rgba(255,255,255,.04);padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.08)}
.card-row{display:flex;gap:12px;align-items:center;justify-content:space-between}
.progress{width:100%;height:10px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden;margin-top:8px;border:1px solid rgba(255,255,255,.08)}
.progress>div{height:100%}
.cand{display:flex;align-items:center;gap:10px}
.cand .dot{width:12px;height:12px;border-radius:50%}


.panel{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}
@media(max-width:900px){.panel{grid-template-columns:1fr}}
.panel-left{padding:16px}
.panel-right{padding:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:16px}
.legend{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0 12px}
.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:4px 8px;font-size:12px;background:rgba(255,255,255,.03)}
.chip .dot{width:10px;height:10px;border-radius:50%}
.bar{height:12px;border-radius:999px;background:rgba(255,255,255,.08);position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.bar>span{display:block;height:100%}
.row{display:flex;justify-content:space-between;align-items:center;margin:8px 0}
.row .lbl{display:flex;align-items:center;gap:8px}
.toggle{display:inline-flex;border:1px solid rgba(255,255,255,.2);border-radius:10px;overflow:hidden}
.toggle button{background:transparent;color:var(--text);padding:6px 10px;border:none}
.toggle button.active{background:rgba(255,255,255,.1)}
#mapWrap svg .active{filter:brightness(1.1);stroke:#fff;stroke-width:1.5}
.fixed-legend{position:sticky;top:0;background:linear-gradient(180deg, rgba(11,16,32,.95), rgba(11,16,32,.85));backdrop-filter:blur(6px);padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.06)}
.searchbox{display:flex;gap:8px;margin:8px 0}
.hatch{fill:url(#hatch);}


.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:10px}
@media(max-width:1000px){.kpi-row{grid-template-columns:repeat(2,1fr)}}
.kpi-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px 14px}
.kpi-card .label{color:var(--muted);font-size:12px;margin-bottom:6px}
.kpi-card .value{font-weight:800;font-size:22px}
.select{appearance:none;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);padding:10px 12px;border-radius:12px;color:var(--text);width:100%}
.overlay{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);background:#0b1020;border:1px solid rgba(255,255,255,.15);box-shadow:0 12px 40px rgba(0,0,0,.45);border-radius:14px;min-width:320px;max-width:420px}
.overlay .head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08)}
.overlay .title{font-weight:700}
.overlay .body{padding:10px 12px}
.overlay .row{display:flex;justify-content:space-between;align-items:center;margin:10px 0}
.overlay .bar{height:8px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.06);overflow:hidden}
.overlay .bar>span{display:block;height:100%}
.donut{width:80px;height:80px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--accent) 0deg, var(--accent) 0deg, rgba(255,255,255,.08) 0deg)}
.donut .inner{width:60px;height:60px;border-radius:50%;background:#0b1020;display:grid;place-items:center;font-weight:700}
.grid-top{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:10px}
.grid-top .left{display:flex;align-items:center;gap:14px}


/* --- Home tiles style (TR-style cards) --- */
.cards{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card-tile{grid-column:span 3;background:#0e142b;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:18px;text-align:center}
@media(max-width:1100px){.card-tile{grid-column:span 6}}
@media(max-width:640px){.card-tile{grid-column:span 12}}
.tile-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:6px solid #121a35;box-shadow:0 2px 10px rgba(0,0,0,.35)}
.tile-name{font-weight:800;letter-spacing:.3px;margin-top:12px;text-transform:uppercase}
.tile-bar{position:relative;height:28px;border-radius:999px;background:#232946;border:1px solid rgba(255,255,255,.08);overflow:hidden;margin-top:14px}
.tile-bar>span{display:block;height:100%}
.tile-bar .pct{position:absolute;left:0;right:0;top:0;bottom:0;display:grid;place-items:center;font-weight:800}
.tile-votes{margin-top:8px;color:#a3b1c6;font-size:12px}
.badge-flag{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#0e142b}
.badge-flag img{width:22px;height:22px;border-radius:50%}
.kpi-turnout{display:flex;align-items:center;gap:6px;color:#a3b1c6}
.kpi-turnout .strong{font-weight:800;color:#e2e8f0}


.kpi-bottom{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:14px}
@media(max-width:1100px){.kpi-bottom{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.kpi-bottom{grid-template-columns:repeat(2,1fr)}}
.kpi-box{display:flex;gap:10px;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px 12px}
.kpi-box .ic{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:#0f1530;border:1px solid rgba(255,255,255,.08)}
.kpi-box .meta{line-height:1.2}
.kpi-box .meta .lbl{color:#9aa7bd;font-size:12px}
.kpi-box .meta .val{font-weight:800}
.city-inline{display:flex;gap:18px;justify-content:center;align-items:center;margin:10px 0 14px 0;flex-wrap:wrap}
.city-inline .chip{display:flex;gap:6px;align-items:center}
.city-inline .dot{width:10px;height:10px;border-radius:50%}
.select-wrap{display:flex;justify-content:center;margin:8px 0}
.select{appearance:none;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);padding:10px 12px;border-radius:12px;color:var(--text);min-width:260px}
.badge-title{display:flex;justify-content:center}
.badge-title .pill{display:inline-flex;gap:8px;align-items:center;padding:6px 12px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:#0e142b;font-weight:800}

#tooltip{max-width:260px;word-wrap:break-word;font-size:13px;line-height:1.3}

#tooltip{max-width:260px;word-wrap:break-word;font-size:13px;line-height:1.3}


/* --- Hover tooltip card (city info) --- */
#tooltip.tt-card{position:fixed;pointer-events:none;z-index:9999;display:none}
.tt-wrap{background:#f8fafc;color:#0f172a;border:1px solid rgba(15,23,42,.15);border-radius:12px;min-width:220px;max-width:280px;box-shadow:0 10px 30px rgba(0,0,0,.35);overflow:hidden}
.tt-head{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-bottom:1px solid rgba(15,23,42,.08);font-weight:800;letter-spacing:.2px}
.tt-head .label{font-weight:700;font-size:11px;color:#334155}
.tt-progress{height:4px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin:6px 10px}
.tt-progress>span{display:block;height:100%;background:#16a34a}
.tt-body{padding:8px}
.tt-row{display:grid;grid-template-columns:18px 1fr auto auto;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid rgba(15,23,42,.06)}
.tt-row:last-child{border-bottom:none}
.tt-dot{width:12px;height:12px;border-radius:3px}
.tt-name{font-weight:700;font-size:12px;text-transform:uppercase;color:#0f172a}
.tt-votes{font-weight:700;color:#0f172a}
.tt-pct{font-weight:800;color:#475569}
