@charset "UTF-8";
/* ============================================================================
   Baccarat Bro Fresh — page components, ported verbatim from the baczim
   per-page <style> blocks (how-to-play, strategy hub, strategy detail, tools,
   articles, article). Loaded site-wide; class names are page-scoped so they
   don't collide. The casino-hub components live in page-casinos.php.
   ============================================================================ */

/* ---- shared page hero ---- */
.page-hero { padding:40px 0 8px; position:relative; overflow:hidden; }
.page-hero .wrap { position:relative; z-index:1; }
.page-hero h1 { font-family:var(--display); font-weight:800; line-height:1.05; letter-spacing:-.015em; font-size:clamp(2.2rem,4.6vw,3.6rem); }
.page-hero .breadcrumb { margin-bottom:4px; }
.hero__felt { position:absolute; inset:0; z-index:0; background:radial-gradient(120% 90% at 80% -10%, rgba(199,154,75,.16), transparent 55%), radial-gradient(90% 80% at 10% 110%, rgba(26,107,81,.16), transparent 60%); pointer-events:none; }
.page-hero__grid { display:grid; grid-template-columns:1fr auto; gap:40px; align-items:center; }
.page-hero__bro .bro-emblem { width:120px; height:120px; filter:drop-shadow(0 10px 22px rgba(10,58,43,.2)); }
.hero-chips { display:flex; gap:9px; flex-wrap:wrap; margin-top:26px; margin-bottom:28px; }
.hero-chips .chip-tag { display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:12px; font-weight:700; background:var(--paper); border:1px solid var(--line); padding:8px 14px; border-radius:999px; }
.hero-chips .chip-tag svg { width:15px; height:15px; color:var(--felt); }

