/* ===================================================================
   100TIP.COM — EDITORIAL SPORTSBOOK DESIGN SYSTEM (v2)
   ===================================================================
   Light theme = the default, paper-led editorial look.
   Dark theme  = inverted pitch-led look.
   =================================================================== */

/* -------------------------- Design tokens ------------------------- */
:root{
  --turf-700: #1E6E45;
  --turf-600: #258654;
  --turf-500: #2FA464;
  --turf-400: #4FC480;
  --turf-300: #9CE3B9;

  --gold-600: #9A7325;
  --gold-500: #C99A3D;
  --gold-300: #E6C778;

  --brick-500: #B6533F;

  --ticket-bg: #FFFFFF;
  --ticket-ink: #11201A;
  --ticket-soft: #5B6D62;
  --ticket-faint: #93A39A;
  --ticket-border: #ECE7D8;

  --font-display: "Fraunces", "Iowan Old Style", Georgia, serif;
  --font-utility: "Barlow Condensed", "Arial Narrow", sans-serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --fs-h1: clamp(2.2rem, 5.4vw + 0.6rem, 4.4rem);
  --fs-h2: clamp(1.7rem, 3.2vw + 0.5rem, 2.7rem);
  --fs-h3: clamp(1.25rem, 1.6vw + 0.6rem, 1.6rem);
  --fs-lead: clamp(1.05rem, 1vw + 0.7rem, 1.25rem);
  --fs-body: clamp(0.95rem, 0.3vw + 0.85rem, 1.02rem);
  --fs-small: clamp(0.8rem, 0.2vw + 0.74rem, 0.875rem);
  --fs-micro: clamp(0.7rem, 0.15vw + 0.66rem, 0.75rem);

  --space-2xs: clamp(0.4rem, 0.6vw, 0.55rem);
  --space-xs:  clamp(0.65rem, 1vw, 0.9rem);
  --space-sm:  clamp(1rem, 1.6vw, 1.4rem);
  --space-md:  clamp(1.5rem, 2.6vw, 2.2rem);
  --space-lg:  clamp(2.2rem, 4vw, 3.4rem);
  --space-xl:  clamp(3rem, 6vw, 5.5rem);

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;

  --container: 1240px;

  /* ---- Light theme (default) ---- */
  --bg-page:      #F6F3EA;
  --bg-surface:   #FFFFFF;
  --bg-surface-2: #EFE9D6;
  --bg-panel:     #15392A;
  --bg-panel-2:   #1D4A34;
  --panel-line:        rgba(246,243,234,0.16);
  --panel-line-strong: rgba(246,243,234,0.3);

  --text-primary:      #11201A;
  --text-secondary:    #45564C;
  --text-faint:        #7C8B81;
  --text-on-panel:      #F6F3EA;
  --text-on-panel-soft: rgba(246,243,234,0.78);

  --border-color:  #DDD6C4;
  --border-strong: #C9C0A6;

  --header-bg:      #FFFFFF;
  --header-text:     #11201A;
  --header-text-soft: rgba(17,32,26,0.68);
  --header-border:  #E4DECB;
  --header-hover-bg: rgba(17,32,26,0.06);

  --nav-overlay-bg: #FFFFFF;

  --footer-bg:     #EFE9D6;
  --footer-text:    #33453A;
  --footer-text-soft: rgba(51,69,58,0.72);
  --footer-border: #DDD3B8;
  --footer-heading: #1E6E45;

  --accent-heading: #1E6E45;

  --chip-bg:     #FFFFFF;
  --chip-border: #DDD6C4;
  --chip-text:   #45564C;

  --chip-tint-bg:   #E7F5EC;
  --chip-tint-text: #1E6E45;
  --gold-tint-bg:   #FBF1DC;
  --gold-tint-text: #9A7325;

  --shadow-sm: 0 1px 2px rgba(17,32,26,0.08);
  --shadow-md: 0 8px 24px -8px rgba(17,32,26,0.18);
  --shadow-lg: 0 24px 48px -16px rgba(17,32,26,0.28);
}

html[data-theme="dark"]{
  --bg-page:      #0A1C14;
  --bg-surface:   #0F2A1F;
  --bg-surface-2: #0C2419;
  --bg-panel:     #07140F;
  --bg-panel-2:   #0E2A1E;
  --panel-line:        rgba(243,241,231,0.1);
  --panel-line-strong: rgba(243,241,231,0.2);

  --text-primary:      #F3F1E7;
  --text-secondary:    #B9C4BB;
  --text-faint:        #7F9088;
  --text-on-panel:      #F3F1E7;
  --text-on-panel-soft: rgba(243,241,231,0.75);

  --border-color:  #1C3A2A;
  --border-strong: #28503A;

  --header-bg:      #07140F;
  --header-text:     #F3F1E7;
  --header-text-soft: rgba(243,241,231,0.7);
  --header-border:  #173527;
  --header-hover-bg: rgba(243,241,231,0.08);

  --nav-overlay-bg: #0A1C14;

  --footer-bg:     #07140F;
  --footer-text:    rgba(243,241,231,0.82);
  --footer-text-soft: rgba(243,241,231,0.58);
  --footer-border: #173527;
  --footer-heading: #9CE3B9;

  --accent-heading: #9CE3B9;

  --chip-bg:     #0F2A1F;
  --chip-border: #1C3A2A;
  --chip-text:   #B9C4BB;

  --chip-tint-bg:   rgba(79,196,128,0.16);
  --chip-tint-text: #9CE3B9;
  --gold-tint-bg:   rgba(201,154,61,0.18);
  --gold-tint-text: #E6C778;

  --shadow-sm: 0 1px 2px rgba(0,0,0,0.35);
  --shadow-md: 0 8px 24px -8px rgba(0,0,0,0.5);
  --shadow-lg: 0 24px 48px -16px rgba(0,0,0,0.6);
}

/* ------------------------------ Reset ------------------------------ */
*, *::before, *::after{ box-sizing: border-box; }
html{
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}
body{
  margin: 0;
  background: var(--bg-page);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  transition: background-color 0.25s ease, color 0.25s ease;
}
img, svg{ display: block; max-width: 100%; }
a{ color: inherit; text-decoration: none; }
ul{ list-style: none; margin: 0; padding: 0; }
button{ font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
h1,h2,h3,h4,p,figure{ margin: 0; }
input, textarea{ font: inherit; }

:focus-visible{
  outline: 3px solid var(--gold-500);
  outline-offset: 3px;
  border-radius: 4px;
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

.skip-link{
  position: absolute;
  left: 0.75rem; top: -3rem;
  background: var(--turf-500);
  color: #fff;
  padding: 0.6rem 1rem;
  border-radius: var(--radius-sm);
  z-index: 999;
  transition: top 0.2s ease;
  font-weight: 600;
}
.skip-link:focus{ top: 0.75rem; }

.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2.5rem);
}

.eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-family: var(--font-utility);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: var(--fs-micro);
  color: var(--accent-heading);
}
.eyebrow::before{
  content: "";
  width: 18px; height: 2px;
  background: currentColor;
  display: inline-block;
}
.section-on-dark .eyebrow{ color: var(--turf-300); }

.section-head{
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}
.section-head h2{ font-family: var(--font-display); font-size: var(--fs-h2); font-weight: 600; color: var(--text-primary); }
.section-head .lede{ max-width: 56ch; color: var(--text-secondary); font-size: var(--fs-body); margin-top: 0.5rem; }
.section-on-dark .section-head h2{ color: var(--text-on-panel); }
.section-on-dark .section-head .lede{ color: var(--text-on-panel-soft); }

/* ------------------------------ Buttons ----------------------------- */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  padding: 0.75em 1.4em;
  border-radius: 999px;
  font-weight: 600;
  font-size: var(--fs-small);
  white-space: nowrap;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.btn-primary{ background: var(--turf-500); color: #fff; box-shadow: var(--shadow-sm); }
.btn-primary:hover{ background: var(--turf-400); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-ghost{ border: 1.5px solid var(--header-border); color: var(--header-text); }
.btn-ghost:hover{ background: var(--header-border); }
.btn-outline{ border: 1.5px solid var(--border-strong); color: var(--text-primary); }
.btn-outline:hover{ background: var(--border-color); }
.btn-gold{ background: var(--gold-500); color: #1A1303; }
.btn-gold:hover{ background: var(--gold-300); transform: translateY(-1px); }
.btn-sm{ padding: 0.55em 1.1em; font-size: var(--fs-micro); }
.btn-block{ width: 100%; }

/* ------------------------------ Header ------------------------------ */
.site-header{
  position: sticky; top: 0; z-index: 90;
  background: var(--header-bg);
  border-bottom: 1px solid var(--header-border);
  transition: background-color 0.25s ease, border-color 0.25s ease, box-shadow 0.2s ease;
}
.site-header.is-scrolled{ box-shadow: var(--shadow-sm); }
.header-inner{
  position: relative;
  max-width: var(--container); margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2.5rem);
  height: clamp(64px, 8vw, 76px);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm);
}
.logo{
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(1.3rem, 2.4vw, 1.7rem);
  color: var(--header-text); flex-shrink: 0; min-width: 0;
}
.logo em{ font-style: normal; color: var(--turf-500); }
.logo small{
  display: block; font-family: var(--font-utility); font-size: 0.55rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--header-text-soft);
  font-weight: 600; margin-top: 2px; white-space: nowrap;
}
.logo-stack{ display: flex; flex-direction: column; line-height: 1; min-width: 0; }
.logo-word{ white-space: nowrap; }

.main-nav ul{ display: flex; align-items: center; gap: clamp(0.2rem, 0.5vw, 0.4rem); flex-shrink: 0; }
.main-nav > ul > li{ display: flex; align-items: center; flex-shrink: 0; }
.main-nav > ul > li > a,
.mega-trigger{
  font-family: var(--font-utility); font-weight: 600; font-size: 0.92rem;
  letter-spacing: 0.03em; text-transform: uppercase; white-space: nowrap;
  color: var(--header-text-soft); padding: 0.55rem 0.85rem; border-radius: 999px;
  position: relative; display: inline-flex; align-items: center; gap: 0.35em;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.main-nav > ul > li > a:hover,
.mega-trigger:hover,
.mega-trigger[aria-expanded="true"]{ color: var(--header-text); background: var(--header-hover-bg); }
.mega-trigger .chevron{ width: 11px; height: 11px; transition: transform 0.2s ease; }
.mega-trigger[aria-expanded="true"] .chevron{ transform: rotate(180deg); }

.header-actions{ display: flex; align-items: center; gap: 0.6rem; flex-shrink: 0; }

.theme-toggle{
  width: 40px; height: 40px; border-radius: 50%;
  border: 1.5px solid var(--header-border); color: var(--header-text);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.theme-toggle:hover{ background: var(--header-border); }
.theme-toggle svg{ width: 18px; height: 18px; }
.theme-toggle .icon-moon{ display: none; }
html[data-theme="dark"] .theme-toggle .icon-sun{ display: none; }
html[data-theme="dark"] .theme-toggle .icon-moon{ display: inline-flex; }

.nav-toggle{
  display: none; width: 42px; height: 42px; border-radius: var(--radius-sm);
  align-items: center; justify-content: center; color: var(--header-text); flex-shrink: 0;
}
.nav-toggle .bars{ position: relative; width: 20px; height: 14px; }
.nav-toggle .bars span{
  position: absolute; left: 0; width: 100%; height: 2px;
  background: currentColor; border-radius: 2px;
  transition: transform 0.25s ease, opacity 0.2s ease, top 0.25s ease;
}
.nav-toggle .bars span:nth-child(1){ top: 0; }
.nav-toggle .bars span:nth-child(2){ top: 6px; }
.nav-toggle .bars span:nth-child(3){ top: 12px; }
.nav-toggle[aria-expanded="true"] .bars span:nth-child(1){ top: 6px; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .bars span:nth-child(2){ opacity: 0; }
.nav-toggle[aria-expanded="true"] .bars span:nth-child(3){ top: 6px; transform: rotate(-45deg); }

.header-telegram-btn{ flex-shrink: 0; }
.nav-mobile-cta{ display: none; }

@media (max-width: 1160px){
  .main-nav{
    position: fixed; inset: 0; top: clamp(64px, 8vw, 76px);
    background: var(--nav-overlay-bg);
    transform: translateX(100%);
    transition: transform 0.3s ease, background-color 0.25s ease;
    overflow-y: auto; padding: var(--space-lg) var(--space-md) var(--space-xl);
    -webkit-overflow-scrolling: touch;
  }
  .main-nav[data-open="true"]{ transform: translateX(0); }
  .main-nav ul{ flex-direction: column; align-items: stretch; gap: 0; }
  .main-nav > ul > li{ display: block; width: 100%; border-bottom: 1px solid var(--border-color); }
  .main-nav > ul > li > a,
  .mega-trigger{
    display: flex; width: 100%; padding: 0.95rem 0.9rem; font-size: 1.05rem;
    color: var(--text-primary); justify-content: space-between; border-radius: var(--radius-sm);
    background: transparent; border-left: 3px solid transparent;
  }
  .main-nav > ul > li > a:hover,
  .mega-trigger:hover{ color: var(--text-primary); background: var(--bg-surface-2); border-left-color: var(--turf-500); }
  .mega-trigger .chevron{ flex-shrink: 0; }
  .header-telegram-btn{ display: none; }
  .nav-toggle{ display: inline-flex; }
  .nav-mobile-cta{ display: block; margin-top: var(--space-md); }
  .nav-mobile-cta-card{
    background: var(--bg-surface-2); border: 1px solid var(--border-color);
    border-radius: var(--radius-md); padding: var(--space-sm);
    display: flex; flex-direction: column; gap: 0.6rem;
  }
  .nav-mobile-cta-card p{ font-size: var(--fs-small); color: var(--text-secondary); }
  .nav-mobile-cta-card .btn svg{ width: 16px; height: 16px; }
}
@media (min-width: 1161px){
  .main-nav{ display: block; flex-shrink: 0; }
}

/* --------------------------- Mega menu -------------------------- */
.mega-menu{
  position: static; width: 100%; background: transparent; border: none; box-shadow: none; padding: 0;
  max-height: 0; overflow: hidden; opacity: 1; visibility: visible; pointer-events: auto;
  transition: max-height 0.3s ease, padding 0.3s ease, background-color 0.2s ease;
}
.mega-menu.is-open{
  max-height: 2600px; padding: var(--space-sm);
  background: var(--bg-surface-2); border-radius: var(--radius-md); margin-top: 0.25rem;
}
.mega-menu-inner{ display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.mega-col h6{
  font-family: var(--font-utility); text-transform: uppercase; letter-spacing: 0.08em;
  font-size: var(--fs-micro); color: var(--accent-heading); font-weight: 700; margin-bottom: 0.6rem;
}
.mega-col ul{ display: flex; flex-direction: column; }
.mega-col li{ border-bottom: 1px solid var(--border-color); }
.mega-col li:last-child{ border-bottom: none; }
.mega-col a{
  display: flex; align-items: center; gap: 0.55rem; font-size: var(--fs-small);
  color: var(--text-secondary); padding: 0.7rem 0.3rem;
  transition: background-color 0.12s ease, color 0.12s ease;
}
.mega-col a:hover{ color: var(--turf-500); background: var(--bg-surface); }
.mega-code{
  font-family: var(--font-utility); font-weight: 700; font-size: 0.66rem;
  color: var(--chip-tint-text); background: var(--chip-tint-bg);
  padding: 0.15em 0.3em; border-radius: 4px; flex-shrink: 0; width: 42px; text-align: center;
}
.mega-footer{ display: none; }

@media (min-width: 1161px){
  .mega-menu{
    position: absolute; top: calc(100% + 14px); right: 0; left: auto;
    transform: translateY(6px) scale(0.98); transform-origin: top right;
    width: min(94vw, 1220px); max-width: calc(100vw - 2.5rem);
    background: var(--bg-surface); border: 1px solid var(--border-color);
    border-radius: var(--radius-md); box-shadow: var(--shadow-lg); padding: 1.5rem;
    opacity: 0; visibility: hidden; pointer-events: none; overflow: hidden;
    max-height: none; margin-top: 0;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
    z-index: 95;
  }
  .mega-menu::before{
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--turf-500), var(--gold-500));
  }
  .mega-menu.is-open{
    opacity: 1; visibility: visible; pointer-events: auto;
    transform: translateY(0) scale(1); background: var(--bg-surface);
    border-radius: var(--radius-md); margin-top: 0;
  }
  .mega-menu-inner{ grid-template-columns: repeat(6, 1fr); gap: 1.25rem; }
  .mega-col ul{ gap: 0.2rem; }
  .mega-col li{ border-bottom: none; }
  .mega-col a{ padding: 0.4rem 0.5rem; margin-inline: -0.5rem; border-radius: 8px; }
  .mega-col a:hover{ background: var(--bg-surface-2); }
  .mega-footer{
    display: flex; grid-column: 1 / -1; margin-top: var(--space-md);
    padding-top: var(--space-md); border-top: 1px solid var(--border-color); justify-content: center;
  }
  .mega-footer a{
    font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small);
    text-transform: uppercase; letter-spacing: 0.05em; color: var(--turf-500);
    display: inline-flex; align-items: center; gap: 0.4em;
  }
  .mega-footer a svg{ width: 13px; height: 13px; }
}

/* ------------------------------- Hero -------------------------------- */
.hero{
  background: radial-gradient(120% 140% at 100% 0%, var(--bg-panel-2) 0%, var(--bg-panel) 55%);
  color: var(--text-on-panel); position: relative; overflow: hidden;
  transition: background-color 0.25s ease;
}
.hero::after{
  content: ""; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(90deg, var(--panel-line) 0 1px, transparent 1px 120px),
    repeating-linear-gradient(0deg, var(--panel-line) 0 1px, transparent 1px 120px);
  opacity: 0.5; pointer-events: none;
}
.hero-inner{
  position: relative; display: grid; grid-template-columns: minmax(0,1fr);
  gap: var(--space-xl); padding-block: var(--space-xl) var(--space-lg); align-items: center;
}
.hero-copy h1{
  font-family: var(--font-display); font-size: var(--fs-h1); font-weight: 600;
  line-height: 1.04; letter-spacing: -0.01em; margin-top: var(--space-sm); color: var(--text-on-panel);
}
.hero-copy h1 em{ font-style: italic; color: var(--turf-300); }
.hero-copy p.lede{ font-size: var(--fs-lead); color: var(--text-on-panel-soft); max-width: 52ch; margin-top: var(--space-sm); }
.hero-actions{ display: flex; flex-wrap: wrap; gap: 0.8rem; margin-top: var(--space-md); }
.hero-meta{
  display: flex; flex-wrap: wrap; gap: var(--space-md);
  margin-top: var(--space-lg); padding-top: var(--space-md); border-top: 1px solid var(--panel-line);
}
.hero-meta .stat b{
  display: block; font-family: var(--font-utility);
  font-size: clamp(1.5rem, 2.4vw, 2rem); font-weight: 700; color: var(--text-on-panel);
}
.hero-meta .stat span{ font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-on-panel-soft); }

