/* ============================================================
   ScoreBattle · Fixture screen (SPA)
   Copied (and trimmed) from sbLog/fixture-week.css so the SPA
   has no dependency on the design-lab folder. Adds:
     · row layout for .fwk-m__top (one match per row)
     · crest color palette used by .fwk-team .crest
     · .fxsc screen wrapper (topbar + flex column)
   ============================================================ */

/* ── Screen wrapper ────────────────────────────────────────── */
.fxsc{
  background:var(--bone);
  display:flex;flex-direction:column;height:100%;overflow:hidden;
  position:relative;
}
/* Make room for the bottom tab bar so .fwk-foot isn't hidden behind it. */
.fxsc .fwk{padding-bottom:calc(62px + env(safe-area-inset-bottom))}
@media (min-width:760px){
  .fxsc .fwk{padding-bottom:0}
}
/* ── Fwk container ─────────────────────────────────────────── */
.fwk{
  background:var(--bone);flex:1;overflow-y:auto;overflow-x:hidden;
  display:flex;flex-direction:column;
}

/* Week header */
.fwk-head{
  background:linear-gradient(180deg,#fff 0%,#FAF8F2 100%);
  border-bottom:1px solid var(--line);
  padding:18px 22px 14px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;
}
.fwk-head__wknav{display:flex;align-items:center;gap:12px}
.fwk-head__arr{
  width:38px;height:38px;border-radius:11px;border:1.5px solid var(--line);background:#fff;
  display:grid;place-items:center;color:var(--ink);cursor:pointer;
  transition:background .12s,border-color .12s,color .12s,transform .08s;
}
.fwk-head__arr:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.fwk-head__arr:active{transform:translateY(1px)}
.fwk-head__arr.is-disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.fwk-head__dice{margin-left:4px;color:var(--red, #C8202F)}
.fwk-head__dice:hover{background:var(--red, #C8202F);border-color:var(--red, #C8202F);color:#fff}
.fwk-head__dice:active svg{transform:rotate(30deg);transition:transform .12s ease-out}
.fwk-head__wknum{display:flex;flex-direction:column;line-height:1}

/* Share-this-gameweek bar (above the match list) */
.fwk-sharebar{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:14px 18px 0;padding:13px 16px;
  border-radius:14px;border:1.5px solid var(--line);
  background:linear-gradient(180deg,#fff 0%,#FAF8F2 100%);color:var(--navy);
  font-weight:800;font-size:14.5px;letter-spacing:.01em;cursor:pointer;
  transition:background .12s,border-color .12s,color .12s,transform .08s;
}
.fwk-sharebar svg{width:18px;height:18px;flex:0 0 auto}
.fwk-sharebar:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.fwk-sharebar:active{transform:translateY(1px)}
.fwk-sharebar.is-busy{opacity:.6;cursor:progress;pointer-events:none}
@media (max-width: 720px){ .fwk-sharebar{margin:12px 14px 0} }

/* Small share button pinned to the match card's top-right corner */
.fwk-m__share{
  position:absolute;top:10px;right:10px;z-index:2;
  width:30px;height:30px;display:grid;place-items:center;
  border-radius:9px;border:1.5px solid var(--line);
  background:#fff;color:var(--navy);cursor:pointer;
  box-shadow:0 2px 6px -3px rgba(22,34,46,.22);
  transition:background .12s,border-color .12s,color .12s,transform .08s;
}
.fwk-m__share svg{width:15px;height:15px}
.fwk-m__share:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.fwk-m__share:active{transform:translateY(1px)}
.fwk-m__share.is-busy{opacity:.55;cursor:progress;pointer-events:none}

/* Stats button — sits just left of the share button on live/finished cards */
.fwk-m__stats{
  position:absolute;top:10px;right:46px;z-index:2;
  width:30px;height:30px;display:grid;place-items:center;
  border-radius:9px;border:1.5px solid var(--line);
  background:#fff;color:var(--navy);cursor:pointer;
  box-shadow:0 2px 6px -3px rgba(22,34,46,.22);
  transition:background .12s,border-color .12s,color .12s,transform .08s;
}
.fwk-m__stats svg{width:15px;height:15px}
.fwk-m__stats:hover{background:var(--navy);border-color:var(--navy);color:#fff}
.fwk-m__stats:active{transform:translateY(1px)}
.fwk-m__stats.is-busy{opacity:.55;cursor:progress;pointer-events:none}

/* ── Match-stats overlay (opens inside the fixture screen) ─── */
.fx-stats{
  position:absolute;inset:0;z-index:60;
  display:flex;align-items:flex-end;justify-content:center;
  background:rgba(14,21,48,.46);backdrop-filter:blur(2px);
  opacity:0;transition:opacity .2s ease;
}
.fx-stats.is-open{opacity:1}
.fx-stats__sheet{
  position:relative;width:100%;max-width:560px;max-height:92%;
  background:var(--paper);border-radius:18px 18px 0 0;
  border:1px solid var(--line);border-bottom:0;
  box-shadow:0 -10px 40px -12px rgba(0,0,0,.45);
  display:flex;flex-direction:column;overflow:hidden;
  transform:translateY(14px);transition:transform .2s ease;
}
.fx-stats.is-open .fx-stats__sheet{transform:translateY(0)}
@media (min-width:760px){
  .fx-stats{align-items:center}
  .fx-stats__sheet{border-radius:18px;max-height:88%;border-bottom:1px solid var(--line)}
}
.fx-stats__close{
  position:absolute;top:12px;right:12px;z-index:3;
  width:32px;height:32px;display:grid;place-items:center;
  border-radius:9px;border:1.5px solid var(--line);background:var(--paper);color:var(--ink);
  cursor:pointer;transition:background .12s,color .12s;
}
.fx-stats__close:hover{background:var(--ink);border-color:var(--ink);color:var(--bone)}
.fx-stats__close svg{width:16px;height:16px}
.fx-stats__body{overflow-y:auto;padding:18px 16px 26px;-webkit-overflow-scrolling:touch}
.fx-stats__state{padding:48px 16px;text-align:center;color:var(--muted);font-weight:600;font-size:14px}
.fx-stats__state.is-error{color:var(--red-deep);font-weight:700}
.fx-stats__empty{padding:18px 4px;text-align:center;color:var(--muted);font-weight:600;font-size:12.5px}

.fx-stats__head{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;
  padding:8px 30px 16px;border-bottom:1px solid var(--line);margin-bottom:16px;
}
.fx-stats__team{display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;min-width:0}
.fx-stats__team .cr{width:42px;height:42px;object-fit:contain}
/* Forma jerseys are portrait — let them grow taller, no letterboxing. */
.fx-stats__team img.cr--forma{width:48px;height:auto;max-height:56px;border-radius:5px}
.fx-stats__team .cr--empty{border-radius:50%;background:var(--field)}
.fx-stats__team .nm{font-size:12.5px;font-weight:700;color:var(--ink);line-height:1.2}
.fx-stats__score{display:flex;flex-direction:column;align-items:center;gap:3px}
.fx-stats__score .sc{font-family:var(--display);font-size:30px;color:var(--ink);font-weight:800;white-space:nowrap}
.fx-stats__score .sc em{color:var(--muted);font-style:normal;margin:0 1px}
.fx-stats__score .st{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

.fx-stats__periods{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 14px;margin-bottom:18px}
.fx-stats__per{font-size:11px;color:var(--muted);font-weight:600}
.fx-stats__per b{color:var(--ink-2);font-weight:800;margin-right:3px;text-transform:uppercase;letter-spacing:.05em;font-size:10px}

.fx-stats__sec{margin-top:6px}
.fx-stats__sec + .fx-stats__sec{margin-top:22px}
.fx-stats__sec-h{
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  font-weight:800;margin:0 0 12px;
}
.fx-stats__rows{display:flex;flex-direction:column;gap:13px}
.fx-stats__row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;
  grid-template-areas:"vh lbl va" "bar bar bar";
}
.fx-stats__row .v{font-size:13px;font-weight:800;color:var(--ink)}
.fx-stats__row .v--h{grid-area:vh;justify-self:start}
.fx-stats__row .v--a{grid-area:va;justify-self:end}
.fx-stats__row .lbl{grid-area:lbl;text-align:center;font-size:11px;color:var(--muted);font-weight:600}
.fx-stats__row .bar{grid-area:bar;height:5px;border-radius:99px;background:var(--field);overflow:hidden;display:block}
.fx-stats__row .bar i{display:block;height:100%;border-radius:99px;background:var(--ink)}

.fx-stats__events{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.fx-ev{display:grid;grid-template-columns:34px 22px minmax(0,1fr);align-items:center;gap:8px}
/* Away events mirror to the right — reorder columns via `order` (NOT rtl,
   which clipped names from the wrong end). */
.fx-ev--a{grid-template-columns:minmax(0,1fr) 22px 34px}
.fx-ev--a .fx-ev__txt{order:1;align-items:flex-end;text-align:right}
.fx-ev--a .fx-ev__ic{order:2}
.fx-ev--a .fx-ev__min{order:3;text-align:right}
.fx-ev__min{font-size:11px;font-weight:800;color:var(--muted)}
.fx-ev__ic{display:grid;place-items:center}
.fx-ev__txt{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.fx-ev__txt b{font-size:12.5px;color:var(--ink);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fx-ev__txt small{font-size:10.5px;color:var(--muted);font-weight:500}
.fx-ev .ic{font-size:13px;line-height:1}
.fx-ev .ic--yellow{width:11px;height:14px;border-radius:2px;background:#F2C200;display:block}
.fx-ev .ic--red{width:11px;height:14px;border-radius:2px;background:var(--red, #C8202F);display:block}
.fx-ev .ic--var{font-size:7px;font-weight:800;letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);border-radius:3px;padding:1px 2px}
.fx-ev .ic--miss{color:var(--red, #C8202F)}
.fwk-head__wknum .lbl{
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:700;margin-bottom:6px;
}
.fwk-head__wknum h1{
  margin:0;font-family:var(--display);font-size:38px;letter-spacing:.02em;color:var(--ink);
  display:flex;align-items:baseline;gap:10px;
}
.fwk-head__wknum h1 small{
  font-family:var(--sans);font-size:12px;color:var(--muted);font-weight:600;letter-spacing:0;
}

.fwk-head__center{display:flex;align-items:center;justify-content:center;gap:10px}
.fwk-head__date{
  font-size:13px;color:var(--ink-2);font-weight:600;letter-spacing:.02em;
  background:#fff;border:1px solid var(--line);border-radius:99px;padding:8px 14px;
}
.fwk-head__date b{color:var(--ink);font-weight:800}

/* Mini week strip */
.fwk-weeks{
  display:flex;gap:4px;padding:0 22px;
  border-bottom:1px solid var(--line);background:#fff;
  overflow-x:auto;scrollbar-width:none;
  flex:0 0 auto;
}
.fwk-weeks::-webkit-scrollbar{display:none}
.fwk-weeks a{
  flex-shrink:0;padding:10px 12px;font-size:12px;font-weight:700;color:var(--muted);
  text-decoration:none;border-bottom:2px solid transparent;letter-spacing:.02em;
  display:flex;align-items:center;gap:6px;cursor:pointer;
}
.fwk-weeks a small{font-size:10px;color:#A8AEC4;font-weight:600;letter-spacing:0}
.fwk-weeks a:hover{color:var(--ink-2)}
.fwk-weeks a.is-active{color:var(--ink);border-bottom-color:var(--red)}
.fwk-weeks a.is-active small{color:var(--red)}
.fwk-weeks a .dot{
  width:6px;height:6px;border-radius:99px;background:var(--success);margin-left:2px;
  animation:fwk-livedot 1.6s infinite;
}
@keyframes fwk-livedot{0%{box-shadow:0 0 0 0 rgba(31,138,91,.55)}70%{box-shadow:0 0 0 6px rgba(31,138,91,0)}100%{box-shadow:0 0 0 0 rgba(31,138,91,0)}}

/* ── List · one match per row ─────────────────────────────── */
.fwk-list{
  padding:14px 18px 24px;
  display:grid;grid-template-columns:1fr;gap:10px;
  align-content:start;
}
@media (min-width: 1100px){
  .fwk-list{grid-template-columns:repeat(2, minmax(0, 1fr));gap:12px;align-items:start}
  .fwk-list .fwk-day{grid-column:1 / -1}
  .fwk-list .fwk-state{grid-column:1 / -1}
}
.fwk-day{
  grid-column:1 / -1;
  display:flex;align-items:baseline;gap:10px;margin:6px 0 -2px;
}
.fwk-day h3{
  margin:0;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);font-weight:800;
}
.fwk-day .when{font-size:11.5px;color:var(--muted);font-weight:600}
.fwk-day .badge{
  margin-left:auto;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);font-weight:700;
}
.fwk-day .badge b{color:var(--ink-2)}
.fwk-day .badge.live b{color:var(--red)}
.fwk-day .badge.done b{color:var(--success)}

/* ── Match card ───────────────────────────────────────────── */
.fwk-m{
  position:relative;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  display:flex;flex-direction:column;overflow:hidden;
  transition:border-color .12s,box-shadow .12s;
}
.fwk-m:hover{border-color:#D0D4E2;box-shadow:0 8px 22px -16px rgba(14,21,48,.18)}
.fwk-m.is-live{
  border-color:var(--gold, #E8B848);
  animation:fwk-live-frame 1.4s ease-in-out infinite;
}
@keyframes fwk-live-frame{
  0%,100%{
    border-color:rgba(232,184,72,1);
    box-shadow:0 0 0 1px rgba(232,184,72,.35), 0 0 14px -2px rgba(232,184,72,.55);
  }
  50%{
    border-color:rgba(232,184,72,.35);
    box-shadow:0 0 0 1px rgba(232,184,72,.08), 0 0 6px -2px rgba(232,184,72,.15);
  }
}
.fwk-m.is-done{
  background:#FBF9F4;
  border-color:rgba(135,195,66,.45);
  box-shadow:0 0 0 1px rgba(135,195,66,.08);
}

/* Top row — time top-left, then home · mid · away below */
.fwk-m__top{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);
  grid-template-areas:
    "when when when"
    "home mid  away";
  align-items:center;column-gap:12px;row-gap:10px;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
}
.fwk-m__top .fwk-when      {grid-area:when;justify-self:start;align-self:start}
.fwk-m__top .fwk-team--home{grid-area:home}
.fwk-m__top .fwk-mid       {grid-area:mid}
.fwk-m__top .fwk-team--away{grid-area:away}
.fwk-when{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.fwk-when .t{font-family:var(--display);font-size:22px;color:var(--ink)}
.fwk-when .s{font-size:11px;color:var(--muted);font-weight:600;margin-top:3px}
.fwk-when .pill{
  display:inline-flex;align-items:center;gap:5px;background:var(--gold, #E8B848);color:#1f1408;
  font-size:10px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;
  padding:3px 8px;border-radius:99px;width:max-content;animation:fwk-pulse 1.4s infinite;
}
.fwk-when .pill::before{
  content:'';width:5px;height:5px;border-radius:99px;background:#1f1408;display:inline-block;animation:fwk-pulse 1.4s infinite;
}
.fwk-when.is-done .t{color:var(--success)}
/* finished match: FT and the earned-points badge sit side by side */
.fwk-when.is-done{flex-direction:row;align-items:center;gap:6px;flex-wrap:wrap}
.fwk-when__pts{
  display:inline-flex;align-items:center;width:max-content;
  background:var(--accent);color:var(--accent-ink,#15280A);
  font-size:10px;font-weight:800;letter-spacing:.04em;
  padding:2px 7px;border-radius:99px;white-space:nowrap;
}
.fwk-when__pts.is-zero{background:var(--field);color:var(--muted)}

.fwk-team{display:flex;align-items:center;gap:10px;min-width:0}
.fwk-team--away{flex-direction:row-reverse;text-align:right}
.fwk-team .info{display:flex;flex-direction:column;min-width:0;gap:2px}
.fwk-team .info .n{
  font-size:20px;font-weight:800;color:var(--ink);line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.fwk-team .f{display:flex;gap:3px;margin-top:1px}
.fwk-team--away .f{justify-content:flex-end}
.fwk-team .f i{width:5px;height:5px;border-radius:99px;display:block}
.fwk-team .f i.w{background:var(--success)}
.fwk-team .f i.d{background:#C5CAD8}
.fwk-team .f i.l{background:var(--red)}

.fwk-mid{display:flex;flex-direction:column;align-items:center;gap:3px;min-width:60px}
.fwk-mid .vs{font-family:var(--display);font-size:18px;color:#C5CAD8;letter-spacing:.10em}
.fwk-mid .score{font-family:var(--display);font-size:26px;color:var(--ink);letter-spacing:.04em;display:flex;align-items:baseline;gap:5px;line-height:1}
.fwk-mid .score em{font-style:normal;color:#C5CAD8;font-size:20px}
.fwk-mid .min{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;
  color:var(--red);background:rgba(200,32,47,.12);padding:3px 8px;border-radius:99px;
}
.fwk-mid .min::before{
  content:'';width:5px;height:5px;border-radius:99px;background:var(--red);animation:fwk-pulse 1.4s infinite;
}
.fwk-mid .min.ft{color:var(--success);background:rgba(31,138,91,.14)}
.fwk-mid .min.ft::before{background:var(--success);animation:none}
@keyframes fwk-pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* Crest palette */
.fwk-team .crest{
  width:34px;height:34px;border-radius:8px;
  display:inline-grid;place-items:center;flex:0 0 auto;
  font-family:var(--display);font-size:13px;letter-spacing:.02em;
  background:#EFEFF3;color:var(--ink);overflow:hidden;
}
.fwk-team img.crest{display:block;object-fit:contain;background:transparent !important;padding:2px}
.fwk-team .crest.crest--forma{
  width:96px;height:auto;
  background:transparent;padding:0;border-radius:4px;
}
.fwk-team .crest.crest--empty{
  width:96px;height:96px;background:#EFEFF3;
}
.fwk-team .crest.red    {background:#FFE0E3;color:#A11824}
.fwk-team .crest.navy   {background:#E0E7F4;color:#14224A}
.fwk-team .crest.black  {background:#1A2138;color:#fff}
.fwk-team .crest.sky    {background:#DEF0FB;color:#1F6FB0}
.fwk-team .crest.gold   {background:#FFF1D1;color:#8e620f}
.fwk-team .crest.green  {background:#DBEFE4;color:#15623f}
.fwk-team .crest.claret {background:#F4E0E7;color:#671e3f}
.fwk-team .crest.white  {background:#F5F5F5;color:#333}

/* ── Picks ────────────────────────────────────────────────── */
.fwk-picks{padding:12px 16px 14px;display:flex;gap:14px;flex-wrap:wrap}
.fwk-pgrp{flex:1;min-width:170px;display:flex;flex-direction:column;gap:6px}
.fwk-pgrp__lbl{
  display:flex;align-items:center;gap:8px;font-size:10.5px;
  color:var(--muted);font-weight:700;letter-spacing:.10em;text-transform:uppercase;
}
.fwk-pgrp__lbl .name{color:var(--ink-2);white-space:nowrap}
.fwk-pgrp__lbl .meta{
  margin-left:auto;color:var(--muted);text-transform:none;letter-spacing:0;font-size:11px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;
}
.fwk-pgrp__lbl .meta.ok{color:var(--success);font-weight:700}
.fwk-pgrp__lbl .meta.warn{color:var(--warning);font-weight:700}

.fwk-btns{display:grid;gap:5px}
.fwk-btns--3{grid-template-columns:1fr 1fr 1fr}
.fwk-btns--2{grid-template-columns:1fr 1fr}

.fwk-b{
  background:#fff;border:1.5px solid var(--line);border-radius:9px;
  padding:8px 6px 7px;cursor:pointer;font-family:var(--sans);
  display:flex;flex-direction:column;align-items:center;gap:2px;
  transition:transform .08s,border-color .12s,background .12s;
  position:relative;min-width:0;
}
.fwk-b:hover:not([disabled]){border-color:var(--ink);transform:translateY(-1px)}
.fwk-b:active:not([disabled]){transform:translateY(0)}
.fwk-b .lbl{font-size:10.5px;color:var(--muted);font-weight:700;letter-spacing:.04em;text-transform:uppercase;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fwk-b .val{font-size:15px;color:var(--ink);font-weight:800;letter-spacing:-.01em;line-height:1}
.fwk-b .val .x{color:var(--muted);font-weight:600;margin-right:1px}
.fwk-b .pts{font-size:9.5px;color:var(--muted);font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.fwk-b[disabled]{opacity:.5;cursor:not-allowed;background:var(--field)}
.fwk-b.is-locked{opacity:.5;cursor:not-allowed;background:var(--field)}

/* Picked state — used for both fresh picks (this session) and picks restored
   from /history. Wins over [disabled] / .is-locked so a restored pick stays
   visible even when its group is otherwise greyed out. */
/* Solid dark fill framed with a bright brand-green ring + glow, so the active
   pick pops in both light and dark themes (see design.md — green as accent,
   never as a fill behind light text). */
.fwk-b.is-picked{
  background:var(--ink);border-color:var(--accent);opacity:1;cursor:pointer;
  box-shadow:0 0 0 1px rgba(135,195,66,.30), 0 8px 20px -12px rgba(135,195,66,.55);
}
.fwk-b.is-picked .lbl{color:rgba(255,255,255,.7)}
.fwk-b.is-picked .val{color:#fff}
.fwk-b.is-picked .pts{color:var(--accent)}
.fwk-b.is-picked::after{
  content:'';position:absolute;top:5px;right:5px;
  width:6px;height:6px;border-radius:99px;background:var(--accent);
  box-shadow:0 0 6px rgba(135,195,66,.8);
}
.fwk-b.is-picked[disabled]{opacity:1;cursor:not-allowed}

/* Settled outcomes (FT) — restored from history when a fixture is finished. */
.fwk-b.is-won{background:#F0F8F4;border-color:rgba(31,138,91,.45)}
.fwk-b.is-won .lbl{color:var(--success)}
.fwk-b.is-won .val{color:var(--success)}
.fwk-b.is-picked.is-won{background:linear-gradient(135deg,#1F8A5B,#0F6E48);border-color:var(--success)}
.fwk-b.is-picked.is-won .lbl{color:rgba(255,255,255,.75)}
.fwk-b.is-picked.is-won .val{color:#fff}
.fwk-b.is-picked.is-won .pts{color:rgba(255,255,255,.9)}
.fwk-b.is-picked.is-lost{background:#FDEDEE;border-color:var(--red);color:var(--red-deep)}
.fwk-b.is-picked.is-lost .lbl{color:var(--red-deep)}
.fwk-b.is-picked.is-lost .val{color:var(--red-deep);text-decoration:line-through;text-decoration-color:rgba(161,24,36,.4)}
.fwk-b.is-picked.is-lost .pts{color:var(--red-deep)}
.fwk-b.is-picked.is-lost::after{background:var(--red)}

/* ── Footer bar ───────────────────────────────────────────── */
.fwk-foot{
  background:linear-gradient(0deg,#fff 70%,rgba(255,255,255,0));
  padding:12px 22px 14px;display:flex;align-items:center;gap:14px;
  border-top:1px solid var(--line);flex:0 0 auto;
}
.fwk-foot .meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.fwk-foot .meta b{color:var(--ink);font-weight:700}
.fwk-foot .meta .dot{width:5px;height:5px;border-radius:99px;background:#C5CAD8;display:inline-block}
.fwk-legend{display:flex;align-items:center;gap:14px;font-size:11px;color:var(--muted);font-weight:600;margin-left:auto}
.fwk-legend i{display:inline-flex;align-items:center;gap:5px;font-style:normal}
.fwk-legend i::before{content:'';width:8px;height:8px;border-radius:3px;background:var(--ink);display:block}
.fwk-legend i.live::before{background:var(--red)}
.fwk-legend i.ok::before{background:var(--success)}
.fwk-legend i.warn::before{background:var(--warning)}

/* ── Live challenge band (in-play, SSE-driven) ────────────── */
/* Collapsible challenge-section header. Sits on its own full-width row above
   the .fwk-live bands and folds them away when .fwk-picks.is-ch-collapsed.
   Uses the gold/points palette (--gold / --gold-deep) — challenges award bonus
   points (the won-points badge is gold too), so it reads as reward, not alarm.
   Built from theme tokens so it works in both light and dark mode. */
.fwk-ch-toggle{
  flex:1 1 100%;width:100%;min-width:0;
  margin:10px 0 2px;
  display:flex;align-items:center;gap:8px;
  background:none;border:0;border-top:1px solid var(--line);
  padding:10px 4px 2px;cursor:pointer;
  font:inherit;font-size:11px;font-weight:800;letter-spacing:.08em;
  color:var(--gold-deep, #CF9E2C);text-transform:uppercase;
  transition:color .15s ease,background .15s ease;
}
.fwk-ch-toggle .lbl{flex:1;text-align:left}
.fwk-ch-toggle .chev{
  flex:0 0 auto;color:var(--muted);
  transition:transform .18s ease,color .15s ease;
}
.fwk-ch-toggle:hover .chev{color:var(--gold-deep, #CF9E2C)}
.fwk-picks.is-ch-collapsed > .fwk-live{display:none}

/* Collapsed → make the header an obvious "tap to open" chip rather than a
   faint divider. A gold-tinted fill, full border and a "+" chevron read
   clearly as an inviting action when the bands are hidden. */
.fwk-picks.is-ch-collapsed .fwk-ch-toggle{
  border:1.5px solid rgba(232,184,72,.45);border-radius:10px;
  background:linear-gradient(180deg,#fff,#FFFBF0);
  padding:9px 12px;margin:8px 0 0;
}
.fwk-picks.is-ch-collapsed .fwk-ch-toggle .chev{transform:rotate(-90deg)}
.fwk-picks.is-ch-collapsed .fwk-ch-toggle:hover{
  background:linear-gradient(180deg,#FFFBF0,#FDF3D8);
}

.fwk-live{
  margin:6px 0 -2px;
  /* .fwk-picks is flex-wrap; force this band to its own full-width row. */
  flex:1 1 100%;width:100%;min-width:0;
  background:linear-gradient(180deg,#fff,#FFF6F7);
  border:1.5px solid rgba(200,32,47,.32);border-radius:10px;
  padding:10px 12px;position:relative;
  display:flex;flex-direction:column;gap:8px;
}
.fwk-live::before{
  content:'';position:absolute;left:-1px;top:-1px;bottom:-1px;width:4px;
  border-radius:10px 0 0 10px;background:var(--red, #C8202F);
}
.fwk-live__hd{display:flex;align-items:center;gap:8px}
.fwk-live__pill{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--red, #C8202F);color:#fff;font-size:9.5px;font-weight:800;
  letter-spacing:.10em;text-transform:uppercase;padding:4px 8px;border-radius:99px;
}
.fwk-live__pill::before{
  content:'';width:5px;height:5px;border-radius:99px;background:#fff;
  animation:fwk-pulse 1.4s infinite;
}
.fwk-live__q{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.fwk-live__q b{font-size:12.5px;color:var(--ink);font-weight:800;letter-spacing:-.005em}
.fwk-live__q small{font-size:10.5px;color:var(--muted);font-weight:500}
.fwk-live__opts{display:grid;gap:5px}
.fwk-live__opts.c2{grid-template-columns:1fr 1fr}
.fwk-live__opts.c3{grid-template-columns:1fr 1fr 1fr}
.fwk-live__opts .fwk-b .val small{font-size:9px;color:var(--muted);font-weight:600;margin-left:2px}
.fwk-live.is-locked .fwk-b,
.fwk-live.is-resolved .fwk-b{opacity:.6;pointer-events:none}
/* Won button the user did NOT pick — pale green tint, dark text stays readable. */
.fwk-live.is-resolved .fwk-b.is-won:not(.is-picked){
  opacity:1;border-color:var(--green, #1F8A5B);background:rgba(31,138,91,.08);
}
.fwk-live.is-resolved .fwk-b.is-won:not(.is-picked) .lbl,
.fwk-live.is-resolved .fwk-b.is-won:not(.is-picked) .val{color:var(--success, #1F8A5B)}
/* Won button the user DID pick — solid green gradient with white text + gold pts. */
.fwk-live.is-resolved .fwk-b.is-picked.is-won{
  opacity:1;background:linear-gradient(135deg,#1F8A5B,#0F6E48);border-color:var(--success, #1F8A5B);
}
.fwk-live.is-resolved .fwk-b.is-picked.is-won .lbl{color:rgba(255,255,255,.85)}
.fwk-live.is-resolved .fwk-b.is-picked.is-won .val{color:#fff}
.fwk-live.is-resolved .fwk-b.is-picked.is-won .pts{color:#FFD166}
.fwk-live.is-resolved .fwk-b.is-picked.is-won::after{background:#FFD166}

/* ── State helpers (loading / error / empty placeholder rows) */
.fwk-state{
  grid-column:1 / -1;padding:32px 16px;text-align:center;
  color:var(--muted);font-size:13px;font-weight:600;
}
.fwk-state.is-error{color:var(--red-deep);font-weight:700}

/* ── Mobile-ish narrowing ─────────────────────────────────── */
@media (max-width: 720px){
  /* Stack: forma on top, team name below — for both sides. */
  .fwk-m__top .fwk-team{
    flex-direction:column;align-items:center;text-align:center;gap:6px;
  }
  .fwk-m__top .fwk-team .info{align-items:center}
  .fwk-m__top .fwk-team .info .n{font-size:14px;white-space:normal;line-height:1.2}
  .fwk-m__top .fwk-team .f{justify-content:center}
  .fwk-head{padding:14px 16px 10px;gap:10px;grid-template-columns:auto 1fr auto}
  .fwk-head__wknum h1{font-size:30px}
  .fwk-list{padding:12px 14px 24px}
  /* Always stack 1X2 + O/U on their own rows in mobile. Without this the
     flex-wrap groups fit side-by-side at some widths and collapse to one row. */
  .fwk-pgrp{flex:1 1 100%;min-width:0}
}
