/* Sidebar */
.sidebar{position:sticky;top:var(--s-5);align-self:start}
.sidebar__block{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s-3);margin-bottom:var(--s-4)}
.sidebar__heading{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:0 var(--s-2) var(--s-2)}
.sidebar__heading--accent{color:var(--accent-hi)}
.sidebar__tree details{padding:6px 8px;border-radius:var(--r-sm)}
.sidebar__tree summary{cursor:pointer;list-style:none;font-weight:600;display:flex;align-items:center;justify-content:space-between;padding:4px 0}
.sidebar__tree summary::-webkit-details-marker{display:none}
.sidebar__tree summary::after{content:"+";color:var(--ink-3);font-weight:400}
.sidebar__tree details[open] summary::after{content:"−"}
.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),padding-left var(--dur-fast) var(--ease)}
.sidebar__tree ul a:hover{background:var(--rail);color:var(--ink);text-decoration:none;padding-left:12px}
.sidebar__tree--flat ul{padding-left:0;gap:2px}
.sidebar__link{display:block;padding:8px 10px;border-radius:var(--r-sm);color:var(--ink-2);font-weight:600;font-size:var(--fs-14);transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),padding-left var(--dur-fast) var(--ease)}
.sidebar__link:hover{background:var(--rail);color:var(--ink);text-decoration:none;padding-left:14px}
.sidebar__link.is-active{background:var(--rail);color:var(--ink);border-left:2px solid var(--accent-hi);padding-left:12px}

/* Hero */
.hero{
  background:
    radial-gradient(60% 80% at 80% 0%,rgba(47,123,255,.18) 0%,transparent 60%),
    radial-gradient(40% 60% at 10% 100%,rgba(47,123,255,.12) 0%,transparent 70%),
    linear-gradient(180deg,#0E1620 0%,#0B0F14 100%);
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s-6);overflow:hidden;position:relative;
}
.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{font-size:11px;color:var(--accent-hi);text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.hero h1{font-size:clamp(24px,2.6vw,38px);margin:8px 0 12px;color:#fff;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,15,20,.6);
  border:1px solid var(--line-2);border-radius:var(--r-md);padding:var(--s-4);
  backdrop-filter:blur(6px);
}
.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}
.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)}
.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;
  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);
  will-change:transform;
}
.odd:hover{background:var(--line);border-color:var(--line-2);text-decoration:none}
.odd:active{transform:scale(.96)}
.odd small{font-size:11px;color:var(--ink-3);font-weight:500;transition:color var(--dur-fast) var(--ease)}
.odd strong{font-variant-numeric:tabular-nums;font-size:var(--fs-16);color:var(--accent-hi);font-weight:700;transition:color var(--dur-fast) var(--ease)}
.odd.is-active{background:var(--accent);border-color:var(--accent-hi);transform:none}
.odd.is-active strong, .odd.is-active small{color:#fff}
@keyframes oddFlash{
  0%  {box-shadow:0 0 0 0 rgba(47,123,255,.55)}
  60% {box-shadow:0 0 0 10px rgba(47,123,255,0)}
  100%{box-shadow:0 0 0 0 rgba(47,123,255,0)}
}
.odd.is-flash{animation:oddFlash .6s var(--ease-out)}

/* 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(--line-2);box-shadow:var(--shadow-1)}
.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}
.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}
.odd--ghost{background:transparent;border-color:transparent;color:var(--ink-3);cursor:default;pointer-events:none}
.odd--ghost strong{color:var(--ink-3)}

/* 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:#fff;border-radius:var(--r-xs);font-size:11px;font-weight:700;letter-spacing:.04em}
.meeting__name{font-weight:700;font-size:var(--fs-16)}
.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;
  transition:
    transform var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease),
    background var(--dur-fast) var(--ease);
}
.race-tile:hover{border-color:var(--accent);background:rgba(47,123,255,.06);text-decoration:none;transform:translateY(-1px)}
.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-hi);font-weight:700}
.race-tile__runners{color:var(--ink-3)}
.race-tile.is-jumped{opacity:.5}

/* Promo card */
.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(--line-2);box-shadow:var(--shadow-1)}
.promo__type{font-size:11px;color:var(--accent-hi);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.promo h3{font-size:var(--fs-18)}
.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}
.promo-neutral{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-3);align-items:flex-start}
.promo-neutral p{margin:0;color:var(--ink-2)}