/* Betting-slip ticket */
.ticket{
  background: var(--ticket-bg); color: var(--ticket-ink);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  position: relative; overflow: hidden; max-width: 420px; width: 100%; margin-inline: auto;
}
.ticket-top{ padding: var(--space-md) var(--space-md) var(--space-sm); }
.ticket-brand{
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-utility); font-size: var(--fs-micro);
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--ticket-faint);
}
.ticket-brand .live{ display: inline-flex; align-items: center; gap: 0.4em; color: var(--turf-600); font-weight: 700; }
.ticket-brand .live::before{
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--turf-500); animation: pulse-dot 1.6s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: 0.45; transform: scale(0.8); }
}
.ticket-match{ display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); margin-top: var(--space-sm); }
.ticket-team{ text-align: center; flex: 1; min-width: 0; }
.ticket-crest{
  width: 44px; height: 44px; border-radius: 50%; margin-inline: auto;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-utility); font-weight: 700; font-size: 0.95rem;
  color: #fff; background: var(--turf-700);
}
.ticket-crest.alt{ background: var(--gold-600); }
.ticket-team p{ margin-top: 0.4rem; font-size: var(--fs-small); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--ticket-ink); }
.ticket-vs{ font-family: var(--font-utility); font-size: var(--fs-micro); color: var(--ticket-faint); }
.ticket-divider{ position: relative; height: 0; border-top: 2px dashed var(--ticket-border); }
.ticket-divider::before, .ticket-divider::after{
  content: ""; position: absolute; top: 50%; transform: translateY(-50%);
  width: 24px; height: 24px; border-radius: 50%; background: var(--bg-panel);
  transition: background-color 0.25s ease;
}
.ticket-divider::before{ left: -12px; }
.ticket-divider::after{ right: -12px; }
.ticket-bottom{ padding: var(--space-sm) var(--space-md) var(--space-md); }
.ticket-pick{ display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); }
.ticket-pick .label{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.08em; color: var(--ticket-faint); }
.ticket-pick .value{ font-family: var(--font-display); font-weight: 600; font-size: 1.15rem; color: var(--ticket-ink); }
.ticket-odds{ font-family: var(--font-utility); font-weight: 700; font-size: 1.5rem; color: var(--turf-600); }
.ticket-confidence{ margin-top: var(--space-sm); display: flex; align-items: center; gap: 0.6rem; }
.confidence-bar{ flex: 1; height: 6px; border-radius: 999px; background: var(--ticket-border); overflow: hidden; }
.confidence-bar i{ display: block; height: 100%; background: linear-gradient(90deg, var(--turf-400), var(--turf-600)); border-radius: inherit; }
.ticket-confidence span{ font-size: var(--fs-micro); font-weight: 700; color: var(--turf-600); white-space: nowrap; }
.ticket-barcode{ margin-top: var(--space-sm); height: 26px; background-image: repeating-linear-gradient(90deg, var(--ticket-ink) 0 2px, transparent 2px 5px); opacity: 0.16; }

@media (min-width: 880px){
  .hero-inner{ grid-template-columns: 1.1fr 0.9fr; gap: var(--space-lg); }
  .ticket{ margin-inline: 0; }
}

/* Trust bar */
.trust-bar{ background: var(--bg-surface); border-bottom: 1px solid var(--border-color); transition: background-color 0.25s ease, border-color 0.25s ease; }
.trust-grid{ display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-md); padding-block: var(--space-md); }
.trust-grid .stat{ text-align: center; }
.trust-grid .stat b{ display: block; font-family: var(--font-utility); font-size: clamp(1.4rem, 2.6vw, 2.1rem); font-weight: 700; color: var(--turf-500); }
.trust-grid .stat span{ display: block; font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-secondary); margin-top: 0.2rem; }
@media (min-width: 640px){ .trust-grid{ grid-template-columns: repeat(4, 1fr); } }

/* Markets board */
.markets{ padding-block: var(--space-xl); }
.markets-intro{ display: flex; flex-direction: column; gap: var(--space-sm); }
.chip-rail{
  display: flex; gap: 0.55rem; overflow-x: auto; padding-bottom: 0.6rem;
  margin: var(--space-md) calc(var(--space-sm) * -1) var(--space-lg);
  padding-inline: var(--space-sm); scroll-snap-type: x proximity; -webkit-overflow-scrolling: touch;
}
.chip-rail::-webkit-scrollbar{ height: 5px; }
.chip-rail::-webkit-scrollbar-thumb{ background: var(--border-color); border-radius: 999px; }
.chip{
  scroll-snap-align: start; flex-shrink: 0; display: inline-flex; align-items: center; gap: 0.4em;
  padding: 0.5em 0.95em; border-radius: 999px; border: 1.5px solid var(--chip-border);
  background: var(--chip-bg); font-family: var(--font-utility); font-weight: 600;
  font-size: var(--fs-small); letter-spacing: 0.02em; text-transform: uppercase; color: var(--chip-text);
  transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}
.chip:hover, .chip:focus-visible{ border-color: var(--turf-500); color: var(--turf-500); }
.market-group{ margin-bottom: var(--space-lg); }
.market-group-head{
  display: flex; align-items: baseline; gap: 0.8rem; margin-bottom: var(--space-sm);
  padding-bottom: 0.6rem; border-bottom: 2px solid var(--text-primary);
}
.market-group-head h3{ font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 600; color: var(--text-primary); }
.market-group-head p{ font-size: var(--fs-small); color: var(--text-faint); }
.market-grid{ display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 540px){ .market-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px){ .market-grid{ grid-template-columns: repeat(3, 1fr); } }
.market-card{
  background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: var(--radius-md);
  padding: var(--space-sm); display: flex; flex-direction: column; gap: 0.6rem;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background-color 0.25s ease;
}
.market-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: transparent; }
.market-card-top{ display: flex; align-items: flex-start; justify-content: space-between; gap: 0.6rem; }
.market-code{
  font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small);
  letter-spacing: 0.04em; color: var(--chip-tint-text); background: var(--chip-tint-bg);
  border-radius: 6px; padding: 0.25em 0.6em; white-space: nowrap;
}
.market-card.is-premium .market-code{ color: var(--gold-tint-text); background: var(--gold-tint-bg); }
.market-card h4{ font-family: var(--font-display); font-weight: 600; font-size: 1.1rem; color: var(--text-primary); }
.market-card p{ font-size: var(--fs-small); color: var(--text-secondary); flex: 1; }
.market-card .go{
  font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small);
  text-transform: uppercase; letter-spacing: 0.05em; color: var(--turf-500);
  display: inline-flex; align-items: center; gap: 0.35em;
}
.market-card .go svg{ width: 13px; height: 13px; transition: transform 0.15s ease; }
.market-card:hover .go svg{ transform: translateX(3px); }
.sub-lines{ display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: -0.2rem; }
.sub-lines a{
  font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700;
  border: 1px solid var(--border-color); border-radius: 6px; padding: 0.25em 0.55em; color: var(--text-secondary);
}
.sub-lines a:hover{ border-color: var(--turf-500); color: var(--turf-500); }

/* Today's tips */
.featured-tips{ background: var(--bg-panel); color: var(--text-on-panel); padding-block: var(--space-xl); transition: background-color 0.25s ease; }
.featured-grid{ display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 720px){ .featured-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px){ .featured-grid{ grid-template-columns: repeat(3, 1fr); } }
.featured-grid .ticket{ margin-inline: 0; max-width: none; }

/* Grading ladder */
.grading{ padding-block: var(--space-xl); }
.ladder{ display: grid; grid-template-columns: 1fr; gap: 0.9rem; counter-reset: rung; }
@media (min-width: 760px){ .ladder{ grid-template-columns: repeat(4, 1fr); gap: 1rem; } }
.rung{
  counter-increment: rung; background: var(--bg-surface); border: 1px solid var(--border-color);
  border-radius: var(--radius-md); padding: var(--space-sm); position: relative;
  transition: background-color 0.25s ease, border-color 0.25s ease;
}
.rung::before{ content: counter(rung, decimal-leading-zero); font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); color: var(--text-faint); letter-spacing: 0.05em; }
.rung h4{ font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; margin-top: 0.4rem; color: var(--text-primary); }
.rung p{ font-size: var(--fs-small); color: var(--text-secondary); margin-top: 0.4rem; }
.rung.level-vip{ border: 2px solid var(--gold-500); }
.rung.level-vip::before{ color: var(--gold-500); }

/* Analysis teaser */
.analysis{ padding-block: var(--space-xl); background: var(--bg-surface); border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); transition: background-color 0.25s ease, border-color 0.25s ease; }
.analysis-grid{ display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 720px){ .analysis-grid{ grid-template-columns: 1.2fr 1fr 1fr; } }
.analysis-card{ display: flex; flex-direction: column; gap: 0.6rem; padding-bottom: var(--space-sm); border-bottom: 1px solid var(--border-color); }
.analysis-grid > .analysis-card:first-child{ border-bottom: none; padding: var(--space-md); background: var(--bg-surface-2); border-left: 4px solid var(--turf-500); border-radius: var(--radius-md); }
.analysis-card .tag{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent-heading); font-weight: 700; }
.analysis-card h3, .analysis-card h4{ font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; color: var(--text-primary); }
.analysis-card p{ font-size: var(--fs-small); color: var(--text-secondary); }
.analysis-card .go{ color: var(--turf-500); font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 0.05em; display: inline-flex; align-items: center; gap: 0.35em; }
.analysis-card .go svg{ width: 13px; height: 13px; }

/* Testimonials */
.testimonials{ padding-block: var(--space-xl); }
.testimonial-grid{ display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
@media (min-width: 700px){ .testimonial-grid{ grid-template-columns: repeat(3, 1fr); } }
.testimonial{ background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: var(--space-sm); transition: background-color 0.25s ease, border-color 0.25s ease; }
.testimonial p{ font-size: var(--fs-body); color: var(--text-secondary); font-style: italic; }
.testimonial .who{ display: flex; align-items: center; gap: 0.6rem; margin-top: var(--space-sm); }
.testimonial .avatar{ width: 38px; height: 38px; border-radius: 50%; background: var(--chip-tint-bg); color: var(--chip-tint-text); display: flex; align-items: center; justify-content: center; font-family: var(--font-utility); font-weight: 700; font-size: 0.85rem; }
.testimonial .who b{ display: block; font-size: var(--fs-small); color: var(--text-primary); }
.testimonial .who span{ display: block; font-size: var(--fs-micro); color: var(--text-faint); }

/* CTA / VIP */
.cta-vip{
  background: linear-gradient(135deg, var(--bg-panel-2), var(--bg-panel)); color: var(--text-on-panel);
  border-radius: var(--radius-lg); margin-inline: clamp(1rem, 4vw, 2.5rem); padding: var(--space-lg);
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-md);
  transition: background-color 0.25s ease;
}
.cta-vip h2{ font-family: var(--font-display); font-size: var(--fs-h2); font-weight: 600; max-width: 24ch; color: var(--text-on-panel); }
.cta-vip p{ color: var(--text-on-panel-soft); margin-top: 0.5rem; max-width: 42ch; }
.cta-vip .actions{ display: flex; gap: 0.7rem; flex-wrap: wrap; }

/* Newsletter */
.newsletter{ padding-block: var(--space-xl); }
.newsletter-box{
  background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: var(--radius-lg);
  padding: var(--space-lg); display: grid; gap: var(--space-md); grid-template-columns: 1fr; align-items: center;
  transition: background-color 0.25s ease, border-color 0.25s ease;
}
@media (min-width: 760px){ .newsletter-box{ grid-template-columns: 1.1fr 1fr; } }
.newsletter-box h3{ font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 600; color: var(--text-primary); }
.newsletter-box p{ color: var(--text-secondary); margin-top: 0.4rem; font-size: var(--fs-small); }
.newsletter-form{ display: flex; gap: 0.6rem; flex-wrap: wrap; }
.newsletter-form input{
  flex: 1; min-width: 0; padding: 0.85em 1.1em;
  border: 1.5px solid var(--border-color); border-radius: 999px;
  background: var(--bg-page); color: var(--text-primary);
}
.newsletter-form input::placeholder{ color: var(--text-faint); }
.newsletter-form input:focus{ outline: none; border-color: var(--turf-500); }

/* SEO / editorial */
.seo-content{ padding-block: var(--space-xl); background: var(--bg-surface); border-top: 1px solid var(--border-color); }
.seo-content-inner{ max-width: 760px; }
.seo-content h2{ font-family: var(--font-display); font-weight: 600; font-size: var(--fs-h2); color: var(--text-primary); margin-top: 0.6rem; line-height: 1.15; }
.seo-content h3{ font-family: var(--font-display); font-weight: 600; font-size: 1.3rem; color: var(--text-primary); margin-top: var(--space-lg); }
.seo-content p{ color: var(--text-secondary); margin-top: var(--space-sm); line-height: 1.75; }
.seo-content p + p{ margin-top: 1rem; }
.faq-list{ margin-top: var(--space-md); display: flex; flex-direction: column; gap: 0.6rem; }
.faq-item{ background: var(--bg-page); border: 1px solid var(--border-color); border-radius: var(--radius-sm); padding: 0.2rem var(--space-sm); }
.faq-item summary{ cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.9rem 0; font-family: var(--font-display); font-weight: 600; font-size: 1rem; color: var(--text-primary); }
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-item summary .plus{ flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid var(--border-strong); display: flex; align-items: center; justify-content: center; position: relative; }
.faq-item summary .plus::before, .faq-item summary .plus::after{ content: ""; position: absolute; background: var(--text-secondary); }
.faq-item summary .plus::before{ width: 9px; height: 1.5px; }
.faq-item summary .plus::after{ width: 1.5px; height: 9px; transition: transform 0.2s ease; }
.faq-item[open] summary .plus::after{ transform: rotate(90deg); opacity: 0; }
.faq-item p{ padding-bottom: var(--space-sm); margin-top: -0.3rem; }
.responsible-callout{ margin-top: var(--space-lg); display: flex; gap: 0.7rem; background: var(--gold-tint-bg); border: 1px solid var(--gold-300); border-radius: var(--radius-md); padding: var(--space-sm); }
.responsible-callout b{ color: var(--gold-tint-text); flex-shrink: 0; }
.responsible-callout p{ margin-top: 0; font-size: var(--fs-small); color: var(--text-secondary); }
.responsible-callout a{ color: var(--turf-500); font-weight: 600; }

