/* InstaSpin Casino UK - "INSTANT VIOLET" design system. Independent non-GamStop review. v2 */
:root{
  --bg:#0a0712;          /* near-black violet ink */
  --bg-2:#0d0918;
  --panel:#160f24;
  --panel-2:#1c1330;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(167,139,250,0.26);
  --violet:#8b5cf6;
  --violet-bright:#a78bfa;
  --violet-deep:#6d28d9;
  --lime:#bef264;
  --lime-bright:#d9f99d;
  --lime-deep:#a3e635;
  --ink:#f3eefe;
  --ink-soft:#c3b8da;
  --ink-mut:#8c7fa6;
  --warn:#fbbf24;
  --warn-bg:rgba(251,191,36,0.10);
  --bad:#fb7185;
  --bad-bg:rgba(251,113,133,0.10);
  --good-bg:rgba(190,242,100,0.10);
  --shell:92%;
  --radius:16px;
  --shadow:0 20px 54px rgba(0,0,0,0.5);
  --font:"Space Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);line-height:1.66;
  background:
    radial-gradient(1100px 600px at 82% -6%, rgba(139,92,246,0.15), transparent 60%),
    radial-gradient(840px 480px at 6% 6%, rgba(190,242,100,0.05), transparent 55%),
    linear-gradient(180deg,#0a0712,#08060f 62%,#060409);
  background-attachment:fixed;
  padding-bottom:78px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--violet-bright);text-decoration:none}
a:hover{color:var(--lime)}
h1,h2,h3,h4{line-height:1.16;font-weight:700;letter-spacing:-0.015em;margin:0 0 .5em}
h2{font-size:clamp(1.55rem,2.5vw,2.15rem);margin-top:1.6em}
h3{font-size:1.2rem}
p{margin:0 0 1.05em}
img{max-width:100%;display:block}
.shell{width:var(--shell);max-width:1480px;margin-inline:auto}
.accent{color:var(--lime)}
.vt{color:var(--violet-bright)}
small{font-size:.8rem}

/* drifting glow orbs */
.orbs{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.38;animation:drift 24s ease-in-out infinite}
.orb.o1{width:440px;height:440px;background:rgba(139,92,246,.24);top:-130px;left:-90px}
.orb.o2{width:340px;height:340px;background:rgba(190,242,100,.09);bottom:-110px;right:-70px;animation-delay:-8s}
.orb.o3{width:300px;height:300px;background:rgba(167,139,250,.15);top:42%;left:62%;animation-delay:-15s}
@keyframes drift{0%,100%{transform:translate(0,0)}33%{transform:translate(44px,-32px)}66%{transform:translate(-30px,28px)}}

