/* ECZ National Results Centre — live display.
   Light, modern fintech design language: white rounded cards, soft shadows,
   green + near-black-green palette, pill controls, big bold numbers.
   Candidate portraits + Google Maps province choropleth. Mobile-optimised. */

:root{
    --bg:#edf1ee;
    --card:#ffffff;

    --ink:#0f241a;       /* near-black green — headings & big numbers */
    --text:#243029;
    --muted:#8a938c;
    --line:#e9edea;
    --track:#eef1ef;

    --green:#6e982f;        /* official ECZ green */
    --green-strong:#557a22;
    --green-soft:#dcecc2;
    --green-tint:#f0f5e7;
    --dark:#14261a;      /* dark accent (active pills, dark chips, map) */

    --gap:16px;
    --radius:22px;
    --radius-sm:16px;
    --shadow:0 1px 2px rgba(15,36,26,.05), 0 10px 28px rgba(15,36,26,.05);
}

*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{
    background:
        radial-gradient(900px 520px at 100% -8%, rgba(72,161,74,.08), transparent 60%),
        var(--bg);
    color:var(--text);
    font-family:"Open Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
    -webkit-font-smoothing:antialiased;
    overflow:hidden;
}

.stage{
    height:100vh;
    display:flex; flex-direction:column;
    padding:20px 24px 0; gap:14px;
    padding-left:max(24px, env(safe-area-inset-left));
    padding-right:max(24px, env(safe-area-inset-right));
}

/* ---------- Top bar ---------- */
.topbar{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:16px; }
.brand{ display:flex; align-items:center; gap:13px; min-width:0; }
.brand-logo{ height:52px; width:auto; max-width:240px; object-fit:contain; display:block; }
.brand-text .auth{ font-size:15px; font-weight:700; color:var(--ink); }
.brand-text .centre{ font-size:12px; color:var(--muted); margin-top:2px; }

.title-block{ text-align:center; }
.title-block .election{ font-size:23px; font-weight:800; letter-spacing:.2px; color:var(--ink); }
.title-block .sub{ font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-top:3px; }