/* Footer */
.site-footer{ position: relative; background: var(--footer-bg); color: var(--footer-text); padding-top: var(--space-xl); transition: background-color 0.25s ease, color 0.25s ease; }
.site-footer::before{ content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--turf-500), var(--gold-500)); }
.footer-top{ display: flex; flex-wrap: wrap; gap: var(--space-lg) var(--space-xl); padding-bottom: var(--space-lg); border-bottom: 1px solid var(--footer-border); }
.footer-brand{ flex: 1 1 260px; max-width: 360px; }
.footer-links{ flex: 2 1 480px; display: grid; grid-template-columns: 1fr; gap: var(--space-lg) var(--space-md); }
@media (min-width: 640px){ .footer-links{ grid-template-columns: repeat(3, 1fr); } }
.footer-brand .logo{ margin-bottom: var(--space-sm); color: var(--footer-text); }
.footer-brand .logo small{ color: var(--footer-text-soft); }
.footer-brand p{ font-size: var(--fs-small); max-width: 36ch; color: var(--footer-text-soft); }
.footer-socials{ margin-top: var(--space-sm); }
.footer-social-telegram{ display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.55em 1em; border-radius: 999px; border: 1px solid var(--footer-border); color: var(--footer-text); font-size: var(--fs-small); font-weight: 600; transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, transform 0.15s ease; }
.footer-social-telegram:hover{ background: var(--turf-600); border-color: var(--turf-600); color: #fff; transform: translateY(-2px); }
.footer-social-telegram svg{ width: 17px; height: 17px; flex-shrink: 0; }
.footer-col h5{ position: relative; font-family: var(--font-utility); text-transform: uppercase; letter-spacing: 0.1em; font-size: var(--fs-micro); color: var(--footer-heading); padding-bottom: 0.6rem; margin-bottom: 0.9rem; }
.footer-col h5::after{ content: ""; position: absolute; left: 0; bottom: 0; width: 26px; height: 2px; background: var(--turf-500); }
.footer-col ul{ display: flex; flex-direction: column; gap: 0.6rem; }
.footer-col a{ display: inline-flex; align-items: center; font-size: var(--fs-small); color: var(--footer-text-soft); transition: color 0.15s ease, transform 0.15s ease; width: fit-content; }
.footer-col a:hover{ color: var(--footer-text); transform: translateX(3px); }
.footer-col .view-all{ font-weight: 700; color: var(--turf-500); }
.footer-col .view-all:hover{ color: var(--turf-400); }
.partners{ padding-top: var(--space-lg); padding-bottom: var(--space-sm); border-bottom: 1px solid var(--footer-border); }
.partners-head{ display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0.6rem; margin-bottom: var(--space-sm); }
.partners-title{ font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--footer-text); }
.partners-count{ font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.05em; background: var(--turf-500); color: #fff; padding: 0.3em 0.7em; border-radius: 999px; }
.partners-chips{ display: flex; flex-wrap: wrap; gap: 0.6rem; }
.partners-chips .chip-partner{ font-size: var(--fs-small); padding: 0.5em 1em; border-radius: 999px; border: 1px solid var(--footer-border); color: var(--footer-text-soft); transition: border-color 0.15s ease, color 0.15s ease; }
.partners-chips .chip-partner:hover{ border-color: var(--turf-500); color: var(--footer-text); }
.partners-chips .chip-partner.is-extra{ display: none; }
.partners-chips.is-expanded .chip-partner.is-extra{ display: inline-flex; }
.partners-toggle{ margin-top: var(--space-sm); border-color: var(--footer-border); color: var(--footer-text); }
.partners-toggle:hover{ background: var(--footer-border); }
.partners-toggle svg{ width: 13px; height: 13px; transition: transform 0.2s ease; }
.partners-toggle[aria-expanded="true"] svg{ transform: rotate(180deg); }
.responsible-note{ display: flex; align-items: center; gap: 0.6rem; background: var(--bg-surface-2, transparent); border: 1px solid var(--footer-border); border-radius: var(--radius-sm); padding: var(--space-sm); margin-top: var(--space-md); font-size: var(--fs-micro); color: var(--footer-text-soft); }
.responsible-note b{ color: var(--gold-500); flex-shrink: 0; }
.footer-bottom{ display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.8rem; padding-block: var(--space-md); font-size: var(--fs-micro); color: var(--footer-text-soft); }
.footer-bottom .legal-links{ display: flex; gap: 1rem; flex-wrap: wrap; }
.footer-bottom a:hover{ color: var(--footer-text); }

/* Back to top */
#backToTop{ position: fixed; right: clamp(1rem, 3vw, 1.6rem); bottom: clamp(1rem, 3vw, 1.6rem); width: 46px; height: 46px; border-radius: 50%; background: var(--turf-500); color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md); opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity 0.2s ease, transform 0.2s ease; z-index: 80; }
#backToTop.visible{ opacity: 1; pointer-events: auto; transform: translateY(0); }

/* Narrow / foldable safety */
@media (max-width: 360px){
  .container{ padding-inline: 0.9rem; }
  .hero-actions .btn, .cta-vip .actions .btn{ width: 100%; }
  .hero-meta{ gap: var(--space-sm); }
  .ticket{ max-width: 100%; }
}
@media (max-width: 300px){
  .logo{ font-size: 1.05rem; }
  .ticket-team p{ font-size: 0.68rem; }
  .ticket-odds{ font-size: 1.2rem; }
}
.site-header, .site-footer, .container{
  padding-left: max(env(safe-area-inset-left), 0px);
  padding-right: max(env(safe-area-inset-right), 0px);
}
@media print{
  .site-header, #backToTop, .nav-toggle, .newsletter, .cta-vip, .theme-toggle{ display: none; }
  body{ background: #fff; color: #000; }
}

/* ===================================================================
   TODAY'S PREDICTIONS PAGE — /todays-predictions
   =================================================================== */

/* Page hero */
.tp-hero{ background: radial-gradient(120% 140% at 100% 0%, var(--bg-panel-2) 0%, var(--bg-panel) 55%); color: var(--text-on-panel); position: relative; overflow: hidden; padding-block: var(--space-lg) var(--space-md); transition: background-color 0.25s ease; }
.tp-hero::after{ content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(90deg, var(--panel-line) 0 1px, transparent 1px 120px), repeating-linear-gradient(0deg, var(--panel-line) 0 1px, transparent 1px 120px); opacity: 0.5; pointer-events: none; }
.tp-hero-inner{ position: relative; z-index: 1; }
.tp-hero-copy{ max-width: 760px; }
/* Breadcrumb — default (used inside pagebar on light bg) */
.breadcrumb{ display: inline-flex; align-items: center; gap: 0.4em; font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); margin-bottom: .3rem; }
.breadcrumb a{ color: var(--text-faint); transition: color 0.15s ease; }
.breadcrumb a:hover{ color: var(--turf-500); }
/* Breadcrumb on dark panel (tp-hero) */
.tp-hero .breadcrumb, .section-on-dark .breadcrumb{ color: var(--text-on-panel-soft); }
.tp-hero .breadcrumb a, .section-on-dark .breadcrumb a{ color: var(--text-on-panel-soft); }
.tp-hero .breadcrumb a:hover, .section-on-dark .breadcrumb a:hover{ color: var(--turf-300); }
.tp-hero h1{ font-family: var(--font-display); font-size: var(--fs-h1); font-weight: 600; line-height: 1.04; letter-spacing: -0.01em; margin-top: var(--space-sm); color: var(--text-on-panel); }
.tp-hero h1 em{ font-style: italic; color: var(--turf-300); }
.tp-hero .lede{ font-size: var(--fs-lead); color: var(--text-on-panel-soft); max-width: 52ch; margin-top: var(--space-sm); }
.tp-hero-meta{ display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-md); margin-top: var(--space-md); padding-top: var(--space-md); border-top: 1px solid var(--panel-line); }
.tp-live-badge{ display: inline-flex; align-items: center; gap: 0.5em; font-family: var(--font-utility); font-size: var(--fs-small); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--turf-300); }
.live-dot{ width: 8px; height: 8px; border-radius: 50%; background: var(--turf-400); flex-shrink: 0; animation: pulse-dot 1.6s ease-in-out infinite; }
.tp-hero-stats{ display: flex; flex-wrap: wrap; align-items: center; gap: 0.5em; font-size: var(--fs-small); color: var(--text-on-panel-soft); }
.tp-hero-stats b{ color: var(--text-on-panel); }
.tp-hero-stats .divider{ color: var(--panel-line-strong); }