/* top compliance bar */
.topbar{background:#07050d;border-bottom:1px solid var(--line);font-size:.78rem}
.topbar-inner{width:var(--shell);max-width:1480px;margin-inline:auto;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:7px 0;color:var(--ink-mut);flex-wrap:wrap}
.topbar strong{color:var(--ink-soft)}
.age-badge{background:var(--good-bg);border:1px solid var(--line-2);color:var(--lime);padding:2px 10px;border-radius:99px;font-weight:600}

/* header / nav */
.site-header{position:sticky;top:0;z-index:900;background:rgba(8,6,15,0.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{width:var(--shell);max-width:1480px;margin-inline:auto;display:flex;align-items:center;gap:20px;padding:12px 0;position:relative}
.brand{display:flex;align-items:center;gap:11px;color:var(--ink);font-weight:700}
.brand:hover{color:var(--ink)}
.brand-mark{width:40px;height:40px;display:grid;place-items:center;background:linear-gradient(135deg,var(--violet),var(--violet-deep));border-radius:12px;box-shadow:0 0 20px rgba(139,92,246,.55);overflow:hidden}
.brand-mark img{width:100%;height:100%;object-fit:contain;border-radius:12px;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.1;font-size:1.08rem}
.brand-text small{color:var(--ink-mut);font-weight:500;font-size:.66rem;letter-spacing:.05em;text-transform:uppercase}
.nav-spacer{flex:1}
.nav-menu{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-menu>li{position:relative}
.nav-menu>li>a,.nav-menu>li>span{display:inline-flex;align-items:center;gap:5px;padding:9px 13px;border-radius:10px;color:var(--ink-soft);font-weight:500;font-size:.92rem;cursor:pointer}
.nav-menu>li>a:hover,.nav-menu>li:hover>span{color:var(--ink);background:rgba(139,92,246,.12)}
.has-drop>span::after{content:"";width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.7}
.drop{position:absolute;top:100%;left:0;min-width:235px;background:var(--panel);border:1px solid var(--line-2);border-radius:13px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;list-style:none;margin:0}
.has-drop::before{content:"";position:absolute;top:100%;left:0;height:14px;width:100%}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateY(4px)}
.drop a{display:block;padding:9px 12px;border-radius:9px;color:var(--ink-soft);font-size:.9rem;font-weight:500}
.drop a:hover{background:rgba(139,92,246,.14);color:var(--ink)}
.nav-cta{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--lime),var(--lime-deep));color:#15240a;font-weight:700;padding:10px 18px;border-radius:11px;box-shadow:0 0 18px rgba(190,242,100,.35)}
.nav-cta:hover{color:#15240a;filter:brightness(1.06)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* hero */
.hero{position:relative;padding:52px 0 28px}
.hero-grid{width:var(--shell);max-width:1480px;margin-inline:auto;display:grid;grid-template-columns:1.3fr .9fr;gap:38px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:var(--violet-bright);background:rgba(139,92,246,.12);border:1px solid var(--line-2);padding:6px 13px;border-radius:99px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 9px var(--lime);animation:pulseDot 1.7s infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(2.05rem,4.3vw,3.35rem);margin:18px 0 14px}
.hero-lede{color:var(--ink-soft);font-size:1.07rem;max-width:62ch}
.hero-media{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow);margin-bottom:18px}
.hero-media img{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover;display:block;animation:floatHero 7s ease-in-out infinite}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 55%,rgba(8,6,15,.55));pointer-events:none}
@keyframes floatHero{0%,100%{transform:scale(1)}50%{transform:scale(1.035)}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px;align-items:flex-start}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;border-radius:12px;padding:14px 26px;font-size:1rem;border:1px solid transparent;cursor:pointer}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-lime{background:linear-gradient(135deg,var(--lime),var(--lime-deep));color:#15240a;animation:glowLime 2.4s ease-in-out infinite}
.btn-lime:hover{color:#15240a;filter:brightness(1.06)}
@keyframes glowLime{0%,100%{box-shadow:0 0 16px 2px rgba(190,242,100,.4)}50%{box-shadow:0 0 30px 8px rgba(190,242,100,.6)}}
.btn-violet{background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;animation:glowVt 2.8s ease-in-out infinite}
.btn-violet:hover{color:#fff;filter:brightness(1.08)}
@keyframes glowVt{0%,100%{box-shadow:0 0 16px 2px rgba(139,92,246,.42)}50%{box-shadow:0 0 30px 9px rgba(139,92,246,.66)}}
.btn-ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{background:rgba(139,92,246,.12);color:var(--ink)}
.hero-flags{display:flex;gap:16px;flex-wrap:wrap;margin-top:24px;font-size:.86rem;color:var(--ink-soft)}
.hero-flags div{display:flex;align-items:center;gap:7px}

/* SPEED METER scorecard (signature component) */
.meter{background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:18px;padding:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.meter::before{content:"";position:absolute;inset:0;background:radial-gradient(320px 150px at 82% 0,rgba(139,92,246,.15),transparent);pointer-events:none}
.m-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;position:relative}
.m-title{font-size:1.05rem;font-weight:700}
.m-sub{color:var(--ink-mut);font-size:.78rem}
.m-score{text-align:center;line-height:1;flex-shrink:0}
.m-score b{display:block;font-size:2.6rem;font-weight:700;color:var(--lime);font-variant-numeric:tabular-nums}
.m-score span{font-size:.7rem;color:var(--ink-mut);text-transform:uppercase;letter-spacing:.06em}
.m-rows{margin-top:18px;display:flex;flex-direction:column;gap:11px;position:relative}
.m-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;font-size:.86rem}
.m-row .lbl{color:var(--ink-soft)}
.m-bar{grid-column:1/-1;height:7px;border-radius:99px;background:rgba(255,255,255,.07);overflow:hidden}
.m-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--violet),var(--violet-bright))}
.m-bar.warn i{background:linear-gradient(90deg,#b45309,var(--warn))}
.m-bar.low i{background:linear-gradient(90deg,#9f1239,var(--bad))}
.m-foot{margin-top:16px;font-size:.74rem;color:var(--ink-mut);border-top:1px solid var(--line);padding-top:12px;position:relative}

/* sections */
main{padding:14px 0 40px}
.section{margin:46px 0}
.lead{color:var(--ink-soft);font-size:1.06rem;max-width:82ch}
.prose p{max-width:84ch}
.card{background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* quick-answer cards (used sparingly) */
.qa-card{background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:.2s;position:relative}
.qa-card:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 14px 34px rgba(0,0,0,.42)}
.qa-card h3{font-size:1.04rem;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.qa-card p{font-size:.92rem;color:var(--ink-soft);margin-bottom:12px}
.qa-card .more{font-weight:600;font-size:.88rem}
.qa-ic{font-size:1.1rem}

/* pros/cons split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
.split-col{border-radius:16px;padding:20px;border:1px solid}
.split-col.good{background:var(--good-bg);border-color:var(--line-2)}
.split-col.bad{background:var(--bad-bg);border-color:rgba(251,113,133,.28)}
.split-col h3{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.split-col.good h3{color:var(--lime)}
.split-col.bad h3{color:var(--bad)}
.tick{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.tick li{display:flex;gap:10px;font-size:.93rem;color:var(--ink-soft);line-height:1.5}
.tick li::before{content:"";flex-shrink:0;width:18px;height:18px;border-radius:50%;margin-top:2px}
.split-col.good li::before{background:radial-gradient(circle at 35% 35%,var(--lime-bright),var(--lime-deep))}
.split-col.bad li::before{background:radial-gradient(circle at 35% 35%,#fda4af,#e11d48)}

/* tables */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);margin:18px 0}
table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:560px}
caption{caption-side:top;text-align:left;font-weight:600;color:var(--ink-soft);padding:12px 16px;font-size:.9rem}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
thead th{background:rgba(139,92,246,.09);color:var(--violet-bright);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
tbody tr:hover{background:rgba(255,255,255,.025)}
tbody tr:last-child td{border-bottom:0}
td strong{color:var(--ink)}

/* fact / warn / check boxes */
.factbox{background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(190,242,100,.05));border:1px solid var(--line-2);border-left:4px solid var(--violet);border-radius:13px;padding:20px 22px;margin:22px 0}
.factbox h3{color:var(--violet-bright);margin-bottom:12px}
.factbox dl{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;margin:0;font-size:.92rem}
.factbox dt{color:var(--ink-mut);font-weight:600}
.factbox dd{margin:0;color:var(--ink)}
.warnbox{background:var(--bad-bg);border:1px solid rgba(251,113,133,.28);border-left:4px solid var(--bad);border-radius:13px;padding:18px 22px;margin:22px 0;color:var(--ink-soft)}
.warnbox h3{color:var(--bad)}
.checkbox-note{background:var(--warn-bg);border:1px solid rgba(251,191,36,.24);border-left:4px solid var(--warn);border-radius:13px;padding:18px 22px;margin:22px 0;color:var(--ink-soft)}
.checkbox-note h3{color:var(--warn)}
.checkbox-note ul,.warnbox ul{margin:8px 0 0;padding-left:20px}
.checkbox-note li,.warnbox li{margin-bottom:7px}

/* steps */
.steps{list-style:none;counter-reset:s;margin:22px 0;padding:0;display:flex;flex-direction:column;gap:16px}
.steps li{counter-increment:s;position:relative;padding:18px 20px 18px 66px;background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:13px}
.steps li::before{content:counter(s);position:absolute;left:18px;top:18px;width:34px;height:34px;display:grid;place-items:center;border-radius:10px;background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;font-weight:700;box-shadow:0 0 13px rgba(139,92,246,.45)}
.steps li h3{margin-bottom:5px;font-size:1.04rem}
.steps li p{margin:0;font-size:.92rem;color:var(--ink-soft)}

/* slot grid */
.slots{display:grid;grid-template-columns:repeat(6,1fr);gap:13px;margin:22px 0}
.slot{display:block;text-align:center}
.slot a{display:block;border-radius:13px;overflow:hidden;border:1px solid var(--line);background:var(--panel);transition:.2s}
.slot a:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 10px 26px rgba(139,92,246,.28)}
.slot img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}
.slot span{display:block;margin-top:7px;font-size:.78rem;color:var(--ink-mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* inline CTA band */
.cta-band{background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(190,242,100,.045));border:1px solid var(--line-2);border-radius:16px;padding:26px 28px;margin:30px 0;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.cta-band h3{margin:0 0 5px}
.cta-band p{margin:0;color:var(--ink-soft);font-size:.9rem}

/* FAQ */
.faq{margin:22px 0;display:flex;flex-direction:column;gap:12px}
.faq details{background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:13px;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-weight:600;list-style:none;display:flex;justify-content:space-between;gap:12px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--lime);font-weight:700;font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"\2212"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq .ans{padding:14px 20px 18px;color:var(--ink-soft);font-size:.94rem}

/* breadcrumbs */
.crumbs{width:var(--shell);max-width:1480px;margin:14px auto 0;font-size:.82rem;color:var(--ink-mut)}
.crumbs a{color:var(--ink-mut)}
.crumbs a:hover{color:var(--violet-bright)}
.crumbs span{color:var(--ink-soft)}

/* author byline + card */
.byline{display:flex;align-items:center;gap:13px;margin:24px 0;padding:14px 18px;background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:13px}
.byline .ava,.author-card .ava{width:52px;height:52px;border-radius:50%;flex-shrink:0;object-fit:cover;background:linear-gradient(135deg,var(--violet),var(--violet-deep));display:grid;place-items:center;color:#fff;font-weight:700;font-size:1.2rem;border:2px solid var(--line-2)}
.byline .who{font-size:.9rem}
.byline .who b{color:var(--ink)}
.byline .who span{color:var(--ink-mut);display:block;font-size:.82rem}
.author-card{display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap}
.author-card .ava{width:96px;height:96px;font-size:2rem}
.author-card .bio{flex:1;min-width:240px}

/* page header block + banner */
.page-head{padding:30px 0 6px}
.page-head h1{font-size:clamp(1.85rem,3.5vw,2.75rem);margin:10px 0}
.page-head .lead{margin-top:6px}
.page-banner{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow);margin:18px 0 6px}
.page-banner img{width:100%;height:auto;aspect-ratio:24/7;object-fit:cover;display:block}
.page-banner::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,6,15,.45),transparent 55%);pointer-events:none}
@media(max-width:760px){.page-banner img{aspect-ratio:16/7}}

