/* ═══════════════════════════════════════════════════════════════════
   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:#eef1f6;        /* warm page bg */
  --paper-2:#e4e9f1;
  --card:#ffffff;
  --card-2:#f5f8fc;
  --ink:#0e1526;          /* near-black warm */
  --ink-2:#46506a;        /* muted */
  --ink-3:#8b94a8;        /* faint */
  --line:#dfe5ef;         /* warm hairline */
  --line-2:#eaeef4;

  --accent:#1f6feb;       /* vermilion */
  --accent-d:#1657c4;
  --accent-soft:#dce8fd;

  --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:1360px; --mast-h:66px;
}

*{ 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(31,111,235,.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:#cfe0ff; }
.ticker-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 0 rgba(31,111,235,.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(31,111,235,.6);} 70%{ box-shadow:0 0 0 7px rgba(31,111,235,0);} 100%{ box-shadow:0 0 0 0 rgba(31,111,235,0);} }

/* ── Masthead nav ── */
.mast{ position:sticky; top:0; z-index:100; background:rgba(9,14,26,.85);
  backdrop-filter:saturate(160%) blur(12px); -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid rgba(255,255,255,.09); transition:box-shadow .2s, background .2s; }
.mast.is-stuck{ box-shadow:0 8px 28px rgba(0,0,0,.34); background:rgba(9,14,26,.95); }
.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:14px; font-weight:600;
  color:rgba(255,255,255,.78); padding:8px 14px; border-radius:999px; transition:color .12s, background .12s; white-space:nowrap; }
