: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}
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}

/* 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}

/* 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:14.5px; color:var(--ink); background:#fff;
  border:1px solid var(--line); border-radius:9px; padding:9px 12px; min-width:240px;
  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)}

/* 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: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)}

/* 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}

/* 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}
  .panel{position:static}
  .legend{bottom:62px}
}
@media (max-width:560px){
  .masthead h1{font-size:23px}
  .controls select{min-width:0; width:100%}
  .ctrl{width:100%}
}
