/* ============================================================
   Matchday — the sole visual identity.
   Acid lime on editorial black, Archivo Black + Inter + JetBrains Mono.
   ============================================================ */
:root {
  /* Surface */
  --bg:           #0A0B0D;
  --bg-alt:       #111316;
  --bg-card:      #0F1114;
  --bg-elev:      #16181D;

  /* Ink */
  --ink:          #F4F1E8;
  --ink-muted:    rgba(244, 241, 232, 0.55);
  --ink-dim:      rgba(244, 241, 232, 0.35);

  /* Lines */
  --line:         rgba(244, 241, 232, 0.08);
  --line-strong:  rgba(244, 241, 232, 0.16);

  /* Accents */
  --accent:       #C6FF3D;   /* acid lime */
  --accent-2:     #FF5B2E;   /* stadium orange */
  --accent-ink:   #0A0B0D;   /* ink color against accent bg */

  /* Semantic — matchday palette, matches demo/theme.jsx.
     good == accent on purpose: HIGH bars/chips read as the same bright lime
     as the brand accent. */
  --good:         #C6FF3D;
  --warn:         #FFB840;
  --danger:       #FF4D4D;

  /* Tier chip colors */
  --tier-very-high-bg: #C6FF3D;
  --tier-very-high-fg: #0A0B0D;
  --tier-high-bg:      #70E0A4;
  --tier-high-fg:      #0A0B0D;
  --tier-medium-bg:    #FFB020;
  --tier-medium-fg:    #0A0B0D;
  --tier-low-bg:       rgba(244, 241, 232, 0.12);
  --tier-low-fg:       #F4F1E8;

  /* Typography */
  --font-display: "Archivo Black", Impact, "Helvetica Neue", sans-serif;
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Radius & spacing */
  --radius-xs:    2px;
  --radius-sm:    4px;
  --radius:       4px;
  --radius-lg:    8px;

  /* Animation */
  --ease-out:     cubic-bezier(0.16, 1, 0.3, 1);

  /* Layout */
  --header-h:      56px;
  --header-h-d:    64px;
  --bottom-nav-h:  56px;
  --max-content:   720px;
  --desktop-max:   1440px;
  --rail-w:        340px;
  --break-desktop: 960px;
  --gutter:        32px;

  /* Tier chip style: VERY HIGH / VERY LOW are filled, HIGH/MEDIUM/LOW are outlined.
     Foregrounds track --good/--warn/--danger exactly (demo parity). */
  --chip-high-fg:   #C6FF3D;
  --chip-medium-fg: #FFB840;
  --chip-low-fg:    #FF4D4D;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
/* ============================================================
   Reset + base typography
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 900;
  letter-spacing: -0.01em;
  margin: 0 0 12px;
  line-height: 1.1;
}
h1 { font-size: 28px; }
h2 { font-size: 22px; }
h3 { font-size: 18px; }

p { margin: 0 0 12px; }

a {
  color: inherit;
  text-decoration: none;
}
a:hover { color: var(--accent); }

button {
  font-family: inherit;
  font: inherit;
  color: inherit;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}

/* Accessible focus ring everywhere */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Skip link for keyboard users */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  padding: 12px 16px;
  background: var(--accent);
  color: var(--accent-ink);
  font-weight: 700;
  z-index: 100;
}
.skip-link:focus {
  left: 12px;
  top: 12px;
}

img, svg { display: block; max-width: 100%; }

.mono { font-family: var(--font-mono); }
.display { font-family: var(--font-display); }
.muted { color: var(--ink-muted); }
.dim { color: var(--ink-dim); }

/* Self-hosted fonts — WOFF2 subsets. Files ship in public/assets/fonts/.
   Drop actual .woff2 files during Phase 1. */
@font-face {
  font-family: "Archivo Black";
  src: url("../fonts/archivo-black-latin.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Inter";
  src: url("../fonts/inter-latin.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("../fonts/jetbrains-mono-latin.woff2") format("woff2");
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

/* Layout helpers */
.container {
  width: 100%;
  max-width: var(--max-content);
  margin: 0 auto;
  padding: 0 16px;
}

.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;
}
/* ============================================================
   Header / top bar — desktop-first
   ============================================================ */
.topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(10, 11, 13, 0.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  transition: transform 220ms var(--ease-out);
}
.topbar--hidden { transform: translateY(-100%); }

.topbar__row {
  display: flex;
  align-items: center;
  gap: 16px;
  height: var(--header-h-d);
  padding: 0 var(--gutter);
  max-width: var(--desktop-max);
  margin: 0 auto;
}

/* Desktop sport tabs — underlined tab style (matches demo/layout.jsx). */
.sport-tabs {
  display: inline-flex;
  gap: 2px;
  margin-left: 32px;
}
.sport-tabs a {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.sport-tabs a:hover { color: var(--ink); }
.sport-tabs a[aria-current="page"] {
  color: var(--ink);
  font-weight: 700;
  border-bottom-color: var(--accent);
}

/* Sync status — dot + text showing data freshness */
.sync-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.05em;
}
.sync-status__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--good);
  box-shadow: 0 0 8px var(--good);
  animation: syncPulse 2s infinite;
}
.sync-status--stale .sync-status__dot { background: var(--warn); box-shadow: 0 0 8px var(--warn); }
.sync-status--offline .sync-status__dot { background: var(--danger); box-shadow: none; animation: none; }
@keyframes syncPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Sub-nav tabs (second row in topbar) */
.subnav {
  border-top: 1px solid var(--line);
}
.subnav__row {
  max-width: var(--desktop-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  align-items: center;
  gap: 4px;
}
.subnav__tab {
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  background: none;
  border-left: 0; border-right: 0; border-top: 0;
  cursor: pointer;
  text-decoration: none;
}
.subnav__tab:hover { color: var(--ink); }
.subnav__tab[aria-current="page"],
.subnav__tab.is-active {
  color: var(--ink);
  font-weight: 700;
  border-bottom-color: var(--accent);
}

/* GO VIP button — matches demo CTA. Clicking opens a "Coming soon" state. */
.vip-btn {
  display: inline-flex;
  align-items: center;
  padding: 9px 16px;
  background: var(--accent);
  color: var(--accent-ink);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
}
.vip-btn:hover { filter: brightness(1.05); color: var(--accent-ink); }
.vip-btn--disabled { opacity: 0.55; cursor: default; }
.vip-btn--disabled:hover { filter: none; }
/* Lockup = W|D mark + two-line wordmark (wordmark + tagline). */
.topbar__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
}
.topbar__brand:hover { color: var(--ink); }
.topbar__brand:hover .mark { filter: brightness(1.05); }
.wordmark-block { display: inline-flex; flex-direction: column; line-height: 1; }
.wordmark-block__tagline {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--ink-muted);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-top: 3px;
}

.mark {
  width: 28px;
  height: 28px;
  background: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.mark__letters {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-display);
  color: var(--accent-ink);
  font-size: 14px;
  letter-spacing: -0.5px;
  line-height: 1;
}
.mark__divider {
  width: 1px;
  height: 11px;
  background: var(--accent-ink);
  margin: 0 2px;
}

.wordmark {
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: -0.4px;
  line-height: 1;
  text-transform: uppercase;
}
.wordmark__or { color: var(--accent); }

