/* bgfgy 1ejlhz1 */
/* ════════════════════════════════════════════════════════
   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.vyeh6dj).
   Anti-footprint post-processor renames classes/vars/ids.
════════════════════════════════════════════════════════ */

:root {
  --s5wn6b5: #F7F8FA;
  --d32b8: #FFFFFF;
  --y85pa: #E4E7ED;
  --gw6ec: #1A1E2C;
  --qf8qm2: #6B7280;
  --efuw4m: #1A56DB;
  --amjdf: #E8222A;
  --zkydrip: #F59E0B;
  --l947uhpx: #0F1629;
  --v0vi6gbz: #FFFFFF;
  --oejkp: #1E2A45;
  --l3vgmcb: #22C55E;
  --pxrqs05y: #22C55E;
  --syweri: #F59E0B;
  --drh3s5u: #E8222A;
  --ll62q: #D1D5DB;
  --yk2thr: 6px;
  --mks8n: 10px;
  --bxg2j: 16px;
  --z5q6ngze: 0 1px 3px rgba(0, 0, 0, .08);
  --vhiyh7q: 0 4px 16px rgba(0, 0, 0, .10);
  --h1k7elp: 'Barlow Condensed', sans-serif;
  --joaoxsmt: 'Inter', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--joaoxsmt);
  background: var(--s5wn6b5);
  color: var(--gw6ec);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.h0ytc2 { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ─── HEADER / NAV ─────────────────────────────────────── */
.site-header { background: var(--oejkp); position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 12px rgba(0, 0, 0, .25); }
.yqjrp570 { display: flex; align-items: center; height: 62px; gap: 0; }
.mernv { display: flex; align-items: center; gap: 10px; color: #fff; font-family: var(--h1k7elp); font-size: 1.5rem; font-weight: 800; letter-spacing: .5px; white-space: nowrap; margin-right: 32px; flex-shrink: 0; }
.mernv .vkjcz8h { background: var(--amjdf); color: #fff; font-size: .65rem; font-weight: 700; letter-spacing: 1px; padding: 2px 6px; border-radius: 4px; text-transform: uppercase; }
.pz4dswjz { display: flex; align-items: center; gap: 4px; flex: 1; }
.pz4dswjz a { color: rgba(255, 255, 255, .85); font-size: .9rem; font-weight: 600; padding: 8px 14px; border-radius: var(--yk2thr); transition: background .15s, color .15s; white-space: nowrap; }
.pz4dswjz a:hover, .pz4dswjz a.active { background: rgba(255, 255, 255, .12); color: #fff; }
.pz4dswjz a.lbs1c { background: var(--efuw4m); color: #fff; }
.pz4dswjz a.lbs1c:hover { filter: brightness(.92); }
.atieo { display: flex; align-items: center; gap: 4px; margin-left: auto; flex-shrink: 0; }
.atieo a { color: rgba(255, 255, 255, .75); font-size: .82rem; font-weight: 500; padding: 6px 12px; border-radius: var(--yk2thr); transition: background .15s, color .15s; white-space: nowrap; }
.atieo a:hover { background: rgba(255, 255, 255, .1); color: #fff; }
.ghowp { background: var(--amjdf) !important; color: #fff !important; font-weight: 700 !important; padding: 7px 20px !important; }
.ghowp: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(--l947uhpx); 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(--yk2thr); 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 */
.fa4nr { background: var(--l947uhpx); }
.i088m { box-shadow: none; border-bottom: 3px solid var(--efuw4m); }
.dk68wl .pz4dswjz a { background: rgba(255, 255, 255, .08); }
.jkyoz6r6 .yqjrp570 { height: 54px; }
.jkyoz6r6 .mernv { font-size: 1.3rem; }
.bjo9a5i { 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(--y85pa); position: relative; }
.mkezkg6 { display: flex; overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; scroll-behavior: smooth; padding: 8px 32px; gap: 8px; }
.mkezkg6::-webkit-scrollbar { display: none; }
.wtwyz97 { 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; }
.wtwyz97:hover { color: #404040; }
.wtwyz97.left { left: 0; border-right: 1px solid var(--y85pa); }
.wtwyz97.right { right: 0; border-left: 1px solid var(--y85pa); }
.odds-card { flex-shrink: 0; width: 280px; border: 1px solid var(--y85pa); 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(--y85pa); 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; }
.gojvd { 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.uqlbq { color: #DC2626; }
.g878p0eo { width: 0; height: 0; border-left: 3px solid transparent; border-right: 3px solid transparent; flex-shrink: 0; }
.g878p0eo.up { border-bottom: 5px solid #47A167; }
.g878p0eo.uqlbq { border-top: 5px solid #E72535; }
.odds-status { font-size: .7rem; font-weight: 600; color: var(--efuw4m); text-align: center; padding: 4px 8px; width: 100%; display: block; text-decoration: none; transition: background .12s; }
.odds-status:hover { background: #F0F4FF; }
.hku481 { font-size: .6rem; color: var(--qf8qm2); text-align: center; padding: 3px 20px; background: #FAFBFC; border-top: 1px solid var(--y85pa); }
/* odds-strip section-variant modifiers (id/JS hooks preserved) */
.y01p7 .odds-card { width: 240px; }
.xr6vfclg .odds-card { width: 320px; }
.xr6vfclg .odds-btn-val { font-size: .78rem; }
.falog .odds-card { border-top: 3px solid var(--efuw4m); }
.c5u7tyg { background: var(--oejkp); }
.c5u7tyg .wtwyz97 { background: var(--oejkp); color: rgba(255, 255, 255, .55); }
.c5u7tyg .wtwyz97.left { border-right-color: rgba(255, 255, 255, .12); }
.c5u7tyg .wtwyz97.right { border-left-color: rgba(255, 255, 255, .12); }

/* ─── HERO ─────────────────────────────────────────────── */
.rqbkk { background: linear-gradient(135deg, #0F1629 0%, #1A2545 60%, var(--efuw4m) 100%); color: #fff; padding: 56px 0 52px; position: relative; overflow: hidden; }
.rqbkk::before { content: '2026'; position: absolute; right: -20px; top: 50%; transform: translateY(-50%); font-family: var(--h1k7elp); font-size: clamp(120px, 18vw, 220px); font-weight: 800; color: rgba(255, 255, 255, .04); line-height: 1; pointer-events: none; user-select: none; }
.t6tc04 { 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; }
.rqbkk h1 { font-family: var(--h1k7elp); font-size: clamp(2.4rem, 6vw, 4.2rem); font-weight: 800; line-height: 1.05; letter-spacing: -.5px; margin-bottom: 16px; max-width: 680px; }
.rqbkk h1 em { font-style: normal; color: var(--zkydrip); }
.lx8i8crr { font-size: 1.05rem; color: rgba(255, 255, 255, .75); max-width: 520px; margin-bottom: 28px; line-height: 1.55; }
.x8k6hxj { display: flex; flex-wrap: wrap; gap: 12px; }
/* hero section-variant modifiers */
.k6htj1 .h0ytc2 { text-align: center; }
.k6htj1 h1, .k6htj1 .lx8i8crr { margin-left: auto; margin-right: auto; }
.k6htj1 .x8k6hxj { justify-content: center; }
.g7zcts::before { display: none; }
.k25jr .h0ytc2 { text-align: right; }
.k25jr h1, .k25jr .lx8i8crr { margin-left: auto; }
.k25jr .x8k6hxj { justify-content: flex-end; }
.k25jr::before { right: auto; left: -20px; }
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 12px 24px; border-radius: var(--yk2thr); font-size: .9rem; font-weight: 600; cursor: pointer; transition: filter .15s, transform .1s; border: none; }
.btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.a997gg { background: var(--efuw4m); color: #fff; }
.kou0ervi { background: transparent; color: #fff; border: 1.5px solid rgba(255, 255, 255, .4); }
.kou0ervi:hover { background: rgba(255, 255, 255, .1); }

/* ─── SECTION ──────────────────────────────────────────── */
.section { padding: 56px 0; }
.p2dvw { padding: 36px 0; }
.ednqfkzh { background: var(--d32b8); }
.t3ytmcju { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 28px; gap: 12px; flex-wrap: wrap; }
.section-title { font-family: var(--h1k7elp); 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(--efuw4m); border-radius: 2px; }
.tb8m17e { font-size: .85rem; font-weight: 600; color: var(--efuw4m); white-space: nowrap; }
.tb8m17e:hover { text-decoration: underline; }

/* ─── STATS STRIP ──────────────────────────────────────── */
.g0ff70c { background: var(--d32b8); border-top: 1px solid var(--y85pa); border-bottom: 1px solid var(--y85pa); }
.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(--y85pa); 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(--h1k7elp); font-size: clamp(2.2rem, 4vw, 3rem); font-weight: 800; color: var(--efuw4m); line-height: 1; letter-spacing: -1px; }
.stats-label { font-size: .65rem; font-weight: 700; color: var(--qf8qm2); text-transform: uppercase; letter-spacing: 1px; white-space: nowrap; }
/* stats section-variant modifiers (anti-footprint layout uniqueness) */
.g8f9qh3 .stats-cell { flex-direction: row; align-items: baseline; gap: 8px; }
.g8f9qh3 .stats-num { font-size: clamp(1.5rem, 3vw, 2.1rem); }
.lmlam44 .stats-cell { border-top: 3px solid var(--efuw4m); }
.lmlam44 .stats-num { color: var(--gw6ec); }
.lmlam44 .stats-label { color: var(--efuw4m); }
.euoi6x .stats-grid { flex-wrap: wrap; }
.euoi6x .stats-cell { flex: 0 0 50%; }
.euoi6x .stats-cell:nth-child(odd) { border-right: 1px solid var(--y85pa); }
.euoi6x .stats-cell:nth-child(-n+2) { border-bottom: 1px solid var(--y85pa); }

/* ─── PROSE / ARTICLE ──────────────────────────────────── */
.f5n1af2 { max-width: 100%; }
/* article section-variant modifiers (H2 .section-title + html preserved) */
.jf0t8 { background: var(--s5wn6b5); }
.gij0wseg .f5n1af2 { max-width: 760px; margin: 0 auto; }
.gij0wseg .t3ytmcju { text-align: center; }
.gmlr0v6 .section-title { border-left: 4px solid var(--efuw4m); padding-left: 14px; }
.nyq6772r { border-top: 1px solid var(--y85pa); }
.f5n1af2 h2 { font-family: var(--h1k7elp); font-size: 1.7rem; font-weight: 800; margin: 36px 0 12px; line-height: 1.15; }
.f5n1af2 h3 { font-family: var(--h1k7elp); font-size: 1.25rem; font-weight: 700; margin: 28px 0 10px; line-height: 1.2; }
.f5n1af2 h4 { font-size: 1rem; font-weight: 700; margin: 20px 0 8px; color: var(--gw6ec); }
.f5n1af2 p { color: #374151; margin-bottom: 16px; line-height: 1.7; }
.f5n1af2 ul { list-style: none; margin: 0 0 18px 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.f5n1af2 ul li { padding-left: 22px; position: relative; color: #374151; line-height: 1.6; }
.f5n1af2 ul li::before { content: ''; position: absolute; left: 6px; top: 10px; width: 6px; height: 6px; border-radius: 50%; background: var(--efuw4m); }
.f5n1af2 ol { counter-reset: ol-counter; list-style: none; margin: 0 0 18px 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.f5n1af2 ol li { counter-increment: ol-counter; padding-left: 36px; position: relative; color: #374151; line-height: 1.6; }
.f5n1af2 ol li::before { content: counter(ol-counter); position: absolute; left: 0; top: 0; width: 24px; height: 24px; background: var(--efuw4m); color: #fff; font-size: .75rem; font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.f5n1af2 strong { font-weight: 700; color: var(--gw6ec); }
.f5n1af2 a { color: var(--efuw4m); text-decoration: underline; }

.wc08s0 { margin: 24px 0 28px; }
.xi8trnfb { width: 100%; height: 280px; background: #F1F3F7; border: 2px dashed var(--y85pa); border-radius: var(--mks8n); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; }
.xi8trnfb .rkwmbe { font-size: 2rem; opacity: .4; }
.xi8trnfb .rug8w42 { font-size: .8rem; font-weight: 600; color: var(--qf8qm2); }
.ofa4jrcn { width: 100%; height: 280px; object-fit: cover; border-radius: var(--mks8n); display: block; }
.k6clt { font-size: .75rem; color: var(--qf8qm2); margin-top: 8px; font-style: italic; }

/* prose inline table */
.lq2qdvi0 { overflow-x: auto; margin: 20px 0 24px; border-radius: var(--mks8n); border: 1px solid var(--y85pa); box-shadow: var(--z5q6ngze); }
.a66vx { width: 100%; border-collapse: collapse; background: var(--d32b8); font-size: .875rem; }
.a66vx thead tr { background: #F1F3F7; }
.a66vx thead th { padding: 10px 16px; text-align: left; font-size: .68rem; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--qf8qm2); border-bottom: 2px solid var(--y85pa); white-space: nowrap; }
.a66vx tbody tr { border-bottom: 1px solid var(--y85pa); transition: background .12s; }
.a66vx tbody tr:first-child { background: #EFF6FF; }
.a66vx tbody tr:first-child td { font-weight: 600; }
.a66vx tbody tr:last-child { border-bottom: none; }
.a66vx tbody tr:hover { background: #F7F9FF; }
.a66vx tbody td { padding: 11px 16px; vertical-align: middle; }
.mnvcaa5 { display: inline-block; padding: 2px 10px; border-radius: 20px; font-size: .78rem; font-weight: 700; }
.mnvcaa5.rbmuo59 { background: var(--efuw4m); color: #fff; }

/* prose CTA blocks */
.waxapw75 { margin: 28px 0; background: linear-gradient(135deg, #EFF6FF 0%, #E0EAFF 100%); border: 1px solid rgba(26, 86, 219, .18); border-left: 4px solid var(--efuw4m); border-radius: var(--mks8n); padding: 20px 24px; }
.glim93 { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.diky5z0 { display: flex; flex-direction: column; gap: 4px; }
.diky5z0 strong { font-size: 1rem; font-weight: 700; color: var(--gw6ec); }
.diky5z0 span { font-size: .8rem; color: var(--qf8qm2); }
.gydgr0x { background: var(--efuw4m); color: #fff !important; padding: 11px 24px; border-radius: var(--yk2thr); font-size: .9rem; font-weight: 700; font-family: var(--joaoxsmt); 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; }
.gydgr0x:hover { filter: brightness(1.08); transform: translateY(-1px); }
.ugzaxkc { margin: 20px 0 28px; background: var(--oejkp); border-radius: var(--mks8n); padding: 22px 28px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; position: relative; overflow: hidden; }
.ugzaxkc::after { content: '2026'; position: absolute; right: 180px; top: 50%; transform: translateY(-50%); font-family: var(--h1k7elp); 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) */
.v1oj0jrc { display: flex; flex-direction: column; gap: 5px; }
.dmi68 { font-size: .68rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .6); }
.hj4ho { font-family: var(--h1k7elp); font-size: 1.3rem; font-weight: 800; color: #fff; line-height: 1.2; }
.l4yx6i { font-size: .75rem; color: rgba(255, 255, 255, .5); }
.c7uiqc { background: var(--efuw4m); color: #fff !important; padding: 12px 26px; border-radius: var(--yk2thr); font-size: .9rem; font-weight: 700; font-family: var(--joaoxsmt); 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; }
.c7uiqc:hover { filter: brightness(1.1); transform: translateY(-1px); }

/* split block */
.w918y57 { margin: 32px 0 8px; padding-top: 32px; border-top: 1px solid var(--y85pa); }
.qipkb { margin-bottom: 20px !important; }
/* r9: float the image so the text flows AROUND it and fills the space under it (no empty column) */
.txytm4y8 { display: block; }
.txytm4y8::after { content: ''; display: block; clear: both; }
.v7apv07 { float: left; width: 42%; margin: 4px 32px 14px 0; }
.c0jnam4 { width: 100%; }
.c9b8yg3i { height: 240px !important; }
.z067lf { display: block; }
.z067lf p { margin-bottom: 14px; }
.z067lf ul { margin-bottom: 0; }

/* ─── FAQ ──────────────────────────────────────────────── */
.k0e5pg { display: flex; flex-direction: column; gap: 12px; max-width: none; } /* r10: full width */
.kv11jnf { background: var(--d32b8); border: 1px solid var(--y85pa); border-radius: var(--mks8n); padding: 16px 20px; box-shadow: var(--z5q6ngze); }
.n0epx { font-family: var(--h1k7elp); font-size: 1.05rem; font-weight: 700; color: var(--gw6ec); margin: 0 0 6px; } /* r10: question is an <h3>, reset default margins */
.e1fah5 { font-size: .92rem; color: #374151; line-height: 1.6; }
/* faq section-variant modifiers */
.jqzm2r .kv11jnf { background: transparent; border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--y85pa); padding: 16px 0; }
.wc38gv .k0e5pg { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); max-width: none; }
.f2sd5w .kv11jnf { border-left: 3px solid var(--efuw4m); }
.kw6zx .kv11jnf { padding: 12px 16px; }
.kw6zx .n0epx { font-size: .95rem; margin-bottom: 3px; }

/* ─── HERO-SUB LINK + CONTACT FORM ─────────────────────── */
.ozdtfo { color: var(--qf8qm2); font-size: .82rem; margin-top: 6px; max-width: 760px; }
.k67i75d { display: flex; flex-direction: column; gap: 14px; max-width: 520px; margin: 8px 0 4px; }
.k67i75d label { display: flex; flex-direction: column; gap: 6px; font-size: .85rem; font-weight: 600; color: var(--gw6ec); }
.k67i75d input, .k67i75d textarea { font-family: var(--joaoxsmt); font-size: .95rem; padding: 10px 12px; border: 1px solid var(--y85pa); border-radius: var(--yk2thr); background: var(--d32b8); color: var(--gw6ec); }
.k67i75d input:focus, .k67i75d textarea:focus { outline: none; border-color: var(--efuw4m); }
.k67i75d button { align-self: flex-start; }

/* ─── LEGAL / INFO PAGES (sobre, contato, privacidade, cookies) ─── */
.ttbd2sl6 { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
.na7ssrb { max-width: none; }
.na7ssrb h3 { margin-top: 26px; }
.na7ssrb h3:first-child { margin-top: 0; }
.kenos7 { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 80px; }
.vj9b1m { background: var(--d32b8); border: 1px solid var(--y85pa); border-radius: var(--bxg2j); padding: 22px 24px; box-shadow: var(--z5q6ngze); }
.kyy716ql { font-family: var(--h1k7elp); font-size: 1.2rem; font-weight: 800; color: var(--gw6ec); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.pk1tse { font-size: .82rem; color: var(--qf8qm2); line-height: 1.55; margin-bottom: 16px; }
.o1o7h8 { font-size: .65rem; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--qf8qm2); margin: 14px 0 8px; }
.vf2w8 { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.vf2w8 a { font-size: .9rem; color: var(--efuw4m); font-weight: 600; }
.vf2w8 a:hover { text-decoration: underline; }
.wfdetl { font-size: .88rem; color: var(--gw6ec); word-break: break-all; font-weight: 600; }
.fau8cvz6 { background: var(--efuw4m); color: #fff; text-align: center; padding: 13px 18px; border-radius: var(--yk2thr); font-weight: 700; font-size: .9rem; transition: filter .15s, transform .1s; }
.fau8cvz6:hover { filter: brightness(1.08); transform: translateY(-1px); }
.alru6 { font-size: .8rem; color: var(--qf8qm2); margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--y85pa); }
@media (max-width: 860px) { .ttbd2sl6 { grid-template-columns: 1fr; } .kenos7 { position: static; } }

/* ─── GENERIC TABLE (home preview) ─────────────────────── */
.dyrty { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: var(--mks8n); border: 1px solid var(--y85pa); box-shadow: var(--z5q6ngze); }
table { width: 100%; border-collapse: collapse; background: var(--d32b8); font-size: .88rem; }
/* tabela-preview section-variant modifiers */
.liddyz table tbody tr:nth-child(even) { background: #FAFBFC; }
.bn3dwo table th, .bn3dwo table td { padding: 6px 8px; font-size: .8rem; }
.zmjuw8m9 table thead tr { background: var(--oejkp); }
.zmjuw8m9 table thead th { color: rgba(255, 255, 255, .85); }
.yqbg50lc table tbody tr { border-bottom: 1px solid var(--y85pa); }
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(--qf8qm2); white-space: nowrap; border-bottom: 2px solid var(--y85pa); }
thead th:not(:first-child) { text-align: center; }
tbody tr { border-bottom: 1px solid var(--y85pa); 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; }
.felbwf { 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(--qf8qm2); font-size: .8rem; width: 24px; text-align: center; display: inline-block; }
.rank-pos.qualify { color: var(--efuw4m); }
.pts-badge { display: inline-block; background: var(--efuw4m); 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.s2sok { background: var(--pxrqs05y); }
.form-dot.d { background: var(--zkydrip); }
.form-dot.cj6w1ld { background: var(--amjdf); }

/* ─── 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(--d32b8); border: 1.5px solid var(--efuw4m); color: var(--efuw4m); font-weight: 700; font-size: .9rem; padding: 12px 30px; border-radius: var(--yk2thr); cursor: pointer; transition: background .15s, transform .1s; font-family: var(--joaoxsmt); }
.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(--qf8qm2); padding: 8px 0 4px; border-top: 1px solid var(--y85pa); margin-top: 4px; }
.match-day-label:first-child { border-top: none; margin-top: 0; }
/* jogos-preview section-variant modifiers */
.uf13zxe .matches-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 12px; }
.uf13zxe .match-day-label { grid-column: 1 / -1; }
.gtvu19a .match-card { padding: 10px 16px; }
.gtvu19a .score-nums { font-size: 1.4rem; }
.vm4d8 .match-card { border-left: 3px solid var(--efuw4m); }
.xb931m9 .match-card { background: transparent; border: none; box-shadow: none; border-radius: 0; border-bottom: 1px solid var(--y85pa); }
.match-day-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 0 6px; border-top: 1px solid var(--y85pa); 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(--gw6ec); }
.match-day-phase { font-size: .72rem; font-weight: 600; color: var(--qf8qm2); }
.match-card { background: var(--d32b8); border: 1px solid var(--y85pa); border-radius: var(--mks8n); 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(--efuw4m); box-shadow: 0 0 0 3px rgba(26, 86, 219, .08); }
.match-card.finished:hover { border-color: var(--y85pa); 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(--y85pa); 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(--h1k7elp); font-size: 1.8rem; font-weight: 800; letter-spacing: 4px; line-height: 1; color: var(--gw6ec); }
.score-nums.upcoming { color: var(--qf8qm2); letter-spacing: 2px; font-size: 1.3rem; }
.e7spodc { color: var(--y85pa); }
.score-time { font-size: .72rem; color: var(--qf8qm2); 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(--amjdf); }
.score-status.finished { background: #F1F3F7; color: var(--qf8qm2); }
.score-status.upcoming { background: #EFF6FF; color: var(--efuw4m); }
.match-venue { font-size: .7rem; color: var(--efuw4m); font-weight: 500; margin-top: 3px; }
.bewj0 { font-size: .66rem; color: var(--qf8qm2); }

/* ─── BANNER STRIP ─────────────────────────────────────── */
.ektt6 { background: #F1F3F7; border-top: 1px solid var(--y85pa); border-bottom: 1px solid var(--y85pa); }
.qmfxo7kp { display: block; }
.r02qkeo3 { width: 100%; height: 90px; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; border: 2px dashed var(--y85pa); cursor: pointer; transition: background .15s, border-color .15s; position: relative; overflow: hidden; }
.r02qkeo3:hover { background: #E8EBF0; border-color: var(--efuw4m); }
.y3jydzi { display: flex; align-items: center; gap: 10px; }
.rkwmbe { font-size: 1.4rem; opacity: .4; }
.rug8w42 { font-size: .75rem; font-weight: 600; color: var(--qf8qm2); letter-spacing: .3px; }
.thkszk { width: 100%; height: 90px; object-fit: cover; display: block; }
.wcuk3e { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.qm6ils { display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px; border-radius: var(--yk2thr); font-size: .85rem; font-weight: 700; white-space: nowrap; transition: filter .15s, transform .1s; text-decoration: none; }
.qm6ils:hover { filter: brightness(1.08); transform: translateY(-1px); }
.ylvynxq4 { background: var(--efuw4m); color: #fff; }
.rgt2nlih { background: transparent; color: var(--efuw4m); border: 1.5px solid var(--efuw4m); }
.rgt2nlih:hover { background: #EFF6FF; }
/* banner section-variant modifiers */
.oyn73 .r02qkeo3 { justify-content: center; }
.oyn73 .y3jydzi { gap: 16px; }
.yq5mshab .r02qkeo3 { border-style: solid; }

/* ─── PAGE HEADER + PHASE TABS (tabela/jogos) ──────────── */
.d37c9 { background: var(--d32b8); border-bottom: 1px solid var(--y85pa); padding: 20px 0 0; }
.j1m3hl5 { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 16px; flex-wrap: wrap; gap: 8px; }
.ocb47j9 { font-family: var(--h1k7elp); font-size: 1.8rem; font-weight: 800; letter-spacing: -.2px; }
.si86b { font-size: .8rem; color: var(--qf8qm2); margin-top: 2px; }
.djmnrf { display: inline-block; font-size: .72rem; font-weight: 600; color: var(--efuw4m); background: #EFF6FF; border: 1px solid rgba(26,86,219,.18); padding: 3px 10px; border-radius: 20px; margin-top: 8px; }
.nj50vpx { background: var(--d32b8); border-bottom: 1px solid var(--y85pa); }
.oce5m { display: flex; gap: 0; border-bottom: 2px solid var(--y85pa); }
.phase-tab { padding: 10px 18px; font-size: .82rem; font-weight: 600; color: var(--qf8qm2); border-bottom: 2px solid transparent; margin-bottom: -2px; cursor: pointer; white-space: nowrap; transition: color .15s, border-color .15s; }
.phase-tab:hover { color: var(--efuw4m); }
.phase-tab.active { color: var(--efuw4m); border-bottom-color: var(--efuw4m); }

/* ─── GROUP NAV PILLS (tabela) ─────────────────────────── */
.group-nav-wrap { background: var(--d32b8); border-bottom: 1px solid var(--y85pa); position: sticky; top: 62px; z-index: 90; }
.ivqh9jh { display: flex; align-items: center; gap: 0; overflow-x: auto; scrollbar-width: none; padding: 10px 0; }
.ivqh9jh::-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(--qf8qm2); background: transparent; border: 1.5px solid transparent; transition: all .15s; white-space: nowrap; }
.group-pill:hover, .group-pill.active { color: var(--efuw4m); border-color: var(--efuw4m); background: #EFF6FF; }

/* ─── TABELA: groups + classification ──────────────────── */
.ncqxe48c { padding: 28px 0 56px; }
.group-block { margin-bottom: 48px; scroll-margin-top: 130px; }
.fctzwij { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; max-width: 1000px; margin: 0 auto; }
.lwty97 { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 12px; }
.lwty97 h2 { font-family: var(--h1k7elp); font-size: 1.4rem; font-weight: 800; letter-spacing: -.1px; }
.btn-completa { font-size: .72rem; font-weight: 700; color: var(--efuw4m); border: 1.5px solid var(--efuw4m); 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(--amjdf); border-color: var(--amjdf); 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 .fctzwij { grid-template-columns: 1fr; max-width: 1140px; }
.group-block.expanded .fctzwij > div:nth-child(2) { display: none; }
.tr76sz3 { display: none; width: 100%; flex-wrap: wrap; align-items: center; gap: 10px 22px; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--y85pa); }
.group-block.expanded .jpjtc { align-items: flex-start; }
.group-block.expanded .tr76sz3 { display: flex; }
.fgxs9a0 { display: flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--qf8qm2); }
.zofp30 { display: flex; flex-wrap: wrap; gap: 4px 16px; }
.h012r { font-size: .68rem; color: var(--qf8qm2); }
.h012r b { color: var(--gw6ec); font-weight: 700; margin-right: 4px; }
table.cls-table { width: 100%; border-collapse: collapse; background: var(--d32b8); 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(--qf8qm2); border-bottom: 2px solid var(--y85pa); white-space: nowrap; }
table.cls-table thead th.baqddr3f { text-align: left; }
table.cls-table thead th.s2tr0cy { background: #EFF6FF; color: var(--efuw4m); }
table.cls-table tbody tr { border-bottom: 1px solid var(--y85pa); 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(--l3vgmcb); }
td.pos-cell { position: relative; width: 36px; padding-left: 14px; text-align: center; }
.pos-num { font-size: .75rem; font-weight: 700; color: var(--qf8qm2); }
.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(--y85pa); }
.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.s2sok { background: var(--pxrqs05y); }
.bullet.d { background: var(--syweri); }
.bullet.cj6w1ld { background: var(--drh3s5u); }
.bullet.p { background: var(--ll62q); }
.jpjtc { padding: 8px 12px; display: flex; align-items: center; flex-wrap: wrap; gap: 12px; border-top: 1px solid var(--y85pa); background: #FAFBFC; border-radius: 0 0 var(--mks8n) var(--mks8n); }
.dh1m8 { display: flex; align-items: center; gap: 6px; font-size: .68rem; color: var(--qf8qm2); }
.sffsyrc2 { width: 10px; height: 10px; border-radius: 2px; background: var(--l3vgmcb); }
.ppqw7pvw { display: flex; align-items: center; gap: 10px; }
.fgxs9a0 { display: flex; align-items: center; gap: 4px; font-size: .68rem; color: var(--qf8qm2); }

/* tabela match column */
.wm5mg { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.wm5mg h2 { font-family: var(--h1k7elp); font-size: 1.4rem; font-weight: 800; }
.round-nav { display: flex; align-items: center; gap: 8px; }
.dwonq17 { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--y85pa); background: var(--d32b8); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: .85rem; color: var(--qf8qm2); transition: border-color .15s, color .15s; }
.dwonq17:hover { border-color: var(--efuw4m); color: var(--efuw4m); }
.round-label { font-size: .8rem; font-weight: 600; color: var(--gw6ec); 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; }
.faray { padding: 5px 12px; display: flex; align-items: center; gap: 8px; border-bottom: 1px solid var(--y85pa); background: #FAFBFC; }
.xbk2k440 { font-size: .65rem; font-weight: 700; display: flex; align-items: center; gap: 4px; }
.xbk2k440.finished { color: var(--qf8qm2); }
.xbk2k440.live { color: var(--amjdf); }
.xbk2k440.upcoming { color: var(--efuw4m); }
.bl6udu { font-size: .65rem; color: var(--qf8qm2); margin-left: auto; }
.vqczco { font-size: .62rem; color: var(--qf8qm2); }
.om6mfnoa { padding: 10px 12px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 8px; }
.om6mfnoa .match-team { font-size: .82rem; gap: 8px; }
.om6mfnoa .match-team.away { justify-content: flex-end; flex-direction: row-reverse; }
.ae0ku { text-align: center; min-width: 60px; }
.la8sj9b9 { font-family: var(--h1k7elp); font-size: 1.5rem; font-weight: 800; line-height: 1; letter-spacing: 2px; }
.sryxng { color: #CBD5E1; }

/* knockout */
.phase-content { display: none; }
.phase-content.active { display: block; }
.ikr9r { padding: 14px 0 18px; }
.bracket-link { font-size: .82rem; font-weight: 600; color: var(--efuw4m); 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(--d32b8); border: 1px solid var(--y85pa); border-radius: var(--mks8n); overflow: hidden; transition: border-color .15s; }
.ko-match:hover { border-color: var(--efuw4m); }
.ko-match.is-final { border-color: var(--zkydrip); box-shadow: 0 0 0 2px rgba(245, 158, 11, .15); }
.ko-datetime { padding: 16px 20px; border-right: 1px solid var(--y85pa); background: #FAFBFC; }
.ko-datetime.is-final { background: #FFFBEB; }
.ko-date { font-size: .78rem; font-weight: 600; color: var(--gw6ec); line-height: 1.3; }
.ko-date.jxa4twi { color: var(--zkydrip); font-size: .85rem; font-weight: 800; }
.ko-time { font-size: .72rem; color: var(--qf8qm2); margin-top: 2px; }
.ko-broadcast { font-size: .65rem; color: var(--efuw4m); 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(--gw6ec); }
.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(--qf8qm2); font-weight: 400; flex-shrink: 0; }
.ko-sep.ko-score { font-family: var(--h1k7elp); font-size: 1.15rem; font-weight: 800; color: var(--gw6ec); 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(--d32b8); 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(--y85pa); flex-shrink: 0; }
.bk-close { font-size: 1.7rem; line-height: 1; background: none; border: none; cursor: pointer; color: var(--qf8qm2); padding: 0 4px; }
.bk-close:hover { color: var(--gw6ec); }
.bk-title { font-family: var(--h1k7elp); 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 { --vecbtaep: 38px; --bo1m4tyg: #9aa6b8; display: flex; align-items: stretch; min-width: max-content; gap: var(--vecbtaep); }
.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(--d32b8); border: 1px solid var(--y85pa); border-radius: 6px; box-shadow: var(--z5q6ngze); }
.bk-game.is-final .bk-card { border-color: var(--zkydrip); }
/* 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(--vecbtaep) / -2); width: calc(var(--vecbtaep) / 2); border-right: 2.5px solid var(--bo1m4tyg); }
.bk-col:not(:last-child) .bk-games .bk-game:nth-of-type(odd)::after { top: 50%; bottom: 0; border-top: 2.5px solid var(--bo1m4tyg); }
.bk-col:not(:last-child) .bk-games .bk-game:nth-of-type(even)::after { top: 0; bottom: 50%; border-bottom: 2.5px solid var(--bo1m4tyg); }
/* 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(--vecbtaep) / -2); width: calc(var(--vecbtaep) / 2); top: 50%; height: 2.5px; background: var(--bo1m4tyg); }
.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(--y85pa); }
.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(--h1k7elp); font-weight: 800; color: var(--gw6ec); margin-left: 4px; }
.bk-empty { padding: 50px; text-align: center; color: var(--qf8qm2); 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(--d32b8); font-family: var(--h1k7elp); font-weight: 800; font-size: 1.05rem; padding: 10px 2px 6px; border-bottom: 2px solid var(--efuw4m); 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 */
.v2b0xl { background: #F1F3F7; border-top: 1px solid var(--y85pa); border-bottom: 1px solid var(--y85pa); margin: 32px 0; }
.kxjhg { height: 90px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.kxjhg span { font-size: .72rem; color: var(--qf8qm2); font-weight: 500; }
.cbi6a9zc { background: var(--l947uhpx); border-radius: var(--bxg2j); padding: 28px 32px; display: flex; align-items: center; justify-content: space-between; gap: 24px; margin: 28px 0; position: relative; overflow: hidden; flex-wrap: wrap; }
.cbi6a9zc::before { content: '2026'; position: absolute; right: 190px; top: 50%; transform: translateY(-50%); font-family: var(--h1k7elp); 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 */
.r8jmdf { display: flex; flex-direction: column; gap: 4px; position: relative; z-index: 1; flex: 1 1 auto; min-width: 0; order: 0; }
.fh2ki76n { font-size: .65rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: rgba(255, 255, 255, .5); }
.af6l9h { font-family: var(--h1k7elp); font-size: 1.25rem; font-weight: 800; color: #fff; line-height: 1.2; }
.dfai8 { font-size: .75rem; color: rgba(255, 255, 255, .45); }
.gy2awi { background: var(--efuw4m); color: #fff; padding: 11px 24px; border-radius: var(--yk2thr); 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(--joaoxsmt); order: 1; }
.gy2awi: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. */
.r3vnvnu { border-left: 4px solid var(--efuw4m); }
.s37re1d { border-top: 3px solid var(--efuw4m); }
.jlozzw::before { display: none; }

/* ─── FOOTER ───────────────────────────────────────────── */
.qo68uxw { background: var(--oejkp); color: rgba(255, 255, 255, .65); padding: 40px 0 28px; }
.qo02e { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; margin-bottom: 36px; }
.envq14j { font-family: var(--h1k7elp); font-size: 1.3rem; font-weight: 800; color: #fff; margin-bottom: 10px; }
.me7c1mpv { font-size: .85rem; line-height: 1.6; max-width: 280px; }
.erykghj4 { font-size: .72rem; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: rgba(255, 255, 255, .4); margin-bottom: 14px; }
.c8vhh9 { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.c8vhh9 a { font-size: .85rem; color: rgba(255, 255, 255, .6); transition: color .15s; }
.c8vhh9 a:hover { color: #fff; }
.zwp8g3 { 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 */
.j6atj .qo02e { grid-template-columns: 1fr 1fr 1fr; }
.lq0hjvzx .qo02e { grid-template-columns: 1fr 1fr 2fr; }
.scljsiu .qo02e { grid-template-columns: 1fr; text-align: center; justify-items: center; }
.scljsiu .c8vhh9 { align-items: center; }
.scljsiu .me7c1mpv { max-width: 100%; }
.scljsiu .zwp8g3 { justify-content: center; }
.yp7s3j2 .c8vhh9 { flex-direction: row; flex-wrap: wrap; gap: 16px; }

/* ─── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 900px) {
  .fctzwij { grid-template-columns: 1fr; }
  .wm5mg, .lwty97 { flex-wrap: wrap; }
}
@media (max-width: 768px) {
  .pz4dswjz { display: none; }
  .atieo { display: none; }
  .burger { display: flex; }
  .rqbkk { padding: 36px 0 32px; }
  .rqbkk::before { display: none; }
  .section { padding: 36px 0; }
  .p2dvw { padding: 24px 0; }
  .stats-grid { flex-wrap: wrap; }
  .stats-cell { flex: 0 0 50%; border-right: none; border-bottom: 1px solid var(--y85pa); }
  .stats-cell:nth-child(odd) { border-right: 1px solid var(--y85pa); }
  .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; }
  .qo02e { grid-template-columns: 1fr; gap: 24px; }
  .me7c1mpv { max-width: 100%; }
  .v7apv07 { float: none; width: 100%; margin: 0 0 16px; }
  .c9b8yg3i { 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; }
  .r02qkeo3, .thkszk { height: 60px; }
  .xi8trnfb, .ofa4jrcn { height: 180px; }
}
@media (max-width: 640px) {
  .ko-match { grid-template-columns: 1fr; }
  .ko-datetime { border-right: none; border-bottom: 1px solid var(--y85pa); }
  .ko-teams { justify-content: flex-start; }
  .cbi6a9zc { padding: 20px; }
  .cbi6a9zc::before { display: none; }
  .gy2awi { width: 100%; justify-content: center; }
}
@media (max-width: 600px) {
  .wcuk3e { display: none; }
  .r02qkeo3 { justify-content: center; }
  .glim93 { flex-direction: column; align-items: flex-start; }
  .gydgr0x { width: 100%; justify-content: center; }
  .ugzaxkc { padding: 18px 20px; }
  .ugzaxkc::after { display: none; }
  .c7uiqc { width: 100%; justify-content: center; }
}
@media (max-width: 480px) {
  .x8k6hxj { flex-direction: column; }
  .btn { justify-content: center; }
  .phase-tab { padding: 8px 12px; font-size: .75rem; }
}
