/* =========================================================================
   Sidebar — primary navigation. Holds search, sport pills, NTJ, sport tree,
   showdowns, and sticky CTAs at the bottom.
   ========================================================================= */
.sidebar{
  position:sticky;top:var(--s-5);align-self:start;
  display:flex;flex-direction:column;
  max-height:calc(100vh - var(--s-8));
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;
}
.sidebar__scroll{
  flex:1;overflow-y:auto;padding:var(--s-3);
  scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;
}
.sidebar__scroll::-webkit-scrollbar{width:6px}
.sidebar__scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:3px}

.sidebar__block{padding:var(--s-2) 0;border-bottom:1px solid var(--line)}
.sidebar__block:last-child{border-bottom:0}

.sidebar__heading{
  font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);
  padding:var(--s-2) var(--s-2) var(--s-3);
  display:flex;align-items:center;gap:6px;
}
.sidebar__heading--accent{color:var(--signal)}
.sidebar__heading--with-pulse .ntj__pulse{width:6px;height:6px}

.sidebar__search{padding:0 var(--s-2) var(--s-2)}
.sidebar__search input{background:var(--rail);border-color:transparent}
@media (min-width:961px){ .sidebar__search{display:none} }

/* Sport pills — wrapping grid inside sidebar */
.sport-pills{display:flex;flex-wrap:wrap;gap:6px;padding:0 var(--s-2)}
.sidebar__pill-row{display:flex;flex-wrap:wrap;gap:6px;padding:var(--s-2) var(--s-2) 0}
.sport-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:999px;
  background:var(--rail);color:var(--ink-2);
  font-size:var(--fs-13);font-weight:600;white-space:nowrap;
  border:1px solid transparent;
  position:relative;overflow:hidden;
  transition:
    color var(--dur-base) var(--ease),
    background var(--dur-base) var(--ease),
    border-color var(--dur-base) var(--ease),
    transform var(--dur-fast) var(--ease);
}
.sport-pill::before{
  content:"";position:absolute;inset:auto 0 0 0;height:100%;
  background:linear-gradient(180deg,transparent 0%,rgba(156,230,0,.08) 100%);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform var(--dur-base) var(--ease-out-quart);
  pointer-events:none;
}
.sport-pill:hover{color:var(--ink);text-decoration:none;border-color:var(--line-2)}
.sport-pill:hover::before{transform:scaleY(1)}
.sport-pill:active{transform:translateY(1px)}
.sport-pill.is-active{
  background:var(--accent);color:var(--accent-ink);border-color:var(--accent);
  box-shadow:var(--glow-accent);
}
.sport-pill.is-active::before{display:none}
.sport-pill.is-active .pill-badge{background:rgba(0,0,0,.3);color:var(--accent-ink)}
.sport-pill--alt{color:var(--signal);background:transparent}
.sport-pill--alt:hover{color:var(--signal-hi)}
.pill-badge{
  font-size:10px;background:var(--signal);color:var(--accent-ink);
  padding:2px 6px;border-radius:999px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;
}
.pill-dot{width:8px;height:8px;background:var(--ok);border-radius:50%}

/* Sidebar NTJ (vertical, compact) */
.sidebar__ntj{display:flex;flex-direction:column;gap:2px;padding:0 var(--s-2)}
.sidebar__ntj-row{
  display:flex;align-items:center;justify-content:space-between;gap:var(--s-2);
  padding:8px 10px;border-radius:var(--r-sm);
  font-size:var(--fs-13);color:var(--ink);
  background:var(--rail);border:1px solid transparent;
  transition:
    border-color var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease),
    transform var(--dur-fast) var(--ease);
}
.sidebar__ntj-row:hover{border-color:var(--accent);background:rgba(156,230,0,.06);text-decoration:none;transform:translateX(2px)}
.sidebar__ntj-row.is-soon{border-color:var(--signal);animation:soonPulse 2.4s infinite}
.sidebar__ntj-venue{display:flex;align-items:center;gap:var(--s-2);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar__ntj-time{color:var(--accent);font-weight:700;flex:0 0 auto}
.sidebar__ntj-row.is-soon .sidebar__ntj-time{color:var(--signal)}

/* Sidebar details tree — smooth open via grid-template-rows trick */
.sidebar__tree{padding:0 var(--s-2)}
.sidebar__tree details{padding:6px 8px;border-radius:var(--r-sm);transition:background var(--dur-fast) var(--ease)}
.sidebar__tree summary{
  cursor:pointer;list-style:none;font-weight:600;
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 0;color:var(--ink);
}
.sidebar__tree summary::-webkit-details-marker{display:none}
.sidebar__tree summary::after{
  content:"+";color:var(--ink-3);font-weight:400;font-size:18px;line-height:1;
  transition:transform var(--dur-base) var(--ease-out-quart),color var(--dur-fast) var(--ease);
}
.sidebar__tree details[open] summary::after{transform:rotate(45deg);color:var(--accent)}
.sidebar__tree details[open]{background:rgba(255,255,255,.02)}
.sidebar__tree ul{margin-top:var(--s-1);padding-left:var(--s-2);display:flex;flex-direction:column;gap:2px}
.sidebar__tree ul a{
  display:block;padding:6px 8px;border-radius:var(--r-sm);
  color:var(--ink-2);font-size:var(--fs-13);
  transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease);
}
.sidebar__tree ul a:hover{background:var(--rail);color:var(--accent);text-decoration:none;transform:translateX(4px)}
.sidebar__tree--flat ul{padding-left:0}