/* Filter bar */
.tp-filter-bar{ background: var(--bg-surface); border-bottom: 1px solid var(--border-color); position: sticky; top: clamp(64px, 8vw, 76px); z-index: 80; transition: background-color 0.25s ease, border-color 0.25s ease; }
.tp-filter-bar .container{ display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); height: 52px; overflow: hidden; }
.tp-filters{ display: flex; align-items: center; gap: 0.4rem; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; flex: 1; min-width: 0; }
.tp-filters::-webkit-scrollbar{ display: none; }
.tp-filter-chip{ display: inline-flex; align-items: center; gap: 0.4em; padding: 0.45em 1em; border-radius: 999px; border: 1.5px solid var(--border-color); background: transparent; font-family: var(--font-utility); font-weight: 600; font-size: var(--fs-small); letter-spacing: 0.03em; text-transform: uppercase; color: var(--text-secondary); white-space: nowrap; cursor: pointer; flex-shrink: 0; transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease; }
.tp-filter-chip:hover, .tp-filter-chip.active{ border-color: var(--turf-500); background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.grade-dot{ width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.grade-banker{ background: var(--gold-500); }
.grade-sure{ background: var(--turf-500); }
.grade-free{ background: var(--text-faint); }
.grade-vip{ background: var(--gold-300); }
.tp-filter-right{ display: flex; align-items: center; gap: 0.5rem; flex-shrink: 0; }
.tp-sort-label{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); white-space: nowrap; }
.tp-sort-select{ appearance: none; -webkit-appearance: none; background: var(--bg-page); border: 1.5px solid var(--border-color); border-radius: var(--radius-sm); padding: 0.35em 2em 0.35em 0.7em; font-family: var(--font-utility); font-size: var(--fs-small); font-weight: 600; color: var(--text-primary); cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237C8B81' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.6em center; background-size: 10px; }
.tp-sort-select:focus{ outline: none; border-color: var(--turf-500); }
@media (max-width: 540px){ .tp-sort-label{ display: none; } }

/* Shared section */
.tp-section{ padding-block: var(--space-xl); }
.tp-section-alt{ background: var(--bg-page); border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); }
.tp-section-label{ display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.4rem; }
.tp-section-desc{ color: var(--text-secondary); font-size: var(--fs-small); max-width: 58ch; margin-bottom: var(--space-md); }
.tp-badge{ display: inline-flex; align-items: center; padding: 0.2em 0.65em; border-radius: 6px; font-family: var(--font-utility); font-weight: 700; font-size: 0.68rem; letter-spacing: 0.04em; }
.tp-badge-banker{ background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.tp-badge-sure{ background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.tp-badge-free{ background: var(--bg-surface-2); color: var(--text-faint); border: 1px solid var(--border-color); }
.tp-badge-acca{ background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.tp-badge-vip{ background: var(--gold-tint-bg); color: var(--gold-tint-text); }

/* Banker spotlight */
.tp-banker-spotlight{ background: var(--bg-panel); color: var(--text-on-panel); padding-block: var(--space-xl); transition: background-color 0.25s ease; }
.tp-banker-spotlight .eyebrow{ color: var(--turf-300); }
.tp-banker-spotlight .tp-section-label{ margin-bottom: var(--space-sm); }
.tp-banker-inner{ display: grid; grid-template-columns: 1fr; gap: var(--space-lg); align-items: start; }
@media (min-width: 900px){ .tp-banker-inner{ grid-template-columns: 1fr 1fr; } }
.ticket-banker{ max-width: none; margin-inline: 0; }
.ticket-analyst-note{ margin-top: var(--space-sm); padding-top: var(--space-sm); border-top: 1px dashed var(--ticket-border); }
.note-label{ display: inline-block; font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--turf-600); margin-bottom: 0.3rem; }
.ticket-analyst-note p{ font-size: var(--fs-small); color: var(--ticket-soft); line-height: 1.65; }
.tp-banker-stats{ display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; align-content: start; }
.tp-stat-cell{ background: rgba(255,255,255,0.06); border: 1px solid var(--panel-line); border-radius: var(--radius-md); padding: var(--space-sm); display: flex; flex-direction: column; gap: 0.4rem; }
.tp-stat-label{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-on-panel-soft); }
.tp-stat-value{ font-family: var(--font-utility); font-weight: 700; font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--turf-300); }

/* Sure pick cards */
.tp-card-grid{ display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 620px){ .tp-card-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px){ .tp-card-grid{ grid-template-columns: repeat(3, 1fr); } }
.tp-pick-card{ background: var(--bg-surface); border: 1px solid var(--border-color); border-radius: var(--radius-md); padding: var(--space-sm); display: flex; flex-direction: column; gap: 0.7rem; transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background-color 0.25s ease; }
.tp-pick-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: transparent; }
.tp-card-header{ display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; }
.tp-card-meta{ display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-faint); }
.tp-ko{ font-weight: 700; color: var(--text-secondary); }
.tp-grade-tag{ font-family: var(--font-utility); font-weight: 700; font-size: 0.66rem; letter-spacing: 0.04em; padding: 0.2em 0.5em; border-radius: 5px; flex-shrink: 0; text-transform: uppercase; }
.tp-grade-tag--banker{ background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.tp-grade-tag--sure{ background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.tp-grade-tag--free{ background: var(--bg-surface-2); color: var(--text-faint); border: 1px solid var(--border-color); }
.tp-card-match{ display: flex; align-items: center; gap: 0.5em; font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--text-primary); line-height: 1.25; }
.tp-card-vs{ font-family: var(--font-utility); font-size: var(--fs-micro); color: var(--text-faint); flex-shrink: 0; }
.tp-team{ flex: 1; min-width: 0; }
.tp-team-right{ text-align: right; }
.tp-card-pick{ display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; padding: 0.55rem 0.65rem; background: var(--bg-surface-2); border-radius: var(--radius-sm); }
.tp-pick-market{ display: flex; align-items: center; gap: 0.5rem; min-width: 0; }
.tp-pick-selection{ font-size: var(--fs-small); font-weight: 600; color: var(--text-primary); }
.tp-pick-odds{ font-family: var(--font-utility); font-weight: 700; font-size: 1.15rem; color: var(--turf-500); flex-shrink: 0; }
.tp-card-bar{ display: flex; align-items: center; gap: 0.6rem; }
.tp-bar-track{ flex: 1; height: 5px; border-radius: 999px; background: var(--border-color); overflow: hidden; }
.tp-bar-fill{ height: 100%; background: linear-gradient(90deg, var(--turf-400), var(--turf-600)); border-radius: inherit; transition: width 0.4s ease; }
.tp-bar-label{ font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; color: var(--turf-500); white-space: nowrap; }
.tp-pick-note{ font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.6; border-top: 1px solid var(--border-color); padding-top: 0.6rem; margin-top: -0.1rem; }

/* Free tips table */
.tp-league-group{ margin-bottom: var(--space-lg); }
.tp-league-head{ display: flex; align-items: center; gap: 0.65rem; padding-bottom: 0.55rem; border-bottom: 2px solid var(--text-primary); margin-bottom: 0.25rem; }
.tp-league-flag{ font-size: 1.1rem; line-height: 1; }
.tp-league-head h3{ font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 600; color: var(--text-primary); }
.tp-league-count{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); margin-left: auto; }
.tp-table{ width: 100%; }
.tp-table-head, .tp-table-row{ display: grid; grid-template-columns: 52px 1fr 80px 1fr 64px 60px; align-items: center; gap: 0.5rem 0.75rem; padding: 0.75rem 0.5rem; }
.tp-table-head{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); border-bottom: 1px solid var(--border-color); }
.tp-table-row{ border-bottom: 1px solid var(--border-color); font-size: var(--fs-small); color: var(--text-secondary); transition: background-color 0.12s ease; }
.tp-table-row:hover{ background: var(--bg-surface); }
.tp-row-ko{ font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); color: var(--text-secondary); white-space: nowrap; }
.tp-row-match{ font-weight: 500; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tp-row-match b{ font-weight: 400; color: var(--text-faint); font-size: 0.8em; }
.tp-row-market{ display: flex; }
.tp-row-pick{ color: var(--text-primary); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tp-row-odds{ font-family: var(--font-utility); font-weight: 700; color: var(--turf-500); white-space: nowrap; }
.tp-row-conf{ white-space: nowrap; }
.align-right{ text-align: right; justify-content: flex-end; }
.conf-pip{ font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; color: var(--text-faint); }
[data-confidence="87"] .conf-pip, [data-confidence="81"] .conf-pip, [data-confidence="78"] .conf-pip,
[data-confidence="76"] .conf-pip, [data-confidence="74"] .conf-pip, [data-confidence="72"] .conf-pip{ color: var(--turf-500); }
[data-confidence="71"] .conf-pip, [data-confidence="70"] .conf-pip, [data-confidence="69"] .conf-pip{ color: var(--text-secondary); }
@media (max-width: 700px){
  .tp-table-head{ display: none; }
  .tp-table-row{ grid-template-columns: 1fr 1fr; grid-template-rows: auto auto auto; row-gap: 0.35rem; padding: 0.9rem 0.5rem; }
  .tp-row-ko{ grid-column: 1; grid-row: 1; }
  .tp-row-conf{ grid-column: 2; grid-row: 1; text-align: right; }
  .tp-row-match{ grid-column: 1 / -1; grid-row: 2; font-size: 0.95rem; }
  .tp-row-pick{ grid-column: 1; grid-row: 3; }
  .tp-row-odds{ grid-column: 2; grid-row: 3; text-align: right; }
  .tp-row-market{ display: none; }
}

/* Accumulator */
.tp-acca{ background: var(--bg-panel); color: var(--text-on-panel); padding-block: var(--space-xl); transition: background-color 0.25s ease; }
.tp-acca .eyebrow{ color: var(--turf-300); }
.tp-acca .tp-section-label{ margin-bottom: var(--space-sm); }
.tp-acca-inner{ display: grid; grid-template-columns: 1fr; gap: var(--space-lg); align-items: start; margin-top: var(--space-md); }
@media (min-width: 860px){ .tp-acca-inner{ grid-template-columns: 1.6fr 1fr; } }
.tp-acca-legs{ display: flex; flex-direction: column; gap: 0; }
.tp-acca-leg{ display: flex; align-items: center; gap: 0.9rem; padding: 1rem 1.1rem; background: rgba(255,255,255,0.05); border: 1px solid var(--panel-line); border-radius: var(--radius-md); }
.tp-acca-leg + .tp-acca-leg:not(.tp-acca-leg-connector){ margin-top: 0.5rem; }
.tp-acca-leg-connector{ background: transparent; border: none; padding: 0.15rem 0; justify-content: center; }
.tp-acca-plus{ font-family: var(--font-utility); font-size: 1.2rem; font-weight: 700; color: var(--panel-line-strong); }
.tp-acca-leg-num{ font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-micro); color: var(--text-on-panel-soft); flex-shrink: 0; width: 26px; }
.tp-acca-leg-body{ flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.2rem; }
.tp-acca-match{ font-family: var(--font-display); font-weight: 600; font-size: 0.95rem; color: var(--text-on-panel); }
.tp-acca-pick{ font-size: var(--fs-small); color: var(--text-on-panel-soft); display: flex; align-items: center; gap: 0.4rem; }
.tp-acca-leg .market-code{ background: rgba(79,196,128,0.18); color: var(--turf-300); }
.tp-acca-odds{ font-family: var(--font-utility); font-weight: 700; font-size: 1.1rem; color: var(--turf-300); flex-shrink: 0; }
.tp-acca-summary{ position: sticky; top: calc(clamp(64px, 8vw, 76px) + 52px + var(--space-md)); }
.tp-acca-summary-inner{ background: var(--ticket-bg); color: var(--ticket-ink); border-radius: var(--radius-lg); padding: var(--space-md); display: flex; flex-direction: column; gap: 0.7rem; box-shadow: var(--shadow-lg); }
.tp-acca-total-label{ font-family: var(--font-utility); font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: 0.08em; color: var(--ticket-faint); }
.tp-acca-total-odds{ font-family: var(--font-display); font-size: clamp(2.4rem, 5vw, 3.4rem); font-weight: 700; color: var(--turf-600); line-height: 1; }
.tp-acca-eg{ font-size: var(--fs-small); color: var(--ticket-soft); }
.tp-acca-eg b{ color: var(--ticket-ink); }
.tp-acca-tg{ width: 100%; justify-content: center; gap: 0.5rem; }
.tp-acca-disclaimer{ font-size: var(--fs-micro); color: var(--ticket-faint); line-height: 1.5; }

/* VIP teaser */
.tp-vip-teaser{ padding-block: var(--space-xl); background: var(--bg-surface); border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); }
.tp-vip-grid{ display: grid; grid-template-columns: 1fr; gap: var(--space-xl); align-items: center; }
@media (min-width: 860px){ .tp-vip-grid{ grid-template-columns: 1.2fr 0.8fr; } }
.tp-vip-copy h2{ font-family: var(--font-display); font-size: var(--fs-h2); font-weight: 600; color: var(--text-primary); margin-top: var(--space-sm); max-width: 26ch; }
.tp-vip-copy p{ color: var(--text-secondary); margin-top: var(--space-sm); max-width: 44ch; }
.tp-vip-perks{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.55rem; margin-top: var(--space-md); margin-bottom: var(--space-md); }
.tp-vip-perks li{ display: flex; align-items: flex-start; gap: 0.6rem; font-size: var(--fs-small); color: var(--text-secondary); }
.tp-vip-perks li svg{ flex-shrink: 0; margin-top: 2px; }
.tp-vip-preview{ position: relative; user-select: none; pointer-events: none; }
.tp-vip-preview .ticket{ max-width: none; margin-inline: 0; }
.tp-vip-blur{ filter: blur(6px); user-select: none; }
.tp-vip-lock{ position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0.5rem; background: rgba(255,255,255,0.55); border-radius: var(--radius-lg); font-family: var(--font-utility); font-size: var(--fs-small); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ticket-ink); backdrop-filter: blur(2px); pointer-events: none; }
html[data-theme="dark"] .tp-vip-lock{ background: rgba(15,42,31,0.6); color: var(--text-on-panel); }

/* Filter hidden state */
[data-hidden="true"]{ display: none !important; }

/* Narrow safety for tp page */
@media (max-width: 360px){
  .tp-acca-inner{ gap: var(--space-md); }
  .tp-banker-stats{ grid-template-columns: 1fr 1fr; }
}

/* ===================================================================
   TODAY'S PREDICTIONS PAGE — /todays-predictions  (v2 — data-page)
   Replaces the previous tp-* block above.
   =================================================================== */

/* ── Page bar ── */
.prd-pagebar {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-color);
  padding-block: var(--space-sm);
  transition: background-color .25s ease, border-color .25s ease;
}
.prd-pagebar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem var(--space-md);
}
.prd-page-title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2vw + .6rem, 1.85rem);
  font-weight: 600;
  color: var(--text-primary);
  margin-top: .15rem;
}
.prd-pagebar-right {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-shrink: 0;
}

/* Ensure all top strips have safe horizontal padding on every screen size */
.prd-pagebar .container,
.mw-explainer-strip .container,
.prd-stats-strip .container,
.prd-toolbar .container {
  padding-inline: max(1rem, env(safe-area-inset-left, 1rem));
}
@media (max-width: 480px) {
  .prd-pagebar .container,
  .mw-explainer-strip .container,
  .prd-stats-strip .container,
  .prd-toolbar .container {
    padding-inline: 1rem;
  }
  .prd-page-title {
    font-size: clamp(1.2rem, 5vw, 1.5rem);
  }
  .prd-pagebar-right {
    gap: .5rem;
  }
  .prd-date {
    display: none;
  }
}
.prd-live-chip {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--turf-600);
}
.prd-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--turf-500);
  animation: pulse-dot 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
.prd-date {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* ── Stats strip ── */
.prd-stats-strip {
  background: var(--bg-panel);
  padding-block: .6rem;
  transition: background-color .25s ease;
}
.prd-stats-inner {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.prd-stat {
  display: flex;
  align-items: baseline;
  gap: .35em;
}
.prd-stat b {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: 1rem;
  color: var(--turf-300);
}
.prd-stat span {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-on-panel-soft);
}
.prd-stat-tg { margin-left: auto; }
.prd-tg-link {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  font-family: var(--font-utility);
  font-size: var(--fs-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--gold-300);
  padding: .35em .8em;
  border: 1px solid rgba(230,199,120,.3);
  border-radius: 999px;
  transition: background .15s ease, border-color .15s ease;
}
.prd-tg-link:hover { background: rgba(230,199,120,.12); border-color: var(--gold-300); }

/* ── Toolbar ── */
.prd-toolbar {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-color);
  position: sticky;
  top: clamp(64px,8vw,76px);
  z-index: 80;
  transition: background-color .25s ease, border-color .25s ease;
}
.prd-toolbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  height: 48px;
}
.prd-filters {
  display: flex;
  align-items: center;
  gap: .35rem;
  overflow-x: auto;
  scrollbar-width: none;
  flex: 1; min-width: 0;
}
.prd-filters::-webkit-scrollbar { display: none; }
.prd-chip {
  display: inline-flex;
  align-items: center;
  gap: .35em;
  padding: .38em .9em;
  border-radius: 999px;
  border: 1.5px solid var(--border-color);
  background: transparent;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--text-faint);
  white-space: nowrap;
  cursor: pointer;
  flex-shrink: 0;
  transition: border-color .15s ease, background .15s ease, color .15s ease;
}
.prd-chip:hover, .prd-chip.active {
  border-color: var(--turf-500);
  background: var(--chip-tint-bg);
  color: var(--chip-tint-text);
}
.prd-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.prd-dot--banker { background: var(--gold-500); }
.prd-dot--sure   { background: var(--turf-500); }
.prd-dot--free   { background: var(--text-faint); }
.prd-dot--vip    { background: var(--gold-300); }
.prd-toolbar-right { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.prd-sort-label {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-faint);
  white-space: nowrap;
}
.prd-sort-sel {
  appearance: none; -webkit-appearance: none;
  background: var(--bg-page);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: .3em 1.8em .3em .6em;
  font-family: var(--font-utility);
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text-primary);
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237C8B81' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .55em center;
  background-size: 9px;
}
.prd-sort-sel:focus { outline: none; border-color: var(--turf-500); }
@media (max-width: 480px) { .prd-sort-label { display: none; } }

/* ── Layout: 2-col feed + sidebar ── */
.prd-layout { padding-block: var(--space-lg) var(--space-xl); }
.prd-layout-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
  align-items: start;
}
@media (min-width: 1060px) {
  .prd-layout-inner {
    grid-template-columns: 1fr 300px;
  }
}

/* ── Section scaffold ── */
.prd-section { margin-bottom: var(--space-lg); }
.prd-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: var(--space-sm);
  padding-bottom: .65rem;
  border-bottom: 2px solid var(--border-strong);
}
.prd-section-title {
  display: flex;
  align-items: center;
  gap: .6rem;
}
.prd-section-title h2 {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1.4vw + .4rem, 1.4rem);
  font-weight: 600;
  color: var(--text-primary);
}
.prd-section-sub {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-faint);
}

/* Grade badges */
.prd-grade-badge {
  display: inline-flex;
  align-items: center;
  padding: .2em .55em;
  border-radius: 5px;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .04em;
  flex-shrink: 0;
}
.prd-grade-badge--banker { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.prd-grade-badge--sure   { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.prd-grade-badge--free   { background: var(--bg-surface-2); color: var(--text-faint); border: 1px solid var(--border-color); }
.prd-grade-badge--acca   { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.prd-grade-badge--vip    { background: var(--gold-tint-bg); color: var(--gold-tint-text); }

/* Grade tags (inline small pill) */
.prd-grade-tag {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .62rem;
  padding: .15em .4em;
  border-radius: 4px;
  flex-shrink: 0;
  text-transform: uppercase;
}
.prd-grade-tag--sure   { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.prd-grade-tag--banker { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.prd-grade-tag--free   { background: var(--bg-surface-2); color: var(--text-faint); border: 1px solid var(--border-color); }

/* Market tag pill */
.prd-market-tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .03em;
  color: var(--chip-tint-text);
  background: var(--chip-tint-bg);
  padding: .15em .45em;
  border-radius: 4px;
  flex-shrink: 0;
}

/* ── Banker card ── */
.prd-banker-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  border-top: 3px solid var(--gold-500);
  transition: background-color .25s ease, border-color .25s ease;
}
.prd-banker-top {
  padding: var(--space-sm) var(--space-sm) var(--space-xs);
  border-bottom: 1px solid var(--border-color);
}
.prd-match-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .5rem;
}
.prd-league-chip {
  display: inline-flex;
  align-items: center;
  gap: .35em;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-faint);
}
.prd-ko-time {
  font-family: var(--font-utility);
  font-size: var(--fs-small);
  font-weight: 700;
  color: var(--text-secondary);
}
.prd-match-teams {
  display: flex;
  align-items: center;
  gap: .5em;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(1.1rem, 1.6vw + .4rem, 1.4rem);
  color: var(--text-primary);
}
.prd-vs {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  color: var(--text-faint);
  flex-shrink: 0;
}
.prd-team { flex: 1; }

.prd-banker-body { padding: var(--space-sm); }
.prd-pick-row {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
  margin-bottom: var(--space-sm);
}
.prd-pick-text {
  flex: 1;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--text-primary);
}
.prd-odds-pill {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: 1.35rem;
  color: var(--turf-500);
  white-space: nowrap;
}
.prd-conf {
  display: flex;
  align-items: center;
  gap: .5rem;
  width: 100%;
}
.prd-conf-bar {
  flex: 1;
  height: 5px;
  background: var(--border-color);
  border-radius: 999px;
  overflow: hidden;
}
.prd-conf-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--turf-400), var(--turf-600));
  border-radius: inherit;
}
.prd-conf-label {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  color: var(--turf-500);
  white-space: nowrap;
  min-width: 28px;
  text-align: right;
}

/* Analyst note */
.prd-analyst-note {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  background: var(--bg-surface-2);
  border-radius: var(--radius-sm);
  padding: .7rem .8rem;
  margin-bottom: var(--space-sm);
  transition: background-color .25s ease;
}
.prd-note-icon { color: var(--text-faint); flex-shrink: 0; margin-top: 1px; }
.prd-analyst-note p { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.6; }

/* Banker stats row */
.prd-banker-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .6rem;
}
@media (min-width: 540px) { .prd-banker-stats { grid-template-columns: repeat(4, 1fr); } }
.prd-bstat {
  background: var(--bg-page);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: .55rem .7rem;
  display: flex;
  flex-direction: column;
  gap: .2rem;
  transition: background-color .25s ease;
}
.prd-bstat span {
  font-family: var(--font-utility);
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-faint);
  line-height: 1.3;
}
.prd-bstat b {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .95rem;
  color: var(--text-primary);
}

