/* q12yaz7y 1bz23ov */
/* ════════════════════════════════════════════════════════
   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.lnbuy).
   Anti-footprint post-processor renames classes/vars/ids.
════════════════════════════════════════════════════════ */

:root {
  --tims1m: #F7F8FA;
  --zmks2u: #FFFFFF;
  --g1k9az9: #E4E7ED;
  --z5yhosp: #1A1E2C;
  --j2d2i6kd: #6B7280;
  --sou7nn: #1A56DB;
  --fjndhb4: #E8222A;
  --tmjilo98: #F59E0B;
  --h3dreple: #0F1629;
  --k404yory: #FFFFFF;
  --gzps8: #1E2A45;
  --lbmqvwsu: #22C55E;
  --pcycwq: #22C55E;
  --ss1hu0c: #F59E0B;
  --peobjwb7: #E8222A;
  --vim5e7: #D1D5DB;
  --o1ppypy: 6px;
  --aclyzcf: 10px;
  --s3bxgm: 16px;
  --iksqac: 0 1px 3px rgba(0, 0, 0, .08);
  --lfdjk: 0 4px 16px rgba(0, 0, 0, .10);
  --eynfo8gx: 'Barlow Condensed', sans-serif;
  --tyjt6dpn: 'Inter', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--tyjt6dpn);
  background: var(--tims1m);
  color: var(--z5yhosp);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.sjvbv { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ─── HEADER / NAV ─────────────────────────────────────── */
.site-header { background: var(--gzps8); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(0, 0, 0, .25); }
.mws5a14y { display: flex; align-items: center; height: 62px; gap: 0; }
.wf22xz6c { display: flex; align-items: center; gap: 10px; color: #fff; font-family: var(--eynfo8gx); font-size: 1.5rem; font-weight: 800; letter-spacing: .5px; white-space: nowrap; margin-right: 32px; flex-shrink: 0; }
.wf22xz6c .zjljs { background: var(--fjndhb4); color: #fff; font-size: .65rem; font-weight: 700; letter-spacing: 1px; padding: 2px 6px; border-radius: 4px; text-transform: uppercase; }
.jjrqx { display: flex; align-items: center; gap: 4px; flex: 1; }
.jjrqx a { color: rgba(255, 255, 255, .85); font-size: .9rem; font-weight: 600; padding: 8px 14px; border-radius: var(--o1ppypy); transition: background .15s, color .15s; white-space: nowrap; }
.jjrqx a:hover, .jjrqx a.active { background: rgba(255, 255, 255, .12); color: #fff; }
.jjrqx a.hu63m { background: var(--sou7nn); color: #fff; }
.jjrqx a.hu63m:hover { filter: brightness(.92); }
.wciy39a { display: flex; align-items: center; gap: 4px; margin-left: auto; flex-shrink: 0; }
.wciy39a a { color: rgba(255, 255, 255, .75); font-size: .82rem; font-weight: 500; padding: 6px 12px; border-radius: var(--o1ppypy); transition: background .15s, color .15s; white-space: nowrap; }
.wciy39a a:hover { background: rgba(255, 255, 255, .1); color: #fff; }
.x2k9u3 { background: var(--fjndhb4) !important; color: #fff !important; font-weight: 700 !important; padding: 7px 20px !important; }
.x2k9u3: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(--h3dreple); 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(--o1ppypy); 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 */
.hlsf93k { background: var(--h3dreple); }
.xuiyu { box-shadow: none; border-bottom: 3px solid var(--sou7nn); }
.toytxq0 .jjrqx a { background: rgba(255, 255, 255, .08); }
.msarz0 .mws5a14y { height: 54px; }
.msarz0 .wf22xz6c { font-size: 1.3rem; }
.lh786sv { 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(--g1k9az9); position: relative; }
.u5gw9 { display: flex; overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; scroll-behavior: smooth; padding: 8px 32px; gap: 8px; }
.u5gw9::-webkit-scrollbar { display: none; }
.oz5dmj5t { 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; }
.oz5dmj5t:hover { color: #404040; }
.oz5dmj5t.left { left: 0; border-right: 1px solid var(--g1k9az9); }
.oz5dmj5t.right { right: 0; border-left: 1px solid var(--g1k9az9); }
.odds-card { flex-shrink: 0; width: 280px; border: 1px solid var(--g1k9az9); 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(--g1k9az9); 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; }
.ldbchuce { 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.down { color: #DC2626; }
.yu5gc { width: 0; height: 0; border-left: 3px solid transparent; border-right: 3px solid transparent; flex-shrink: 0; }
.yu5gc.up { border-bottom: 5px solid #47A167; }
.yu5gc.down { border-top: 5px solid #E72535; }
.odds-status { font-size: .7rem; font-weight: 600; color: var(--sou7nn); text-align: center; padding: 4px 8px; width: 100%; display: block; text-decoration: none; transition: background .12s; }
.odds-status:hover { background: #F0F4FF; }
.rc79mg5 { font-size: .6rem; color: var(--j2d2i6kd); text-align: center; padding: 3px 20px; background: #FAFBFC; border-top: 1px solid var(--g1k9az9); }
/* odds-strip section-variant modifiers (id/JS hooks preserved) */
.htqao .odds-card { width: 240px; }
.ootw2gy .odds-card { width: 320px; }
.ootw2gy .odds-btn-val { font-size: .78rem; }
.yfasl8a .odds-card { border-top: 3px solid var(--sou7nn); }
.i3re3ww6 { background: var(--gzps8); }
.i3re3ww6 .oz5dmj5t { background: var(--gzps8); color: rgba(255, 255, 255, .55); }
.i3re3ww6 .oz5dmj5t.left { border-right-color: rgba(255, 255, 255, .12); }
.i3re3ww6 .oz5dmj5t.right { border-left-color: rgba(255, 255, 255, .12); }

/* ─── HERO ─────────────────────────────────────────────── */
.zz0bf { background: linear-gradient(135deg, #0F1629 0%, #1A2545 60%, var(--sou7nn) 100%); color: #fff; padding: 56px 0 52px; position: relative; overflow: hidden; }
.zz0bf::before { content: '2026'; position: absolute; right: -20px; top: 50%; transform: translateY(-50%); font-family: var(--eynfo8gx); font-size: clamp(120px, 18vw, 220px); font-weight: 800; color: rgba(255, 255, 255, .04); line-height: 1; pointer-events: none; user-select: none; }
.qgugjc { 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; }
.zz0bf h1 { font-family: var(--eynfo8gx); font-size: clamp(2.4rem, 6vw, 4.2rem); font-weight: 800; line-height: 1.05; letter-spacing: -.5px; margin-bottom: 16px; max-width: 680px; }
.zz0bf h1 em { font-style: normal; color: var(--tmjilo98); }
.ddh7b { font-size: 1.05rem; color: rgba(255, 255, 255, .75); max-width: 520px; margin-bottom: 28px; line-height: 1.55; }
.rc6f2sp5 { display: flex; flex-wrap: wrap; gap: 12px; }
/* hero section-variant modifiers */
.rbqum .sjvbv { text-align: center; }
.rbqum h1, .rbqum .ddh7b { margin-left: auto; margin-right: auto; }
.rbqum .rc6f2sp5 { justify-content: center; }
.rfvatv::before { display: none; }
.fa61ub .sjvbv { text-align: right; }
.fa61ub h1, .fa61ub .ddh7b { margin-left: auto; }
.fa61ub .rc6f2sp5 { justify-content: flex-end; }
.fa61ub::before { right: auto; left: -20px; }
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 12px 24px; border-radius: var(--o1ppypy); font-size: .9rem; font-weight: 600; cursor: pointer; transition: filter .15s, transform .1s; border: none; }
.btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.ufdr2csr { background: var(--sou7nn); color: #fff; }
.v2b05 { background: transparent; color: #fff; border: 1.5px solid rgba(255, 255, 255, .4); }
.v2b05:hover { background: rgba(255, 255, 255, .1); }

/* ─── SECTION ──────────────────────────────────────────── */
.section { padding: 56px 0; }
.wtan2mdt { padding: 36px 0; }
.hcf4l { background: var(--zmks2u); }
.hd5s68 { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; gap: 12px; flex-wrap: wrap; }
.section-title { font-family: var(--eynfo8gx); 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(--sou7nn); border-radius: 2px; }
.pcerxh8 { font-size: .85rem; font-weight: 600; color: var(--sou7nn); white-space: nowrap; }
.pcerxh8:hover { text-decoration: underline; }

/* ─── STATS STRIP ──────────────────────────────────────── */
.v7q4qfoe { background: var(--zmks2u); border-top: 1px solid var(--g1k9az9); border-bottom: 1px solid var(--g1k9az9); }
.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(--g1k9az9); 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(--eynfo8gx); font-size: clamp(2.2rem, 4vw, 3rem); font-weight: 800; color: var(--sou7nn); line-height: 1; letter-spacing: -1px; }
.stats-label { font-size: .65rem; font-weight: 700; color: var(--j2d2i6kd); text-transform: uppercase; letter-spacing: 1px; white-space: nowrap; }
/* stats section-variant modifiers (anti-footprint layout uniqueness) */
.xwdz6 .stats-cell { flex-direction: row; align-items: baseline; gap: 8px; }
.xwdz6 .stats-num { font-size: clamp(1.5rem, 3vw, 2.1rem); }
.henzd .stats-cell { border-top: 3px solid var(--sou7nn); }
.henzd .stats-num { color: var(--z5yhosp); }
.henzd .stats-label { color: var(--sou7nn); }
.otd7ijb .stats-grid { flex-wrap: wrap; }
.otd7ijb .stats-cell { flex: 0 0 50%; }
.otd7ijb .stats-cell:nth-child(odd) { border-right: 1px solid var(--g1k9az9); }
.otd7ijb .stats-cell:nth-child(-n+2) { border-bottom: 1px solid var(--g1k9az9); }

/* ─── PROSE / ARTICLE ──────────────────────────────────── */
.pwgukg { max-width: 100%; }
/* article section-variant modifiers (H2 .section-title + html preserved) */
.pmbrkak { background: var(--tims1m); }
.zprlywd .pwgukg { max-width: 760px; margin: 0 auto; }
.zprlywd .hd5s68 { text-align: center; }
.h65yg .section-title { border-left: 4px solid var(--sou7nn); padding-left: 14px; }
.n4fah6y6 { border-top: 1px solid var(--g1k9az9); }
.pwgukg h2 { font-family: var(--eynfo8gx); font-size: 1.7rem; font-weight: 800; margin: 36px 0 12px; line-height: 1.15; }
.pwgukg h3 { font-family: var(--eynfo8gx); font-size: 1.25rem; font-weight: 700; margin: 28px 0 10px; line-height: 1.2; }
.pwgukg h4 { font-size: 1rem; font-weight: 700; margin: 20px 0 8px; color: var(--z5yhosp); }
.pwgukg p { color: #374151; margin-bottom: 16px; line-height: 1.7; }
.pwgukg ul { list-style: none; margin: 0 0 18px 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.pwgukg ul li { padding-left: 22px; position: relative; color: #374151; line-height: 1.6; }
.pwgukg ul li::before { content: ''; position: absolute; left: 6px; top: 10px; width: 6px; height: 6px; border-radius: 50%; background: var(--sou7nn); }
.pwgukg ol { counter-reset: ol-counter; list-style: none; margin: 0 0 18px 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.pwgukg ol li { counter-increment: ol-counter; padding-left: 36px; position: relative; color: #374151; line-height: 1.6; }
.pwgukg ol li::before { content: counter(ol-counter); position: absolute; left: 0; top: 0; width: 24px; height: 24px; background: var(--sou7nn); color: #fff; font-size: .75rem; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.pwgukg strong { font-weight: 700; color: var(--z5yhosp); }
.pwgukg a { color: var(--sou7nn); text-decoration: underline; }

.kr6cl3 { margin: 24px 0 28px; }
.lz5njut { width: 100%; height: 280px; background: #F1F3F7; border: 2px dashed var(--g1k9az9); border-radius: var(--aclyzcf); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; }
.lz5njut .n9f67o { font-size: 2rem; opacity: .4; }
.lz5njut .i2rt3ggf { font-size: .8rem; font-weight: 600; color: var(--j2d2i6kd); }
.oqkcavps { width: 100%; height: 280px; object-fit: cover; border-radius: var(--aclyzcf); display: block; }
.g6xblgi9 { font-size: .75rem; color: var(--j2d2i6kd); margin-top: 8px; font-style: italic; }

/* prose inline table */
.z0z1ryry { overflow-x: auto; margin: 20px 0 24px; border-radius: var(--aclyzcf); border: 1px solid var(--g1k9az9); box-shadow: var(--iksqac); }
.ae4y742 { width: 100%; border-collapse: collapse; background: var(--zmks2u); font-size: .875rem; }
.ae4y742 thead tr { background: #F1F3F7; }
.ae4y742 thead th { padding: 10px 16px; text-align: left; font-size: .68rem; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--j2d2i6kd); border-bottom: 2px solid var(--g1k9az9); white-space: nowrap; }
.ae4y742 tbody tr { border-bottom: 1px solid var(--g1k9az9); transition: background .12s; }
.ae4y742 tbody tr:first-child { background: #EFF6FF; }
.ae4y742 tbody tr:first-child td { font-weight: 600; }
.ae4y742 tbody tr:last-child { border-bottom: none; }
.ae4y742 tbody tr:hover { background: #F7F9FF; }
.ae4y742 tbody td { padding: 11px 16px; vertical-align: middle; }
.i2bszcc { display: inline-block; padding: 2px 10px; border-radius: 20px; font-size: .78rem; font-weight: 700; }
.i2bszcc.l8ino0jv { background: var(--sou7nn); color: #fff; }

/* prose CTA blocks */
.w8iqhqna { margin: 28px 0; background: linear-gradient(135deg, #EFF6FF 0%, #E0EAFF 100%); border: 1px solid rgba(26, 86, 219, .18); border-left: 4px solid var(--sou7nn); border-radius: var(--aclyzcf); padding: 20px 24px; }
.ziyxc2 { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.ex067mhn { display: flex; flex-direction: column; gap: 4px; }
.ex067mhn strong { font-size: 1rem; font-weight: 700; color: var(--z5yhosp); }
.ex067mhn span { font-size: .8rem; color: var(--j2d2i6kd); }
.edi0i { background: var(--sou7nn); color: #fff !important; padding: 11px 24px; border-radius: var(--o1ppypy); font-size: .9rem; font-weight: 700; font-family: var(--tyjt6dpn); 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; }
.edi0i:hover { filter: brightness(1.08); transform: translateY(-1px); }
.o5rum { margin: 20px 0 28px; background: var(--gzps8); border-radius: var(--aclyzcf); padding: 22px 28px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; position: relative; overflow: hidden; }
.o5rum::after { content: '2026'; position: absolute; right: 180px; top: 50%; transform: translateY(-50%); font-family: var(--eynfo8gx); 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) */
.mbugy { display: flex; flex-direction: column; gap: 5px; }
.rtn6dt { font-size: .68rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .6); }
.vyhok8 { font-family: var(--eynfo8gx); font-size: 1.3rem; font-weight: 800; color: #fff; line-height: 1.2; }
.eeqih { font-size: .75rem; color: rgba(255, 255, 255, .5); }
.zbg7u { background: var(--sou7nn); color: #fff !important; padding: 12px 26px; border-radius: var(--o1ppypy); font-size: .9rem; font-weight: 700; font-family: var(--tyjt6dpn); 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; }
.zbg7u:hover { filter: brightness(1.1); transform: translateY(-1px); }

/* split block */
.wq2z7ckl { margin: 32px 0 8px; padding-top: 32px; border-top: 1px solid var(--g1k9az9); }
.ydic1825 { margin-bottom: 20px !important; }
/* r9: float the image so the text flows AROUND it and fills the space under it (no empty column) */
.e502nn { display: block; }
.e502nn::after { content: ''; display: block; clear: both; }
.n4onm54y { float: left; width: 42%; margin: 4px 32px 14px 0; }
.eimrgq4 { width: 100%; }
.a7qttwvf { height: 240px !important; }
.e4bz4vim { display: block; }
.e4bz4vim p { margin-bottom: 14px; }
.e4bz4vim ul { margin-bottom: 0; }

/* ─── FAQ ──────────────────────────────────────────────── */
.vzbpe2wk { display: flex; flex-direction: column; gap: 12px; max-width: none; } /* r10: full width */
.bgrnn { background: var(--zmks2u); border: 1px solid var(--g1k9az9); border-radius: var(--aclyzcf); padding: 16px 20px; box-shadow: var(--iksqac); }
.dy449 { font-family: var(--eynfo8gx); font-size: 1.05rem; font-weight: 700; color: var(--z5yhosp); margin: 0 0 6px; } /* r10: question is an <h3>, reset default margins */
.o5v4pf { font-size: .92rem; color: #374151; line-height: 1.6; }
/* faq section-variant modifiers */
.zjr43w11 .bgrnn { background: transparent; border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--g1k9az9); padding: 16px 0; }
.n03xl .vzbpe2wk { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); max-width: none; }
.iuugdc5 .bgrnn { border-left: 3px solid var(--sou7nn); }
.oa6gv34k .bgrnn { padding: 12px 16px; }
.oa6gv34k .dy449 { font-size: .95rem; margin-bottom: 3px; }

/* ─── HERO-SUB LINK + CONTACT FORM ─────────────────────── */
.imfdw0y { color: var(--j2d2i6kd); font-size: .82rem; margin-top: 6px; max-width: 760px; }
.y3hnyrq { display: flex; flex-direction: column; gap: 14px; max-width: 520px; margin: 8px 0 4px; }
.y3hnyrq label { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--z5yhosp); }
.y3hnyrq input, .y3hnyrq textarea { font-family: var(--tyjt6dpn); font-size: .95rem; padding: 10px 12px; border: 1px solid var(--g1k9az9); border-radius: var(--o1ppypy); background: var(--zmks2u); color: var(--z5yhosp); }
.y3hnyrq input:focus, .y3hnyrq textarea:focus { outline: none; border-color: var(--sou7nn); }
.y3hnyrq button { align-self: flex-start; }

/* ─── LEGAL / INFO PAGES (sobre, contato, privacidade, cookies) ─── */
.zbr6d { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
.ybz6tu1 { max-width: none; }
.ybz6tu1 h3 { margin-top: 26px; }
.ybz6tu1 h3:first-child { margin-top: 0; }
.mt22ih { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 80px; }
.ypmh8fhu { background: var(--zmks2u); border: 1px solid var(--g1k9az9); border-radius: var(--s3bxgm); padding: 22px 24px; box-shadow: var(--iksqac); }
.e41jgf4 { font-family: var(--eynfo8gx); font-size: 1.2rem; font-weight: 800; color: var(--z5yhosp); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.yry3be { font-size: .82rem; color: var(--j2d2i6kd); line-height: 1.55; margin-bottom: 16px; }
.kd6r1em0 { font-size: .65rem; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--j2d2i6kd); margin: 14px 0 8px; }
.yleves { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.yleves a { font-size: .9rem; color: var(--sou7nn); font-weight: 600; }
.yleves a:hover { text-decoration: underline; }
.wm6q3o7 { font-size: .88rem; color: var(--z5yhosp); word-break: break-all; font-weight: 600; }
.dac5e { background: var(--sou7nn); color: #fff; text-align: center; padding: 13px 18px; border-radius: var(--o1ppypy); font-weight: 700; font-size: .9rem; transition: filter .15s, transform .1s; }
.dac5e:hover { filter: brightness(1.08); transform: translateY(-1px); }
.lr4wxbhp { font-size: .8rem; color: var(--j2d2i6kd); margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--g1k9az9); }
@media (max-width: 860px) { .zbr6d { grid-template-columns: 1fr; } .mt22ih { position: static; } }

/* ─── GENERIC TABLE (home preview) ─────────────────────── */
.yt1gv0i { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: var(--aclyzcf); border: 1px solid var(--g1k9az9); box-shadow: var(--iksqac); }
table { width: 100%; border-collapse: collapse; background: var(--zmks2u); font-size: .88rem; }
/* tabela-preview section-variant modifiers */
.czcvq table tbody tr:nth-child(even) { background: #FAFBFC; }
.ow55bz table th, .ow55bz table td { padding: 6px 8px; font-size: .8rem; }
.nyjqda table thead tr { background: var(--gzps8); }
.nyjqda table thead th { color: rgba(255, 255, 255, .85); }
.m4ev76 table tbody tr { border-bottom: 1px solid var(--g1k9az9); }
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(--j2d2i6kd); white-space: nowrap; border-bottom: 2px solid var(--g1k9az9); }
thead th:not(:first-child) { text-align: center; }
tbody tr { border-bottom: 1px solid var(--g1k9az9); 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; }
.d1dteno { 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(--j2d2i6kd); font-size: .8rem; width: 24px; text-align: center; display: inline-block; }
.rank-pos.qualify { color: var(--sou7nn); }
.pts-badge { display: inline-block; background: var(--sou7nn); 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.w { background: var(--pcycwq); }
.form-dot.d { background: var(--tmjilo98); }
.form-dot.l { background: var(--fjndhb4); }

/* ─── 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(--zmks2u); border: 1.5px solid var(--sou7nn); color: var(--sou7nn); font-weight: 700; font-size: .9rem; padding: 12px 30px; border-radius: var(--o1ppypy); cursor: pointer; transition: background .15s, transform .1s; font-family: var(--tyjt6dpn); }
.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(--j2d2i6kd); padding: 8px 0 4px; border-top: 1px solid var(--g1k9az9); margin-top: 4px; }
.match-day-label:first-child { border-top: none; margin-top: 0; }
/* jogos-preview section-variant modifiers */
.uu2p4n .matches-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 12px; }
.uu2p4n .match-day-label { grid-column: 1 / -1; }
.av50ogo9 .match-card { padding: 10px 16px; }
.av50ogo9 .score-nums { font-size: 1.4rem; }
.jfehu0aj .match-card { border-left: 3px solid var(--sou7nn); }
.d3ypob .match-card { background: transparent; border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--g1k9az9); }
.match-day-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 0 6px; border-top: 1px solid var(--g1k9az9); 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(--z5yhosp); }
.match-day-phase { font-size: .72rem; font-weight: 600; color: var(--j2d2i6kd); }
.match-card { background: var(--zmks2u); border: 1px solid var(--g1k9az9); border-radius: var(--aclyzcf); 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(--sou7nn); box-shadow: 0 0 0 3px rgba(26, 86, 219, .08); }
.match-card.finished:hover { border-color: var(--g1k9az9); 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(--g1k9az9); 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(--eynfo8gx); font-size: 1.8rem; font-weight: 800; letter-spacing: 4px; line-height: 1; color: var(--z5yhosp); }
.score-nums.upcoming { color: var(--j2d2i6kd); letter-spacing: 2px; font-size: 1.3rem; }
.gb89u2q { color: var(--g1k9az9); }
.score-time { font-size: .72rem; color: var(--j2d2i6kd); 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(--fjndhb4); }
.score-status.finished { background: #F1F3F7; color: var(--j2d2i6kd); }
.score-status.upcoming { background: #EFF6FF; color: var(--sou7nn); }
.match-venue { font-size: .7rem; color: var(--sou7nn); font-weight: 500; margin-top: 3px; }
.fal9rrm { font-size: .66rem; color: var(--j2d2i6kd); }

/* ─── BANNER STRIP ─────────────────────────────────────── */
.br7ziqj { background: #F1F3F7; border-top: 1px solid var(--g1k9az9); border-bottom: 1px solid var(--g1k9az9); }
.rh7etls { display: block; }
.id1dioob { width: 100%; height: 90px; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; border: 2px dashed var(--g1k9az9); cursor: pointer; transition: background .15s, border-color .15s; position: relative; overflow: hidden; }
.id1dioob:hover { background: #E8EBF0; border-color: var(--sou7nn); }
.rpkp9 { display: flex; align-items: center; gap: 10px; }
.n9f67o { font-size: 1.4rem; opacity: .4; }
.i2rt3ggf { font-size: .75rem; font-weight: 600; color: var(--j2d2i6kd); letter-spacing: .3px; }
.lwnf1 { width: 100%; height: 90px; object-fit: cover; display: block; }
.mlnea1 { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.p032c1k { display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px; border-radius: var(--o1ppypy); font-size: .85rem; font-weight: 700; white-space: nowrap; transition: filter .15s, transform .1s; text-decoration: none; }
.p032c1k:hover { filter: brightness(1.08); transform: translateY(-1px); }
.so6r2p0 { background: var(--sou7nn); color: #fff; }
.i6m2q1q { background: transparent; color: var(--sou7nn); border: 1.5px solid var(--sou7nn); }
.i6m2q1q:hover { background: #EFF6FF; }
/* banner section-variant modifiers */
.b1i0ad6 .id1dioob { justify-content: center; }
.b1i0ad6 .rpkp9 { gap: 16px; }
.z5gk2 .id1dioob { border-style: solid; }

/* ─── PAGE HEADER + PHASE TABS (tabela/jogos) ──────────── */
.m1ui28kv { background: var(--zmks2u); border-bottom: 1px solid var(--g1k9az9); padding: 20px 0 0; }
.x1cr2c { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 16px; flex-wrap: wrap; gap: 8px; }
.iqnt7i { font-family: var(--eynfo8gx); font-size: 1.8rem; font-weight: 800; letter-spacing: -.2px; }
.sm0bkdpl { font-size: .8rem; color: var(--j2d2i6kd); margin-top: 2px; }
.hug5ec5o { display: inline-block; font-size: .72rem; font-weight: 600; color: var(--sou7nn); background: #EFF6FF; border: 1px solid rgba(26,86,219,.18); padding: 3px 10px; border-radius: 20px; margin-top: 8px; }
.uzld0szn { background: var(--zmks2u); border-bottom: 1px solid var(--g1k9az9); }
.vthi3r { display: flex; gap: 0; border-bottom: 2px solid var(--g1k9az9); }
.phase-tab { padding: 10px 18px; font-size: .82rem; font-weight: 600; color: var(--j2d2i6kd); border-bottom: 2px solid transparent; margin-bottom: -2px; cursor: pointer; white-space: nowrap; transition: color .15s, border-color .15s; }
.phase-tab:hover { color: var(--sou7nn); }
.phase-tab.active { color: var(--sou7nn); border-bottom-color: var(--sou7nn); }

/* ─── GROUP NAV PILLS (tabela) ─────────────────────────── */
.group-nav-wrap { background: var(--zmks2u); border-bottom: 1px solid var(--g1k9az9); position: sticky; top: 62px; z-index: 90; }
.t21ykkd { display: flex; align-items: center; gap: 0; overflow-x: auto; scrollbar-width: none; padding: 10px 0; }
.t21ykkd::-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(--j2d2i6kd); background: transparent; border: 1.5px solid transparent; transition: all .15s; white-space: nowrap; }
.group-pill:hover, .group-pill.active { color: var(--sou7nn); border-color: var(--sou7nn); background: #EFF6FF; }

/* ─── TABELA: groups + classification ──────────────────── */
.p9o2x2t { padding: 28px 0 56px; }
.group-block { margin-bottom: 48px; scroll-margin-top: 130px; }
.q670dm { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; max-width: 1000px; margin: 0 auto; }
.vrd9hl { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 12px; }
.vrd9hl h2 { font-family: var(--eynfo8gx); font-size: 1.4rem; font-weight: 800; letter-spacing: -.1px; }
.btn-completa { font-size: .72rem; font-weight: 700; color: var(--sou7nn); border: 1.5px solid var(--sou7nn); 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(--fjndhb4); border-color: var(--fjndhb4); 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 .q670dm { grid-template-columns: 1fr; max-width: 1140px; }
.group-block.expanded .q670dm > div:nth-child(2) { display: none; }
.tbs1q1 { display: none; width: 100%; flex-wrap: wrap; align-items: center; gap: 10px 22px; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--g1k9az9); }
.group-block.expanded .sr91l44 { align-items: flex-start; }
.group-block.expanded .tbs1q1 { display: flex; }
.hckqy4 { display: flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--j2d2i6kd); }
.plg7m { display: flex; flex-wrap: wrap; gap: 4px 16px; }
.y7y6tfg { font-size: .68rem; color: var(--j2d2i6kd); }
.y7y6tfg b { color: var(--z5yhosp); font-weight: 700; margin-right: 4px; }
table.cls-table { width: 100%; border-collapse: collapse; background: var(--zmks2u); 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(--j2d2i6kd); border-bottom: 2px solid var(--g1k9az9); white-space: nowrap; }
table.cls-table thead th.mmawm { text-align: left; }
table.cls-table thead th.udwtd { background: #EFF6FF; color: var(--sou7nn); }
table.cls-table tbody tr { border-bottom: 1px solid var(--g1k9az9); 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(--lbmqvwsu); }
td.pos-cell { position: relative; width: 36px; padding-left: 14px; text-align: center; }
.pos-num { font-size: .75rem; font-weight: 700; color: var(--j2d2i6kd); }
.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(--g1k9az9); }
.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.w { background: var(--pcycwq); }
.bullet.d { background: var(--ss1hu0c); }
.bullet.l { background: var(--peobjwb7); }
.bullet.p { background: var(--vim5e7); }
.sr91l44 { padding: 8px 12px; display: flex; align-items: center; flex-wrap: wrap; gap: 12px; border-top: 1px solid var(--g1k9az9); background: #FAFBFC; border-radius: 0 0 var(--aclyzcf) var(--aclyzcf); }
.tj5xsi { display: flex; align-items: center; gap: 6px; font-size: .68rem; color: var(--j2d2i6kd); }
.m94rq21 { width: 10px; height: 10px; border-radius: 2px; background: var(--lbmqvwsu); }
.vjmgsdh { display: flex; align-items: center; gap: 10px; }
.hckqy4 { display: flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--j2d2i6kd); }

/* tabela match column */
.yw1emx2p { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.yw1emx2p h2 { font-family: var(--eynfo8gx); font-size: 1.4rem; font-weight: 800; }
.round-nav { display: flex; align-items: center; gap: 8px; }
.lcnzokbi { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--g1k9az9); background: var(--zmks2u); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: .85rem; color: var(--j2d2i6kd); transition: border-color .15s, color .15s; }
.lcnzokbi:hover { border-color: var(--sou7nn); color: var(--sou7nn); }
.round-label { font-size: .8rem; font-weight: 600; color: var(--z5yhosp); 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; }
.tfky8 { padding: 5px 12px; display: flex; align-items: center; gap: 8px; border-bottom: 1px solid var(--g1k9az9); background: #FAFBFC; }
.brnvefl { font-size: .65rem; font-weight: 700; display: flex; align-items: center; gap: 4px; }
.brnvefl.finished { color: var(--j2d2i6kd); }
.brnvefl.live { color: var(--fjndhb4); }
.brnvefl.upcoming { color: var(--sou7nn); }
.lqzm7 { font-size: .65rem; color: var(--j2d2i6kd); margin-left: auto; }
.y79agn9b { font-size: .62rem; color: var(--j2d2i6kd); }
.p29y01kw { padding: 10px 12px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 8px; }
.p29y01kw .match-team { font-size: .82rem; gap: 8px; }
.p29y01kw .match-team.away { justify-content: flex-end; flex-direction: row-reverse; }
.s0xlq81 { text-align: center; min-width: 60px; }
.i8eof { font-family: var(--eynfo8gx); font-size: 1.5rem; font-weight: 800; line-height: 1; letter-spacing: 2px; }
.y8clop { color: #CBD5E1; }

/* knockout */
.phase-content { display: none; }
.phase-content.active { display: block; }
.qhnl2vmx { padding: 14px 0 18px; }
.bracket-link { font-size: .82rem; font-weight: 600; color: var(--sou7nn); 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(--zmks2u); border: 1px solid var(--g1k9az9); border-radius: var(--aclyzcf); overflow: hidden; transition: border-color .15s; }
.ko-match:hover { border-color: var(--sou7nn); }
.ko-match.is-final { border-color: var(--tmjilo98); box-shadow: 0 0 0 2px rgba(245, 158, 11, .15); }
.ko-datetime { padding: 16px 20px; border-right: 1px solid var(--g1k9az9); background: #FAFBFC; }
.ko-datetime.is-final { background: #FFFBEB; }
.ko-date { font-size: .78rem; font-weight: 600; color: var(--z5yhosp); line-height: 1.3; }
.ko-date.dmej6m { color: var(--tmjilo98); font-size: .85rem; font-weight: 800; }
.ko-time { font-size: .72rem; color: var(--j2d2i6kd); margin-top: 2px; }
.ko-broadcast { font-size: .65rem; color: var(--sou7nn); 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(--z5yhosp); }
.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(--j2d2i6kd); font-weight: 400; flex-shrink: 0; }
.ko-sep.ko-score { font-family: var(--eynfo8gx); font-size: 1.15rem; font-weight: 800; color: var(--z5yhosp); 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(--zmks2u); 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(--g1k9az9); flex-shrink: 0; }
.bk-close { font-size: 1.7rem; line-height: 1; background: none; border: none; cursor: pointer; color: var(--j2d2i6kd); padding: 0 4px; }
.bk-close:hover { color: var(--z5yhosp); }
.bk-title { font-family: var(--eynfo8gx); 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 { --pk01dk56: 38px; --u3siu5u: #9aa6b8; display: flex; align-items: stretch; min-width: max-content; gap: var(--pk01dk56); }
.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(--zmks2u); border: 1px solid var(--g1k9az9); border-radius: 6px; box-shadow: var(--iksqac); }
.bk-game.is-final .bk-card { border-color: var(--tmjilo98); }
/* 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(--pk01dk56) / -2); width: calc(var(--pk01dk56) / 2); border-right: 2.5px solid var(--u3siu5u); }
.bk-col:not(:last-child) .bk-games .bk-game:nth-of-type(odd)::after { top: 50%; bottom: 0; border-top: 2.5px solid var(--u3siu5u); }
.bk-col:not(:last-child) .bk-games .bk-game:nth-of-type(even)::after { top: 0; bottom: 50%; border-bottom: 2.5px solid var(--u3siu5u); }
/* 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(--pk01dk56) / -2); width: calc(var(--pk01dk56) / 2); top: 50%; height: 2.5px; background: var(--u3siu5u); }
.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(--g1k9az9); }
.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(--eynfo8gx); font-weight: 800; color: var(--z5yhosp); margin-left: 4px; }
.bk-empty { padding: 50px; text-align: center; color: var(--j2d2i6kd); 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(--zmks2u); font-family: var(--eynfo8gx); font-weight: 800; font-size: 1.05rem; padding: 10px 2px 6px; border-bottom: 2px solid var(--sou7nn); 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 */
.fcdusuc { background: #F1F3F7; border-top: 1px solid var(--g1k9az9); border-bottom: 1px solid var(--g1k9az9); margin: 32px 0; }
.l79zxq { height: 90px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.l79zxq span { font-size: .72rem; color: var(--j2d2i6kd); font-weight: 500; }
.s7b79ri { background: var(--h3dreple); border-radius: var(--s3bxgm); padding: 28px 32px; display: flex; align-items: center; justify-content: space-between; gap: 24px; margin: 28px 0; position: relative; overflow: hidden; flex-wrap: wrap; }
.s7b79ri::before { content: '2026'; position: absolute; right: 190px; top: 50%; transform: translateY(-50%); font-family: var(--eynfo8gx); 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 */
.pykb41 { display: flex; flex-direction: column; gap: 4px; position: relative; z-index: 1; flex: 1 1 auto; min-width: 0; order: 0; }
.q98t44i6 { font-size: .65rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .5); }
.tfztrd83 { font-family: var(--eynfo8gx); font-size: 1.25rem; font-weight: 800; color: #fff; line-height: 1.2; }
.pgyi61 { font-size: .75rem; color: rgba(255, 255, 255, .45); }
.y1tf8f { background: var(--sou7nn); color: #fff; padding: 11px 24px; border-radius: var(--o1ppypy); 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(--tyjt6dpn); order: 1; }
.y1tf8f: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. */
.oiyu9 { border-left: 4px solid var(--sou7nn); }
.rhz65 { border-top: 3px solid var(--sou7nn); }
.u6ls4q::before { display: none; }

/* ─── FOOTER ───────────────────────────────────────────── */
.blf2cg { background: var(--gzps8); color: rgba(255, 255, 255, .65); padding: 40px 0 28px; }
.ygx73 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; margin-bottom: 36px; }
.nlwoa1fq { font-family: var(--eynfo8gx); font-size: 1.3rem; font-weight: 800; color: #fff; margin-bottom: 10px; }
.usr570l { font-size: .85rem; line-height: 1.6; max-width: 280px; }
.r4ebhd1 { font-size: .72rem; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: rgba(255, 255, 255, .4); margin-bottom: 14px; }
.m0u1ly25 { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.m0u1ly25 a { font-size: .85rem; color: rgba(255, 255, 255, .6); transition: color .15s; }
.m0u1ly25 a:hover { color: #fff; }
.k1knts { 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 */
.fb5kllcd .ygx73 { grid-template-columns: 1fr 1fr 1fr; }
.d2fsi .ygx73 { grid-template-columns: 1fr 1fr 2fr; }
.e68z33 .ygx73 { grid-template-columns: 1fr; text-align: center; justify-items: center; }
.e68z33 .m0u1ly25 { align-items: center; }
.e68z33 .usr570l { max-width: 100%; }
.e68z33 .k1knts { justify-content: center; }
.npwmns .m0u1ly25 { flex-direction: row; flex-wrap: wrap; gap: 16px; }

/* ─── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 900px) {
  .q670dm { grid-template-columns: 1fr; }
  .yw1emx2p, .vrd9hl { flex-wrap: wrap; }
}
@media (max-width: 768px) {
  .jjrqx { display: none; }
  .wciy39a { display: none; }
  .burger { display: flex; }
  .zz0bf { padding: 36px 0 32px; }
  .zz0bf::before { display: none; }
  .section { padding: 36px 0; }
  .wtan2mdt { padding: 24px 0; }
  .stats-grid { flex-wrap: wrap; }
  .stats-cell { flex: 0 0 50%; border-right: none; border-bottom: 1px solid var(--g1k9az9); }
  .stats-cell:nth-child(odd) { border-right: 1px solid var(--g1k9az9); }
  .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; }
  .ygx73 { grid-template-columns: 1fr; gap: 24px; }
  .usr570l { max-width: 100%; }
  .n4onm54y { float: none; width: 100%; margin: 0 0 16px; }
  .a7qttwvf { 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; }
  .id1dioob, .lwnf1 { height: 60px; }
  .lz5njut, .oqkcavps { height: 180px; }
}
@media (max-width: 640px) {
  .ko-match { grid-template-columns: 1fr; }
  .ko-datetime { border-right: none; border-bottom: 1px solid var(--g1k9az9); }
  .ko-teams { justify-content: flex-start; }
  .s7b79ri { padding: 20px; }
  .s7b79ri::before { display: none; }
  .y1tf8f { width: 100%; justify-content: center; }
}
@media (max-width: 600px) {
  .mlnea1 { display: none; }
  .id1dioob { justify-content: center; }
  .ziyxc2 { flex-direction: column; align-items: flex-start; }
  .edi0i { width: 100%; justify-content: center; }
  .o5rum { padding: 18px 20px; }
  .o5rum::after { display: none; }
  .zbg7u { width: 100%; justify-content: center; }
}
@media (max-width: 480px) {
  .rc6f2sp5 { flex-direction: column; }
  .btn { justify-content: center; }
  .phase-tab { padding: 8px 12px; font-size: .75rem; }
}