/* Sticky CTA footer of the sidebar */
.sidebar__foot{
  padding:var(--s-3);border-top:1px solid var(--line);background:var(--rail);
  display:flex;flex-direction:column;gap:var(--s-2);
}
.sidebar__foot-quiet{text-align:center;font-size:11px;color:var(--ink-3);padding:6px 0 0}
.sidebar__foot-quiet:hover{color:var(--accent)}

/* Mobile drawer — sidebar slides in from the left */
@media (max-width:960px){
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;z-index:80;
    width:min(320px,86vw);max-height:100vh;border-radius:0;
    transform:translateX(-100%);
    transition:transform var(--dur-xl) var(--ease-snap);
    box-shadow:var(--shadow-2);
  }
  .sidebar.is-open{transform:none}
}
.sidebar-scrim{
  position:fixed;inset:0;z-index:75;
  background:rgba(0,0,0,.55);backdrop-filter:blur(var(--blur-bg));
  opacity:0;transition:opacity var(--dur-base) var(--ease);
  border:0;cursor:pointer;
}
.sidebar-scrim.is-visible{opacity:1}
.sidebar-scrim[hidden]{display:none}

/* =========================================================================
   Hero
   ========================================================================= */
.hero{
  background:
    radial-gradient(60% 80% at calc(var(--mx,80%) ) calc(var(--my,0%)),rgba(156,230,0,.16) 0%,transparent 60%),
    radial-gradient(40% 60% at 10% 100%,rgba(255,214,10,.10) 0%,transparent 70%),
    linear-gradient(180deg,#10160E 0%,#0B0E0A 100%);
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);overflow:hidden;position:relative;
  transition:background var(--dur-slow) var(--ease);
}
.hero__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--s-6);align-items:center}
@media (max-width:960px){ .hero__grid{grid-template-columns:1fr} }
.hero__eyebrow{
  display:inline-block;font-size:11px;color:var(--accent-ink);background:var(--signal);
  padding:3px 8px;border-radius:var(--r-xs);
  text-transform:uppercase;letter-spacing:.1em;font-weight:700;
}
.hero h1{font-size:clamp(24px,2.6vw,38px);margin:12px 0 12px;color:var(--ink);line-height:1.1;max-width:560px}
.hero__sub{color:var(--ink-2);max-width:520px;font-size:var(--fs-16)}
.hero__cta{display:flex;align-items:center;gap:var(--s-3);margin-top:var(--s-5);flex-wrap:wrap}
.hero__terms{display:block;color:var(--ink-3);font-size:11px;margin-top:var(--s-2);max-width:520px;line-height:1.5}

.hero-card{
  background:rgba(11,14,10,.65);
  border:1px solid var(--line-2);border-radius:var(--r-md);padding:var(--s-4);
  backdrop-filter:blur(8px);
  transition:transform var(--dur-base) var(--ease-out-quart),border-color var(--dur-base) var(--ease);
}
.hero-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.hero-card__head{display:flex;align-items:center;justify-content:space-between;font-size:var(--fs-12);color:var(--ink-3);margin-bottom:var(--s-3)}
.hero-card__teams{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);margin-bottom:var(--s-4)}
.hero-card__team{display:flex;align-items:center;gap:var(--s-2);font-weight:700;color:var(--ink)}
.hero-card__crest{width:32px;height:32px;border-radius:50%;background:var(--rail);display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:var(--ink-2);overflow:hidden}
.hero-card__vs{color:var(--ink-3);font-size:var(--fs-12)}
.hero-card__odds{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-2)}

