/* ─── §2 Design tokens — Bloomberg-navy, institutional ─────────── */
:root {
  /* Surfaces */
  --bg-page:      #F5F6F8;   /* page bg, light institutional */
  --bg-chrome:    #0F1A2E;   /* navy header, footer, hero, masthead */
  --bg-chrome-2:  #162542;   /* live ticker band */
  --bg-card:      #FFFFFF;   /* card surfaces */
  --bg-muted:     #F1F2F4;   /* table headers, track fills */

  /* Ink */
  --ink:          #0F1A2E;   /* primary text on light */
  --ink-2:        #1F2A44;   /* body copy */
  --ink-muted:    #6B7280;   /* meta, labels */
  --ink-dim:      #9CA3AF;   /* axis ticks, minor */
  --ink-on-dark:  #FFFFFF;
  --ink-accent:   #7AA7E5;   /* navy-on-navy accent (kickers, half-wordmark) */

  /* Rules & shadows */
  --rule:         #E1E5EA;
  --rule-strong:  #2A3F66;   /* rules inside navy chrome */
  --shadow-card:  0 1px 2px rgba(15,26,46,0.04);
  --shadow-lift:  0 1px 0 rgba(0,0,0,0.04), 0 8px 16px rgba(0,0,0,0.08);

  /* Party colours — verbatim, do not retune */
  --lpc:#D71920; --cpc:#1A4785; --ndp:#F37021; --bq:#4B9CD3; --grn:#3D9B35;

  /* Status */
  --up:#16A34A; --down:#DC2626; --warn:#FBBF24;
}

