:root{
  --ink:#2A2540; --subink:#6B6585; --grid:#E7E3F1; --bg:#FCFBFE;
  --accent:#8C7AC9; --highlight:#6D28D9; --deep:#4C1D95;
  --panel:#FFFFFF; --line:#EBE7F4; --soft:#F6F3FC;
  --win:#16794a; --warn:#B45309;
  --font:"Inter","Helvetica Neue",Helvetica,Arial,system-ui,sans-serif;
  --shadow:0 1px 2px rgba(42,37,64,.04),0 4px 16px rgba(42,37,64,.06);
}
*{box-sizing:border-box}
/* The `hidden` attribute must win over author `display` rules (e.g. .ctrl below
   sets display:flex, which otherwise overrides the UA [hidden]{display:none}
   and leaves toggled controls like #cmpPicker always visible). */
[hidden]{display:none !important}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font); font-size:16px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:1280px; margin:0 auto; padding:0 24px}
/* Mobile (M1): keep all form controls >=16px so iOS Safari doesn't zoom the
   page on focus (and then fail to zoom back out). */
select, input, textarea{font-size:16px}

/* masthead */
.masthead{
  background:linear-gradient(180deg,var(--soft) 0%,var(--bg) 100%);
  border-bottom:1px solid var(--line); padding:30px 0 22px;
}
.tab{width:46px; height:6px; background:var(--highlight); border-radius:2px; margin-bottom:14px}
.masthead h1{font-size:29px; line-height:1.12; margin:0 0 8px; letter-spacing:-.015em}
.deck{color:var(--subink); margin:0; font-size:15px; max-width:760px}

/* masthead layout: title/deck stacked ABOVE the nav pill row (full width) so the
   title isn't squished by the pills. Mobile already stacked; this matches desktop. */
.masthead-inner{display:flex; flex-direction:column; align-items:flex-start; gap:16px}
.masthead-title{min-width:0}