/* ============ HOW TO PLAY (learn) ============ */
.learn-layout { display:grid; grid-template-columns:240px 1fr; gap:48px; align-items:start; }
/* grid-blowout guard: children may not force the column wider than the viewport */
.learn-layout > * { min-width:0; }
.learn-nav { position:sticky; top:90px; max-width:100%; }
.learn-nav__card { max-width:100%; }
.learn-nav__card { background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; box-shadow:var(--shadow-sm); }
.side-title { font-family:var(--sans); font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-faint); margin-bottom:14px; }
.learn-toc { list-style:none; margin:0; padding:0; counter-reset:toc; display:flex; flex-direction:column; }
.learn-toc li { counter-increment:toc; }
.learn-toc a { display:flex; gap:10px; padding:8px 0; font-weight:600; font-size:.92rem; border-bottom:1px solid var(--line-soft); color:var(--ink); }
.learn-toc li:last-child a { border-bottom:0; }
.learn-toc a::before { content:counter(toc,decimal-leading-zero); font-family:var(--mono); font-size:11px; color:var(--gold-deep); font-weight:700; }
.learn-toc a:hover { color:var(--felt); }
.learn-main { max-width:none; }
.goal-cards { display:flex; align-items:center; gap:18px; justify-content:center; margin:6px 0; }
.goal-card { flex:1; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; text-align:center; box-shadow:var(--shadow-sm); }
.goal-card .dot { width:14px; height:14px; margin-bottom:10px; }
.goal-card b { display:block; font-family:var(--display); font-size:1.6rem; }
.goal-card span:last-child { display:block; color:var(--ink-soft); font-size:.9rem; margin-top:4px; }
.goal-card--player { border-top:3px solid var(--player); }
.goal-card--banker { border-top:3px solid var(--felt); }
.goal-vs { font-family:var(--display); font-style:italic; font-size:1.3rem; color:var(--ink-faint); }
.value-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.value-chip { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:18px 14px; text-align:center; }
.vc-card { display:block; font-family:var(--display); font-weight:800; font-size:1.5rem; color:var(--felt); }
.vc-val { display:block; font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); margin-top:6px; }
.hand-demo { background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px 26px; box-shadow:var(--shadow-sm); }
.hand-row { display:flex; align-items:center; gap:16px; padding:14px 0; }
.hand-row + .hand-row { border-top:1px solid var(--line-soft); }
.hand-row__label { width:104px; font-weight:700; display:flex; align-items:center; gap:9px; font-size:1.05rem; }
.hand-cards { display:flex; gap:8px; }
.pcard { width:50px; height:70px; border-radius:9px; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; color:var(--ink); }
.pcard.red { color:var(--player); }
.pcard .rank { font-family:var(--display); font-weight:800; font-size:1.5rem; line-height:1; }
.pcard .suit { font-size:1rem; line-height:1; }
.hand-row__total { margin-left:auto; text-align:right; }
.hand-row__total small { display:block; font-family:var(--mono); font-size:11px; color:var(--ink-faint); }
.hand-row__total b { font-family:var(--display); font-size:2.1rem; line-height:1; }
.hand-row__total b.win { color:var(--felt); }
.hand-result { margin-top:8px; padding-top:16px; border-top:1px solid var(--line-soft); display:flex; align-items:flex-start; gap:11px; font-size:.97rem; }
.hand-result svg { color:var(--felt); flex:none; margin-top:2px; }
.bets-3 { grid-template-columns:1fr 1fr 1fr; }
.variant-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.variant { background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-sm); }
.variant .card__icon { margin-bottom:14px; }
.variant h4 { font-family:var(--sans); font-size:1.1rem; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.variant p { margin:9px 0 0; color:var(--ink-soft); font-size:.94rem; line-height:1.55; }
.terms { display:grid; grid-template-columns:1fr 1fr; gap:0 36px; margin:0; }
.terms > div { padding:16px 0; border-bottom:1px solid var(--line-soft); }
.terms dt { font-family:var(--display); font-weight:700; font-size:1.2rem; color:var(--felt-deep); }
.terms dd { margin:6px 0 0; color:var(--ink-soft); font-size:.95rem; line-height:1.5; }
.mistakes { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.mistakes li { display:flex; gap:14px; align-items:flex-start; background:var(--player-tint); border:1px solid #ecccc8; border-radius:var(--r); padding:16px 18px; }
.mistakes .ic { flex:none; display:grid; place-items:center; width:30px; height:30px; border-radius:50%; background:#fff; color:var(--player); margin-top:1px; }
.mistakes .ic svg { width:17px; height:17px; }
.mistakes div { font-size:.96rem; line-height:1.5; }
.mistakes b { color:var(--player); }
.faq { display:flex; flex-direction:column; gap:10px; }
.faq details { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow-sm); overflow:hidden; }
.faq summary { list-style:none; cursor:pointer; padding:17px 20px; font-weight:700; font-size:1.02rem; display:flex; align-items:center; justify-content:space-between; gap:14px; }
.faq summary::-webkit-details-marker { display:none; }
.faq .faq-x { position:relative; width:16px; height:16px; flex:none; }
.faq .faq-x::before, .faq .faq-x::after { content:""; position:absolute; background:var(--felt); border-radius:2px; transition:transform .2s; }
.faq .faq-x::before { top:7px; left:0; width:16px; height:2px; }
.faq .faq-x::after { left:7px; top:0; width:2px; height:16px; }
.faq details[open] .faq-x::after { transform:rotate(90deg); opacity:0; }
.faq details p { margin:0; padding:0 20px 18px; color:var(--ink-soft); font-size:.97rem; line-height:1.6; }
.next-steps { margin-top:44px; background:var(--felt-deep); border-radius:var(--r-xl); padding:36px 38px; color:#fff; }
.next-steps h3 { color:#fff; font-size:1.6rem; margin-bottom:22px; font-family:var(--display); }
.next-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.next-card { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--r-lg); padding:20px; display:flex; flex-direction:column; gap:4px; transition:background .18s, transform .18s; color:#fff; }
.next-card:hover { background:rgba(255,255,255,.12); transform:translateY(-3px); }
.next-card .card__icon { background:var(--gold); color:#211806; width:42px; height:42px; margin-bottom:10px; }
.next-card .card__icon svg { width:22px; height:22px; }
.next-card b { font-size:1.1rem; }
.next-card span:last-child { color:rgba(255,255,255,.6); font-size:.86rem; }
/* defeat the prose/entry-content text-link styling inside the next-steps band */
.prose .next-grid a, .entry-content .next-grid a { color:#fff; text-decoration:none; font-weight:400; }
.prose .next-card b, .entry-content .next-card b { color:#fff; font-weight:700; }
/* same for the TOC sidebar when rendered next to entry-content */
.learn-toc a { text-decoration:none; }
/* the Next button must wrap — guide titles are longer than "strategy" */
.learn-nav__card .btn { white-space:normal; text-align:center; line-height:1.35; }

/* ============ STRATEGY HUB ============ */
.filter-bar { display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; margin-bottom:34px; padding-bottom:22px; border-bottom:1px solid var(--line); }
.filter-group { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.filter-lbl { font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin-right:4px; }
.chip { background:#fff; border:1px solid var(--line); color:var(--ink-soft); font-weight:600; font-size:.92rem; padding:9px 16px; border-radius:999px; transition:all .15s; }
.chip:hover { border-color:var(--felt); color:var(--felt); }
.chip.active { background:var(--felt); border-color:var(--felt); color:#fff; }
.chip.active:hover { color:#fff; } /* active = felt bg — keep text white, not felt-on-felt */
.chip--mini { padding:7px 13px; font-size:.85rem; }
.strat-card .strat-meta { display:flex; gap:26px; padding-top:16px; border-top:1px solid var(--line-soft); }
.strat-card .lbl { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:6px; }
.strat-card h3 { font-family:var(--display); font-weight:800; }
.math-band { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:46px; background:var(--felt-deep); border-radius:var(--r-xl); padding:38px 40px; color:#fff; }
.math-band__item b { font-family:var(--display); font-size:2.6rem; font-weight:800; color:var(--gold); display:block; line-height:1; }
.math-band__item span { display:block; margin-top:10px; color:rgba(255,255,255,.72); font-size:.95rem; }

/* ============ STRATEGY DETAIL ============ */
.detail-hero { background:var(--cream-deep); padding:40px 0 36px; border-bottom:1px solid var(--line); }
.detail-hero .wrap { position:relative; }
.detail-hero h1 { font-family:var(--display); font-weight:800; font-size:clamp(2.4rem,5vw,4rem); line-height:1.04; letter-spacing:-.015em; }
.detail-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:30px; padding-top:26px; border-top:1px solid var(--line); }
.dstat .lbl { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:8px; }
.dstat__v { font-weight:700; display:inline-flex; align-items:center; gap:7px; }
.detail-layout { display:grid; grid-template-columns:1fr 320px; gap:48px; align-items:start; }
.detail-main { max-width:none; }
.detail-side { position:sticky; top:90px; display:flex; flex-direction:column; gap:18px; }
.side-card { background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-sm); }
.side-dl { margin:0; display:flex; flex-direction:column; gap:0; }
.side-dl > div { display:flex; justify-content:space-between; align-items:center; padding:11px 0; border-bottom:1px solid var(--line-soft); }
.side-dl > div:last-child { border-bottom:0; }
.side-dl dt { color:var(--ink-soft); font-size:.92rem; }
.side-dl dd { margin:0; font-weight:700; display:inline-flex; align-items:center; gap:6px; }
.side-links { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.side-links a { display:flex; justify-content:space-between; align-items:center; gap:10px; padding:12px 0; border-bottom:1px solid var(--line-soft); font-weight:600; font-size:.95rem; color:var(--ink); }
.side-links li:last-child a { border-bottom:0; }
.side-links a:hover { color:var(--felt); }

/* shared step sequence (learn + strategy detail) */
.seq { display:flex; align-items:stretch; gap:14px 8px; flex-wrap:wrap; margin:1.6rem 0; }
.seq__step { flex:1; min-width:120px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:16px; text-align:center; }
.seq__step--win { border-color:var(--gold); background:var(--gold-tint); }
.seq__n { display:inline-grid; place-items:center; width:26px; height:26px; border-radius:50%; background:var(--felt); color:#fff; font-family:var(--mono); font-size:12px; font-weight:700; margin-bottom:8px; }
.seq__step b { display:block; font-family:var(--display); font-size:1.5rem; }
.seq__step .win { display:block; color:var(--felt); font-weight:700; font-size:.85rem; margin-top:4px; }
.seq__step small { display:block; color:var(--ink-faint); font-family:var(--mono); font-size:10.5px; margin-top:6px; }
.seq__arrow { display:flex; align-items:center; color:var(--ink-faint); font-size:1.3rem; }
.seq__step b { font-family:var(--sans); font-size:1.05rem; }
.seq__step.seq__step--win b, .seq__step b.win { font-family:var(--display); }

/* pros/cons (shared) */
.pc { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.pc__box { border-radius:var(--r-lg); padding:22px 24px; border:1px solid var(--line); }
.pc__box h4 { font-family:var(--sans); font-size:.85rem; text-transform:uppercase; letter-spacing:.1em; display:flex; align-items:center; gap:8px; margin-bottom:14px; }
.pc__box ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; font-size:.98rem; }
.pc__box li { display:flex; gap:10px; align-items:flex-start; }
.pc__box li .ic { flex:none; margin-top:2px; }
.pc__box li .ic svg { width:18px; height:18px; }
.pc--pro { background:var(--felt-tint); border-color:#cfe0d6; }
.pc--pro h4 { color:var(--felt-deep); }
.pc--con { background:var(--player-tint); border-color:#ecccc8; }
.pc--con h4 { color:var(--player); }

/* ============ ARTICLES INDEX ============ */
.feature-article { display:grid; grid-template-columns:1.1fr 1fr; gap:0; padding:0; overflow:hidden; }
.feature-article__img { border-radius:0; border:0; min-height:340px; height:100%; }

/* Featured-image media boxes — drop-in replacement for .ph placeholders.
   Keeps the same box class so card dimensions/aspect ratios still apply. */
.bbro-media { position:relative; overflow:hidden; background:var(--cream-deep); border-radius:var(--r); }
.bbro-media > img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.bbro-media--contain > img { object-fit:contain; padding:6px; }
.art-card .bbro-media { min-height:190px; border-radius:0; border-bottom:1px solid var(--line); }
.feature-article__img.bbro-media { border-radius:0; }
.feature-article__body { padding:38px 40px; display:flex; flex-direction:column; justify-content:center; }
.feature-article__body h2 { font-family:var(--display); font-weight:800; font-size:clamp(1.6rem,2.8vw,2.3rem); margin:14px 0 14px; }
.feature-article__body .muted { font-size:1.02rem; line-height:1.55; margin:0 0 18px; }
.cat-filter { margin:36px 0 28px; }

/* ============ SINGLE ARTICLE ============ */
.art-hero { padding:34px 0 30px; }
.art-hero h1 { font-family:var(--display); font-weight:800; font-size:clamp(2.1rem,4.4vw,3.3rem); max-width:18ch; line-height:1.05; }
.art-byline { display:flex; align-items:center; gap:14px; margin-top:26px; padding-top:22px; border-top:1px solid var(--line); }
.art-byline__bro .bro-emblem { width:50px; height:50px; }
.art-byline b { display:block; font-weight:700; }
.art-byline span { display:block; font-family:var(--mono); font-size:11.5px; color:var(--ink-faint); margin-top:2px; }
.art-cover { min-height:300px; border-radius:0; border-left:0; border-right:0; }
.art-tags { display:flex; gap:8px; flex-wrap:wrap; }
.art-tags .badge:hover { border-color:var(--felt); color:var(--felt); }
.related { margin:56px 0 72px; padding-top:36px; border-top:1px solid var(--line); }
.related h3 { font-family:var(--display); font-weight:800; font-size:1.5rem; margin-bottom:22px; }

/* ============ TOOLS ============ */
.calc { display:grid; grid-template-columns:.85fr 1.15fr; gap:0; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow); }
.calc__intro { background:var(--felt-deep); color:#fff; padding:40px; }
.calc__intro h2 { color:#fff; font-family:var(--display); font-weight:800; font-size:2rem; margin:14px 0 12px; }
.calc__intro .muted { color:rgba(255,255,255,.72); }
.calc__intro .bro-callout { margin:26px 0 0; }
.calc__panel { padding:40px; }
.calc__field { margin-bottom:24px; }
.calc__field > label { display:block; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:10px; font-weight:700; }
.calc__field .cur { color:var(--felt); }
.seg { display:flex; gap:6px; background:var(--cream-deep); padding:5px; border-radius:999px; }
.seg__btn { flex:1; display:inline-flex; align-items:center; justify-content:center; gap:7px; background:transparent; border:0; padding:11px; border-radius:999px; font-weight:700; font-size:.95rem; color:var(--ink-soft); transition:all .15s; }
.seg__btn.active { background:#fff; color:var(--felt); box-shadow:var(--shadow-sm); }
.seg__btn svg { width:16px; height:16px; }
.stake-input { display:flex; align-items:center; background:var(--cream); border:1.5px solid var(--line); border-radius:var(--r); padding:0 16px; margin-bottom:14px; }
.stake-input:focus-within { border-color:var(--felt); }
.stake-cur { font-family:var(--display); font-size:1.5rem; color:var(--felt); font-weight:700; }
.stake-input input { flex:1; border:0; background:transparent; font-family:var(--display); font-size:1.8rem; font-weight:700; padding:14px 8px; color:var(--ink); outline:none; -moz-appearance:textfield; }
.stake-input input::-webkit-outer-spin-button, .stake-input input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.slider { -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:999px; background:var(--cream-deep); outline:none; }
.slider::-webkit-slider-thumb { -webkit-appearance:none; width:22px; height:22px; border-radius:50%; background:var(--felt); border:3px solid #fff; box-shadow:var(--shadow-sm); cursor:pointer; }
.slider::-moz-range-thumb { width:18px; height:18px; border-radius:50%; background:var(--felt); border:3px solid #fff; cursor:pointer; }
.calc__results { margin-top:30px; }
.res { background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--r); padding:18px 20px; }
.res__lbl { display:block; font-family:var(--mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:6px; }
.res b { font-family:var(--display); font-weight:800; font-size:1.6rem; color:var(--ink); line-height:1; }
.res small { display:block; margin-top:8px; color:var(--ink-soft); font-size:.86rem; }
.res--win { background:var(--felt-tint); border-color:#cfe0d6; }
.res--win b { color:var(--felt-deep); font-size:2.2rem; }
.calc__grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:12px; }
.res--sm b { font-size:1.3rem; }
.res--loss b { color:var(--player); }
.calc__fine { font-size:.78rem; color:var(--ink-faint); margin-top:14px; line-height:1.5; }
.planner { display:grid; grid-template-columns:.85fr 1.15fr; gap:0; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow); margin-top:24px; }
.planner__intro { background:var(--gold-tint); border-right:1px solid #e8d9b4; padding:40px; }
.planner__intro h2 { font-family:var(--display); font-weight:800; font-size:2rem; margin:14px 0 12px; }
.planner__intro .bro-callout { margin:26px 0 0; }
.planner__panel { padding:40px; }
.planner__style-note { font-size:.86rem; color:var(--ink-soft); margin:12px 0 0; line-height:1.45; }
.planner__out { margin-top:30px; }
.loss-v { color:var(--player) !important; }
.res--sm b#pWin { color:var(--felt-deep); }
.planner__bar { margin-top:16px; }
.pbar { display:flex; align-items:stretch; height:18px; border-radius:999px; overflow:hidden; background:var(--cream-deep); border:1px solid var(--line-soft); }
.pbar__loss { background:repeating-linear-gradient(45deg, var(--player), var(--player) 6px, #a23b35 6px, #a23b35 12px); }
.pbar__start { width:4px; background:var(--ink); flex:none; }
.pbar__win { background:var(--felt); }
.pbar__legend { display:flex; gap:16px; margin-top:10px; font-size:11.5px; color:var(--ink-soft); font-family:var(--mono); }
.pbar__legend span { display:inline-flex; align-items:center; gap:6px; }
.pbar__legend .lg { width:11px; height:11px; border-radius:3px; }
.lg--loss { background:var(--player); } .lg--start { background:var(--ink); } .lg--win { background:var(--felt); }
.tool-card { display:flex; flex-direction:column; }
.tool-card .badge { align-self:flex-start; }

/* prose helper (article columns) */
.prose { font-size:1.12rem; line-height:1.75; color:var(--ink); }
.prose > * + * { margin-top:1.3rem; }
.prose h2 { font-family:var(--display); font-weight:800; font-size:1.9rem; margin-top:2.6rem; }
.prose h3 { font-family:var(--display); font-weight:800; font-size:1.4rem; margin-top:2rem; }
/* .prose p margin reset lives in baczim-source.css — duplicating it here would override theme.css flow spacing */
.prose ul, .prose ol { margin:0; padding-left:1.3em; }
.prose li + li { margin-top:.5rem; }
.prose blockquote { margin:0; padding:6px 0 6px 24px; border-left:4px solid var(--gold); font-family:var(--display); font-style:italic; font-size:1.35rem; color:var(--felt-deep); }
.prose a.link, .prose a { color:var(--felt); text-decoration:underline; text-decoration-color:var(--gold); text-underline-offset:3px; font-weight:600; }
.tbl { width:100%; border-collapse:collapse; font-size:.98rem; background:var(--paper); border-radius:var(--r); overflow:hidden; border:1px solid var(--line); }
.tbl th, .tbl td { padding:14px 16px; text-align:left; border-bottom:1px solid var(--line-soft); }
.tbl th { background:var(--felt-tint); font-family:var(--mono); font-size:11.5px; text-transform:uppercase; letter-spacing:.07em; color:var(--felt-deep); font-weight:700; }
.tbl tr:last-child td { border-bottom:0; }
.tbl .num { font-family:var(--mono); }

/* ---- responsive ---- */
@media (max-width:920px){
	.learn-layout { grid-template-columns:1fr; gap:26px; }
	.learn-nav { position:static; }
	/* Mobile TOC: clean one-per-row list with dividers (not wrapping pills). */
	.learn-toc { flex-direction:column; }
	.learn-toc a { padding:13px 2px; }
	.detail-layout { grid-template-columns:1fr; gap:32px; }
	.detail-side { position:static; }
	.detail-stats { grid-template-columns:1fr 1fr; }
}
@media (max-width:860px){
	.bets-3, .variant-grid, .terms, .next-grid { grid-template-columns:1fr; }
	.value-grid { grid-template-columns:repeat(2,1fr); }
	.math-band { grid-template-columns:1fr; gap:22px; padding:30px 26px; }
	.page-hero__bro { display:none; }
	.calc, .planner { grid-template-columns:1fr; }
	.pc { grid-template-columns:1fr; }
}

/* ===== Mobile overflow hardening (2026-06) ===========================
   Grid/flex items default to min-width:auto, so a wide child (a table, a
   long token, a fixed box) forces the column past the viewport — causing
   horizontal page scroll or clipped content. min-width:0 lets these columns
   shrink so their content wraps/scrolls inside its own box instead. */
.learn-main, .learn-nav,
.detail-main, .detail-side,
.rev-hero__main, .rev-hero__grid > *,
.calc__intro, .calc__panel,
.planner__intro, .planner__panel,
.seg__btn { min-width: 0; }

.detail-main, .detail-side,
.calc__intro, .calc__panel,
.rev-hero__main { overflow-wrap: anywhere; }

/* Wide data tables scroll inside their own box on small screens instead of
   widening the whole page. */
@media (max-width:860px){
	.entry-content table, .prose table,
	.bbro-odds__table, .detail-main table, .rev-main table {
		display:block;
		width:100%;
		max-width:100%;
		overflow-x:auto;
		-webkit-overflow-scrolling:touch;
	}
	/* The bbro data tables set `overflow:hidden !important` elsewhere (for rounded
	   corners) at higher specificity, which clips wide tables instead of letting
	   them scroll. Match that specificity + !important so they scroll on mobile. */
	.bbro-edition .entry-content table,
	.bbro-edition .entry-content table.bbro-odds__table,
	.bbro-edition .entry-content .bbro-odds__table,
	.bbro-edition .entry-content .bbro-3card table,
	.bbro-edition .entry-content .bbro-mart table,
	.bbro-edition .entry-content .bbro-ctable__table {
		display:block !important;
		overflow-x:auto !important;
		overflow-y:visible !important;
		-webkit-overflow-scrolling:touch;
	}
	/* segmented controls wrap rather than clip when labels are long. */
	.seg { flex-wrap:wrap; }
}

@media (max-width:820px){ .feature-article { grid-template-columns:1fr; } .feature-article__img { min-height:220px; } }
@media (max-width:640px){
	.hand-row__label { width:auto; font-size:.95rem; }
	.hand-row { flex-wrap:wrap; gap:10px; }
	.hand-row__total { margin-left:0; text-align:left; }
	.calc__intro, .calc__panel, .planner__intro, .planner__panel { padding:28px 24px; }
	.related .grid-3 { grid-template-columns:1fr; }
	/* step sequence stacks vertically: arrows point down, even spacing */
	.seq { flex-direction:column; align-items:stretch; gap:12px; }
	.seq__step { min-width:0; }
	.seq__arrow { transform:rotate(90deg); align-self:center; margin:-4px 0; }
}

/* ============================================================
   CASINO REVIEW (cloned from baczim2/casino-review.html)
   ============================================================ */
.rev-hero { background:var(--cream-deep); border-bottom:1px solid var(--line); padding:36px 0 44px; }
.rev-hero__grid { display:grid; grid-template-columns:1.25fr .75fr; gap:44px; margin-top:22px; align-items:start; }
.rev-hero__id { display:flex; align-items:center; gap:22px; }
.rev-logo { width:92px; height:92px; min-height:0; border-radius:22px; flex:none; }
.rev-logo img { width:100%; height:100%; object-fit:cover; border-radius:inherit; }
.rev-hero h1 { font-family:var(--display); font-weight:800; font-size:clamp(2.2rem,4.4vw,3.4rem); line-height:1.05; letter-spacing:-.015em; margin:0; }
.rev-trust { display:grid; grid-template-columns:repeat(4,auto); gap:30px; margin-top:28px; padding-top:24px; border-top:1px solid var(--line); justify-content:start; }
.rt__lbl { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:6px; }
.rt b { font-family:var(--display); font-size:1.35rem; font-weight:800; color:var(--felt-deep); display:block; line-height:1.1; }
.rt small { display:block; color:var(--ink-soft); font-size:.8rem; margin-top:3px; }

.score-card { background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); padding:28px; box-shadow:var(--shadow-lg); }
.score-card__top { text-align:center; padding-bottom:20px; border-bottom:1px solid var(--line-soft); }
.score-num b { font-family:var(--display); font-size:4rem; font-weight:900; color:var(--felt); line-height:1; }
.score-num span { font-size:1.1rem; color:var(--ink-faint); }
.score-card .stars { justify-content:center; display:flex; margin-top:6px; color:var(--gold); }
.score-verdict { font-family:var(--display); font-style:italic; font-size:1.02rem; color:var(--ink-soft); margin:12px 0 0; line-height:1.45; }
.score-bars { display:flex; flex-direction:column; gap:12px; padding:20px 0; border-bottom:1px solid var(--line-soft); }
.sbar { display:grid; grid-template-columns:118px 1fr 30px; align-items:center; gap:10px; font-size:.85rem; }
.sbar__lbl { color:var(--ink-soft); font-weight:600; }
.sbar__track { height:8px; border-radius:999px; background:var(--cream-deep); overflow:hidden; }
.sbar__track i { display:block; height:100%; width:var(--w); border-radius:999px; background:var(--felt); }
.sbar--low .sbar__track i { background:var(--player); }
.sbar b { font-family:var(--mono); font-size:.82rem; text-align:right; }
.score-bonus { text-align:center; padding:18px 0; }
.score-bonus .lbl { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.score-bonus b { display:block; font-family:var(--display); font-size:1.3rem; color:var(--felt-deep); margin-top:5px; }
.score-bonus small { display:block; color:var(--ink-soft); font-size:.8rem; margin-top:3px; }
.score-fine { text-align:center; font-size:.74rem; color:var(--ink-faint); margin:12px 0 0; }

.rev-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; padding-top:14px; }
.rev-layout > * { min-width:0; }
.rev-main { min-width:0; }
.rev-side { position:sticky; top:90px; display:flex; flex-direction:column; gap:18px; max-width:100%; }
.shot-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:6px 0 10px; }
.shot-row .ph { min-height:190px; }
.pay-chips { display:flex; flex-wrap:wrap; gap:8px; }

.verdict-band { display:flex; align-items:center; gap:30px; background:var(--felt); color:#fff; border-radius:var(--r-xl); padding:32px 36px; margin:44px 0 10px; }
.verdict-band__score { text-align:center; flex:none; }
.verdict-band__score b { font-family:var(--display); font-size:3.4rem; font-weight:900; color:var(--gold); line-height:1; }
.verdict-band__score span { color:rgba(255,255,255,.6); }
.verdict-band__score .stars { display:flex; justify-content:center; margin-top:4px; color:var(--gold); }
.verdict-band__text .says { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); font-weight:700; margin:0 0 8px; }
.verdict-band__text p:last-child { margin:0; font-size:1.05rem; line-height:1.6; color:#fff; }
.verdict-band__text strong { color:var(--gold); }
.verdict-band .btn { flex:none; }
.compare .tbl a.link { color:var(--felt); font-weight:600; text-decoration:underline; text-decoration-color:var(--gold); }

@media (max-width:1020px){
	.rev-hero__grid { grid-template-columns:1fr; gap:30px; }
	.rev-layout { grid-template-columns:1fr; gap:30px; }
	.rev-side { position:static; }
	.rev-trust { grid-template-columns:repeat(2,1fr); gap:20px; }
}
@media (max-width:640px){
	.rev-hero__id { flex-direction:column; align-items:flex-start; gap:16px; }
	.rev-logo { width:72px; height:72px; }
	.shot-row { grid-template-columns:1fr; }
	.verdict-band { flex-direction:column; text-align:center; padding:28px 24px; gap:18px; }
	.sbar { grid-template-columns:96px 1fr 28px; }
}


/* review sidebar refinements (reference variant of side-dl) */
.rev-side .side-dl > div { padding:10px 0; gap:12px; }
.rev-side .side-dl dt { font-size:.9rem; }
.rev-side .side-dl dd { display:block; font-weight:700; font-size:.9rem; text-align:right; }
/* reference h2 rhythm inside the review body */
.bbro-edition .rev-main h2 { font-size:1.8rem; margin:44px 0 16px; }
.bbro-edition .rev-main > h2:first-child { margin-top:34px; }
.bbro-edition .rev-main p { font-size:1.08rem; line-height:1.7; }

/* review tables scroll instead of forcing page overflow on small screens */
@media (max-width: 640px) {
	.rev-main table.tbl { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* "deep dive" cross-links inside the learn pillar */
.deep-dive { margin: 14px 0 0; font-size: .95rem; }

/* ---- learn page: mini "build a hand" scorer ---- */
.hand-builder { background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); padding:22px 24px; margin:1.4rem 0; }
.hand-builder .hb-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.hand-builder .hb-field { display:flex; flex-direction:column; gap:6px; }
.hand-builder .hb-field span { font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); font-weight:700; }
.hand-builder .hb-field em { text-transform:none; letter-spacing:0; font-weight:400; }
.hand-builder select { width:100%; padding:11px 12px; border:1px solid var(--line); border-radius:10px; font:inherit; font-size:1.05rem; font-weight:700; background:var(--cream); color:var(--ink); }
.hand-builder select:focus { outline:2px solid var(--gold); outline-offset:1px; }
.hand-builder .hb-out { display:flex; align-items:center; gap:20px; margin-top:18px; padding-top:18px; border-top:1px solid var(--line-soft); flex-wrap:wrap; }
.hand-builder .hb-out__score { display:flex; flex-direction:column; align-items:center; flex:none; }
.hand-builder .hb-out__lbl { font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); font-weight:700; }
.hand-builder .hb-out__score b { font-family:var(--display); font-weight:900; font-size:3rem; line-height:1; color:var(--felt); }
.hand-builder .hb-out__detail { margin:0; font-size:1rem; color:var(--ink-soft); }
.hand-builder .hb-note { margin:14px 0 0; font-size:.92rem; color:var(--ink-soft); }
@media (max-width:560px){ .hand-builder .hb-cards { grid-template-columns:1fr; } }

/* featured-article badge shouldn't stretch in the flex column */
.feature-article__body .badge { align-self: flex-start; }


/* ===== Relocated from inline <style> blocks → external stylesheet (2026-06-20) ===== */

/* --- homepage (edition-home.php) --- */
.hero__grid { display:grid; grid-template-columns: 1.15fr .85fr; gap:56px; align-items:center; }
.hero h1 { font-size: clamp(2.6rem, 5.4vw, 4.4rem); }
.hero__trust { display:flex; gap:40px; margin-top:42px; padding-top:30px; border-top:1px solid var(--line); }
.hero__card { position:relative; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); padding:34px; box-shadow:var(--shadow-lg); }
.hero__card-glow { position:absolute; inset:0; border-radius:var(--r-xl); background:radial-gradient(70% 60% at 70% 0%, rgba(199,154,75,.12), transparent 60%); pointer-events:none; }
.hero__bro { display:flex; justify-content:center; }
.hero__bro .bro-emblem { width:120px; height:120px; filter:drop-shadow(0 10px 22px rgba(10,58,43,.24)); }
.hero__speech { background:var(--felt); color:#fff; border-radius:var(--r-lg); padding:22px 24px; margin-top:24px; position:relative; }
.hero__speech::before { content:""; position:absolute; top:-12px; left:50%; transform:translateX(-50%); border-width:0 11px 13px 11px; border-style:solid; border-color:transparent transparent var(--felt) transparent; }
.hero__speech .says { font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); font-weight:700; margin:0 0 8px; }
.hero__speech p:last-child { margin:0; font-size:1.04rem; line-height:1.55; }
.hero__speech strong { color:var(--gold); }
.hero__chips { display:flex; gap:8px; justify-content:center; margin-top:22px; flex-wrap:wrap; }
.chip-tag { display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11.5px; font-weight:700; background:var(--cream); border:1px solid var(--line); padding:6px 12px; border-radius:999px; }
.card__icon svg { width:26px; height:26px; }
.tools-promo { display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.tools-promo__grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.tool-chip { display:flex; flex-direction:column; gap:12px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--r-lg); padding:22px; font-weight:700; transition:background .2s, transform .2s; color:#fff; }
.tool-chip:hover { background:rgba(255,255,255,.12); transform:translateY(-3px); }
.tool-chip__ic { display:grid; place-items:center; width:46px; height:46px; border-radius:12px; background:var(--gold); color:#211806; }
.tool-chip__ic svg { width:24px; height:24px; }
@media (max-width:920px){ .hero__grid { grid-template-columns:1fr; gap:36px; } .tools-promo { grid-template-columns:1fr; gap:32px; } }
@media (max-width:640px){ .hero__trust { gap:22px; flex-wrap:wrap; } .stat b { font-size:1.9rem; } }

/* --- casinos hub (page-casinos.php) --- */
.page-hero { padding:40px 0 8px; position:relative; overflow:hidden; }
.page-hero h1 { font-family:var(--display); font-weight:800; font-size:clamp(2.2rem,4.6vw,3.6rem); max-width:18ch; line-height:1.05; letter-spacing:-.015em; }
.region-tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:30px; padding-bottom:24px; border-bottom:1px solid var(--line); }
.rtab { display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--line); color:var(--ink-soft); font-weight:600; font-size:.95rem; padding:10px 18px; border-radius:999px; transition:all .15s; }
.rtab .flag { font-size:1.15rem; }
.rtab:hover { border-color:var(--felt); color:var(--felt); }
.rtab.active { background:var(--felt); border-color:var(--felt); color:#fff; }
.casino-list { display:flex; flex-direction:column; gap:20px; }
.casino-card { display:grid; grid-template-columns:auto auto 1fr 220px; gap:26px; align-items:start; position:relative; }
.casino-card__rank { font-family:var(--display); font-size:1.4rem; font-weight:800; color:var(--gold); width:30px; }
.casino-card__logo { width:88px; height:88px; min-height:0; border-radius:18px; }
.casino-card__logo--img { overflow:hidden; }
.casino-card__logo--img img { width:100%; height:100%; object-fit:cover; border-radius:18px; display:block; }
.casino-card__head { display:flex; justify-content:space-between; align-items:flex-start; gap:16px; }
.casino-card__head h3 { font-family:var(--display); font-weight:800; font-size:1.5rem; }
.casino-card .stars { margin-top:6px; font-size:1rem; color:var(--gold); display:inline-flex; gap:2px; }
.casino-card__feats { margin-top:16px; }
.casino-card__feats li { font-size:.95rem; }
.casino-card__feats svg { vertical-align:-2px; }
.bro-take { margin-top:16px; background:var(--felt-tint); border-radius:var(--r); padding:14px 16px; }
.bro-take__lbl { display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--felt-deep); font-weight:700; }
.bro-take p { margin:6px 0 0; font-size:.95rem; color:var(--ink); line-height:1.5; }
.casino-card__cta { display:flex; flex-direction:column; gap:10px; background:var(--cream); border-radius:var(--r-lg); padding:18px; border:1px solid var(--line-soft); }
.casino-card__bonus { text-align:center; margin-bottom:4px; }
.casino-card__bonus .lbl { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }
.casino-card__bonus b { display:block; font-family:var(--display); font-size:1.15rem; color:var(--felt-deep); margin-top:4px; line-height:1.2; }
.rate-band { margin-top:54px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); padding:42px 40px; }
.rate-band h2 { font-family:var(--display); font-weight:800; font-size:1.9rem; }
.rate-item .card__icon { margin-bottom:14px; }
.rate-item h4 { font-family:var(--sans); font-size:1.05rem; }
.rate-item p { margin:8px 0 0; color:var(--ink-soft); font-size:.93rem; line-height:1.5; }
@media (max-width:1080px){
	.casino-card { grid-template-columns:auto 1fr; grid-template-areas:"rank logo" "main main" "cta cta"; }
	.casino-card__rank { grid-area:rank; } .casino-card__logo { grid-area:logo; } .casino-card__main { grid-area:main; } .casino-card__cta { grid-area:cta; }
	.casino-card__cta { flex-direction:row; align-items:center; flex-wrap:wrap; }
	.casino-card__bonus { text-align:left; margin-bottom:0; margin-right:auto; }
	.casino-card__cta .btn { flex:1; min-width:140px; }
}
@media (max-width:560px){
	.casino-card { grid-template-columns:1fr; grid-template-areas:"logo" "main" "cta"; }
	.casino-card__rank { display:none; } .casino-card__logo { width:64px; height:64px; }
	.rate-band { padding:28px 22px; }
}

/* --- tool widgets (bbro-tools.php) --- */
.btool{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-sm);margin:1.8rem 0}
.bbro-toolpanel{margin:2.2rem 0}
.calc__panel .btool{background:none;border:0;border-radius:0;box-shadow:none;padding:0;margin:0}
.entry-content .bbro-toolpanel h2{margin-top:14px}
.btool .b-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px}
.btool label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:6px;font-weight:700}
.btool input,.btool select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:.98rem;background:var(--cream);color:var(--ink)}
.btool input:focus,.btool select:focus{outline:2px solid var(--gold);outline-offset:1px}
.btool .b-btn{display:inline-flex;align-items:center;gap:8px;background:var(--felt);color:#fff;border:0;border-radius:999px;padding:12px 22px;font:inherit;font-weight:700;font-size:.95rem;cursor:pointer}
.btool .b-btn:hover{background:var(--felt-bright);color:#fff}
.btool .b-btn--gold{background:var(--gold);color:#211806}.btool .b-btn--gold:hover{background:var(--gold-deep);color:#fff}
.btool .b-btn--ghost{background:var(--cream);color:var(--ink);border:1px solid var(--line)}.btool .b-btn--ghost:hover{background:var(--felt-tint);color:var(--felt)}
.btool .b-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:18px}
.btool .b-stat{background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;text-align:center}
.btool .b-stat b{display:block;font-family:var(--display);font-weight:800;font-size:1.55rem;color:var(--felt);line-height:1.15}
.btool .b-stat span{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:5px}
.btool .b-stat.is-bad b{color:var(--player)}.btool .b-stat.is-gold b{color:var(--gold-deep)}
.btool .b-note{font-size:.88rem;color:var(--ink-soft);margin-top:14px;line-height:1.5}
.btool .b-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btool .b-bars{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.btool .b-bar{display:grid;grid-template-columns:170px 1fr 86px;gap:12px;align-items:center;font-size:.92rem}
.btool .b-bar.is-hero .b-bar__name{color:var(--felt);font-weight:800}
.btool .b-bar__track{height:14px;border-radius:999px;background:var(--cream-deep);overflow:hidden}
.btool .b-bar__track i{display:block;height:100%;border-radius:999px;background:var(--felt)}
.btool .b-bar.is-bad .b-bar__track i{background:var(--player)}
.btool .b-bar__val{font-family:var(--mono);font-size:.82rem;text-align:right;white-space:nowrap}
.btool .b-roadwrap{overflow-x:auto;padding-bottom:6px}
.btool .b-road{display:grid;grid-auto-flow:column;grid-template-rows:repeat(6,24px);gap:3px;width:max-content;min-width:100%;background:var(--cream);border:1px solid var(--line-soft);border-radius:10px;padding:8px}
.btool .b-cell{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:10px;font-weight:700;color:#fff}
.btool .b-cell--b{background:var(--felt)}.btool .b-cell--p{background:var(--player)}.btool .b-cell--t{background:var(--gold);color:#211806}
.btool .b-cell--empty{background:transparent;border:1px dashed var(--line-soft)}
.btool .b-cell--ob{background:none;border:2.5px solid var(--felt)}.btool .b-cell--op{background:none;border:2.5px solid var(--player)}
.btool .b-cell--tie{position:relative}.btool .b-cell--tie::after{content:"";position:absolute;inset:9px 2px auto;height:3px;background:var(--gold);transform:rotate(-45deg);border-radius:2px}
.btool h4.b-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);margin:20px 0 8px}
.btool canvas{width:100%;height:240px;background:var(--cream);border:1px solid var(--line-soft);border-radius:10px;margin-top:16px}
.btool .b-table{width:100%;border-collapse:collapse;font-size:.92rem;margin-top:16px}
.btool .b-table th{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
.btool .b-table td{padding:9px 10px;border-bottom:1px solid var(--line-soft)}
.btool .b-pos{color:var(--felt);font-weight:700}.btool .b-neg{color:var(--player);font-weight:700}
.btool .b-flag{font-size:.78rem;color:var(--gold-deep);font-family:var(--mono)}
@media(max-width:640px){.btool{padding:18px}.btool .b-bar{grid-template-columns:110px 1fr 76px}}


/* --- viz shortcodes (relocated from bbro-visuals.php) --- */
/* ===== Hub vs article layout =====
	   The parent theme sets `.bbro-edition .entry-content > :where(p, h2, figure, ...)`
	   to `max-width: var(--reading)` (720px). Our hub overrides need !important
	   because the parent theme stylesheet loads later than this inline block. */
	body.bbro-layout-hub .grid-container,
	body.bbro-layout-hub .inside-article,
	body.bbro-layout-hub .site-content .content-area,
	body.bbro-layout-hub .entry-content,
	body.bbro-layout-hub .bbro-edition .entry-content{max-width:1320px !important}
	body.bbro-layout-hub .bbro-pagehero{padding-block:clamp(2rem,5vw,4.2rem);background:linear-gradient(180deg,#fbf8f2 0%,transparent 100%);border-bottom:1px solid #eee5cf}
	body.bbro-layout-hub .bbro-pagehero .bbro-container{max-width:1320px}
	body.bbro-layout-hub .bbro-pagehero__title{font-size:clamp(2.4rem,5.5vw,4rem);line-height:1.04;letter-spacing:-.015em}
	body.bbro-layout-hub .bbro-byline{font-size:.95rem}
	/* Keep body prose at reading-width inside hubs (still narrow + readable). */
	body.bbro-layout-hub .bbro-edition .entry-content > :where(p,ul,ol,blockquote,pre,.bbro-callout,.bbro-sources,.bbro-keytakeaways){max-width:760px !important;margin-left:auto !important;margin-right:auto !important}
	body.bbro-layout-hub .bbro-edition .entry-content > :where(h2,h3,h4){max-width:1100px !important;margin-left:auto !important;margin-right:auto !important}
	/* Visual components on hubs get the full wide canvas. Each rule on its
	   own line so the CSS parser cannot choke on a long comma list. */
	body.bbro-layout-hub .bbro-silogrid{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub figure.bbro-ctable{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub figure.bbro-odds{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub .bbro-3card{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub figure.bbro-mart{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub figure.bbro-bnkchart{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub .bbro-betcards{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub .bbro-stats{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub .bbro-dodont{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub .bbro-steps{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub .bbro-revhd{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub figure.wp-block-table{max-width:1240px !important;margin-left:auto !important;margin-right:auto !important;width:auto !important}
	body.bbro-layout-hub h2{font-size:clamp(1.5rem,2.3vw,2.1rem) !important;margin-top:2.5rem !important}

	/* ===== Silo grid (visual child-pages on hub pages) ===== */
	.bbro-silogrid{margin:2.5rem 0 3rem}
	.bbro-silogrid__heading{margin:0 0 1.3rem;font-size:clamp(1.3rem,2.6vw,1.8rem);font-weight:700;color:#1a1014;letter-spacing:-.01em}
	.bbro-silogrid__grid{display:grid;grid-template-columns:1fr;gap:14px}
	@media(min-width:640px){.bbro-silogrid__grid{grid-template-columns:repeat(2,1fr)}}
	@media(min-width:1024px){.bbro-silogrid--cols3 .bbro-silogrid__grid{grid-template-columns:repeat(3,1fr)} .bbro-silogrid--cols4 .bbro-silogrid__grid{grid-template-columns:repeat(4,1fr)}}
	.bbro-silogrid__card{display:grid;grid-template-rows:auto auto auto 1fr auto;gap:8px;padding:1.4rem 1.4rem 1.2rem;background:linear-gradient(180deg,#fff,#fbf8f2);border:1.5px solid #e5e0d7;border-radius:12px;text-decoration:none;color:inherit;box-shadow:0 1px 0 rgba(0,0,0,.02);transition:transform .15s,box-shadow .15s,border-color .15s;position:relative;overflow:hidden}
	.bbro-silogrid__card:before{content:"";position:absolute;left:0;top:0;width:4px;height:0;background:#dc2626;transition:height .25s}
	.bbro-silogrid__card:hover{transform:translateY(-3px);border-color:#9a8757;box-shadow:0 8px 22px rgba(0,0,0,.08);color:inherit}
	.bbro-silogrid__card:hover:before{height:100%}
	.bbro-silogrid__icon{font-size:1.6rem;color:#9a8757;line-height:1;margin-bottom:.3rem}
	.bbro-silogrid__title{margin:0;font-size:1.12rem;line-height:1.25;font-weight:700;color:#1a1014;letter-spacing:-.005em}
	.bbro-silogrid__desc{margin:.2rem 0 0;font-size:.92rem;color:#5a4f3c;line-height:1.5}
	.bbro-silogrid__arrow{margin-top:.7rem;font-size:.78rem;font-weight:700;color:#dc2626;letter-spacing:.08em;text-transform:uppercase}

	/* ===== Odds grid ===== */
	.bbro-odds{margin:1.5rem 0;padding:0;border:1px solid #e5e0d7;border-radius:8px;background:#fff;overflow:hidden}
	.bbro-odds__table{width:100%;border-collapse:collapse;font-size:.95rem;margin:0}
	.bbro-odds__table thead th{background:#1a1014;color:#fff8d8;font-weight:600;padding:12px 14px;text-align:left;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase}
	.bbro-odds__table tbody th{font-weight:600;color:#1a1014}
	.bbro-odds__table td,.bbro-odds__table tbody th{padding:10px 14px;border-top:1px solid #f0eee9}
	.bbro-odds__table tr.is-best{background:linear-gradient(90deg,rgba(34,197,94,.05),transparent)}
	.bbro-odds__table tr.is-ok{background:transparent}
	.bbro-odds__table tr.is-avoid{background:linear-gradient(90deg,rgba(220,38,38,.05),transparent);color:#7c1414}
	.bbro-odds__group th{background:#fbf8f2;color:#9a8757;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;padding:8px 14px;font-weight:700}
	.bbro-odds__verdict{display:inline-block;padding:2px 9px;border-radius:99px;font-size:.78rem;font-weight:600;letter-spacing:.04em}
	.bbro-odds__verdict.is-best{background:#dcfce7;color:#15803d}
	.bbro-odds__verdict.is-ok{background:#fef3c7;color:#92400e}
	.bbro-odds__verdict.is-avoid{background:#fee2e2;color:#991b1b}
	@media(max-width:640px){.bbro-odds__table{font-size:.85rem}.bbro-odds__table td,.bbro-odds__table tbody th{padding:8px 9px}}

	/* ===== Third-card table ===== */
	.bbro-3card{display:grid;grid-template-columns:1fr;gap:1.4rem;margin:1.5rem 0}
	@media(min-width:768px){.bbro-3card{grid-template-columns:1fr 1.6fr}}
	.bbro-3card__col{background:#fff;border:1px solid #e5e0d7;border-radius:8px;padding:1rem 1.1rem}
	.bbro-3card__title{margin:0 0 .75rem;font-weight:700;color:#1a1014;font-size:1.05rem}
	.bbro-3card__note{margin:.5rem 0 0;font-size:.85rem;color:#5a4f3c;line-height:1.5}
	.bbro-3card__table{width:100%;border-collapse:collapse;font-size:.92rem}
	.bbro-3card__table th[scope=row]{background:#fbf8f2;padding:8px 10px;text-align:left;font-weight:700;color:#1a1014;width:30%;border:1px solid #ece6da}
	.bbro-3card__table td{padding:8px 10px;border:1px solid #ece6da;background:#fff}
	.bbro-3card__table thead th{background:#1a1014;color:#fff8d8;padding:9px 10px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}
	.bbro-3card__pill{display:inline-block;padding:2px 10px;border-radius:99px;font-size:.85rem;font-weight:600}
	.bbro-3card__pill.is-draw{background:#dbeafe;color:#1e40af}
	.bbro-3card__pill.is-stand{background:#fef3c7;color:#92400e}
	.bbro-3card__pill.is-nat{background:#dcfce7;color:#15803d}

	/* ===== Score diagram ===== */
	.bbro-score{margin:1.5rem 0;padding:1.2rem;background:#fbf8f2;border:1px solid #e5e0d7;border-radius:10px}
	.bbro-score__rules{margin:0 0 1.2rem;padding-left:1.4rem;color:#1a1014;font-size:.95rem}
	.bbro-score__rules li{margin:.25rem 0}
	.bbro-score__examples{display:grid;grid-template-columns:1fr;gap:1rem}
	@media(min-width:768px){.bbro-score__examples{grid-template-columns:repeat(3,1fr)}}
	.bbro-score__ex{background:#fff;border:1px solid #e5e0d7;border-radius:8px;padding:.85rem 1rem;text-align:center}
	.bbro-score__exlabel{margin:0 0 .6rem;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:#9a8757;font-weight:700}
	.bbro-score__cards{display:flex;justify-content:center;gap:.4rem;margin:.4rem 0 .7rem}
	.bbro-card{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:48px;height:64px;background:#fff;border:1.5px solid #1a1014;border-radius:6px;font-family:"Georgia",serif;color:#1a1014;box-shadow:0 2px 0 #d4cfc2}
	.bbro-card.is-red{color:#dc2626}
	.bbro-card__rank{font-size:1.1rem;font-weight:700;line-height:1}
	.bbro-card__suit{font-size:1.2rem;line-height:1;margin-top:2px}
	.bbro-score__math{margin:.4rem 0 .3rem;font-size:.95rem;color:#1a1014}
	.bbro-score__final{color:#dc2626;font-weight:700}
	.bbro-score__note{margin:.3rem 0 0;font-size:.82rem;color:#5a4f3c;line-height:1.4}

	/* ===== Martingale progression ===== */
	.bbro-mart{margin:1.5rem 0;background:#fff;border:1px solid #e5e0d7;border-radius:8px;overflow:hidden}
	.bbro-mart__table{width:100%;border-collapse:collapse;font-size:.95rem;margin:0}
	.bbro-mart__table thead th{background:#1a1014;color:#fff8d8;padding:12px 14px;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;text-align:left}
	.bbro-mart__table td,.bbro-mart__table tbody th{padding:10px 14px;border-top:1px solid #f0eee9}
	.bbro-mart__table tbody th{font-weight:700;color:#1a1014;background:#fbf8f2;width:80px}
	.bbro-mart__table tr.is-danger{background:#fef3c7}
	.bbro-mart__table tr.is-broke{background:#fee2e2;color:#7c1414}
	.bbro-mart__caption{padding:.9rem 1rem;color:#5a4f3c;font-size:.88rem;background:#fbf8f2;border-top:1px solid #e5e0d7;line-height:1.5}
	.bbro-mart__recover{margin:0;padding:.9rem 1rem;background:#fef3c7;color:#7c1414;font-size:.92rem;border-top:1px solid #e5e0d7;line-height:1.5}

	/* ===== Bankroll chart ===== */
	.bbro-bnkchart{margin:1.5rem 0;background:#fff;border:1px solid #e5e0d7;border-radius:8px;padding:1.2rem 1.2rem .8rem}
	.bbro-bnkchart__canvaswrap{max-width:100%;margin:0 auto;position:relative;height:320px}
	.bbro-bnkchart__caption{margin-top:.7rem;color:#5a4f3c;font-size:.86rem;line-height:1.5}

	/* ===== Casino table ===== */
	.bbro-ctable{margin:1.5rem 0;background:#fff;border:1px solid #e5e0d7;border-radius:8px;overflow:hidden;overflow-x:auto}
	.bbro-ctable__table{width:100%;border-collapse:collapse;font-size:.92rem;margin:0}
	.bbro-ctable__table thead th{background:#1a1014;color:#fff8d8;padding:12px 14px;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;text-align:left}
	.bbro-ctable__table tbody td{padding:11px 14px;border-top:1px solid #f0eee9;vertical-align:middle}
	.bbro-ctable__table .is-rank{font-family:"Georgia",serif;font-weight:700;font-size:1.05rem;color:#9a8757;width:60px}
	.bbro-ctable__table .is-name a{color:#1a1014;font-weight:700;text-decoration:none}
	.bbro-ctable__table .is-name a:hover{color:#dc2626;text-decoration:underline}
	.bbro-ctable__score{display:inline-block;font-weight:700;font-size:1.05rem;padding:4px 11px;border-radius:6px}
	.bbro-ctable__score.is-good{background:#dcfce7;color:#15803d}
	.bbro-ctable__score.is-ok{background:#fef3c7;color:#92400e}
	.bbro-ctable__score.is-warn{background:#fee2e2;color:#991b1b}
	.bbro-ctable__cta{display:inline-block;padding:7px 12px;background:#1a1014;color:#fff8d8;border-radius:6px;text-decoration:none;font-weight:600;font-size:.85rem;white-space:nowrap}
	.bbro-ctable__cta:hover{background:#dc2626;color:#fff}
	.bbro-ctable__table .is-cta{text-align:right;white-space:nowrap;min-width:130px}
	/* Keep narrow text-y columns from sprawling so the CTA has room */
	.bbro-ctable__table thead th:nth-child(7){max-width:160px}
	.bbro-ctable__table tbody td:nth-child(7){max-width:160px;font-size:.85rem}
	@media(max-width:768px){.bbro-ctable__table{font-size:.85rem}.bbro-ctable__table thead{display:none}.bbro-ctable__table tr{display:grid;grid-template-columns:60px 1fr;gap:6px;padding:14px;border-top:1px solid #f0eee9}.bbro-ctable__table td{padding:0;border:0}.bbro-ctable__table .is-rank{grid-row:1}.bbro-ctable__table .is-name{grid-row:1;font-size:1.05rem}.bbro-ctable__table td:not(.is-rank):not(.is-name){grid-column:1/-1}}

	/* ===== Review scorecard header ===== */
	.bbro-revhd{margin:1.5rem 0;border:2px solid;border-radius:12px;padding:1.5rem;position:relative;overflow:hidden}
	.bbro-revhd--good{border-color:#22c55e;background:linear-gradient(135deg,#f0fdf4,#fff)}
	.bbro-revhd--ok{border-color:#9a8757;background:linear-gradient(135deg,#fefce8,#fff)}
	.bbro-revhd--warn{border-color:#f59e0b;background:linear-gradient(135deg,#fff7ed,#fff)}
	.bbro-revhd--avoid{border-color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fff)}
	.bbro-revhd__top{display:grid;grid-template-columns:1fr auto;gap:1.2rem;align-items:start;padding-bottom:1rem;border-bottom:1px dashed #e5e0d7;margin-bottom:1rem}
	.bbro-revhd__brand{margin:0 0 .3rem;font-size:1.6rem;line-height:1.1;color:#1a1014;font-weight:800}
	.bbro-revhd__verdict{margin:0;color:#1a1014;font-size:1rem;font-weight:600;opacity:.85}
	.bbro-revhd__score{text-align:right;line-height:1}
	.bbro-revhd__score-num{font-family:"Georgia",serif;font-size:3.5rem;font-weight:700;color:#1a1014;line-height:1}
	.bbro-revhd__score-max{font-size:1.2rem;color:#9a8757;margin-left:2px}
	.bbro-revhd--good .bbro-revhd__score-num{color:#15803d}
	.bbro-revhd--warn .bbro-revhd__score-num{color:#b45309}
	.bbro-revhd--avoid .bbro-revhd__score-num{color:#991b1b}
	.bbro-revhd__score-lbl{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#9a8757;margin-top:6px;font-weight:600}
	.bbro-revhd__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem 1rem;margin:0}
	.bbro-revhd__cell{display:flex;flex-direction:column;gap:2px}
	.bbro-revhd__cell dt{font-size:.72rem;color:#9a8757;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
	.bbro-revhd__cell dd{margin:0;font-size:.92rem;color:#1a1014;font-weight:600;line-height:1.3}
	@media(max-width:560px){.bbro-revhd__top{grid-template-columns:1fr;gap:.6rem}.bbro-revhd__score{text-align:left}.bbro-revhd__brand{font-size:1.35rem}.bbro-revhd__score-num{font-size:2.6rem}}

/* === Casino hub — rich sections (hero quick-picks, buyer's guide, payments, legality, callout) === */
.hero-quickpicks{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:26px;max-width:680px}
.qpick{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;display:flex;flex-direction:column;gap:3px;transition:transform .15s,box-shadow .2s,border-color .15s}
.qpick:hover{transform:translateY(-3px);box-shadow:var(--shadow,0 8px 24px rgba(0,0,0,.08));border-color:var(--gold)}
.qpick__lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:700}
.qpick__name{font-family:var(--display);font-weight:800;font-size:1.15rem;line-height:1.1}
.qpick__score{font-size:.8rem;color:var(--felt);font-weight:700}
.hub-block{margin-top:60px;padding-top:54px;border-top:1px solid var(--line)}
.hub-block .section-head h2{font-size:clamp(1.6rem,3vw,2.3rem)}
.hub-block .section-head .muted,.hub-block .section-head .eyebrow+h2+p{max-width:60ch}
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.guide-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-sm)}
.guide-item .card__icon{margin-bottom:16px;color:var(--felt)}
.guide-item h3{font-size:1.2rem}
.guide-item p{margin:10px 0 0;color:var(--ink-soft);font-size:.94rem;line-height:1.6}
.pay-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pay-col{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 26px}
.pay-col h4{font-family:var(--sans);font-size:1rem;display:flex;align-items:center;gap:9px;margin-bottom:16px}
.pay-col h4 svg{width:20px;height:20px;color:var(--felt)}
.pay-col .feature-list li{font-size:.94rem;align-items:flex-start}
.pay-col .feature-list svg{flex:none;margin-top:2px;color:var(--felt)}
.legal-box{display:flex;gap:22px;background:var(--gold-tint);border:1px solid #e8d9b4;border-radius:var(--r-lg);padding:30px 32px}
.legal-box__icon{flex:none;width:52px;height:52px;border-radius:14px;background:#fff;display:grid;place-items:center;color:var(--gold-deep)}
.legal-box__icon svg{width:28px;height:28px}
.legal-box p{margin:0;font-size:1.02rem;line-height:1.65;color:var(--ink)}
@media(max-width:860px){.hero-quickpicks{grid-template-columns:1fr;max-width:none}.guide-grid,.pay-cols{grid-template-columns:1fr}.legal-box{flex-direction:column;gap:16px}}

/* === Hover glossary: decorated terms + shared tooltip (glossary.js) === */
.entry-content .bbro-gloss{border-bottom:1px dashed var(--gold-deep,#a9842f);cursor:help;}
.entry-content .bbro-gloss:hover,.entry-content .bbro-gloss:focus-visible{color:var(--felt,#0f4f3c);border-bottom-color:var(--felt,#0f4f3c);outline:none;}
#bbro-gloss-tip{position:absolute;left:0;top:0;z-index:1000;max-width:280px;background:#0f1c17;color:#f6f1e7;padding:11px 14px;border-radius:10px;font-size:.86rem;line-height:1.5;box-shadow:0 12px 34px rgba(10,30,23,.35);pointer-events:none;display:none;}
#bbro-gloss-tip.is-visible{display:block;}
#bbro-gloss-tip b{display:block;color:#d8b25a;font-family:var(--display);font-weight:800;margin-bottom:3px;}
#bbro-gloss-tip::after{content:"";position:absolute;left:var(--arrow-x,50%);transform:translateX(-50%);border:6px solid transparent;}
#bbro-gloss-tip[data-flip="up"]::after{top:100%;border-top-color:#0f1c17;}
#bbro-gloss-tip[data-flip="down"]::after{bottom:100%;border-bottom-color:#0f1c17;}