.search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 6px 10px;
}
.search input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--ink);
  font: inherit;
}
.search input::placeholder { color: var(--ink-dim); }

.iconbtn {
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center; justify-content: center;
  border-radius: var(--radius);
  color: var(--ink);
}
.iconbtn:hover { background: var(--bg-alt); }

/* Back arrow — only useful on mobile; desktop has full subnav */
.topbar__back { display: none; }
@media (max-width: 959.98px) {
  .topbar__back { display: inline-flex; }
}

/* ============================================================
   Bottom nav — MOBILE ONLY (hidden on desktop)
   Glass nav with TODAY / FIXTURES / RECORD / PROFILE.
   ============================================================ */
.bottom-nav {
  display: none;
  position: fixed;
  inset: auto 0 0 0;
  z-index: 30;
  background: rgba(10, 11, 13, 0.68);
  border-top: 1px solid var(--line-strong);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.bottom-nav__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  max-width: var(--max-content);
  margin: 0 auto;
  height: var(--bottom-nav-h);
}
.bottom-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  text-decoration: none;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.bottom-nav__item:hover { color: var(--ink); }
.bottom-nav__item[aria-current="page"] { color: var(--accent); }
.bottom-nav__item--vip { color: var(--accent); }
.bottom-nav__item--vip:hover { color: var(--accent); filter: brightness(1.1); }
.bottom-nav__icon { width: 22px; height: 22px; }

/* ============================================================
   Search — desktop inline (legacy) + icon button + floating overlay
   ============================================================ */
.search-iconbtn {
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center; justify-content: center;
  border-radius: var(--radius);
  color: var(--ink);
  background: none;
  border: 0;
  cursor: pointer;
}
.search-iconbtn:hover { background: var(--bg-alt); color: var(--accent); }

.search-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(10, 11, 13, 0.75);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 16px 16px;
}
.search-overlay[data-open="true"] { display: flex; }
.search-overlay__panel {
  width: 100%;
  max-width: 640px;
  background: var(--bg-card);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.6);
  display: flex;
  flex-direction: column;
  max-height: calc(100dvh - 96px);
}
.search-overlay__row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
}
.search-overlay__row svg { color: var(--ink-muted); flex: 0 0 auto; }
.search-overlay__input {
  flex: 1;
  min-width: 0;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--ink);
  font: inherit;
  font-size: 15px;
}
.search-overlay__input::placeholder { color: var(--ink-dim); }
.search-overlay__close {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: none;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: 5px 9px;
  cursor: pointer;
  flex: 0 0 auto;
}
.search-overlay__close:hover { color: var(--ink); border-color: var(--ink-muted); }
.search-overlay__results {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
}
.search-overlay__result {
  display: block;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  text-decoration: none !important;
  color: var(--ink);
}
.search-overlay__result:hover { background: var(--bg-elev); }
.search-overlay__result:last-child { border-bottom: 0; }
.search-overlay__result-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.search-overlay__result-match {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
}
.search-overlay__result-pick {
  font-size: 12px;
  color: var(--ink-muted);
}
.search-overlay__hint {
  padding: 28px 16px;
  text-align: center;
  color: var(--ink-muted);
  font-size: 13px;
}

/* ============================================================
   Footer
   ============================================================ */
.footer {
  border-top: 1px solid var(--line);
  padding: 40px 0;
  color: var(--ink-muted);
  font-size: 13px;
}
.footer__inner {
  max-width: var(--desktop-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.footer p { margin: 0 0 12px; }
.footer p:last-child { margin: 0; }
.footer__disclaimer {
  border-top: 1px solid var(--line);
  margin-top: 16px;
  padding-top: 16px;
  font-size: 12px;
  color: var(--ink-dim);
  line-height: 1.55;
}
.footer a { text-decoration: underline; }
.footer a:hover { color: var(--accent); }

/* Footer grid — brand + Sports / Tools / Company columns */
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 32px;
  padding-bottom: 32px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.footer__brand-row {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  text-decoration: none !important;
  color: var(--ink);
}
.footer__brand-row:hover { color: var(--ink); }
.footer__tagline {
  font-size: 12px;
  color: var(--ink-muted);
  max-width: 360px;
  line-height: 1.55;
  margin: 0 0 16px !important;
}
.footer__gamble-line {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.04em;
  margin: 0 !important;
}
.footer__col-head {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.15em;
  color: var(--ink-muted);
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.footer__col a {
  display: block;
  font-size: 13px;
  color: var(--ink);
  padding: 5px 0;
  text-decoration: none;
}
.footer__col a:hover { color: var(--accent); }
.footer__channels {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}
.footer__channel {
  flex: 1;
  padding: 10px 12px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 600;
}
.footer__channel:hover { border-color: var(--accent); color: var(--accent); }

/* Socials row — Instagram / TikTok / X (secondary channels) */
.socials {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 16px;
}
.socials__label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-right: 8px;
}
.social {
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  color: var(--ink-muted);
  transition: color 120ms, border-color 120ms;
}
.social:hover { color: var(--accent); border-color: var(--accent); }
.social svg { width: 18px; height: 18px; }

/* ============================================================
   TierChip
   ============================================================ */
/* Tier chip — design system: filled for VERY HIGH, outlined for the rest. */
.tier-chip {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 2px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  line-height: 1.2;
  border: 1px solid transparent;
}
.tier-chip--very-high { background: var(--good);       color: var(--accent-ink); border-color: var(--good); }
.tier-chip--high      { background: transparent;       color: var(--chip-high-fg);   border-color: var(--chip-high-fg); }
.tier-chip--medium    { background: transparent;       color: var(--chip-medium-fg); border-color: var(--chip-medium-fg); }
.tier-chip--low       { background: transparent;       color: var(--chip-low-fg);    border-color: var(--chip-low-fg); }
.tier-chip--very-low  { background: var(--danger);     color: var(--accent-ink); border-color: var(--danger); }

/* ============================================================
   ProbBar
   ============================================================ */
.probbar {
  position: relative;
  width: 100%;
  height: 6px;
  background: var(--gauge-track, rgba(244, 241, 232, 0.1));
  border-radius: 999px;
  overflow: hidden;
}
.probbar__fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--accent);
  border-radius: 999px;
  width: 0;
  transition: width 900ms var(--ease-out);
}
.probbar__fill--tint-good   { background: var(--good); }
.probbar__fill--tint-warn   { background: var(--warn); }
.probbar__fill--tint-danger { background: var(--danger); }

/* ============================================================
   ConfidenceGauge (semi-circle)
   ============================================================ */