/* ── Sure / pick list ── */
.prd-picks-list { display: flex; flex-direction: column; gap: .5rem; }
.prd-pick {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  transition: border-color .15s ease, background-color .25s ease;
}
.prd-pick:hover { border-color: var(--turf-500); }
.prd-pick-left { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .45rem; }
.prd-pick-meta {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}
.prd-pick-ko {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.prd-pick-league {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.prd-pick-fixture {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
}
.prd-pick-fixture b { font-weight: 400; color: var(--text-faint); font-size: .85em; }
.prd-pick-selection {
  display: flex;
  align-items: center;
  gap: .45rem;
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text-primary);
}
.prd-pick-reason {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.55;
}
.prd-pick-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .5rem;
  flex-shrink: 0;
  padding-top: .15rem;
}
.prd-odds {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: 1.3rem;
  color: var(--turf-500);
}
.prd-conf-vert {
  display: flex;
  align-items: center;
  gap: .4rem;
}
.prd-conf-bar--vert {
  width: 60px;
  height: 4px;
  background: var(--border-color);
  border-radius: 999px;
  overflow: hidden;
}

/* ── Free tips table ── */
.prd-league-block { margin-bottom: var(--space-md); }
.prd-league-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--border-strong);
  margin-bottom: .1rem;
}
.prd-league-flag { font-size: 1rem; line-height: 1; }
.prd-league-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
}
.prd-league-country {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-faint);
  margin-right: .2em;
}
.prd-league-count {
  margin-left: auto;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-faint);
}

.prd-table { width: 100%; }
.prd-table-head, .prd-row {
  display: grid;
  grid-template-columns: 48px 1fr 58px 1fr 56px 46px;
  align-items: center;
  gap: .4rem .65rem;
  padding: .65rem .4rem;
}
.prd-table-head {
  font-family: var(--font-utility);
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-faint);
  border-bottom: 1px solid var(--border-color);
}
.prd-row {
  border-bottom: 1px solid var(--border-color);
  font-size: var(--fs-small);
  color: var(--text-secondary);
  transition: background-color .1s ease;
}
.prd-row:last-child { border-bottom: none; }
.prd-row:hover { background: var(--bg-surface); }

.prd-row-time {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.prd-row-match { font-weight: 500; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prd-row-match em { font-style: normal; color: var(--text-faint); font-size: .85em; }
.prd-row-mkt { display: flex; }
.prd-row-pick { color: var(--text-primary); font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.prd-row-odds { font-family: var(--font-utility); font-weight: 700; color: var(--turf-500); }
.prd-row-conf { font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-micro); }
.prd-conf-high { color: var(--turf-500); }
.prd-conf-mid  { color: var(--text-secondary); }
.prd-conf-low  { color: var(--text-faint); }
.ta-r { text-align: right; justify-content: flex-end; }

@media (max-width: 640px) {
  .prd-table-head { display: none; }
  .prd-row {
    grid-template-columns: 44px 1fr 50px 44px;
    grid-template-rows: auto auto;
    gap: .25rem .5rem;
    padding: .75rem .4rem;
  }
  .prd-row-time  { grid-column: 1; grid-row: 1; }
  .prd-row-match { grid-column: 2 / -1; grid-row: 1; }
  .prd-row-mkt   { grid-column: 1; grid-row: 2; }
  .prd-row-pick  { grid-column: 2; grid-row: 2; font-size: var(--fs-small); }
  .prd-row-odds  { grid-column: 3; grid-row: 2; text-align: right; }
  .prd-row-conf  { grid-column: 4; grid-row: 2; text-align: right; }
}

/* ── Accumulator ── */
.prd-acca-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  display: grid;
  grid-template-columns: 1fr;
  overflow: hidden;
  transition: background-color .25s ease, border-color .25s ease;
}
@media (min-width: 700px) { .prd-acca-card { grid-template-columns: 1fr auto; } }
.prd-acca-legs { padding: var(--space-sm); display: flex; flex-direction: column; gap: 0; }
.prd-acca-leg {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .75rem 0;
  border-bottom: 1px dashed var(--border-color);
}
.prd-acca-leg:last-child { border-bottom: none; }
.prd-acca-num {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-micro);
  color: var(--text-faint);
  flex-shrink: 0;
  width: 22px;
}
.prd-acca-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .15rem; }
.prd-acca-fix {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: .9rem;
  color: var(--text-primary);
}
.prd-acca-sel {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.prd-acca-odds {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: 1rem;
  color: var(--turf-500);
  flex-shrink: 0;
}
.prd-acca-sep {
  text-align: center;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  color: var(--text-faint);
  padding: .1rem 0;
  display: none; /* hidden — visual sep done via border-bottom on leg */
}
.prd-acca-total {
  background: var(--bg-panel);
  color: var(--text-on-panel);
  padding: var(--space-md) var(--space-sm);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  min-width: 160px;
  text-align: center;
  transition: background-color .25s ease;
}
.prd-acca-combined-label {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-on-panel-soft);
}
.prd-acca-combined-odds {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 700;
  color: var(--turf-300);
  line-height: 1;
}
.prd-acca-eg { font-size: var(--fs-small); color: var(--text-on-panel-soft); }
.prd-acca-eg b { color: var(--text-on-panel); }
.prd-acca-disc { font-size: var(--fs-micro); color: var(--text-on-panel-soft); max-width: 16ch; line-height: 1.4; }

/* ── VIP locked card ── */
.prd-vip-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: flex-start;
  transition: background-color .25s ease, border-color .25s ease;
}
.prd-vip-lock-icon { color: var(--gold-500); flex-shrink: 0; padding-top: .2rem; }
.prd-vip-copy { flex: 1; min-width: 220px; }
.prd-vip-copy h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--text-primary);
  margin-bottom: .4rem;
}
.prd-vip-copy > p { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.6; }
.prd-vip-list {
  list-style: none; padding: 0; margin: .7rem 0 0;
  display: flex; flex-direction: column; gap: .4rem;
}
.prd-vip-list li {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.prd-vip-list li::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold-500);
  flex-shrink: 0;
}
.prd-vip-btn { flex-shrink: 0; align-self: flex-start; }

/* SEO section within feed */
.prd-seo {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-md);
  margin-top: var(--space-lg);
  transition: background-color .25s ease, border-color .25s ease;
}
.prd-seo .eyebrow { color: var(--accent-heading); }
.prd-seo h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(1.3rem, 2vw + .5rem, 1.9rem);
  color: var(--text-primary);
  margin-top: .5rem;
  line-height: 1.2;
}
.prd-seo h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--text-primary);
  margin-top: var(--space-md);
}
.prd-seo p {
  color: var(--text-secondary);
  font-size: var(--fs-body);
  line-height: 1.75;
  margin-top: .6rem;
}
.prd-seo a { color: var(--turf-500); font-weight: 600; }
.prd-seo a:hover { color: var(--turf-400); }
.prd-seo .responsible-callout { margin-top: var(--space-lg); }

/* ── Sidebar ── */
.prd-sidebar { display: flex; flex-direction: column; gap: var(--space-sm); }
@media (min-width: 1060px) {
  .prd-sidebar { position: sticky; top: calc(clamp(64px,8vw,76px) + 48px + var(--space-md)); }
}
.prd-sidebar-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  transition: background-color .25s ease, border-color .25s ease;
}
.prd-sidebar-title {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--accent-heading);
  margin-bottom: .75rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--border-color);
}

.prd-summary-rows { display: flex; flex-direction: column; gap: .1rem; margin-bottom: .75rem; }
.prd-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .45rem .2rem;
  border-bottom: 1px solid var(--border-color);
  font-size: var(--fs-small);
}
.prd-summary-row:last-child { border-bottom: none; }
.prd-summary-label { display: flex; align-items: center; gap: .4rem; color: var(--text-secondary); }
.prd-summary-val { font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); color: var(--text-primary); }
.prd-summary-locked { color: var(--gold-500); }
.prd-summary-acca-link {
  display: inline-flex;
  align-items: center;
  gap: .35em;
  font-family: var(--font-utility);
  font-size: var(--fs-small);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--turf-500);
}
.prd-summary-acca-link:hover { color: var(--turf-400); }

.prd-markets-nav { display: flex; flex-direction: column; gap: .1rem; }
.prd-markets-nav a {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  padding: .45rem .2rem;
  border-bottom: 1px solid var(--border-color);
  transition: color .12s ease, background .12s ease;
}
.prd-markets-nav a:last-of-type { border-bottom: none; }
.prd-markets-nav a:hover { color: var(--turf-500); background: var(--bg-surface-2); border-radius: var(--radius-sm); }
.prd-markets-all {
  font-family: var(--font-utility);
  font-weight: 700;
  color: var(--turf-500) !important;
  margin-top: .3rem;
  border-bottom: none !important;
}

.prd-sidebar-tg p { font-size: var(--fs-small); color: var(--text-secondary); margin-bottom: .75rem; }
.prd-tg-sub { font-size: var(--fs-micro); color: var(--text-faint); text-align: center; margin-top: .4rem !important; }
.prd-sidebar-resp b { font-size: var(--fs-small); color: var(--text-primary); display: block; margin-bottom: .3rem; }
.prd-sidebar-resp p { font-size: var(--fs-micro); color: var(--text-faint); line-height: 1.5; }
.prd-sidebar-resp a { color: var(--turf-500); font-weight: 600; }

/* Hidden via filter */
[data-hidden="true"] { display: none !important; }

/* Narrow safety */
@media (max-width: 360px) {
  .prd-banker-stats { grid-template-columns: 1fr 1fr; }
  .prd-vip-card { flex-direction: column; }
}

/* ===================================================================
   MATCH WINNER PAGE — /match-winner
   =================================================================== */

/* Market explainer strip */
.mw-explainer-strip {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-color);
  padding-block: .65rem;
  transition: background-color .25s ease, border-color .25s ease;
}
.mw-explainer-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .6rem var(--space-md);
}
.mw-outcome { display: inline-flex; align-items: center; gap: .45rem; }
.mw-outcome-code {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: 1rem;
  width: 28px; height: 28px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.mw-outcome--home .mw-outcome-code { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.mw-outcome--draw .mw-outcome-code { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.mw-outcome--away .mw-outcome-code { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }
.mw-outcome-label {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-secondary);
}
.mw-outcome-sep { color: var(--border-strong); font-weight: 700; }
.mw-explainer-divider {
  width: 1px; height: 18px;
  background: var(--border-color);
  flex-shrink: 0;
  display: none;
}
@media (min-width: 540px) { .mw-explainer-divider { display: block; } }
.mw-explainer-note {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-faint);
}

/* Toolbar label (replaces filter chips) */
.mw-toolbar-label {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--font-utility);
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Page title market tag */
.prd-page-title-market {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .7em;
  background: var(--chip-tint-bg);
  color: var(--chip-tint-text);
  padding: .15em .5em;
  border-radius: 6px;
  vertical-align: middle;
  margin-left: .3rem;
  letter-spacing: .04em;
}

/* Outcome badge on banker card */
.mw-outcome-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .04em;
  padding: .2em .55em;
  border-radius: 5px;
  text-transform: uppercase;
  flex-shrink: 0;
}
.mw-outcome-badge--home { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.mw-outcome-badge--draw { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.mw-outcome-badge--away { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* Table — 8 columns: Time, League, Match, Pick, Result, Odds, Conf., Grade */
.mw-table-head,
.mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 68px 56px 46px 56px;
}
@media (max-width: 900px) {
  /* Drop League column */
  .mw-table-head,
  .mw-row { grid-template-columns: 48px 1fr 1fr 68px 56px 46px 56px; }
  .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .mw-table-head { display: none !important; }
  .mw-row {
    grid-template-columns: 52px 1fr 60px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .mw-row .prd-row-time     { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .mw-row .prd-row-match    { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .mw-row .prd-row-pick     { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .mw-row .mw-result-badge  { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .mw-row .prd-row-odds     { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .mw-row .prd-row-conf     { display: none !important; }
  .mw-row .mw-row-grade,
  .mw-row .prd-row-league   { display: none !important; }
}

/* League label inside table row */
.prd-row-league {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-faint);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Result badge */
.mw-result-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .62rem;
  letter-spacing: .04em;
  padding: .18em .45em;
  border-radius: 4px;
  text-transform: uppercase;
  white-space: nowrap;
}
.mw-result-badge--home { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.mw-result-badge--draw { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.mw-result-badge--away { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }
.mw-row-grade { display: flex; }

/* View More button */
.mw-viewmore-wrap {
  text-align: center;
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-color);
}
.mw-viewmore-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .7em 1.6em;
  border-radius: 999px;
  border: 1.5px solid var(--border-strong);
  background: var(--bg-surface);
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-secondary);
  cursor: pointer;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.mw-viewmore-btn:hover {
  border-color: var(--turf-500);
  color: var(--turf-500);
  background: var(--chip-tint-bg);
}
.mw-viewmore-btn svg { transition: transform .2s ease; }
.mw-viewmore-btn.is-expanded svg { transform: rotate(180deg); }

/* Extra rows hidden via JS inline style — no CSS class needed */

/* Outcome breakdown grid */
.mw-breakdown-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.mw-breakdown-card {
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-sm);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .3rem;
  transition: background-color .25s ease, border-color .25s ease;
}
.mw-breakdown-code { font-family: var(--font-utility); font-weight: 700; font-size: 1.6rem; line-height: 1; }
.mw-breakdown-label { font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-micro); text-transform: uppercase; letter-spacing: .07em; color: var(--text-faint); }
.mw-breakdown-count { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.6rem, 3vw, 2.4rem); line-height: 1; margin-top: .2rem; }
.mw-breakdown-sub { font-size: var(--fs-micro); color: var(--text-faint); }
.mw-breakdown-card--home { background: var(--chip-tint-bg); border-color: transparent; }
.mw-breakdown-card--home .mw-breakdown-code,
.mw-breakdown-card--home .mw-breakdown-count { color: var(--chip-tint-text); }
.mw-breakdown-card--draw { background: var(--gold-tint-bg); border-color: transparent; }
.mw-breakdown-card--draw .mw-breakdown-code,
.mw-breakdown-card--draw .mw-breakdown-count { color: var(--gold-tint-text); }
.mw-breakdown-card--away { background: var(--bg-surface); }
.mw-breakdown-card--away .mw-breakdown-code,
.mw-breakdown-card--away .mw-breakdown-count { color: var(--text-secondary); }

/* Related markets grid */
.mw-related-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .75rem;
}
@media (max-width: 540px) { .mw-related-grid { grid-template-columns: 1fr; } }
.mw-related-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  display: flex;
  flex-direction: column;
  gap: .4rem;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background-color .25s ease;
}
.mw-related-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--turf-500); }
.mw-related-name { font-family: var(--font-display); font-weight: 600; font-size: 1rem; color: var(--text-primary); }
.mw-related-desc { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.55; }

/* Sidebar guide card */
.mw-guide-rows { display: flex; flex-direction: column; gap: .1rem; margin-bottom: .5rem; }
.mw-guide-row { display: flex; align-items: flex-start; gap: .6rem; padding: .5rem .2rem; border-bottom: 1px solid var(--border-color); }
.mw-guide-row:last-child { border-bottom: none; }
.mw-guide-row b { font-size: var(--fs-small); color: var(--text-primary); display: block; }
.mw-guide-row p { font-size: var(--fs-micro); color: var(--text-faint); margin-top: .1rem; }
.mw-guide-note { font-size: var(--fs-micro); color: var(--text-faint); line-height: 1.5; padding-top: .4rem; border-top: 1px solid var(--border-color); margin-top: .3rem; }

