/* ============================================================
   Ballot Access Risk Board — layered on styles.css tokens
   ============================================================ */

.ba{ position:relative; z-index:1; max-width: 1180px; margin:0 auto; padding: clamp(40px,7vh,80px) clamp(18px,5vw,40px) 80px; }

.ba__head{ max-width: 820px; margin-bottom: 38px; }
.ba__head h1{ font-size: clamp(30px,5vw,52px); line-height:1.05; letter-spacing:-.025em; font-weight:700; margin-top:16px; }
.ba__sub{ margin-top:18px; font-size: clamp(15px,1.6vw,18px); color: var(--paper-soft); line-height:1.62; max-width:720px; }
.ba__sub b{ color: var(--paper); }

/* summary tiles */
.ba-summary{ display:grid; grid-template-columns: repeat(5,1fr); gap:1px; background: var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; margin-bottom: 30px; }
.ba-tile{ background: var(--ink-1); padding: 16px 18px; min-width:0; }
.ba-tile dt{ font-family: var(--mono); font-size:10.5px; text-transform:uppercase; letter-spacing:.08em; color: var(--faint); }
.ba-tile dd{ font-family: var(--mono); font-size: clamp(22px,3vw,30px); font-weight:500; margin-top:6px; letter-spacing:-.01em; }
.ba-tile--green dd{ color: var(--mint); }
.ba-tile--amber dd{ color: var(--amber); }
.ba-tile--red dd{ color: var(--rose); }
.ba-tile--sos dd{ color: var(--sky); }