/* =========================================================================
   Odds button + odometer (Flagship B)
   ========================================================================= */
.odd{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:10px 8px;background:var(--rail);border:1px solid var(--line);border-radius:var(--r-sm);
  font-size:var(--fs-13);color:var(--ink);cursor:pointer;
  position:relative;
  transition:
    background var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease),
    transform var(--dur-fast) var(--ease),
    box-shadow var(--dur-base) var(--ease);
  will-change:transform;
}
.odd:hover{background:var(--surface);border-color:var(--accent);text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 16px rgba(156,230,0,.12)}
.odd:active{transform:scale(.96)}
.odd small{font-size:11px;color:var(--ink-3);font-weight:500}
.odd strong{font-variant-numeric:tabular-nums;font-size:var(--fs-16);color:var(--accent);font-weight:700}
.odd.is-active{background:var(--accent);border-color:var(--accent-hi);color:var(--accent-ink);transform:none}
.odd.is-active strong, .odd.is-active small{color:var(--accent-ink)}

@keyframes oddFlash{
  0%  {box-shadow:0 0 0 0 rgba(156,230,0,.55)}
  60% {box-shadow:0 0 0 10px rgba(156,230,0,0)}
  100%{box-shadow:0 0 0 0 rgba(156,230,0,0)}
}
.odd.is-flash{animation:oddFlash .6s var(--ease-out)}

@keyframes oddUp{
  0%   {background:rgba(156,230,0,.0)}
  30%  {background:rgba(156,230,0,.22)}
  100% {background:var(--rail)}
}
@keyframes oddDown{
  0%   {background:rgba(255,214,10,.0)}
  30%  {background:rgba(255,214,10,.22)}
  100% {background:var(--rail)}
}
.odd.is-up{animation:oddUp .8s var(--ease)}
.odd.is-down{animation:oddDown .8s var(--ease)}

.odd--ghost{background:transparent;border-color:transparent;color:var(--ink-3);cursor:default;pointer-events:none}
.odd--ghost strong{color:var(--ink-3)}