.gauge {
  display: inline-block;
  position: relative;
  line-height: 0;
}
.gauge__svg { overflow: visible; }
.gauge__track { stroke: var(--gauge-track, rgba(244, 241, 232, 0.1)); }
.gauge__fill  { stroke: var(--accent); transition: stroke-dashoffset 1100ms var(--ease-out); }
.gauge__label {
  position: absolute;
  inset: auto 0 0 0;
  text-align: center;
  padding-bottom: 4px;
}
.gauge__value {
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1;
  display: block;
}
.gauge__caption {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ============================================================
   Crest (team badge placeholder)
   ============================================================ */
.crest {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  /* Double-ring per demo/theme.jsx Crest:
     inner border matches the card background (creates a clean gap against
     the team color), outer box-shadow is the visible muted ring. */
  border: 2px solid var(--bg-card);
  box-shadow: 0 0 0 1px var(--line-strong);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  color: #fff;
  background: var(--bg-elev);
  flex: 0 0 auto;
  letter-spacing: 0.02em;
  /* Inherits text-shadow so labels stay legible on any team color */
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

/* ============================================================
   Filter chip row
   ============================================================ */
.chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 8px 12px;
  scrollbar-width: none;
}
.chip-row::-webkit-scrollbar { display: none; }

.chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  color: var(--ink-muted);
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  flex: 0 0 auto;
}
.chip:hover { color: var(--ink); border-color: var(--line-strong); }
.chip[aria-pressed="true"] {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
  font-weight: 700;
}

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-radius: var(--radius);
  background: var(--accent);
  color: var(--accent-ink);
  font-weight: 700;
  font-size: 14px;
  text-align: center;
}
.btn:hover { filter: brightness(1.05); color: var(--accent-ink); }
.btn--ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--line-strong);
}
.btn--ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn--block { width: 100%; }

/* ============================================================
   Intro modal
   ============================================================ */
.modal-scrim {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 60;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  animation: modalFadeIn 200ms var(--ease-out);
}
@keyframes modalFadeIn { from { opacity: 0; } to { opacity: 1; } }

.modal {
  width: 100%;
  max-width: var(--max-content);
  background: var(--bg-card);
  border-top: 1px solid var(--line-strong);
  border-radius: 16px 16px 0 0;
  padding: 24px 20px calc(20px + env(safe-area-inset-bottom));
  animation: modalSlide 280ms var(--ease-out);
}
@keyframes modalSlide { from { transform: translateY(30px); } to { transform: translateY(0); } }

.modal__close {
  position: absolute;
  top: 12px; right: 12px;
  padding: 6px 10px;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-size: 12px;
}
.modal__dot-row {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-top: 20px;
}
.modal__dot {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--line-strong);
}
.modal__dot[aria-current="step"] { background: var(--accent); }

/* ============================================================
   Mid-week banner
   ============================================================ */
.banner {
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin: 12px 16px;
  font-size: 14px;
}
.banner__title {
  font-family: var(--font-display);
  font-size: 16px;
  margin-bottom: 4px;
}

/* ============================================================
   Empty state
   ============================================================ */
.empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--ink-muted);
}
.empty__title {
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 6px;
}

/* ============================================================
   Results ticker — matches demo/layout.jsx ResultsTicker
   ============================================================ */
.ticker {
  background: var(--bg-alt);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.ticker__row {
  max-width: var(--desktop-max);
  margin: 0 auto;
  display: flex;
  align-items: stretch;
}
.ticker__label {
  padding: 10px 16px;
  background: var(--accent);
  color: var(--accent-ink);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 0 0 auto;
}
.ticker__label-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent-ink);
  animation: tickerPulse 1.5s infinite;
}
@keyframes tickerPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

.ticker__viewport {
  flex: 1;
  overflow: hidden;
  padding: 10px 0;
}
.ticker__track {
  display: inline-flex;
  gap: 32px;
  white-space: nowrap;
  animation: tickerScroll 60s linear infinite;
  /* Force a GPU compositing layer so the marquee animation runs off the
     main thread. Without these hints the track repaints every frame on
     mobile (Safari + Chrome Android), producing the visible judder. */
  will-change: transform;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  contain: layout paint;
}
.ticker__item {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-muted);
}
.ticker__item-match { color: var(--ink); }
.ticker__item-sep   { color: var(--ink-dim); }
.ticker__item-pick  { color: var(--ink); }
.ticker__item-status { font-weight: 800; }
.ticker__item--hit     .ticker__item-status { color: var(--good); }
.ticker__item--miss    .ticker__item-status { color: var(--danger); }
.ticker__item--pending .ticker__item-status { color: var(--accent); }
.ticker__item--live    .ticker__item-status { color: var(--danger); letter-spacing: 0.08em; }
.ticker__item--live    .ticker__item-match  { color: var(--ink); }
.ticker__item-live-dot {
  display: inline-block;
  width: 8px; height: 8px;
  margin-right: 6px;
  background: var(--danger);
  border-radius: 50%;
  vertical-align: middle;
  animation: tickerLivePulse 1.4s ease-in-out infinite;
}
@keyframes tickerLivePulse {
  0%, 100% { opacity: 1;   transform: scale(1); }
  50%      { opacity: 0.35; transform: scale(0.85); }
}
@keyframes tickerScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================
   Stats strip — coverage KPIs only
   ============================================================ */
.stats-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin: 24px 0;
  overflow: hidden;
}
.stats-strip__cell {
  padding: 18px 20px;
  background: var(--bg-card);
}
.stats-strip__label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.stats-strip__value {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1;
  margin-top: 6px;
}
.stats-strip__value--accent { color: var(--accent); }
.stats-strip__caption {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  color: var(--ink-dim);
  margin-top: 8px;
  text-transform: uppercase;
}

/* ============================================================
   Hero leaderboard — mirrors demo/layout.jsx HeroLeaderboard.
   Eyebrow + big display headline + sub, with perf card floated right.
   Below: bordered board table (CSS grid rows) listing top 10.
   ============================================================ */
.hero-lb {
  margin-bottom: 24px;
}
.hero-lb__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 24px;
}
.hero-lb__intro { min-width: 0; flex: 1; }
.hero-lb__eyebrow {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 6px;
}
.hero-lb__eyebrow-bar {
  display: block;
  height: 1px;
  width: 40px;
  background: var(--accent);
}
.hero-lb__eyebrow-text {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.18em;
  font-weight: 700;
  text-transform: uppercase;
}
.hero-lb__title {
  font-family: var(--font-display);
  font-size: 52px;
  font-weight: 900;
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
  text-transform: uppercase;
  max-width: 700px;
}
.hero-lb__sub {
  font-size: 14px;
  color: var(--ink-muted);
  margin: 10px 0 0;
  max-width: 520px;
  line-height: 1.5;
}
.hero-lb__perf {
  min-width: 280px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  flex: 0 0 auto;
}
.hero-lb__perf:empty { display: none; }
.hero-lb__perf-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px;
}
.hero-lb__perf-label {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-muted);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
}
.hero-lb__perf-hitrate {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 900;
  color: var(--good);
  line-height: 1;
  margin-top: 4px;
  letter-spacing: -0.02em;
}
.hero-lb__perf-hitrate--locked {
  color: var(--ink-muted);
  font-size: 28px;
}
.hero-lb__perf-streak-val {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 800;
  color: var(--ink);
  line-height: 1;
  margin-top: 4px;
}
.hero-lb__perf-foot {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-dim);
  margin-top: 6px;
  letter-spacing: 0.06em;
}
.hero-lb__perf-chart { color: var(--good); }
.hero-lb__perf-chart svg { display: block; width: 100%; }

