/* ============================================================
   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:auto;
  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}
.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}
  .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{
  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:rgba(200,32,47,.35);
  box-shadow:0 0 0 1px rgba(200,32,47,.07), 0 14px 28px -18px rgba(200,32,47,.28);
}
.fwk-m.is-done{background:#FBF9F4}

/* 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(--red);color:#fff;
  font-size:10px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;
  padding:3px 8px;border-radius:99px;width:max-content;
}
.fwk-when .pill::before{
  content:'';width:5px;height:5px;border-radius:99px;background:#fff;display:inline-block;animation:fwk-pulse 1.4s infinite;
}
.fwk-when.is-done .t{color:var(--success)}

.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:#fff;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. */
.fwk-b.is-picked{background:var(--ink);border-color:var(--ink);opacity:1;cursor:pointer}
.fwk-b.is-picked .lbl{color:rgba(255,255,255,.7)}
.fwk-b.is-picked .val{color:#fff}
.fwk-b.is-picked .pts{color:#9FE3BD}
.fwk-b.is-picked::after{
  content:'';position:absolute;top:5px;right:5px;
  width:6px;height:6px;border-radius:99px;background:#9FE3BD;
}
.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) ────────────── */
.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}
}