/* Mini outcome codes for sidebar */
.mw-mini-code {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .7rem;
  width: 20px; height: 20px;
  border-radius: 4px;
  flex-shrink: 0;
}
.mw-mini-code--home { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.mw-mini-code--draw { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.mw-mini-code--away { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* ===================================================================
   DOUBLE CHANCE PAGE — /double-chance
   =================================================================== */

/* DC explainer strip outcome code — wider pill for two-char codes */
.dc-code {
  width: auto;
  padding-inline: .45em;
  font-size: .85rem;
  letter-spacing: .02em;
}
.dc-code--12 {
  background: var(--bg-surface-2);
  color: var(--text-secondary);
  border: 1px solid var(--border-color);
}

/* DC badge in table rows and banker card */
.dc-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .06em;
  padding: .2em .6em;
  border-radius: 5px;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.dc-badge--1X { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.dc-badge--X2 { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.dc-badge--12 { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* DC mini codes for sidebar */
.dc-mini {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .04em;
  min-width: 24px;
  height: 20px;
  padding-inline: .3em;
  border-radius: 4px;
  flex-shrink: 0;
}
.dc-mini--1X { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.dc-mini--X2 { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.dc-mini--12 { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* DC table — same 8-col grid as mw-table, DC column replaces Result */
.dc-table .mw-table-head,
.dc-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 52px 56px 46px 56px;
}
@media (max-width: 900px) {
  .dc-table .mw-table-head,
  .dc-table .mw-row { grid-template-columns: 48px 1fr 1fr 52px 56px 46px 56px; }
  .dc-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .dc-table .mw-table-head { display: none !important; }
  .dc-table .mw-row {
    grid-template-columns: 52px 1fr 40px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .dc-table .mw-row .prd-row-time  { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .dc-table .mw-row .prd-row-match { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .dc-table .mw-row .prd-row-pick  { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .dc-table .mw-row .dc-badge      { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .dc-table .mw-row .prd-row-odds  { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .dc-table .mw-row .prd-row-conf  { display: none !important; }
  .dc-table .mw-row .mw-row-grade,
  .dc-table .mw-row .prd-row-league { display: none !important; }
}

/* ===================================================================
   DRAW NO BET TABLE — /draw-no-bet
   8 columns: Time, League, Match, Pick, DNB badge, Odds, Conf., Grade
   =================================================================== */
.dnb-table.mw-table-head,
.dnb-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 52px 56px 46px 56px;
}
@media (max-width: 900px) {
  .dnb-table .mw-table-head,
  .dnb-table .mw-row { grid-template-columns: 48px 1fr 1fr 52px 56px 46px 56px; }
  .dnb-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .dnb-table .mw-table-head { display: none !important; }
  .dnb-table .mw-row {
    grid-template-columns: 52px 1fr 48px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .dnb-table .mw-row .prd-row-time  { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .dnb-table .mw-row .prd-row-match { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .dnb-table .mw-row .prd-row-pick  { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); color: var(--text-primary); font-weight: 500; }
  .dnb-table .mw-row .dc-badge      { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .dnb-table .mw-row .prd-row-odds  { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .dnb-table .mw-row .prd-row-conf  { display: none !important; }
  .dnb-table .mw-row .mw-row-grade,
  .dnb-table .mw-row .prd-row-league { display: none !important; }
}

/* ===================================================================
   CORRECT SCORE PAGE — /correct-score
   =================================================================== */

/* Score type badges — H Win / Draw / A Win */
.cs-score-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .04em;
  padding: .2em .6em;
  border-radius: 5px;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.cs-score-badge--home  { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.cs-score-badge--draw  { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.cs-score-badge--away  { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* CS table reuses dnb-table 8-col grid exactly */
.cs-table.mw-table-head,
.cs-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 52px 56px 52px 56px;
}
@media (max-width: 900px) {
  .cs-table .mw-table-head,
  .cs-table .mw-row { grid-template-columns: 48px 1fr 1fr 52px 56px 52px 56px; }
  .cs-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .cs-table .mw-table-head { display: none !important; }
  .cs-table .mw-row {
    grid-template-columns: 52px 1fr 44px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .cs-table .mw-row .prd-row-time       { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .cs-table .mw-row .prd-row-match      { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .cs-table .mw-row .prd-row-pick       { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 600; color: var(--text-primary); }
  .cs-table .mw-row .cs-score-badge     { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .cs-table .mw-row .prd-row-odds       { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .cs-table .mw-row .prd-row-conf       { display: none !important; }
  .cs-table .mw-row .mw-row-grade,
  .cs-table .mw-row .prd-row-league     { display: none !important; }
}

/* ===================================================================
   HALF-TIME RESULT PAGE — /half-time-result
   8 columns: Time, League, Match, Pick, HT badge, Odds, Conf., Grade
   Reuses mw-result-badge colours (home/draw/away) already in CSS.
   =================================================================== */
.ht-table .mw-table-head,
.ht-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 52px 56px 46px 56px;
}
@media (max-width: 900px) {
  .ht-table .mw-table-head,
  .ht-table .mw-row { grid-template-columns: 48px 1fr 1fr 52px 56px 46px 56px; }
  .ht-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .ht-table .mw-table-head { display: none !important; }
  .ht-table .mw-row {
    grid-template-columns: 52px 1fr 44px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .ht-table .mw-row .prd-row-time        { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .ht-table .mw-row .prd-row-match       { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .ht-table .mw-row .prd-row-pick        { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .ht-table .mw-row .mw-result-badge     { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .ht-table .mw-row .prd-row-odds        { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .ht-table .mw-row .prd-row-conf        { display: none !important; }
  .ht-table .mw-row .mw-row-grade,
  .ht-table .mw-row .prd-row-league      { display: none !important; }
}

/* ===================================================================
   HALF-TIME / FULL-TIME PAGE — /half-time-full-time
   =================================================================== */

/* HT/FT combination badges */
.htft-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .06em;
  padding: .2em .55em;
  border-radius: 5px;
  white-space: nowrap;
  flex-shrink: 0;
}
/* 1/1 — home/home: green */
.htft-badge--11 { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
/* X/1 — draw/home: teal-ish using surface */
.htft-badge--x1 { background: var(--bg-surface-2); color: var(--turf-600); border: 1px solid var(--turf-300); }
/* X/X — draw/draw: gold */
.htft-badge--xx { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
/* X/2 — draw/away: gold variant */
.htft-badge--x2 { background: var(--gold-tint-bg); color: var(--gold-600); border: 1px solid var(--gold-300); }
/* 2/2 — away/away: neutral */
.htft-badge--22 { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* HT/FT code in breakdown tiles */
.htft-code { font-size: .95rem !important; letter-spacing: .04em; }

/* HT/FT breakdown — 5-column grid */
.htft-breakdown-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
}
@media (min-width: 540px) {
  .htft-breakdown-grid { grid-template-columns: repeat(5, 1fr); }
}

/* HT/FT table — 8 columns */
.htft-table .mw-table-head,
.htft-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 52px 56px 46px 56px;
}
@media (max-width: 900px) {
  .htft-table .mw-table-head,
  .htft-table .mw-row { grid-template-columns: 48px 1fr 1fr 52px 56px 46px 56px; }
  .htft-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .htft-table .mw-table-head { display: none !important; }
  .htft-table .mw-row {
    grid-template-columns: 52px 1fr 44px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .htft-table .mw-row .prd-row-time   { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .htft-table .mw-row .prd-row-match  { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .htft-table .mw-row .prd-row-pick   { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .htft-table .mw-row .htft-badge     { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .htft-table .mw-row .prd-row-odds   { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .htft-table .mw-row .prd-row-conf   { display: none !important; }
  .htft-table .mw-row .mw-row-grade,
  .htft-table .mw-row .prd-row-league { display: none !important; }
}

/* ===================================================================
   HANDICAP PAGE — /handicap
   =================================================================== */

/* Handicap line badges */
.hcap-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .04em;
  padding: .2em .6em;
  border-radius: 5px;
  white-space: nowrap;
  flex-shrink: 0;
}
/* Negative handicap (−1, −2) — green: favourite must cover */
.hcap-badge--neg { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
/* Positive handicap (+1, +2) — gold: underdog given head-start */
.hcap-badge--pos { background: var(--gold-tint-bg); color: var(--gold-tint-text); }

/* HCAP table — 8 columns, reuses mw-table grid */
.hcap-table .mw-table-head,
.hcap-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 52px 56px 46px 56px;
}
@media (max-width: 900px) {
  .hcap-table .mw-table-head,
  .hcap-table .mw-row { grid-template-columns: 48px 1fr 1fr 52px 56px 46px 56px; }
  .hcap-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .hcap-table .mw-table-head { display: none !important; }
  .hcap-table .mw-row {
    grid-template-columns: 52px 1fr 44px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .hcap-table .mw-row .prd-row-time   { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .hcap-table .mw-row .prd-row-match  { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .hcap-table .mw-row .prd-row-pick   { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .hcap-table .mw-row .hcap-badge     { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .hcap-table .mw-row .prd-row-odds   { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .hcap-table .mw-row .prd-row-conf   { display: none !important; }
  .hcap-table .mw-row .mw-row-grade,
  .hcap-table .mw-row .prd-row-league { display: none !important; }
}

/* ===================================================================
   ASIAN HANDICAP PAGE — /asian-handicap
   =================================================================== */
.ah-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .03em;
  padding: .2em .55em;
  border-radius: 5px;
  white-space: nowrap;
  flex-shrink: 0;
}
.ah-badge--neg { background: var(--chip-tint-bg); color: var(--chip-tint-text); }
.ah-badge--pos { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.ah-badge--qtr { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

.ah-table .mw-table-head,
.ah-table .mw-row {
  grid-template-columns: 48px 100px 1fr 1fr 56px 56px 46px 56px;
}
@media (max-width: 900px) {
  .ah-table .mw-table-head,
  .ah-table .mw-row { grid-template-columns: 48px 1fr 1fr 56px 56px 46px 56px; }
  .ah-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .ah-table .mw-table-head { display: none !important; }
  .ah-table .mw-row {
    grid-template-columns: 52px 1fr 52px 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .6rem !important;
    padding: .85rem .5rem !important;
  }
  .ah-table .mw-row .prd-row-time   { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .ah-table .mw-row .prd-row-match  { grid-column: 2 / 5 !important; grid-row: 1 !important; }
  .ah-table .mw-row .prd-row-pick   { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .ah-table .mw-row .ah-badge       { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .ah-table .mw-row .prd-row-odds   { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .ah-table .mw-row .prd-row-conf   { display: none !important; }
  .ah-table .mw-row .mw-row-grade,
  .ah-table .mw-row .prd-row-league { display: none !important; }
}

/* ===================================================================
   ACCUMULATOR PAGE — /accumulator
   =================================================================== */

/* Acca fold badge */
.acca-fold-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .06em;
  padding: .2em .65em;
  border-radius: 5px;
  background: var(--chip-tint-bg);
  color: var(--chip-tint-text);
  white-space: nowrap;
  flex-shrink: 0;
}
.acca-fold-badge--btts  { background: var(--gold-tint-bg); color: var(--gold-tint-text); }
.acca-fold-badge--mixed { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* Acca market tag */
.acca-market-tag {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-faint);
}

/* Acca estimated odds */
.acca-est-odds {
  font-family: var(--font-utility);
  font-size: var(--fs-small);
  color: var(--text-secondary);
}
.acca-est-odds b { color: var(--turf-500); }

/* Acca card shell */
.acca-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color .2s ease;
}
.acca-card:hover { border-color: var(--turf-300); }

/* Acca card head */
.acca-card-head {
  padding: .85rem 1rem .7rem;
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-surface-2);
}
.acca-meta {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}

/* Acca legs list */
.acca-legs {
  display: flex;
  flex-direction: column;
}
.acca-leg {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--border-subtle, color-mix(in srgb, var(--border-color) 50%, transparent));
  gap: 1rem;
  flex-wrap: wrap;
}
.acca-leg:last-child { border-bottom: none; }

.acca-leg-match {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex: 1;
  min-width: 0;
  flex-wrap: wrap;
}
.acca-leg-time {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  color: var(--text-secondary);
  white-space: nowrap;
  flex-shrink: 0;
}
.acca-leg-league {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-faint);
  white-space: nowrap;
  flex-shrink: 0;
}
.acca-leg-teams {
  font-size: var(--fs-body);
  font-weight: 500;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.acca-leg-teams em { font-style: normal; color: var(--text-faint); font-size: .8em; margin: 0 .2em; }

.acca-leg-pick {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-shrink: 0;
}
.acca-leg-pick-text {
  font-size: var(--fs-small);
  font-weight: 500;
  color: var(--text-secondary);
  white-space: nowrap;
}
.acca-leg-odds {
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: var(--fs-small);
  color: var(--turf-500);
  white-space: nowrap;
}

/* Acca card foot */
.acca-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  background: var(--bg-surface-2);
  border-top: 1px solid var(--border-color);
  gap: 1rem;
  flex-wrap: wrap;
}
.acca-foot-stats {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  color: var(--text-faint);
  flex-wrap: wrap;
}
.acca-foot-sep { color: var(--border-color); }
.acca-tg-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--turf-600);
  text-decoration: none;
  white-space: nowrap;
}
.acca-tg-btn:hover { color: var(--turf-500); }

/* Mobile */
@media (max-width: 600px) {
  .acca-leg { flex-direction: column; align-items: flex-start; gap: .5rem; }
  .acca-leg-pick { width: 100%; justify-content: flex-start; }
  .acca-leg-teams { white-space: normal; }
  .acca-card-foot { flex-direction: column; align-items: flex-start; }
}

/* ===================================================================
   SURE TIPS PAGE — /sure-tips
   Extra column: Market tag between League and Match columns
   =================================================================== */
.sure-table .mw-table-head,
.sure-table .mw-row {
  grid-template-columns: 48px 90px 1fr 52px 1fr 56px 56px 46px 56px;
}
@media (max-width: 900px) {
  .sure-table .mw-table-head,
  .sure-table .mw-row { grid-template-columns: 48px 1fr 52px 1fr 56px 46px 56px; }
  .sure-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .sure-table .mw-table-head { display: none !important; }
  .sure-table .mw-row {
    grid-template-columns: 52px 44px 1fr 52px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .5rem !important;
    padding: .85rem .5rem !important;
  }
  .sure-table .mw-row .prd-row-time    { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .sure-table .mw-row .sure-mkt-tag   { grid-column: 2 !important; grid-row: 1 !important; }
  .sure-table .mw-row .prd-row-match  { grid-column: 3 / 5 !important; grid-row: 1 !important; }
  .sure-table .mw-row .prd-row-pick   { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .sure-table .mw-row [class*="-badge"], .sure-table .mw-row [class*="result-badge"] { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .sure-table .mw-row .prd-row-odds   { grid-column: 4 !important; grid-row: 2 !important; text-align: right; color: var(--turf-500); font-weight: 700; }
  .sure-table .mw-row .prd-row-conf,
  .sure-table .mw-row .mw-row-grade,
  .sure-table .mw-row .prd-row-league { display: none !important; }
}

/* Market tag inline cell */
.sure-mkt-tag { display: flex; align-items: center; }

/* ===================================================================
   HIGH VALUE TIPS PAGE — /high-value-tips
   =================================================================== */

/* Edge badge */
.val-edge-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .04em;
  padding: .2em .55em;
  border-radius: 5px;
  background: var(--gold-tint-bg);
  color: var(--gold-tint-text);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Value table: 9 cols — Time, League, Match, Market, Pick, Type badge, Odds, Model%, Edge */
.val-table .mw-table-head,
.val-table .mw-row {
  grid-template-columns: 48px 90px 1fr 52px 1fr 60px 56px 52px 56px;
}
@media (max-width: 1000px) {
  .val-table .mw-table-head,
  .val-table .mw-row { grid-template-columns: 48px 1fr 52px 1fr 60px 56px 52px 56px; }
  .val-table .prd-row-league { display: none; }
}
@media (max-width: 680px) {
  .val-table .mw-table-head { display: none !important; }
  .val-table .mw-row {
    grid-template-columns: 52px 44px 1fr 56px !important;
    grid-template-rows: auto auto !important;
    gap: .3rem .5rem !important;
    padding: .85rem .5rem !important;
  }
  .val-table .mw-row .prd-row-time    { grid-column: 1 !important; grid-row: 1 !important; font-weight: 700; }
  .val-table .mw-row .sure-mkt-tag   { grid-column: 2 !important; grid-row: 1 !important; }
  .val-table .mw-row .prd-row-match  { grid-column: 3 / 5 !important; grid-row: 1 !important; }
  .val-table .mw-row .prd-row-pick   { grid-column: 1 / 3 !important; grid-row: 2 !important; font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
  .val-table .mw-row [class*="-badge"]:not(.val-edge-badge) { grid-column: 3 !important; grid-row: 2 !important; justify-self: end; }
  .val-table .mw-row .val-edge-badge  { grid-column: 4 !important; grid-row: 2 !important; }
  .val-table .mw-row .prd-row-odds,
  .val-table .mw-row .prd-row-conf,
  .val-table .mw-row .prd-row-league  { display: none !important; }
}

/* ===================================================================
   VIP PAGE — /vip
   =================================================================== */

/* Hero */
.vip-hero {
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border-color);
  padding: clamp(2.5rem, 6vw, 4.5rem) 0;
}
.vip-hero-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem 3rem;
  align-items: center;
}
@media (max-width: 680px) {
  .vip-hero-inner { grid-template-columns: 1fr; }
  .vip-hero-badge-wrap { display: none; }
}
.vip-hero-text .eyebrow {
  display: block;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--turf-400);
  margin-bottom: .6rem;
}
.vip-hero-title {
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 4vw + .5rem, 3.2rem);
  font-weight: 700;
  color: var(--text-on-panel);
  line-height: 1.08;
  margin-bottom: 1rem;
}
.vip-hero-sub {
  font-size: var(--fs-body);
  color: var(--text-on-panel-soft);
  max-width: 520px;
  margin-bottom: 1.5rem;
  line-height: 1.6;
}
.vip-hero-sub strong { color: var(--text-on-panel); }
.vip-hero-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: .9rem; }
.vip-tg-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: var(--fs-body);
  padding: .7rem 1.4rem;
  font-weight: 700;
}
.vip-free-btn {
  display: inline-flex;
  align-items: center;
  font-size: var(--fs-body);
  padding: .7rem 1.2rem;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  color: var(--text-on-panel-soft);
  text-decoration: none;
  font-weight: 500;
  transition: border-color .2s, color .2s;
}
.vip-free-btn:hover { border-color: var(--turf-400); color: var(--text-on-panel); }
.vip-hero-members { font-family: var(--font-utility); font-size: var(--fs-small); color: var(--text-on-panel-soft); }
.vip-member-count { font-weight: 700; color: var(--turf-300); }

/* VIP badge */
.vip-hero-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 1.5rem 2rem;
  min-width: 120px;
}
.vip-badge-label { font-family: var(--font-utility); font-weight: 700; font-size: 1.1rem; letter-spacing: .1em; color: #FFD700; }
.vip-badge-sub { font-size: var(--fs-micro); color: var(--text-on-panel-soft); white-space: nowrap; }

/* Sections */
.vip-section { padding: clamp(2rem, 5vw, 4rem) 0; }
.vip-section--dark {
  background: var(--bg-panel);
  color: var(--text-on-panel);
}
.vip-section-head { text-align: center; margin-bottom: 2rem; }
.vip-section-title {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.5vw + .3rem, 2rem);
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: .4rem;
}
.vip-section--dark .vip-section-title { color: var(--text-on-panel); }
.vip-section-sub { font-size: var(--fs-small); color: var(--text-faint); }
.vip-section--dark .vip-section-sub { color: var(--text-on-panel-soft); }

/* Features grid */
.vip-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}
.vip-feature-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1.25rem 1.25rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  transition: border-color .2s ease, transform .15s ease;
}
.vip-feature-card:hover { border-color: var(--turf-300); transform: translateY(-2px); }
.vip-feature-icon { margin-bottom: .25rem; }
.vip-feature-card h3 { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--text-primary); margin: 0; }
.vip-feature-card p { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.55; margin: 0; flex: 1; }
.vip-feature-link { font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--turf-500); text-decoration: none; margin-top: auto; }
.vip-feature-link:hover { color: var(--turf-400); }

/* Steps */
.vip-steps {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.vip-step {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  max-width: 240px;
  flex: 1 1 200px;
}
.vip-step-num {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--turf-600);
  color: #fff;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .95rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.vip-step-body h3 { font-size: var(--fs-body); font-weight: 600; color: var(--text-on-panel); margin: 0 0 .3rem; }
.vip-step-body p { font-size: var(--fs-small); color: var(--text-on-panel-soft); margin: 0; line-height: 1.5; }
.vip-step-body p strong { color: var(--text-on-panel); }
.vip-step-arrow { font-size: 1.4rem; color: var(--turf-400); padding-top: .5rem; flex-shrink: 0; }
@media (max-width: 680px) { .vip-step-arrow { display: none; } }
.vip-join-cta { text-align: center; margin-top: 2rem; }

/* Schedule */
.vip-schedule-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}
.vip-schedule-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1.1rem 1.1rem .9rem;
}
.vip-sched-time {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  color: var(--turf-500);
  letter-spacing: .04em;
  margin-bottom: .3rem;
}
.vip-sched-label {
  font-weight: 600;
  font-size: var(--fs-body);
  color: var(--text-primary);
  margin-bottom: .35rem;
}
.vip-sched-body {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.5;
}

/* FAQ */
.vip-faq-list { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: .5rem; }
.vip-faq-item {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.vip-faq-q {
  cursor: pointer;
  padding: 1rem 1.1rem;
  font-weight: 600;
  font-size: var(--fs-body);
  color: var(--text-primary);
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  user-select: none;
}
.vip-faq-q::after { content: '+'; font-size: 1.2rem; color: var(--turf-500); flex-shrink: 0; }
details[open] .vip-faq-q::after { content: '−'; }
.vip-faq-a { padding: 0 1.1rem 1rem; }
.vip-faq-a p { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.6; margin: 0; }

/* Final CTA */
.vip-final-cta { text-align: center; }
.vip-cta-inner { max-width: 560px; margin: 0 auto; }
.vip-cta-title { font-family: var(--font-display); font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 700; color: var(--text-on-panel); margin-bottom: .75rem; }
.vip-cta-sub { font-size: var(--fs-body); color: var(--text-on-panel-soft); margin-bottom: 1.5rem; line-height: 1.55; }
.vip-cta-resp { font-size: var(--fs-micro); color: var(--text-on-panel-soft); margin-top: 1rem; line-height: 1.6; }
.vip-cta-resp a { color: var(--turf-300); }

/* ===================================================================
   DAILY FREE TIPS PAGE — /daily-free-tips
   =================================================================== */

/* Market card grid */
.dft-markets-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem;
}

.dft-market-card {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem 1rem .85rem;
  text-decoration: none;
  transition: border-color .18s ease, transform .15s ease;
}
.dft-market-card:hover { border-color: var(--turf-300); transform: translateY(-2px); }
.dft-market-card--featured { border-color: var(--turf-300); background: color-mix(in srgb, var(--chip-tint-bg) 30%, var(--bg-surface)); }

.dft-market-top {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: .1rem;
}
.dft-market-name {
  font-family: var(--font-display);
  font-size: .95rem;
  font-weight: 600;
  color: var(--text-primary);
}
.dft-market-desc {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.45;
  flex: 1;
}
.dft-market-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: .5rem;
}
.dft-picks-count {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  color: var(--turf-500);
  letter-spacing: .03em;
}
.dft-arrow {
  font-size: .85rem;
  color: var(--text-faint);
  transition: color .15s, transform .15s;
}
.dft-market-card:hover .dft-arrow { color: var(--turf-400); transform: translateX(3px); }

/* Aggregator cards */
.dft-agg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: .75rem;
}
.dft-agg-card {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem;
  text-decoration: none;
  transition: border-color .18s ease;
}
.dft-agg-card:hover { border-color: var(--turf-300); }
.dft-agg-card--tg { border-color: color-mix(in srgb, var(--turf-500) 30%, var(--border-color)); }
.dft-agg-card--tg svg { color: var(--turf-500); flex-shrink: 0; margin-top: .1rem; }
.dft-agg-card strong { display: block; font-weight: 600; font-size: var(--fs-body); color: var(--text-primary); margin-bottom: .2rem; }
.dft-agg-card p { font-size: var(--fs-small); color: var(--text-secondary); margin: 0; line-height: 1.45; }
.dft-agg-card .prd-grade-badge { flex-shrink: 0; margin-top: .1rem; }

/* ===================================================================
   CORRECT SCORE TIPS LANDING PAGE — /correct-score-tips
   =================================================================== */

/* Hero card */
.cst-hero-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  align-items: center;
}
@media (max-width: 720px) {
  .cst-hero-card { grid-template-columns: 1fr; }
  .cst-hero-right { display: none; }
}

.cst-hero-badge {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .75rem;
}
.cst-hero-market {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-faint);
}
.cst-hero-title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.5vw + .3rem, 1.75rem);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 .65rem;
  line-height: 1.15;
}
.cst-hero-sub {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.55;
  margin: 0 0 1.1rem;
}
.cst-hero-actions {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
}
.cst-main-btn, .cst-tg-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: var(--fs-small);
  padding: .6rem 1rem;
  font-weight: 600;
  border-radius: var(--radius-md);
  text-decoration: none;
  white-space: nowrap;
}
.cst-main-btn {
  background: var(--turf-600);
  color: #fff;
  transition: background .2s;
}
.cst-main-btn:hover { background: var(--turf-500); }

/* Score tiles preview */
.cst-score-tiles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
}
.cst-score-tile {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  background: var(--bg-surface-2);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: .65rem .75rem;
}
.cst-tile-match {
  font-size: var(--fs-micro);
  color: var(--text-faint);
  font-family: var(--font-utility);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cst-tile-odds {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  color: var(--turf-500);
}

/* See-all CTA */
.cst-see-all {
  display: flex;
  justify-content: center;
  margin-top: 1rem;
}
.cst-see-all .btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--turf-600);
  color: #fff;
  padding: .7rem 1.4rem;
  border-radius: var(--radius-md);
  font-weight: 600;
  text-decoration: none;
  transition: background .2s;
}
.cst-see-all .btn:hover { background: var(--turf-500); }

/* ===================================================================
   WEEKEND PREDICTIONS PAGE — /weekend-predictions
   =================================================================== */

/* Day grid */
.wknd-day-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 680px) { .wknd-day-grid { grid-template-columns: 1fr; } }

.wknd-day-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.wknd-day-head {
  background: var(--bg-panel);
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--border-color);
}
.wknd-day-label {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-on-panel);
  display: block;
}
.wknd-day-leagues {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  color: var(--text-on-panel-soft);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.wknd-market-links {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  padding: .85rem .85rem .6rem;
}
.wknd-mkt-link {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: var(--fs-micro);
  color: var(--text-secondary);
  text-decoration: none;
  padding: .2em .5em;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-color);
  transition: border-color .15s, color .15s;
}
.wknd-mkt-link:hover { border-color: var(--turf-300); color: var(--turf-500); }
.wknd-day-foot {
  padding: .6rem .85rem .75rem;
  border-top: 1px solid var(--border-color);
}
.wknd-banker-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  color: var(--turf-500);
  text-decoration: none;
}
.wknd-banker-link:hover { color: var(--turf-400); }

/* Compact banker rows */
.wknd-bankers-list {
  display: flex;
  flex-direction: column;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.wknd-banker-row {
  display: grid;
  grid-template-columns: 80px 1fr 1fr 80px;
  align-items: center;
  gap: .75rem;
  padding: .7rem 1rem;
  border-bottom: 1px solid var(--border-color);
}
.wknd-banker-row:last-child { border-bottom: none; }
@media (max-width: 600px) {
  .wknd-banker-row { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; row-gap: .3rem; }
  .wknd-brow-meta { grid-column: 1; grid-row: 1; }
  .wknd-brow-right { grid-column: 2; grid-row: 1; text-align: right; }
  .wknd-brow-match { grid-column: 1 / 3; grid-row: 2; }
  .wknd-brow-pick { grid-column: 1 / 3; grid-row: 3; }
}
.wknd-brow-meta { display: flex; flex-direction: column; gap: .1rem; }
.wknd-brow-time { font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; color: var(--text-secondary); }
.wknd-brow-league { font-family: var(--font-utility); font-size: var(--fs-micro); color: var(--text-faint); }
.wknd-brow-match { font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
.wknd-brow-match em { font-style: normal; color: var(--text-faint); font-size: .8em; margin: 0 .2em; }
.wknd-brow-pick { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; }
.wknd-brow-pick-text { font-size: var(--fs-small); color: var(--text-secondary); }
.wknd-brow-right { display: flex; flex-direction: column; align-items: flex-end; gap: .15rem; }
.wknd-brow-odds { font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); color: var(--turf-500); }
.wknd-brow-conf { font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 600; }

/* Fixture cards */
.wknd-fixtures-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: .75rem;
}
.wknd-fixture-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.wknd-fix-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .55rem .85rem;
  background: var(--bg-surface-2);
  border-bottom: 1px solid var(--border-color);
}
.wknd-fix-time { font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; color: var(--turf-500); }
.wknd-fix-league { font-family: var(--font-utility); font-size: var(--fs-micro); color: var(--text-faint); text-transform: uppercase; letter-spacing: .04em; }
.wknd-fix-teams { font-size: var(--fs-small); font-weight: 600; color: var(--text-primary); padding: .6rem .85rem .4rem; }
.wknd-fix-teams em { font-style: normal; color: var(--text-faint); margin: 0 .25em; font-size: .85em; }
.wknd-fix-picks { display: flex; flex-direction: column; gap: 0; padding: 0 .85rem .75rem; }
.wknd-fix-pick {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: var(--fs-micro);
  color: var(--text-secondary);
  text-decoration: none;
  padding: .3rem 0;
  border-top: 1px solid var(--border-subtle, color-mix(in srgb, var(--border-color) 50%, transparent));
  transition: color .15s;
}
.wknd-fix-pick:first-child { border-top: none; }
.wknd-fix-pick:hover { color: var(--turf-500); }

/* ===================================================================
   MUST WIN TEAMS PAGE — /must-win-teams
   =================================================================== */

/* Pressure badges */
.mwt-pressure-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-utility);
  font-weight: 700;
  font-size: .62rem;
  letter-spacing: .08em;
  padding: .2em .6em;
  border-radius: 4px;
  white-space: nowrap;
  text-transform: uppercase;
}
.mwt-pressure--critical { background: #DC2626; color: #fff; }
.mwt-pressure--high     { background: #D97706; color: #fff; }
.mwt-pressure--moderate { background: var(--bg-surface-2); color: var(--text-secondary); border: 1px solid var(--border-color); }

/* MWT card list */
.mwt-cards { display: flex; flex-direction: column; gap: 1rem; }

.mwt-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color .2s;
}
.mwt-card:hover { border-color: var(--turf-300); }

/* Card head */
.mwt-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .65rem 1rem;
  background: var(--bg-surface-2);
  border-bottom: 1px solid var(--border-color);
  gap: .75rem;
}
.mwt-head-left { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.mwt-league {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.mwt-head-right { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.mwt-odds { font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); color: var(--turf-500); }

/* Card body */
.mwt-card-body { padding: .9rem 1rem 1rem; display: flex; flex-direction: column; gap: .65rem; }

/* Teams */
.mwt-teams { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.mwt-team {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-primary);
}
.mwt-team--win { color: var(--turf-600); }
[data-theme="dark"] .mwt-team--win { color: var(--turf-400); }
.mwt-vs { font-size: var(--fs-small); color: var(--text-faint); padding: 0 .2rem; }

/* Pick row */
.mwt-pick-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}
.mwt-pick-text { font-size: var(--fs-small); font-weight: 500; color: var(--text-primary); }
.mwt-market-link {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  color: var(--turf-500);
  text-decoration: none;
  margin-left: auto;
}
.mwt-market-link:hover { color: var(--turf-400); }

/* Context */
.mwt-context {
  display: flex;
  gap: .6rem;
  align-items: flex-start;
  background: var(--bg-surface-2);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-sm);
  padding: .65rem .8rem;
}
.mwt-context-icon { font-size: .9rem; flex-shrink: 0; margin-top: .05rem; }
.mwt-context p { font-size: var(--fs-small); color: var(--text-secondary); margin: 0; line-height: 1.55; }
.mwt-context strong { color: var(--text-primary); }

/* Stats row */
.mwt-stats-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.mwt-stat {
  display: flex;
  flex-direction: column;
  gap: .1rem;
  min-width: 120px;
}
.mwt-stat span { font-size: var(--fs-micro); color: var(--text-faint); font-family: var(--font-utility); }
.mwt-stat b { font-size: var(--fs-small); color: var(--text-primary); font-weight: 700; }

/* ===================================================================
   OVER/UNDER GOALS — index + sub-pages
   =================================================================== */

/* Line selection cards on index page */
.ou-lines-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: .75rem;
}
.ou-line-card {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem;
  text-decoration: none;
  transition: border-color .18s, transform .15s;
}
.ou-line-card:hover { border-color: var(--turf-300); transform: translateY(-2px); }
.ou-line-card--featured { border-color: var(--turf-300); }
.ou-line-card--active { border-color: var(--turf-500); background: color-mix(in srgb, var(--chip-tint-bg) 25%, var(--bg-surface)); }
.ou-line-badge { display: flex; gap: .4rem; margin-bottom: .15rem; }
.ou-line-title { font-family: var(--font-display); font-size: .95rem; font-weight: 600; color: var(--text-primary); }
.ou-line-desc { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.45; flex: 1; }
.ou-line-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: .4rem; }
.ou-typical-odds { font-family: var(--font-utility); font-size: var(--fs-micro); color: var(--text-faint); }

/* Comparison table on index page */
.ou-comparison-table {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.ou-comp-head,
.ou-comp-row {
  display: grid;
  grid-template-columns: 80px 1fr 1fr 1fr 2fr;
  gap: .5rem 1rem;
  padding: .65rem 1rem;
  align-items: center;
  font-size: var(--fs-small);
  border-bottom: 1px solid var(--border-color);
}
.ou-comp-row:last-child { border-bottom: none; }
.ou-comp-head {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-faint);
  background: var(--bg-surface-2);
}
.ou-comp-line { display: flex; align-items: center; }
@media (max-width: 600px) {
  .ou-comp-head { display: none; }
  .ou-comp-row { grid-template-columns: 60px 1fr 60px 60px; font-size: var(--fs-micro); }
  .ou-comp-row > span:last-child { display: none; }
}

/* ===================================================================
   TODAY'S TIPS PAGE — /todays-tips
   =================================================================== */

/* Top shortcut cards */
.tt-top-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem;
}
.tt-top-card {
  display: flex;
  flex-direction: column;
  gap: .45rem;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem 1rem .85rem;
  text-decoration: none;
  transition: border-color .18s, transform .15s;
}
.tt-top-card:hover { transform: translateY(-2px); }
.tt-top-card--banker { border-color: var(--turf-400); }
.tt-top-card--banker:hover { border-color: var(--turf-300); }
.tt-top-card--sure { border-color: color-mix(in srgb, var(--gold-tint-bg) 60%, var(--border-color)); }
.tt-top-card--acca:hover, .tt-top-card--value:hover { border-color: var(--turf-300); }

.tt-top-card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .1rem; }
.tt-top-count { font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; color: var(--turf-500); }
.tt-top-title { font-family: var(--font-display); font-size: .95rem; font-weight: 600; color: var(--text-primary); }
.tt-top-desc { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.45; flex: 1; }
.tt-top-preview {
  display: flex;
  flex-direction: column;
  gap: .2rem;
  padding-top: .5rem;
  margin-top: auto;
  border-top: 1px solid var(--border-color);
}
.tt-preview-item { font-size: var(--fs-micro); color: var(--text-secondary); display: flex; align-items: center; gap: .3rem; }
.tt-preview-more { color: var(--turf-500); font-weight: 600; font-family: var(--font-utility); }

/* Fixture cards grid */
.tt-fixtures-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: .75rem;
}
.tt-fixture {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color .18s;
}
.tt-fixture:hover { border-color: var(--turf-300); }
.tt-fix-head {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem .85rem;
  background: var(--bg-surface-2);
  border-bottom: 1px solid var(--border-color);
}
.tt-fix-time { font-family: var(--font-utility); font-size: var(--fs-micro); font-weight: 700; color: var(--turf-500); }
.tt-fix-league { font-family: var(--font-utility); font-size: var(--fs-micro); color: var(--text-faint); text-transform: uppercase; letter-spacing: .04em; }
.tt-fix-teams { font-size: var(--fs-small); font-weight: 600; color: var(--text-primary); padding: .55rem .85rem .35rem; }
.tt-fix-teams em { font-style: normal; color: var(--text-faint); margin: 0 .2em; font-size: .85em; }
.tt-fix-tips { display: flex; flex-direction: column; padding: 0 .85rem .65rem; }
.tt-fix-tip {
  display: flex;
  align-items: center;
  gap: .35rem;
  font-size: var(--fs-micro);
  color: var(--text-secondary);
  text-decoration: none;
  padding: .28rem 0;
  border-top: 1px solid color-mix(in srgb, var(--border-color) 50%, transparent);
  transition: color .15s;
}
.tt-fix-tip:first-child { border-top: none; }
.tt-fix-tip:hover { color: var(--turf-500); }

/* ===================================================================
   GRADING PAGE — /grading
   =================================================================== */

/* Grade tier cards */
.grade-tier-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}
.grade-tier-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.grade-tier-card--banker { border-top: 3px solid var(--turf-500); }
.grade-tier-card--sure   { border-top: 3px solid #D97706; }
.grade-tier-card--free   { border-top: 3px solid var(--border-color); }

.grade-tier-head {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .9rem 1rem .7rem;
  background: var(--bg-surface-2);
  border-bottom: 1px solid var(--border-color);
}
.grade-tier-badge { font-size: .7rem; }
.grade-tier-name { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--text-primary); }

.grade-tier-body { padding: 1rem; display: flex; flex-direction: column; gap: .65rem; }
.grade-tier-def { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.55; margin: 0; }
.grade-tier-facts {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: .3rem;
}
.grade-tier-facts li {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  padding-left: 1rem;
  position: relative;
}
.grade-tier-facts li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--turf-500);
  font-size: .7em;
  top: .1em;
}
.grade-tier-link {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--turf-500);
  text-decoration: none;
  margin-top: auto;
}
.grade-tier-link:hover { color: var(--turf-400); }

/* Confidence examples */
.grade-explainer { display: flex; flex-direction: column; gap: 1rem; }
.grade-explainer p { font-size: var(--fs-body); color: var(--text-secondary); line-height: 1.65; margin: 0; }
.grade-explainer strong { color: var(--text-primary); }

.grade-conf-examples { display: flex; flex-direction: column; gap: .6rem; margin-top: .25rem; }
.grade-conf-ex { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.grade-conf-bar-wrap { display: flex; align-items: center; gap: .5rem; width: 200px; flex-shrink: 0; }
.grade-conf-bar-label { font-family: var(--font-utility); font-weight: 700; font-size: var(--fs-small); color: var(--turf-500); min-width: 32px; }
.grade-conf-bar-full { flex: 1; height: 8px; background: var(--bg-surface-2); border-radius: 4px; overflow: hidden; }
.grade-conf-desc { font-size: var(--fs-small); color: var(--text-secondary); }
.grade-conf-desc b { color: var(--text-primary); }
@media (max-width: 480px) { .grade-conf-bar-wrap { width: 140px; } }

/* Model inputs */
.grade-inputs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem;
}
.grade-input-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.grade-input-icon { font-size: 1.2rem; line-height: 1; }
.grade-input-card h3 { font-size: var(--fs-body); font-weight: 600; color: var(--text-primary); margin: 0; }
.grade-input-card p { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.5; margin: 0; }

/* What grades do not mean */
.grade-myth-list { display: flex; flex-direction: column; gap: .65rem; }
.grade-myth {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem;
}
.grade-myth-label {
  font-family: var(--font-utility);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .05em;
  padding: .2em .5em;
  border-radius: 4px;
  flex-shrink: 0;
  margin-top: .15rem;
  white-space: nowrap;
}
.grade-myth-false { background: #FEE2E2; color: #991B1B; }
[data-theme="dark"] .grade-myth-false { background: rgba(220,38,38,.2); color: #FCA5A5; }
.grade-myth-truth b { display: block; font-size: var(--fs-small); color: var(--text-primary); margin-bottom: .3rem; }
.grade-myth-truth p { font-size: var(--fs-small); color: var(--text-secondary); margin: 0; line-height: 1.5; }

/* Usage cards */
.grade-usage-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .75rem;
}
.grade-usage-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.grade-usage-head { display: flex; align-items: center; gap: .5rem; }
.grade-usage-head strong { font-size: var(--fs-body); color: var(--text-primary); }
.grade-usage-card p { font-size: var(--fs-small); color: var(--text-secondary); line-height: 1.55; margin: 0; }

/* Value comparison */
.grade-value-comparison {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: .5rem;
}
@media (max-width: 560px) { .grade-value-comparison { grid-template-columns: 1fr; } }
.grade-val-col {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1rem;
}
.grade-val-head {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-weight: 600;
  font-size: var(--fs-small);
  color: var(--text-primary);
  margin-bottom: .65rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--border-color);
}
.grade-val-col ul {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: .3rem;
}
.grade-val-col li {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  padding-left: .85rem;
  position: relative;
}
.grade-val-col li::before { content: '·'; position: absolute; left: 0; color: var(--turf-500); }

/* ===================================================================
   ANALYSIS PAGE — /analysis
   =================================================================== */

/* Analysis card */
.an-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 1rem;
  transition: border-color .2s;
}
.an-card:hover { border-color: var(--turf-300); }
.an-card:last-child { margin-bottom: 0; }

/* Card header */
.an-card-head {
  padding: .75rem 1rem .65rem;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border-color);
}
.an-head-meta {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .5rem;
}
.an-ko {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  color: var(--text-on-panel-soft);
  letter-spacing: .04em;
}

/* Teams row */
.an-teams-row {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.an-team-block {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex: 1;
}
.an-team-block--away { flex-direction: row-reverse; }
.an-team-name {
  font-family: var(--font-display);
  font-size: clamp(.9rem, 2vw + .1rem, 1.1rem);
  font-weight: 600;
  color: var(--text-on-panel);
  white-space: nowrap;
}
.an-vs {
  font-size: var(--fs-small);
  color: var(--text-on-panel-soft);
  font-weight: 400;
  flex-shrink: 0;
}

/* Form strip */
.an-form-strip { display: flex; gap: 3px; flex-shrink: 0; }
.an-form {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 3px;
  font-family: var(--font-utility);
  font-size: .6rem;
  font-weight: 700;
  color: #fff;
}
.an-form--w { background: var(--turf-600); }
.an-form--d { background: #6B7280; }
.an-form--l { background: #DC2626; }
@media (max-width: 420px) {
  .an-form { width: 15px; height: 15px; font-size: .55rem; }
}

/* Stats row */
.an-stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: .1rem;
  border-bottom: 1px solid var(--border-color);
}
.an-stat-block {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  padding: .6rem .85rem;
  border-right: 1px solid var(--border-color);
}
.an-stat-block:nth-child(3n) { border-right: none; }
@media (max-width: 560px) {
  .an-stats-row { grid-template-columns: 1fr 1fr; }
  .an-stat-block { border-right: 1px solid var(--border-color); }
  .an-stat-block:nth-child(2n) { border-right: none; }
  .an-stat-block:nth-child(3n) { border-right: 1px solid var(--border-color); }
}
.an-stat-label { font-family: var(--font-utility); font-size: .6rem; text-transform: uppercase; letter-spacing: .05em; color: var(--text-faint); }
.an-stat-val { font-family: var(--font-utility); font-size: var(--fs-small); font-weight: 700; color: var(--text-primary); }
.an-stat-val--high { color: var(--turf-500); }
.an-stat-val--low  { color: #DC2626; }
[data-theme="dark"] .an-stat-val--low { color: #FCA5A5; }

/* Verdict */
.an-verdict {
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--border-color);
}
.an-verdict p {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.65;
  margin: 0;
}
.an-verdict strong { color: var(--text-primary); }

/* Tip row */
.an-tip-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .65rem 1rem;
  background: var(--bg-surface-2);
  gap: .75rem;
  flex-wrap: wrap;
}
.an-tip-picks {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem;
}
.an-tip {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: var(--fs-micro);
  font-family: var(--font-utility);
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  padding: .2em .5em;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-color);
  transition: border-color .15s, color .15s;
  white-space: nowrap;
}
.an-tip:hover { border-color: var(--turf-300); color: var(--turf-500); }

/* League filter */
.an-card[data-league].an-hidden { display: none; }

/* ===================================================================
   MARKETS PAGE — /markets
   =================================================================== */
.mkt-explain-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: .75rem;
}
.mkt-explain-card:last-of-type { margin-bottom: 0; }

.mkt-explain-head {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .7rem 1rem;
  background: var(--bg-surface-2);
  border-bottom: 1px solid var(--border-color);
}
.mkt-explain-name {
  font-family: var(--font-display);
  font-size: .95rem;
  font-weight: 600;
  color: var(--text-primary);
  flex: 1;
}
.mkt-explain-link {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--turf-500);
  text-decoration: none;
  flex-shrink: 0;
}
.mkt-explain-link:hover { color: var(--turf-400); }

.mkt-explain-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
@media (max-width: 600px) {
  .mkt-explain-body { grid-template-columns: 1fr; }
}
.mkt-explain-col {
  padding: .85rem 1rem;
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.55;
  border-right: 1px solid var(--border-color);
}
.mkt-explain-col:last-child { border-right: none; }
.mkt-explain-col p { margin: 0; }

.mkt-explain-label {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
  color: var(--text-faint);
  margin-bottom: .35rem;
}
.mkt-outcome-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.mkt-outcome-list li {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  padding-left: .75rem;
  position: relative;
}
.mkt-outcome-list li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--turf-500);
}