/* ─── §3A.1 Top bar (navy chrome) ──────────────────────────────── */
.rw-topbar{position:sticky;top:0;z-index:100;background:var(--bg-chrome);color:var(--ink-on-dark);border-bottom:1px solid var(--rule-strong);font-family:'Inter',system-ui,sans-serif}
.rw-topbar-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:0 24px;height:56px;gap:24px}
.rw-topbar-left{display:flex;align-items:center;gap:24px;min-width:0}
.rw-topbar-right{display:flex;align-items:center;gap:12px}
.rw-wordmark{display:inline-flex;align-items:baseline;position:relative;font-size:19px;font-weight:800;letter-spacing:-0.5px;text-decoration:none;padding-right:8px;color:#fff;line-height:1}
.rw-wordmark-1{color:#fff}
.rw-wordmark-2{color:var(--ink-accent)}
.rw-wordmark-dot{position:absolute;right:0;top:-2px;width:5px;height:5px;border-radius:5px;background:var(--lpc)}
.rw-nav{display:flex;align-items:center}
.rw-nav-item{padding:18px 14px;font-size:13px;font-weight:600;color:rgba(255,255,255,0.65);text-decoration:none;line-height:1}
.rw-nav-item:hover{color:#fff}
.rw-nav-active{color:#fff;font-weight:700;border-bottom:2px solid var(--ink-accent);margin-bottom:-1px}
.rw-search{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.08);padding:8px 12px;border-radius:4px;font-size:12px;color:rgba(255,255,255,0.65);min-width:240px;cursor:text;font-family:inherit}
.rw-search-cmd{opacity:0.5;font-size:12px}
.rw-search-hint{flex:1}
.rw-search-kbd{margin-left:auto;background:rgba(255,255,255,0.1);padding:1px 6px;border-radius:2px;font-size:10px;font-weight:600}
.rw-myriding{padding:7px 12px;background:rgba(122,167,229,0.12);color:var(--ink-accent);border:1px solid rgba(122,167,229,0.25);border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;line-height:1}
.rw-subscribe{padding:7px 14px;background:#fff;color:var(--bg-chrome);border:none;border-radius:4px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;line-height:1}

/* ─── §3A.2 Live ticker (42px band) ─────────────────────────────── */
.rw-ticker{display:flex;align-items:stretch;background:var(--bg-chrome-2);color:#fff;height:42px;border-bottom:1px solid var(--rule-strong);overflow:hidden;font-family:'Inter',system-ui,sans-serif;font-variant-numeric:tabular-nums}
.rw-ticker-tag{display:flex;align-items:center;gap:10px;padding:0 16px;background:var(--bg-chrome);border-right:1px solid var(--rule-strong);flex-shrink:0}
.rw-live{color:var(--down);font-size:10px;font-weight:800;letter-spacing:1.2px;display:inline-flex;align-items:center;gap:5px;line-height:1}
.rw-ticker-tag-text{color:rgba(255,255,255,0.5);font-size:10px;letter-spacing:1.5px;font-weight:600;line-height:1}

.rw-ticker-cell{display:flex;align-items:center;gap:8px;padding:0 16px;height:42px;border-right:1px solid rgba(255,255,255,0.06);flex-shrink:0}
.rw-ticker-cell:last-child{border-right:0}
.rw-ticker-sep{width:1px;height:20px;background:rgba(255,255,255,0.15);margin:0 8px;flex-shrink:0}
.rw-ticker-dot{width:8px;height:8px;border-radius:1px;flex-shrink:0}
.rw-ticker-party{font-size:11px;font-weight:800;letter-spacing:0.5px}
.rw-ticker-label{font-size:9px;font-weight:700;letter-spacing:1.2px;color:rgba(255,255,255,0.5)}
.rw-ticker-pct{font-size:14px;font-weight:700;letter-spacing:-0.2px}
.rw-ticker-delta{font-size:11px;font-weight:700}
.rw-ticker-delta.up{color:#4ADE80}
.rw-ticker-delta.dn{color:#F87171}
.rw-ticker-delta.flat{color:rgba(255,255,255,0.4)}
.rw-ticker-pct.good{color:#4ADE80}


/* ─── Live ticker scrolling track ─── */
.rw-ticker-body{position:relative;flex:1;padding:0;overflow:hidden}
.rw-tk-track{display:inline-flex;align-items:center;white-space:nowrap;will-change:transform}
.rw-tk-set{display:inline-flex;align-items:center;flex-shrink:0}
.rw-tk-track:hover{animation-play-state:paused}
@media (prefers-reduced-motion: reduce) { .rw-tk-track { animation: none !important; transform: none !important; } }

@media (max-width: 900px) {
  .rw-nav, .rw-search, .rw-myriding{display:none}
  .rw-topbar-inner{padding:0 16px;gap:12px}
  .rw-ticker-tag-text{display:none}
}


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip}
:root{
  --lpc:#D71920;--cpc:#1A4785;--ndp:#F37021;--bq:#4B9CD3;--grn:#3D9B35;
  --bg:#F5F6F7;--card:#fff;--header:#111827;--text:#1a1a1a;--muted:#6B7280;
  --border:#E5E7EB;--radius:8px;--shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --serif:'Source Serif 4','Georgia',serif;
}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;min-width:0;overflow-wrap:break-word}
header{background:var(--header);color:#fff;padding:0 clamp(16px, 4vw, 32px);position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.header-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:52px}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none;color:#fff}
.logo-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 0 0 1px rgba(255,255,255,0.12) inset;background:#1A4785}
.logo-text{font-size:16px;font-weight:700;letter-spacing:-.3px}
.logo-text span{color:rgba(255,255,255,.55);font-weight:500}
.hamburger-btn{display:none;background:none;border:none;color:#fff;cursor:pointer;font-size:20px;padding:6px 8px;border-radius:4px;transition:all .15s;width:44px;height:44px}
.hamburger-btn:hover{background:rgba(255,255,255,.1)}
nav{display:flex;gap:2px}
nav a{color:rgba(255,255,255,.55);text-decoration:none;font-size:13px;font-weight:500;padding:5px 11px;border-radius:4px;transition:all .15s}
nav a:hover,nav a.active{color:rgba(255,255,255,.95);background:rgba(255,255,255,.08)}
.header-badge{background:rgba(34,197,94,.15);color:#4ade80;font-size:10px;font-weight:600;padding:2px 7px;border-radius:3px;letter-spacing:.3px;text-transform:uppercase}
/* ─── HERO ─── */
.hero{background:var(--header);color:#fff;padding:0 0 28px;border-bottom:1px solid rgba(255,255,255,.06);overflow:hidden}

/* Ticker bar */
.hero-ticker-wrap{background:rgba(0,0,0,.25);border-bottom:1px solid rgba(255,255,255,.06);overflow:hidden;position:relative;height:36px}
.hero-ticker-wrap::before,.hero-ticker-wrap::after{content:'';position:absolute;top:0;bottom:0;width:48px;z-index:2;pointer-events:none}
.hero-ticker-wrap::before{left:0;background:linear-gradient(90deg,var(--header),transparent)}
.hero-ticker-wrap::after{right:0;background:linear-gradient(270deg,var(--header),transparent)}
.hero-ticker{display:flex;align-items:center;height:36px;white-space:nowrap;will-change:transform;padding-top:3px}
.hero-ticker:hover{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:6px;padding:0 22px;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;letter-spacing:.3px}
.ticker-pip{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ticker-party{color:rgba(255,255,255,.5);text-transform:uppercase;font-size:10px;letter-spacing:.8px}
.ticker-pct{color:#fff;font-size:14px;font-weight:700;font-variant-numeric:tabular-nums}
.ticker-delta{font-size:10px;font-weight:600;padding:1px 5px;border-radius:3px}
.ticker-delta-up{color:#4ade80;background:rgba(74,222,128,.1)}
.ticker-delta-dn{color:#f87171;background:rgba(248,113,113,.1)}
.ticker-delta-flat{color:rgba(255,255,255,.3)}
.ticker-sep{color:rgba(255,255,255,.1);font-size:16px;padding:0 4px}
/* ticker keyframes injected dynamically via JS */
/* Leader PM Ticker */
.leader-ticker-wrap{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:var(--radius);overflow:hidden;position:relative;height:40px;margin:12px 0 16px;border:1px solid rgba(255,255,255,.06);display:flex;align-items:center}
.leader-ticker-outer{overflow:hidden;flex:1;position:relative;height:40px}
.leader-ticker{display:flex;align-items:center;height:40px;white-space:nowrap;will-change:transform}
.leader-ticker:hover{animation-play-state:paused}
.leader-ticker .lt-item{display:inline-flex;align-items:center;gap:7px;padding:0 22px;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;letter-spacing:.3px}
.leader-ticker .lt-photo{width:24px;height:24px;border-radius:50%;background-size:cover;background-position:center top;border:1.5px solid rgba(255,255,255,.2);flex-shrink:0}
.leader-ticker .lt-name{color:rgba(255,255,255,.6);font-size:11px;font-weight:600}
.leader-ticker .lt-pct{color:#fff;font-size:15px;font-weight:700;font-variant-numeric:tabular-nums}
.leader-ticker .lt-label{color:rgba(255,255,255,.3);font-size:9px;text-transform:uppercase;letter-spacing:.5px}
.leader-ticker .lt-delta{font-size:10px;font-weight:600;padding:1px 5px;border-radius:3px}
.leader-ticker .lt-delta-up{color:#4ade80;background:rgba(74,222,128,.1)}
.leader-ticker .lt-delta-dn{color:#f87171;background:rgba(248,113,113,.1)}
.leader-ticker .lt-delta-flat{color:rgba(255,255,255,.3)}
.leader-ticker .lt-sep{color:rgba(255,255,255,.1);font-size:16px;padding:0 4px}
.leader-ticker-title{display:flex;align-items:center;padding:0 12px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.35);white-space:nowrap;flex-shrink:0;border-right:1px solid rgba(255,255,255,.08)}

/* Hero body */
.hero-inner{max-width:640px;margin:0 auto;padding:clamp(18px, 5vw, 28px) clamp(16px, 4vw, 32px) 0;text-align:center}
.hero h1{font-family:var(--serif);font-size:clamp(20px, 3.5vw, 26px);font-weight:600;letter-spacing:-.3px;margin-bottom:10px;line-height:1.25;color:#fff;opacity:0;animation:heroFadeUp .7s ease-out .3s forwards}
.hero-sub{font-size:14px;color:rgba(255,255,255,.55);line-height:1.55;margin-bottom:16px;opacity:0;animation:heroFadeUp .7s ease-out .5s forwards}
.hero-meta{display:flex;align-items:center;justify-content:center;gap:14px;font-size:12px;color:rgba(255,255,255,.35);opacity:0;animation:heroFadeUp .6s ease-out .7s forwards}

@keyframes heroFadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.built-in-public{background:var(--header);color:#fff;padding:clamp(18px, 5vw, 28px) clamp(16px, 4vw, 32px);text-align:center;border-top:1px solid rgba(255,255,255,.06)}
.built-in-public-inner{max-width:560px;margin:0 auto}
.built-in-public h2{font-family:var(--serif);font-size:16px;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:8px;letter-spacing:-.1px}
.built-in-public p{font-size:13px;color:rgba(255,255,255,.38);line-height:1.6;margin-bottom:0}
.built-in-public p+p{margin-top:6px}
.hero-cta{display:inline-flex;align-items:center;justify-content:center;margin-top:14px;padding:8px 20px;min-height:44px;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;color:rgba(255,255,255,.75);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:4px;text-decoration:none;transition:all .15s;cursor:pointer}
.hero-cta:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.22)}
.dot{width:6px;height:6px;border-radius:50%;background:#4ade80;display:inline-block;margin-right:4px;animation:pulse 3s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
main{max-width:1100px;margin:0 auto;padding:clamp(16px, 3vw, 24px) clamp(12px, 3vw, 20px) clamp(32px, 5vw, 48px)}
.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:10px}
/* AVERAGES */
.averages-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:20px}
.avg-card{background:var(--card);border-radius:var(--radius);padding:14px 10px 12px;box-shadow:var(--shadow);border-top:3px solid transparent;text-align:center;cursor:pointer;transition:transform .15s,box-shadow .15s}
.avg-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.avg-card .party-name{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:3px}
.avg-card .pct{font-size:clamp(22px, 4vw, 28px);font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:2px}
.avg-card .trend{font-size:11px;font-weight:600}
.trend-up{color:#16a34a}.trend-down{color:#dc2626}.trend-flat{color:var(--muted)}
.avg-deltas{display:flex;flex-direction:column;gap:3px;margin:7px 0 5px;padding:6px 4px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.avg-delta-row{display:flex;align-items:center;justify-content:space-between;gap:4px}
.avg-delta-row .delta-lbl{color:var(--muted);font-size:10px;text-align:left;white-space:nowrap}
.avg-delta-row .delta-val{font-weight:800;font-size:12px;font-variant-numeric:tabular-nums}
.delta-up{color:#16a34a}.delta-dn{color:#dc2626}.delta-flat{color:#9CA3AF}
.avg-card .full-name{font-size:10px;color:var(--muted);margin-top:3px}
.avg-card .seat-proj{font-size:11px;font-weight:600;color:var(--muted);margin:1px 0 4px;letter-spacing:.01em}
.avg-card.lpc{border-top-color:var(--lpc)}.avg-card.lpc .pct{color:var(--lpc)}
.avg-card.cpc{border-top-color:var(--cpc)}.avg-card.cpc .pct{color:var(--cpc)}
.avg-card.ndp{border-top-color:var(--ndp)}.avg-card.ndp .pct{color:var(--ndp)}
.avg-card.bq{border-top-color:var(--bq)}.avg-card.bq .pct{color:var(--bq)}
.avg-card.grn{border-top-color:var(--grn)}.avg-card.grn .pct{color:var(--grn)}
/* REGION ACCORDION */
.region-row{cursor:pointer;user-select:none}
.region-row:hover td{background:#F0F4FF!important}
.region-row td:first-child .toggle-arrow{display:inline-block;font-size:10px;margin-right:6px;transition:transform .2s;color:var(--muted)}
.region-row.open td:first-child .toggle-arrow{transform:rotate(90deg)}
.prov-row td{background:#FAFBFF;font-size:13px}
.prov-row td:first-child{padding-left:28px;color:var(--muted)}
.prov-row:last-of-type td{border-bottom:2px solid var(--border)}
/* PARLIAMENT */
.parl-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(16px, 3vw, 22px) clamp(16px, 3vw, 24px);margin-bottom:20px;border:1px solid var(--border)}
.parl-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:10px}
.parl-header h2{font-size:15px;font-weight:700;letter-spacing:-.2px}
.prob-banner{display:inline-block;background:#dcfce7;color:#15803d;font-size:12px;font-weight:600;padding:3px 10px;border-radius:4px}
.prob-outcomes{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.prob-chip{display:flex;align-items:center;gap:5px;background:var(--bg);border-radius:4px;padding:5px 10px;font-size:11px;font-weight:500;border-left:2px solid transparent}
.prob-chip .pc-label{color:var(--muted);font-weight:500}
.prob-chip .pc-val{font-weight:700;font-size:12px;font-variant-numeric:tabular-nums}
.parl-layout{display:flex;align-items:flex-start;gap:28px;flex-wrap:wrap}
.seat-counts{display:flex;flex-direction:column;gap:9px;min-width:220px;padding-top:4px}
.seat-row{display:flex;align-items:center;gap:10px}
.seat-swatch{width:13px;height:13px;border-radius:3px;flex-shrink:0}
.seat-label{font-size:13px;font-weight:500;flex:1}
.seat-bar-wrap{flex:2;background:#F3F4F6;border-radius:4px;height:7px;overflow:hidden}
.seat-bar{height:100%;border-radius:4px}
.seat-num{font-size:14px;font-weight:800;min-width:34px;text-align:right}
.majority-line{font-size:12px;color:var(--muted);margin-top:4px;border-top:1px dashed var(--border);padding-top:8px}
/* SEAT PROJECTION CARDS */
.seat-cards-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:14px}
.seat-card{background:var(--bg);border-radius:var(--radius);padding:14px 10px 12px;border-top:3px solid transparent;text-align:center;transition:transform .15s,box-shadow .15s}
.seat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1);cursor:pointer}
.seat-card .party-name{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:3px}
.seat-card .seat-count{font-size:clamp(22px, 4vw, 28px);font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:2px}
.seat-card .seat-label-sub{font-size:11px;font-weight:600;color:var(--muted);margin:1px 0 4px}
.seat-card .seat-deltas{display:flex;flex-direction:column;gap:3px;margin:7px 0 5px;padding:6px 4px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.seat-card .seat-delta-row{display:flex;align-items:center;justify-content:space-between;gap:4px}
.seat-card .delta-lbl{color:var(--muted);font-size:10px;text-align:left;white-space:nowrap}
.seat-card .delta-val{font-weight:800;font-size:12px;font-variant-numeric:tabular-nums}
.seat-card .full-name{font-size:10px;color:var(--muted);margin-top:3px}
.seat-card .current-seats{font-size:10px;color:var(--muted);margin-top:2px;font-weight:500}
.seat-card.lpc{border-top-color:var(--lpc)}.seat-card.lpc .seat-count{color:var(--lpc)}
.seat-card.cpc{border-top-color:var(--cpc)}.seat-card.cpc .seat-count{color:var(--cpc)}
.seat-card.ndp{border-top-color:var(--ndp)}.seat-card.ndp .seat-count{color:var(--ndp)}
.seat-card.bq{border-top-color:var(--bq)}.seat-card.bq .seat-count{color:var(--bq)}
.seat-card.grn{border-top-color:var(--grn)}.seat-card.grn .seat-count{color:var(--grn)}
/* LEADER POPULARITY CARDS */
.leader-section{margin-bottom:20px}
.leader-cards-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:8px}
.leader-card{background:var(--card);border-radius:var(--radius);padding:14px 10px 12px;box-shadow:var(--shadow);border-top:3px solid transparent;text-align:center;transition:transform .15s,box-shadow .15s;border:1px solid var(--border)}
.leader-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1);cursor:pointer}
.leader-card .leader-photo{width:56px;height:56px;border-radius:50%;margin:0 auto 8px;background-size:cover;background-position:center top;border:2px solid var(--border)}
.leader-card .leader-name{font-size:12px;font-weight:700;margin-bottom:1px;line-height:1.2}
.leader-card .leader-role{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px}
.leader-card .leader-pct{font-size:clamp(22px,4vw,28px);font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:2px}
.leader-card .leader-pct-label{font-size:11px;font-weight:600;color:var(--muted);margin:1px 0 4px}
.leader-card .leader-deltas{display:flex;flex-direction:column;gap:3px;margin:7px 0 5px;padding:6px 4px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.leader-card .leader-delta-row{display:flex;align-items:center;justify-content:space-between;gap:4px}
.leader-card .delta-lbl{color:var(--muted);font-size:10px;text-align:left;white-space:nowrap}
.leader-card .delta-val{font-weight:800;font-size:12px;font-variant-numeric:tabular-nums}
.leader-card .party-tag{font-size:10px;color:var(--muted);margin-top:3px;font-weight:600}
.leader-card.lpc{border-top-color:var(--lpc)}.leader-card.lpc .leader-pct{color:var(--lpc)}
.leader-card.cpc{border-top-color:var(--cpc)}.leader-card.cpc .leader-pct{color:var(--cpc)}
.leader-card.ndp{border-top-color:var(--ndp)}.leader-card.ndp .leader-pct{color:var(--ndp)}
.leader-card.bq{border-top-color:var(--bq)}.leader-card.bq .leader-pct{color:var(--bq)}
.leader-card.grn{border-top-color:var(--grn)}.leader-card.grn .leader-pct{color:var(--grn)}
/* AD PLACEMENTS */
/* TWO-COL */
.two-col{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;margin-bottom:20px}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(14px, 3vw, 20px);border:1px solid var(--border)}
.card h3{font-size:14px;font-weight:700;margin-bottom:2px;letter-spacing:-.1px}
.card .subtitle{font-size:11px;color:var(--muted);margin-bottom:14px}
.chart-wrap{position:relative;height:250px}
/* REGION TABLE */
.region-table{width:100%;border-collapse:collapse;font-size:13px}
.region-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:7px 9px;text-align:left;border-bottom:2px solid var(--border)}
.region-table td{padding:9px 9px;border-bottom:1px solid var(--border)}
.region-table tr:last-child td{border-bottom:none}
.region-table tr:hover td{background:#F9FAFB}
.leader-badge{display:inline-block;font-size:10px;font-weight:600;padding:2px 6px;border-radius:3px;color:#fff}
/* POLLS TABLE */
.polls-section{margin-bottom:20px}
.polls-table{width:100%;border-collapse:collapse;font-size:13px}
.polls-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:9px 13px;text-align:left;border-bottom:2px solid var(--border)}
.polls-table td{padding:10px 13px;border-bottom:1px solid var(--border);vertical-align:middle}
.polls-table tr:last-child td{border-bottom:none}
.polls-table tr:hover td{background:#F9FAFB}
.pollster-name{font-weight:600}
.method-badge{font-size:11px;font-weight:600;padding:2px 6px;border-radius:6px;background:#F3F4F6;color:var(--muted)}
.new-badge{font-size:10px;font-weight:700;background:#FEF3C7;color:#92400E;padding:1px 5px;border-radius:10px;margin-left:5px}
/* RIDING TABLE */
.riding-section{margin-bottom:20px}
.riding-controls{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
.find-riding-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow)}
.riding-search{flex:1;min-width:200px;padding:9px 12px;border:1px solid var(--border);border-radius:6px;font-family:'Inter',sans-serif;font-size:14px;outline:none;transition:border .15s}
.riding-search:focus{border-color:#1A4785;box-shadow:0 0 0 3px rgba(26,71,133,.12)}
.riding-filter{padding:7px 10px;border:1px solid var(--border);border-radius:4px;font-family:'Inter',sans-serif;font-size:12px;outline:none;background:#fff;cursor:pointer}
.riding-filter:focus{border-color:#9CA3AF}
.riding-count{font-size:13px;color:var(--muted);white-space:nowrap}
.riding-table-wrap{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--border)}
.riding-table{width:100%;border-collapse:collapse;font-size:13px}
.riding-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:10px 13px;text-align:left;border-bottom:2px solid var(--border);background:#FAFAFA;white-space:nowrap;cursor:pointer;user-select:none}
.riding-table th:hover{background:#F3F4F6}
.riding-table td{padding:9px 13px;border-bottom:1px solid var(--border);vertical-align:middle}
.riding-table tr:last-child td{border-bottom:none}
.riding-table tbody tr:hover td{background:#F9FAFB}
.riding-name{font-weight:600;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prov-tag{font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px;background:#F3F4F6;color:var(--muted)}
.rating-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:3px;white-space:nowrap}
.r-safe-lpc{background:#fee2e2;color:#991b1b}
.r-likely-lpc{background:#fecaca;color:#b91c1c}
.r-lean-lpc{background:#fde8e8;color:#c02626}
.r-tossup{background:#F3F4F6;color:#374151}
.r-lean-cpc{background:#dbeafe;color:#1d4ed8}
.r-likely-cpc{background:#bfdbfe;color:#1e40af}
.r-safe-cpc{background:#93c5fd;color:#1e3a8a}
.r-safe-bq{background:#cce5f5;color:#1e6a9e}
.r-likely-bq{background:#d9edf8;color:#2577a8}
.r-lean-bq{background:#e8f4fb;color:#2d84b8}
.r-safe-ndp{background:#fed7aa;color:#92400e}
.r-likely-ndp{background:#ffedd5;color:#9a3412}
.r-lean-ndp{background:#fff7ed;color:#a16207}
.r-lean-grn{background:#dcfce7;color:#166534}
.r-likely-grn{background:#bbf7d0;color:#15803d}
.r-safe-grn{background:#86efac;color:#14532d}
.winner-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle}
.pct-sm{font-size:12px;color:var(--text)}
.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);background:#FAFAFA;font-size:13px}
.page-btn{padding:5px 12px;min-height:44px;display:inline-flex;align-items:center;border:1.5px solid var(--border);background:#fff;border-radius:6px;cursor:pointer;font-size:13px;font-family:'Inter',sans-serif}
.page-btn:hover{background:#F3F4F6}
.page-btn:disabled{opacity:.4;cursor:not-allowed}
/* SCENARIO */
.scenario-section{background:#1a1f2e;border-radius:var(--radius);padding:clamp(16px, 3vw, 24px);margin-bottom:20px;color:#fff;border:1px solid rgba(255,255,255,.06)}
.scenario-section h2{font-size:15px;font-weight:700;margin-bottom:3px;letter-spacing:-.2px}
.scenario-section .subtitle{font-size:12px;color:rgba(255,255,255,.45);margin-bottom:18px}
.scenario-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:28px;align-items:start}
.sliders{display:flex;flex-direction:column;gap:16px}
.slider-row label{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;margin-bottom:6px}
.slider-row .lbl-name{display:flex;align-items:center;gap:7px}
.slider-row .party-pip{width:9px;height:9px;border-radius:50%;display:inline-block}
.slider-row label span{font-size:18px;font-weight:900;font-variant-numeric:tabular-nums}
input[type=range]{width:100%;height:6px;border-radius:3px;outline:none;cursor:pointer;-webkit-appearance:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.4)}
/* Scenario results panel */
.sc-panel{display:flex;flex-direction:column;gap:0}
#scParl{display:block;width:100%;border-radius:8px;margin-bottom:14px}
.sc-seat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;margin-bottom:12px}
.sc-seat-item{text-align:center;padding:8px 4px 7px;background:rgba(255,255,255,.05);border-radius:6px;border:1px solid rgba(255,255,255,.07)}
.sc-pip{width:8px;height:8px;border-radius:50%;margin:0 auto 3px}
.sc-pname{display:block;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:rgba(255,255,255,.4);margin-bottom:2px}
.sc-snum{display:block;font-size:20px;font-weight:700;line-height:1;letter-spacing:-.5px}
.sc-delta{display:block;font-size:10px;font-weight:600;margin-top:3px;min-height:14px}
.sc-delta-up{color:#4ade80}.sc-delta-dn{color:#f87171}.sc-delta-eq{color:rgba(255,255,255,.3)}
.sc-divider{height:1px;background:rgba(255,255,255,.1);margin:4px 0 10px}
#sc-status{font-size:14px;font-weight:800;padding:10px 16px;border-radius:8px;text-align:center}
.status-majority{background:rgba(34,197,94,.18);color:#86efac;border:1px solid rgba(34,197,94,.3)}
.status-minority{background:rgba(251,191,36,.18);color:#fde68a;border:1px solid rgba(251,191,36,.3)}
.status-hung{background:rgba(239,68,68,.18);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.reset-btn{margin-top:14px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.18);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;font-family:'Inter',sans-serif;transition:all .15s;width:100%}
.reset-btn:hover{background:rgba(255,255,255,.16);color:#fff}
.sc-dist-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;margin-bottom:4px}
.sc-dist-bar .seg{height:100%;transition:width .25s ease;min-width:0}
.sc-other-row{opacity:.55}
.sc-other-row .vb-track-dark{flex:1;height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden}
.sc-other-row .vb-fill-dark{height:100%;background:rgba(255,255,255,.22);border-radius:3px;transition:width .25s ease}
/* METHODOLOGY */
.method-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(16px, 3vw, 24px);margin-bottom:20px;border:1px solid var(--border)}
.method-section h2{font-family:var(--serif);font-size:18px;font-weight:600;margin-bottom:4px;letter-spacing:-.2px}
.method-section>p{margin-top:2px}
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.method-item{padding:14px 16px;background:transparent;border-radius:6px;border:1px solid var(--border);border-left:none}
.method-item h4{font-size:12px;font-weight:700;margin-bottom:4px;color:var(--text)}
.method-item p{font-size:12px;color:var(--muted);line-height:1.65}
.compare-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:12px}
.compare-table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:2px solid var(--border);background:var(--bg)}
.compare-table th:not(:first-child){text-align:center}
.compare-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top}
.compare-table td:not(:first-child){text-align:center}
.compare-table tr:last-child td{border-bottom:none}
.compare-table .feat-label{font-weight:600;color:var(--text);white-space:nowrap}
.compare-table .cmp-yes{color:#16a34a;font-weight:700}
.compare-table .cmp-no{color:#dc2626;font-weight:600}
.compare-table .cmp-partial{color:#d97706;font-weight:600}
.compare-table .cmp-highlight{background:rgba(215,25,32,.04)}
.compare-table thead th:nth-child(2){color:var(--lpc);border-bottom-color:var(--lpc)}
.compare-table thead th:nth-child(3){color:var(--muted)}
footer:not(.site-footer){background:var(--header);color:rgba(255,255,255,.4);padding:20px clamp(16px, 4vw, 32px);text-align:center;font-size:12px;line-height:1.6}
footer:not(.site-footer) strong{color:rgba(255,255,255,.7)}
footer:not(.site-footer) a{color:rgba(255,255,255,.5);text-decoration:none}
footer:not(.site-footer) a:hover{color:rgba(255,255,255,.8)}
.site-footer{background:var(--header);color:rgba(255,255,255,.35);padding:16px clamp(16px, 4vw, 32px);font-size:11px;border-top:1px solid rgba(255,255,255,.06)}
.site-footer .footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-links{display:flex;gap:16px}
.footer-links a{color:rgba(255,255,255,.4);text-decoration:none;font-size:11px;transition:color .15s}
.footer-links a:hover{color:rgba(255,255,255,.7)}

/* ══════════════════════════════════════════════════════════════
   FEATURE 1 — WHY DID THIS CHANGE? (change badges + explain card)
   ══════════════════════════════════════════════════════════════ */
.change-badge{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;font-size:8px;font-weight:900;margin-left:5px;vertical-align:middle;flex-shrink:0;cursor:help}
.cb-high{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5}
.cb-medium{background:#fffbeb;color:#d97706;border:1px solid #fcd34d}
.cb-low{background:#f0f9ff;color:#0284c7;border:1px solid #93c5fd}
tr.riding-changed td:first-child{font-weight:600}
.explain-card{background:#FFFDF5;border:1px solid #e5e2d5;border-left:3px solid #d4a017;border-radius:6px;padding:12px 14px;margin-bottom:14px}
.explain-card h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#92400e;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.explain-change-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px}
.explain-change-list li{font-size:13px;color:var(--text);display:flex;align-items:flex-start;gap:7px}
.explain-change-list li::before{content:'•';font-size:16px;line-height:1;color:var(--text);flex-shrink:0;margin-top:0px}
.ecl-winner::before{color:var(--text)!important}
.ecl-class::before{color:var(--text)!important}
.ecl-tight::before{color:var(--text)!important}
.ecl-wide::before{color:var(--text)!important}
.explain-date{font-size:10px;color:#a16207;margin-top:6px}

/* ══════════════════════════════════════════════════════════════
   FEATURE 2 — STRATEGIC VOTING ASSISTANT
   ══════════════════════════════════════════════════════════════ */
.sv-section{background:#F8FAFB;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}
.sv-section h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#0369a1;margin-bottom:12px;display:flex;align-items:center;gap:7px}
.sv-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.sv-label{font-size:12px;font-weight:600;color:#0c4a6e;white-space:nowrap}
.sv-select{font-family:'Inter',sans-serif;font-size:13px;font-weight:500;padding:7px 10px;border-radius:8px;border:1.5px solid #7dd3fc;background:#fff;color:var(--text);cursor:pointer;flex:1;min-width:180px}
.sv-select:focus{outline:2px solid #38bdf8;outline-offset:1px}
.sv-result{border-radius:10px;padding:14px;background:#fff;border:1.5px solid #7dd3fc;display:flex;gap:12px;align-items:flex-start}
.sv-result.sv-warning{border-color:#fcd34d;background:#fffbeb}
.sv-rec-party{font-size:28px;font-weight:900;letter-spacing:-1px;white-space:nowrap;min-width:52px}
.sv-rec-body{}
.sv-rec-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:3px}
.sv-rec-explanation{font-size:13px;color:var(--text);line-height:1.5}
.sv-standings{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.sv-stand-chip{font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;background:#F4F6FA}
.sv-viability{font-size:10px;margin-top:2px;color:var(--muted)}

/* ══════════════════════════════════════════════════════════════
   FEATURE 3 — QUICK VIEWS + SMART FILTERS
   ══════════════════════════════════════════════════════════════ */
.quick-views{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:10px;padding:8px 12px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.qv-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-right:2px;white-space:nowrap}
.qv-btn{font-family:'Inter',sans-serif;font-size:11px;font-weight:600;padding:4px 10px;display:inline-flex;align-items:center;min-height:44px;border-radius:4px;border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;transition:all .15s;white-space:nowrap}
.qv-btn:hover{border-color:#9CA3AF;background:#F9FAFB}
.qv-btn.qv-active{background:var(--header);color:#fff;border-color:var(--header)}
.qv-btn.qv-lpc.qv-active{background:var(--lpc);border-color:var(--lpc)}
.qv-btn.qv-cpc.qv-active{background:var(--cpc);border-color:var(--cpc)}
.qv-btn.qv-ndp.qv-active{background:var(--ndp);border-color:var(--ndp)}
.qv-btn.qv-bq.qv-active{background:var(--bq);border-color:var(--bq)}
.qv-btn.qv-change.qv-active{background:#f59e0b;border-color:#f59e0b;color:#fff}
.qv-result-note{font-size:11px;color:var(--muted);padding:4px 0 0;display:none}
.qv-result-note.visible{display:block}

/* ── RIDING DETAIL MODAL ───────────────────────────────────── */
.riding-modal{position:fixed;inset:0;z-index:1000;background:rgba(15,23,42,.55);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.riding-modal.open{opacity:1;pointer-events:all}
.riding-modal-card{background:#fff;border-radius:12px 12px 0 0;width:100%;max-width:720px;max-height:92vh;overflow-y:auto;transform:translateY(40px);transition:transform .25s cubic-bezier(.32,1,.55,1);display:flex;flex-direction:column}
.riding-modal.open .riding-modal-card{transform:translateY(0)}
.modal-header{padding:18px 24px 14px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff;z-index:2;border-radius:12px 12px 0 0}
.modal-close{position:absolute;top:14px;right:16px;width:28px;height:28px;border-radius:4px;border:none;background:transparent;cursor:pointer;font-size:16px;line-height:28px;text-align:center;color:#9CA3AF;transition:all .15s}
.modal-close:hover{background:#F3F4F6;color:#374151}
.modal-riding-title{font-family:var(--serif);font-size:18px;font-weight:600;margin:0 0 4px;padding-right:40px}
.modal-riding-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.modal-body{padding:20px 24px 28px;display:flex;flex-direction:column;gap:22px}
/* Vote comparison bars */
.vote-section h3,.trend-section h3,.mp-section h3,.demo-section h3,.nearby-section h3{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin:0 0 10px}
.vote-cols{display:grid;grid-template-columns:1fr;gap:18px}
.vote-col-label{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.4px}
.vb-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.vb-party{font-size:12px;font-weight:700;width:34px;flex-shrink:0}
.vb-track{flex:1;height:10px;background:#F3F4F6;border-radius:5px;overflow:hidden}
.vb-fill{height:100%;border-radius:5px;transition:width .4s cubic-bezier(.4,0,.2,1)}
.vb-pct{font-size:12px;font-weight:600;width:36px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}
.vb-swing{font-size:11px;font-weight:700;width:42px;text-align:right;flex-shrink:0}
.swing-up{color:#16a34a}.swing-dn{color:#dc2626}.swing-eq{color:#9CA3AF}
/* Trend chart */
.modal-chart-wrap{height:170px;position:relative}
/* MP card */
.mp-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#FAFAFA;border-radius:6px;border:1px solid var(--border)}
.mp-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:#fff;flex-shrink:0;font-family:'Inter',sans-serif}
.mp-info .mp-name{font-size:14px;font-weight:600;margin:0 0 1px}
.mp-info .mp-party{font-size:11px;font-weight:600;color:var(--muted)}
.mp-info .mp-since{font-size:11px;color:var(--muted);margin-top:1px}
/* Demographics */
.demo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.demo-stat{padding:10px;background:#FAFAFA;border-radius:6px;border:1px solid var(--border);text-align:center}
.demo-stat .ds-val{font-size:16px;font-weight:700;display:block;line-height:1;font-variant-numeric:tabular-nums}
.demo-stat .ds-lbl{font-size:10px;color:var(--muted);margin-top:3px;display:block}
/* About */
.about-text{font-family:var(--serif);font-size:14px;line-height:1.75;color:#374151;background:transparent;border-radius:0;padding:0;border-left:none}
/* Nearby ridings */
.nearby-chips{display:flex;flex-wrap:wrap;gap:8px}
.nearby-chip{display:flex;align-items:center;gap:5px;padding:5px 10px;min-height:44px;border-radius:4px;background:#F3F4F6;border:1px solid var(--border);cursor:pointer;font-size:11px;font-weight:600;transition:background .15s;color:var(--text)}
.nearby-chip:hover{background:#E5E7EB}
.nc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
/* Clickable table rows */
.riding-table tbody tr{cursor:pointer}
.riding-table tbody tr:hover td{background:#F5F7FA}
/* ─── RESPONSIVE: TABLET (≤ 900px) ─── */
@media(max-width:900px){
  .hamburger-btn{display:flex}
  #mobile-nav{display:none;position:absolute;top:52px;left:0;right:0;flex-direction:column;background:var(--header);border-bottom:1px solid rgba(255,255,255,.06);gap:0;z-index:99}
  #mobile-nav.open{display:flex}
  #mobile-nav a{padding:12px 16px;border-radius:0;border:none}
  #mobile-nav a:hover{background:rgba(255,255,255,.12)}
  .averages-grid{grid-template-columns:repeat(3,1fr)}
  .seat-cards-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .leader-cards-grid{grid-template-columns:repeat(3,1fr);gap:6px}
  .two-col{grid-template-columns:1fr}
  .scenario-grid{grid-template-columns:1fr}
  .method-grid{grid-template-columns:1fr}
  nav{display:flex}
  .parl-layout{flex-direction:column}
  .ptv-overview-grid{grid-template-columns:1fr 1fr!important}
  .ptv-seat-path{flex-wrap:wrap}
  .ptv-narratives{grid-template-columns:1fr 1fr!important}
  .ptv-bottom-grid{grid-template-columns:1fr!important}
  .method-grid{grid-template-columns:1fr 1fr}
  .vote-cols{grid-template-columns:1fr}
  .demo-grid{grid-template-columns:repeat(2,1fr)}
}

/* ─── RESPONSIVE: LARGE PHONE (≤ 640px) ─── */
@media(max-width:640px){
  body{font-size:13px}
  header{padding:0 16px}
  .header-inner{height:48px}
  .logo-icon{width:24px;height:24px;font-size:12px;border-radius:4px}
  .logo-text{font-size:15px}
  .hero-inner{padding:22px 16px 0}
  .hero h1{font-size:21px}
  .hero-sub{font-size:13px;margin-bottom:12px}
  .hero-meta{gap:8px;font-size:11px;flex-wrap:wrap}
  .built-in-public{padding:20px 16px}
  .built-in-public h2{font-size:14px}
  .built-in-public p{font-size:12px}
  .hero-cta{padding:9px 18px;font-size:12px;min-height:40px;display:inline-flex;align-items:center}
  main{padding:16px 12px 40px}
  .section-title{font-size:10px;margin-bottom:8px}

  /* Averages: 2-col on phone */
  .averages-grid{grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:14px}
  .seat-cards-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .leader-cards-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .leader-card .leader-photo{width:44px;height:44px}
  .leader-card .leader-name{font-size:11px}
  .leader-card .leader-pct{font-size:24px}
  .leader-card .leader-deltas{margin:5px 0 4px;padding:4px 2px}
  .leader-card .delta-lbl{font-size:9px}
  .leader-card .delta-val{font-size:11px}
  .avg-card{padding:10px 8px 8px;border-top-width:2px}
  .avg-card .pct{font-size:24px}
  .avg-card .pct small{font-size:13px!important}
  .avg-card .party-name{font-size:9px}
  .avg-card .full-name{font-size:9px}
  .seat-card{padding:10px 8px 8px;border-top-width:2px}
  .seat-card .seat-count{font-size:24px}
  .seat-card .party-name{font-size:9px}
  .seat-card .full-name{font-size:9px}
  .seat-card .seat-deltas{margin:5px 0 4px;padding:4px 2px}
  .seat-card .delta-lbl{font-size:9px}
  .seat-card .delta-val{font-size:11px}
  .avg-deltas{margin:5px 0 4px;padding:4px 2px}
  .avg-delta-row .delta-lbl{font-size:9px}
  .avg-delta-row .delta-val{font-size:11px}

  /* Parliament section */
  .parl-section{padding:14px 12px;margin-bottom:14px}
  .parl-header h2{font-size:14px}
  .parl-header p{font-size:10px!important}
  .prob-outcomes{gap:4px;margin-top:10px;padding-top:10px}
  .prob-chip{padding:4px 7px;font-size:10px}
  .prob-chip .pc-val{font-size:11px}
  .parl-layout{gap:16px}
  .seat-counts{min-width:0;width:100%}
  #parlCanvas{max-width:100%;height:auto!important}

  /* Poll tracker + Regional */
  .two-col{gap:12px;margin-bottom:14px}
  .card{padding:14px 12px}
  .card h3{font-size:13px}
  .chart-wrap{height:200px}

  /* Tables: horizontal scroll on mobile */
  .table-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .riding-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .polls-table{min-width:640px}
  .region-table{min-width:520px}
  .riding-table{min-width:600px}

  /* Polls section */
  .polls-section{margin-bottom:14px}
  .polls-table th,.polls-table td{padding:7px 8px;font-size:12px}

  /* Quick views */
  .quick-views{padding:8px 10px;gap:5px}
  .qv-btn{padding:6px 9px;font-size:11px}

  /* Riding controls: stack on mobile */
  .riding-controls{flex-direction:column;gap:8px;align-items:stretch}
  .riding-search{min-width:0;width:100%;padding:10px 12px;font-size:14px}
  .riding-filter{width:100%;padding:10px 12px;font-size:14px}
  .riding-count{text-align:center}
  .riding-section{margin-bottom:14px}

  /* Riding table */
  .riding-table th{padding:8px 10px;font-size:10px}
  .riding-table td{padding:7px 10px;font-size:12px}
  .riding-name{max-width:150px;font-size:12px}
  .prov-tag{font-size:10px;padding:1px 5px}
  .rating-badge{font-size:9px;padding:2px 6px}
  .table-pagination{padding:10px 12px;font-size:12px}
  .page-btn{padding:8px 14px;font-size:13px;min-height:44px}

  /* Scenario modeler */
  .scenario-section{padding:16px 14px;margin-bottom:14px}
  .scenario-section h2{font-size:14px}
  .scenario-grid{gap:18px}
  .slider-row label{font-size:12px}
  .slider-row label span{font-size:16px}
  input[type=range]::-webkit-slider-thumb{width:24px;height:24px}
  input[type=range]::-moz-range-thumb{width:24px;height:24px}
  .sc-seat-grid{grid-template-columns:repeat(5,1fr);gap:3px}
  .sc-seat-item{padding:6px 2px 5px}
  .sc-pname{font-size:8px;letter-spacing:.3px}
  .sc-snum{font-size:16px}
  .sc-delta{font-size:9px}
  #sc-status{font-size:12px;padding:8px 10px}
  .reset-btn{padding:10px 16px;font-size:13px;min-height:44px}
  #scParl{border-radius:6px}

  /* Methodology */
  .method-section{padding:16px 14px;margin-bottom:14px}
  .method-section h2{font-size:16px}
  .method-section>p{font-size:12px!important}
  .method-grid{grid-template-columns:1fr!important;gap:8px}
  .method-item{padding:12px}
  .method-item h4{font-size:11px}
  .method-item p{font-size:11px}

  /* Paths to Victory */
  .paths-section{padding:16px 14px;margin-bottom:14px}
  .ptv-party-tabs{gap:5px;margin-bottom:14px}
  .ptv-tab{padding:8px 12px;font-size:11px;min-height:44px}
  .ptv-overview-grid{grid-template-columns:1fr!important;gap:8px}
  .ptv-overview-card .ptv-card-val{font-size:22px}
  .ptv-narratives{grid-template-columns:1fr!important;gap:8px}
  .ptv-narrative-card{padding:12px}
  .ptv-tipping-table{font-size:11px}
  .ptv-tipping-table th{font-size:9px;padding:4px 6px}
  .ptv-tipping-table td{padding:5px 6px}
  .ptv-region-name{width:70px;font-size:11px}
  .ptv-region-count{width:50px;font-size:10px}
  .ptv-disclaimer{font-size:10px;padding:10px 12px}
  .ptv-fragility{padding:12px}
  .ptv-frag-title{font-size:12px}
  .ptv-frag-desc{font-size:11px}

  /* Footer */
  footer:not(.site-footer){padding:16px}
  footer:not(.site-footer){font-size:11px}
  .site-footer{padding:14px 16px}
  .site-footer .footer-inner{flex-direction:column;text-align:center;gap:8px}
  .footer-links{justify-content:center}

  /* Modal responsive */
  .riding-modal-card{border-radius:8px 8px 0 0;max-height:95vh}
  .modal-header{padding:14px 16px 12px;border-radius:8px 8px 0 0}
  .modal-riding-title{font-size:16px}
  .modal-close{top:12px;right:12px}
  .modal-body{padding:14px 16px 20px;gap:16px}
  .vote-section h3,.trend-section h3,.mp-section h3,.demo-section h3,.nearby-section h3{font-size:10px;margin-bottom:8px}
  .vote-cols{grid-template-columns:1fr;gap:14px}
  .vote-col-label{font-size:11px}
  .vb-row{gap:5px;margin-bottom:5px}
  .vb-party{font-size:11px;width:28px}
  .vb-pct{font-size:11px;width:32px}
  .vb-swing{font-size:10px;width:36px}
  .vb-track{height:8px}
  .modal-chart-wrap{height:140px}
  .mp-card{padding:10px 12px;gap:10px}
  .mp-avatar{width:38px;height:38px;font-size:15px}
  .mp-info .mp-name{font-size:13px}
  .demo-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .demo-stat{padding:8px 6px}
  .demo-stat .ds-val{font-size:15px}
  .demo-stat .ds-lbl{font-size:9px}
  .about-text{font-size:13px;line-height:1.7}
  .nearby-chips{gap:5px}
  .sv-section{padding:12px}
  .sv-section h3{font-size:12px}
  .sv-controls{gap:6px}
  .sv-select{font-size:14px;padding:8px 10px;min-height:40px}
  .sv-result{flex-direction:column;gap:8px;padding:12px}
  .sv-rec-party{font-size:22px}
  .sv-rec-explanation{font-size:12px}
  .explain-card{padding:10px 12px}
  .explain-card h4{font-size:10px}
  .explain-change-list li{font-size:12px}
}

/* ─── RESPONSIVE: SMALL PHONE (≤ 380px) ─── */
@media(max-width:380px){
  main{padding:12px 8px 32px}
  .hero-inner{padding:16px 12px 0}
  .hero h1{font-size:18px}
  .hero-sub{font-size:12px}
  .hero-ticker-wrap{height:30px}
  .hero-ticker{height:30px}
  .ticker-item{padding:0 14px}
  .ticker-pct{font-size:12px}
  .ticker-party{font-size:9px}
  .leader-ticker-wrap{height:34px;margin:8px 0 12px}
  .leader-ticker-outer{height:34px}
  .leader-ticker{height:34px}
  .leader-ticker .lt-item{padding:0 14px;font-size:11px}
  .leader-ticker .lt-photo{width:20px;height:20px}
  .leader-ticker .lt-name{font-size:10px}
  .leader-ticker .lt-pct{font-size:13px}
  .leader-ticker-title{font-size:8px;padding:0 8px}
  .averages-grid{grid-template-columns:1fr 1fr;gap:4px}
  .seat-cards-grid{grid-template-columns:1fr 1fr;gap:4px}
  .leader-cards-grid{grid-template-columns:1fr 1fr;gap:4px}
  .leader-card .leader-pct{font-size:22px}
  .leader-card .leader-photo{width:40px;height:40px}
  .avg-card .pct{font-size:22px}
  .seat-card .seat-count{font-size:22px}
  .parl-section{padding:12px 8px}
  .prob-outcomes{flex-direction:column;gap:3px}
  .prob-chip{width:100%}
  .scenario-section{padding:14px 10px}
  .sc-seat-grid{grid-template-columns:repeat(3,1fr);gap:4px}
  .paths-section{padding:14px 10px}
  .ptv-tab{padding:7px 10px;font-size:10px}
  .method-section{padding:14px 10px}
  .quick-views{flex-direction:row;flex-wrap:wrap}
  .qv-label{width:100%;margin-bottom:2px}
  .riding-search{font-size:16px}
  .riding-filter{font-size:16px}
}
/* ── PATHS TO VICTORY ───────────────────────────────────────── */
.paths-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(16px, 3vw, 22px) clamp(16px, 3vw, 24px);margin-bottom:20px}
.ptv-party-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.ptv-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;min-height:44px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.ptv-tab:hover{opacity:.85}
.ptv-tab.active{color:#fff}
.ptv-tab-lpc{border-color:var(--lpc)}.ptv-tab-lpc.active{background:var(--lpc);border-color:var(--lpc)}
.ptv-tab-cpc{border-color:var(--cpc)}.ptv-tab-cpc.active{background:var(--cpc);border-color:var(--cpc)}
.ptv-tab-ndp{border-color:var(--ndp)}.ptv-tab-ndp.active{background:var(--ndp);border-color:var(--ndp)}
.ptv-tab-bq{border-color:var(--bq)}.ptv-tab-bq.active{background:var(--bq);border-color:var(--bq)}
.ptv-tab-grn{border-color:var(--grn)}.ptv-tab-grn.active{background:var(--grn);border-color:var(--grn)}
.ptv-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}
/* Overview cards */
.ptv-overview-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:18px}
.ptv-overview-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:16px 18px;position:relative}
.ptv-overview-card .ptv-card-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:4px}
.ptv-overview-card .ptv-card-val{font-size:26px;font-weight:800;line-height:1.1;margin-bottom:2px}
.ptv-overview-card .ptv-card-sub{font-size:11px;color:var(--muted)}
.ptv-overview-card .ptv-card-note{font-size:10px;color:var(--muted);opacity:.7;margin-top:2px;font-style:italic}
.ptv-disclaimer{margin-top:24px;padding:12px 16px;background:rgba(255,193,7,.08);border:1px solid rgba(255,193,7,.3);border-radius:8px;font-size:11px;color:var(--muted);line-height:1.6}
.ptv-disclaimer strong{color:var(--text);font-weight:700}
.ptv-win-bar-wrap{margin:0 0 18px}
.ptv-win-bar-label{font-size:11px;color:var(--muted);margin-bottom:6px;display:flex;justify-content:space-between}
.ptv-win-bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:4px}
.ptv-win-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}
/* Seat path bar */
.ptv-path-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:10px}
.ptv-seat-path{display:flex;height:28px;border-radius:6px;overflow:hidden;margin-bottom:8px;gap:1px}
.ptv-seg{display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;min-width:0;transition:flex .4s ease;overflow:hidden;white-space:nowrap}
.ptv-seg-label{padding:0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ptv-path-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.ptv-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}
.ptv-legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
/* Fragility */
.ptv-fragility{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:18px}
.ptv-fragility-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.ptv-frag-icon{font-size:18px}
.ptv-frag-title{font-size:13px;font-weight:700}
.ptv-frag-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}
.frag-robust{background:#16a34a22;color:#16a34a;border:1px solid #16a34a55}
.frag-moderate{background:#ca8a0422;color:#d97706;border:1px solid #ca8a0455}
.frag-fragile{background:#dc262622;color:#dc2626;border:1px solid #dc262655}
.ptv-frag-desc{font-size:12px;color:var(--muted);line-height:1.5}
/* Tipping point ridings */
.ptv-tipping-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:4px}
.ptv-tipping-table th{text-align:left;padding:5px 8px;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}
.ptv-tipping-table td{padding:6px 8px;border-bottom:1px solid var(--border)22}
.ptv-tipping-table tr.ptv-riding-row{cursor:pointer;transition:background .1s}
.ptv-tipping-table tr.ptv-riding-row:hover{background:var(--border)33}
.ptv-prob-bar{display:flex;align-items:center;gap:6px}
.ptv-prob-track{width:60px;height:5px;background:var(--border);border-radius:3px;overflow:hidden;flex-shrink:0}
.ptv-prob-fill{height:100%;border-radius:3px}
.ptv-prob-pct{font-size:10px;color:var(--muted);width:28px;text-align:right;flex-shrink:0}
/* Region dependency */
.ptv-region-grid{display:grid;gap:6px}
.ptv-region-row{display:flex;align-items:center;gap:8px}
.ptv-region-name{font-size:12px;font-weight:600;width:90px;flex-shrink:0}
.ptv-region-bar-track{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.ptv-region-bar-fill{height:100%;border-radius:4px;opacity:.75}
.ptv-region-count{font-size:11px;color:var(--muted);width:60px;text-align:right;flex-shrink:0}
/* Narratives */
.ptv-narratives{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:4px}
.ptv-narrative-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 15px}
.ptv-narrative-icon{font-size:16px;margin-bottom:6px}
.ptv-narrative-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px}
.ptv-narrative-text{font-size:12px;color:var(--text);line-height:1.55}
/* Bottom grid */
.ptv-bottom-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-top:18px}
.ptv-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:10px}
/* Threshold line on seat path */
.ptv-path-wrap{position:relative;margin-bottom:24px}
.ptv-threshold-marker{position:absolute;top:0;height:28px;width:2px;background:#fff;opacity:.7;pointer-events:none}
.ptv-threshold-tip{position:absolute;top:30px;transform:translateX(-50%);font-size:9px;color:var(--muted);white-space:nowrap}
