/* a0wt34a 8hgto7 */
/* ════════════════════════════════════════════════════════
   betting-directory — Copa do Mundo 2026 site template
   Consolidated stylesheet (union of the 3 mockups).
   Theme colours come from CSS variables; per-site overrides
   are injected inline in <head> (see partials/head.fvec4tf).
   Anti-footprint post-processor renames classes/vars/ids.
════════════════════════════════════════════════════════ */

:root {
  --lcegyrs: #F7F8FA;
  --gw7bt: #FFFFFF;
  --v3l1ct: #E4E7ED;
  --lbza6: #1A1E2C;
  --almeww4: #6B7280;
  --nwgj6: #1A56DB;
  --scel1g: #E8222A;
  --v70l6pn: #F59E0B;
  --s51l13a: #0F1629;
  --vtvco91: #FFFFFF;
  --i2gplvue: #1E2A45;
  --kx06hjm1: #22C55E;
  --mb27r: #22C55E;
  --tc1seuy: #F59E0B;
  --twkxo: #E8222A;
  --upokpu1: #D1D5DB;
  --qf8cjkyn: 6px;
  --py34ai: 10px;
  --hw714: 16px;
  --vuupif: 0 1px 3px rgba(0, 0, 0, .08);
  --ytb7oqc: 0 4px 16px rgba(0, 0, 0, .10);
  --gb8121: 'Barlow Condensed', sans-serif;
  --elq9wt: 'Inter', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--elq9wt);
  background: var(--lcegyrs);
  color: var(--lbza6);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.a6zwbwxd { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ─── HEADER / NAV ─────────────────────────────────────── */
.site-header { background: var(--i2gplvue); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(0, 0, 0, .25); }
.w676lf { display: flex; align-items: center; height: 62px; gap: 0; }
.mshigq2 { display: flex; align-items: center; gap: 10px; color: #fff; font-family: var(--gb8121); font-size: 1.5rem; font-weight: 800; letter-spacing: .5px; white-space: nowrap; margin-right: 32px; flex-shrink: 0; }
.mshigq2 .d1f8jh8k { background: var(--scel1g); color: #fff; font-size: .65rem; font-weight: 700; letter-spacing: 1px; padding: 2px 6px; border-radius: 4px; text-transform: uppercase; }
.eznr4wu6 { display: flex; align-items: center; gap: 4px; flex: 1; }
.eznr4wu6 a { color: rgba(255, 255, 255, .85); font-size: .9rem; font-weight: 600; padding: 8px 14px; border-radius: var(--qf8cjkyn); transition: background .15s, color .15s; white-space: nowrap; }
.eznr4wu6 a:hover, .eznr4wu6 a.active { background: rgba(255, 255, 255, .12); color: #fff; }
.eznr4wu6 a.yrxqr { background: var(--nwgj6); color: #fff; }
.eznr4wu6 a.yrxqr:hover { filter: brightness(.92); }
.uyupgv { display: flex; align-items: center; gap: 4px; margin-left: auto; flex-shrink: 0; }
.uyupgv a { color: rgba(255, 255, 255, .75); font-size: .82rem; font-weight: 500; padding: 6px 12px; border-radius: var(--qf8cjkyn); transition: background .15s, color .15s; white-space: nowrap; }
.uyupgv a:hover { background: rgba(255, 255, 255, .1); color: #fff; }
.favuv8r { background: var(--scel1g) !important; color: #fff !important; font-weight: 700 !important; padding: 7px 20px !important; }
.favuv8r:hover { filter: brightness(1.1); }
.burger { display: none; flex-direction: column; justify-content: center; align-items: center; width: 40px; height: 40px; cursor: pointer; gap: 5px; border: none; background: transparent; padding: 0; margin-left: auto; }
.burger span { display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px; transition: transform .25s, opacity .25s; }
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-drawer { display: none; flex-direction: column; background: var(--s51l13a); padding: 12px 20px 20px; gap: 2px; }
/* full-screen overlay (like escort): fills the whole viewport below the sticky header.
   JS sets `top` to the exact header height so it works across all header variants. */
.nav-drawer.open { display: flex; position: fixed; left: 0; right: 0; bottom: 0; top: 62px; z-index: 99; overflow-y: auto; -webkit-overflow-scrolling: touch; }
body.nav-open { overflow: hidden; }
.nav-drawer a { color: rgba(255, 255, 255, .85); font-size: 1.05rem; font-weight: 500; padding: 14px 12px; border-radius: var(--qf8cjkyn); border-bottom: 1px solid rgba(255, 255, 255, .06); }
.nav-drawer a:hover { background: rgba(255, 255, 255, .08); color: #fff; }
/* header section-variant modifiers */
.uwjcqr { background: var(--s51l13a); }
.wsykuy { box-shadow: none; border-bottom: 3px solid var(--nwgj6); }
.bhsgdwqy .eznr4wu6 a { background: rgba(255, 255, 255, .08); }
.blcg1yu6 .w676lf { height: 54px; }
.blcg1yu6 .mshigq2 { font-size: 1.3rem; }
.qts44p { font-size: .7rem; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: rgba(255, 255, 255, .35); padding: 12px 12px 4px; }

/* ─── ODDS STRIP ───────────────────────────────────────── */
.odds-strip { background: #fff; border-bottom: 1px solid var(--v3l1ct); position: relative; }
.rf7rki { display: flex; overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; scroll-behavior: smooth; padding: 8px 32px; gap: 8px; }
.rf7rki::-webkit-scrollbar { display: none; }
.i3rfpi8 { position: absolute; top: 0; bottom: 0; width: 28px; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 2; border: none; font-size: .9rem; color: #A3A3A3; background: #fff; transition: color .15s; }
.i3rfpi8:hover { color: #404040; }
.i3rfpi8.left { left: 0; border-right: 1px solid var(--v3l1ct); }
.i3rfpi8.right { right: 0; border-left: 1px solid var(--v3l1ct); }
.odds-card { flex-shrink: 0; width: 280px; border: 1px solid var(--v3l1ct); border-radius: 8px; background: #fff; display: flex; flex-direction: column; align-items: center; overflow: hidden; }
.odds-meta { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 5px 8px; gap: 4px; }
.odds-meta-league { font-size: .6rem; color: #A3A3A3; font-weight: 500; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.odds-meta-time { display: flex; align-items: center; gap: 4px; font-size: .6rem; font-weight: 500; color: #404040; white-space: nowrap; flex-shrink: 0; }
.odds-divider { width: 100%; height: 1px; background: var(--v3l1ct); flex-shrink: 0; }
.odds-teams { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 6px 8px; width: 100%; min-height: 48px; }
.odds-team { display: flex; align-items: center; gap: 4px; font-size: .88rem; color: #404040; }
.odds-team.away { flex-direction: row-reverse; }
.efwa4h { font-size: .85rem; line-height: 1; flex-shrink: 0; }
.odds-crest { width: 18px; height: 18px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.odds-row { display: flex; justify-content: center; gap: 6px; padding: 0 6px 6px; width: 100%; }
.odds-btn { display: flex; align-items: center; background: #F5F5F5; padding: 2px 6px; border-radius: 3px; gap: 4px; cursor: pointer; border: none; text-decoration: none; transition: background .12s; }
.odds-btn:hover { background: #E8EAFF; }
.odds-btn-val { font-size: .7rem; font-weight: 500; color: #404040; }
.odds-btn-label { font-size: .65rem; font-weight: 500; color: #A3A3A3; }
.odds-trend { font-size: .55rem; line-height: 1; }
.odds-trend.up { color: #16A34A; }
.odds-trend.x3vhm3jy { color: #DC2626; }
.bwxzzf { width: 0; height: 0; border-left: 3px solid transparent; border-right: 3px solid transparent; flex-shrink: 0; }
.bwxzzf.up { border-bottom: 5px solid #47A167; }
.bwxzzf.x3vhm3jy { border-top: 5px solid #E72535; }
.odds-status { font-size: .7rem; font-weight: 600; color: var(--nwgj6); text-align: center; padding: 4px 8px; width: 100%; display: block; text-decoration: none; transition: background .12s; }
.odds-status:hover { background: #F0F4FF; }
.mv21pvj { font-size: .6rem; color: var(--almeww4); text-align: center; padding: 3px 20px; background: #FAFBFC; border-top: 1px solid var(--v3l1ct); }
/* odds-strip section-variant modifiers (id/JS hooks preserved) */
.co6mb25 .odds-card { width: 240px; }
.cai2t1pt .odds-card { width: 320px; }
.cai2t1pt .odds-btn-val { font-size: .78rem; }
.flu1r8 .odds-card { border-top: 3px solid var(--nwgj6); }
.habvccrp { background: var(--i2gplvue); }
.habvccrp .i3rfpi8 { background: var(--i2gplvue); color: rgba(255, 255, 255, .55); }
.habvccrp .i3rfpi8.left { border-right-color: rgba(255, 255, 255, .12); }
.habvccrp .i3rfpi8.right { border-left-color: rgba(255, 255, 255, .12); }

/* ─── HERO ─────────────────────────────────────────────── */
.hnjof6p { background: linear-gradient(135deg, #0F1629 0%, #1A2545 60%, var(--nwgj6) 100%); color: #fff; padding: 56px 0 52px; position: relative; overflow: hidden; }
.hnjof6p::before { content: '2026'; position: absolute; right: -20px; top: 50%; transform: translateY(-50%); font-family: var(--gb8121); font-size: clamp(120px, 18vw, 220px); font-weight: 800; color: rgba(255, 255, 255, .04); line-height: 1; pointer-events: none; user-select: none; }
.r0r60 { display: inline-flex; align-items: center; gap: 6px; background: rgba(255, 255, 255, .12); border: 1px solid rgba(255, 255, 255, .2); color: rgba(255, 255, 255, .85); font-size: .75rem; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; padding: 5px 12px; border-radius: 20px; margin-bottom: 16px; }
.hnjof6p h1 { font-family: var(--gb8121); font-size: clamp(2.4rem, 6vw, 4.2rem); font-weight: 800; line-height: 1.05; letter-spacing: -.5px; margin-bottom: 16px; max-width: 680px; }
.hnjof6p h1 em { font-style: normal; color: var(--v70l6pn); }
.agxjda { font-size: 1.05rem; color: rgba(255, 255, 255, .75); max-width: 520px; margin-bottom: 28px; line-height: 1.55; }
.oc2s5 { display: flex; flex-wrap: wrap; gap: 12px; }
/* hero section-variant modifiers */
.fa6tzuog .a6zwbwxd { text-align: center; }
.fa6tzuog h1, .fa6tzuog .agxjda { margin-left: auto; margin-right: auto; }
.fa6tzuog .oc2s5 { justify-content: center; }
.ilikc::before { display: none; }
.s7t98d2 .a6zwbwxd { text-align: right; }
.s7t98d2 h1, .s7t98d2 .agxjda { margin-left: auto; }
.s7t98d2 .oc2s5 { justify-content: flex-end; }
.s7t98d2::before { right: auto; left: -20px; }
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 12px 24px; border-radius: var(--qf8cjkyn); font-size: .9rem; font-weight: 600; cursor: pointer; transition: filter .15s, transform .1s; border: none; }
.btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.aytc1 { background: var(--nwgj6); color: #fff; }
.v314urx { background: transparent; color: #fff; border: 1.5px solid rgba(255, 255, 255, .4); }
.v314urx:hover { background: rgba(255, 255, 255, .1); }

/* ─── SECTION ──────────────────────────────────────────── */
.section { padding: 56px 0; }
.bs6qx { padding: 36px 0; }
.wj0mem { background: var(--gw7bt); }
.nznvgolo { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; gap: 12px; flex-wrap: wrap; }
.section-title { font-family: var(--gb8121); font-size: 1.9rem; font-weight: 800; letter-spacing: -.2px; line-height: 1.1; position: relative; padding-left: 14px; }
.section-title::before { content: ''; position: absolute; left: 0; top: 6px; bottom: 6px; width: 4px; background: var(--nwgj6); border-radius: 2px; }
.hto8vlj { font-size: .85rem; font-weight: 600; color: var(--nwgj6); white-space: nowrap; }
.hto8vlj:hover { text-decoration: underline; }

/* ─── STATS STRIP ──────────────────────────────────────── */
.q7ifu7pw { background: var(--gw7bt); border-top: 1px solid var(--v3l1ct); border-bottom: 1px solid var(--v3l1ct); }
.stats-grid { display: flex; align-items: stretch; }
.stats-cell { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px 16px; border-right: 1px solid var(--v3l1ct); text-align: center; transition: background .15s; }
.stats-cell:last-child { border-right: none; }
.stats-cell:hover { background: #F7F9FF; }
.stats-cell-body { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.stats-num { font-family: var(--gb8121); font-size: clamp(2.2rem, 4vw, 3rem); font-weight: 800; color: var(--nwgj6); line-height: 1; letter-spacing: -1px; }
.stats-label { font-size: .65rem; font-weight: 700; color: var(--almeww4); text-transform: uppercase; letter-spacing: 1px; white-space: nowrap; }
/* stats section-variant modifiers (anti-footprint layout uniqueness) */
.n067s11 .stats-cell { flex-direction: row; align-items: baseline; gap: 8px; }
.n067s11 .stats-num { font-size: clamp(1.5rem, 3vw, 2.1rem); }
.kjf1b4 .stats-cell { border-top: 3px solid var(--nwgj6); }
.kjf1b4 .stats-num { color: var(--lbza6); }
.kjf1b4 .stats-label { color: var(--nwgj6); }
.akbmxw5 .stats-grid { flex-wrap: wrap; }
.akbmxw5 .stats-cell { flex: 0 0 50%; }
.akbmxw5 .stats-cell:nth-child(odd) { border-right: 1px solid var(--v3l1ct); }
.akbmxw5 .stats-cell:nth-child(-n+2) { border-bottom: 1px solid var(--v3l1ct); }

/* ─── PROSE / ARTICLE ──────────────────────────────────── */
.xgayn { max-width: 100%; }
/* article section-variant modifiers (H2 .section-title + html preserved) */
.ai6480a { background: var(--lcegyrs); }
.a7ai9s .xgayn { max-width: 760px; margin: 0 auto; }
.a7ai9s .nznvgolo { text-align: center; }
.s05zy2 .section-title { border-left: 4px solid var(--nwgj6); padding-left: 14px; }
.izdio { border-top: 1px solid var(--v3l1ct); }
.xgayn h2 { font-family: var(--gb8121); font-size: 1.7rem; font-weight: 800; margin: 36px 0 12px; line-height: 1.15; }
.xgayn h3 { font-family: var(--gb8121); font-size: 1.25rem; font-weight: 700; margin: 28px 0 10px; line-height: 1.2; }
.xgayn h4 { font-size: 1rem; font-weight: 700; margin: 20px 0 8px; color: var(--lbza6); }
.xgayn p { color: #374151; margin-bottom: 16px; line-height: 1.7; }
.xgayn ul { list-style: none; margin: 0 0 18px 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.xgayn ul li { padding-left: 22px; position: relative; color: #374151; line-height: 1.6; }
.xgayn ul li::before { content: ''; position: absolute; left: 6px; top: 10px; width: 6px; height: 6px; border-radius: 50%; background: var(--nwgj6); }
.xgayn ol { counter-reset: ol-counter; list-style: none; margin: 0 0 18px 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.xgayn ol li { counter-increment: ol-counter; padding-left: 36px; position: relative; color: #374151; line-height: 1.6; }
.xgayn ol li::before { content: counter(ol-counter); position: absolute; left: 0; top: 0; width: 24px; height: 24px; background: var(--nwgj6); color: #fff; font-size: .75rem; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.xgayn strong { font-weight: 700; color: var(--lbza6); }
.xgayn a { color: var(--nwgj6); text-decoration: underline; }

.tkbv47c { margin: 24px 0 28px; }
.uo7u9 { width: 100%; height: 280px; background: #F1F3F7; border: 2px dashed var(--v3l1ct); border-radius: var(--py34ai); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; }
.uo7u9 .my6qrmxe { font-size: 2rem; opacity: .4; }
.uo7u9 .hqt4w { font-size: .8rem; font-weight: 600; color: var(--almeww4); }
.vii0p { width: 100%; height: 280px; object-fit: cover; border-radius: var(--py34ai); display: block; }
.cbdwjk { font-size: .75rem; color: var(--almeww4); margin-top: 8px; font-style: italic; }

/* prose inline table */
.c0qiu { overflow-x: auto; margin: 20px 0 24px; border-radius: var(--py34ai); border: 1px solid var(--v3l1ct); box-shadow: var(--vuupif); }
.fijg33s { width: 100%; border-collapse: collapse; background: var(--gw7bt); font-size: .875rem; }
.fijg33s thead tr { background: #F1F3F7; }
.fijg33s thead th { padding: 10px 16px; text-align: left; font-size: .68rem; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--almeww4); border-bottom: 2px solid var(--v3l1ct); white-space: nowrap; }
.fijg33s tbody tr { border-bottom: 1px solid var(--v3l1ct); transition: background .12s; }
.fijg33s tbody tr:first-child { background: #EFF6FF; }
.fijg33s tbody tr:first-child td { font-weight: 600; }
.fijg33s tbody tr:last-child { border-bottom: none; }
.fijg33s tbody tr:hover { background: #F7F9FF; }
.fijg33s tbody td { padding: 11px 16px; vertical-align: middle; }
.yf06xd1 { display: inline-block; padding: 2px 10px; border-radius: 20px; font-size: .78rem; font-weight: 700; }
.yf06xd1.w2vsy55 { background: var(--nwgj6); color: #fff; }

/* prose CTA blocks */
.nqi5vyli { margin: 28px 0; background: linear-gradient(135deg, #EFF6FF 0%, #E0EAFF 100%); border: 1px solid rgba(26, 86, 219, .18); border-left: 4px solid var(--nwgj6); border-radius: var(--py34ai); padding: 20px 24px; }
.xsmagkr { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.eloedk { display: flex; flex-direction: column; gap: 4px; }
.eloedk strong { font-size: 1rem; font-weight: 700; color: var(--lbza6); }
.eloedk span { font-size: .8rem; color: var(--almeww4); }
.p6q3a { background: var(--nwgj6); color: #fff !important; padding: 11px 24px; border-radius: var(--qf8cjkyn); font-size: .9rem; font-weight: 700; font-family: var(--elq9wt); white-space: nowrap; text-decoration: none !important; display: inline-flex; align-items: center; gap: 6px; transition: filter .15s, transform .1s; flex-shrink: 0; line-height: 1.4; }
.p6q3a:hover { filter: brightness(1.08); transform: translateY(-1px); }
.wbdmf5 { margin: 20px 0 28px; background: var(--i2gplvue); border-radius: var(--py34ai); padding: 22px 28px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; position: relative; overflow: hidden; }
.wbdmf5::after { content: '2026'; position: absolute; right: 180px; top: 50%; transform: translateY(-50%); font-family: var(--gb8121); font-size: 5rem; font-weight: 800; color: rgba(255, 255, 255, .05); line-height: 1; pointer-events: none; letter-spacing: -2px; } /* subtle background year art (button fills the right) */
.e5yiag0 { display: flex; flex-direction: column; gap: 5px; }
.vc1hv88z { font-size: .68rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .6); }
.uv5oun { font-family: var(--gb8121); font-size: 1.3rem; font-weight: 800; color: #fff; line-height: 1.2; }
.z4ntahec { font-size: .75rem; color: rgba(255, 255, 255, .5); }
.hjv0l { background: var(--nwgj6); color: #fff !important; padding: 12px 26px; border-radius: var(--qf8cjkyn); font-size: .9rem; font-weight: 700; font-family: var(--elq9wt); white-space: nowrap; text-decoration: none !important; display: inline-flex; align-items: center; flex-shrink: 0; transition: filter .15s, transform .1s; line-height: 1.4; position: relative; z-index: 1; }
.hjv0l:hover { filter: brightness(1.1); transform: translateY(-1px); }

/* split block */
.mhc4o8 { margin: 32px 0 8px; padding-top: 32px; border-top: 1px solid var(--v3l1ct); }
.zu1j47iq { margin-bottom: 20px !important; }
/* r9: float the image so the text flows AROUND it and fills the space under it (no empty column) */
.wea70sb { display: block; }
.wea70sb::after { content: ''; display: block; clear: both; }
.qz5vav8b { float: left; width: 42%; margin: 4px 32px 14px 0; }
.uueuna1 { width: 100%; }
.jae6f { height: 240px !important; }
.l8pyc { display: block; }
.l8pyc p { margin-bottom: 14px; }
.l8pyc ul { margin-bottom: 0; }

/* ─── FAQ ──────────────────────────────────────────────── */
.jpm5ymy1 { display: flex; flex-direction: column; gap: 12px; max-width: none; } /* r10: full width */
.kmio6h { background: var(--gw7bt); border: 1px solid var(--v3l1ct); border-radius: var(--py34ai); padding: 16px 20px; box-shadow: var(--vuupif); }
.ntiunvvz { font-family: var(--gb8121); font-size: 1.05rem; font-weight: 700; color: var(--lbza6); margin: 0 0 6px; } /* r10: question is an <h3>, reset default margins */
.x6wnb4lt { font-size: .92rem; color: #374151; line-height: 1.6; }
/* faq section-variant modifiers */
.uddgnfej .kmio6h { background: transparent; border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--v3l1ct); padding: 16px 0; }
.vfheuwcm .jpm5ymy1 { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); max-width: none; }
.yf9hhed .kmio6h { border-left: 3px solid var(--nwgj6); }
.olncz1 .kmio6h { padding: 12px 16px; }
.olncz1 .ntiunvvz { font-size: .95rem; margin-bottom: 3px; }

/* ─── HERO-SUB LINK + CONTACT FORM ─────────────────────── */
.choeb5 { color: var(--almeww4); font-size: .82rem; margin-top: 6px; max-width: 760px; }
.gw4y9 { display: flex; flex-direction: column; gap: 14px; max-width: 520px; margin: 8px 0 4px; }
.gw4y9 label { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--lbza6); }
.gw4y9 input, .gw4y9 textarea { font-family: var(--elq9wt); font-size: .95rem; padding: 10px 12px; border: 1px solid var(--v3l1ct); border-radius: var(--qf8cjkyn); background: var(--gw7bt); color: var(--lbza6); }
.gw4y9 input:focus, .gw4y9 textarea:focus { outline: none; border-color: var(--nwgj6); }
.gw4y9 button { align-self: flex-start; }

/* ─── LEGAL / INFO PAGES (sobre, contato, privacidade, cookies) ─── */
.uauvm { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
.a049v7rx { max-width: none; }
.a049v7rx h3 { margin-top: 26px; }
.a049v7rx h3:first-child { margin-top: 0; }
.qu6qy2oc { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 80px; }
.qh8g6v2d { background: var(--gw7bt); border: 1px solid var(--v3l1ct); border-radius: var(--hw714); padding: 22px 24px; box-shadow: var(--vuupif); }
.kqco7fcs { font-family: var(--gb8121); font-size: 1.2rem; font-weight: 800; color: var(--lbza6); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.ns052m { font-size: .82rem; color: var(--almeww4); line-height: 1.55; margin-bottom: 16px; }
.u1lrjk { font-size: .65rem; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--almeww4); margin: 14px 0 8px; }
.jk46wl4n { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.jk46wl4n a { font-size: .9rem; color: var(--nwgj6); font-weight: 600; }
.jk46wl4n a:hover { text-decoration: underline; }
.q95q1v { font-size: .88rem; color: var(--lbza6); word-break: break-all; font-weight: 600; }
.z7eyrv { background: var(--nwgj6); color: #fff; text-align: center; padding: 13px 18px; border-radius: var(--qf8cjkyn); font-weight: 700; font-size: .9rem; transition: filter .15s, transform .1s; }
.z7eyrv:hover { filter: brightness(1.08); transform: translateY(-1px); }
.d1j6gd { font-size: .8rem; color: var(--almeww4); margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--v3l1ct); }
@media (max-width: 860px) { .uauvm { grid-template-columns: 1fr; } .qu6qy2oc { position: static; } }

/* ─── GENERIC TABLE (home preview) ─────────────────────── */
.er92j2 { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: var(--py34ai); border: 1px solid var(--v3l1ct); box-shadow: var(--vuupif); }
table { width: 100%; border-collapse: collapse; background: var(--gw7bt); font-size: .88rem; }
/* tabela-preview section-variant modifiers */
.t29tbs table tbody tr:nth-child(even) { background: #FAFBFC; }
.anpr77 table th, .anpr77 table td { padding: 6px 8px; font-size: .8rem; }
.i7g3fa table thead tr { background: var(--i2gplvue); }
.i7g3fa table thead th { color: rgba(255, 255, 255, .85); }
.tc8la0ip table tbody tr { border-bottom: 1px solid var(--v3l1ct); }
thead tr { background: #F1F3F7; }
thead th { padding: 11px 14px; text-align: left; font-size: .72rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--almeww4); white-space: nowrap; border-bottom: 2px solid var(--v3l1ct); }
thead th:not(:first-child) { text-align: center; }
tbody tr { border-bottom: 1px solid var(--v3l1ct); transition: background .12s; }
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: #F7F9FF; }
tbody td { padding: 11px 14px; vertical-align: middle; white-space: nowrap; }
tbody td:not(:first-child) { text-align: center; }
.team-cell { display: flex; align-items: center; gap: 10px; }
.rueljg1 { width: 26px; height: 18px; border-radius: 3px; background: linear-gradient(90deg, #E4E7ED 25%, #f0f2f5 50%, #E4E7ED 75%); flex-shrink: 0; }
.rank-pos { font-weight: 700; color: var(--almeww4); font-size: .8rem; width: 24px; text-align: center; display: inline-block; }
.rank-pos.qualify { color: var(--nwgj6); }
.pts-badge { display: inline-block; background: var(--nwgj6); color: #fff; font-weight: 700; font-size: .8rem; min-width: 28px; padding: 3px 7px; border-radius: 4px; text-align: center; }
.pts-badge.gray { background: #9CA3AF; }
.form-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin: 0 1px; }
.form-dot.dh3wk9gg { background: var(--mb27r); }
.form-dot.d { background: var(--v70l6pn); }
.form-dot.jx9r62 { background: var(--scel1g); }

/* ─── MATCH CARDS (home + jogos full) ──────────────────── */
.matches-grid { display: flex; flex-direction: column; gap: 10px; }
.match-day-group { display: flex; flex-direction: column; gap: 8px; }
.jogos-hidden { display: none !important; }
.load-more-btn { align-self: center; margin-top: 18px; background: var(--gw7bt); border: 1.5px solid var(--nwgj6); color: var(--nwgj6); font-weight: 700; font-size: .9rem; padding: 12px 30px; border-radius: var(--qf8cjkyn); cursor: pointer; transition: background .15s, transform .1s; font-family: var(--elq9wt); }
.load-more-btn:hover { background: #EFF6FF; transform: translateY(-1px); }
.match-day-label { font-size: .75rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--almeww4); padding: 8px 0 4px; border-top: 1px solid var(--v3l1ct); margin-top: 4px; }
.match-day-label:first-child { border-top: none; margin-top: 0; }
/* jogos-preview section-variant modifiers */
.oq2lw .matches-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 12px; }
.oq2lw .match-day-label { grid-column: 1 / -1; }
.wrl5n .match-card { padding: 10px 16px; }
.wrl5n .score-nums { font-size: 1.4rem; }
.o8w7ty2 .match-card { border-left: 3px solid var(--nwgj6); }
.m8sw8 .match-card { background: transparent; border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--v3l1ct); }
.match-day-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 0 6px; border-top: 1px solid var(--v3l1ct); margin-top: 8px; }
.match-day-header:first-child { border-top: none; margin-top: 0; }
.match-day-date { font-size: .78rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--lbza6); }
.match-day-phase { font-size: .72rem; font-weight: 600; color: var(--almeww4); }
.match-card { background: var(--gw7bt); border: 1px solid var(--v3l1ct); border-radius: var(--py34ai); padding: 16px 24px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 16px; transition: box-shadow .15s, border-color .15s; }
.match-card:hover { border-color: var(--nwgj6); box-shadow: 0 0 0 3px rgba(26, 86, 219, .08); }
.match-card.finished:hover { border-color: var(--v3l1ct); box-shadow: none; }
.match-team { display: flex; align-items: center; gap: 12px; font-weight: 600; font-size: .95rem; }
.match-team.away { justify-content: flex-end; flex-direction: row; }
.match-team.away .team-flag-circle { order: 2; }
.match-team.away .team-name { order: 1; }
.team-flag-circle { width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--v3l1ct); background: linear-gradient(135deg, #E4E7ED 0%, #F7F8FA 100%); flex-shrink: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; line-height: 1; }
.team-flag-circle img { width: 100%; height: 100%; object-fit: cover; }
.match-center { text-align: center; min-width: 130px; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.match-score { text-align: center; min-width: 80px; }
.score-nums { font-family: var(--gb8121); font-size: 1.8rem; font-weight: 800; letter-spacing: 4px; line-height: 1; color: var(--lbza6); }
.score-nums.upcoming { color: var(--almeww4); letter-spacing: 2px; font-size: 1.3rem; }
.nnt6my1c { color: var(--v3l1ct); }
.score-time { font-size: .72rem; color: var(--almeww4); font-weight: 500; }
.score-status { display: inline-block; font-size: .65rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; padding: 2px 8px; border-radius: 3px; }
.score-status.live { background: #FEE2E2; color: var(--scel1g); }
.score-status.finished { background: #F1F3F7; color: var(--almeww4); }
.score-status.upcoming { background: #EFF6FF; color: var(--nwgj6); }
.match-venue { font-size: .7rem; color: var(--nwgj6); font-weight: 500; margin-top: 3px; }
.fsg6h { font-size: .66rem; color: var(--almeww4); }

/* ─── BANNER STRIP ─────────────────────────────────────── */
.ovds1ci5 { background: #F1F3F7; border-top: 1px solid var(--v3l1ct); border-bottom: 1px solid var(--v3l1ct); }
.n0jt1 { display: block; }
.kv2rlcgv { width: 100%; height: 90px; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; border: 2px dashed var(--v3l1ct); cursor: pointer; transition: background .15s, border-color .15s; position: relative; overflow: hidden; }
.kv2rlcgv:hover { background: #E8EBF0; border-color: var(--nwgj6); }
.kn8fm2 { display: flex; align-items: center; gap: 10px; }
.my6qrmxe { font-size: 1.4rem; opacity: .4; }
.hqt4w { font-size: .75rem; font-weight: 600; color: var(--almeww4); letter-spacing: .3px; }
.vku9i3b { width: 100%; height: 90px; object-fit: cover; display: block; }
.g1i5l9 { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.ilqennt { display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px; border-radius: var(--qf8cjkyn); font-size: .85rem; font-weight: 700; white-space: nowrap; transition: filter .15s, transform .1s; text-decoration: none; }
.ilqennt:hover { filter: brightness(1.08); transform: translateY(-1px); }
.knsje9 { background: var(--nwgj6); color: #fff; }
.xcgwh1 { background: transparent; color: var(--nwgj6); border: 1.5px solid var(--nwgj6); }
.xcgwh1:hover { background: #EFF6FF; }
/* banner section-variant modifiers */
.cvitn .kv2rlcgv { justify-content: center; }
.cvitn .kn8fm2 { gap: 16px; }
.lbiboo02 .kv2rlcgv { border-style: solid; }

/* ─── PAGE HEADER + PHASE TABS (tabela/jogos) ──────────── */
.gvdhm { background: var(--gw7bt); border-bottom: 1px solid var(--v3l1ct); padding: 20px 0 0; }
.k41xzh { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 16px; flex-wrap: wrap; gap: 8px; }
.jzxjn { font-family: var(--gb8121); font-size: 1.8rem; font-weight: 800; letter-spacing: -.2px; }
.r2zs2fg { font-size: .8rem; color: var(--almeww4); margin-top: 2px; }
.no40quv { display: inline-block; font-size: .72rem; font-weight: 600; color: var(--nwgj6); background: #EFF6FF; border: 1px solid rgba(26,86,219,.18); padding: 3px 10px; border-radius: 20px; margin-top: 8px; }
.t0ma8w { background: var(--gw7bt); border-bottom: 1px solid var(--v3l1ct); }
.ks26e0ht { display: flex; gap: 0; border-bottom: 2px solid var(--v3l1ct); }
.phase-tab { padding: 10px 18px; font-size: .82rem; font-weight: 600; color: var(--almeww4); border-bottom: 2px solid transparent; margin-bottom: -2px; cursor: pointer; white-space: nowrap; transition: color .15s, border-color .15s; }
.phase-tab:hover { color: var(--nwgj6); }
.phase-tab.active { color: var(--nwgj6); border-bottom-color: var(--nwgj6); }

/* ─── GROUP NAV PILLS (tabela) ─────────────────────────── */
.group-nav-wrap { background: var(--gw7bt); border-bottom: 1px solid var(--v3l1ct); position: sticky; top: 62px; z-index: 90; }
.x49ayqv2 { display: flex; align-items: center; gap: 0; overflow-x: auto; scrollbar-width: none; padding: 10px 0; }
.x49ayqv2::-webkit-scrollbar { display: none; }
.group-pill { flex-shrink: 0; padding: 6px 16px; border-radius: 20px; font-size: .8rem; font-weight: 600; cursor: pointer; color: var(--almeww4); background: transparent; border: 1.5px solid transparent; transition: all .15s; white-space: nowrap; }
.group-pill:hover, .group-pill.active { color: var(--nwgj6); border-color: var(--nwgj6); background: #EFF6FF; }

/* ─── TABELA: groups + classification ──────────────────── */
.pm4ul44b { padding: 28px 0 56px; }
.group-block { margin-bottom: 48px; scroll-margin-top: 130px; }
.i01vvmy { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; max-width: 1000px; margin: 0 auto; }
.l3sgx4b { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 12px; }
.l3sgx4b h2 { font-family: var(--gb8121); font-size: 1.4rem; font-weight: 800; letter-spacing: -.1px; }
.btn-completa { font-size: .72rem; font-weight: 700; color: var(--nwgj6); border: 1.5px solid var(--nwgj6); padding: 4px 12px; border-radius: 4px; cursor: pointer; background: transparent; transition: background .12s; white-space: nowrap; }
.btn-completa:hover { background: #EFF6FF; }
.btn-completa.is-expanded { color: var(--scel1g); border-color: var(--scel1g); background: transparent; }
.btn-completa.is-expanded:hover { background: #FEF2F2; }
/* Completa toggle: compact ↔ full-width table (D/GP/GC/SG/%) */
.col-extra { display: none; }
.group-block.expanded .col-extra { display: table-cell; }
.group-block.expanded .i01vvmy { grid-template-columns: 1fr; max-width: 1140px; }
.group-block.expanded .i01vvmy > div:nth-child(2) { display: none; }
.qj0ks9fn { display: none; width: 100%; flex-wrap: wrap; align-items: center; gap: 10px 22px; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--v3l1ct); }
.group-block.expanded .gbha9 { align-items: flex-start; }
.group-block.expanded .qj0ks9fn { display: flex; }
.l8iajh { display: flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--almeww4); }
.iusvx { display: flex; flex-wrap: wrap; gap: 4px 16px; }
.hkzca { font-size: .68rem; color: var(--almeww4); }
.hkzca b { color: var(--lbza6); font-weight: 700; margin-right: 4px; }
table.cls-table { width: 100%; border-collapse: collapse; background: var(--gw7bt); font-size: .82rem; }
table.cls-table thead tr { background: #F1F3F7; }
table.cls-table thead th { padding: 9px 10px; text-align: center; font-size: .65rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: var(--almeww4); border-bottom: 2px solid var(--v3l1ct); white-space: nowrap; }
table.cls-table thead th.ngommo05 { text-align: left; }
table.cls-table thead th.egltctkc { background: #EFF6FF; color: var(--nwgj6); }
table.cls-table tbody tr { border-bottom: 1px solid var(--v3l1ct); transition: background .12s; }
table.cls-table tbody tr:last-child { border-bottom: none; }
table.cls-table tbody tr:hover { background: #F7F9FF; }
table.cls-table tbody td { padding: 9px 10px; text-align: center; vertical-align: middle; }
.qualify-bar { width: 3px; min-height: 38px; position: absolute; left: 0; top: 0; bottom: 0; background: var(--kx06hjm1); }
td.pos-cell { position: relative; width: 36px; padding-left: 14px; text-align: center; }
.pos-num { font-size: .75rem; font-weight: 700; color: var(--almeww4); }
.cls-table .team-cell { display: flex; align-items: center; gap: 8px; text-align: left; }
.team-crest { width: 24px; height: 24px; object-fit: contain; border-radius: 50%; flex-shrink: 0; background: var(--v3l1ct); }
.team-name { font-weight: 600; font-size: .82rem; }
.form-bullets { display: flex; gap: 3px; justify-content: center; }
.bullet { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; display: inline-block; }
.bullet.dh3wk9gg { background: var(--mb27r); }
.bullet.d { background: var(--tc1seuy); }
.bullet.jx9r62 { background: var(--twkxo); }
.bullet.p { background: var(--upokpu1); }
.gbha9 { padding: 8px 12px; display: flex; align-items: center; flex-wrap: wrap; gap: 12px; border-top: 1px solid var(--v3l1ct); background: #FAFBFC; border-radius: 0 0 var(--py34ai) var(--py34ai); }
.l01b86 { display: flex; align-items: center; gap: 6px; font-size: .68rem; color: var(--almeww4); }
.q3xefds { width: 10px; height: 10px; border-radius: 2px; background: var(--kx06hjm1); }
.yyokpi2 { display: flex; align-items: center; gap: 10px; }
.l8iajh { display: flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--almeww4); }

/* tabela match column */
.lewbghw { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.lewbghw h2 { font-family: var(--gb8121); font-size: 1.4rem; font-weight: 800; }
.round-nav { display: flex; align-items: center; gap: 8px; }
.y2o01wv { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--v3l1ct); background: var(--gw7bt); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: .85rem; color: var(--almeww4); transition: border-color .15s, color .15s; }
.y2o01wv:hover { border-color: var(--nwgj6); color: var(--nwgj6); }
.round-label { font-size: .8rem; font-weight: 600; color: var(--lbza6); white-space: nowrap; }
.match-list { display: flex; flex-direction: column; gap: 8px; }
.round-matches { display: flex; flex-direction: column; gap: 8px; }
.match-list .match-card { display: block; padding: 0; overflow: hidden; cursor: pointer; }
.c9f16p { padding: 5px 12px; display: flex; align-items: center; gap: 8px; border-bottom: 1px solid var(--v3l1ct); background: #FAFBFC; }
.ynnmzv7i { font-size: .65rem; font-weight: 700; display: flex; align-items: center; gap: 4px; }
.ynnmzv7i.finished { color: var(--almeww4); }
.ynnmzv7i.live { color: var(--scel1g); }
.ynnmzv7i.upcoming { color: var(--nwgj6); }
.odsc1 { font-size: .65rem; color: var(--almeww4); margin-left: auto; }
.br0pq75 { font-size: .62rem; color: var(--almeww4); }
.a8m79q { padding: 10px 12px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 8px; }
.a8m79q .match-team { font-size: .82rem; gap: 8px; }
.a8m79q .match-team.away { justify-content: flex-end; flex-direction: row-reverse; }
.uz3vv { text-align: center; min-width: 60px; }
.z0p27e { font-family: var(--gb8121); font-size: 1.5rem; font-weight: 800; line-height: 1; letter-spacing: 2px; }
.oyt7b4ki { color: #CBD5E1; }

/* knockout */
.phase-content { display: none; }
.phase-content.active { display: block; }
.mp7mkq { padding: 14px 0 18px; }
.bracket-link { font-size: .82rem; font-weight: 600; color: var(--nwgj6); cursor: pointer; display: inline-flex; align-items: center; gap: 4px; }
.bracket-link:hover { text-decoration: underline; }
.ko-match-list { display: flex; flex-direction: column; gap: 10px; max-width: 820px; margin: 0 auto; }
.ko-match { display: grid; grid-template-columns: 200px 1fr; align-items: center; background: var(--gw7bt); border: 1px solid var(--v3l1ct); border-radius: var(--py34ai); overflow: hidden; transition: border-color .15s; }
.ko-match:hover { border-color: var(--nwgj6); }
.ko-match.is-final { border-color: var(--v70l6pn); box-shadow: 0 0 0 2px rgba(245, 158, 11, .15); }
.ko-datetime { padding: 16px 20px; border-right: 1px solid var(--v3l1ct); background: #FAFBFC; }
.ko-datetime.is-final { background: #FFFBEB; }
.ko-date { font-size: .78rem; font-weight: 600; color: var(--lbza6); line-height: 1.3; }
.ko-date.s7s3zp7 { color: var(--v70l6pn); font-size: .85rem; font-weight: 800; }
.ko-time { font-size: .72rem; color: var(--almeww4); margin-top: 2px; }
.ko-broadcast { font-size: .65rem; color: var(--nwgj6); margin-top: 4px; font-weight: 500; }
.ko-teams { padding: 16px 24px; display: flex; align-items: center; justify-content: center; gap: 16px; font-size: .9rem; color: var(--lbza6); }
.ko-team { display: flex; align-items: center; gap: 8px; font-weight: 500; }
.ko-team-crest { width: 28px; height: 28px; border-radius: 50%; object-fit: contain; flex-shrink: 0; }
.ko-team-ph { width: 28px; height: 28px; border-radius: 50%; background: #2D3748; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ko-team-ph svg { width: 16px; height: 16px; fill: #718096; }
.ko-sep { font-size: .85rem; color: var(--almeww4); font-weight: 400; flex-shrink: 0; }
.ko-sep.ko-score { font-family: var(--gb8121); font-size: 1.15rem; font-weight: 800; color: var(--lbza6); letter-spacing: 1px; min-width: 56px; text-align: center; }

/* ─── Chaveamento (knockout bracket) drawer + tree ─── */
.bk-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 200; display: none; }
.bk-overlay.open { display: block; }
body.bk-lock { overflow: hidden; }
.bk-panel { position: absolute; top: 0; right: 0; bottom: 0; width: min(1000px, 100%); background: var(--gw7bt); display: flex; flex-direction: column; box-shadow: -8px 0 30px rgba(0,0,0,.3); }
.bk-head { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border-bottom: 1px solid var(--v3l1ct); flex-shrink: 0; }
.bk-close { font-size: 1.7rem; line-height: 1; background: none; border: none; cursor: pointer; color: var(--almeww4); padding: 0 4px; }
.bk-close:hover { color: var(--lbza6); }
.bk-title { font-family: var(--gb8121); font-size: 1.4rem; font-weight: 800; }
.bk-scroll { flex: 1; overflow: auto; padding: 24px; -webkit-overflow-scrolling: touch; }
/* DESKTOP: equal-height columns; each game in an equal flex slot so pair midpoints line up,
   then proper bracket connectors (vertical join per pair + horizontal stub into the next round). */
.bk-tree { --nmxqpqg: 38px; --nsmln: #9aa6b8; display: flex; align-items: stretch; min-width: max-content; gap: var(--nmxqpqg); }
.bk-col { display: flex; flex-direction: column; min-width: 168px; }
.bk-roundhead { display: none; }
.bk-games { flex: 1; display: flex; flex-direction: column; }
.bk-game { flex: 1 1 0; min-height: 72px; display: flex; flex-direction: column; justify-content: center; position: relative; }
.bk-card { background: var(--gw7bt); border: 1px solid var(--v3l1ct); border-radius: 6px; box-shadow: var(--vuupif); }
.bk-game.is-final .bk-card { border-color: var(--v70l6pn); }
/* vertical pair-join sits in the right half of the gap; top game draws center→bottom-edge, bottom game top-edge→center */
.bk-col:not(:last-child) .bk-games .bk-game::after { content: ''; position: absolute; right: calc(var(--nmxqpqg) / -2); width: calc(var(--nmxqpqg) / 2); border-right: 2.5px solid var(--nsmln); }
.bk-col:not(:last-child) .bk-games .bk-game:nth-of-type(odd)::after { top: 50%; bottom: 0; border-top: 2.5px solid var(--nsmln); }
.bk-col:not(:last-child) .bk-games .bk-game:nth-of-type(even)::after { top: 0; bottom: 50%; border-bottom: 2.5px solid var(--nsmln); }
/* horizontal line from the pair-join into the next round's game (left half of the gap) */
.bk-col:not(:first-child) .bk-games .bk-game::before { content: ''; position: absolute; left: calc(var(--nmxqpqg) / -2); width: calc(var(--nmxqpqg) / 2); top: 50%; height: 2.5px; background: var(--nsmln); }
.bk-slot { display: flex; align-items: center; gap: 7px; padding: 4px 9px; font-size: .8rem; line-height: 1.2; }
.bk-slot.is-team { font-weight: 600; }
.bk-slot + .bk-slot { border-top: 1px solid var(--v3l1ct); }
.bk-slot img { width: 18px; height: 18px; object-fit: contain; flex-shrink: 0; }
.bk-ph { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.bk-ph svg { width: 14px; height: 14px; fill: #94a3b8; }
.bk-name { flex: 1; min-width: 0; word-break: break-word; } /* wrap long slot labels instead of clipping */
.bk-sc { font-family: var(--gb8121); font-weight: 800; color: var(--lbza6); margin-left: 4px; }
.bk-empty { padding: 50px; text-align: center; color: var(--almeww4); width: 100%; }

/* MOBILE: no horizontal tree — stack rounds vertically (sticky round header + cards), no connectors */
@media (max-width: 768px) {
  .bk-panel { width: 100%; }
  .bk-scroll { padding: 12px 14px; }
  .bk-tree { flex-direction: column; min-width: 0; gap: 0; }
  .bk-col { min-width: 0; width: 100%; }
  .bk-roundhead { display: block; position: sticky; top: 0; background: var(--gw7bt); font-family: var(--gb8121); font-weight: 800; font-size: 1.05rem; padding: 10px 2px 6px; border-bottom: 2px solid var(--nwgj6); margin: 16px 0 8px; z-index: 1; }
  .bk-col:first-child .bk-roundhead { margin-top: 0; }
  .bk-games { display: block; }
  .bk-game { display: block; }
  .bk-card { margin: 6px 0; }
  .bk-game::before, .bk-game::after { display: none !important; }
}
.ko-team-label { font-size: .85rem; }

/* ad strip + tabela CTA */
.o3soi8l5 { background: #F1F3F7; border-top: 1px solid var(--v3l1ct); border-bottom: 1px solid var(--v3l1ct); margin: 32px 0; }
.mel9tj4 { height: 90px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.mel9tj4 span { font-size: .72rem; color: var(--almeww4); font-weight: 500; }
.i3caq { background: var(--s51l13a); border-radius: var(--hw714); padding: 28px 32px; display: flex; align-items: center; justify-content: space-between; gap: 24px; margin: 28px 0; position: relative; overflow: hidden; flex-wrap: wrap; }
.i3caq::before { content: '2026'; position: absolute; right: 190px; top: 50%; transform: translateY(-50%); font-family: var(--gb8121); font-size: 5rem; font-weight: 800; color: rgba(255, 255, 255, .05); line-height: 1; pointer-events: none; letter-spacing: -2px; } /* subtle background year art (button fills the right) */
/* r13: text block grows, button stays RIGHT on the same line in every variant */
.mjsb4r4c { display: flex; flex-direction: column; gap: 4px; position: relative; z-index: 1; flex: 1 1 auto; min-width: 0; order: 0; }
.ln0kw { font-size: .65rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .5); }
.pomid1 { font-family: var(--gb8121); font-size: 1.25rem; font-weight: 800; color: #fff; line-height: 1.2; }
.lorl8r { font-size: .75rem; color: rgba(255, 255, 255, .45); }
.puzqfvad { background: var(--nwgj6); color: #fff; padding: 11px 24px; border-radius: var(--qf8cjkyn); font-size: .88rem; font-weight: 700; white-space: nowrap; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; transition: filter .15s, transform .1s; position: relative; z-index: 1; flex-shrink: 0; font-family: var(--elq9wt); order: 1; }
.puzqfvad:hover { filter: brightness(1.12); transform: translateY(-1px); }
/* tabela-cta section-variant modifiers — button stays RIGHT on one line in ALL of them (r13);
   variants differ by accent/decoration, NOT by stacking the button below the text. */
.mm1loqa { border-left: 4px solid var(--nwgj6); }
.s8z2f2 { border-top: 3px solid var(--nwgj6); }
.uzowfjlc::before { display: none; }

/* ─── FOOTER ───────────────────────────────────────────── */
.czs8rk88 { background: var(--i2gplvue); color: rgba(255, 255, 255, .65); padding: 40px 0 28px; }
.p54hq { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; margin-bottom: 36px; }
.ahslix9 { font-family: var(--gb8121); font-size: 1.3rem; font-weight: 800; color: #fff; margin-bottom: 10px; }
.nlc3dl { font-size: .85rem; line-height: 1.6; max-width: 280px; }
.p4ngo0 { font-size: .72rem; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: rgba(255, 255, 255, .4); margin-bottom: 14px; }
.fwhypf43 { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.fwhypf43 a { font-size: .85rem; color: rgba(255, 255, 255, .6); transition: color .15s; }
.fwhypf43 a:hover { color: #fff; }
.h9m0wp7y { border-top: 1px solid rgba(255, 255, 255, .08); padding-top: 20px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px; font-size: .8rem; color: rgba(255, 255, 255, .35); }
/* footer section-variant modifiers */
.ia9aiq .p54hq { grid-template-columns: 1fr 1fr 1fr; }
.sn8n05 .p54hq { grid-template-columns: 1fr 1fr 2fr; }
.q5ax2 .p54hq { grid-template-columns: 1fr; text-align: center; justify-items: center; }
.q5ax2 .fwhypf43 { align-items: center; }
.q5ax2 .nlc3dl { max-width: 100%; }
.q5ax2 .h9m0wp7y { justify-content: center; }
.b1tc1dx .fwhypf43 { flex-direction: row; flex-wrap: wrap; gap: 16px; }

/* ─── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 900px) {
  .i01vvmy { grid-template-columns: 1fr; }
  .lewbghw, .l3sgx4b { flex-wrap: wrap; }
}
@media (max-width: 768px) {
  .eznr4wu6 { display: none; }
  .uyupgv { display: none; }
  .burger { display: flex; }
  .hnjof6p { padding: 36px 0 32px; }
  .hnjof6p::before { display: none; }
  .section { padding: 36px 0; }
  .bs6qx { padding: 24px 0; }
  .stats-grid { flex-wrap: wrap; }
  .stats-cell { flex: 0 0 50%; border-right: none; border-bottom: 1px solid var(--v3l1ct); }
  .stats-cell:nth-child(odd) { border-right: 1px solid var(--v3l1ct); }
  .match-card { grid-template-columns: 1fr auto 1fr; gap: 8px; padding: 12px 14px; }
  .team-flag-circle { width: 32px; height: 32px; font-size: 1rem; }
  .match-team { font-size: .82rem; gap: 8px; }
  .score-nums { font-size: 1.4rem; letter-spacing: 2px; }
  .match-center { min-width: 90px; }
  .p54hq { grid-template-columns: 1fr; gap: 24px; }
  .nlc3dl { max-width: 100%; }
  .qz5vav8b { float: none; width: 100%; margin: 0 0 16px; }
  .jae6f { height: 180px !important; }
  thead th:nth-child(n+4):not(:last-child) { display: none; }
  tbody td:nth-child(n+4):not(:last-child) { display: none; }
  .kv2rlcgv, .vku9i3b { height: 60px; }
  .uo7u9, .vii0p { height: 180px; }
}
@media (max-width: 640px) {
  .ko-match { grid-template-columns: 1fr; }
  .ko-datetime { border-right: none; border-bottom: 1px solid var(--v3l1ct); }
  .ko-teams { justify-content: flex-start; }
  .i3caq { padding: 20px; }
  .i3caq::before { display: none; }
  .puzqfvad { width: 100%; justify-content: center; }
}
@media (max-width: 600px) {
  .g1i5l9 { display: none; }
  .kv2rlcgv { justify-content: center; }
  .xsmagkr { flex-direction: column; align-items: flex-start; }
  .p6q3a { width: 100%; justify-content: center; }
  .wbdmf5 { padding: 18px 20px; }
  .wbdmf5::after { display: none; }
  .hjv0l { width: 100%; justify-content: center; }
}
@media (max-width: 480px) {
  .oc2s5 { flex-direction: column; }
  .btn { justify-content: center; }
  .phase-tab { padding: 8px 12px; font-size: .75rem; }
}
