/* ═══════════════════════════════════════════════════════════════════
   AI WORLD CUP 2026 — predict5 theme  "Broadsheet"
   Light editorial / sports-broadcast. Header nav, no sidebar.
   Warm paper + ink + vermilion accent. Independent of predict6 theme.
   ═══════════════════════════════════════════════════════════════════ */

:root{
  --paper:#f4f1ea;        /* warm page bg */
  --paper-2:#efeae1;
  --card:#ffffff;
  --card-2:#faf8f3;
  --ink:#17140f;          /* near-black warm */
  --ink-2:#564f43;        /* muted */
  --ink-3:#8f877a;        /* faint */
  --line:#e4ddcf;         /* warm hairline */
  --line-2:#eee9df;

  --accent:#e8431f;       /* vermilion */
  --accent-d:#c9360f;
  --accent-soft:#fbe3da;

  --pos:#1f8f4e;          /* win / value */
  --pos-soft:#dcf0e2;
  --neg:#d23b3b;          /* loss */
  --neg-soft:#f7dede;
  --draw:#b88410;         /* draw */
  --draw-soft:#f6ecd4;
  --teal:#0ea5a3;

  --r:12px; --rl:18px; --rxl:26px;
  --shadow:0 1px 2px rgba(23,20,15,.05), 0 10px 30px rgba(23,20,15,.06);
  --shadow-lg:0 8px 24px rgba(23,20,15,.10), 0 30px 70px rgba(23,20,15,.10);

  --fn: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --fn-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;

  --wrap:1080px; --mast-h:64px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ overflow-x:clip; -webkit-text-size-adjust:100%; }
html.lock,body.lock{ overflow:hidden; }
body{
  background:var(--paper); color:var(--ink); font-family:var(--fn);
  font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow-x:hidden; overflow-wrap:break-word;
}
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:0; background:0; color:inherit; }
img{ max-width:100%; height:auto; display:block; }
h1,h2,h3{ line-height:1.12; letter-spacing:-.02em; font-weight:800; }
:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; border-radius:4px; }