/* controls */
.ba-controls{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:18px; }
.chips{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{ font-family: var(--mono); font-size:12.5px; color: var(--muted); background: var(--ink-1); border:1px solid var(--line); border-radius:999px; padding:7px 14px; cursor:pointer; transition: all .2s; display:flex; align-items:center; gap:7px; }
.chip:hover{ color: var(--paper); border-color: var(--line-2); }
.chip[aria-selected="true"]{ color: var(--paper); border-color: var(--paper-soft); background: var(--ink-3); }
.chip .cdot{ width:8px; height:8px; border-radius:50%; }
.chip[data-f="green"] .cdot{ background: var(--mint); }
.chip[data-f="amber"] .cdot{ background: var(--amber); }
.chip[data-f="red"] .cdot{ background: var(--rose); }
.chip .cn{ color: var(--faint); }
.ba-controls__right{ display:flex; gap:10px; }
.ba-search, .ba-sort{ font-family: var(--mono); font-size:13px; background: var(--ink-1); color: var(--paper); border:1px solid var(--line-2); border-radius:9px; padding:9px 13px; outline:none; }
.ba-search:focus, .ba-sort:focus{ border-color: var(--mint); }
.ba-search{ width:180px; }
.ba-sort{ cursor:pointer; }

/* board list */
.board{ display:flex; flex-direction:column; gap:8px; }
.srow{ border:1px solid var(--line); border-radius:12px; background: var(--ink-1); overflow:hidden; transition: border-color .25s, transform .25s; }
.srow:hover{ border-color: var(--line-2); }
.srow[data-status="green"]{ border-left:3px solid var(--mint); }
.srow[data-status="amber"]{ border-left:3px solid var(--amber); }
.srow[data-status="red"]{ border-left:3px solid var(--rose); }

.srow__head{ display:grid; grid-template-columns: 18px 168px 1fr 1fr auto 16px; gap:16px; align-items:center; padding:15px 18px; cursor:pointer; }
.srow__dot{ width:11px; height:11px; border-radius:50%; }
[data-status="green"] .srow__dot{ background: var(--mint); box-shadow:0 0 10px -1px var(--mint); }
[data-status="amber"] .srow__dot{ background: var(--amber); box-shadow:0 0 10px -1px var(--amber); }
[data-status="red"]   .srow__dot{ background: var(--rose); box-shadow:0 0 10px -1px var(--rose); }
.srow__name{ font-size:16px; font-weight:700; letter-spacing:-.01em; }
.srow__cell{ font-size:12.5px; color: var(--muted); line-height:1.35; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.srow__cell .lbl{ font-family: var(--mono); font-size:9.5px; text-transform:uppercase; letter-spacing:.08em; color: var(--faint); display:block; margin-bottom:2px; }
.srow__meta{ display:flex; gap:10px; font-family: var(--mono); font-size:11.5px; white-space:nowrap; }
.srow__meta .h{ color: var(--amber); } .srow__meta .b{ color: var(--rose); } .srow__meta .s{ color: var(--sky); } .srow__meta .ok{ color: var(--mint); }
.srow__chev{ color: var(--faint); transition: transform .25s; font-family: var(--mono); }
.srow.open .srow__chev{ transform: rotate(90deg); color: var(--paper-soft); }

/* detail panel */
.srow__detail{ display:none; padding: 4px 18px 20px; border-top:1px solid var(--line); }
.srow.open .srow__detail{ display:block; }
.srow__risk{ font-size:13px; color: var(--paper-soft); background: rgba(255,178,77,.06); border:1px solid rgba(255,178,77,.22); border-radius:9px; padding:11px 14px; margin:16px 0 14px; line-height:1.5; }
.srow__risk b{ color: var(--amber); font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.06em; }
.fld{ padding:11px 0; border-top:1px solid var(--line); }
.fld:first-child{ border-top:0; }
.fld__top{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.gate{ font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.05em; padding:3px 8px; border-radius:6px; white-space:nowrap; }
.gate--AUTOLIVE{ color: var(--mint); background: rgba(54,242,192,.12); border:1px solid rgba(54,242,192,.3); }
.gate--HOLD{ color: var(--amber); background: rgba(255,178,77,.1); border:1px solid rgba(255,178,77,.32); }
.gate--BLOCKED{ color: var(--rose); background: rgba(255,107,129,.12); border:1px solid rgba(255,107,129,.34); }
.fld__name{ font-family:var(--mono); font-size:12.5px; color: var(--paper); }
.fld__conf{ font-family:var(--mono); font-size:10.5px; color: var(--faint); margin-left:auto; }
.fld__val{ font-size:13.5px; color: var(--paper-soft); margin-top:6px; line-height:1.5; }
.fld__note{ font-size:12px; color: var(--muted); margin-top:5px; line-height:1.5; }
.fld__note .nk{ font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.06em; color: var(--faint); }

.sos{ margin-top:16px; }
.sos__h{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.07em; color: var(--sky); margin-bottom:8px; }
.sos__item{ font-size:12.5px; color: var(--paper-soft); padding:9px 12px; border:1px solid var(--line); border-left:2px solid var(--sky); border-radius:8px; margin-bottom:6px; line-height:1.5; background: rgba(95,176,255,.03); }

.ba-empty{ text-align:center; font-family:var(--mono); color: var(--muted); padding:40px; }
.hl-amber{ color: var(--amber); }

/* reveal (reuses app.js observer) */
[data-reveal]{ opacity:0; transform: translateY(20px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }

@media (max-width: 820px){
  .ba-summary{ grid-template-columns: repeat(2,1fr); }
  .srow__head{ grid-template-columns: 14px 1fr auto 14px; gap:10px; }
  .srow__cell{ grid-column: 2 / -1; -webkit-line-clamp:3; }
  .srow__cell--deadline{ display:none; } /* keep collapsed rows compact on mobile; shown in detail */
  .ba-lens{ order:-1; }
}

/* lens toggle (critical-only vs all-holds) */
.ba-controls{ justify-content:flex-start; }
.ba-controls__right{ margin-left:auto; }
.ba-lens{ display:inline-flex; border:1px solid var(--line-2); border-radius:999px; overflow:hidden; background: var(--ink-1); }
.seg{ font-family:var(--mono); font-size:12.5px; color: var(--muted); background:transparent; border:0; padding:8px 15px; cursor:pointer; transition: all .2s; }
.seg + .seg{ border-left:1px solid var(--line); }
.seg:hover{ color: var(--paper); }
.seg[aria-selected="true"]{ background: var(--mint); color:#022; font-weight:600; }
.ba-lenscap{ font-family:var(--mono); font-size:11.5px; color: var(--faint); margin: 0 0 20px; line-height:1.55; max-width:780px; }

/* critical-field marker + muted minor count */
.srow__meta .mute{ color: var(--faint); }
.fld__crit{ font-family:var(--mono); font-size:9px; text-transform:uppercase; letter-spacing:.08em; color: var(--sky); border:1px solid rgba(95,176,255,.34); border-radius:5px; padding:2px 6px; }
.fld--crit .fld__name{ color: var(--paper); }

/* compensation-model block (UNVERIFIED initiative-law prior) */
.comp{ margin-top:16px; border:1px solid var(--line); border-left:2px solid var(--sky); border-radius:9px; padding:12px 14px; background: rgba(95,176,255,.04); }
.comp--banned{ border-left-color: var(--rose); background: rgba(255,107,129,.05); }
.comp--permitted{ border-left-color: var(--mint); background: rgba(54,242,192,.04); }
.comp--na{ border-left-color: var(--faint); }
.comp__h{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.07em; color: var(--paper-soft); display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.comp__status{ font-size:9px; color: var(--amber); border:1px solid rgba(255,178,77,.4); border-radius:5px; padding:2px 6px; letter-spacing:.05em; }
.comp__row{ font-size:12.5px; color: var(--paper-soft); margin-top:4px; line-height:1.5; }
.comp__row .ck{ font-family:var(--mono); font-size:9.5px; text-transform:uppercase; letter-spacing:.06em; color: var(--faint); margin-right:7px; }
.comp__row b{ color: var(--paper); }
.comp__note{ font-size:11px; color: var(--faint); margin-top:7px; line-height:1.5; }
.comp__flag{ font-family:var(--mono); font-size:9.5px; color: var(--amber); border:1px solid rgba(255,178,77,.4); border-radius:5px; padding:1px 6px; white-space:nowrap; }

/* official source links (per-jurisdiction, in the expanded detail) */
.srcs{ margin-top:16px; }
.srcs__h{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.07em; color: var(--mint); margin-bottom:9px; display:flex; align-items:center; gap:8px; }
.srcs__n{ font-family:var(--mono); font-size:10px; color: var(--faint); border:1px solid var(--line-2); border-radius:999px; padding:1px 7px; }
.srcs__list{ display:flex; flex-direction:column; gap:5px; }
.src{ display:flex; align-items:baseline; gap:8px; font-size:12.5px; color: var(--muted); border:1px solid var(--line); border-radius:8px; padding:8px 11px; transition: color .15s, border-color .15s, background .15s; }
.src:hover{ color: var(--paper); border-color: var(--line-2); background: rgba(255,255,255,.02); }
.src--gov{ color: var(--paper-soft); border-left:2px solid var(--mint); }
.src--gov:hover{ border-color: var(--mint); }
.src__dom{ font-family:var(--mono); font-size:10.5px; color: var(--faint); margin-left:auto; white-space:nowrap; }
.src:hover .src__dom{ color: var(--mint); }
