/* jackpotmegabet.com — betting-native, mobile-first, <50KB */
:root{
 --bg:#0a0a0a;
 --surface:#151515;
 --surface-2:#1f1f1f;
 --border:#2a2a2a;
 --text:#f5f5f5;
 --dim:#9a9a9a;
 --accent:#ff6a00;
 --accent-hot:#ff3d00;
 --ok:#00e676;
 --warn:#ffd600;
 --bad:#ff1744;
 --pick-1:#00e676;
 --pick-x:#ffd600;
 --pick-2:#ff1744;
 --pick-dc:#29b6f6;
 --display:"Anton",Impact,"Arial Narrow Bold",sans-serif;
 --body:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;
 --w:min(100% - 1.5rem,1120px);
}
*,*::before,*::after{box-sizing:border-box}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.5;font-feature-settings:"tnum" 1,"lnum" 1}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-hot)}
a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
button{font:inherit}
/* Global table baseline. Every <table> the LLM or PHP emits must be readable
   on the dark theme out of the box, with visible cell borders + an accent
   header row. Per-class rules (.match-table etc) only override specifics.
   NEVER ship a <table> without this baseline applying. */
table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.9rem;border:1px solid var(--border);background:rgba(255,255,255,.02)}
table th,table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;line-height:1.5}
table th{font-family:var(--display);font-weight:400;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem;color:var(--accent);background:#000}
table tbody tr:nth-child(even){background:var(--surface)}
table tbody tr:hover{background:var(--surface-2)}
table tbody tr:last-child td{border-bottom:0}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:.02em;text-transform:uppercase;margin:0 0 .5rem;line-height:1.05;color:var(--text)}
h1{font-size:clamp(1.75rem,5vw + .5rem,3rem);letter-spacing:.01em}
h2{font-size:clamp(1.25rem,3vw + .25rem,1.75rem);margin:2rem 0 1rem;padding:.25rem 0 .25rem .75rem;border-left:4px solid var(--accent);position:relative}
h3{font-size:1.1rem}
h4{font-size:.85rem;letter-spacing:.08em;color:var(--dim)}
p{margin:0 0 1rem}
hr{border:0;border-top:1px solid var(--border);margin:2rem 0}

.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;background:var(--accent);color:#000;padding:.5rem 1rem;z-index:100;font-weight:700}

/* header */
.site-header{background:#000;border-bottom:2px solid var(--accent)}
.site-header,.site-content,.site-footer{width:var(--w);margin:0 auto}
.site-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;gap:1rem;flex-wrap:wrap}
.site-branding a{font-family:var(--display);font-size:1.5rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text);display:inline-block}
.site-branding a::first-letter{color:var(--accent)}
.primary-nav ul{display:flex;gap:.25rem;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.primary-nav a{display:block;padding:.5rem .75rem;font-family:var(--display);letter-spacing:.06em;text-transform:uppercase;color:var(--text);font-size:.9rem}
.primary-nav a:hover{background:var(--accent);color:#000}

/* main wrappers */
main{display:block;padding:1rem 0 3rem}
.breadcrumbs{font-size:.8rem;color:var(--dim);padding:.5rem 0 1rem;text-transform:uppercase;letter-spacing:.08em}
.breadcrumbs a{color:var(--dim)}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs span[aria-current]{color:var(--text)}

/* trust bar — metrics strip */
.trust-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:2px;list-style:none;margin:1rem 0;padding:0;background:var(--border);border:1px solid var(--border)}
.trust-bar li{display:flex;flex-direction:column;background:var(--surface);padding:.75rem 1rem;gap:.125rem}
.trust-bar .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--dim)}
.trust-bar .v{font-family:var(--display);font-size:1.5rem;color:var(--text);letter-spacing:.02em}

