:root{--forest:#1f3d2f;--forest2:#2d5a43;--forest3:#3f7458;--deep:#163024;--parch:#f5f0e6;--parch2:#efe8d8;--sienna:#9c4a1e;--gold:#e0a868;--ink:#27392e;--ink2:#3b5345;--muted:#586861;--line:#d8cfba;--sage:#7fa78c}
*{box-sizing:border-box}
/* Prevent the document from ever scrolling horizontally — the program
   table scrolls internally via .tbl-scroll (overflow-x:auto). A sticky
   first column can otherwise leak extra scrollWidth onto <html>. */
html{overflow-x:hidden}
body{margin:0;background:var(--parch);color:var(--ink);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:780px;margin:0 auto;padding:0 26px}
.kicker{font:600 12px/1 'Inter';letter-spacing:.16em;text-transform:uppercase;color:var(--sienna)}
h1{font-family:'Fraunces',serif;font-weight:700;font-size:clamp(36px,6.5vw,62px);line-height:1;letter-spacing:-.02em;color:var(--forest);margin:16px 0 14px}
h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(25px,4vw,36px);line-height:1.08;color:var(--forest);margin:0 0 12px;letter-spacing:-.01em}
.lede{font-family:'Fraunces',serif;font-size:clamp(17px,2.4vw,22px);line-height:1.45;color:var(--ink2)}
p.body{font-size:16px;line-height:1.62;color:var(--ink2);margin:0 0 16px}
strong.h{color:var(--forest)}
section{padding:56px 0}.hero{padding:64px 0 40px}
.chips{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.chip{flex:1 1 150px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.chip b{display:block;font-family:'Fraunces',serif;font-weight:700;font-size:34px;line-height:1;color:var(--forest)}
.chip.acc b{color:var(--sienna)}.chip span{font-size:12px;color:var(--muted);display:block;margin-top:6px;line-height:1.35}
.method{font-size:12.5px;color:var(--muted);font-style:italic;border-left:2px solid var(--line);padding-left:12px;margin-top:30px}
.cap{font-style:italic;font-size:12.5px;color:var(--muted);margin-top:12px}
.barline{display:flex;align-items:center;gap:12px;margin:9px 0;font-size:13px;color:var(--ink2)}
.barline .lab{width:120px;text-align:right;flex:none}.barline .track{flex:1;background:var(--parch2);border-radius:3px;overflow:hidden}
.barline .fill{height:18px;border-radius:3px}.barline .val{width:54px;flex:none;font-weight:600;color:var(--forest)}
.band{background:var(--forest);color:var(--parch);padding:62px 0}.band.alt{background:var(--deep)}
.band .kicker{color:var(--gold)}.band h2{color:var(--parch)}.band p.body{color:#d2ddd4}
.band .big{font-family:'Fraunces',serif;font-weight:700;font-size:clamp(58px,12vw,104px);line-height:.9;color:var(--gold);letter-spacing:-.02em}
/* scatter */
.scatter{position:relative;height:420px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0));border-left:1.5px solid rgba(255,255,255,.3);border-bottom:1.5px solid rgba(255,255,255,.3);margin:24px 0 6px}
.zone{position:absolute;left:0;top:0;width:42%;height:55%;background:rgba(224,168,104,.12);border:1px dashed rgba(224,168,104,.5);border-radius:8px}
.zone span{position:absolute;top:8px;left:10px;font:700 11px/1.2 'Inter';letter-spacing:.08em;color:var(--gold);text-transform:uppercase}
.pt{position:absolute;transform:translate(-50%,50%);border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;font:600 10px/1.05 'Inter';color:#fff;border:2px solid rgba(255,255,255,.55)}
.axx{position:absolute;bottom:-26px;width:100%;text-align:center;font-size:11px;color:#bcd0c2;letter-spacing:.04em}
.axy{position:absolute;left:-12px;top:50%;transform:rotate(-90deg) translateX(50%);transform-origin:left;font-size:11px;color:#bcd0c2;letter-spacing:.04em;white-space:nowrap}
/* head to head */
.vs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:22px}
.vscol{border-radius:12px;padding:20px}
.vscol.q{background:rgba(127,167,140,.18);border:1px solid rgba(127,167,140,.5)}
.vscol.l{background:rgba(181,101,29,.16);border:1px solid rgba(181,101,29,.5)}
.vscol h3{font-family:'Fraunces',serif;font-size:20px;margin:0 0 4px;color:var(--parch)}
.vscol .tag{font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.7}
.vrow{display:flex;justify-content:space-between;font-size:13px;padding:7px 0;border-top:1px solid rgba(255,255,255,.12);color:#dce6de}
.vrow b{color:var(--parch)}
/* leaderboard */
.lb{margin-top:22px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.lbrow{display:grid;grid-template-columns:34px 1fr 90px;gap:12px;align-items:center;padding:13px 16px;border-top:1px solid var(--parch2)}
.lbrow:first-child{border-top:none}
.lbrow .rk{font-family:'Fraunces',serif;font-weight:700;font-size:18px;color:var(--sienna)}
.lbrow .nm{font-size:14px;color:var(--forest);font-weight:600}
.lbrow .meta{font-size:11.5px;color:var(--muted);margin-top:2px}
.lbrow .sc{text-align:right}.lbrow .sc b{font-family:'Fraunces',serif;font-size:20px;color:var(--forest)}.lbrow .sc span{font-size:10px;color:var(--muted);display:block}
.hub{background:var(--parch2)} .hubgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:20px}
.hubcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px}.hubcard h3{font:600 15px/1.2 'Inter';margin:0 0 6px;color:var(--forest)}
.hubcard p{font-size:13px;color:var(--muted);margin:0 0 12px}.platforms{display:flex;flex-wrap:wrap;gap:8px}.platforms span,.platforms a{font-size:11.5px;border:1px solid var(--line);border-radius:999px;padding:5px 11px;color:var(--ink2)}.platforms a{text-decoration:none;border-color:var(--accent,var(--ink2))}.platforms a:hover,.platforms a:focus-visible{text-decoration:underline}
.btn{display:inline-block;background:var(--sienna);color:#fff;font-weight:600;font-size:14px;padding:12px 24px;border-radius:9px;text-decoration:none}.btn.ghost{background:transparent;border:1px solid var(--forest);color:var(--forest)}
.play{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0}
.pcard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:18px}
.pcard .num{font-family:'Fraunces',serif;font-size:30px;color:var(--gold);line-height:1}.pcard h3{margin:8px 0 4px;font-size:15px;color:var(--parch)}.pcard p{font-size:12.5px;color:#bcd0c2;margin:0;line-height:1.45}
footer{background:var(--deep);color:#9fb3a4;font-size:12.5px;padding:34px 0}footer a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}footer a:hover{text-decoration-color:var(--parch)}
.note{background:#fff;border:1px dashed var(--sienna);border-radius:10px;padding:14px 16px;font-size:13px;color:var(--ink2);margin-top:18px}

/* ── Explorer Section ──────────────────────────────────────────────── */
#explorer-section{background:var(--parch2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
/* wider wrap for the table section */
.wrap--wide{max-width:1060px;margin:0 auto;padding:0 26px}
/* keep editorial intro at a comfortable reading measure even though the
   table itself uses the full wide container (deliberate full-width table) */
#explorer-section .kicker,
#explorer-section > .wrap--wide > h2,
#explorer-section > .wrap--wide > p.body{max-width:720px}

/* ── Filters ────────────────────────────────────────────────────────── */
.tbl-filters{margin:24px 0 0;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.tbl-filter-row{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:flex-end}
.tbl-filter-group{display:flex;flex-direction:column;gap:4px;min-width:120px;flex:1 1 120px}
.tbl-filter-group--check{flex:0 0 auto;min-width:unset;justify-content:flex-end;padding-bottom:3px}
.tbl-filter-label{font:600 11px/1 'Inter';letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.tbl-input,.tbl-select{border:1px solid var(--line);border-radius:7px;padding:8px 10px;font:400 13px/1 'Inter';color:var(--ink);background:#fff;-webkit-appearance:none;appearance:none;outline:none;width:100%}
.tbl-input:focus,.tbl-select:focus{border-color:var(--forest2);box-shadow:0 0 0 2px rgba(31,61,47,.15)}
.tbl-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7d70'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:26px}
.tbl-check-label{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:13px;color:var(--ink2);font-weight:500;user-select:none}
.tbl-check{width:16px;height:16px;accent-color:var(--forest);cursor:pointer;flex-shrink:0}
.tbl-count{font-size:12px;color:var(--muted);margin-top:12px;padding-top:10px;border-top:1px solid var(--parch2)}

/* ── Table container ─────────────────────────────────────────────────── */
/* Bounded scroll viewport: the table scrolls inside this box on both axes.
   max-height makes the sticky <thead> pin relative to THIS container (the
   correct self-contained data-table pattern) and prevents the wide table
   from leaking scrollWidth onto <html> (horizontal page-scroll bug). */
.tbl-scroll{margin-top:14px;max-height:72vh;overflow:auto;scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:12px;background:#fff;contain:paint}
/* prevent table from stretching infinitely on desktop */
.qm-table{width:100%;border-collapse:collapse;font-size:13px}
.qm-table thead{position:sticky;top:0;z-index:2;background:#fff;box-shadow:0 1px 0 var(--line)}
.qm-table th{padding:0;font-weight:600;color:var(--muted);text-align:left;white-space:nowrap}
.qm-table th:last-child,.qm-table td:last-child{text-align:right}
.sort-btn{background:none;border:none;cursor:pointer;font:600 11.5px/1 'Inter';letter-spacing:.04em;color:var(--muted);text-transform:uppercase;padding:12px 14px;display:flex;align-items:center;gap:5px;white-space:nowrap;text-align:left;width:100%}
.sort-btn:hover{color:var(--forest)}.sort-btn.active{color:var(--forest)}
.sort-btn:focus-visible{outline:2px solid var(--forest2);outline-offset:-2px;border-radius:4px}
.sort-icon{font-size:9px;opacity:.7;min-width:8px}
/* Geography th has no button — use matching padding */
.col-geo.th-plain{padding:12px 14px;font:600 11.5px/1 'Inter';letter-spacing:.04em;color:var(--muted);text-transform:uppercase;white-space:nowrap}
.qm-table td{padding:11px 14px;border-top:1px solid var(--parch2);vertical-align:middle;color:var(--ink2)}
.qm-table tbody tr:first-child td{border-top:none}
.qm-table tbody tr:hover td{background:rgba(31,61,47,.025)}
.qm-table tbody tr.row-quiet td{background:rgba(127,167,140,.05)}
.qm-table tbody tr.row-quiet:hover td{background:rgba(127,167,140,.1)}

/* Column widths */
.col-program{width:auto;min-width:200px}
.col-type{width:110px;white-space:nowrap}
.col-level{width:90px;white-space:nowrap}
.col-geo{width:100px;white-space:nowrap}
.col-award{width:80px;text-align:right;white-space:nowrap}
.col-score{width:130px;text-align:right}

/* program cell */
.prog-link{color:var(--forest);font-weight:600;font-size:13px;text-decoration:none;line-height:1.35}
.prog-link:hover{text-decoration:underline;text-decoration-color:var(--sienna)}
.prog-link:focus-visible{outline:2px solid var(--forest2);border-radius:2px}
.prog-org{font-size:11px;color:var(--muted);margin-top:2px;line-height:1.3}

/* badges */
.badge{display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;border-radius:999px;white-space:nowrap;line-height:1.5}
.badge--grant{background:#e6f0eb;color:#1f5a36}
.badge--tax-credit{background:#fef3e2;color:#7a4a00}
.badge--loan,.badge--forgivable-loan{background:#e8eef8;color:#1d3461}
.badge--program{background:#f0eaf6;color:#4a286a}
.badge--award{background:#fdf2ef;color:#7a2a12}

/* geo truncation tooltip */
.geo-trunc{cursor:help;border-bottom:1px dotted var(--muted)}

/* score cell */
.score-cell{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.score-num{font-family:'Fraunces',serif;font-weight:700;font-size:16px;color:var(--forest);line-height:1}
.score-bar{width:64px;height:5px;background:var(--parch2);border-radius:3px;overflow:hidden}
.score-fill{height:100%;border-radius:3px}
.score-fill.bar-high{background:var(--forest2)}
.score-fill.bar-mid{background:var(--forest3)}
.score-fill.bar-low{background:var(--sage)}
.score-fill.bar-base{background:var(--sienna)}
@media(prefers-reduced-motion:no-preference){.score-fill{transition:width .2s ease}}

/* loading / empty states */
.tbl-loading{text-align:center;padding:32px 16px;color:var(--muted);font-size:13px}
.tbl-error{color:var(--sienna)}
.tbl-empty{margin-top:12px;text-align:center;padding:28px 0;font-size:14px;color:var(--muted)}
.tbl-empty p{margin:0}
.tbl-reset-link{background:none;border:none;color:var(--forest);font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0}
.tbl-reset-link:hover{color:var(--sienna)}

/* CTA below table */
.tbl-cta{margin-top:28px;text-align:center;padding:28px 20px;background:#fff;border:1px solid var(--line);border-radius:12px}
.tbl-cta p{font-size:14px;color:var(--ink2);margin:0 0 16px;max-width:440px;margin-left:auto;margin-right:auto}

/* ── Mobile: card layout at narrow widths ───────────────────────────── */
@media(max-width:640px){
  /* Don't collapse the table to cards — allow horizontal scroll instead.
     The sticky header stays useful. But clamp column widths so it's not too wide. */
  .col-type,.col-level{width:76px}
  .col-geo{width:72px}
  .col-award{width:66px}
  .col-score{width:90px}
  .score-bar{width:44px}
  .tbl-filters{padding:12px 14px}
  .tbl-filter-group{min-width:calc(50% - 8px);flex:1 1 calc(50% - 8px)}
  .tbl-filter-group--check{min-width:unset;flex:0 0 auto}
  .wrap--wide{padding:0 14px}
}
@media(max-width:390px){
  /* Very narrow: allow table to scroll horizontally */
  .qm-table{min-width:600px}
}

/* ── Paired-bar comparison ───────────────────────────────────────────── */
.pbars{margin:28px 0 4px}
.pbar-row{margin-bottom:22px}
.pbar-row:last-child{margin-bottom:0}
.pbar-label{font:600 11px/1 'Inter';letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.pbar-tracks{display:grid;grid-template-columns:1fr 1fr;gap:0}
.pbar-side{display:flex;flex-direction:column;gap:5px}
.pbar-side--q{padding-right:14px;border-right:1px solid rgba(255,255,255,.15)}
.pbar-side--l{padding-left:14px}
.pbar-side-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.55;color:var(--parch)}
.pbar-side--q .pbar-side-label{text-align:right;color:var(--sage)}
.pbar-side--l .pbar-side-label{text-align:left;color:var(--gold)}
.pbar-track-wrap{display:flex;align-items:center;gap:6px}
.pbar-side--q .pbar-track-wrap{flex-direction:row-reverse}
.pbar-track{flex:1;height:10px;background:rgba(255,255,255,.1);border-radius:5px;overflow:hidden}
.pbar-fill{height:100%;border-radius:5px;width:0;transition:width .9s cubic-bezier(.22,1,.36,1)}
@media(prefers-reduced-motion:reduce){.pbar-fill{transition:none}}
.pbar-fill--q{background:var(--forest3)}
.pbar-fill--l{background:var(--sienna)}
.pbar-val{font-family:'Fraunces',serif;font-weight:700;font-size:16px;line-height:1;white-space:nowrap;color:var(--parch);flex-shrink:0}
.pbar-side--q .pbar-val{color:var(--sage)}
.pbar-gap-callout{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:6px;font-size:12px;color:rgba(188,208,194,.7);font-style:italic}
.pbar-gap-arrow{font-size:14px;color:var(--gold)}
/* winner highlight */
.pbar-side--winner .pbar-val{color:var(--sage)}
.pbar-side--winner .pbar-fill--q,.pbar-side--winner .pbar-fill--l{opacity:1}

/* Shared responsive fixes */
@media(max-width:640px){.vs,.play,.hubgrid{grid-template-columns:1fr}.barline .lab{width:96px}.pt{font-size:8px}}
@media(max-width:390px){
  .pbar-tracks{grid-template-columns:1fr}
  .pbar-side--q{padding-right:0;border-right:none;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:10px;margin-bottom:10px}
  .pbar-side--l{padding-left:0}
  .pbar-side--q .pbar-track-wrap{flex-direction:row}
  .pbar-side--q .pbar-side-label{text-align:left}
  .pbar-val{font-size:14px}
}

/* ── Skip link (a11y) ────────────────────────────────────────────────── */
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
  background:var(--forest);color:var(--parch);font:600 14px/1 'Inter';
  padding:10px 18px;border-radius:0 0 8px 0;text-decoration:none;z-index:9999;
  white-space:nowrap
}
.skip-link:focus,.skip-link:focus-visible{
  position:fixed;left:0;top:0;width:auto;height:auto;overflow:visible;
  outline:3px solid var(--gold);outline-offset:2px
}

/* ── sr-only utility ─────────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ── Map: no-JS / pre-hydration fallback list ────────────────────────── */
.map-fallback{list-style:none;margin:24px 0 6px;padding:18px 20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:12px}
.map-fallback li{font-size:13.5px;line-height:1.7;color:#cddcd2}
.map-fallback b{color:var(--parch)}

/* ── Quick-filter chips ──────────────────────────────────────────────── */
.tbl-quick{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:22px 0 0}
.tbl-quick-lbl{font:600 11px/1 'Inter';letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-right:2px}
.qchip{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink2);
  font:600 12.5px/1 'Inter';padding:8px 13px;border-radius:999px;display:inline-flex;align-items:center;gap:5px;
  transition:background .12s ease,border-color .12s ease,color .12s ease}
@media(prefers-reduced-motion:reduce){.qchip{transition:none}}
.qchip:hover{border-color:var(--forest2);color:var(--forest)}
.qchip:focus-visible{outline:2px solid var(--forest2);outline-offset:2px}
.qchip--on{background:var(--forest);border-color:var(--forest);color:#fff}
.qchip--on:hover{background:var(--forest2);color:#fff}

/* ── Filters: count row + clear-all + active chips ───────────────────── */
.tbl-countrow{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding-top:10px;border-top:1px solid var(--parch2)}
.tbl-count{font-size:12.5px;color:var(--muted);margin:0;padding:0;border:none}
.tbl-count strong{color:var(--forest);font-weight:700}
.tbl-clearall{appearance:none;background:none;border:none;cursor:pointer;color:var(--sienna);font:600 12.5px/1 'Inter';padding:4px 2px;text-decoration:underline;flex:none}
.tbl-clearall:hover{color:var(--forest)}
.tbl-clearall:focus-visible{outline:2px solid var(--forest2);outline-offset:2px;border-radius:3px}
.tbl-active{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.tbl-chip{appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  background:#eef3ef;border:1px solid #cfdfd5;color:var(--forest);
  font:500 12px/1 'Inter';padding:6px 10px;border-radius:999px;transition:background .12s ease}
@media(prefers-reduced-motion:reduce){.tbl-chip{transition:none}}
.tbl-chip:hover{background:#e0ebe2}
.tbl-chip span[aria-hidden]{font-size:13px;line-height:1;color:var(--muted);font-weight:700}
.tbl-chip:hover span[aria-hidden]{color:var(--sienna)}
.tbl-chip:focus-visible{outline:2px solid var(--forest2);outline-offset:2px}

/* ── Info icon buttons (header / toggle) ─────────────────────────────── */
.tbl-info,.th-info{display:inline-flex;align-items:center;justify-content:center;cursor:help;
  background:none;border:none;padding:0;margin-left:3px;color:var(--muted);font-size:12px;line-height:1;
  vertical-align:middle;font-weight:400}
.tbl-info:hover,.tbl-info:focus-visible,.sort-btn:hover .th-info,.sort-btn.active .th-info{color:var(--sienna)}
.tbl-info:focus-visible{outline:2px solid var(--forest2);outline-offset:2px;border-radius:50%}
.th-info{font-size:11px}

/* ── Generic tooltip (data-tip) ──────────────────────────────────────── */
.qm-tip{position:fixed;z-index:10000;max-width:280px;background:var(--deep);color:#e8efe9;
  font:400 12.5px/1.5 'Inter';padding:10px 13px;border-radius:9px;border:1px solid rgba(224,168,104,.4);
  box-shadow:0 10px 28px rgba(0,0,0,.28);pointer-events:none;opacity:0;transform:translateY(3px);
  transition:opacity .13s ease,transform .13s ease}
@media(prefers-reduced-motion:reduce){.qm-tip{transition:none}}
.qm-tip--on{opacity:1;transform:translateY(0)}
.qm-tip::after{content:"";position:absolute;left:50%;margin-left:-6px;bottom:-6px;
  border:6px solid transparent;border-top-color:var(--deep)}
.qm-tip--below::after{bottom:auto;top:-6px;border-top-color:transparent;border-bottom-color:var(--deep)}

/* ── Sort idle arrows ────────────────────────────────────────────────── */
.sort-icon{font-size:10px;opacity:.4;min-width:10px;display:inline-block}
.sort-icon.sort-icon--active{opacity:1;color:var(--sienna);font-size:9px}
.sort-btn:hover .sort-icon{opacity:.85}

/* ── Score legend under the table ────────────────────────────────────── */
.tbl-legend{display:flex;flex-wrap:wrap;align-items:center;gap:6px 16px;margin-top:14px;
  font-size:11.5px;color:var(--muted)}
.tbl-legend-lbl{font:600 11px/1 'Inter';letter-spacing:.06em;text-transform:uppercase;color:var(--ink2)}
.tbl-legend-item{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.tbl-legend-sw{width:18px;height:6px;border-radius:3px;flex:none}
.tbl-legend-sw.sw-high{background:var(--forest2)}
.tbl-legend-sw.sw-mid{background:var(--forest3)}
.tbl-legend-sw.sw-low{background:var(--sage)}
.tbl-legend-sw.sw-base{background:var(--sienna)}
.tbl-legend-row{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.tbl-legend-dot{width:11px;height:11px;border-radius:3px;background:rgba(127,167,140,.18);border:1px solid rgba(127,167,140,.5);flex:none}

/* ── Score heat-bar legibility bump ──────────────────────────────────── */
.score-bar{width:72px;height:6px}
.col-score{width:140px}

/* ── Mobile: sticky first column on horizontal scroll ────────────────── */
@media(max-width:640px){
  .tbl-quick{gap:6px}
  .qchip{font-size:11.5px;padding:7px 10px}
  .qm-table th.col-program,.qm-table td.col-program{position:sticky;left:0;z-index:1;background:#fff;
    box-shadow:1px 0 0 var(--parch2)}
  .qm-table tbody tr.row-quiet td.col-program{background:#eef4ef}
  .qm-table thead th.col-program{z-index:3}
}

/* ── Global prefers-reduced-motion safety net ────────────────────────── */
@media(prefers-reduced-motion:reduce){
  /* Catch any remaining transition/animation not guarded by their own blocks */
  *,::before,::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important
  }
}