/* site nav pills */
.site-nav{display:flex; flex:0 0 auto; align-items:center; gap:8px; flex-wrap:wrap; padding-top:2px}
.site-nav a{
  display:inline-flex; align-items:center;
  color:var(--highlight); text-decoration:none;
  font-weight:600; font-size:.85rem;
  border:1.5px solid var(--highlight); border-radius:999px;
  padding:.5rem 1.1rem; min-height:44px;
  white-space:nowrap; transition:background .15s,color .15s;
}
.site-nav a:hover{background:var(--highlight); color:#fff}
.site-nav a.active{background:var(--highlight); color:#fff; pointer-events:none}
/* nav disclosure: desktop (>560px) renders as today's flat pill row regardless of [open] */
.site-nav summary{display:none}
.site-nav .nav-links{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.site-nav .nav-divider{display:none}
/* TEMP: hide the Ranked Choice tab while rcv.html shows SAMPLE data only (task
   6caaf85e). The page + assets stay shipped and reachable by direct URL; remove
   this one rule (and its guard test) to re-link it once official BOE RCV data
   replaces data/rcv.json. Applies in both desktop and mobile breakpoints. */
.site-nav .nav-links a[href="rcv.html"]{display:none}
/* Chromium 131+ hides a closed <details>'s content via content-visibility:hidden on
   the ::details-content wrapper, which the .nav-links display override above can't
   defeat — that blanked the desktop nav. Un-hide the wrapper on desktop (where the
   disclosure is never [open]). Older engines lack ::details-content and ignore this,
   relying on the display override instead. Scoped to >560px so mobile still collapses. */
@media (min-width:561px){
  .site-nav .nav-disclosure::details-content{content-visibility:visible}
}

/* controls bar (sticky) */
.controls{
  position:sticky; top:0; z-index:1000;
  background:rgba(252,251,254,.94); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.controls-inner{display:flex; flex-wrap:wrap; gap:18px; align-items:flex-end; padding:14px 24px}
.ctrl{display:flex; flex-direction:column; gap:5px}
.ctrl-lbl{font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--subink)}
.controls select{
  font:inherit; font-size:16px; color:var(--ink); background:#fff;
  border:1px solid var(--line); border-radius:9px; padding:10px 12px; min-width:240px;
  min-height:44px; cursor:pointer; box-shadow:var(--shadow);
}
.controls select:focus{outline:2px solid var(--accent); outline-offset:1px}
.scope-note{font-size:13px; color:var(--subink); padding-bottom:9px; align-self:flex-end}
.scope-note b{color:var(--highlight)}

/* head-to-head pair picker */
.cmp-row{display:flex; align-items:center; gap:6px}
.cmp-row select{min-width:120px}
.cmp-vs{font-size:12px; font-weight:700; color:var(--subink); text-transform:uppercase}

/* three-stop scale ends for the diverging compare legend */
.legend .scale-ends-3 span:nth-child(2){flex:1; text-align:center}

/* cross-contest precinct profile */
.xcross{margin-top:6px; border-top:1px solid var(--line); padding-top:6px}
.xc-list{display:flex; flex-direction:column; gap:1px}
.xc-row{display:grid; grid-template-columns:1fr auto; gap:2px 10px; align-items:center;
  padding:6px 8px; border-radius:8px; cursor:pointer}
.xc-row:hover{background:var(--soft)}
.xc-row.active{background:rgba(109,40,217,.08)}
.xc-contest{font-size:13px; color:var(--ink); min-width:0}
.xc-leader{font-size:12.5px; color:var(--subink); display:flex; align-items:center; gap:6px;
  white-space:nowrap; justify-self:end}
.xc-share{font-variant-numeric:tabular-nums}
.xc-badge{font-size:10px; font-weight:700; color:var(--warn); background:rgba(180,83,9,.12);
  padding:1px 7px; border-radius:999px; letter-spacing:.02em}

/* explorer grid */
main{padding:22px 0 56px}
.explorer{display:grid; grid-template-columns:minmax(0,1.55fr) minmax(320px,1fr); gap:22px; align-items:start}

/* map */
.map-col{position:relative}
#map{height:620px; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); background:#eef}
.map-hint{font-size:12.5px; color:var(--subink); margin:10px 2px 0}
.leaflet-container{border-radius:14px; font-family:var(--font)}

/* legend */
.legend{
  position:absolute; right:14px; bottom:46px; z-index:600;
  background:rgba(255,255,255,.96); border:1px solid var(--line);
  border-radius:10px; padding:11px 13px; box-shadow:var(--shadow); max-width:230px;
}
.legend h4{margin:0 0 8px; font-size:12px; letter-spacing:.02em; color:var(--ink)}
.legend .grad{height:11px; border-radius:3px; margin-bottom:5px}
.legend .scale-ends{display:flex; justify-content:space-between; font-size:11px; color:var(--subink)}
.legend .swatch-row{display:flex; align-items:center; gap:7px; font-size:12px; margin:4px 0; color:var(--ink)}
.legend .swatch{width:13px; height:13px; border-radius:3px; flex:none; border:1px solid rgba(0,0,0,.08)}
.legend .na{color:var(--subink); font-size:11px; margin-top:7px}

/* panel */
.panel{background:var(--panel); border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); padding:18px 20px; position:sticky; top:84px}
.panel .eyebrow{font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--accent); margin:0 0 3px}
.panel h2{font-size:20px; margin:0 0 4px; letter-spacing:-.01em}
.panel .sub{font-size:13px; color:var(--subink); margin:0 0 14px}
.back-link{display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:600;
  color:var(--highlight); background:none; border:none; cursor:pointer; padding:0; margin:0 0 12px}
.back-link:hover{text-decoration:underline}

/* stat chips inside panel */
.mini-stats{display:grid; grid-template-columns:1fr 1fr; gap:9px; margin:0 0 16px}
.mini{background:var(--soft); border:1px solid var(--line); border-radius:10px; padding:9px 11px}
.mini .n{font-size:18px; font-weight:700; color:var(--highlight); letter-spacing:-.01em}
.mini .l{font-size:11px; color:var(--subink); margin-top:1px}

/* candidate bar list */
.cand-list{display:flex; flex-direction:column; gap:2px}
.cand{display:grid; grid-template-columns:1fr auto; gap:2px 10px; align-items:center;
  padding:7px 8px; border-radius:8px; cursor:pointer; position:relative}
.cand:hover{background:var(--soft)}
.cand.active{background:rgba(109,40,217,.08)}
.cand.lead .cn{font-weight:700}
.cand .cn{font-size:13.5px; grid-column:1; position:relative; z-index:1}
.cand .cv{font-size:13px; color:var(--subink); grid-column:2; text-align:right; position:relative; z-index:1; white-space:nowrap}
.cand .barwrap{grid-column:1 / -1; height:6px; background:var(--grid); border-radius:99px; overflow:hidden; margin-top:1px}
.cand .bar{height:100%; background:var(--accent); border-radius:99px}
.cand.lead .bar{background:var(--highlight)}
.badge{display:inline-block; font-size:10px; font-weight:700; padding:1px 7px;
  border-radius:999px; color:#fff; margin-left:6px; vertical-align:middle; background:var(--win)}
.badge.lead{background:var(--highlight)}

/* slate chips + slate block */
.slate-chip{display:inline-block; font-size:10.5px; font-weight:700; line-height:1.4;
  padding:1px 7px; border-radius:999px; margin-left:6px; vertical-align:middle;
  color:var(--sc); background:color-mix(in srgb, var(--sc) 13%, #fff);
  border:1px solid color-mix(in srgb, var(--sc) 35%, #fff); white-space:nowrap}
.slate-block{margin:2px 0 4px; padding:13px 13px 11px; background:var(--soft);
  border:1px solid var(--line); border-radius:11px}
.slate-list{display:flex; flex-direction:column; gap:3px}
.slate-row{display:grid; grid-template-columns:1fr auto; gap:2px 10px; align-items:center;
  padding:6px 7px; border-radius:8px; cursor:pointer}
.slate-row:hover{background:#fff}
.slate-row.active{background:#fff; box-shadow:inset 0 0 0 1px var(--line)}
.slate-row .sl-name{font-size:13px; font-weight:600; display:flex; align-items:center; gap:7px}
.slate-row .sl-val{font-size:12.5px; color:var(--subink); white-space:nowrap}
.slate-row .barwrap{grid-column:1 / -1; height:6px; background:var(--grid); border-radius:99px; overflow:hidden; margin-top:2px}
.slate-row .bar{height:100%; border-radius:99px}
.slate-row .seats{font-size:10.5px; font-weight:700; color:var(--win); margin-left:2px;
  background:rgba(22,121,74,.1); padding:0 6px; border-radius:999px}
.swatch{width:12px; height:12px; border-radius:3px; flex:none; display:inline-block; border:1px solid rgba(0,0,0,.08)}
.slate-sub{display:flex; flex-wrap:wrap; gap:6px; margin:0 0 12px}
.sl-pill{display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:600;
  color:var(--ink); background:var(--soft); border:1px solid var(--line);
  border-radius:999px; padding:2px 9px}

/* slate-results overview (contest x slate seat matrix) */
.slate-overview-section{margin-top:34px; border-top:1px solid var(--line); padding-top:26px}
.slate-tallies{display:flex; flex-wrap:wrap; gap:10px; margin:16px 0 4px}
.slate-tally{display:inline-flex; align-items:center; gap:7px; font-size:13px; color:var(--subink);
  background:var(--soft); border:1px solid var(--line); border-radius:999px; padding:5px 13px}
.slate-tally b{color:var(--ink); font-weight:700}
table.slate-matrix th .swatch{margin-right:6px; vertical-align:-2px}
table.slate-matrix tbody tr{cursor:pointer}
table.slate-matrix tbody tr:hover{background:var(--soft)}
table.slate-matrix tfoot tr{cursor:default}
table.slate-matrix tbody td{color:var(--subink)}
table.slate-matrix td.scope{color:var(--subink); font-size:12.5px}
table.slate-matrix td.won{font-weight:700; color:var(--highlight); background:rgba(109,40,217,.07)}
table.slate-matrix td.zero{color:var(--grid)}
table.slate-matrix tfoot td{border-top:2px solid var(--line); font-weight:700; color:var(--ink)}
table.slate-matrix tfoot td.name{color:var(--ink)}

/* analysis page (analysis.html): intro + shared chart pieces */
.analysis-intro{margin:8px 0 4px}
.analysis-intro h2{font-size:23px; margin:0 0 4px; letter-spacing:-.01em}
.analysis-intro .back-link{display:inline; margin-left:6px}

/* shared chart pickers (contest / metric dropdowns above a chart) */
.chart-pickers{display:flex; flex-wrap:wrap; gap:16px; margin:16px 0 6px; align-items:flex-end}
.chart-picker{display:flex; flex-direction:column; gap:5px}
.chart-picker span{font-size:11px; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--subink)}
.chart-picker select{
  font:inherit; font-size:16px; color:var(--ink); background:#fff;
  border:1px solid var(--line); border-radius:9px; padding:10px 11px; min-width:240px;
  min-height:44px; cursor:pointer; box-shadow:var(--shadow);
}
.chart-picker select:focus{outline:2px solid var(--accent); outline-offset:1px}

/* analytical views (waterfall + by-ward heatmap) */
.analysis-section{margin-top:34px; border-top:1px solid var(--line); padding-top:26px}

/* seat-margin waterfall */
.wf-grid{display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:16px}
.wf-panel{min-width:0}
.wf-title{font-size:14px; font-weight:700; color:var(--ink)}
.wf-sub{font-size:12px; color:var(--subink); margin:1px 0 4px}
.wf-svg{width:100%; height:auto; display:block}
.wf-axis{stroke:var(--subink); stroke-width:1}
.wf-cum{fill:none; stroke:var(--accent); stroke-width:1.4; stroke-dasharray:3 3}
.wf-dot{fill:var(--accent)}
.wf-val{font-size:9px; font-weight:700; text-anchor:middle; font-family:var(--font)}
.wf-xlbl{font-size:10px; fill:var(--subink); text-anchor:middle; font-family:var(--font)}
.wf-xlbl.wf-net{fill:var(--ink); font-weight:700}
.wf-legend{display:flex; flex-wrap:wrap; gap:16px; margin-top:10px; font-size:12.5px; color:var(--ink)}
.wf-legend .swatch-row{display:inline-flex; align-items:center; gap:7px}

/* by-ward heatmap */
.seg-toggle{display:inline-flex; gap:6px; margin:16px 0 4px; flex-wrap:wrap}
.seg-btn{font:inherit; font-size:13px; font-weight:600; color:var(--subink);
  background:#fff; border:1px solid var(--line); border-radius:999px; padding:6px 15px; cursor:pointer}
.seg-btn:hover{color:var(--highlight)}
.seg-btn.active{background:var(--highlight); color:#fff; border-color:var(--highlight)}
table.heatmap{font-size:13px}
table.heatmap th,table.heatmap td{padding:7px 9px; text-align:center}
table.heatmap th.hm-name,table.heatmap td.hm-name{text-align:left; white-space:nowrap}
table.heatmap th.hm-rank,table.heatmap td.hm-rank{text-align:right; color:var(--subink); font-variant-numeric:tabular-nums}
table.heatmap th.hm-city,table.heatmap td.hm-city{color:var(--subink); border-left:1px solid var(--line)}
table.heatmap tbody tr.hm-win td.hm-name,table.heatmap tbody tr.hm-win td.hm-rank,
table.heatmap tbody tr.hm-win td.hm-city{font-weight:700; color:var(--ink)}
table.heatmap tbody tr.hm-divider td{border-bottom:2px dashed var(--ink)}
.hm-cell{font-variant-numeric:tabular-nums; font-weight:600}
.hm-dot{font-size:9px; font-weight:700; letter-spacing:.04em; color:var(--highlight)}
table.heatmap tbody tr.hm-win .hm-dot{color:var(--highlight)}
.legend-inline{display:flex; align-items:center; flex-wrap:wrap; gap:10px; margin-top:12px;
  font-size:12px; color:var(--subink)}
.hm-leg-bar{width:120px; height:11px; border-radius:3px; display:inline-block}
.hm-leg-ends{font-variant-numeric:tabular-nums}
.hm-leg-note{margin-left:4px}
.hm-leg-lbl{font-weight:600; color:var(--ink)}

/* share-by-ward small multiples */
.sm-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:16px}
.sm-card{border:1px solid var(--line); border-radius:11px; background:#fff; padding:11px 12px; min-width:0}
.sm-title{font-size:12px; font-weight:700; color:var(--ink); margin-bottom:8px}
.sm-bars{display:flex; flex-direction:column; gap:5px}
.sm-row{display:grid; grid-template-columns:64px 1fr auto; gap:7px; align-items:center; font-size:11.5px}
.sm-lbl{color:var(--subink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.sm-barwrap{height:7px; background:var(--grid); border-radius:99px; overflow:hidden}
.sm-bar{display:block; height:100%; border-radius:99px; background:var(--accent)}
.sm-val{color:var(--ink); font-variant-numeric:tabular-nums; font-weight:600}

/* turnout vs. share scatter + candidate-across-wards slope (shared SVG style) */
.scatter-wrap{position:relative}
.sc-svg{width:100%; height:auto; display:block; margin-top:6px}
.sc-grid{stroke:var(--grid); stroke-width:1}
.sc-tick{font-size:10px; fill:var(--subink); text-anchor:middle; font-family:var(--font)}
.sc-tick-y{text-anchor:end}
.sc-axis-title{font-size:11px; font-weight:700; fill:var(--subink); text-anchor:middle; font-family:var(--font)}
.sc-dot{fill-opacity:.62; stroke:#fff; stroke-width:.6; cursor:pointer}
.sc-dot:hover{fill-opacity:.95; stroke:var(--ink); stroke-width:1.2}
.sc-trend{stroke:var(--ink); stroke-width:1.4; stroke-dasharray:5 4; opacity:.55}
.sc-r2{font-size:11px; font-weight:700; fill:var(--ink); text-anchor:end; font-family:var(--font)}
.scatter-tip{position:absolute; z-index:700; pointer-events:none; max-width:180px;
  background:var(--ink); color:#fff; border-radius:7px; box-shadow:var(--shadow);
  font-size:12px; line-height:1.4; padding:6px 9px; font-weight:500}
.scatter-tip b{font-weight:700}

/* slope plot specifics */
.slope-candidates{display:flex; flex-wrap:wrap; gap:7px; margin:8px 0 6px}
.slope-chip{font:inherit; font-size:12.5px; font-weight:600; color:var(--subink);
  background:#fff; border:1px solid var(--line); border-radius:999px; padding:11px 16px; cursor:pointer;
  display:inline-flex; align-items:center; min-height:44px}
.slope-chip:hover{color:var(--highlight)}
.slope-chip.on{color:#fff; background:var(--chip,var(--highlight)); border-color:var(--chip,var(--highlight))}
.sl-line{fill:none; stroke-width:2.2}
.sl-dot{stroke:#fff; stroke-width:.8}
.sl-median{fill:none; stroke:var(--subink); stroke-width:1.4; stroke-dasharray:4 4; opacity:.5}
.sl-median-key{background:repeating-linear-gradient(90deg,var(--subink) 0 4px,transparent 4px 8px)}

/* results table */
.table-section{margin-top:34px; border-top:1px solid var(--line); padding-top:26px}
.table-head{display:flex; flex-wrap:wrap; justify-content:space-between; align-items:baseline; gap:8px}
.table-head h2{font-size:21px; margin:0; letter-spacing:-.01em}
.hint{font-size:13px; color:var(--subink); margin:0}
.table-scroll{overflow-x:auto; border:1px solid var(--line); border-radius:12px; background:#fff; margin-top:14px}
table.data{border-collapse:collapse; width:100%; font-size:13.5px}
table.data th,table.data td{padding:9px 13px; text-align:right; white-space:nowrap}
table.data th:first-child,table.data td:first-child{text-align:left}
table.data thead th{position:sticky; top:0; background:var(--soft); color:var(--ink);
  font-weight:600; border-bottom:2px solid var(--grid); cursor:pointer; user-select:none}
table.data thead th:hover{color:var(--highlight)}
table.data thead th[data-dir=asc]::after{content:" \2191"; color:var(--accent)}
table.data thead th[data-dir=desc]::after{content:" \2193"; color:var(--accent)}
table.data tbody tr{border-bottom:1px solid var(--line); cursor:pointer}
table.data tbody tr:last-child{border-bottom:none}
table.data tbody tr:hover{background:var(--soft)}
table.data tbody tr.win{background:rgba(109,40,217,.06)}
table.data tbody tr.active{background:rgba(109,40,217,.12)}
table.data td.name{font-weight:600}
.bar-cell{position:relative; min-width:120px}
.bar-cell .fill{position:absolute; left:0; top:0; bottom:0; background:rgba(140,122,201,.20); z-index:0}
.bar-cell span{position:relative; z-index:1}

/* footer */
footer{border-top:1px solid var(--line); padding:22px 0 36px; background:var(--soft)}
footer p{font-size:12.5px; color:var(--subink); margin:0}
.fineprint{margin-top:6px; font-size:11.5px; opacity:.85}
.data-credit{margin-top:6px; font-size:12px}
.data-credit a{color:var(--highlight); font-weight:600; text-decoration:none}
.data-credit a:hover{text-decoration:underline}

/* ballot drops page (drops.html): vote-delta bars, share shift, precinct grid */
.margin-line{margin:2px 0 14px; font-size:14px; color:var(--subink)}
.margin-line b{color:var(--ink); font-weight:700}
/* signed vote deltas reuse .cand/.barwrap; color the value + bar by sign */
.cand .cv.pos{color:var(--win)} .cand .cv.neg{color:var(--warn)}
.cand .bar.neg{background:var(--warn)}
/* vote-share shift: two stacked bars (A faint, B accent) per candidate */
.share-list{display:flex; flex-direction:column; gap:3px}
.share-row{display:grid; grid-template-columns:minmax(120px,1fr) 2fr auto; gap:4px 12px;
  align-items:center; padding:7px 8px; border-radius:8px}
.share-row.lead .sr-name{font-weight:700}
.share-row .sr-name{font-size:13.5px}
.share-row .sr-track{position:relative; height:18px}
.share-row .sr-a,.share-row .sr-b{position:absolute; left:0; height:7px; border-radius:99px}
.share-row .sr-a{top:0; background:var(--accent); opacity:.45}
.share-row .sr-b{top:10px; background:var(--highlight)}
.share-row .sr-val{font-size:12.5px; color:var(--subink); white-space:nowrap; text-align:right}
.share-row .sr-val b{color:var(--ink)}
.share-row .sr-val .pos{color:var(--win); font-weight:700}
.share-row .sr-val .neg{color:var(--warn); font-weight:700}
.share-key{margin-left:8px; white-space:nowrap; font-size:12px}
.share-key i{display:inline-block; width:11px; height:11px; border-radius:3px; vertical-align:-1px; margin:0 4px 0 10px}
.share-key i.a{background:var(--accent); opacity:.45} .share-key i.b{background:var(--highlight)}
/* precinct reporting grid */
.pgrid{display:grid; grid-template-columns:repeat(auto-fill,minmax(30px,1fr)); gap:4px; margin:14px 0 8px}
.pcell{aspect-ratio:1; border-radius:5px; display:flex; align-items:center; justify-content:center;
  font-size:9.5px; background:var(--grid); color:var(--subink)}
.pcell.rep{background:color-mix(in srgb, var(--accent) 22%, #fff); color:var(--deep)}
.pcell.new{background:var(--highlight); color:#fff; font-weight:700}
.pgrid-key{font-size:12px; color:var(--subink); margin:2px 0 0}
.key-cell{display:inline-block; width:12px; height:12px; border-radius:3px; vertical-align:-2px;
  margin:0 3px 0 12px; background:var(--grid)}
.key-cell.rep{background:color-mix(in srgb, var(--accent) 22%, #fff)} .key-cell.new{background:var(--highlight)}

/* closest-races leaderboard (closest.html) */
.closest-board{display:flex; flex-direction:column; gap:2px; margin-top:10px}
.cls-row{display:grid; grid-template-columns:30px minmax(0,2.4fr) minmax(90px,1fr) minmax(120px,1.1fr);
  gap:6px 14px; align-items:center; padding:10px 10px; border-radius:9px; border:1px solid transparent}
.cls-row:not(.cls-head):hover{background:var(--soft); border-color:var(--line)}
.cls-head{font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:var(--subink); padding:4px 10px; border-bottom:1px solid var(--line); border-radius:0}
.cls-head:hover{background:none}
.cls-rank{font-size:13px; font-weight:700; color:var(--accent); text-align:center}
.cls-main{min-width:0}
.cls-name{font-size:14px; font-weight:700; color:var(--ink); display:flex; flex-wrap:wrap;
  align-items:center; gap:7px}
.cls-cands{font-size:12.5px; color:var(--subink); margin-top:2px}
.cls-cands b{color:var(--ink); font-weight:600}
.cls-seatnote{color:var(--subink); font-style:italic}
.cls-badge{font-size:10px; font-weight:700; color:var(--deep);
  background:color-mix(in srgb, var(--accent) 18%, #fff);
  border-radius:99px; padding:1px 8px; letter-spacing:.02em}
.cls-flag{font-size:10px; font-weight:700; color:var(--warn);
  background:rgba(180,83,9,.12); border-radius:99px; padding:1px 8px; letter-spacing:.02em}
.cls-margin{text-align:right; white-space:nowrap}
.cls-margin .cls-mv{font-size:14px; font-weight:700; color:var(--highlight)}
.cls-margin.cls-tie .cls-mv{color:var(--subink)}
.cls-margin .cls-mp{font-size:12px; color:var(--subink); margin-top:1px}
.cls-trend{display:flex; align-items:center; gap:9px; min-width:0}
.cls-spark{font-size:17px; line-height:1; letter-spacing:1px; color:var(--accent);
  font-family:"Segoe UI Symbol","Apple Symbols",sans-serif}
.cls-label{font-size:11px; font-weight:700; letter-spacing:.02em; white-space:nowrap}
.cls-label.narrowing{color:var(--win)}
.cls-label.widening{color:var(--subink)}
.cls-label.steady{color:var(--subink)}
.cls-label.flipped{color:var(--warn)}
@media (max-width:560px){
  .cls-row{grid-template-columns:24px minmax(0,1.6fr) auto; gap:5px 10px}
  .cls-trend{grid-column:2 / -1; margin-top:2px}
  .cls-head .cls-trend{display:none}
}

/* tooltip */
.leaflet-tooltip.pct-tip{background:var(--ink); color:#fff; border:none; border-radius:7px;
  box-shadow:var(--shadow); font-size:12.5px; padding:6px 9px; font-weight:500}
.leaflet-tooltip.pct-tip::before{display:none}
.pct-tip b{font-weight:700}
.pct-tip .tval{color:#D9C9FF}

@media (max-width:900px){
  .explorer{grid-template-columns:1fr}
  #map{height:460px}
  /* Single-column: the stacked controls bar is ~370px tall, so pinning it to
     the top covers the results and lets the map's zoom control (also z-index
     1000) paint over the filters mid-scroll. Let it scroll with the page. */
  .controls{position:static}
  .panel{position:static}
  .legend{bottom:62px}
  .wf-grid{grid-template-columns:1fr}
  .sm-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .masthead h1{font-size:23px}
  .masthead-inner{flex-direction:column}
  .controls select{min-width:0; width:100%}
  .ctrl{width:100%}
  /* nav collapses into a pure-CSS <details> disclosure (no JS) */
  .site-nav{width:100%}
  .nav-disclosure{width:100%; border:1.5px solid var(--highlight); border-radius:12px; overflow:hidden}
  .site-nav summary{display:flex; align-items:center; min-height:44px; padding:.5rem 1.1rem;
    font-weight:600; font-size:.85rem; color:var(--highlight); list-style:none; cursor:pointer}
  .site-nav summary::-webkit-details-marker{display:none}
  .site-nav summary::after{content:"\25BE"; margin-left:auto; transition:transform .15s}
  .nav-disclosure[open] summary::after{transform:rotate(180deg)}
  .site-nav .nav-links{display:none; flex-direction:column; gap:0}
  .nav-disclosure[open] .nav-links{display:flex}
  .site-nav .nav-links a{border:none; border-radius:0; justify-content:flex-start;
    border-top:1px solid var(--line); width:100%}
  .site-nav .nav-divider{display:block; height:1px; background:var(--line); margin:0}
}

/* ===== drops page: "where the votes came from" choropleth (self-contained,
   appended to minimize merge conflicts with concurrent style.css edits) ===== */
.dropmap-wrap{position:relative; margin:14px 0 8px}
#dropMap{height:560px; border:1px solid var(--line); border-radius:14px;
  box-shadow:var(--shadow); background:#eef}
.dropmap-legend{position:absolute; right:14px; bottom:14px; z-index:500;
  background:rgba(255,255,255,.94); border:1px solid var(--line); border-radius:10px;
  box-shadow:var(--shadow); padding:10px 12px; max-width:230px}
.dropmap-legend h4{margin:0 0 8px; font-size:12px; letter-spacing:.02em; color:var(--ink)}
.dropmap-legend .grad{height:11px; border-radius:3px; margin-bottom:5px}
.dropmap-legend .scale-ends{display:flex; justify-content:space-between;
  font-size:11px; color:var(--subink)}
.dropmap-legend .na{color:var(--subink); font-size:11px; margin-top:8px;
  display:flex; align-items:center; gap:6px}
.dropmap-legend .swatch{width:13px; height:13px; border-radius:3px; flex:none;
  border:1px solid rgba(0,0,0,.08)}
.dropmap-hint{margin-top:10px}
@media (max-width:900px){
  #dropMap{height:440px}
}
@media (max-width:560px){
  .dropmap-legend{right:8px; bottom:8px; padding:8px 10px; max-width:190px}
}

/* ===== ranked-choice page (rcv.html) - self-contained, appended to minimize
   merge conflicts with concurrent style.css edits ===== */
.rcv-banner{margin:14px 0 4px; padding:12px 15px; border-radius:11px;
  background:rgba(180,83,9,.08); border:1px solid rgba(180,83,9,.35);
  color:var(--ink); font-size:13.5px; line-height:1.5}
.rcv-banner strong{color:var(--warn)}
.rcv-empty{margin:26px 0; padding:18px 16px; border:1px dashed var(--line);
  border-radius:12px; background:var(--soft)}

/* chart */
#rcvChart{margin-top:8px}
.rcv-svg{width:100%; height:auto; display:block; overflow:visible}
.rcv-grid{stroke:var(--grid); stroke-width:1}
.rcv-tick{font-size:11px; fill:var(--subink)}
.rcv-tick-y{text-anchor:end}
.rcv-xlbl{text-anchor:middle; font-size:12px; font-weight:600; fill:var(--ink)}
.rcv-winlbl{text-anchor:middle; font-size:12px; font-weight:700; fill:var(--highlight)}
.rcv-seg{stroke:#fff; stroke-width:1; rx:1.5}
.rcv-seg.rcv-win{stroke:var(--deep); stroke-width:1.4}
.rcv-seg.rcv-elim{stroke-width:2; stroke-dasharray:3 2}
.rcv-seg.rcv-exhaust{stroke:#fff}

/* legend (reuses .swatch / .swatch-row from .legend) */
.rcv-leg-lbl{font-size:11px; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--subink); margin-right:2px}
#rcvLegend .swatch{width:13px; height:13px; border-radius:3px; flex:none;
  border:1px solid rgba(0,0,0,.08)}
#rcvLegend .swatch-row{display:inline-flex; align-items:center; gap:7px; font-size:12px;
  color:var(--ink)}
.rcv-wintag{color:var(--highlight); font-size:10px; letter-spacing:.04em}

/* table */
table.rcv-data td.rcv-out{color:var(--subink); opacity:.5; text-align:right}
table.rcv-data td.rcv-elim-cell{color:var(--warn); font-style:italic;
  background:rgba(180,83,9,.06)}
table.rcv-data tbody tr.win .rcv-dot{color:var(--highlight); font-weight:700; font-size:11px}
table.rcv-data tbody tr.rcv-exhaust-row{color:var(--subink); cursor:default}
table.rcv-data tbody tr.rcv-exhaust-row:hover{background:transparent}
table.rcv-data tbody tr.rcv-total-row{border-top:2px solid var(--line);
  font-weight:700; color:var(--ink); cursor:default}
table.rcv-data tbody tr.rcv-total-row:hover{background:transparent}

@media (max-width:560px){
  .rcv-banner{font-size:13px; padding:11px 13px}
  .rcv-svg{min-width:520px}
  #rcvChart{overflow-x:auto; -webkit-overflow-scrolling:touch}
}