/* affiliate CTA — the money button */
.cta-affiliate{display:block;width:100%;text-align:center;padding:1.1rem 1rem;background:var(--accent);color:#000;font-family:var(--display);font-size:clamp(1.15rem,3vw,1.5rem);letter-spacing:.06em;text-transform:uppercase;text-decoration:none;margin:1.25rem 0;border:3px solid #000;box-shadow:6px 6px 0 0 var(--accent-hot);transition:transform .08s ease,box-shadow .08s ease}
.cta-affiliate:hover{color:#000;background:#ffa14a;transform:translate(-2px,-2px);box-shadow:8px 8px 0 0 var(--accent-hot)}
.cta-affiliate:active{transform:translate(2px,2px);box-shadow:2px 2px 0 0 var(--accent-hot)}
.cta-affiliate small{display:block;font-family:var(--body);font-size:.7rem;font-weight:600;letter-spacing:.08em;opacity:.8;margin-top:.25rem}

/* hero */
.hero{padding:2rem 0 1rem;position:relative}
.hero h1{max-width:18ch}
.hero .sub{color:var(--dim);max-width:60ch;font-size:1rem}
.hero-card{display:block;margin-top:1.5rem;padding:1.25rem;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--accent);text-decoration:none;color:inherit;position:relative;overflow:hidden}
.hero-card::before{content:"";position:absolute;top:0;right:0;width:80px;height:80px;background:var(--accent);clip-path:polygon(100% 0,100% 100%,0 0);opacity:.15}
.hero-card .label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:700}
.hero-card strong{display:block;font-family:var(--display);font-size:1.5rem;margin:.25rem 0;letter-spacing:.02em}
.hero-card .cta{display:inline-block;margin-top:.75rem;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}