.mast-link svg{ width:16px; height:16px; }
.mast-link:hover{ color:#fff; background:rgba(255,255,255,.10); }
.mast-link.is-active{ color:#fff; }
.mast-nav>.mast-link.is-active{ background:var(--accent); color:#fff; box-shadow:0 4px 12px rgba(31,111,235,.4); }

/* 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(31,111,235,.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 rgba(255,255,255,.18);
  background:rgba(255,255,255,.06); flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.burger span{ display:block; width:18px; height:2px; border-radius:2px; background:#fff; }

/* 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),#67a6ff,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(31,111,235,.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(31,111,235,.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:#c3ccdb; 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:22px; 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:24px; margin:22px 0 10px; }
.prose h3{ font-size:18px; margin:18px 0 8px; }
.prose h2:first-child,.prose h3:first-child{ margin-top:0; }
.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),#67a6ff,var(--accent)); }
.hero-glow{ position:absolute; right:-70px; top:-90px; width:440px; height:440px; border-radius:50%;
  background:radial-gradient(circle,rgba(31,111,235,.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:#cfe0ff; 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:#c3ccdb; 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:#aab4c7; }
.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; }

/* Image hero (predict7) */
.bghero{ position:relative; overflow:hidden; border-radius:var(--rxl); margin-bottom:26px; min-height:430px; display:flex; align-items:flex-end; isolation:isolate; }
.bghero-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 28%; z-index:-2; }
.bghero-veil{ position:absolute; inset:0; z-index:-1; background:
  linear-gradient(180deg, rgba(7,11,22,.28) 0%, rgba(7,11,22,.52) 52%, rgba(7,11,22,.90) 100%),
  linear-gradient(90deg, rgba(7,11,22,.72) 0%, rgba(7,11,22,.10) 62%); }
.bghero-in{ position:relative; padding:34px 34px; max-width:700px; color:#fff; }
.bghero-kick{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  color:#cfe0ff; background:rgba(31,111,235,.24); border:1px solid rgba(120,170,255,.42); padding:7px 14px; border-radius:999px; backdrop-filter:blur(5px); }
.bghero-kick-dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(31,111,235,.32); animation:pulse 1.8s infinite; }
.bghero-title{ font-size:clamp(28px,4.8vw,48px); font-weight:800; letter-spacing:-.03em; line-height:1.04; margin:16px 0 13px; text-shadow:0 2px 22px rgba(0,0,0,.55); }
.bghero-lead{ font-size:16px; line-height:1.55; color:#e6ecf7; max-width:560px; margin:0 0 24px; text-shadow:0 1px 10px rgba(0,0,0,.45); }
.bghero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom:26px; }
.btn-ghost--img{ color:#fff; border-color:rgba(255,255,255,.5); background:rgba(255,255,255,.10); backdrop-filter:blur(5px); }
.btn-ghost--img:hover{ background:rgba(255,255,255,.20); color:#fff; }
.bghero-stats{ list-style:none; display:flex; flex-wrap:wrap; gap:26px; margin:0; padding:0; }
.bghero-stats li{ display:flex; flex-direction:column; font-size:11.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#aeb8cc; }
.bghero-stats b{ font-size:27px; font-weight:800; letter-spacing:-.02em; color:#fff; font-variant-numeric:tabular-nums; }
@media (max-width:680px){ .bghero{ min-height:380px; } .bghero-in{ padding:24px 18px; max-width:100%; } .bghero-stats{ gap:18px; } .bghero-stats b{ font-size:23px; } }

@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:#c3ccdb; 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:#aab4c7; }
.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:#aab4c7; }
.tip-main-conf{ margin-left:auto; font-size:12px; color:#aab4c7; }
.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:#aab4c7; 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:#aab4c7; }
.tip-main-why{ font-size:13.5px; color:#c3ccdb; 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:#c3ccdb; 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; max-width:1000px; }
@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:46px 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:linear-gradient(135deg,#1f6feb 0%,#1657c4 52%,#0c1f4a 100%); color:#fff; position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; right:-80px; top:-130px; width:460px; height:460px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.16),transparent 66%); }
.cta-band::after{ content:""; position:absolute; left:-90px; bottom:-150px; width:430px; height:430px; border-radius:50%; background:radial-gradient(circle,rgba(0,0,0,.24),transparent 66%); }
.cta-band-in{ max-width:820px; margin:0 auto; padding:62px 20px; text-align:center; position:relative; z-index:1; }
.cta-band-ey{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.26); padding:7px 15px; border-radius:999px; }
.cta-band-ey-dot{ width:8px; height:8px; border-radius:50%; background:#fff; animation:pulse 1.8s infinite; }
.cta-band-h{ font-size:clamp(30px,5.2vw,50px); font-weight:800; letter-spacing:-.02em; line-height:1.05; margin:18px 0 12px; }
.cta-band-h-hl{ color:#bfe0ff; }
.cta-band-sub{ color:rgba(255,255,255,.86); max-width:56ch; margin:0 auto 26px; font-size:16px; }
.cta-band-btns{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.cta-band-btns .btn-solid{ background:#fff; color:var(--accent-d); box-shadow:0 12px 30px rgba(0,0,0,.22); }
.cta-band-btns .btn-solid:hover{ background:var(--ink); color:#fff; }
.cta-band-btns .btn-line{ color:#fff; border-color:rgba(255,255,255,.55); }
.cta-band-btns .btn-line:hover{ background:rgba(255,255,255,.16); color:#fff; }
.cta-band-trust{ list-style:none; display:inline-flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:30px; padding:0; }
.cta-band-trust li{ font-size:12.5px; font-weight:700; color:#fff; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); padding:8px 15px; border-radius:999px; }
.cta-band-trust li::before{ content:"✓ "; color:#bfe0ff; }

/* ════════ Footer ════════ */
.foot{ background:#0a0f1d; border-top:3px solid var(--accent); }
.foot-in{ max-width:var(--wrap); margin:0 auto; padding:54px 20px 26px; }
.foot-top{ display:block; }
.foot-brand{ margin-bottom:36px; padding-bottom:32px; border-bottom:1px solid rgba(255,255,255,.08);
  display:flex; flex-direction:column; align-items:flex-start; gap:14px; }
.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(--accent); color:#fff; }
.foot-word-mark svg{ width:19px; height:19px; }
.foot-tag{ font-size:14px; color:#9aa6bd; margin:0; max-width:62ch; }
.foot-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.foot-h{ font-size:11.5px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:13px; }
.foot-links{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.foot-links a{ font-size:13.5px; color:#c0c9d9; font-weight:600; }
.foot-links a:hover{ color:#fff; }
.foot-rule{ border:0; border-top:1px solid rgba(255,255,255,.10); margin:34px 0 18px; }
.foot-legal{ font-size:12px; color:#6f7d97; 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; }
}

/* ════ Betting Tip block — refreshed look (predict7) ════ */
.agents.tips .agents-head{ align-items:center; padding-bottom:14px; border-bottom:1px solid var(--line); }
.agents.tips .agents-h2{ display:inline-flex; align-items:center; gap:10px; margin:0; font-size:22px; }
.agents.tips .agents-h2::before{ content:""; width:6px; height:24px; border-radius:3px; background:var(--accent); }
.agents.tips .agents-count{ background:var(--accent-soft); color:var(--accent-d); }
.tip-main{ background:linear-gradient(135deg,#1f6feb 0%,#1657c4 56%,#0e2a66 100%); border:0;
  box-shadow:0 14px 34px rgba(31,111,235,.34); }
.tip-main::before{ display:none; }
.tip-main-badge{ background:#fff; color:var(--accent-d); }
.tip-main-row{ background:rgba(255,255,255,.13); }
.tip-main-l{ color:#dbe7ff; }
.tip-main .pick-conf-bar{ background:rgba(255,255,255,.26); }
.tip-main .pick-conf-fill{ background:#fff; }
.tip-main-cta{ background:#fff; color:var(--accent-d); }
.tip-main:hover .tip-main-cta{ background:var(--ink); color:#fff; }
.tip-sec{ border:1px solid var(--line); border-top:3px solid var(--accent); }
.tip-sec:hover{ border-top-color:var(--accent-d); }
.tip-sec-conf{ color:var(--accent-d); background:var(--accent-soft); }
.tip-sec-val{ font-size:16px; font-weight:800; margin:6px 0; }

/* ════ Match-page block restyle (predict7) ════ */
/* Match Probability Engine — highlighted top tile */
.prob-tiles{ gap:12px; }
.prob-tile{ background:var(--card); border:1.5px solid var(--line-2); border-radius:14px; padding:14px; transition:transform .15s, box-shadow .15s; }
.prob-tile:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(14,21,38,.10); }
.prob-tile.is-top{ border-color:var(--accent); background:linear-gradient(140deg,var(--accent-soft),var(--card) 72%); box-shadow:0 8px 22px rgba(31,111,235,.16); }
/* H2H — rows become cards with a dark score chip */
.h2h{ background:var(--card-2); border:1px solid var(--line-2); border-radius:11px; padding:11px 13px; margin-bottom:8px; border-bottom:1px solid var(--line-2); }
.h2h:last-child{ margin-bottom:0; }
.h2h-score{ background:var(--ink); color:#fff; padding:4px 11px; border-radius:8px; }
/* Key Players — highlighted star cards */
.roster--top .panel-hd h2::before{ content:"★ "; color:var(--accent); }
.roster--top .roster-row{ background:var(--card-2); border:1px solid var(--line-2); border-radius:10px; padding:9px 12px; margin-bottom:7px; }
.roster--top .roster-row:last-child{ margin-bottom:0; }
.roster--top .roster-name{ color:var(--accent-d); }
/* Expected Lineups — framed pitch */
.pitch{ max-width:430px; border:3px solid var(--ink); box-shadow:0 16px 38px rgba(14,21,38,.24); }