.hero-lb__board {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-card);
}
.hero-lb__row {
  display: grid;
  grid-template-columns: 48px 1fr 140px 110px 90px 80px 72px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  align-items: center;
  gap: 12px;
  color: var(--ink);
  text-decoration: none;
  transition: background 150ms;
}
.hero-lb__row:last-child { border-bottom: 0; }
.hero-lb__row:not(.hero-lb__row--head):hover { background: var(--bg-alt); }
.hero-lb__row--head {
  background: var(--bg-alt);
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-muted);
  letter-spacing: 0.18em;
  font-weight: 700;
  text-transform: uppercase;
  padding: 10px 18px;
  cursor: default;
}
.hero-lb__col--right  { text-align: right; }
.hero-lb__col--center { text-align: center; }

.hero-lb__rank {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 22px;
  color: var(--ink-muted);
  letter-spacing: -0.02em;
}
.hero-lb__rank--first { color: var(--accent); }
.hero-lb__rank--top   { color: var(--ink); }

.hero-lb__match { display: flex; align-items: center; gap: 10px; min-width: 0; }
.hero-lb__crests { display: flex; flex: 0 0 auto; }
.hero-lb__crests > *:nth-child(2) { margin-left: -6px; }
.hero-lb__crests .crest {
  width: 22px; height: 22px;
  font-size: 9px;
  border-width: 1.5px;
}
.hero-lb__names { min-width: 0; overflow: hidden; }
.hero-lb__teams {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-lb__teams-vs { color: var(--ink-dim); font-weight: 400; }
.hero-lb__meta {
  font-size: 10px;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-lb__market {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
}
.hero-lb__market-primary {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-lb__market-secondary {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--ink-muted);
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-lb__prob { text-align: right; }
.hero-lb__prob-val {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--good);
}
.hero-lb__prob-bar { margin-top: 4px; }
.hero-lb__prob-bar .probbar { height: 3px; display: block; }
.hero-lb__conf  { display: flex; justify-content: center; }
.hero-lb__trend { display: flex; justify-content: center; color: var(--accent); opacity: 0.9; }
.hero-lb__ko {
  text-align: right;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-muted);
  white-space: nowrap;
}

/* Narrow-desktop: drop the trend sparkline column to avoid squeeze. */
@media (max-width: 1199.98px) {
  .hero-lb__row { grid-template-columns: 44px 1fr 120px 100px 80px 72px; gap: 10px; padding: 12px 16px; }
  .hero-lb__row--head { padding: 10px 16px; }
  .hero-lb__trend, .hero-lb__row--head > span:nth-child(6) { display: none; }
  .hero-lb__row--head > span:nth-child(7) { grid-column: auto; }
}

/* Stack head + perf card on narrow desktop */
@media (max-width: 1099.98px) {
  .hero-lb__head { flex-direction: column; align-items: stretch; }
  .hero-lb__perf { min-width: 0; }
  .hero-lb__title { font-size: 42px; }
}

/* ============================================================
   Right rail (desktop only) — sticky CTAs sidebar
   ============================================================ */
.rail {
  position: sticky;
  top: calc(var(--header-h-d) + 24px);
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rail__card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 18px 20px;
}
.rail__label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.rail__title {
  font-family: var(--font-display);
  font-size: 16px;
  line-height: 1.2;
  margin: 6px 0 12px;
}
.rail__p { font-size: 13px; color: var(--ink-muted); line-height: 1.5; margin-bottom: 12px; }

/* ============================================================
   Section heading (Today / Fixtures / etc.)
   ============================================================ */
.section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin: 32px 0 12px;
}
.section-head__title {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -0.01em;
}
.section-head__sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ============================================================
   Page-level spacing helpers
   ============================================================ */
main { padding-bottom: 60px; }

/* ============================================================
   Mobile overrides @media (max-width: 959px)
   Match today's mobile design; hide desktop-only elements.
   ============================================================ */
@media (max-width: 959.98px) {
  /* Keep topbar permanently pinned on mobile — no auto-hide on scroll. */
  .topbar--hidden { transform: none !important; }
  .topbar__row {
    height: var(--header-h);
    padding: 0 12px;
    max-width: var(--max-content);
    gap: 12px;
  }
  .sport-tabs { display: none; }
  /* Mobile topbar shows only: (optional back) + logo + LIVE + search icon. */
  .topbar .vip-btn,
  .topbar #share-btn,
  .topbar > .topbar__row > .search { display: none; }
  /* Tagline under wordmark gets cramped on narrow phones — drop it */
  .topbar .wordmark-block__tagline { display: none; }

  .stats-strip { display: none; }   /* mobile skips the 5-cell coverage strip */
  /* hero-lb stays visible on mobile — restyled in pages-home.css */
  /* ticker stays visible on mobile — tighten spacing for small viewports */
  .ticker { padding: 0 !important; }
  .ticker__label { padding: 8px 10px; font-size: 9px; letter-spacing: 1px; }
  .ticker__viewport { padding: 8px 0; }
  .ticker__item { font-size: 10px; }
  .rail { display: none; }
  .bottom-nav { display: block; }
  main { padding-bottom: calc(var(--bottom-nav-h) + 40px); }
  .footer {
    padding: 24px 0 calc(var(--bottom-nav-h) + 24px);
  }
  .footer__inner { padding: 0 16px; }
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding-bottom: 24px;
    margin-bottom: 16px;
  }
  .footer__brand { grid-column: 1 / -1; }

  /* Search overlay becomes fullscreen sheet on mobile */
  .search-overlay {
    padding: 0;
    align-items: stretch;
  }
  .search-overlay__panel {
    max-width: 100%;
    border-radius: 0;
    border: 0;
    height: 100dvh;
    max-height: 100dvh;
  }

  /* Subnav tabs can overflow 4 long labels on narrow phones — scroll instead. */
  .subnav__row {
    overflow-x: auto;
    scrollbar-width: none;
    padding: 0 12px;
    -webkit-overflow-scrolling: touch;
  }
  .subnav__row::-webkit-scrollbar { display: none; }
  .subnav__tab {
    flex: 0 0 auto;
    padding: 10px 12px;
    font-size: 12px;
    white-space: nowrap;
  }
}
/* ============================================================
   Home feed — desktop-first layout
   ============================================================ */

/* Desktop shell is now a vertical block: hero + stats are full-bleed
   (constrained by inner max-width), and the picks section below has
   its own 2-col grid for picks + rail. */
.home-shell {
  max-width: var(--desktop-max);
  margin: 0 auto;
  padding: 24px var(--gutter);
  display: block;
}

/* Today's Top Picks section — eyebrow + title + filter pills, then
   2-col grid (picks grid | rail). */