/* match table — data-dense, tabular */
.match-table{font-size:.9rem;margin:1rem 0;border:1px solid var(--border)}
.match-table th,.match-table td{padding:.6rem .5rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
.match-table thead{background:#000}
.match-table th{font-family:var(--display);font-weight:400;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem;color:var(--accent)}
.match-table tbody tr:nth-child(even){background:var(--surface)}
.match-table tbody tr:hover{background:var(--surface-2)}
.match-table td.num,.match-table td.odds{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.match-table .match-teams{font-weight:600}
.match-table .league{color:var(--dim);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}

/* pick pills */
.pick{display:inline-block;padding:.15rem .55rem;background:var(--surface-2);font-family:var(--display);letter-spacing:.04em;color:var(--text);border:1px solid var(--border);font-size:.9rem;min-width:1.75rem;text-align:center}
.pick-1{background:var(--pick-1);color:#000;border-color:var(--pick-1)}
.pick-x{background:var(--pick-x);color:#000;border-color:var(--pick-x)}
.pick-2{background:var(--pick-2);color:#fff;border-color:var(--pick-2)}
.pick-1x,.pick-x2,.pick-dc{background:var(--pick-dc);color:#000;border-color:var(--pick-dc)}
.pick-over,.pick-bts{background:var(--ok);color:#000;border-color:var(--ok)}
.pick-under,.pick-no-bts{background:var(--warn);color:#000;border-color:var(--warn)}
.section-sub{color:var(--dim);margin:-0.25rem 0 1rem;font-size:.95rem}
.today-top-picks{margin-top:2rem}
.home-trust-bar{margin-bottom:1.5rem}
.prob-legend{color:var(--dim);font-size:.8rem;margin:.4rem 0 1.25rem;line-height:1.45;font-style:italic}

/* confidence bar */
.confidence-bar{position:relative;background:var(--surface-2);height:22px;min-width:80px;border:1px solid var(--border);overflow:hidden}
.confidence-bar span{display:block;height:100%}
.confidence-bar.conf-high span{background:var(--ok)}
.confidence-bar.conf-mid span{background:var(--warn)}
.confidence-bar.conf-low span{background:var(--bad)}
.confidence-bar em{position:absolute;inset:0;text-align:center;font-style:normal;font-family:var(--display);letter-spacing:.04em;font-size:.8rem;line-height:22px;color:#000;mix-blend-mode:screen;filter:invert(1)}

/* result marker */
.result-ok{color:var(--ok);font-weight:700}
.result-bad{color:var(--bad);font-weight:700}
td.result-won{color:var(--ok);font-weight:700}
td.result-lost{color:var(--bad);font-weight:700}

/* country facts list */
.country-facts{list-style:none;padding:0;margin:1.5rem 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.5rem;background:var(--surface);border:1px solid var(--border);padding:1rem}
.country-facts li{padding:.3rem 0;font-size:.9rem}
.country-facts strong{color:var(--accent);margin-right:.4rem}

/* standings form */
.form-pill{display:inline-block;width:18px;height:18px;line-height:18px;text-align:center;border-radius:3px;font-size:.7rem;font-weight:700;margin-right:2px;color:#000}
.form-pill.form-w{background:var(--ok)}
.form-pill.form-d{background:var(--dim);color:#fff}
.form-pill.form-l{background:var(--bad);color:#fff}

/* jackpot card grid */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin:1.25rem 0}
.jackpot-card{display:block;padding:1rem;background:var(--surface);border:1px solid var(--border);text-decoration:none;color:inherit;position:relative;transition:border-color .1s ease,transform .1s ease}
.jackpot-card::before{content:"";position:absolute;top:0;left:0;width:36px;height:36px;background:var(--accent);clip-path:polygon(0 0,100% 0,0 100%)}
.jackpot-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.jackpot-card .title{display:block;font-family:var(--display);font-size:1.25rem;letter-spacing:.02em;margin-bottom:.5rem;padding-left:.25rem}
.jackpot-card dl{display:grid;grid-template-columns:auto 1fr;gap:.2rem .75rem;margin:.5rem 0;font-size:.85rem}
.jackpot-card dt{color:var(--dim);text-transform:uppercase;font-size:.7rem;letter-spacing:.1em;align-self:center}
.jackpot-card dd{margin:0;font-variant-numeric:tabular-nums}
.jackpot-card .cta{color:var(--accent);font-family:var(--display);font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;display:block;margin-top:.75rem}

/* tile grid — country/league tiles */
.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem;margin:1rem 0}
.tile{display:flex;align-items:center;justify-content:center;padding:1.25rem .5rem;background:var(--surface);border:1px solid var(--border);text-align:center;text-decoration:none;color:var(--text);font-family:var(--display);letter-spacing:.04em;text-transform:uppercase;font-size:1rem;transition:background .1s ease,color .1s ease,border-color .1s ease}
.tile:hover{background:var(--accent);color:#000;border-color:var(--accent)}

/* accordion (analysis + faq) */
.analysis details,.faq details{border:1px solid var(--border);margin:.5rem 0;background:var(--surface)}
.analysis summary,.faq summary{cursor:pointer;padding:.75rem 1rem;font-weight:700;list-style:none;display:flex;align-items:center;gap:.75rem;font-size:.95rem}
.analysis summary::-webkit-details-marker,.faq summary::-webkit-details-marker{display:none}
.analysis summary::before,.faq summary::before{content:"+";font-family:var(--display);color:var(--accent);font-size:1.25rem;width:1rem;text-align:center}
.analysis details[open] summary::before,.faq details[open] summary::before{content:"−"}
.analysis summary:hover,.faq summary:hover{background:var(--surface-2)}
.analysis .analysis-body,.faq .faq-body{padding:.25rem 1rem 1rem 2.25rem;color:var(--dim);font-size:.9rem;line-height:1.65}
.analysis .analysis-body p:last-child,.faq .faq-body p:last-child{margin-bottom:0}

/* accuracy widget */
.accuracy-widget{margin:1.5rem 0}
.accuracy-widget ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:2px;background:var(--border);border:1px solid var(--border)}
.accuracy-widget li{display:flex;flex-direction:column;gap:.125rem;padding:.75rem;background:var(--surface);align-items:flex-start}
.accuracy-widget .label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--dim)}
.accuracy-widget .count{font-family:var(--display);font-size:1.35rem;color:var(--ok);letter-spacing:.02em;font-variant-numeric:tabular-nums}

/* responsible gambling strip */
.responsible-gambling{margin:2.5rem 0 0;padding:1rem 1.25rem;background:var(--surface);border-left:4px solid var(--bad);font-size:.85rem;color:var(--dim);line-height:1.6}
.responsible-gambling strong{color:var(--text);text-transform:uppercase;letter-spacing:.08em;font-family:var(--display);font-weight:400;font-size:1rem;display:block;margin-bottom:.25rem}

/* footer */
.site-footer{border-top:2px solid var(--accent);margin-top:3rem;padding:2rem 0 1rem;background:#000}
.footer-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1.5rem;margin-bottom:1.5rem}
.footer-columns h4{margin:0 0 .75rem;color:var(--accent);font-size:.85rem;letter-spacing:.14em}
.footer-columns ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}
.footer-columns a{color:var(--dim);font-size:.85rem}
.footer-columns a:hover{color:var(--accent)}
.bottom-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.75rem;color:var(--dim);text-transform:uppercase;letter-spacing:.08em;flex-wrap:wrap}
.bottom-bar .age{display:inline-block;padding:.15rem .5rem;border:2px solid var(--bad);color:var(--bad);font-family:var(--display);letter-spacing:.04em}

/* bookmaker review specifics */
.quick-facts{background:var(--surface);border:1px solid var(--border);border-top:4px solid var(--accent);padding:1rem;margin:1rem 0}
.quick-facts dl{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;margin:0;font-size:.9rem}
.quick-facts dt{color:var(--dim);text-transform:uppercase;font-size:.7rem;letter-spacing:.1em;align-self:center}
.quick-facts dd{margin:0}
.rating-badge{display:inline-flex;align-items:baseline;gap:.5rem;padding:.5rem .75rem;background:var(--accent);color:#000;font-family:var(--display);font-size:1.5rem;letter-spacing:.02em;margin:.5rem 0}
.rating-badge small{font-size:.8rem;opacity:.7}
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.5rem 0}
.pros-cons>div{padding:1rem;background:var(--surface);border:1px solid var(--border)}
.pros-cons h4{font-size:.9rem;margin-bottom:.5rem}
.pros-cons .pros{border-top:3px solid var(--ok)}
.pros-cons .cons{border-top:3px solid var(--bad)}
.pros-cons ul{margin:0;padding-left:1rem;font-size:.85rem}

/* status/countdown */
.status-bar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;padding:.75rem 1rem;background:var(--surface);border-left:4px solid var(--ok);margin:1rem 0;font-size:.9rem}
.status-bar .dot{display:inline-block;width:.5rem;height:.5rem;background:var(--ok);border-radius:50%;box-shadow:0 0 0 0 rgba(0,230,118,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(0,230,118,.6)}70%{box-shadow:0 0 0 8px rgba(0,230,118,0)}100%{box-shadow:0 0 0 0 rgba(0,230,118,0)}}

/* filter pills */
.filters{display:flex;flex-wrap:wrap;gap:.375rem;margin:1rem 0;list-style:none;padding:0}
.filters a{padding:.4rem .8rem;background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--display);font-size:.8rem;letter-spacing:.06em;text-transform:uppercase}
.filters a:hover,.filters a[aria-current="true"]{background:var(--accent);color:#000;border-color:var(--accent)}

/* archive / post list */
.post-list{list-style:none;padding:0;margin:0}
.post-list li{padding:.75rem 0;border-bottom:1px solid var(--border)}
.post-list a{color:var(--text);font-weight:600}
.post-list a:hover{color:var(--accent)}

/* primary nav menu — fallback list */
.primary-nav .menu,.primary-nav ul.menu{display:flex;gap:.25rem;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.primary-nav .menu-item a{display:block;padding:.5rem .75rem;font-family:var(--display);letter-spacing:.06em;text-transform:uppercase;color:var(--text);font-size:.9rem}
.primary-nav .menu-item a:hover{background:var(--accent);color:#000}

/* contact + advertise forms */
.jackpot-form{margin:1.25rem 0;display:flex;flex-direction:column;gap:.85rem;max-width:560px}
.jackpot-form .form-row{display:flex;flex-direction:column;gap:.3rem}
.jackpot-form label{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);font-family:var(--display);font-weight:400}
.jackpot-form .req{color:var(--accent)}
.jackpot-form input[type=text],.jackpot-form input[type=email],.jackpot-form select,.jackpot-form textarea{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.6rem .75rem;font:inherit;font-size:.95rem;width:100%;border-radius:0}
.jackpot-form input:focus,.jackpot-form select:focus,.jackpot-form textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.jackpot-form textarea{resize:vertical;min-height:140px;font-family:var(--body)}
.jackpot-form .form-submit{font-family:var(--display);font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase;background:var(--accent);color:#000;border:0;padding:.85rem 1.5rem;cursor:pointer;align-self:flex-start;border:3px solid #000;box-shadow:4px 4px 0 0 var(--accent-hot);transition:transform .08s ease,box-shadow .08s ease}
.jackpot-form .form-submit:hover{background:#ffa14a;transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--accent-hot)}
.jackpot-form .form-submit:active{transform:translate(2px,2px);box-shadow:1px 1px 0 0 var(--accent-hot)}
.jackpot-form-hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.form-banner{padding:.85rem 1rem;margin:1rem 0;border-left:4px solid var(--accent);background:var(--surface);font-size:.95rem}
.form-banner-ok{border-left-color:var(--ok)}
.form-banner-err{border-left-color:var(--bad)}

/* legal / long-form content */
.legal{max-width:72ch}
.legal h2{margin-top:2rem}
.legal ul,.legal ol{padding-left:1.25rem}
.legal-page .legal-body{max-width:72ch}
.legal-page .legal-body h2{margin-top:2rem}
.legal-page .legal-body ul,.legal-page .legal-body ol{padding-left:1.25rem}
.legal-page .legal-body table{margin:1.25rem 0;border:1px solid var(--border);font-size:.9rem}
.legal-page .legal-body th,.legal-page .legal-body td{padding:.55rem .8rem;border:1px solid var(--border);text-align:left;vertical-align:top}
.legal-page .legal-body thead{background:var(--surface)}
.legal-page .legal-body th{font-family:var(--display);font-weight:400;letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;color:var(--accent)}
.legal-page .legal-body tbody tr:nth-child(even){background:var(--surface)}

/* /jackpots/ archive — hero + stats + comparison */
.country-hubs{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin:.75rem 0 1.5rem;padding:0;list-style:none}
.country-hub-card{display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);color:var(--text);text-decoration:none;transition:background .15s,border-color .15s,transform .15s}
.country-hub-card:hover{background:#1a1a1a;border-color:var(--accent);transform:translateX(2px)}
.country-hub-card .chc-flag{font-size:1.4rem;line-height:1}
.country-hub-card .chc-name{flex:1;font-family:var(--display);font-size:.95rem;letter-spacing:.04em;text-transform:uppercase}
.country-hub-card .chc-count{font-size:.72rem;color:var(--muted);font-family:var(--display);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}
.jp-hero{display:grid;grid-template-columns:1.4fr auto 1fr;gap:1.25rem;align-items:center;background:linear-gradient(135deg,var(--surface) 0%,#0d0d0d 100%);border:1px solid var(--border);border-left:4px solid var(--accent);padding:1.5rem;margin:1rem 0 1.5rem;position:relative;overflow:hidden}
.jp-hero::after{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(255,168,0,.18) 0%,transparent 70%);pointer-events:none}
.jp-hero-eyebrow{display:inline-block;font-family:var(--display);letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-size:.75rem;margin-bottom:.4rem}
.jp-hero-title{margin:0;font-size:2rem;line-height:1.1;letter-spacing:.01em}
.jp-hero-sub{margin:.5rem 0 0;color:var(--dim);font-size:.95rem}
.jp-hero-countdown{text-align:center;background:#000;border:1px solid var(--border);padding:.75rem 1rem;min-width:240px}
.jp-cd-row{display:flex;gap:.5rem;justify-content:center}
.jp-cd-cell{display:flex;flex-direction:column;align-items:center;min-width:48px;padding:.4rem .25rem;background:var(--surface-2);border:1px solid var(--border)}
.jp-cd-cell strong{font-family:var(--display);font-size:1.6rem;color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:.02em;line-height:1}
.jp-cd-cell em{font-style:normal;color:var(--dim);font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;margin-top:.2rem}
.jp-cd-deadline{margin-top:.55rem;color:var(--dim);font-size:.78rem;letter-spacing:.04em}
.jp-hero-cta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.jp-hero-cta .cta-affiliate{padding:.85rem 1.25rem;font-size:1rem}
.jp-hero-conf{color:var(--dim);font-size:.85rem}
.jp-hero-conf strong{color:var(--ok);font-family:var(--display);font-size:1.05rem}
.jp-stats{list-style:none;padding:0;margin:0 0 1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:2px;background:var(--border);border:1px solid var(--border)}
.jp-stats li{display:flex;flex-direction:column;gap:.2rem;padding:.85rem 1rem;background:var(--surface);align-items:flex-start}
.jp-stats .label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--dim)}
.jp-stats .count{font-family:var(--display);font-size:1.5rem;color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:.02em}
.jp-top-picks{margin:2rem 0}
.jp-top-picks .vs{color:var(--dim);font-weight:400;margin:0 .25rem}
.jp-by-bookmaker{margin:2.5rem 0}
.jp-bm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1rem}
.jp-bm-block{padding:1rem;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--accent)}
.jp-bm-block h3{margin:0 0 .6rem;font-family:var(--display);letter-spacing:.04em;font-size:1rem;display:flex;justify-content:space-between;align-items:center}
.jp-bm-count{display:inline-block;background:var(--surface-2);padding:.1rem .55rem;font-size:.75rem;color:var(--dim);font-family:var(--display)}
.jp-bm-block .post-list{margin:0}
.jp-bm-block .post-list li{padding:.4rem 0;font-size:.85rem;border-bottom:1px dashed var(--border)}
.jp-bm-block .post-list li:last-child{border-bottom:0}
.jp-comparison{margin:2.5rem 0}
.jp-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.jp-comparison .match-table{min-width:680px}
.jp-comparison .jp-pct{color:var(--dim);font-size:.78rem;margin-left:.25rem}
.jp-methodology{margin:2.5rem 0;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--ok)}
.jp-methodology h2{margin-top:0}
.jp-meth-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1rem}
.jp-meth-grid h4{margin:0 0 .35rem;color:var(--accent);font-family:var(--display);font-size:.95rem;letter-spacing:.04em}
.jp-meth-grid p{margin:0;font-size:.88rem;color:var(--dim);line-height:1.6}

/* /today/ — sticky league nav + time buckets */
.today-time-buckets{margin:1rem 0 1.5rem;background:var(--surface);border:1px solid var(--border);border-top:3px solid var(--accent)}
.today-time-buckets .ttb-tabs{display:flex;flex-wrap:wrap;gap:0;border-bottom:1px solid var(--border);background:#000}
.ttb-tab{flex:1 1 auto;padding:.7rem .85rem;background:transparent;border:0;border-right:1px solid var(--border);color:var(--dim);font-family:var(--display);letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;cursor:pointer;text-align:center;min-width:120px}
.ttb-tab:last-child{border-right:0}
.ttb-tab:hover{color:var(--text);background:var(--surface)}
.ttb-tab.is-active{color:#000;background:var(--accent)}
.ttb-count{margin-left:.3rem;font-variant-numeric:tabular-nums;opacity:.85}
.ttb-list{list-style:none;margin:0;padding:.5rem 0;max-height:340px;overflow-y:auto}
.ttb-list.is-hidden{display:none}
.ttb-list li{display:grid;grid-template-columns:auto 1fr auto auto;gap:.6rem;align-items:center;padding:.5rem 1rem;border-bottom:1px dashed var(--border);font-size:.88rem}
.ttb-list li:last-child{border-bottom:0}
.ttb-time{font-family:var(--display);color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:.02em;min-width:3rem}
.ttb-match{display:flex;flex-direction:column;color:var(--text);text-decoration:none;line-height:1.25}
.ttb-match:hover strong{color:var(--accent)}
.ttb-match strong{font-weight:600}
.ttb-league{color:var(--dim);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;margin-top:.1rem}
.ttb-conf{color:var(--ok);font-family:var(--display);font-size:.8rem;font-variant-numeric:tabular-nums;min-width:2.4rem;text-align:right}
.ttb-empty,.ttb-more{padding:.8rem 1rem;color:var(--dim);font-style:italic;font-size:.85rem;border-bottom:0}

.today-league-nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:.6rem;background:#000;border-bottom:2px solid var(--accent);padding:.4rem .5rem;margin:1rem -1rem 1rem}
.today-league-nav .tln-label{font-family:var(--display);color:var(--accent);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;flex-shrink:0;padding:0 .4rem}
.tln-scroller{display:flex;gap:.35rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.tln-scroller::-webkit-scrollbar{height:4px}
.tln-scroller::-webkit-scrollbar-thumb{background:var(--accent)}
.tln-scroller a{flex-shrink:0;padding:.35rem .65rem;background:var(--surface);border:1px solid var(--border);color:var(--text);text-decoration:none;font-size:.78rem;white-space:nowrap;font-family:var(--display);letter-spacing:.04em}
.tln-scroller a:hover{background:var(--accent);color:#000;border-color:var(--accent)}

.today-totop{position:fixed;right:1rem;bottom:1rem;z-index:30;display:inline-block;padding:.55rem .9rem;background:var(--accent);color:#000;text-decoration:none;font-family:var(--display);letter-spacing:.06em;text-transform:uppercase;font-size:.8rem;border:2px solid #000;box-shadow:3px 3px 0 0 var(--accent-hot)}
.today-totop:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 0 var(--accent-hot)}
.today-body h2{scroll-margin-top:60px}

/* mobile overrides */
@media (max-width:640px){
 .site-header{padding:.5rem .75rem}
 .primary-nav a{padding:.4rem .5rem;font-size:.8rem}
 .trust-bar li{padding:.5rem .75rem}
 .trust-bar .v{font-size:1.15rem}
 .match-table{font-size:.8rem;border:0}
 .match-table th,.match-table td{padding:.4rem .35rem}
 .match-table .hide-mobile{display:none}
 .cta-affiliate{padding:.95rem .75rem;box-shadow:4px 4px 0 0 var(--accent-hot)}
 .cta-affiliate:hover{box-shadow:6px 6px 0 0 var(--accent-hot)}
 .pros-cons{grid-template-columns:1fr}
 .bottom-bar{flex-direction:column;align-items:flex-start}
 h2{margin:1.5rem 0 .75rem}
 .jp-hero{grid-template-columns:1fr;padding:1rem;gap:1rem}
 .jp-hero-title{font-size:1.5rem}
 .jp-hero-cta{align-items:stretch}
 .jp-hero-cta .cta-affiliate{text-align:center}
 .jp-cd-cell{min-width:40px;padding:.3rem .15rem}
 .jp-cd-cell strong{font-size:1.25rem}
 .jp-stats{grid-template-columns:repeat(2,1fr)}
 .ttb-tab{min-width:50%;border-right:0;border-bottom:1px solid var(--border)}
 .ttb-list li{grid-template-columns:auto 1fr auto;font-size:.82rem;padding:.45rem .75rem}
 .ttb-conf{display:none}
 .today-league-nav{margin:.5rem -.75rem 1rem;padding:.35rem .5rem}
}
@media (prefers-reduced-motion:reduce){
 *{animation-duration:.001s!important;transition-duration:.001s!important}
}

/* Bookmaker review side-note (single-jackpot template) */
.bookmaker-review-cta{margin:1.5rem 0;padding:.9rem 1rem .9rem 1.1rem;border-left:3px solid var(--accent);background:rgba(255,106,0,.06);font-size:.95rem;line-height:1.55;color:#d4d4d4}
.bookmaker-review-cta p{margin:0}
.bookmaker-review-cta .review-link{color:var(--accent);text-decoration:underline;text-underline-offset:3px;font-weight:600}
.bookmaker-review-cta .review-link:hover{color:#ffa14a}

/* Footer "Bookmakers" column */
.site-footer .footer-columns .col.col-bookmakers ul{margin:0;padding:0;list-style:none}
.site-footer .footer-columns .col.col-bookmakers li{margin:.25rem 0}

/* Editorial byline (single-jackpot, country hub, single-bookmaker, etc) */
.byline{margin:.25rem 0 1.25rem;font-size:.85rem;color:var(--dim);font-family:var(--display);letter-spacing:.04em;text-transform:uppercase}
.byline a{color:var(--dim);text-decoration:none;border-bottom:1px dotted var(--dim)}
.byline a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.byline time{color:#bababa}

/* Team badges. Inline-flex with the team name, vertically centred.
   Always paired with `loading="lazy"` and explicit width/height in the
   img tag so layout doesn't shift while crests load. */
.team-badge{display:inline-block;width:18px;height:18px;vertical-align:-4px;margin:0 .25rem 0 0;object-fit:contain;background:rgba(255,255,255,.05);border-radius:2px}
.match-teams .vs{color:var(--dim);margin:0 .25rem;font-weight:400;font-size:.85em;text-transform:lowercase}
.analysis-pos{color:var(--accent);font-family:var(--display);margin-right:.4rem;letter-spacing:.04em}

/* "n/a" placeholder for matches where our team-strength model has no data */
.confidence-na{color:var(--dim);font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;font-family:var(--display)}