/* Odometer — each digit is a 10-cell vertical stack; the active digit is the only one visible */
.odo{
  display:inline-flex;align-items:center;gap:0;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.odo__d{
  --n:0;
  display:inline-block;width:1ch;height:1em;overflow:hidden;position:relative;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.odo__d-roll{
  display:block;
  transform:translateY(calc(var(--n) * -1em));
  transition:transform var(--dur-base) var(--ease-out-quart);
  will-change:transform;
}
.odo__d-roll > i{
  display:block;height:1em;line-height:1;text-align:center;font-style:normal;
}
.odo__sep{display:inline-block;padding:0 1px}
.odo--blank{color:var(--ink-3)}

/* Cascade-in on first viewport entry */
.js-ready .odo.is-cascading .odo__d-roll{
  transition:transform var(--dur-slow) var(--ease-out-quart);
  transition-delay:calc(var(--anim-i,0) * 50ms);
}

/* =========================================================================
   Match list
   ========================================================================= */
.match-list{display:flex;flex-direction:column;gap:var(--s-2)}
.match{
  display:grid;
  grid-template-columns: 160px minmax(0,1fr) 320px;
  column-gap:var(--s-4); row-gap:var(--s-2);
  align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:var(--s-3) var(--s-4);
  transition:
    transform var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease),
    box-shadow var(--dur-base) var(--ease);
}
.match:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--glow-accent)}
.match__meta{font-size:var(--fs-12);color:var(--ink-3);line-height:1.5}
.match__league{font-weight:600;color:var(--ink-2);margin-bottom:2px}
.match__teams{display:flex;flex-direction:column;gap:6px;font-weight:600;min-width:0;color:var(--ink)}
.match__team{display:flex;align-items:center;gap:var(--s-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.crest{width:22px;height:22px;border-radius:50%;background:var(--rail);display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:var(--ink-2);flex:0 0 22px}
.match__markets{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-2);min-width:0}
.match__more{font-size:var(--fs-12);color:var(--ink-3);text-align:right;grid-column:3 / 4}
.match__markets-wrap{display:flex;flex-direction:column;gap:var(--s-2);grid-column:3 / 4}
.match__markets-wrap .match__markets{grid-column:auto}
.match__markets-wrap .match__more{grid-column:auto;margin-top:2px}
.market-group{display:none}
.show-h2h   .market-group[data-group="h2h"]  ,
.show-line  .market-group[data-group="line"] ,
.show-total .market-group[data-group="total"]{display:grid}

/* Meeting discipline filter */
.meetings-list .meeting{display:none}
.meetings-list.show-Thoroughbred .meeting[data-discipline="Thoroughbred"],
.meetings-list.show-Harness      .meeting[data-discipline="Harness"],
.meetings-list.show-Greyhound    .meeting[data-discipline="Greyhound"]{display:block}

@media (max-width:900px){
  .match{grid-template-columns:1fr;gap:var(--s-3)}
  .match__more{text-align:left;grid-column:auto}
  .match__markets-wrap{grid-column:auto}
}

/* =========================================================================
   Race grid
   ========================================================================= */
.meeting{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  margin-bottom:var(--s-3);overflow:hidden;
}
.meeting__head{
  display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);
  border-bottom:1px solid var(--line);background:var(--rail);
}
.meeting__flag{padding:2px 8px;background:var(--accent);color:var(--accent-ink);border-radius:var(--r-xs);font-size:11px;font-weight:700;letter-spacing:.04em}
.meeting__name{font-weight:700;font-size:var(--fs-16);color:var(--ink)}
.meeting__state{color:var(--ink-3);font-size:var(--fs-12)}
.meeting__races{display:flex;flex-wrap:wrap;gap:var(--s-2);padding:var(--s-3)}
.race-tile{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  padding:8px 10px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);
  min-width:96px;font-size:var(--fs-12);color:var(--ink);
  text-align:left;cursor:pointer;
  position:relative;overflow:hidden;
  transition:
    transform var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease);
}
.race-tile::before{
  content:"";position:absolute;inset:auto 0 0 0;height:100%;
  background:linear-gradient(180deg,transparent 30%,rgba(156,230,0,.10) 100%);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform var(--dur-base) var(--ease-out-quart);
  pointer-events:none;
}
.race-tile:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px)}
.race-tile:hover::before{transform:scaleY(1)}
.race-tile:active{transform:translateY(0)}
.race-tile__r{font-weight:700;color:var(--ink-2)}
.race-tile__time{font-variant-numeric:tabular-nums;color:var(--accent);font-weight:700}
.race-tile__runners{color:var(--ink-3)}
.race-tile.is-jumped{opacity:.5}

/* =========================================================================
   Showdown cards (with tilt)
   ========================================================================= */
.showdowns-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
@media (max-width:960px){ .showdowns-grid{grid-template-columns:1fr} }
.showdown{
  background:linear-gradient(180deg,#161B12 0%,#0F1410 100%);
  border:1px solid var(--line);border-radius:var(--r-md);
  padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-3);
  position:relative;overflow:hidden;
  transform-style:preserve-3d;
  transition:
    transform var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease),
    box-shadow var(--dur-base) var(--ease);
}
.showdown:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow-2),var(--glow-accent)}
.showdown::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(80% 60% at 100% 0%,rgba(255,214,10,.14) 0%,transparent 70%);
  pointer-events:none;
}
.showdown__head{display:flex;align-items:center;justify-content:space-between;position:relative}
.showdown__tag{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--signal);font-weight:700}
.showdown__status{font-size:11px;color:var(--ok);font-weight:600}
.showdown__status.is-live{color:var(--live)}
.showdown__title{
  font-family:'Inter Tight',Inter,sans-serif;font-weight:700;font-size:var(--fs-18);
  position:relative;line-height:1.25;min-height:2.5em;color:var(--ink);
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;
}
.showdown__pool{
  font-family:'Inter Tight',Inter,sans-serif;font-weight:800;font-size:var(--fs-28);
  color:var(--ink);line-height:1;font-variant-numeric:tabular-nums;
}
.showdown__pool small{font-size:var(--fs-12);color:var(--ink-3);font-weight:500;display:block;margin-top:2px}
.showdown__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-2);
  font-size:var(--fs-12);color:var(--ink-2);
  border-top:1px solid var(--line);padding-top:var(--s-3);
  margin-top:auto;
}
.showdown__stats span{min-width:0}
.showdown__stats span strong{display:block;color:var(--ink);font-size:var(--fs-14);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* =========================================================================
   Promo cards
   ========================================================================= */
.promos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
@media (max-width:960px){ .promos-grid{grid-template-columns:1fr} }
.promo{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-2);
  transition:
    transform var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease),
    box-shadow var(--dur-base) var(--ease);
}
.promo:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--glow-accent)}
.promo__type{
  display:inline-block;font-size:11px;color:var(--accent-ink);background:var(--signal);
  padding:2px 8px;border-radius:var(--r-xs);
  text-transform:uppercase;letter-spacing:.06em;font-weight:700;align-self:flex-start;
}
.promo h3{font-size:var(--fs-18);color:var(--ink)}
.promo__terms{font-size:11px;color:var(--ink-3);margin-top:auto;line-height:1.5;border-top:1px dashed var(--line);padding-top:var(--s-2)}
.promo__terms a{color:var(--ink-2);text-decoration:underline}
.promo__age{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-3)}
.promo__age::before{content:"18+";background:var(--danger);color:#fff;font-weight:700;padding:1px 5px;border-radius:var(--r-xs);font-size:10px}

/* =========================================================================
   Editorial articles
   ========================================================================= */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-4)}
