/* Magius Casino UK "ARCANE MAGIC" design system. Independent non-GamStop guide. v2 */
:root{
  --night:#070a1c;          /* midnight blue base */
  --night-2:#0a0f2a;
  --panel:#10153a;
  --panel-2:#161c4a;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(139,92,246,0.30);
  --violet:#8b5cf6;
  --violet-bright:#a78bfa;
  --violet-deep:#6d28d9;
  --indigo:#4f46e5;
  --gold:#f5c542;
  --gold-deep:#d4a017;
  --ink:#eef0ff;
  --ink-soft:#b8bce0;
  --ink-mut:#878cba;
  --red:#fb7185;
  --red-bg:rgba(251,113,133,0.10);
  --good-bg:rgba(139,92,246,0.12);
  --shell:92%;
  --radius:16px;
  --shadow:0 20px 55px rgba(2,4,20,0.6);
  --font:"Spectral","Iowan Old Style",Georgia,serif;
  --sans:"Outfit",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);line-height:1.68;
  background:
    radial-gradient(1200px 680px at 82% -10%, rgba(139,92,246,0.20), transparent 60%),
    radial-gradient(960px 560px at 6% 2%, rgba(245,197,66,0.07), transparent 55%),
    radial-gradient(700px 500px at 50% 110%, rgba(79,70,229,0.15), transparent 60%),
    linear-gradient(180deg,#070a1c,#05071a 60%,#03040f);
  background-attachment:fixed;
  padding-bottom:78px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--violet-bright);text-decoration:none}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--font);line-height:1.16;font-weight:700;letter-spacing:-0.01em;margin:0 0 .5em}
h2{font-size:clamp(1.55rem,2.5vw,2.15rem);margin-top:1.5em}
h3{font-size:1.2rem}
p{margin:0 0 1.05em}
img{max-width:100%;display:block}
.shell{width:var(--shell);max-width:1400px;margin-inline:auto}
.accent{color:var(--gold)}
.em{color:var(--violet-bright)}
small{font-size:.8rem}

/* ---- starfield + drifting orbs ---- */
.orbs{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(76px);opacity:.5;animation:drift 24s ease-in-out infinite}
.orb.o1{width:440px;height:440px;background:rgba(139,92,246,.34);top:-130px;left:-90px}
.orb.o2{width:380px;height:380px;background:rgba(245,197,66,.12);bottom:-110px;right:-70px;animation-delay:-8s}
.orb.o3{width:320px;height:320px;background:rgba(79,70,229,.26);top:42%;left:62%;animation-delay:-14s}
.orbs::after{content:"";position:absolute;inset:0;
  background-image:radial-gradient(1.4px 1.4px at 20% 30%,rgba(255,255,255,.7),transparent),radial-gradient(1.2px 1.2px at 70% 60%,rgba(255,255,255,.55),transparent),radial-gradient(1.6px 1.6px at 40% 80%,rgba(245,197,66,.6),transparent),radial-gradient(1.2px 1.2px at 88% 18%,rgba(167,139,250,.7),transparent),radial-gradient(1.3px 1.3px at 12% 70%,rgba(255,255,255,.5),transparent);
  background-repeat:no-repeat;opacity:.55;animation:twinkle 6s ease-in-out infinite}
@keyframes twinkle{0%,100%{opacity:.55}50%{opacity:.25}}
@keyframes drift{0%,100%{transform:translate(0,0)}33%{transform:translate(44px,-32px)}66%{transform:translate(-32px,28px)}}