/* footer */
.site-footer{background:#07050d;border-top:1px solid var(--line);margin-top:50px;padding:42px 0 20px}
.foot-grid{width:var(--shell);max-width:1480px;margin-inline:auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.foot-grid h4{color:var(--ink);font-size:.92rem;margin-bottom:12px}
.foot-grid ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.foot-grid a{color:var(--ink-mut);font-size:.88rem}
.foot-grid a:hover{color:var(--violet-bright)}
.foot-blurb{color:var(--ink-mut);font-size:.86rem;max-width:42ch}
.foot-bottom{width:var(--shell);max-width:1480px;margin:26px auto 0;padding-top:18px;border-top:1px solid var(--line);font-size:.8rem;color:var(--ink-mut);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* floating CTA */
.float-cta{position:fixed;right:18px;bottom:90px;z-index:800;background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:15px;padding:14px;box-shadow:var(--shadow);width:214px;animation:floatIn .6s ease both}
@keyframes floatIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.float-cta b{display:block;font-size:.9rem;margin-bottom:3px}
.float-cta small{color:var(--ink-mut);display:block;margin-bottom:10px;font-size:.74rem}
.float-cta a{display:block;text-align:center;background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;font-weight:700;padding:10px;border-radius:10px;font-size:.9rem}
.float-cta .x{position:absolute;top:6px;right:9px;color:var(--ink-mut);cursor:pointer;font-size:1rem;background:none;border:0}

/* sticky bottom bar */
.sticky-bar{position:fixed;left:0;right:0;bottom:0;z-index:850;display:flex;align-items:center;justify-content:center;gap:18px;padding:11px 16px;background:linear-gradient(180deg,rgba(7,5,13,.84),rgba(7,5,13,.98));backdrop-filter:blur(10px);border-top:1px solid var(--line-2);box-shadow:0 -8px 28px rgba(0,0,0,.5)}
.sticky-bar .t{display:flex;flex-direction:column;line-height:1.25;font-size:.86rem;font-weight:600}
.sticky-bar .t b{color:var(--lime)}
.sticky-bar .t s{color:var(--ink-mut);font-size:.72rem;font-weight:400;text-decoration:none}
.sticky-bar a.go{background:linear-gradient(135deg,var(--lime),var(--lime-deep));color:#15240a;font-weight:700;padding:12px 24px;border-radius:10px;white-space:nowrap;animation:glowLime 2.4s ease-in-out infinite}
.sticky-bar a.go:hover{color:#15240a;filter:brightness(1.06)}

/* reveal */
.js-on .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}
.reveal.in{opacity:1;transform:none}

/* responsive */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr}
  .slots{grid-template-columns:repeat(4,1fr)}
  .g4{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  :root{--shell:94%}
  .nav-menu{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--panel);border:1px solid var(--line-2);border-radius:13px;padding:10px;gap:2px;display:none;box-shadow:var(--shadow)}
  .nav.open .nav-menu{display:flex}
  .nav-menu>li>a,.nav-menu>li>span{width:100%}
  .drop{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:transparent;padding:0 0 0 12px;display:none}
  .has-drop.open .drop{display:block}
  .nav-toggle{display:flex;margin-left:auto}
  .nav-cta{display:none}
  .nav-spacer{display:none}
  .g2,.g3{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .slots{grid-template-columns:repeat(3,1fr)}
  .factbox dl{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start}
  .float-cta{display:none}
  .sticky-bar .t s{display:none}
}
@media(max-width:680px){
  table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  img,figure,video,iframe{max-width:100%;height:auto}
}
html,body{overflow-x:clip}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .hero-media img{animation:none}
}

/* --- v2 polish pass --- */
/* reveal safety: content is ALWAYS visible even if JS never runs */
.reveal{opacity:1!important;transform:none!important}

/* legibility of muted/meta text sitting over hero glow */
.hero .eyebrow,.hero-lede,.hero-flags,.hero h1,.hero p{text-shadow:0 1px 2px rgba(0,0,0,.45)}

/* focus-visible states for keyboard users */
a:focus-visible,.btn:focus-visible,.nav-cta:focus-visible,.nav-toggle:focus-visible,
.nav-menu>li>span:focus-visible,summary:focus-visible,.sticky-bar a.go:focus-visible,
.float-cta a:focus-visible{outline:2px solid var(--lime);outline-offset:3px;border-radius:8px}

/* mobile top compliance bar: never past 2 lines at 390px */
@media(max-width:600px){
  .topbar{font-size:11px;line-height:1.35}
  .topbar-inner{padding:6px 0;gap:6px 10px;justify-content:center;text-align:center}
  .age-badge{padding:1px 9px}
}

/* slot review cards (job B) */
.slot-reviews{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;margin:22px 0}
.srev{display:flex;flex-direction:column;background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.2s}
.srev:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 14px 34px rgba(0,0,0,.42)}
.srev>a{display:block;overflow:hidden;border-bottom:1px solid var(--line)}
.srev>a img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;transition:transform .25s}
.srev>a:hover img{transform:scale(1.04)}
.srev .body{padding:16px 17px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.srev h3{font-size:1.02rem;margin:0;display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.srev h3 .prov{font-size:.72rem;font-weight:500;color:var(--ink-mut);text-transform:none;letter-spacing:0}
.srev p{margin:0;font-size:.88rem;color:var(--ink-soft);line-height:1.55}
.srev .stat{margin-top:auto;display:flex;flex-wrap:wrap;gap:6px}
.srev .stat span{font-size:.72rem;background:rgba(139,92,246,.10);border:1px solid var(--line-2);color:var(--ink-soft);padding:2px 9px;border-radius:99px;white-space:nowrap}
@media(max-width:760px){.slot-reviews{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}