.picks-section {
  margin-top: 24px;
}
.picks-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.picks-head__intro { min-width: 0; }
.picks-head__eyebrow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.picks-head__eyebrow-bar {
  display: block;
  height: 1px;
  width: 24px;
  background: var(--accent);
}
.picks-head__eyebrow-text {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--accent);
  letter-spacing: 0.2em;
  font-weight: 700;
  text-transform: uppercase;
}
.picks-head__title {
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 900;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0;
}
.picks-head__meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  margin-top: 8px;
}
.picks-head__filters {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.picks-head__pill {
  background: transparent;
  color: var(--ink-muted);
  border: 1px solid var(--line);
  padding: 6px 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: var(--radius-xs);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.picks-head__pill:hover { color: var(--ink); border-color: var(--line-strong); }
.picks-head__pill[aria-pressed="true"] {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.picks-head__pill-count {
  font-size: 9px;
  opacity: 0.7;
  padding: 1px 5px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: var(--radius-xs);
}
.picks-head__pill[aria-pressed="true"] .picks-head__pill-count {
  background: rgba(255,255,255,0.15);
  border: 0;
  color: inherit;
}

/* "More leagues" native <select>, sized and styled to match a pill.
   Uses CSS gradients for the chevron so there's no external svg asset. */
.picks-head__select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: var(--bg-card);
  color: var(--ink);
  border: 1px solid var(--line);
  padding: 6px 24px 6px 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: var(--radius-xs);
  background-image:
    linear-gradient(45deg,  transparent 50%, var(--ink-muted) 50%),
    linear-gradient(135deg, var(--ink-muted) 50%, transparent 50%);
  background-position: calc(100% - 12px) 50%, calc(100% - 8px) 50%;
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
  color-scheme: dark;
  line-height: 1.2;
}
/* Force high-contrast options inside the open dropdown.
   Browsers only respect a small subset of properties on <option>, but these
   stick in Chrome/Firefox/Safari and fix the "faded list" look. */
.picks-head__select option {
  background: var(--bg-card);
  color: var(--ink);
  font-family: var(--font-mono);
}
.picks-head__select:hover { border-color: var(--line-strong); }
.picks-head__select:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

/* Page-level editorial header used on All Picks / Top Banker views.
   Mirrors demo/app.jsx AllPicksTab + TopBankerTab header: eyebrow bar,
   big display title, description paragraph. */
.page-head { margin: 8px 0 20px; }
.page-head__eyebrow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.page-head__eyebrow-bar {
  display: block;
  height: 1px;
  width: 40px;
  background: var(--accent);
}
.page-head__eyebrow-text {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.2em;
  font-weight: 700;
  text-transform: uppercase;
}
.page-head__title {
  font-family: var(--font-display);
  font-size: 44px;
  line-height: 1;
  font-weight: 900;
  color: var(--ink);
  letter-spacing: -0.025em;
  margin: 0;
}
.page-head__sub {
  font-size: 13px;
  color: var(--ink-muted);
  margin: 10px 0 0;
  max-width: 640px;
  line-height: 1.5;
}

/* Bordered filter + sort toolbar used on All Picks / Top Banker views. */
.filter-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding: 14px 16px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin-bottom: 20px;
}
.filter-toolbar__label {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-muted);
  letter-spacing: 0.12em;
  font-weight: 700;
  text-transform: uppercase;
}
.filter-toolbar__pills {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.filter-toolbar__spacer { flex: 1; }
.filter-toolbar__count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
}

.picks-section__grid {
  display: grid;
  grid-template-columns: 1fr var(--rail-w);
  gap: var(--gutter);
  align-items: start;
}
.picks-section__main { min-width: 0; }
.picks-section .rail { position: sticky; top: calc(var(--header-h-d) + 16px); }

/* All filter chip rows stack in a grid on desktop, single row on mobile. */
.filters {
  display: grid;
  grid-template-columns: repeat(4, auto) 1fr;
  gap: 8px;
  padding: 4px 0 16px;
  align-items: center;
}
.filters .chip-row {
  padding: 0;
  display: inline-flex;
}
.filters .chip-row + .chip-row { border-left: 1px solid var(--line); padding-left: 8px; }

/* Match grid — 2 columns on desktop, 1 column on mobile. */
#matches {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding-bottom: 24px;
}

/* ============================================================
   Pick card — ports demo/cards.jsx PickCard.
   Sections (top→bottom): head meta / teams / main pick /
   sure bankers / model bankers / footer 2×2 stats.
   ============================================================ */
.pick-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  color: var(--ink);
  text-decoration: none;
  transition: border-color 160ms var(--ease-out), transform 160ms var(--ease-out);
}
.pick-card:hover {
  border-color: var(--line-strong);
  transform: translateY(-2px);
  color: var(--ink);
}

.pick-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.1em;
}
.pick-card__head-meta { display: flex; gap: 8px; flex-wrap: wrap; }
.pick-card__head-sep  { color: var(--ink-dim); }
.pick-card__risk {
  font-weight: 800;
  letter-spacing: 0.1em;
}
.pick-card__risk--low    { color: var(--good); }
.pick-card__risk--medium { color: var(--warn); }
.pick-card__risk--high   { color: var(--danger); }

.pick-card__teams {
  padding: 18px 16px 14px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.pick-card__crests { display: flex; flex: 0 0 auto; }
.pick-card__crests .pick-card__crest + .pick-card__crest { margin-left: -10px; }
.pick-card__crests .crest {
  width: 36px; height: 36px;
  font-size: 12px;
}
.pick-card__names {
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1.1;
  font-weight: 800;
  color: var(--ink);
  flex: 1;
  min-width: 0;
}
.pick-card__vs { color: var(--ink-dim); font-weight: 400; }

.pick-card__main {
  padding: 0 16px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.pick-card__main-left { flex: 1; min-width: 0; }
.pick-card__main-label {
  font-size: 9px;
  letter-spacing: 0.18em;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  text-transform: uppercase;
  font-weight: 700;
}
.pick-card__main-name {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 800;
  color: var(--accent);
  margin-top: 3px;
}
.pick-card__main-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
}
.pick-card__main-bar { flex: 1; min-width: 0; }
.pick-card__main-bar .probbar { height: 4px; display: block; }
.pick-card__main-pct {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--ink);
}

.pick-card__bankers {
  margin: 0 16px 10px;
  padding: 10px 12px;
  border-radius: var(--radius);
}
.pick-card__bankers--sure {
  background: rgba(255, 184, 64, 0.06);
  border: 1px solid rgba(255, 184, 64, 0.25);
  color: var(--warn);
}
.pick-card__bankers--model {
  background: rgba(198, 255, 61, 0.05);
  border: 1px solid rgba(198, 255, 61, 0.22);
  color: var(--good);
}
.pick-card__bankers-head {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.pick-card__bankers-mark { font-size: 11px; line-height: 1; }
.pick-card__bankers-row {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  padding: 2px 0;
}

.pick-card__footer {
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line);
}
.pick-card__footer-cell {
  background: var(--bg-card);
  padding: 8px 12px;
}
.pick-card__footer-label {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--ink-dim);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 700;
}
.pick-card__footer-row {
  display: flex;
  justify-content: space-between;
  margin-top: 2px;
}
.pick-card__footer-value {
  font-size: 12px;
  color: var(--ink);
  font-weight: 600;
}
.pick-card__footer-pct {
  font-size: 11px;
  color: var(--ink-muted);
  font-family: var(--font-mono);
}

/* ============================================================
   "View all picks" callout — wide horizontal card
   ============================================================ */