/* ===================================================================
   HEADER — sponsored links inside mega-menu
   =================================================================== */
.mega-sponsors {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem .6rem;
  padding: .55rem 1.25rem;
  border-top: 1px solid var(--border-color);
  background: var(--bg-surface-2);
}
.mega-sponsors-label {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-faint);
  flex-shrink: 0;
}
.mega-sponsor-link {
  font-size: var(--fs-micro);
  font-weight: 500;
  color: var(--text-faint);
  padding: .2em .55em;
  border-radius: 4px;
  border: 1px solid var(--border-color);
  transition: border-color .15s, color .15s;
}
.mega-sponsor-link:hover { border-color: var(--turf-400); color: var(--text-secondary); }

/* Mobile nav sponsored links */
.nav-mobile-sponsors {
  margin-top: .75rem;
  padding: .65rem .85rem;
  background: var(--bg-surface-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-color);
}
.nav-mobile-sponsors-label {
  display: block;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-faint);
  margin-bottom: .4rem;
}
.nav-mobile-sponsors-links {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}
.nav-mobile-sponsors-links a {
  font-size: var(--fs-micro);
  color: var(--text-secondary);
  padding: .25em .6em;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  transition: border-color .15s, color .15s;
}
.nav-mobile-sponsors-links a:hover { border-color: var(--turf-400); color: var(--text-primary); }