@media (max-width:720px){ .editorial{grid-template-columns:1fr} }
.article{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s-4);
  transition:transform var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease),box-shadow var(--dur-base) var(--ease);
}
.article:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-1)}
.article__kicker{font-size:11px;color:var(--signal);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.article h3{margin:4px 0 var(--s-2);font-size:var(--fs-18);color:var(--ink)}
.article__byline{font-size:var(--fs-12);color:var(--ink-3);margin-bottom:var(--s-3)}
.article p{color:var(--ink-2);font-size:var(--fs-14);line-height:1.6}

/* =========================================================================
   Bet slip — drawer always (every breakpoint)
   ========================================================================= */
.betslip{
  position:fixed;top:0;right:0;bottom:0;z-index:85;
  width:min(380px,100vw);max-height:100vh;
  background:var(--surface);border-left:1px solid var(--line);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform var(--dur-xl) var(--ease-snap);
  box-shadow:none;
}
.betslip.is-open{transform:none;box-shadow:var(--shadow-2)}
.betslip[hidden]{display:flex}  /* hidden controls aria, not visibility — we use transform */
.betslip__head{display:flex;align-items:center;justify-content:space-between;padding:var(--s-3) var(--s-4);border-bottom:1px solid var(--line)}
.betslip__title{font-weight:700;display:flex;align-items:center;gap:var(--s-2);color:var(--ink)}
.betslip__count{background:var(--accent);color:var(--accent-ink);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;min-width:20px;text-align:center}
.betslip__close{}
.betslip__tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--rail);border-bottom:1px solid var(--line);position:relative}
.betslip__tab{
  padding:10px;font-size:var(--fs-13);font-weight:600;color:var(--ink-2);
  border-bottom:2px solid transparent;
  transition:color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),border-color var(--dur-base) var(--ease);
}
.betslip__tab:hover{color:var(--ink)}
.betslip__tab.is-active{color:var(--ink);border-color:var(--accent);background:var(--surface)}
.betslip__body{flex:1;overflow-y:auto;padding:var(--s-3) var(--s-4)}
.betslip__empty{text-align:center;color:var(--ink-3);padding:var(--s-6) 0;display:flex;flex-direction:column;align-items:center;gap:var(--s-2)}
.betslip__empty svg{opacity:.6;color:var(--ink-3)}
.betslip__row{
  display:grid;grid-template-columns:1fr auto;gap:var(--s-2);
  padding:var(--s-3);background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);
  margin-bottom:var(--s-2);
  animation:slipRowIn var(--dur-slow) var(--ease-out);
  transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),opacity var(--dur-base) var(--ease),transform var(--dur-base) var(--ease);
}
.betslip__row:hover{border-color:var(--line-2)}
.betslip__row.is-leaving{opacity:0;transform:translateX(20px)}
@keyframes slipRowIn{
  from{opacity:0;transform:translateX(8px)}
  to  {opacity:1;transform:none}
}
.betslip__row-meta{font-size:var(--fs-12);color:var(--ink-3)}
.betslip__row-sel{font-weight:600;color:var(--ink)}
.betslip__row-odds{font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent)}
.betslip__row-rm{color:var(--ink-3);font-size:var(--fs-12)}
.betslip__row-rm:hover{color:var(--danger)}
.betslip__foot{padding:var(--s-3) var(--s-4);border-top:1px solid var(--line);display:flex;flex-direction:column;gap:var(--s-3)}
.betslip__stake{display:flex;flex-direction:column;gap:var(--s-1);font-size:var(--fs-13);color:var(--ink-2)}
.betslip__stake-input{display:flex;align-items:center;gap:var(--s-2);background:var(--rail);border:1px solid var(--line);border-radius:var(--r-sm);padding:0 var(--s-3);transition:border-color var(--dur-base) var(--ease),box-shadow var(--dur-base) var(--ease)}
.betslip__stake-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(156,230,0,.18)}
.betslip__stake-input span{color:var(--ink-3)}
.betslip__stake-input input{flex:1;background:none;border:0;padding:10px 0;font-size:var(--fs-16);font-variant-numeric:tabular-nums;box-shadow:none}
.betslip__stake-input input:focus{box-shadow:none}
.betslip__return{display:flex;justify-content:space-between;font-size:var(--fs-13);color:var(--ink-2)}
.betslip__return strong{color:var(--ink);font-size:var(--fs-16)}
.betslip__rg{font-size:11px;color:var(--ink-3);text-align:center;margin:0}
.betslip__rg a{color:var(--accent)}