/* ---- top compliance bar ---- */
.topbar{background:#04061a;border-bottom:1px solid var(--line);font-size:.78rem}
.topbar-inner{width:var(--shell);max-width:1400px;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(--violet-bright);padding:2px 10px;border-radius:99px;font-weight:700}

/* ---- header / nav ---- */
.site-header{position:sticky;top:0;z-index:900;background:rgba(7,10,28,0.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{width:var(--shell);max-width:1400px;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;font-family:var(--font)}
.brand:hover{color:var(--ink)}
.brand-mark{width:40px;height:40px;display:grid;place-items:center;background:linear-gradient(135deg,var(--violet),var(--indigo));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:11px;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.1;font-size:1.1rem}
.brand-text small{color:var(--ink-mut);font-weight:600;font-size:.64rem;letter-spacing:.05em;text-transform:uppercase;font-family:var(--sans)}
.nav-spacer{flex:1}
.nav-menu{display:flex;align-items:center;gap:3px;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 12px;border-radius:9px;color:var(--ink-soft);font-weight:600;font-size:.9rem;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:.89rem;font-weight:600}
.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(--gold),var(--gold-deep));color:#20180a;font-weight:800;padding:10px 18px;border-radius:11px;box-shadow:0 0 18px rgba(245,197,66,.38)}
.nav-cta:hover{color:#20180a;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:54px 0 30px}
.hero-grid{width:var(--shell);max-width:1400px;margin-inline:auto;display:grid;grid-template-columns:1.32fr .92fr;gap:40px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--violet-bright);background:var(--good-bg);border:1px solid var(--line-2);padding:6px 13px;border-radius:99px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--violet-bright);box-shadow:0 0 9px var(--violet-bright);animation:pulseDot 1.8s infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(2.1rem,4.4vw,3.4rem);margin:18px 0 14px}
.hero-lede{color:var(--ink-soft);font-size:1.08rem;max-width:62ch}
.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:800;border-radius:12px;padding:14px 26px;font-size:1rem;border:1px solid transparent;cursor:pointer;font-family:var(--sans)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#20180a;box-shadow:0 0 0 0 rgba(245,197,66,.5);animation:glowGold 2.4s ease-in-out infinite}
.btn-gold:hover{color:#20180a;filter:brightness(1.06)}
@keyframes glowGold{0%,100%{box-shadow:0 0 16px 2px rgba(245,197,66,.4)}50%{box-shadow:0 0 32px 9px rgba(245,197,66,.62)}}
.btn-violet{background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;animation:glowVi 2.8s ease-in-out infinite}
.btn-violet:hover{color:#fff;filter:brightness(1.1)}
@keyframes glowVi{0%,100%{box-shadow:0 0 16px 2px rgba(139,92,246,.45)}50%{box-shadow:0 0 32px 10px rgba(139,92,246,.7)}}
.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}

/* ---- hero image ---- */
.hero-media{position:relative;border-radius:20px;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(5,7,26,.55));pointer-events:none}
@keyframes floatHero{0%,100%{transform:scale(1)}50%{transform:scale(1.03)}}

/* ---- SPELLBOOK SCORECARD (signature) ---- */
.scorecard{background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:20px;padding:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.scorecard::before{content:"";position:absolute;inset:0;background:radial-gradient(320px 150px at 80% 0,rgba(139,92,246,.22),transparent);pointer-events:none}
.sc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;position:relative}
.sc-title{font-size:1.06rem;font-weight:800;font-family:var(--font)}
.sc-sub{color:var(--ink-mut);font-size:.78rem}
.sc-score{text-align:center;line-height:1;flex-shrink:0}
.sc-score b{display:block;font-size:2.6rem;font-weight:800;color:var(--gold);font-variant-numeric:tabular-nums;font-family:var(--font)}
.sc-score span{font-size:.7rem;color:var(--ink-mut);text-transform:uppercase;letter-spacing:.06em}
.sc-rows{margin-top:18px;display:flex;flex-direction:column;gap:11px;position:relative}
.sc-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;font-size:.86rem}
.sc-row .lbl{color:var(--ink-soft)}
.sc-bar{grid-column:1/-1;height:7px;border-radius:99px;background:rgba(255,255,255,.07);overflow:hidden}
.sc-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--violet),var(--violet-bright))}
.sc-bar.warn i{background:linear-gradient(90deg,#b45309,var(--gold))}
.sc-bar.low i{background:linear-gradient(90deg,#9f1239,var(--red))}
.sc-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:80ch}
.prose{max-width:none}
.prose p{max-width:90ch}
.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(2,4,20,.5)}
.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:700;font-size:.88rem}
.qa-ic{font-size:1.1rem}

/* ---- rune flags (green/red) ---- */
.flags{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
.flag-col{border-radius:16px;padding:20px;border:1px solid}
.flag-col.green{background:var(--good-bg);border-color:var(--line-2)}
.flag-col.red{background:var(--red-bg);border-color:rgba(251,113,133,.28)}
.flag-col h3{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.flag-col.green h3{color:var(--violet-bright)}
.flag-col.red h3{color:var(--red)}
.flag-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.flag-list li{display:flex;gap:10px;font-size:.93rem;color:var(--ink-soft);line-height:1.55}
.flag-list li::before{content:"";flex-shrink:0;width:16px;height:16px;border-radius:50%;margin-top:4px}
.flag-col.green li::before{background:radial-gradient(circle at 35% 35%,var(--violet-bright),var(--violet-deep))}
.flag-col.red 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:700;color:var(--ink-soft);padding:12px 16px;font-size:.9rem;font-family:var(--font)}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line)}
thead th{background:rgba(139,92,246,.12);color:var(--violet-bright);font-weight:700;font-size:.8rem;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 / note boxes ---- */
.factbox{background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(245,197,66,.05));border:1px solid var(--line-2);border-left:4px solid var(--violet);border-radius:14px;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(--red-bg);border:1px solid rgba(251,113,133,.28);border-left:4px solid var(--red);border-radius:14px;padding:18px 22px;margin:22px 0;color:var(--ink-soft)}
.warnbox h3{color:var(--red)}
.checkbox-note{background:rgba(245,197,66,.07);border:1px solid rgba(245,197,66,.22);border-left:4px solid var(--gold);border-radius:14px;padding:18px 22px;margin:22px 0;color:var(--ink-soft)}
.checkbox-note h3{color:var(--gold)}
.checkbox-note ul,.warnbox ul{margin:8px 0 0;padding-left:20px}
.checkbox-note li,.warnbox li{margin-bottom:6px}