/* ===================================================================
   PARTNERS PAGE — /partners
   =================================================================== */
.partners-page-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.partner-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 1.1rem 1.1rem .9rem;
  text-decoration: none;
  transition: border-color .18s, transform .15s;
}
.partner-card:hover { border-color: var(--turf-300); transform: translateY(-2px); }
.partner-card-name {
  font-family: var(--font-display);
  font-size: .95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: .35rem;
}
.partner-card-url {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  color: var(--turf-500);
  margin-bottom: .5rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.partner-card-desc {
  font-size: var(--fs-small);
  color: var(--text-secondary);
  line-height: 1.5;
  flex: 1;
}
.partner-card-arrow {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 600;
  color: var(--turf-500);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-top: .75rem;
}

/* ===================================================================
   FOOTER — sponsor strip
   =================================================================== */
.footer-sponsor-strip {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .35rem .5rem;
}
.footer-sponsor-label {
  font-family: var(--font-utility);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--footer-text-soft);
  flex-shrink: 0;
  margin-right: .1rem;
}
.footer-sponsor-link {
  font-size: var(--fs-micro);
  color: var(--footer-text-soft);
  border: 1px solid var(--footer-border);
  border-radius: 999px;
  padding: .22em .7em;
  transition: border-color .15s, color .15s;
}
.footer-sponsor-link:hover {
  border-color: var(--turf-400);
  color: var(--footer-text);
}

/* ===================================================================
   TEXT LINKS mega-menu — narrow single-column variant
   =================================================================== */
.mega-menu--narrow {
  min-width: 220px;
  max-width: 280px;
  right: 0;
  left: auto;
}