.betslip-scrim{
  position:fixed;inset:0;z-index:84;
  background:rgba(0,0,0,.55);backdrop-filter:blur(var(--blur-bg));
  opacity:0;transition:opacity var(--dur-base) var(--ease);
  border:0;cursor:pointer;
}
.betslip-scrim.is-visible{opacity:1}
.betslip-scrim[hidden]{display:none}

/* FAB — always visible when there's a selection in the slip */
.betslip-fab{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  position:fixed;right:16px;bottom:16px;z-index:70;
  background:var(--accent);color:var(--accent-ink);border-radius:999px;padding:12px 18px;
  font-weight:700;font-size:var(--fs-14);box-shadow:var(--shadow-2);
  transform:scale(0);opacity:0;
  transition:transform var(--dur-slow) var(--ease-snap),opacity var(--dur-base) var(--ease),box-shadow var(--dur-base) var(--ease);
  border:0;cursor:pointer;
}
.betslip-fab.is-visible{transform:scale(1);opacity:1}
.betslip-fab:hover{box-shadow:var(--shadow-2),var(--glow-signal);transform:translateY(-3px) scale(1.02)}
.betslip-fab:active{transform:translateY(-1px) scale(.98)}
.betslip-fab__count{background:rgba(0,0,0,.25);padding:2px 8px;border-radius:999px;font-size:11px;transition:transform var(--dur-base) var(--ease-snap)}
.betslip-fab__count.is-bumped{transform:scale(1.3)}
.betslip-fab[hidden]{display:none}

/* Flagship A — ghost flies from the clicked odd to the FAB */
.bet-ghost-layer{position:fixed;inset:0;z-index:88;pointer-events:none}
.bet-ghost{
  position:fixed;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--accent);color:var(--accent-ink);border-radius:var(--r-sm);
  padding:6px 10px;font-size:var(--fs-13);font-weight:700;
  pointer-events:none;will-change:transform,opacity;
  box-shadow:0 8px 24px rgba(156,230,0,.4);
}
.bet-ghost strong{color:var(--accent-ink);font-variant-numeric:tabular-nums}

/* =========================================================================
   Back to top
   ========================================================================= */
.to-top{
  position:fixed;left:16px;bottom:16px;z-index:70;
  width:42px;height:42px;border-radius:999px;
  background:var(--surface);border:1px solid var(--line-2);color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-2);
  transition:
    opacity var(--dur-base) var(--ease),
    transform var(--dur-slow) var(--ease-snap),
    background var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease);
}
.to-top:hover{background:var(--rail);color:var(--accent);transform:translateY(-3px)}
.to-top:active{transform:translateY(-1px)}
.to-top[hidden]{display:none}
.to-top.is-vis{display:inline-flex}