.skip{ position:absolute; left:-9999px; top:0; z-index:200; background:var(--ink); color:#fff; padding:10px 16px; border-radius:0 0 8px 0; font-size:13px; font-weight:700; }
.skip:focus{ left:0; }

.wrap{ max-width:var(--wrap); margin:0 auto; padding:26px 20px 60px; }
.flag{ font-size:1.05em; line-height:1; }
.dot-sep{ color:var(--ink-3); }

/* ── Buttons ── */
.btn{ display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:15px;
  padding:13px 22px; border-radius:999px; transition:transform .12s, box-shadow .15s, background .15s; }
.btn svg{ width:18px; height:18px; }
.btn-solid{ background:var(--accent); color:#fff; box-shadow:0 6px 18px rgba(232,67,31,.28); }
.btn-solid:hover{ background:var(--accent-d); transform:translateY(-1px); }
.btn-line{ background:transparent; color:var(--ink); border:1.5px solid var(--ink); }
.btn-line:hover{ background:var(--ink); color:#fff; }

/* ── Ticker ── */
.ticker{ display:flex; align-items:center; justify-content:center; gap:14px;
  background:var(--ink); color:#fff; padding:9px 46px 9px 18px; position:relative;
  font-size:13px; text-align:center; }
.ticker.is-hidden{ display:none; }
.ticker-msg{ display:inline-flex; align-items:center; gap:8px; cursor:pointer; flex-wrap:wrap; justify-content:center; }
.ticker-msg strong{ color:#ffd2c6; }
.ticker-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 0 rgba(232,67,31,.7); animation:pulse 1.8s infinite; }
.ticker-x{ position:absolute; right:12px; top:50%; transform:translateY(-50%); color:#fff; opacity:.7; font-size:13px; width:24px; height:24px; border-radius:50%; }
.ticker-x:hover{ opacity:1; background:rgba(255,255,255,.12); }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(232,67,31,.6);} 70%{ box-shadow:0 0 0 7px rgba(232,67,31,0);} 100%{ box-shadow:0 0 0 0 rgba(232,67,31,0);} }

/* ── Masthead nav ── */
.mast{ position:sticky; top:0; z-index:100; background:rgba(244,241,234,.86);
  backdrop-filter:saturate(160%) blur(12px); -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line); transition:box-shadow .2s, background .2s; }
.mast.is-stuck{ box-shadow:0 6px 24px rgba(23,20,15,.07); background:rgba(244,241,234,.94); }
.mast-in{ max-width:var(--wrap); margin:0 auto; height:var(--mast-h); padding:0 20px;
  display:flex; align-items:center; gap:20px; }
.brand{ display:inline-flex; align-items:center; gap:11px; font-weight:800; }
.brand-logo{ height:46px; width:auto; display:block; }
.drawer-logo{ height:40px; width:auto; display:block; }
.foot-logo{ height:56px; width:auto; display:block; }
@media (max-width:680px){ .brand-logo{ height:40px; } }
.brand-mark{ width:38px; height:38px; display:grid; place-items:center; border-radius:11px;
  background:var(--ink); color:var(--accent); flex:none; }
.brand-mark svg{ width:21px; height:21px; }
.brand-word{ display:flex; flex-direction:column; line-height:1.05; }
.brand-l1{ font-size:16px; letter-spacing:-.02em; }
.brand-l2{ font-size:10.5px; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:var(--accent); }
.mast-nav{ display:flex; align-items:center; gap:4px; margin-left:8px; }
.mast-link{ display:inline-flex; align-items:center; gap:5px; font-size:14.5px; font-weight:600;
  color:var(--ink-2); padding:9px 13px; border-radius:9px; transition:color .12s, background .12s; white-space:nowrap; }
.mast-link svg{ width:16px; height:16px; }
.mast-link:hover{ color:var(--ink); background:var(--paper-2); }
.mast-link.is-active{ color:var(--ink); }
.mast-link.is-active::after{ content:""; }
.mast-nav>.mast-link.is-active{ position:relative; }
.mast-nav>.mast-link.is-active::before{ content:""; position:absolute; left:13px; right:13px; bottom:2px; height:2.5px; border-radius:2px; background:var(--accent); }

/* mega menu */
.has-mega{ position:relative; }
.mast-mega-btn{ font-family:inherit; }
.mega{ position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(8px);
  width:520px; max-width:92vw; background:var(--card); border:1px solid var(--line); border-radius:var(--rl);
  box-shadow:var(--shadow-lg); padding:14px; opacity:0; visibility:hidden; transition:.16s; z-index:120; }
.has-mega:hover .mega, .has-mega:focus-within .mega{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.mega-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:6px; }
.mega-item{ display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:10px; transition:background .12s; }
.mega-item:hover{ background:var(--paper-2); }
.mega-letter{ width:30px; height:30px; flex:none; display:grid; place-items:center; border-radius:8px;
  background:var(--ink); color:#fff; font-weight:800; font-size:13px; }
.mega-name{ display:block; font-size:13.5px; font-weight:700; }
.mega-flags{ display:block; font-size:12px; letter-spacing:1px; }
.mega-all{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:10px; padding:11px;
  border-radius:11px; background:var(--accent-soft); color:var(--accent-d); font-weight:700; font-size:13.5px; }
.mega-all svg{ width:16px; height:16px; }
.mega-all:hover{ background:var(--accent); color:#fff; }

.mast-end{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.mast-cta{ display:inline-flex; align-items:center; gap:7px; background:var(--accent); color:#fff;
  font-weight:700; font-size:14px; padding:10px 17px; border-radius:999px; box-shadow:0 5px 14px rgba(232,67,31,.28); }
.mast-cta svg{ width:16px; height:16px; }
.mast-cta:hover{ background:var(--accent-d); }
.burger{ display:none; width:42px; height:42px; border-radius:11px; border:1px solid var(--line);
  background:var(--card); flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.burger span{ display:block; width:18px; height:2px; border-radius:2px; background:var(--ink); }

/* scrim + drawer */
.scrim{ position:fixed; inset:0; background:rgba(23,20,15,.45); opacity:0; visibility:hidden; transition:.2s; z-index:140; }
.scrim.is-open{ opacity:1; visibility:visible; }
.drawer{ position:fixed; top:0; right:0; height:100dvh; width:340px; max-width:88vw; z-index:150;
  background:var(--card); border-left:1px solid var(--line); transform:translateX(102%); transition:transform .26s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column; padding:16px; overflow-y:auto; }
.drawer.is-open{ transform:translateX(0); }
.drawer-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.drawer-brand{ font-weight:800; font-size:15px; }
.drawer-x{ width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background:var(--paper-2); }
.drawer-x svg{ width:20px; height:20px; }
.drawer-cta{ display:block; text-align:center; background:var(--accent); color:#fff; font-weight:700;
  padding:13px; border-radius:12px; margin-bottom:14px; }
.drawer-nav{ display:flex; flex-direction:column; gap:2px; }
.drawer-link{ display:flex; align-items:center; justify-content:space-between; gap:8px; width:100%; text-align:left;
  font-size:15.5px; font-weight:600; color:var(--ink); padding:13px 12px; border-radius:11px; }
.drawer-link svg{ width:18px; height:18px; transition:transform .2s; }
.drawer-link:hover{ background:var(--paper-2); }
.drawer-link.is-active{ color:var(--accent); }
.drawer-groups-body{ display:none; flex-direction:column; gap:1px; padding:2px 0 6px; }
.drawer-groups.is-open .drawer-groups-body{ display:flex; }
.drawer-groups.is-open .drawer-groups-toggle svg{ transform:rotate(180deg); }
.drawer-group{ display:flex; align-items:center; gap:9px; padding:10px 12px 10px 14px; border-radius:10px; font-size:14px; font-weight:600; color:var(--ink-2); }
.drawer-group:hover{ background:var(--paper-2); }
.drawer-group-l{ width:24px; height:24px; flex:none; display:grid; place-items:center; border-radius:7px; background:var(--ink); color:#fff; font-size:11px; font-weight:800; }
.drawer-group-f{ margin-left:auto; font-size:12px; letter-spacing:1px; }
.drawer-sep{ font-size:11px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); padding:16px 12px 4px; }
.drawer-foot{ margin-top:auto; padding-top:16px; display:flex; align-items:center; gap:8px; color:var(--ink-3); font-size:12.5px; font-weight:600; }
.drawer-foot-dot{ width:8px; height:8px; border-radius:50%; background:var(--pos); }

/* ── Period segmented sub-nav ── */
.seg{ border-bottom:1px solid var(--line); background:var(--paper); }
.seg-in{ max-width:var(--wrap); margin:0 auto; padding:10px 20px; display:flex; gap:8px; overflow-x:auto; -ms-overflow-style:none; scrollbar-width:none; }
.seg-in::-webkit-scrollbar{ display:none; }
.seg-link{ font-size:13.5px; font-weight:700; color:var(--ink-2); padding:8px 16px; border-radius:999px;
  border:1px solid var(--line); background:var(--card); white-space:nowrap; transition:.12s; }
.seg-link:hover{ border-color:var(--ink-3); }
.seg-link.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.seg-link--all{ margin-left:auto; color:var(--accent-d); border-color:var(--accent-soft); background:var(--accent-soft); }
.seg-link--all:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }

/* ════════ HOME — hero ════════ */
.lede{ margin-bottom:30px; }
.lede-grid{ display:grid; grid-template-columns:1.35fr .9fr; gap:30px; align-items:center;
  background:linear-gradient(180deg,var(--card),var(--card-2)); border:1px solid var(--line);
  border-radius:var(--rxl); padding:38px 38px 34px; box-shadow:var(--shadow); position:relative; overflow:hidden; }
.lede-grid::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px;
  background:linear-gradient(90deg,var(--accent),#ff8a5c,var(--accent)); }
.lede-kicker{ display:inline-block; font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent-d); background:var(--accent-soft); padding:6px 12px; border-radius:999px; margin-bottom:16px; }
.lede-h1{ font-size:clamp(28px,4.6vw,46px); margin-bottom:14px; }
.lede-sub{ font-size:16px; color:var(--ink-2); max-width:54ch; margin-bottom:20px; }
.lede-sub strong{ color:var(--ink); }
.lede-facts{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:24px; }
.fact{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:var(--ink-2);
  background:var(--card); border:1px solid var(--line); padding:8px 13px; border-radius:999px; }
.fact svg{ width:15px; height:15px; }
.fact--live{ color:var(--accent-d); background:var(--accent-soft); border-color:transparent; }
.fact-pulse{ width:8px; height:8px; border-radius:50%; background:var(--accent); animation:pulse 1.8s infinite; }
.fact--flags{ gap:3px; font-size:16px; letter-spacing:1px; }
.lede-cta{ display:flex; flex-wrap:wrap; gap:12px; }
.lede-art{ position:relative; display:grid; place-items:center; min-height:220px; }
.lede-glow{ position:absolute; width:260px; height:260px; border-radius:50%;
  background:radial-gradient(circle,rgba(232,67,31,.22),transparent 65%); filter:blur(8px); }
.lede-trophy{ position:relative; width:min(280px,72%); height:auto; filter:drop-shadow(0 24px 40px rgba(23,20,15,.22)); }

/* stats strip */
.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:14px; }
.stat{ background:var(--card); border:1px solid var(--line); border-radius:var(--rl); padding:18px 16px; text-align:center; box-shadow:var(--shadow); }
.stat-n{ font-size:34px; font-weight:800; letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.stat-l{ font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-top:2px; }

/* featured opener */
.opener{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:14px;
  background:var(--ink); color:#fff; border-radius:var(--rl); padding:20px 24px; position:relative; overflow:hidden; }
.opener::before{ content:""; position:absolute; right:-40px; top:-40px; width:180px; height:180px; border-radius:50%; background:radial-gradient(circle,rgba(232,67,31,.4),transparent 70%); }
.opener-ey{ font-size:11px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.opener-when{ font-size:13px; color:#d8d2c6; margin-top:3px; }
.opener-when strong{ color:#fff; }
.opener-match{ display:flex; align-items:center; gap:10px; font-size:18px; font-weight:800; margin-left:auto; }
.opener-flag{ font-size:22px; }
.opener-vs{ color:var(--accent); font-size:13px; font-weight:800; }
.opener-go{ font-size:13px; font-weight:700; color:#fff; background:rgba(255,255,255,.12); padding:9px 15px; border-radius:999px; }
.opener:hover .opener-go{ background:var(--accent); }

/* simple page head */
.phead{ padding:14px 0 6px; }
.phead-h1{ font-size:clamp(24px,3.6vw,36px); }

/* ════════ Fixtures list ════════ */
.fixtures{ background:var(--card); border:1px solid var(--line); border-radius:var(--rl); box-shadow:var(--shadow); margin-top:22px; overflow:hidden; }
.fx-head{ display:flex; align-items:center; gap:13px; padding:18px 20px; border-bottom:1px solid var(--line-2); }
.fx-badge{ width:42px; height:42px; flex:none; display:grid; place-items:center; border-radius:12px;
  background:var(--ink); color:#fff; font-weight:800; font-size:14px; letter-spacing:.02em; }
.fx-id{ min-width:0; }
.fx-name{ font-size:17px; font-weight:800; letter-spacing:-.01em; }
.fx-loc{ display:flex; align-items:center; gap:6px; font-size:12.5px; color:var(--ink-2); margin-top:2px; }
.fx-count{ margin-left:auto; text-align:center; background:var(--accent-soft); color:var(--accent-d); font-weight:800;
  font-size:18px; line-height:1; padding:8px 12px; border-radius:12px; font-variant-numeric:tabular-nums; }
.fx-count span{ display:block; font-size:9.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; opacity:.8; margin-top:2px; }
.fx-list{ display:flex; flex-direction:column; }
.fx{ display:grid; grid-template-columns:54px auto 1fr auto 26px; align-items:center; gap:14px;
  padding:14px 20px; border-bottom:1px solid var(--line-2); transition:background .12s; }
.fx:last-child{ border-bottom:0; }
.fx:hover{ background:var(--card-2); }
.fx-when{ display:flex; flex-direction:column; align-items:center; line-height:1.15; }
.fx-when .d{ font-size:12px; font-weight:800; font-variant-numeric:tabular-nums; }
.fx-when .t{ font-size:11px; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.fx-crests{ display:flex; }
.fx-crest{ width:34px; height:34px; border-radius:50%; background:var(--paper-2); border:2px solid var(--card);
  display:grid; place-items:center; font-size:11px; font-weight:800; color:var(--ink-2); overflow:hidden; }
.fx-crest:nth-child(2){ margin-left:-10px; }
.fx-crest img{ width:26px; height:26px; object-fit:contain; }
.fx-teams{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.fx-team{ font-size:14.5px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fx-tip{ font-size:12px; font-weight:800; color:var(--pos); background:var(--pos-soft); padding:6px 11px;
  border-radius:999px; white-space:nowrap; max-width:200px; overflow:hidden; text-overflow:ellipsis; }
.fx-tip--muted{ color:var(--ink-2); background:var(--paper-2); }
.fx-go{ color:var(--ink-3); display:grid; place-items:center; }
.fx-go svg{ width:18px; height:18px; }
.fx:hover .fx-go{ color:var(--accent); }
.fx-foot{ display:flex; align-items:center; gap:12px; padding:14px 20px; background:var(--card-2); }
.fx-more{ display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:700; color:var(--accent-d); }
.fx-more svg{ width:16px; height:16px; }
.fx-foot-note{ margin-left:auto; font-size:12px; color:var(--ink-3); font-weight:700; }

/* ════════ Groups grid ════════ */
.groups{ margin-top:34px; }
.groups-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:16px; }
.groups-ey{ font-size:11.5px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-d); }
.groups-h2{ font-size:clamp(22px,3vw,30px); margin-top:4px; }
.groups-all{ display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:700; color:var(--ink);
  border:1.5px solid var(--ink); padding:9px 15px; border-radius:999px; white-space:nowrap; }
.groups-all svg{ width:16px; height:16px; }
.groups-all:hover{ background:var(--ink); color:#fff; }
.groups-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(248px,1fr)); gap:14px; }
.grp{ background:var(--card); border:1px solid var(--line); border-radius:var(--rl); padding:16px; box-shadow:var(--shadow); transition:transform .14s, box-shadow .14s; }
.grp:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.grp-head{ display:flex; align-items:center; gap:10px; padding-bottom:12px; border-bottom:1px solid var(--line-2); margin-bottom:10px; }
.grp-letter{ width:34px; height:34px; display:grid; place-items:center; border-radius:10px; background:var(--accent); color:#fff; font-weight:800; }
.grp-lbl{ font-size:15px; font-weight:800; }
.grp-teams{ list-style:none; display:flex; flex-direction:column; gap:7px; }
.grp-teams li{ display:flex; align-items:center; gap:9px; font-size:13.5px; }
.grp-flag{ font-size:16px; }
.grp-name{ font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.grp-pts{ margin-left:auto; font-weight:800; font-variant-numeric:tabular-nums; color:var(--ink-2);
  background:var(--paper-2); min-width:26px; text-align:center; padding:2px 7px; border-radius:7px; font-size:12.5px; }
.grp-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:12px; padding-top:11px;
  border-top:1px solid var(--line-2); font-size:12.5px; font-weight:700; color:var(--ink-3); }
.grp-foot svg{ width:16px; height:16px; }
.grp:hover .grp-foot{ color:var(--accent); }

/* ════════ Panels (generic cards) ════════ */
.panel{ background:var(--card); border:1px solid var(--line); border-radius:var(--rl); box-shadow:var(--shadow); margin-top:22px; overflow:hidden; }
.panel-hd{ display:flex; align-items:center; gap:12px; width:100%; text-align:left; padding:16px 20px; border-bottom:1px solid var(--line-2); }
.panel-hd h2{ font-size:17px; font-weight:800; }
.panel-pill{ margin-left:auto; font-size:11.5px; font-weight:700; color:var(--ink-2); background:var(--paper-2); padding:5px 11px; border-radius:999px; white-space:nowrap; }
.panel-bd{ padding:20px; }
.panel-bd.empty{ text-align:center; color:var(--ink-3); padding:42px 20px; }

/* prose */
.prose{ background:var(--card); border:1px solid var(--line); border-radius:var(--rl); box-shadow:var(--shadow); padding:26px 28px; margin-top:22px; }
.prose h2{ font-size:22px; margin:22px 0 10px; }
.prose h3{ font-size:18px; margin:18px 0 8px; }
.prose h2:first-child, .prose h3:first-child { margin-top: 15px; }
.prose p{ color:var(--ink-2); margin-bottom:14px; }
.prose a{ color:var(--accent-d); font-weight:600; text-decoration:underline; text-underline-offset:2px; }
.prose ul,.prose ol{ margin:0 0 14px 22px; color:var(--ink-2); }
.prose li{ margin-bottom:6px; }
.prose strong{ color:var(--ink); }
.prose img{ height:auto; border-radius:12px; margin:10px 0; }
.prose figure{ margin:14px 0; }
.prose figure img{ width:100%; object-fit:cover; }
.prose figcaption{ font-size:12.5px; color:var(--ink-3); text-align:center; margin-top:6px; }

/* ════════ Home hero (redesigned, no H1) ════════ */
.hero{ position:relative; overflow:hidden; margin-bottom:24px; border-radius:var(--rxl); color:#fff;
  background:linear-gradient(135deg,#17140f 0%,#241c13 55%,#3a2415 100%);
  display:grid; grid-template-columns:1.45fr .85fr; gap:24px; align-items:center; padding:46px 44px; }
.hero::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:linear-gradient(90deg,var(--accent),#ff9a5c,var(--accent)); }
.hero-glow{ position:absolute; right:-70px; top:-90px; width:440px; height:440px; border-radius:50%;
  background:radial-gradient(circle,rgba(232,67,31,.38),transparent 65%); pointer-events:none; }
.hero-body{ position:relative; z-index:1; }
.hero-kick{ display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:800; letter-spacing:.1em; text-transform:uppercase;
  color:#ffd2c6; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); padding:7px 14px; border-radius:999px; }
.hero-kick-dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); animation:pulse 1.8s infinite; }
.hero-title{ font-size:clamp(30px,5vw,52px); font-weight:800; letter-spacing:-.03em; line-height:1.05; margin:16px 0 12px; }
.hero-lead{ font-size:16px; color:#d8d2c6; max-width:52ch; margin-bottom:24px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; }
.btn-ghost{ background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.28); }
.btn-ghost:hover{ background:#fff; color:var(--ink); }
.hero-stats{ list-style:none; display:flex; flex-wrap:wrap; gap:28px; margin-top:28px; padding-top:22px; border-top:1px solid rgba(255,255,255,.14); }
.hero-stats li{ font-size:11.5px; letter-spacing:.07em; text-transform:uppercase; color:#bdb6a8; }
.hero-stats b{ display:block; font-size:30px; font-weight:800; letter-spacing:-.02em; color:#fff; font-variant-numeric:tabular-nums; }
.hero-art{ position:relative; z-index:1; display:grid; place-items:center; }
.hero-trophy{ width:min(260px,82%); filter:drop-shadow(0 26px 50px rgba(0,0,0,.55)); }
.hero-hosts{ font-size:26px; letter-spacing:7px; margin-top:8px; }
@media (max-width:860px){
  .hero{ grid-template-columns:1fr; text-align:center; padding:32px 22px; }
  .hero-art{ order:-1; } .hero-trophy{ width:160px; }
  .hero-cta,.hero-stats{ justify-content:center; } .hero-lead{ margin-left:auto; margin-right:auto; }
}

/* faq */
.faq{ margin-top:22px; }
.faq-head h2{ font-size:clamp(20px,2.6vw,26px); margin-bottom:14px; }
.faq-item{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); margin-bottom:10px; overflow:hidden; box-shadow:var(--shadow); }
.faq-q{ display:flex; align-items:center; justify-content:space-between; gap:14px; width:100%; text-align:left;
  font-size:15.5px; font-weight:700; padding:16px 18px; }
.faq-chev{ color:var(--ink-3); transition:transform .2s; flex:none; }
.faq-item.is-open .faq-chev{ transform:rotate(180deg); color:var(--accent); }
.faq-a{ display:none; padding:0 18px 18px; color:var(--ink-2); }
.faq-item.is-open .faq-a{ display:block; }

/* breadcrumb */
.crumbs{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:13px; color:var(--ink-3); padding:2px 0 6px; }
.crumbs a{ color:var(--ink-2); font-weight:600; }
.crumbs a:hover{ color:var(--accent-d); }
.crumbs-sep{ color:var(--ink-3); }
.crumbs-cur{ color:var(--ink); font-weight:700; }

/* ════════ Match hero (prediction) ════════ */
.match{ background:linear-gradient(180deg,var(--card),var(--card-2)); border:1px solid var(--line);
  border-radius:var(--rxl); box-shadow:var(--shadow); padding:26px 28px; margin-top:12px; }
.match-meta{ display:flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:var(--ink-2); }
.match-h1{ font-size:clamp(20px,3vw,28px); margin:10px 0 22px; }
.match-grid{ display:grid; grid-template-columns:1fr auto 1fr; align-items:start; gap:16px; }
.side{ text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px; }
.side-crest{ width:74px; height:74px; border-radius:50%; background:var(--card); border:1px solid var(--line);
  display:grid; place-items:center; font-size:20px; font-weight:800; color:var(--ink-2); overflow:hidden; box-shadow:var(--shadow); }
.side-crest img{ width:54px; height:54px; object-fit:contain; }
.side-name{ font-size:16px; font-weight:800; }
.side-form{ display:flex; gap:4px; }
.form-pip{ width:21px; height:21px; border-radius:6px; display:grid; place-items:center; font-size:11px; font-weight:800; color:#fff; }
.form-pip--w{ background:var(--pos); }
.form-pip--l{ background:var(--neg); }
.form-pip--d{ background:var(--draw); }
.match-mid{ display:flex; flex-direction:column; align-items:center; gap:3px; padding-top:18px; }
.match-vs{ font-size:13px; font-weight:800; color:var(--accent); }
.match-time{ font-size:26px; font-weight:800; font-variant-numeric:tabular-nums; }
.match-date{ font-size:12px; color:var(--ink-3); font-weight:700; }
.match-info{ display:flex; flex-wrap:wrap; gap:8px 22px; justify-content:center; margin-top:20px; padding-top:16px;
  border-top:1px solid var(--line-2); font-size:13px; color:var(--ink-2); }
.match-info strong{ color:var(--ink); }

/* top pick */
.pick{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:20px; cursor:pointer;
  background:var(--ink); color:#fff; border-radius:var(--rl); padding:18px 20px; position:relative; overflow:hidden; }
.pick::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--accent); }
.pick-ic{ width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:12px; background:var(--accent); color:#fff; }
.pick-ic svg{ width:24px; height:24px; }
.pick-body{ min-width:0; flex:1; }
.pick-tag{ font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); }
.pick-val{ font-size:19px; font-weight:800; margin:2px 0 8px; }
.pick-conf{ display:flex; align-items:center; gap:9px; }
.pick-conf-bar{ width:130px; max-width:40vw; height:6px; border-radius:999px; background:rgba(255,255,255,.18); overflow:hidden; }
.pick-conf-fill{ display:block; height:100%; background:var(--accent); border-radius:999px; }
.pick-conf-txt{ font-size:12px; color:#d8d2c6; font-weight:700; }
.pick-odds{ text-align:center; }
.pick-odds-n{ font-size:24px; font-weight:800; font-variant-numeric:tabular-nums; }
.pick-odds-l{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#bdb6a8; }
.pick-go{ display:inline-flex; align-items:center; gap:8px; background:var(--accent); color:#fff; font-weight:700;
  font-size:14px; padding:11px 18px; border-radius:999px; }
.pick-go svg{ width:17px; height:17px; }
.pick:hover .pick-go{ background:#fff; color:var(--ink); }

/* ════════ AI agents ════════ */
.agents{ margin-top:24px; }
.agents-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:14px; margin-bottom:14px; }
.agents-ey{ font-size:11.5px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-d); }
.agents-h2{ font-size:clamp(20px,2.6vw,27px); margin-top:3px; }
.agents-count{ font-size:12px; font-weight:700; color:var(--ink-2); background:var(--paper-2); padding:6px 12px; border-radius:999px; white-space:nowrap; }
.agents-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.agent{ background:var(--card); border:1px solid var(--line); border-radius:var(--rl); padding:16px; box-shadow:var(--shadow);
  border-top:3px solid var(--ink-3); }
.agent--claude{ border-top-color:#d97757; }
.agent--chatgpt{ border-top-color:#10a37f; }
.agent--gemini{ border-top-color:#4285f4; }
.agent--deepseek{ border-top-color:#7c3aed; }
.agent-hd{ display:flex; align-items:center; gap:11px; padding-bottom:12px; border-bottom:1px solid var(--line-2); }
.agent-av{ width:38px; height:38px; flex:none; display:grid; place-items:center; border-radius:11px; background:var(--ink); color:#fff; font-weight:800; }
.agent-id{ min-width:0; }
.agent-name{ font-size:15px; font-weight:800; display:flex; align-items:center; gap:7px; }
.agent-tag{ font-size:9.5px; font-weight:800; letter-spacing:.06em; padding:2px 6px; border-radius:5px; background:var(--paper-2); color:var(--ink-2); }
.agent-co{ font-size:12px; color:var(--ink-3); }
.agent-conf{ margin-left:auto; font-size:12px; color:var(--ink-3); }
.agent-conf strong{ font-size:18px; color:var(--ink); font-variant-numeric:tabular-nums; }
.agent-pick{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; cursor:pointer; margin:13px 0;
  background:var(--card-2); border:1px solid var(--line-2); border-radius:12px; padding:12px 13px; transition:border-color .12s; }
.agent-pick:hover{ border-color:var(--accent); }
.agent-pick-l{ font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.agent-pick-v{ font-size:15px; font-weight:800; color:var(--pos); }
.agent-pick-mkt{ font-size:12px; color:var(--ink-3); font-weight:600; }
.agent-pick-odds{ margin-left:auto; text-align:center; }
.agent-pick-odds strong{ font-size:16px; font-weight:800; font-variant-numeric:tabular-nums; }
.agent-pick-odds span{ display:block; font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.agent-pick-go{ width:16px; height:16px; color:var(--ink-3); }
.agent-pick:hover .agent-pick-go{ color:var(--accent); }
.agent-article{ font-size:13.5px; color:var(--ink-2); line-height:1.65; }
.agent-why{ font-size:13px; color:var(--ink-2); margin-top:10px; padding-top:10px; border-top:1px solid var(--line-2); }
.agent-why-l{ font-weight:800; color:var(--ink); text-transform:uppercase; font-size:10.5px; letter-spacing:.06em; }

/* ════════ Betting tip block: 1 Main + 3 Secondary ════════ */
.sec-h2{ font-size:clamp(20px,2.8vw,28px); margin:32px 0 0; }
.agents.tips{ margin-top:12px; }

.tip-main{ position:relative; display:block; cursor:pointer; margin-bottom:14px;
  background:var(--ink); color:#fff; border-radius:var(--rl); padding:20px 22px; overflow:hidden; }
.tip-main::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--accent); }
.tip-main-badge{ display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--ink); background:var(--accent); padding:5px 11px; border-radius:999px; }
.tip-main-badge svg{ width:13px; height:13px; }
.tip-main-src{ display:flex; align-items:center; gap:11px; margin:14px 0; }
.tip-main-src .agent-av{ background:rgba(255,255,255,.14); color:#fff; }
.tip-main-src .agent-name{ color:#fff; }
.tip-main-src .agent-tag{ background:rgba(255,255,255,.16); color:#fff; }
.tip-main-src .agent-co{ color:#bdb6a8; }
.tip-main-conf{ margin-left:auto; font-size:12px; color:#bdb6a8; }
.tip-main-conf strong{ font-size:20px; color:#fff; font-variant-numeric:tabular-nums; }
.tip-main-row{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; padding:14px 16px; background:rgba(255,255,255,.06); border-radius:12px; }
.tip-main-pick{ min-width:0; flex:1; }
.tip-main-l{ display:block; font-size:10.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); }
.tip-main-val{ display:block; font-size:21px; font-weight:800; margin-top:3px; }
.tip-main-mkt{ display:block; font-size:12.5px; color:#bdb6a8; margin-top:2px; }
.tip-main-odds{ text-align:center; flex:none; }
.tip-main-odds strong{ display:block; font-size:26px; font-weight:800; font-variant-numeric:tabular-nums; }
.tip-main-odds span{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#bdb6a8; }
.tip-main-why{ font-size:13.5px; color:#d8d2c6; line-height:1.6; margin-top:14px; }
.tip-main-cta{ display:inline-flex; align-items:center; gap:8px; margin-top:16px; background:var(--accent); color:#fff; font-weight:700; font-size:14px; padding:11px 18px; border-radius:999px; }
.tip-main-cta svg{ width:17px; height:17px; }
.tip-main:hover .tip-main-cta{ background:#fff; color:var(--ink); }

.tips-sec{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.tip-sec{ position:relative; display:flex; flex-direction:column; cursor:pointer;
  background:var(--card); border:1px solid var(--line); border-top:3px solid var(--ink-3); border-radius:var(--r); padding:14px; box-shadow:var(--shadow); transition:transform .12s, box-shadow .12s; }
.tip-sec:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.tip-sec.agent--claude{ border-top-color:#d97757; }
.tip-sec.agent--chatgpt{ border-top-color:#10a37f; }
.tip-sec.agent--gemini{ border-top-color:#4285f4; }
.tip-sec.agent--deepseek{ border-top-color:#7c3aed; }
.tip-sec-hd{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.tip-sec-src{ font-size:12.5px; font-weight:800; }
.tip-sec-conf{ font-size:11px; font-weight:700; color:var(--ink-2); background:var(--paper-2); padding:2px 7px; border-radius:6px; font-variant-numeric:tabular-nums; }
.tip-sec-val{ font-size:15px; font-weight:800; color:var(--pos); margin:9px 0 8px; }
.tip-sec-foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.tip-sec-odds{ font-size:12.5px; color:var(--ink-2); }
.tip-sec-odds strong{ font-size:15px; color:var(--ink); font-variant-numeric:tabular-nums; }
.tip-sec-go{ width:16px; height:16px; color:var(--ink-3); }
.tip-sec:hover .tip-sec-go{ color:var(--accent); }
.tip-sec-why{ font-size:12px; color:var(--ink-3); line-height:1.55; margin-top:9px; padding-top:9px; border-top:1px solid var(--line-2); }
/* main-card confidence row (on dark tip-main) */
.tip-main-conf-row{ display:flex; align-items:center; gap:9px; margin-top:9px; }
.tip-main-conf-txt{ font-size:12px; color:#d8d2c6; font-weight:700; }
/* secondary probability bar */
.tip-sec-bar{ display:block; height:5px; border-radius:999px; background:var(--paper-2); overflow:hidden; margin-top:10px; }
.tip-sec-bar-fill{ display:block; height:100%; background:var(--accent); border-radius:999px; }
/* 4-additional layout */
.tips-sec--4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:860px){ .tips-sec--4{ grid-template-columns:repeat(2,1fr); } }
.match-preview{ margin-top:14px; }
@media (max-width:680px){ .tips-sec{ grid-template-columns:1fr; } }

/* ════════ Win probability ════════ */
.prob-bar{ display:flex; height:16px; border-radius:999px; overflow:hidden; background:var(--paper-2); }
.prob-seg{ display:grid; place-items:center; min-width:0; transition:flex .3s; }
.prob-seg-v{ font-size:13px; font-weight:800; color:#fff; font-variant-numeric:tabular-nums; }
.prob-seg--home{ background:var(--ink); }
.prob-seg--draw{ background:var(--draw); }
.prob-seg--away{ background:var(--accent); }
.prob-seg.is-top{ box-shadow:inset 0 -3px 0 rgba(255,255,255,.4); }
.prob-tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:11px; margin-top:14px; }
.prob-tile{ display:flex; align-items:center; gap:10px; background:var(--card-2); border:1px solid var(--line-2); border-radius:12px; padding:13px; }
.prob-tile.is-top{ border-color:var(--accent); background:var(--accent-soft); }
.prob-dot{ width:11px; height:11px; border-radius:50%; flex:none; }
.prob-dot--home{ background:var(--ink); }
.prob-dot--draw{ background:var(--draw); }
.prob-dot--away{ background:var(--accent); }
.prob-tile-b{ min-width:0; flex:1; }
.prob-team{ font-size:13.5px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.prob-lbl{ font-size:11px; color:var(--ink-3); }
.prob-pct{ font-size:20px; font-weight:800; font-variant-numeric:tabular-nums; }

/* ════════ Form comparison ════════ */
.cmp-teams{ display:flex; justify-content:space-between; margin-bottom:14px; font-size:13.5px; }
.cmp-t{ display:inline-flex; align-items:center; gap:7px; }
.cmp-t-dot{ width:10px; height:10px; border-radius:50%; }
.cmp-t--home .cmp-t-dot{ background:var(--ink); }
.cmp-t--away .cmp-t-dot{ background:var(--accent); }
.cmp-row{ display:grid; grid-template-columns:40px 1fr auto 1fr 40px; align-items:center; gap:10px; padding:7px 0; }
.cmp-pct{ font-size:12.5px; font-weight:800; font-variant-numeric:tabular-nums; }
.cmp-pct--home{ text-align:right; }
.cmp-bar{ height:8px; border-radius:999px; background:var(--paper-2); overflow:hidden; display:flex; }
.cmp-row .cmp-bar:nth-of-type(2){ justify-content:flex-end; }
.cmp-fill{ height:100%; border-radius:999px; }
.cmp-fill--home{ background:var(--ink); margin-left:auto; }
.cmp-fill--away{ background:var(--accent); }
.cmp-lbl{ font-size:12px; font-weight:700; color:var(--ink-2); text-align:center; white-space:nowrap; }
.cmp-row.is-total{ border-top:1px solid var(--line-2); margin-top:6px; padding-top:13px; }
.cmp-row.is-total .cmp-lbl{ color:var(--accent-d); font-weight:800; }

/* ════════ Accordion (recent / h2h) ════════ */
.acc-hd{ cursor:pointer; }
.acc-chev{ margin-left:auto; width:22px; height:22px; flex:none; color:var(--ink-3); transition:transform .2s; }
.acc:not(.is-open) .acc-bd{ display:none; }
.acc.is-open .acc-chev{ transform:rotate(180deg); }
.rline-block + .rline-block{ margin-top:18px; }
.rline-block-hd{ font-size:12px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px; }
.rline{ display:grid; grid-template-columns:80px 1fr auto 26px; align-items:center; gap:12px; padding:9px 0; border-bottom:1px solid var(--line-2); }
.rline:last-child{ border-bottom:0; }
.rline-date{ font-size:12px; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.rline-opp{ font-size:14px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rline-score{ font-size:13px; font-weight:800; font-variant-numeric:tabular-nums; }
.rline-res{ width:24px; height:24px; border-radius:7px; display:grid; place-items:center; font-size:11px; font-weight:800; color:#fff; }
.rline-res--w{ background:var(--pos); }
.rline-res--l{ background:var(--neg); }
.rline-res--d{ background:var(--draw); }
.h2h{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--line-2); }
.h2h:last-child{ border-bottom:0; }
.h2h-date{ font-size:12px; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.h2h-match{ display:flex; align-items:center; gap:8px; font-size:13.5px; min-width:0; }
.h2h-team{ font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.h2h-vs{ color:var(--ink-3); font-size:11px; }
.h2h-score{ font-size:14px; font-weight:800; font-variant-numeric:tabular-nums; }

/* ════════ Injuries ════════ */
.inj{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.inj-h{ display:flex; align-items:center; gap:8px; font-size:14px; font-weight:800; margin-bottom:10px; }
.inj-h-dot{ width:9px; height:9px; border-radius:50%; }
.inj-col--home .inj-h-dot{ background:var(--ink); }
.inj-col--away .inj-h-dot{ background:var(--accent); }
.inj-row{ display:flex; align-items:center; gap:9px; font-size:13.5px; padding:6px 0; color:var(--ink); }
.inj-row--none{ color:var(--ink-3); }
.inj-ic{ width:20px; height:20px; flex:none; display:grid; place-items:center; border-radius:6px; font-size:11px; font-weight:800; background:var(--neg-soft); color:var(--neg); }
.inj-ic.is-susp{ background:var(--draw-soft); color:var(--draw); }

/* ════════ Roster ════════ */
.roster-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.roster-team{ display:flex; align-items:center; gap:8px; font-size:14px; font-weight:800; margin-bottom:9px; }
.roster-dot{ width:9px; height:9px; border-radius:50%; }
.roster-dot--home{ background:var(--ink); }
.roster-dot--away{ background:var(--accent); }
.roster-row{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; padding:7px 0; border-bottom:1px solid var(--line-2); font-size:13.5px; }
.roster-row:last-child{ border-bottom:0; }
.roster-name{ font-weight:700; }
.roster-pos{ font-size:10.5px; font-weight:800; color:var(--ink-2); background:var(--paper-2); padding:2px 7px; border-radius:6px; }
.roster-meta,.roster-detail{ font-size:12px; color:var(--ink-3); }
.roster-status{ margin-left:auto; font-size:11px; font-weight:700; padding:2px 8px; border-radius:999px; }
.roster-status--inj{ background:var(--neg-soft); color:var(--neg); }
.roster-status--sus{ background:var(--draw-soft); color:var(--draw); }
.roster-empty{ color:var(--ink-3); font-size:13px; padding:6px 0; }

/* ════════ Venue ctx ════════ */
.venue-row{ font-size:14px; padding:6px 0; color:var(--ink-2); }
.venue-row strong{ color:var(--ink); }
.venue-alt{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.venue-flag{ font-size:11.5px; font-weight:800; color:var(--accent-d); background:var(--accent-soft); padding:3px 9px; border-radius:999px; }
.venue-note{ font-size:13.5px; color:var(--ink-2); line-height:1.65; margin-top:10px; padding:12px 14px; background:var(--card-2); border-left:3px solid var(--accent); border-radius:0 10px 10px 0; }
.venue-weather{ font-size:13.5px; color:var(--ink-2); margin-top:10px; }
.venue-weather strong{ color:var(--ink); }

/* ════════ Lineups ════════ */
.lineup-wrap{ display:grid; grid-template-columns:minmax(0,360px) 1fr; gap:20px; align-items:center; }
.pitch{ width:100%; max-width:360px; height:auto; border-radius:14px; box-shadow:var(--shadow); }
.pp-name{ paint-order:stroke; stroke:rgba(0,0,0,.35); stroke-width:2px; }
.lineup-coaches{ display:flex; flex-direction:column; gap:12px; }
.lineup-coach{ background:var(--card-2); border:1px solid var(--line-2); border-radius:12px; padding:13px 15px; border-left:4px solid; }
.lineup-coach--home{ border-left-color:var(--teal); }
.lineup-coach--away{ border-left-color:var(--accent); }
.lineup-coach-l{ display:block; font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-3); }
.lineup-coach-n{ display:block; font-size:15px; font-weight:800; margin-top:2px; }
.lineup-pending{ text-align:center; padding:24px; }
.lineup-pending-ic{ font-size:34px; }
.lineup-pending-msg{ font-weight:700; margin-top:8px; }
.lineup-pending-sub{ color:var(--ink-3); font-size:13px; margin-top:3px; }

/* ════════ Standings table ════════ */
.tbl-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
.tbl{ width:100%; border-collapse:collapse; font-size:14px; }
.tbl th{ font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-3); text-align:center; padding:8px 6px; border-bottom:1.5px solid var(--line); }
.tbl td{ padding:11px 6px; border-bottom:1px solid var(--line-2); text-align:center; font-variant-numeric:tabular-nums; }
.tbl tr:last-child td{ border-bottom:0; }
.c-team{ text-align:left !important; }
.c-pos{ width:34px; }
.c-num{ width:38px; }
.pos{ display:inline-grid; place-items:center; min-width:24px; height:24px; padding:0 6px; border-radius:7px; background:var(--paper-2); font-weight:800; font-size:12.5px; }
.team{ display:flex; align-items:center; gap:9px; }
.team-logo{ width:22px; height:22px; object-fit:contain; flex:none; }
.team-name{ font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.star{ color:var(--accent); font-size:12px; }
.gd{ color:var(--ink-2); }
.pts{ font-weight:800; }
.tbl tr.is-hi{ background:var(--accent-soft); }
.tbl tr.is-hi .pos{ background:var(--accent); color:#fff; }
.tbl tr.z-ucl .pos{ box-shadow:inset 3px 0 0 #2563eb; }
.tbl tr.z-uel .pos{ box-shadow:inset 3px 0 0 #f59e0b; }
.tbl tr.z-ucf .pos{ box-shadow:inset 3px 0 0 var(--teal); }
.tbl tr.z-rel .pos{ box-shadow:inset 3px 0 0 var(--neg); }
.tbl-legend{ display:flex; flex-wrap:wrap; gap:14px; margin-top:14px; padding-top:13px; border-top:1px solid var(--line-2); font-size:12px; color:var(--ink-2); }
.tbl-legend span{ display:inline-flex; align-items:center; gap:6px; }
.tbl-legend i{ width:10px; height:10px; border-radius:3px; }
.lg-ucl{ background:#2563eb; } .lg-uel{ background:#f59e0b; } .lg-ucf{ background:var(--teal); } .lg-rel{ background:var(--neg); }

/* ════════ Odds ════════ */
.odds-row{ display:grid; grid-template-columns:1fr 60px 60px 60px auto; align-items:center; gap:10px;
  padding:13px 8px; border-bottom:1px solid var(--line-2); }
.odds-row:last-child{ border-bottom:0; }
.odds-row.is-hd{ font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-3); padding:6px 8px; }
.odds-row.is-hd .odds-col{ text-align:center; }
.odds-bk{ font-weight:700; font-size:14px; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.odds-val{ text-align:center; font-weight:800; font-variant-numeric:tabular-nums; font-size:14.5px; }
.odds-btn{ font-size:12px; font-weight:800; color:#fff; background:var(--ink); padding:8px 14px; border-radius:999px; white-space:nowrap; }
.odds-row.is-best{ background:var(--accent-soft); border-radius:12px; cursor:pointer; }
.odds-row.is-best .odds-btn{ background:var(--accent); }
.odds-row.is-best:hover .odds-btn{ background:var(--accent-d); }
.best-tag{ font-size:9.5px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--accent-d); background:#fff; padding:2px 7px; border-radius:5px; }

/* ════════ Verdict (legacy single tip) ════════ */
.verdict{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; background:var(--card-2); border:1px solid var(--line-2); border-radius:12px; padding:16px; cursor:pointer; }
.verdict-ic{ width:42px; height:42px; flex:none; display:grid; place-items:center; border-radius:11px; background:var(--accent); color:#fff; }
.verdict-ic svg{ width:23px; height:23px; }
.verdict-body{ flex:1; min-width:0; }
.verdict-label{ font-size:17px; font-weight:800; }
.verdict-desc{ font-size:13px; color:var(--ink-2); margin-top:3px; }
.verdict-odds{ text-align:center; }
.verdict-odds-v{ font-size:22px; font-weight:800; font-variant-numeric:tabular-nums; }
.verdict-odds-l{ font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.verdict-add-list{ margin-top:14px; display:flex; flex-direction:column; gap:10px; }
.verdict-add{ display:grid; grid-template-columns:1fr 120px auto; align-items:center; gap:12px; }
.verdict-add-lbl{ font-size:13.5px; font-weight:700; }
.verdict-add-odds{ color:var(--ink-3); font-weight:600; font-family:var(--fn-mono); font-size:11px; margin-left:6px; }
.verdict-add-bar{ height:7px; border-radius:999px; background:var(--paper-2); overflow:hidden; }
.verdict-add-fill{ display:block; height:100%; background:var(--accent); border-radius:999px; }
.verdict-add-pct{ font-size:12.5px; font-weight:800; font-variant-numeric:tabular-nums; }

/* ════════ More picks carousel ════════ */
.more{ margin-top:30px; }
.more-hd{ display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.more-hd-t{ font-size:18px; font-weight:800; white-space:nowrap; }
.more-hd-line{ flex:1; height:1px; background:var(--line); }
.more-nav{ display:flex; gap:7px; }
.more-btn{ width:36px; height:36px; border-radius:10px; border:1px solid var(--line); background:var(--card); display:grid; place-items:center; color:var(--ink); }
.more-btn svg{ width:18px; height:18px; }
.more-btn:hover:not(:disabled){ background:var(--ink); color:#fff; }
.more-btn:disabled{ opacity:.35; cursor:default; }
.more-wrap{ position:relative; }
.more-track{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; -ms-overflow-style:none; scrollbar-width:none; padding-bottom:4px; }
.more-track::-webkit-scrollbar{ display:none; }
.card-more{ flex:0 0 232px; scroll-snap-align:start; background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:14px; box-shadow:var(--shadow); transition:transform .14s; }
.card-more:hover{ transform:translateY(-3px); }
.cm-lg{ font-size:11px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--accent-d); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cm-teams{ margin:10px 0; display:flex; flex-direction:column; gap:8px; }
.cm-team{ display:flex; align-items:center; gap:9px; }
.cm-logo{ width:26px; height:26px; flex:none; border-radius:50%; background:var(--paper-2); display:grid; place-items:center; font-size:10px; font-weight:800; color:var(--ink-2); }
.cm-tn{ font-size:14px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cm-time{ font-size:12px; color:var(--ink-3); font-weight:700; padding-top:10px; border-top:1px solid var(--line-2); }

/* ════════ Big CTA band ════════ */
.cta-band{ margin-top:50px; background:var(--ink); color:#fff; position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; left:50%; top:-120px; width:420px; height:420px; transform:translateX(-50%); border-radius:50%; background:radial-gradient(circle,rgba(232,67,31,.32),transparent 68%); }
.cta-band-in{ max-width:760px; margin:0 auto; padding:56px 20px; text-align:center; position:relative; }
.cta-band-ey{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:#ffd2c6; }
.cta-band-ey-dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); animation:pulse 1.8s infinite; }
.cta-band-h{ font-size:clamp(28px,5vw,46px); margin:14px 0 12px; }
.cta-band-h-hl{ color:var(--accent); }
.cta-band-sub{ color:#cfc9bd; max-width:54ch; margin:0 auto 24px; }
.cta-band-btns{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.cta-band-btns .btn-line{ color:#fff; border-color:rgba(255,255,255,.4); }
.cta-band-btns .btn-line:hover{ background:#fff; color:var(--ink); }
.cta-band-trust{ list-style:none; display:flex; flex-wrap:wrap; gap:28px; justify-content:center; margin-top:28px; padding-top:24px; border-top:1px solid rgba(255,255,255,.14); }
.cta-band-trust li{ font-size:13px; color:#cfc9bd; }
.cta-band-trust strong{ display:block; font-size:24px; color:#fff; font-weight:800; }

/* ════════ Footer ════════ */
.foot{ background:var(--paper-2); border-top:1px solid var(--line); }
.foot-in{ max-width:var(--wrap); margin:0 auto; padding:48px 20px 24px; }
.foot-top{ display:grid; grid-template-columns:1.4fr 2.6fr; gap:36px; }
.foot-word{ display:inline-flex; align-items:center; gap:10px; font-size:18px; font-weight:800; }
.foot-word-mark{ width:34px; height:34px; display:grid; place-items:center; border-radius:10px; background:var(--ink); color:var(--accent); }
.foot-word-mark svg{ width:19px; height:19px; }
.foot-tag{ font-size:13.5px; color:var(--ink-2); margin-top:12px; max-width:42ch; }
.foot-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.foot-h{ font-size:11.5px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:12px; }
.foot-links{ list-style:none; display:flex; flex-direction:column; gap:9px; }
.foot-links a{ font-size:13.5px; color:var(--ink-2); font-weight:600; }
.foot-links a:hover{ color:var(--accent-d); }
.foot-rule{ border:0; border-top:1px solid var(--line); margin:32px 0 18px; }
.foot-legal{ font-size:12px; color:var(--ink-3); line-height:1.7; }

/* ════════ Floating dock ════════ */
.dock{ position:fixed; right:20px; bottom:20px; z-index:90; width:300px; max-width:calc(100vw - 40px);
  background:var(--card); border:1px solid var(--line); border-radius:var(--rl); box-shadow:var(--shadow-lg); padding:18px; }
.dock.is-hidden{ display:none; }
.dock-x{ position:absolute; right:10px; top:10px; width:26px; height:26px; border-radius:50%; color:var(--ink-3); display:grid; place-items:center; }
.dock-x:hover{ background:var(--paper-2); color:var(--ink); }
.dock-ey{ display:inline-flex; align-items:center; gap:7px; font-size:11px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-d); }
.dock-ey-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); animation:pulse 1.8s infinite; }
.dock-h{ font-size:17px; font-weight:800; margin:8px 0 4px; }
.dock-sub{ font-size:13px; color:var(--ink-2); margin-bottom:14px; }
.dock-btn{ display:flex; align-items:center; justify-content:center; gap:8px; background:var(--accent); color:#fff; font-weight:700; padding:12px; border-radius:11px; }
.dock-btn svg{ width:17px; height:17px; }
.dock-btn:hover{ background:var(--accent-d); }

/* ════════ Promo modal ════════ */
.modal{ position:fixed; inset:0; z-index:300; display:grid; place-items:center; padding:20px; opacity:0; visibility:hidden; transition:.2s; }
.modal.is-open{ opacity:1; visibility:visible; }
.modal-bg{ position:absolute; inset:0; background:rgba(23,20,15,.55); backdrop-filter:blur(3px); }
.modal-card{ position:relative; width:420px; max-width:100%; background:var(--card); border-radius:var(--rxl); box-shadow:var(--shadow-lg); padding:30px 28px; transform:translateY(14px) scale(.98); transition:.2s; }
.modal.is-open .modal-card{ transform:none; }
.modal-x{ position:absolute; right:14px; top:14px; width:32px; height:32px; border-radius:50%; font-size:20px; color:var(--ink-3); display:grid; place-items:center; }
.modal-x:hover{ background:var(--paper-2); color:var(--ink); }
.modal-badge{ display:inline-flex; align-items:center; gap:7px; font-size:11.5px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--accent-d); background:var(--accent-soft); padding:6px 12px; border-radius:999px; }
.modal-h{ font-size:25px; margin:14px 0 8px; }
.modal-sub{ font-size:14px; color:var(--ink-2); margin-bottom:16px; }
.modal-sub strong{ color:var(--ink); }
.modal-list{ list-style:none; display:flex; flex-direction:column; gap:9px; margin-bottom:20px; }
.modal-list li{ position:relative; padding-left:26px; font-size:13.5px; color:var(--ink-2); }
.modal-list li::before{ content:"✓"; position:absolute; left:0; top:0; width:18px; height:18px; border-radius:50%; background:var(--pos-soft); color:var(--pos); font-size:11px; font-weight:800; display:grid; place-items:center; }
.modal-cta{ display:flex; align-items:center; justify-content:center; gap:9px; background:var(--accent); color:#fff; font-weight:800; padding:15px; border-radius:13px; }
.modal-cta:hover{ background:var(--accent-d); }
.modal-fine{ text-align:center; font-size:11.5px; color:var(--ink-3); margin-top:12px; }

/* ════════ 404 ════════ */
.nf{ text-align:center; padding:70px 20px; }
.nf-code{ font-size:clamp(70px,16vw,140px); font-weight:800; letter-spacing:-.04em; color:var(--accent); line-height:1; }
.nf-h1{ font-size:28px; margin:10px 0 10px; }
.nf-text{ color:var(--ink-2); max-width:46ch; margin:0 auto 26px; }
.nf-btn{ display:inline-flex; }

/* ════════ Responsive ════════ */
@media (max-width:920px){
  .mast-nav{ display:none; }
  .burger{ display:flex; }
  .mast-cta{ display:none; }
  .lede-grid{ grid-template-columns:1fr; padding:30px 24px; text-align:center; }
  .lede-sub{ margin-left:auto; margin-right:auto; }
  .lede-facts,.lede-cta{ justify-content:center; }
  .lede-art{ order:-1; min-height:auto; }
  .lede-trophy{ width:180px; }
  .foot-top{ grid-template-columns:1fr; gap:26px; }
}
@media (max-width:680px){
  .wrap{ padding:18px 14px 50px; }
  .stat-row{ grid-template-columns:repeat(2,1fr); }
  .agents-grid{ grid-template-columns:1fr; }
  .prob-tiles{ grid-template-columns:1fr; }
  .inj,.roster-grid{ grid-template-columns:1fr; }
  .lineup-wrap{ grid-template-columns:1fr; }
  .pitch{ max-width:300px; margin:0 auto; }
  .fx{ grid-template-columns:46px auto 1fr; grid-template-areas:"when crests teams" "tip tip tip"; row-gap:10px; }
  .fx-when{ grid-area:when; } .fx-crests{ grid-area:crests; } .fx-teams{ grid-area:teams; }
  .fx-tip{ grid-area:tip; max-width:100%; justify-self:start; }
  .fx-go{ display:none; }
  .opener{ flex-direction:column; align-items:flex-start; }
  .opener-match{ margin-left:0; }
  .match-h1{ font-size:20px; }
  .side-crest{ width:60px; height:60px; }
  .side-crest img{ width:44px; height:44px; }
  .match{ padding:20px 16px; }
  .panel-bd{ padding:16px; }
  .verdict-add{ grid-template-columns:1fr auto; }
  .verdict-add-bar{ display:none; }
  .odds-row{ grid-template-columns:1fr 46px 46px 46px; }
  .odds-btn{ display:none; }
  .odds-row.is-best .odds-btn{ display:inline-block; grid-column:1/-1; text-align:center; margin-top:6px; }
  /* panel header: let the heading + pill stack instead of overflowing (e.g. Expected Lineups) */
  .panel-hd{ flex-wrap:wrap; gap:8px; }
  .panel-pill{ margin-left:0; white-space:normal; }
  /* Top Pick card: tidy + full-width CTA on mobile */
  .tip-main{ padding:18px 16px; }
  .tip-main-row{ flex-direction:column; align-items:flex-start; gap:8px; }
  .tip-main-conf-row{ flex-wrap:wrap; }
  .tip-main-cta{ display:flex; width:100%; justify-content:center; }
  .agents-head{ align-items:flex-start; }
}

/* probability stacked bar (home blue / draw grey / away purple) */
.probbar{ display:flex; height:32px; border-radius:9px; overflow:hidden; margin:0 0 8px; }
.probbar-seg{ display:flex; align-items:center; justify-content:center; color:#fff; font-size:12.5px; font-weight:800; min-width:0; white-space:nowrap; }
.probbar-seg--home{ background:#2563eb; } .probbar-seg--draw{ background:#94a3b8; } .probbar-seg--away{ background:#7c3aed; }
.probbar-key{ display:flex; gap:20px; justify-content:center; margin:0 0 16px; font-size:12px; font-weight:700; color:var(--ink-2); flex-wrap:wrap; }
.probbar-key i{ display:inline-block; width:10px; height:10px; border-radius:50%; margin-right:6px; vertical-align:middle; }
.probbar-dot--home{ background:#2563eb; } .probbar-dot--draw{ background:#94a3b8; } .probbar-dot--away{ background:#7c3aed; }

/* H2H override extras */
.h2h-note{ margin:11px 2px 0; font-size:12px; color:var(--ink-3); line-height:1.5; }
.h2h-empty{ margin:0; color:var(--ink-2); font-size:14px; }

.rline-date{ white-space:nowrap; }
.rline-note{ margin:8px 0 0; font-size:11.5px; font-style:italic; color:var(--ink-3); }

/* ── POST-MATCH blocks (wcf) ── */
.panel.pm-result,.panel.pm-forecast,.panel.pm-summary,.panel.pm-standings{ padding:16px 18px; margin-bottom:14px; }
.pm-result{ text-align:center; }
.pm-ft{ display:inline-block; font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--pos,#16a34a); background:rgba(22,163,74,.1); padding:4px 12px; border-radius:20px; margin-bottom:10px; }
.pm-scoreline{ display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; }
.pm-side{ display:flex; align-items:center; gap:10px; font-weight:700; font-size:16px; color:var(--ink); }
.pm-side img{ border-radius:6px; }
.pm-score{ font-weight:800; font-size:34px; color:var(--ink); letter-spacing:-.02em; font-variant-numeric:tabular-nums; }
.pm-score i{ color:var(--ink-3); margin:0 8px; font-style:normal; }
.pm-meta{ margin-top:10px; font-size:12.5px; color:var(--ink-3); }
.pm-forecast{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.pm-forecast-l{ display:flex; flex-direction:column; gap:3px; }
.pm-forecast-lbl{ font-size:11px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.pm-forecast-pick{ font-size:16px; font-weight:800; color:var(--ink); }
.pm-forecast-verdict{ font-weight:800; font-size:14px; }
.pm-forecast--win .pm-forecast-verdict{ color:var(--pos,#16a34a); }
.pm-forecast--loss .pm-forecast-verdict{ color:var(--neg,#dc2626); }
.pm-forecast--win{ border-left:3px solid var(--pos,#16a34a); }
.pm-forecast--loss{ border-left:3px solid var(--neg,#dc2626); }
.pm-summary h2,.pm-standings h2{ font-size:17px; margin:0 0 8px; }
.pm-summary p{ font-size:14.5px; line-height:1.65; color:var(--ink-2); margin:0; }
.pm-tbl{ width:100%; border-collapse:collapse; font-size:13px; }
.pm-tbl th{ text-align:center; font-size:11px; color:var(--ink-3); font-weight:700; padding:6px 4px; border-bottom:1px solid var(--line); }
.pm-tbl th:nth-child(2){ text-align:left; }
.pm-tbl td{ text-align:center; padding:9px 4px; border-bottom:1px solid var(--line); color:var(--ink-2); font-variant-numeric:tabular-nums; }
.pm-tbl tr:last-child td{ border-bottom:0; }
.pm-tbl-team{ text-align:left !important; display:flex; align-items:center; gap:8px; color:var(--ink) !important; font-weight:600; }
.pm-tbl-team img{ border-radius:4px; }
.pm-tbl tr.is-match td{ background:rgba(0,0,0,.035); }
.pm-next{ margin-top:12px; display:flex; gap:14px; flex-wrap:wrap; }
.pm-next a{ font-size:13px; font-weight:700; color:var(--accent-d,#dc2626); text-decoration:none; }
.pm-divider{ display:flex; align-items:center; gap:14px; margin:22px 0 16px; color:var(--ink-3); font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; }
.pm-divider::before,.pm-divider::after{ content:""; flex:1; height:1px; background:var(--line); }