/* Editorial */
.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(--line-2);box-shadow:var(--shadow-1)}
.article__kicker{font-size:11px;color:var(--accent-hi);text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.article h3{margin:4px 0 var(--s-2);font-size:var(--fs-18)}
.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 */
.betslip{
  position:sticky;top:var(--s-5);align-self:start;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  display:flex;flex-direction:column;max-height:calc(100vh - 40px);
  width:100%;min-width:0;
}
.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)}
.betslip__count{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;min-width:20px;text-align:center}
.betslip__close{display:none}
.betslip__tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--rail);border-bottom:1px solid var(--line)}
.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}
.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);
}
.betslip__row:hover{border-color:var(--line-2)}
@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}
.betslip__row-odds{font-variant-numeric:tabular-nums;font-weight:700;color:var(--accent-hi)}
.betslip__row-rm{color:var(--ink-3);font-size:var(--fs-12)}
.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)}
.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}
.betslip__return{display:flex;justify-content:space-between;font-size:var(--fs-13);color:var(--ink-2)}
.betslip__return strong{color:#fff;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-hi)}
.betslip-fab{display:none}

@media (max-width:1279px){
  .betslip{
    position:fixed;top:0;right:0;bottom:0;width:min(360px,100vw);z-index:80;
    transform:translateX(100%);
    transition:transform var(--dur-slow) var(--ease-out);
    border-radius:0;border-left:1px solid var(--line);max-height:100vh;
  }
  .betslip.is-open{transform:none;box-shadow:var(--shadow-2)}
  .betslip__close{display:inline-flex}
  .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:#fff;border-radius:999px;padding:12px 16px;
    font-weight:700;font-size:var(--fs-14);box-shadow:var(--shadow-2);
  }
  .betslip-fab__count{background:rgba(0,0,0,.25);padding:2px 8px;border-radius:999px;font-size:11px}
}

/* 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-base) var(--ease-spring),
    background var(--dur-fast) var(--ease),
    color var(--dur-fast) var(--ease);
}
.to-top:hover{background:var(--rail);color:var(--accent-hi);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}
.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-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-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)}

/* Image-based badges in the compliance footer */
.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:#070A0E;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)}
.site-footer a:hover{color:var(--ink)}
.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)}  /* Visa is already white-fill, Apple Pay is black so invert it */
.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)}
.form-field .error-msg{font-size:11px;color:var(--danger)}

/* 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)}
.modal__card p{margin-bottom:var(--s-4)}
.modal__actions{display:flex;justify-content:flex-end;gap:var(--s-2)}

/* Tabs */
.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}
.tabs button{padding:6px 14px;font-size:var(--fs-13);font-weight:600;color:var(--ink-2);border-radius:var(--r-xs);transition:background var(--dur-base) var(--ease),color var(--dur-base) var(--ease),transform var(--dur-fast) var(--ease);cursor:pointer}
.tabs button:hover{color:var(--ink)}
.tabs button:active{transform:scale(.96)}
.tabs button.is-active{background:var(--bg);color:var(--ink);box-shadow:0 1px 0 rgba(255,255,255,.04),0 2px 6px rgba(0,0,0,.25)}

/* Tables */
.table{font-size:var(--fs-13)}
.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)}
.table tr:hover td{background:rgba(255,255,255,.02)}

/* Accordions (help / FAQ) */
.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}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--ink-3);font-size:var(--fs-18)}
.faq details[open] summary::after{content:"−"}
.faq details > div{padding:0 0 var(--s-4);color:var(--ink-2)}