.view-all-callout {
  margin: 32px 0;
  padding: 28px 32px;
  background: var(--bg-card);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
  cursor: pointer;
  transition: border-color 160ms var(--ease-out), transform 160ms var(--ease-out);
}
.view-all-callout:hover {
  border-color: var(--accent);
  transform: translateY(-1px);
}
.view-all-callout:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.view-all-callout__label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.view-all-callout__title {
  font-family: var(--font-display);
  font-size: 24px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0 0 6px;
}
.view-all-callout__sub {
  color: var(--ink-muted);
  font-size: 13px;
  margin: 0;
}
.view-all-callout__btn {
  padding: 14px 20px;
  background: var(--accent);
  color: var(--accent-ink);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 2px;
  cursor: pointer;
  white-space: nowrap;
  border: 0;
}
.view-all-callout__btn:hover { filter: brightness(1.05); }

@media (max-width: 720px) {
  .view-all-callout {
    grid-template-columns: 1fr;
    padding: 20px 18px;
    gap: 16px;
    margin: 20px 12px;
  }
  .view-all-callout__title { font-size: 20px; }
  .view-all-callout__btn { width: 100%; }
}

/* ============================================================
   Card grid (used by All Picks / Top Banker / Market Breakdown)
   ============================================================ */
.card-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding-bottom: 24px;
}

/* Sort controls */
.sort-controls select {
  background: var(--bg-alt);
  color: var(--ink);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: 6px 10px;
  font: inherit;
  font-size: 12px;
  font-family: var(--font-mono);
  margin-left: 8px;
}

/* ============================================================
   Top Banker card — ported from demo/cards.jsx TopBankerCard
   ============================================================ */
.banker-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color 150ms, transform 150ms;
  cursor: pointer;
  color: inherit;
  text-decoration: none;
}
.banker-card:hover { border-color: var(--accent); transform: translateY(-2px); color: inherit; }
.banker-card__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.banker-card__teams {
  padding: 14px 16px 8px;
  display: flex; gap: 10px; align-items: center;
}
.banker-card__teams-title {
  flex: 1;
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 800;
  line-height: 1.15;
}
.banker-card__teams-title .vs { color: var(--ink-dim); font-weight: 400; }
.banker-card__picks {
  padding: 8px 16px 14px;
  display: flex; flex-direction: column; gap: 16px;
}
.banker-card__pick-row {
  display: flex; justify-content: space-between;
  align-items: baseline; gap: 8px;
}
.banker-card__pick-name {
  font-size: 14px; font-weight: 700; color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  flex: 1 1 auto;
}
.banker-card__pick-right {
  display: flex; align-items: center; gap: 8px; flex-shrink: 0;
}
.banker-card__pick-prob {
  font-family: var(--font-mono);
  font-size: 14px; font-weight: 700; color: var(--ink);
}
.banker-card__pick-cat {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  color: var(--ink-muted);
  text-transform: uppercase;
  margin-top: 4px;
}
.banker-card__pick-bar { margin-top: 6px; }
.banker-card__pick-bar .probbar { height: 4px; display: block; }
.banker-card__foot {
  margin-top: auto;
  padding: 12px 16px;
  border-top: 1px solid var(--line);
  background: rgba(198, 255, 61, 0.04);
  display: flex; align-items: center; justify-content: space-between;
}
.banker-card__foot-row {
  display: flex; align-items: center; gap: 6px;
}
.banker-card__foot-arrow {
  color: var(--accent);
  font-weight: 700;
}
.banker-card__foot-label {
  font-size: 10px;
  letter-spacing: 0.15em;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-weight: 600;
  text-transform: uppercase;
}
.banker-card__foot-value {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.01em;
}

/* ============================================================
   Market Breakdown card — ported from demo/cards.jsx MarketCard
   ============================================================ */
.market-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color 150ms;
}
.market-card:hover { border-color: var(--line-strong); }

/* The clickable region: head + title + visible groups. Sibling to the
   "more markets" button so the button can stop propagation cleanly. */
.market-card__link {
  display: block;
  color: var(--ink);
  text-decoration: none;
  cursor: pointer;
}
.market-card__link:hover { color: var(--ink); }