/* =========================================================================
   Cookie banner
   ========================================================================= */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:90;
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-md);
  box-shadow:var(--shadow-2);
  max-width:880px;margin:0 auto;
  animation:cookieIn var(--dur-slow) var(--ease-out);
}
@keyframes cookieIn{
  from{opacity:0;transform:translateY(20px)}
  to  {opacity:1;transform:none}
}
.cookie-banner__inner{padding:var(--s-4);display:grid;grid-template-columns:1.5fr 1.5fr 1fr;gap:var(--s-4);align-items:start}
@media (max-width:960px){ .cookie-banner__inner{grid-template-columns:1fr} }
.cookie-banner h2{font-size:var(--fs-16);margin-bottom:4px;color:var(--ink)}
.cookie-banner p{font-size:var(--fs-13)}
.cookie-banner__cats{display:flex;flex-direction:column;gap:var(--s-2);border:0;padding:0;margin:0}
.cookie-cat{display:flex;align-items:flex-start;gap:var(--s-2);font-size:var(--fs-13)}
.cookie-cat small{color:var(--ink-3)}
.cookie-cat strong{color:var(--ink)}
.cookie-banner__actions{display:flex;flex-direction:column;gap:var(--s-2)}

/* =========================================================================
   Trust strip + footer
   ========================================================================= */
.trust-strip{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:var(--s-8)}
.trust-strip__inner{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4);padding:var(--s-5) var(--s-5)}
@media (max-width:720px){ .trust-strip__inner{grid-template-columns:1fr 1fr} }
.trust-strip__item{display:flex;align-items:center;gap:var(--s-3);min-width:0}
.trust-strip__item p{font-size:var(--fs-13);color:var(--ink-2);margin:0;line-height:1.5;min-width:0;flex:1}
.trust-strip__item a{color:var(--accent)}
.trust-strip__item a:hover{color:var(--accent-hi)}
.trust-strip__logo{
  display:inline-flex;align-items:center;justify-content:center;
  flex:0 0 auto;
  height:44px;padding:0 12px;
  background:#fff;border:1px solid #d8e4ee;border-radius:var(--r-sm);
}
.trust-strip__logo img{
  height:28px;width:auto;max-width:none;
  display:block;
}
.trust-strip__logo--age{background:transparent;border:0;padding:0;width:44px}
.trust-strip__logo--age img{height:44px;width:44px}
.trust-strip__logo--nt{background:transparent;border:0;padding:0 4px}
.trust-strip__logo--nt img{height:36px}

.badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:var(--r-sm);font-size:11px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;line-height:1;
  flex:0 0 auto;
}
.badge--age     {background:var(--danger);color:#fff}
.badge--licence {background:var(--rail);color:var(--ink);border:1px solid var(--line-2)}
.badge--betstop {background:#0E1A0F;color:#9BE9A8;border:1px solid #1F4D2C}
.badge--help    {background:#1A1606;color:#F5D17A;border:1px solid #3A3216}
.badge--gha     {background:var(--rail);color:var(--ink-2);border:1px solid var(--line-2)}

.badge-img{
  display:inline-flex;align-items:center;justify-content:center;
  height:48px;padding:6px 14px;background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--r-sm);
  flex:0 0 auto;
}
.badge-img:hover{background:var(--rail);text-decoration:none}
.badge-img img{height:32px;width:auto;display:block;max-width:none}
.badge-img--age img{height:36px}
.badge-img--gho{background:#fff;border-color:#d8e4ee}
.badge-img--gho img{height:38px}

.site-footer{background:#070A06;border-top:1px solid var(--line);color:var(--ink-2);padding:var(--s-8) 0 var(--s-6)}
.site-footer__inner{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:var(--s-6);padding-bottom:var(--s-6);border-bottom:1px solid var(--line)}
@media (max-width:960px){ .site-footer__inner{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .site-footer__inner{grid-template-columns:1fr} }
.site-footer h3{font-size:var(--fs-13);text-transform:uppercase;letter-spacing:.06em;color:var(--ink);margin-bottom:var(--s-3)}
.site-footer ul{display:flex;flex-direction:column;gap:var(--s-2)}
.site-footer li{font-size:var(--fs-13)}
.site-footer a{color:var(--ink-2);transition:color var(--dur-fast) var(--ease)}
.site-footer a:hover{color:var(--accent)}
.site-footer__brand p{font-size:var(--fs-13)}

.site-footer__compliance{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--s-4);padding:var(--s-5) var(--s-5)}
.badges-row{display:flex;gap:var(--s-2);flex-wrap:wrap}
.pay-row{display:flex;gap:var(--s-2);flex-wrap:wrap;align-items:center}
.pay{
  display:inline-flex;align-items:center;justify-content:center;
  height:40px;padding:0 14px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-sm);min-width:56px;
}
.pay--dark{background:#000;border-color:#000}
.pay img{height:22px;width:auto;display:block;max-width:none}
.pay--dark img{filter:invert(0)}
.pay--dark[data-invert] img{filter:invert(1) brightness(1.5)}
.site-footer__pay-note{flex-basis:100%;color:var(--ink-3);font-size:var(--fs-12);line-height:1.5;margin-top:var(--s-2)}

.site-footer__legal{padding:var(--s-3) var(--s-5) 0}
.site-footer__legal p{font-size:var(--fs-12);color:var(--ink-3);margin-bottom:var(--s-2);line-height:1.6}
.site-footer__legal strong{color:var(--ink-2)}

/* =========================================================================
   Forms
   ========================================================================= */
.form-stack{display:flex;flex-direction:column;gap:var(--s-4);max-width:480px;margin:0 auto}
.form-field{display:flex;flex-direction:column;gap:var(--s-1)}
.form-field label{font-size:var(--fs-13);color:var(--ink-2);font-weight:600}
.form-field .hint{font-size:11px;color:var(--ink-3)}
.form-field.is-error input{border-color:var(--danger);animation:shake .36s var(--ease)}
.form-field .error-msg{font-size:11px;color:var(--danger)}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-4px)}
  40%{transform:translateX(4px)}
  60%{transform:translateX(-2px)}
  80%{transform:translateX(2px)}
}

/* =========================================================================
   Modal
   ========================================================================= */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:100;padding:var(--s-4)}