.status{ display:flex; align-items:center; justify-content:flex-end; gap:16px; }
.live{
    display:flex; align-items:center; gap:8px; font-weight:800; letter-spacing:1.5px; font-size:12px;
    color:#c0392b; background:#fdecea; border:1px solid #f7d4ce; padding:6px 12px; border-radius:999px;
}
.live .dot{ width:9px; height:9px; border-radius:50%; background:#e23b2e; box-shadow:0 0 0 0 rgba(226,59,46,.6); animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(226,59,46,.55);} 70%{ box-shadow:0 0 0 10px rgba(226,59,46,0);} 100%{ box-shadow:0 0 0 0 rgba(226,59,46,0);} }
.clock{ font-variant-numeric:tabular-nums; font-size:21px; font-weight:700; letter-spacing:.5px; color:var(--ink); }
.declared{ font-size:13px; color:var(--muted); }
.declared #declaredPct{ font-size:20px; font-weight:800; color:var(--ink); }
.declared .pctmark{ font-weight:800; color:var(--ink); }

.flagrule{
    height:3px; border-radius:3px;
    background:linear-gradient(90deg,#198a00 0 25%,#de2010 25% 50%,#111 50% 75%,#ef7d00 75% 100%);
    opacity:.85;
}

.sampleband{
    text-align:center; font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
    color:#9a6b00; background:#fdf6e3; border:1px solid #f1e2bd; border-radius:10px; padding:6px 10px;
}

/* ---------- Tabs (pills) ---------- */
.tabs{ display:flex; gap:8px; flex-wrap:wrap; }
.tab{
    appearance:none; cursor:pointer;
    border:1px solid var(--line); background:var(--card);
    color:var(--muted); font:inherit; font-weight:700; font-size:14px;
    padding:9px 18px; border-radius:999px; transition:all .15s ease;
    box-shadow:0 1px 1px rgba(15,36,26,.03);
}
.tab:hover{ color:var(--ink); border-color:#d7ddd8; }
.tab.active{ color:#fff; background:var(--dark); border-color:var(--dark); }

/* ---------- Main grid ---------- */
.grid{ flex:1; min-height:0; display:grid; grid-template-columns:1.55fr 1fr; gap:var(--gap); }
.panel{
    background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
    box-shadow:var(--shadow); padding:20px 22px; min-height:0; display:flex; flex-direction:column;
}
.panel-head{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:12px; gap:10px; }
.panel-head h2{ margin:0; font-size:21px; font-weight:800; color:var(--ink); }
.panel-head h3{ margin:0; font-size:15px; font-weight:700; color:var(--ink); }
.panel-meta{ font-size:13px; color:var(--muted); }
.hint{ font-size:10px; color:var(--muted); text-transform:uppercase; letter-spacing:1.5px; background:var(--track); padding:3px 9px; border-radius:999px; white-space:nowrap; }

.main-panel{ overflow:hidden; }
.race-body{ flex:1; min-height:0; overflow:auto; }

/* ---------- Candidate rows ---------- */
.cand{
    display:grid; grid-template-columns:30px 50px 1fr auto; align-items:center;
    gap:14px; padding:13px 8px; border-bottom:1px solid var(--line); border-radius:14px;
    transition:background .2s ease;
}
.cand:last-child{ border-bottom:0; }
.cand .rank{ font-size:17px; font-weight:800; color:#c3cac4; text-align:center; }
.cand .avatar{
    position:relative; width:50px; height:50px; border-radius:14px; overflow:hidden;
    background:var(--pc,#557a22); box-shadow:0 6px 14px rgba(15,36,26,.12);
}
.cand .avatar.has-photo{ box-shadow:0 0 0 2px var(--pc), 0 6px 14px rgba(15,36,26,.18); }
.cand .avatar img{ width:100%; height:100%; object-fit:cover; object-position:center top; display:block; position:relative; z-index:1; }
.cand .avatar .ini{ position:absolute; inset:0; display:grid; place-items:center; color:#fff; font-weight:800; font-size:16px; z-index:0; }
.cand .who{ min-width:0; }
.cand .name{ font-size:19px; font-weight:700; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cand .party{ font-size:13px; color:var(--muted); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cand .num{ text-align:right; white-space:nowrap; }
.cand .pct{ font-size:27px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; line-height:1; }
.cand .votes{ font-size:12.5px; color:var(--muted); font-variant-numeric:tabular-nums; margin-top:3px; }
.cand .badge{
    display:inline-block; margin-left:10px; vertical-align:middle;
    font-size:10px; font-weight:800; letter-spacing:1px; text-transform:uppercase;
    color:#fff; background:var(--green-strong); padding:3px 9px; border-radius:999px;
}
.cand.lead{ background:var(--green-tint); }
.bar-wrap{ grid-column:3 / span 2; height:8px; background:var(--track); border-radius:999px; overflow:hidden; margin-top:4px; }
.bar{ height:100%; width:0; border-radius:999px; transition:width .9s cubic-bezier(.22,.61,.36,1); }

/* ---------- Seats panel ---------- */
.seatbar{ height:26px; display:flex; border-radius:999px; overflow:hidden; background:var(--track); margin-bottom:18px; }
.seatbar > span{ height:100%; transition:width .9s cubic-bezier(.22,.61,.36,1); }
.seat-list{ display:flex; flex-direction:column; gap:13px; overflow:auto; }
.seat-row{ display:grid; grid-template-columns:18px 1fr auto; gap:12px; align-items:center; }
.seat-row .sw{ width:16px; height:16px; border-radius:5px; }
.seat-row .pn{ font-size:16px; font-weight:600; color:var(--text); }
.seat-row .pn small{ color:var(--muted); font-weight:500; margin-left:6px; }
.seat-row .sc{ font-size:18px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; }
.seat-row .sc small{ color:#b9c0ba; font-weight:600; font-size:13px; }
.seat-track{ grid-column:2 / span 2; height:6px; background:var(--track); border-radius:999px; overflow:hidden; }
.seat-fill{ height:100%; width:0; transition:width .9s cubic-bezier(.22,.61,.36,1); }

/* ---------- Stats ---------- */
.side{ display:flex; flex-direction:column; gap:var(--gap); min-height:0; }
.stats{ display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); }
.stat{
    background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm);
    box-shadow:var(--shadow); padding:15px 17px;
}
.stat .k{ font-size:11px; letter-spacing:1.2px; text-transform:uppercase; color:var(--muted); }
.stat .v{ font-size:26px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; margin-top:7px; line-height:1; }
.stat .s{ font-size:12px; color:var(--muted); margin-top:5px; }

/* Featured "balance card" stat — echoes the reference green card */
.stats .stat:first-child{
    position:relative; overflow:hidden; border:0;
    background:linear-gradient(150deg,#e9f7dd,#d4eeb6);
}
.stats .stat:first-child .k{ color:#3c6b2b; }
.stats .stat:first-child .v,
.stats .stat:first-child .s{ color:var(--ink); }
.stats .stat:first-child::before{
    content:""; position:absolute; top:13px; right:14px; width:24px; height:24px; opacity:.55;
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230e2419' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M7 8a8 8 0 0 1 0 8'/%3E%3Cpath d='M11 5a13 13 0 0 1 0 14'/%3E%3Cpath d='M15 2a18 18 0 0 1 0 20'/%3E%3C/svg%3E") no-repeat center/contain;
}

/* ---------- Province map ---------- */
.map-panel{ flex:1; min-height:0; }
.map{
    flex:1; min-height:0; margin-bottom:12px; border-radius:14px; background:var(--dark);
    padding:12px; display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.map.gmap{ padding:0; background:#e9efe8; display:block; position:relative; }
.map.gmap img{ max-width:none; }            /* keep Google tiles crisp */
.zm-map{ width:100%; height:100%; display:block; }
.zm-prov{
    fill:rgba(255,255,255,.08); stroke:rgba(255,255,255,.30); stroke-width:1.1;
    transition:fill .6s ease, stroke .6s ease;
}
.zm-prov.declared{ stroke:rgba(255,255,255,.55); }
.zm-label{ fill:#fff; font-size:29px; font-weight:800; letter-spacing:.5px; pointer-events:none; }

.legend{ display:flex; flex-wrap:wrap; gap:9px 16px; }
.legend .li{ display:flex; align-items:center; gap:7px; font-size:12px; color:var(--muted); }
.legend .sw{ width:12px; height:12px; border-radius:4px; }

/* ---------- Ticker ---------- */
.ticker{
    display:flex; align-items:center; gap:14px;
    border-top:1px solid var(--line); margin:0 -24px; padding:13px 24px;
    padding-bottom:max(13px, env(safe-area-inset-bottom));
    background:rgba(255,255,255,.6);
}
.ticker-label{
    flex:none; font-size:11px; font-weight:800; letter-spacing:1.5px; text-transform:uppercase;
    color:#fff; background:var(--dark); padding:6px 12px; border-radius:999px;
}
.ticker-track{ flex:1; overflow:hidden; white-space:nowrap; }
.ticker-content{ display:inline-block; font-size:15px; color:var(--text); animation:scroll 38s linear infinite; }
.ticker-content b{ color:var(--ink); }
.ticker-content .pill{ color:var(--muted); }
.ticker-content .sep{ color:#c7cec8; margin:0 14px; }
@keyframes scroll{ from{ transform:translateX(40%);} to{ transform:translateX(-100%);} }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */

/* Tablets / small laptops — stack the two columns, allow the page to scroll */
@media (max-width:1100px){
    body{ overflow:auto; }
    .stage{ height:auto; min-height:100vh; }
    .grid{ grid-template-columns:1fr; }
    .main-panel{ overflow:visible; }
    .race-body{ overflow:visible; }
    .map-panel{ flex:none; }
    .map{ flex:none; height:360px; }
}

/* Phones */
@media (max-width:760px){
    .stage{ padding:12px 14px 0; gap:11px;
        padding-left:max(14px, env(safe-area-inset-left));
        padding-right:max(14px, env(safe-area-inset-right)); }

    .topbar{ grid-template-columns:1fr; justify-items:center; gap:9px; text-align:center; }
    .brand{ justify-content:center; }
    .brand-logo{ height:40px; }
    .title-block .election{ font-size:18px; }
    .title-block .sub{ font-size:10px; letter-spacing:2px; }
    .status{ justify-content:center; gap:13px; }
    .clock{ font-size:18px; }

    .sampleband{ font-size:9.5px; letter-spacing:.6px; text-transform:none; padding:7px 10px; line-height:1.35; }

    /* horizontally scrollable tab strip */
    .tabs{ flex-wrap:nowrap; overflow-x:auto; gap:7px; padding-bottom:3px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
    .tabs::-webkit-scrollbar{ display:none; }
    .tab{ flex:0 0 auto; font-size:13px; padding:9px 15px; }

    .panel{ padding:14px 14px; border-radius:18px; }
    .panel-head h2{ font-size:18px; }

    .cand{ grid-template-columns:20px 44px 1fr auto; gap:10px; padding:11px 4px; }
    .cand .rank{ font-size:14px; }
    .cand .avatar{ width:44px; height:44px; border-radius:12px; }
    .cand .avatar .ini{ font-size:14px; }
    .cand .name{ font-size:15px; }
    .cand .party{ font-size:11px; }
    .cand .pct{ font-size:20px; }
    .cand .votes{ font-size:11px; }
    .cand .badge{ font-size:9px; padding:2px 7px; margin-left:7px; }

    .stats{ gap:10px; }
    .stat{ padding:12px 13px; border-radius:14px; }
    .stat .v{ font-size:20px; }
    .stat .k{ font-size:10px; }
    .stat .s{ font-size:11px; }

    .map{ height:300px; }
    .zm-label{ font-size:34px; }

    .ticker{ margin:0 -14px; gap:10px; padding:11px 14px;
        padding-bottom:max(11px, env(safe-area-inset-bottom)); }
    .ticker-label{ font-size:10px; padding:5px 10px; }
    .ticker-content{ font-size:13px; }
}

/* Small phones */
@media (max-width:430px){
    .title-block .election{ font-size:16px; }
    .status{ gap:10px; }
    .clock{ font-size:16px; }
    .declared{ font-size:12px; }
    .cand{ grid-template-columns:18px 40px 1fr auto; gap:9px; }
    .cand .avatar{ width:40px; height:40px; }
    .cand .name{ font-size:14px; }
    .cand .pct{ font-size:18px; }
    .stat .v{ font-size:18px; }
    .map{ height:260px; }
}

/* Reduced-motion users */
@media (prefers-reduced-motion:reduce){
    .bar,.seat-fill,.seatbar>span{ transition:none; }
    .ticker-content{ animation:none; }
    .live .dot{ animation:none; }
}

/* =====================================================================
   INTERACTIVITY
   ===================================================================== */

/* Controls row: tabs + playback */
.controls-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.controls-row .tabs{ flex:1 1 auto; }
.playback{ display:flex; gap:8px; flex:0 0 auto; }
.ctrl{
    appearance:none; cursor:pointer; font:inherit; font-weight:700; font-size:13px;
    color:var(--text); background:var(--card); border:1px solid var(--line);
    padding:9px 14px; border-radius:999px; min-height:38px; transition:all .15s ease;
    box-shadow:0 1px 1px rgba(15,36,26,.03);
}
.ctrl:hover{ border-color:#cdd6cf; color:var(--ink); }
.ctrl:active{ transform:translateY(1px); }
#btnPlay{ background:var(--green-tint); border-color:var(--green-soft); color:var(--green-strong); }

/* Clickable candidate cards */
.cand{ cursor:pointer; }
.cand:hover{ background:var(--green-tint); }
.cand:focus-visible{ outline:2px solid var(--green-strong); outline-offset:-2px; }
.cand.lead:hover{ filter:brightness(.99); }

/* Legend becomes clickable filter chips */
.legend .li{
    appearance:none; font:inherit; cursor:pointer;
    border:1px solid transparent; background:transparent; padding:3px 8px; border-radius:999px;
    transition:background .15s ease, border-color .15s ease;
}
.legend .li:hover{ background:var(--track); }
.legend .li.on{ background:var(--green-tint); border-color:var(--green-soft); color:var(--ink); font-weight:700; }

/* SVG map tooltip */
.map{ position:relative; }
.map-tip{
    position:absolute; z-index:5; pointer-events:none; max-width:160px;
    background:#0f241a; color:#fff; border-radius:10px; padding:7px 10px;
    font-size:12px; line-height:1.3; box-shadow:0 8px 24px rgba(0,0,0,.3);
}
.map-tip b{ display:block; font-weight:800; }
.map-tip span{ opacity:.85; }
.zm-prov{ transition:fill .6s ease, stroke .6s ease, opacity .3s ease; }
.zm-prov:hover{ stroke:#fff; stroke-width:2; }

/* Candidate detail modal */
.cmodal{
    position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center;
    background:rgba(8,18,12,.55); backdrop-filter:blur(3px); padding:20px;
    animation:cmfade .18s ease;
}
.cmodal[hidden]{ display:none; }
@keyframes cmfade{ from{ opacity:0; } to{ opacity:1; } }
.cmodal-card{
    position:relative; width:min(360px,92vw); background:var(--card); border-radius:22px;
    box-shadow:0 30px 80px rgba(0,0,0,.4); padding:26px 24px 22px; text-align:center;
    animation:cmpop .2s cubic-bezier(.22,.61,.36,1);
}
@keyframes cmpop{ from{ transform:translateY(10px) scale(.97); opacity:.6; } to{ transform:none; opacity:1; } }
.cmodal-x{
    position:absolute; top:12px; right:14px; width:34px; height:34px; border-radius:50%;
    border:1px solid var(--line); background:var(--card); color:var(--muted);
    font-size:20px; line-height:1; cursor:pointer;
}
.cmodal-x:hover{ color:var(--ink); border-color:#cdd6cf; }
.cmodal-photo{
    position:relative; width:108px; height:108px; margin:4px auto 14px; border-radius:24px;
    overflow:hidden; background:var(--pc,#557a22); box-shadow:0 0 0 3px var(--pc,#557a22), 0 10px 24px rgba(15,36,26,.2);
}
.cmodal-photo img{ width:100%; height:100%; object-fit:cover; object-position:center top; position:relative; z-index:1; }
.cmodal-photo .ini{ position:absolute; inset:0; display:grid; place-items:center; color:#fff; font-weight:800; font-size:34px; z-index:0; }
.cmodal-rank{ font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); font-weight:700; }
.cmodal-name{ font-size:23px; font-weight:800; color:var(--ink); margin-top:2px; }
.cmodal-party{ font-size:13.5px; color:var(--muted); margin-top:3px; }
.cmodal-figs{ display:flex; justify-content:center; align-items:baseline; gap:14px; margin-top:16px; }
.cmodal-pct{ font-size:34px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; line-height:1; }
.cmodal-votes{ font-size:14px; color:var(--muted); font-variant-numeric:tabular-nums; }
.cmodal-link{
    display:inline-block; margin-top:18px; font-size:13px; font-weight:700; text-decoration:none;
    color:var(--green-strong); background:var(--green-tint); border:1px solid var(--green-soft);
    padding:9px 16px; border-radius:999px;
}
.cmodal-link:hover{ background:var(--green-soft); }

/* Google Maps zoom control: keep it tidy */
.map.gmap .gm-style .gmnoprint button{ border-radius:8px !important; }

/* ----- responsiveness refinements ----- */
@media (max-width:760px){
    .controls-row{ gap:8px; }
    .playback{ width:100%; justify-content:flex-end; }
    .ctrl{ font-size:12px; padding:8px 12px; min-height:36px; }
    /* allow candidate names to use two lines instead of truncating */
    .cand{ grid-template-columns:20px 44px 1fr auto; align-items:center; }
    .cand .name{
        white-space:normal; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
        overflow:hidden; line-height:1.16;
    }
    .cand .badge{ display:none !important; }   /* free up room; leader still tinted */
    .cmodal-photo{ width:96px; height:96px; }
    .cmodal-name{ font-size:20px; }
    .cmodal-pct{ font-size:30px; }
}
@media (max-width:430px){
    .playback{ justify-content:stretch; }
    .ctrl{ flex:1; text-align:center; }
}