/* Hidden category list revealed by the footer button. */
.market-card__groups--hidden {
  display: none;
  padding-top: 0;
}
.market-card__groups--open { display: block; }
.market-card__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.market-card__count {
  padding: 2px 8px;
  border: 1px solid var(--line);
  border-radius: 2px;
  font-size: 9px;
}
.market-card__title {
  padding: 14px 16px 10px;
  font-family: var(--font-display);
  font-size: 17px;
  color: var(--accent);
  line-height: 1.15;
}
.market-card__title .vs { color: var(--ink-muted); font-weight: 400; }
.market-card__groups { padding: 0 16px 12px; }
.market-card__group { margin-top: 14px; }
.market-card__group-label {
  font-size: 9px;
  letter-spacing: 0.15em;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.market-card__row {
  display: grid;
  grid-template-columns: 1fr auto auto 80px;
  gap: 10px;
  align-items: center;
  padding: 5px 0;
}
.market-card__row-name {
  font-size: 13px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.market-card__row-prob {
  font-size: 12px;
  font-family: var(--font-mono);
  font-weight: 600;
}
.market-card__row-bar { min-width: 0; }
.market-card__row-bar.probbar { height: 4px; display: block; }

/* Footer "↓ N MORE MARKETS" button. Spans the card width, separated
   from the market rows by a top border. Mirrors demo/cards.jsx:257. */
.market-card__more {
  width: 100%;
  padding: 12px 16px;
  background: transparent;
  color: var(--ink-muted);
  border: 0;
  border-top: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  font-weight: 600;
  margin-top: auto;
}
.market-card__more:hover { color: var(--ink); background: var(--bg-alt); }

/* ============================================================
   Mobile overrides
   ============================================================ */
@media (max-width: 959.98px) {
  .home-shell {
    padding: 0;
  }
  .picks-section { margin-top: 0; }
  .picks-head {
    padding: 16px 12px 8px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .picks-head__filters { max-width: 100%; overflow-x: auto; flex-wrap: nowrap; }
  .picks-section__grid { grid-template-columns: 1fr; gap: 0; }
  .picks-section .rail { position: static; padding: 0 12px 24px; }
  .page-head { padding: 16px 12px 0; margin: 0; }
  .page-head__title { font-size: 30px; }
  .filter-toolbar {
    margin: 12px 12px 16px;
    padding: 12px;
    gap: 10px;
  }
  .filter-toolbar__pills { max-width: 100%; overflow-x: auto; flex-wrap: nowrap; }
  /* `.picks-head__meta` under All Picks / Top Banker lives outside any
     padded container on mobile — pull it back to match the gutter. */
  #all-picks-meta { padding: 0 12px; }
  .filters {
    grid-template-columns: 1fr;
    padding: 0;
    gap: 0;
  }
  .filters .chip-row {
    overflow-x: auto;
    padding: 8px 12px;
    display: flex;
  }
  .filters .chip-row + .chip-row { border-left: none; padding-left: 12px; }
  #matches,
  .card-grid {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 4px 12px 24px;
  }
  .pick-card__teams { padding: 14px 14px 10px; gap: 10px; }
  .pick-card__names { font-size: 16px; }
  .pick-card__main { padding: 0 14px 12px; }
  .pick-card__main .gauge { display: none; }  /* mobile: drop the arc, keep the horizontal probbar */
  .pick-card__bankers { margin: 0 14px 8px; }
  .section-head { margin: 24px 12px 12px; }
  .vip-btn { display: none; }   /* mobile: menu covers it */
  .subnav__row { overflow-x: auto; padding: 0 12px; }
  .subnav__tab { white-space: nowrap; padding: 10px 12px; font-size: 12px; }

  /* Home view only shows 5 picks before the "View all" CTA on mobile.
     All Picks / Top Banker grids are not scoped under #matches, so they
     render their full list. */
  .view--home #matches > :nth-child(n+6) { display: none; }

  /* ─── Mobile hero leaderboard (matches demo mockup) ─────────── */
  .hero-lb {
    padding: 20px 12px 16px;
    margin-bottom: 12px;
  }
  .hero-lb__head {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    margin-bottom: 16px;
  }
  .hero-lb__title { font-size: 44px; letter-spacing: -0.03em; }
  .hero-lb__sub { display: none; }

  /* Perf card → 3 equal cells (HIT RATE / STREAK / 30D) */
  .hero-lb__perf {
    min-width: 0;
    padding: 0;
    background: transparent;
    border: 0;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 8px;
  }
  .hero-lb__perf-row { display: contents; }   /* expose hit-rate & streak divs to the grid */
  .hero-lb__perf-row > div {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 10px 12px;
    text-align: left !important;   /* override inline textAlign:right from JS */
    min-width: 0;
  }
  .hero-lb__perf-hitrate,
  .hero-lb__perf-streak-val { font-size: 22px; line-height: 1.1; }
  .hero-lb__perf-chart {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 10px 12px 8px;
    margin-top: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 4px;
    height: auto;
  }
  .hero-lb__perf-chart::before {
    content: "30D";
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-muted);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
    display: block;
  }
  .hero-lb__perf-chart svg { height: 34px; }
  .hero-lb__perf-foot { display: none; }

  /* Leaderboard board: hide column header; each row is a 2-line compact card */
  .hero-lb__board { border-radius: var(--radius); }
  .hero-lb__row {
    display: grid;
    grid-template-columns: 36px 1fr auto;
    grid-template-areas:
      "rank match prob"
      "rank market chip";
    gap: 4px 12px;
    padding: 14px 14px;
  }
  /* Extra class chained (0,2,0) to beat the .hero-lb__row (0,1,0) rule above —
     both classes live on the header, so an equal-specificity `display: none`
     gets overridden by the grid declaration that comes later in source. */
  .hero-lb__row.hero-lb__row--head { display: none; }
  .hero-lb__rank { grid-area: rank; align-self: center; font-size: 20px; }
  .hero-lb__match { grid-area: match; gap: 8px; }
  .hero-lb__crests { display: none; }   /* tight mobile row — drop crests */
  .hero-lb__meta { display: none; }     /* league/venue sub-line not needed on mobile */
  .hero-lb__teams { font-size: 14px; font-weight: 700; }
  .hero-lb__market {
    grid-area: market;
    font-size: 12px;
    color: var(--ink-muted);
    text-align: left;
    gap: 1px;
  }
  /* Mobile: the leaderboard row is already space-constrained (2-row grid).
     Hide the secondary 1X2 sub-line — the primary market + % is enough. */
  .hero-lb__market-secondary { display: none; }
  .hero-lb__prob { grid-area: prob; align-self: center; }
  .hero-lb__prob-val { font-size: 14px; }
  .hero-lb__prob-bar { display: none; }
  .hero-lb__conf { grid-area: chip; justify-content: flex-end; align-self: start; }
  .hero-lb__trend, .hero-lb__ko { display: none; }
}
/* ============================================================
   Match detail page — ports demo/detail.jsx MatchDetail.
   Layout: breadcrumb · hero · (2-col) main + rail
   ============================================================ */

.match-shell {
  max-width: var(--desktop-max);
  margin: 0 auto;
  padding: 24px var(--gutter) 96px;
}

/* 2-col grid for everything below the hero */
.mdetail-grid {
  display: grid;
  grid-template-columns: 1fr var(--rail-w);
  gap: var(--gutter);
  align-items: start;
  margin-top: 20px;
}
.match-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.match-main > section:empty { display: none; }
.mdetail-grid .rail {
  position: sticky;
  top: calc(var(--header-h-d) + 16px);
}

/* ============================================================
   Breadcrumb — SPORT / LEAGUE / Home vs Away
   ============================================================ */
.mbreadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.mbreadcrumb__sport {
  color: var(--ink-muted);
  text-decoration: none;
}
.mbreadcrumb__sport:hover { color: var(--ink); }
.mbreadcrumb__sep { color: var(--ink-dim); }
.mbreadcrumb__current { color: var(--ink); }

/* ============================================================
   Hero card — match identity + win-prob distribution
   ============================================================ */
.mdetail-hero-slot { display: block; }
.mhero {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 32px;
}
.mhero__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 28px;
}
.mhero__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.15em;
  flex-wrap: wrap;
}
.mhero__league-chip {
  padding: 3px 8px;
  background: var(--accent);
  color: var(--accent-ink);
  font-weight: 800;
}
.mhero__meta-sep { color: var(--ink-dim); }
.mhero__id {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.15em;
  white-space: nowrap;
}

.mhero__teams {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 32px;
}
.mhero__side { min-width: 0; }
.mhero__side-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.15em;
  text-transform: uppercase;
}
.mhero__side-name {
  font-family: var(--font-display);
  font-size: 44px;
  font-weight: 900;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1;
  margin-top: 6px;
  /* Long names can wrap rather than overflow the hero */
  word-break: break-word;
}
.mhero__side-form {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-muted);
  margin-top: 10px;
  letter-spacing: 0.04em;
}

.mhero__badges {
  display: flex;
  align-items: center;
  gap: 20px;
}
.mhero__crest--lg {
  width: 72px; height: 72px;
  font-size: 22px;
}
.mhero__vs {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 900;
  color: var(--ink-dim);
  letter-spacing: -0.02em;
}

/* Win-probability distribution bar */
.mhero__probbar { margin-top: 28px; }
.mhero__probbar-track {
  display: grid;
  height: 10px;
  border-radius: 2px;
  overflow: hidden;
  gap: 0;
}
.mhero__probbar-seg--home { background: var(--good); }
.mhero__probbar-seg--draw { background: var(--ink-dim); }
.mhero__probbar-seg--away { background: var(--danger); }
.mhero__probbar-legend {
  display: grid;
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-muted);
}
.mhero__probbar-leg strong {
  font-weight: 700;
  margin-right: 4px;
}
.mhero__probbar-leg--home { color: var(--ink-muted); }
.mhero__probbar-leg--home strong { color: var(--good); }
.mhero__probbar-leg--draw { color: var(--ink-dim); text-align: center; }
.mhero__probbar-leg--draw strong { color: var(--ink-muted); }
.mhero__probbar-leg--away { color: var(--ink-muted); text-align: right; }
.mhero__probbar-leg--away strong { color: var(--danger); }

/* ============================================================
   Model's top call — accent-bordered callout, big gauge right.
   ============================================================ */
.mtopcall {
  background: var(--bg-card);
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  padding: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: center;
}
.mtopcall__body { min-width: 0; }
.mtopcall__label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.18em;
  font-weight: 800;
  text-transform: uppercase;
}
.mtopcall__market {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 900;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-top: 6px;
}
.mtopcall__sub {
  font-size: 13px;
  color: var(--ink-muted);
  margin: 8px 0 0;
  line-height: 1.5;
  max-width: 480px;
}