.modal.is-open{display:flex;animation:modalFade var(--dur-base) var(--ease-out)}
@keyframes modalFade{from{opacity:0} to{opacity:1}}
.modal__card{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-md);padding:var(--s-5);max-width:480px;width:100%;box-shadow:var(--shadow-2);animation:modalIn var(--dur-slow) var(--ease-spring)}
@keyframes modalIn{
  from{opacity:0;transform:scale(.96) translateY(8px)}
  to  {opacity:1;transform:none}
}
.modal__card h2{font-size:var(--fs-22);margin-bottom:var(--s-2);color:var(--ink)}
.modal__card p{margin-bottom:var(--s-4)}
.modal__actions{display:flex;justify-content:flex-end;gap:var(--s-2)}

/* =========================================================================
   Tabs (with FLIP indicator)
   ========================================================================= */
.tabs{
  display:flex;gap:var(--s-1);background:var(--rail);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:4px;width:fit-content;position:relative;
}
.tabs__indicator{
  position:absolute;top:4px;bottom:4px;left:0;width:0;
  background:var(--signal);border-radius:var(--r-xs);
  transform:translateX(0);
  transition:transform var(--dur-base) var(--ease-out-quart),width var(--dur-base) var(--ease-out-quart);
  pointer-events:none;z-index:0;
}
.tabs button{
  padding:6px 14px;font-size:var(--fs-13);font-weight:600;color:var(--ink-2);
  border-radius:var(--r-xs);position:relative;z-index:1;
  transition:color var(--dur-base) var(--ease),transform var(--dur-fast) var(--ease);
  cursor:pointer;background:transparent;
}
.tabs button:hover{color:var(--ink)}
.tabs button:active{transform:scale(.96)}
.tabs button.is-active{color:var(--accent-ink)}

/* =========================================================================
   Tables
   ========================================================================= */
.table{font-size:var(--fs-13);width:100%}
.table th{text-align:left;color:var(--ink-3);font-weight:600;padding:8px;border-bottom:1px solid var(--line);text-transform:uppercase;font-size:11px;letter-spacing:.04em}
.table td{padding:10px 8px;border-bottom:1px solid var(--line);color:var(--ink)}
.table tr:hover td{background:rgba(156,230,0,.04)}

/* =========================================================================
   FAQ accordions
   ========================================================================= */
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:var(--s-3) 0;font-weight:600;display:flex;justify-content:space-between;align-items:center;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--ink-3);font-size:var(--fs-18);transition:transform var(--dur-base) var(--ease-out-quart),color var(--dur-fast) var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg);color:var(--accent)}
.faq details > div{padding:0 0 var(--s-4);color:var(--ink-2)}

/* =========================================================================
   Skip link + utility
   ========================================================================= */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:16px;top:16px;width:auto;height:auto;padding:8px 12px;background:var(--accent);color:var(--accent-ink);border-radius:var(--r-sm);z-index:200}