/* ---- 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 64px;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:32px;height:32px;display:grid;place-items:center;border-radius:10px;background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;font-weight:800;box-shadow:0 0 14px rgba(139,92,246,.45)}
.steps li h3{margin-bottom:5px;font-size:1.02rem}
.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 28px rgba(139,92,246,.3)}
.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}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(135deg,rgba(139,92,246,.16),rgba(245,197,66,.07));border:1px solid var(--line-2);border-radius:18px;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:700;list-style:none;display:flex;justify-content:space-between;gap:12px;color:var(--ink);font-family:var(--font)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--violet-bright);font-weight:800;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:1400px;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:800;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 */
.page-head{padding:30px 0 6px}
.page-head h1{font-size:clamp(1.85rem,3.5vw,2.8rem);margin:10px 0}
.page-head .lead{margin-top:6px}

/* page banner */
.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(5,7,26,.45),transparent 55%);pointer-events:none}
@media(max-width:760px){.page-banner img{aspect-ratio:16/7}}

/* verdict chip row */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0}
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:99px;font-size:.82rem;font-weight:700;background:var(--good-bg);border:1px solid var(--line-2);color:var(--violet-bright)}
.chip.warn{background:rgba(245,197,66,.08);border-color:rgba(245,197,66,.3);color:var(--gold)}
.chip.bad{background:var(--red-bg);border-color:rgba(251,113,133,.3);color:var(--red)}

/* ---- footer ---- */
.site-footer{background:#04061a;border-top:1px solid var(--line);margin-top:50px;padding:42px 0 20px}
.foot-grid{width:var(--shell);max-width:1400px;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;font-family:var(--font)}
.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:1400px;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:800;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(4,6,26,.84),rgba(4,6,26,.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:700}
.sticky-bar .t b{color:var(--gold)}
.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(--gold),var(--gold-deep));color:#20180a;font-weight:800;padding:12px 24px;border-radius:10px;white-space:nowrap;animation:glowGold 2.4s ease-in-out infinite}
.sticky-bar a.go:hover{color:#20180a;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}
  .flags{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/observer fails */
.reveal{opacity:1!important;transform:none!important}
/* hero lede legibility on the glow band */
.hero-lede,.hero-flags{text-shadow:0 1px 2px rgba(0,0,0,.45)}
/* keyboard focus visibility */
a:focus-visible,.btn:focus-visible,.nav-cta:focus-visible,button:focus-visible,summary:focus-visible,.nav-menu>li>span:focus-visible{
  outline:2px solid var(--violet-bright);outline-offset:2px;border-radius:8px}
/* mobile top compliance bar: keep to <=2 lines at 390px */
@media(max-width:600px){
  .topbar{font-size:11px;line-height:1.35}
  .topbar-inner{padding:6px 10px;gap:4px 8px;justify-content:center;text-align:center;flex-wrap:nowrap}
  .topbar-inner>span:first-child{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
  .topbar .age-badge{flex-shrink:0;white-space:nowrap}
}

/* ---- slot review cards (v2) ---- */
.slot-reviews{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:22px 0}
.slot-rev{background:linear-gradient(170deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.slot-rev:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 14px 34px rgba(2,4,20,.5)}
.slot-rev-media{display:flex;gap:14px;padding:16px 16px 0}
.slot-rev-media a{flex-shrink:0;display:block;width:96px;height:96px;border-radius:12px;overflow:hidden;border:1px solid var(--line-2);transition:.2s}
.slot-rev-media a:hover{box-shadow:0 0 18px rgba(139,92,246,.4)}
.slot-rev-media img{width:100%;height:100%;object-fit:cover;display:block}
.slot-rev-head h3{margin:0 0 3px;font-size:1.04rem}
.slot-rev-head .prov{font-size:.78rem;color:var(--violet-bright);font-weight:700}
.slot-rev-body{padding:12px 16px 16px}
.slot-rev-body p{font-size:.9rem;color:var(--ink-soft);margin:0 0 12px}
.slot-stats{display:flex;flex-wrap:wrap;gap:7px}
.slot-stats span{font-size:.74rem;font-weight:700;padding:4px 10px;border-radius:99px;background:var(--good-bg);border:1px solid var(--line-2);color:var(--violet-bright)}
@media(max-width:760px){.slot-reviews{grid-template-columns:1fr}}