/* ============================================================
   Match analytics — 2-col key/value panel.
   ============================================================ */
.manalytics {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
}
.manalytics__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin: 0 0 14px;
}
.manalytics__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.manalytics__col > * + * { margin-top: 14px; }

.manalytics__pair-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.15em;
  font-weight: 700;
  margin-bottom: 4px;
}
.manalytics__pair-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--ink);
  font-weight: 700;
}
.manalytics__pair-val { flex: 0 0 auto; }
.manalytics__pair-val--good   { color: var(--good); }
.manalytics__pair-val--danger { color: var(--danger); }
.manalytics__pair-vs {
  color: var(--ink-dim);
  font-weight: 400;
  font-size: 11px;
}

.manalytics__kv {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  gap: 12px;
}
.manalytics__kv:last-child { border-bottom: 0; padding-bottom: 0; }
.manalytics__kv-k {
  font-size: 13px;
  color: var(--ink-muted);
}
.manalytics__kv-v {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
  text-align: right;
}
.manalytics__kv--accent .manalytics__kv-v { color: var(--accent); }

/* Optional basketball-only sections below the top 2-col grid. */
.manalytics__section { margin-top: 18px; }
.manalytics__section-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.15em;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 8px;
}

/* Quarter-by-quarter — 4 cards in a row */
.manalytics__qgrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.manalytics__qcard {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 12px;
}
.manalytics__qcard-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.1em;
  font-weight: 700;
}
.manalytics__qcard-score {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 800;
  color: var(--ink);
  margin-top: 2px;
}
.manalytics__qcard-ml {
  font-size: 10px;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  margin-top: 2px;
}

/* Score milestones — 5-col table: team + four percentage columns */
.manalytics__milestones {
  display: grid;
  grid-template-columns: 1fr repeat(4, 0.7fr);
  row-gap: 4px;
  column-gap: 6px;
  font-size: 11px;
}
.manalytics__milestones-head {
  color: var(--ink-muted);
  font-family: var(--font-mono);
  padding: 6px 0;
  letter-spacing: 0.06em;
}
.manalytics__milestones-num {
  font-family: var(--font-mono);
  text-align: right;
  color: var(--ink);
}
.manalytics__milestones-team {
  color: var(--ink);
  font-weight: 700;
}

/* Key player projections — 2-col card grid */
.manalytics__players {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 8px;
}
.manalytics__player {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px;
}
.manalytics__player-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.manalytics__player-name {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.manalytics__player-team {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.1em;
}
.manalytics__player-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-top: 10px;
}
.manalytics__player-stat-k {
  font-size: 9px;
  color: var(--ink-muted);
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
}
.manalytics__player-stat-v {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  margin-top: 1px;
}
.manalytics__player-chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.manalytics__player-chip {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 2px;
  letter-spacing: 0.04em;
}
.manalytics__player-chip--good   { background: rgba(198, 255, 61, 0.1); color: var(--good); }
.manalytics__player-chip--muted  { background: var(--bg-alt);            color: var(--ink);  }

/* ============================================================
   All markets — grouped rows with tier chip + probability bar.
   ============================================================ */
.mmarkets {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
}
.mmarkets__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 20px;
}
.mmarkets__title {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 0;
}
.mmarkets__count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-muted);
  letter-spacing: 0.1em;
}
.mmarkets__group + .mmarkets__group { margin-top: 24px; }
.mmarkets__cat {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--accent);
  font-weight: 700;
  text-transform: uppercase;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 10px;
}
.mmarkets__row {
  display: grid;
  grid-template-columns: 1fr 80px 90px 1fr;
  gap: 16px;
  padding: 8px 0;
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.mmarkets__row:last-child { border-bottom: 0; }
.mmarkets__row-name { font-size: 14px; color: var(--ink); }
.mmarkets__row-pct {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--ink);
  font-weight: 700;
  text-align: right;
}
.mmarkets__row-bar { min-width: 0; }
.mmarkets__row-bar .probbar { height: 5px; display: block; }

/* ============================================================
   Matchday brief — AI summary card.
   ============================================================ */
.mbrief {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
}
.mbrief__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin: 0 0 12px;
}
.mbrief__body {
  font-size: 14px;
  color: var(--ink-muted);
  line-height: 1.6;
  margin: 0;
}

/* ============================================================
   Floating bottom CTA (primary affiliate click)
   ============================================================ */
.floating-cta {
  /* Hidden for now. Code still builds the element and tracks the affiliate
     click wiring — flip this back to the positioned layout when we're ready
     to show the bookmaker CTA again. */
  display: none;

  position: fixed;
  left: 0; right: 0;
  bottom: var(--bottom-nav-h);
  z-index: 25;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(10,11,13,0) 0%, rgba(10,11,13,0.95) 40%);
  pointer-events: none;
}
.floating-cta__inner {
  max-width: var(--max-content);
  margin: 0 auto;
  pointer-events: auto;
}
.floating-cta__btn {
  width: 100%;
  padding: 14px 16px;
  background: var(--accent);
  color: var(--accent-ink);
  font-weight: 800;
  font-size: 14px;
  border-radius: var(--radius);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.4);
}
.floating-cta__sub {
  font-family: var(--font-mono);
  font-size: 11px;
  opacity: 0.7;
  display: block;
  margin-top: 2px;
  font-weight: 500;
}

/* ============================================================
   Mobile
   ============================================================ */
@media (max-width: 959.98px) {
  .match-shell {
    padding: 16px 12px calc(var(--bottom-nav-h) + 96px);
  }
  .mbreadcrumb { margin-bottom: 14px; }
  .mhero { padding: 18px; }
  .mhero__top { margin-bottom: 18px; flex-wrap: wrap; }
  .mhero__teams {
    grid-template-columns: 1fr;
    gap: 14px;
    text-align: center;
  }
  .mhero__side,
  .mhero__side[style] { text-align: center !important; }
  .mhero__side-name { font-size: 30px; }
  .mhero__badges { justify-content: center; gap: 14px; }
  .mhero__crest--lg { width: 56px; height: 56px; font-size: 16px; }
  .mhero__vs { font-size: 22px; }

  .mdetail-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 16px;
  }
  .mdetail-grid .rail { position: static; }

  .mtopcall {
    grid-template-columns: 1fr;
    padding: 18px;
    gap: 14px;
    justify-items: center;
    text-align: center;
  }
  .mtopcall__market { font-size: 28px; }

  .manalytics,
  .mmarkets,
  .mbrief { padding: 18px; }
  .manalytics__grid { grid-template-columns: 1fr; gap: 20px; }
  .manalytics__qgrid { grid-template-columns: repeat(2, 1fr); }
  .manalytics__players { grid-template-columns: 1fr; }
  .manalytics__milestones {
    grid-template-columns: 1.2fr repeat(4, 1fr);
    font-size: 10px;
    overflow-x: auto;
  }

  .mmarkets__row {
    grid-template-columns: 1fr 60px 70px;
    gap: 10px;
  }
  .mmarkets__row-bar { display: none; }
}
