/* ===========================================================
   MyBullseye — Free-to-Play Social Arcade (NZ)
   Stylesheet
   =========================================================== */

:root{
  --navy:#0d1b2a;
  --navy-2:#13283f;
  --navy-3:#1b3a5b;
  --cream:#f4f1de;
  --cream-dim:#d9d4bd;
  --red:#e63946;
  --red-dark:#c52f3b;
  --gold:#ffb703;
  --orange:#fb8500;
  --teal:#2a9d8f;
  --text:#eaf1f7;
  --muted:#a9b8c6;
  --card:#13283f;
  --card-2:#16314d;
  --line:rgba(255,255,255,.10);
  --shadow:0 18px 40px rgba(0,0,0,.35);
  --radius:18px;
  --maxw:1180px;
  --font:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 80% -10%, #1c3d61 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 10%, #16314d 0%, transparent 55%),
    var(--navy);
  line-height:1.65;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--gold);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;margin:0 0 .5em;font-weight:700}
h2{font-size:clamp(1.5rem,4vw,2.4rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.4rem)}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(14px,4vw,32px)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--navy);padding:10px 16px;border-radius:0 0 10px 0;z-index:1000}
.skip-link:focus{left:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:600;font-size:1rem;cursor:pointer;border:none;
  padding:.85rem 1.6rem;border-radius:999px;transition:transform .15s ease,box-shadow .2s ease,filter .2s ease;
  text-decoration:none;
}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--orange));color:#3a2400;box-shadow:0 10px 22px rgba(251,133,0,.35)}
.btn-red{background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;box-shadow:0 10px 22px rgba(230,57,70,.35)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(10,21,36,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:64px}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:clamp(.95rem,3.6vw,1.2rem);color:var(--text);white-space:nowrap;flex-shrink:0}
.brand:hover{text-decoration:none}
.brand img{width:clamp(26px,7vw,34px);height:clamp(26px,7vw,34px);flex-shrink:0}
.brand .dot{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:clamp(.55rem,1.7vw,1.4rem);list-style:none;margin:0;padding:0}
.nav-links a{color:var(--cream-dim);font-weight:500;font-size:clamp(.8rem,1.05vw,.97rem);white-space:nowrap}
.nav-links a:hover{color:var(--gold);text-decoration:none}
.nav-cta{margin-left:clamp(.1rem,.6vw,.4rem)}
.nav-cta .btn{padding:clamp(.5rem,.95vw,.85rem) clamp(.85rem,1.5vw,1.5rem);font-size:clamp(.8rem,1vw,.95rem)}
.burger{
  display:none;width:46px;height:46px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  border-radius:12px;cursor:pointer;padding:0;position:relative;
}
.burger span{position:absolute;left:11px;right:11px;height:2.5px;background:var(--cream);border-radius:3px;transition:.3s;}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:29px}
.burger[aria-expanded="true"] span:nth-child(1){top:22px;transform:rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* ---------- Top strip / date ---------- */
.topstrip{background:linear-gradient(90deg,var(--red),var(--orange));color:#fff;font-size:clamp(.68rem,2.6vw,.82rem);font-weight:600;text-align:center;padding:6px 10px;letter-spacing:.02em;line-height:1.35}
.topstrip span{opacity:.95}

/* ---------- Hero ---------- */
.hero{position:relative;padding:clamp(48px,9vw,96px) 0 clamp(40px,7vw,72px);text-align:center}
.hero .badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,183,3,.14);color:var(--gold);border:1px solid rgba(255,183,3,.4);padding:.35rem .9rem;border-radius:999px;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.hero h1{font-size:clamp(2.1rem,7vw,4.2rem);margin:.6em 0 .2em}
.hero h1 .accent{background:linear-gradient(135deg,var(--gold),var(--red));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:clamp(1rem,2.4vw,1.25rem);color:var(--muted);max-width:620px;margin:0 auto 1.6rem}
.hero .target-deco{position:absolute;opacity:.12;pointer-events:none}
.hero .target-deco.one{width:240px;top:-30px;right:-40px}
.hero .target-deco.two{width:170px;bottom:-30px;left:-30px}
.hero-note{font-size:.82rem;color:var(--muted);margin-top:1.4rem;max-width:560px;margin-left:auto;margin-right:auto}

/* ---------- Marquee strip ---------- */
.ticker{background:var(--navy-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap}
.ticker .track{display:inline-block;padding:12px 0;animation:scroll 22s linear infinite;font-weight:700;letter-spacing:.08em;color:var(--cream-dim);font-size:.85rem}
.ticker .track span{margin:0 1.4rem;opacity:.8}
.ticker .track span::before{content:"●";color:var(--gold);margin-right:1.4rem;font-size:.6rem;vertical-align:middle}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker .track{animation:none}}

/* ---------- Sections ---------- */
section{padding:clamp(44px,8vw,84px) 0}
.section-head{text-align:center;max-width:680px;margin:0 auto clamp(28px,5vw,48px)}
.section-head .eyebrow{color:var(--gold);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;display:block;margin-bottom:.6rem}
.section-head p{color:var(--muted)}

/* ---------- Feature grid ---------- */
.grid{display:grid;gap:clamp(16px,2.5vw,26px)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,30px);
  box-shadow:var(--shadow);transition:transform .2s ease,border-color .2s ease;
}
.card:hover{transform:translateY(-4px);border-color:rgba(255,183,3,.4)}
.card .ico{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:rgba(255,183,3,.12);margin-bottom:1rem}
.card h3{margin-bottom:.4rem}
.card p{color:var(--muted);margin:0}

/* ---------- Team ---------- */
.team-card{text-align:center}
.avatar{width:84px;height:84px;border-radius:50%;margin:0 auto .9rem;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:800;color:var(--navy);background:linear-gradient(135deg,var(--gold),var(--orange))}
.team-card h3{margin-bottom:.15rem;font-size:1.1rem}
.team-card .role{color:var(--teal);font-weight:600;font-size:.9rem}

/* ---------- World / mascot ---------- */
.world{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(24px,5vw,56px);align-items:center}
.world .mascot{background:radial-gradient(circle at 50% 40%,var(--navy-3),var(--navy));border:1px solid var(--line);border-radius:24px;padding:30px;text-align:center;box-shadow:var(--shadow)}
.world .mascot .ring{width:min(280px,70vw);height:min(280px,70vw);margin:0 auto;border-radius:50%;background:
  radial-gradient(circle,var(--red) 0 18%,var(--cream) 18% 30%,var(--red) 30% 44%,var(--cream) 44% 58%,var(--navy-3) 58% 100%);
  display:flex;align-items:center;justify-content:center;font-size:4rem;box-shadow:inset 0 0 0 4px rgba(0,0,0,.25)}
.world .mascot .mascot-photo{position:relative;width:min(300px,76vw);margin:0 auto;border-radius:20px;overflow:hidden;
  background:radial-gradient(circle at 50% 30%, #24486e, #0a1622);border:1px solid var(--line);
  box-shadow:0 22px 46px rgba(0,0,0,.45)}
.world .mascot .mascot-photo::after{content:"";position:absolute;inset:0;border-radius:20px;
  box-shadow:inset 0 -60px 60px -30px rgba(10,22,34,.9);pointer-events:none}
.world .mascot .mascot-photo img{width:100%;height:auto;display:block}

/* ---------- Games ---------- */
.balance{display:flex;align-items:center;justify-content:center;gap:.6rem;background:rgba(42,157,143,.14);border:1px solid rgba(42,157,143,.4);color:#9ff0e6;padding:.55rem 1.1rem;border-radius:999px;font-weight:700;width:max-content;margin:0 auto clamp(24px,4vw,40px)}
.game-card{display:flex;flex-direction:column;overflow:hidden;padding:0}
.game-card .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--navy-3),var(--navy));display:flex;align-items:center;justify-content:center;font-size:4rem;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.game-card .thumb picture{position:absolute;inset:0}
.game-card .thumb img{width:100%;height:100%;object-fit:cover;object-position:center 28%;display:block;transition:transform .4s ease}
.game-card:hover .thumb img{transform:scale(1.05)}
.game-card .thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,27,42,0) 45%,rgba(13,27,42,.85) 100%);pointer-events:none}
.game-card .thumb .tag{position:absolute;top:12px;left:12px;z-index:2;background:var(--red);color:#fff;font-size:.72rem;font-weight:700;padding:.25rem .7rem;border-radius:999px;letter-spacing:.05em;box-shadow:0 4px 12px rgba(0,0,0,.35)}
.game-card .body{padding:clamp(20px,3vw,28px);display:flex;flex-direction:column;flex:1}
.game-card .stats{display:flex;gap:1.4rem;margin:.6rem 0 1rem}
.game-card .stats div{flex:1}
.game-card .stats .k{display:block;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}
.game-card .stats .v{font-weight:800;font-size:1.05rem;color:var(--gold)}
.game-card ul{margin:.4rem 0 1.2rem;padding-left:1.1rem;color:var(--muted);font-size:.92rem}
.game-card ul li{margin-bottom:.35rem}
.game-card .foot{margin-top:auto}
.game-card .foot small{display:block;text-align:center;color:var(--muted);margin-top:.6rem;font-size:.76rem}

/* ---------- Mini games ---------- */
.mini-game{position:relative;border-radius:18px;padding:16px 16px 14px;margin:.2rem 0 1.2rem;overflow:hidden;
  background:radial-gradient(120% 120% at 50% -10%, #1d3e63 0%, #0c1a2b 60%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), inset 0 -30px 50px -30px rgba(0,0,0,.7), 0 14px 30px rgba(0,0,0,.35)}
.mini-game .mg-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.mini-game .mg-tag{font-size:.62rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);
  background:rgba(255,183,3,.12);border:1px solid rgba(255,183,3,.35);padding:.22rem .6rem;border-radius:999px}
.mini-game .mg-win{font-size:.72rem;font-weight:700;color:var(--muted)}
.mini-game .mg-win b{color:var(--gold)}
.play-result{margin:.9rem 0 0;text-align:center;font-size:.86rem;font-weight:600;color:var(--muted);min-height:1.2em;transition:color .2s}
.play-result.win{color:var(--gold)}
/* celebratory flash */
.mini-game.flash::after{content:"";position:absolute;inset:0;border-radius:18px;pointer-events:none;
  box-shadow:0 0 0 2px var(--gold), 0 0 40px rgba(255,183,3,.45) inset;animation:mgflash .9s ease-out}
@keyframes mgflash{0%{opacity:1}100%{opacity:0}}

/* ----- Slot reels ----- */
.reels{position:relative;display:flex;gap:8px;justify-content:center;padding:10px;border-radius:14px;
  background:linear-gradient(180deg,#070f19,#102338);
  box-shadow:inset 0 0 0 2px rgba(255,183,3,.25), inset 0 6px 20px rgba(0,0,0,.7)}
.reels::before{content:"";position:absolute;left:8px;right:8px;top:50%;height:46px;transform:translateY(-50%);
  border-radius:8px;pointer-events:none;z-index:2;
  background:linear-gradient(90deg,rgba(230,57,70,.0),rgba(255,183,3,.16),rgba(230,57,70,.0));
  box-shadow:0 0 0 1px rgba(255,183,3,.3)}
.reel{position:relative;flex:1;max-width:88px;border-radius:10px;overflow:hidden;
  background:linear-gradient(180deg,#16314d,#0a1622);
  box-shadow:inset 0 2px 6px rgba(255,255,255,.06), inset 0 -10px 18px rgba(0,0,0,.6);
  display:flex;flex-direction:column}
.reel::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.5),rgba(0,0,0,0) 22%,rgba(0,0,0,0) 78%,rgba(0,0,0,.5))}
.reel span{height:clamp(44px,12.5vw,60px);display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 3px rgba(0,0,0,.5))}
.reel span + span{border-top:1px solid rgba(255,255,255,.07)}
.reel span svg.rs{width:clamp(28px,7.2vw,42px);height:clamp(28px,7.2vw,42px);display:block}
.reel span.cell-hit{background:rgba(255,183,3,.16);box-shadow:inset 0 0 0 2px var(--gold)}
.reel span.cell-hit svg.rs{animation:pop .45s ease}
.reel.spinning span{animation:reelspin .09s linear infinite;filter:blur(1px) drop-shadow(0 2px 3px rgba(0,0,0,.5))}
@keyframes reelspin{0%{transform:translateY(-70%)}100%{transform:translateY(70%)}}
.reel.hit{box-shadow:inset 0 0 0 2px var(--gold), 0 0 18px rgba(255,183,3,.55)}
.reel.hit span{animation:pop .45s ease}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.35)}100%{transform:scale(1)}}

/* ----- Arrow drop board ----- */
.drop-board{position:relative;border-radius:14px;padding:14px 10px 8px;height:230px;display:flex;flex-direction:column;overflow:hidden;
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(255,183,3,.10), transparent 60%),
    linear-gradient(180deg,#0a1626 0%,#102338 100%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05), inset 0 8px 24px rgba(0,0,0,.6)}
/* drop slot at the very top */
.drop-board::before{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);
  width:42px;height:6px;border-radius:4px;background:linear-gradient(90deg,var(--gold),var(--orange));
  box-shadow:0 0 12px rgba(255,183,3,.6);z-index:2}
.drop-board .pegs{position:relative;flex:1;margin:10px 0 6px}
.drop-board .pegs i{position:absolute;width:7px;height:7px;border-radius:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle at 35% 30%, #fff, #7fa8cc);box-shadow:0 0 6px rgba(127,168,204,.65)}
.drop-board .arrow{position:absolute;top:4%;left:50%;transform:translate(-50%,-50%);width:clamp(20px,5vw,26px);z-index:4;
  filter:drop-shadow(0 0 7px rgba(255,183,3,.75))}
.drop-board .arrow svg{display:block;width:100%;height:auto}
/* glowing trail behind the dart while it falls */
.drop-board .arrow::after{content:"";position:absolute;left:50%;bottom:100%;transform:translateX(-50%);
  width:3px;height:22px;border-radius:3px;opacity:0;
  background:linear-gradient(180deg,rgba(255,183,3,0),rgba(255,183,3,.7))}
.drop-board .arrow.falling{transition:top .14s linear, left .14s cubic-bezier(.45,0,.55,1)}
.drop-board .arrow.falling::after{opacity:.85}
.drop-board .slots{display:flex;gap:3px;position:relative;z-index:3;padding-top:6px;
  border-top:1px solid rgba(255,255,255,.08)}
.drop-board .slots span{flex:1;text-align:center;font-size:.64rem;font-weight:800;color:#dfe9f2;padding:6px 0;border-radius:7px;
  background:linear-gradient(180deg,#1b3a5b,#122a43);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
/* heat scale for the multiplier slots (set via nth-child) */
.drop-board .slots span:nth-child(1),.drop-board .slots span:nth-child(9){background:linear-gradient(180deg,#22405f,#16314d);color:#9fb6cb}
.drop-board .slots span:nth-child(2),.drop-board .slots span:nth-child(8){background:linear-gradient(180deg,#2a9d8f,#1f7a6f);color:#eafffb}
.drop-board .slots span:nth-child(3),.drop-board .slots span:nth-child(7){background:linear-gradient(180deg,#3b82c4,#2c63a0);color:#eaf4ff}
.drop-board .slots span:nth-child(4),.drop-board .slots span:nth-child(6){background:linear-gradient(180deg,#fb8500,#d96b00);color:#2a1700}
.drop-board .slots span.hot,.drop-board .slots span:nth-child(5){background:linear-gradient(180deg,#ffd34d,#ffb703);color:#3a2400;box-shadow:0 0 14px rgba(255,183,3,.5)}
.drop-board .slots span.landed{transform:translateY(-3px) scale(1.06);outline:2px solid #fff;outline-offset:1px;animation:landpulse .5s ease}
@keyframes landpulse{0%{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.12)}100%{transform:translateY(-3px) scale(1.06)}}

@media (max-width:360px){
  .reel{max-width:70px}
  .reels::before{height:40px}
  .drop-board{height:188px}
  .drop-board .slots span{font-size:.56rem}
}

/* ---------- Steps ---------- */
.steps{counter-reset:step}
.step-card{position:relative;padding-top:46px}
.step-card::before{counter-increment:step;content:counter(step);position:absolute;top:-22px;left:24px;width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--red),var(--orange));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.3rem;color:#fff;box-shadow:var(--shadow)}

/* ---------- Prose blocks (policy + responsible) ---------- */
.prose{max-width:820px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,5vw,48px);box-shadow:var(--shadow)}
.prose h1{font-size:clamp(1.8rem,5vw,2.6rem)}
.prose h2{font-size:clamp(1.25rem,3vw,1.6rem);margin-top:1.8em;color:var(--gold)}
.prose h3{margin-top:1.4em}
.prose p,.prose li{color:var(--cream-dim)}
.prose ul,.prose ol{padding-left:1.3rem;margin-bottom:1.2rem}
.prose li{margin-bottom:.5rem}
.prose .updated{color:var(--muted);font-size:.9rem;margin-bottom:2rem;border-bottom:1px solid var(--line);padding-bottom:1rem}
.prose a{text-decoration:underline}
.callout{background:rgba(230,57,70,.1);border-left:4px solid var(--red);border-radius:8px;padding:1rem 1.2rem;margin:1.4rem 0}
.callout.gold{background:rgba(255,183,3,.1);border-left-color:var(--gold)}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:.8rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1.05rem 1.3rem;font-weight:600;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:1.5rem;font-weight:400;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details .ans{padding:0 1.3rem 1.2rem;color:var(--muted)}

/* ---------- Responsible band ---------- */
.responsible-band{background:linear-gradient(180deg,#0d1b2a,#102338);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.responsible-band .rb-card{position:relative;overflow:hidden;display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(20px,4vw,48px);align-items:center;
  background:radial-gradient(120% 140% at 0% 0%, rgba(42,157,143,.16), transparent 55%), linear-gradient(135deg,var(--navy-3),var(--navy-2));
  border:1px solid var(--line);border-radius:22px;padding:clamp(22px,3.5vw,38px);box-shadow:var(--shadow)}
.responsible-band .rb-card::before{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(42,157,143,.22),transparent 70%);pointer-events:none}
.responsible-band .rb-main{display:flex;gap:1.1rem;align-items:flex-start;position:relative;z-index:1}
.responsible-band .rb-icon{flex-shrink:0;width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;
  color:#9ff0e6;background:rgba(42,157,143,.16);border:1px solid rgba(42,157,143,.4)}
.responsible-band .rb-eyebrow{color:var(--teal);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem}
.responsible-band .rb-main h3{margin:.25rem 0 .45rem}
.responsible-band .rb-main p{color:var(--muted);margin:0;font-size:.93rem}
.responsible-band .rb-side{position:relative;z-index:1}
.responsible-band .rb-helpline{display:block;text-decoration:none;background:linear-gradient(135deg,var(--teal),#1f7a6f);
  border-radius:14px;padding:.85rem 1.1rem;color:#fff;box-shadow:0 10px 24px rgba(42,157,143,.3);transition:transform .15s ease}
.responsible-band .rb-helpline:hover{transform:translateY(-2px);text-decoration:none}
.responsible-band .rb-helpline-label{display:block;font-size:.72rem;opacity:.9;font-weight:600}
.responsible-band .rb-helpline-num{display:block;font-size:1.5rem;font-weight:800;letter-spacing:.01em;line-height:1.2}
.responsible-band .rb-chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.9rem}
.responsible-band .rb-chips a{background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.45rem .85rem;border-radius:999px;color:var(--cream-dim);font-size:.82rem;font-weight:500}
.responsible-band .rb-chips a:hover{border-color:var(--gold);color:var(--gold);text-decoration:none}
@media (max-width:760px){
  .responsible-band .rb-card{grid-template-columns:1fr}
}

/* ---------- CTA band ---------- */
.cta-band{text-align:center}
.cta-band .box{background:linear-gradient(135deg,var(--navy-3),var(--navy-2));border:1px solid var(--line);border-radius:24px;padding:clamp(30px,6vw,64px);box-shadow:var(--shadow)}

/* ---------- Footer ---------- */
.site-footer{background:#0a1622;border-top:1px solid var(--line);padding:clamp(40px,6vw,64px) 0 28px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(24px,4vw,48px);margin-bottom:2rem}
.footer-grid h4{color:var(--text);font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}
.footer-grid ul{list-style:none;margin:0;padding:0}
.footer-grid li{margin-bottom:.6rem}
.footer-grid a{color:var(--muted)}
.footer-grid a:hover{color:var(--gold)}
.footer-brand{display:flex;align-items:center;gap:.6rem;font-weight:800;font-size:1.15rem;color:var(--text);margin-bottom:.8rem}
.footer-brand img{width:30px;height:30px}
.footer-about{color:var(--muted);max-width:340px}
.footer-legal{border-top:1px solid var(--line);padding-top:1.6rem;color:var(--muted);font-size:.82rem}
.footer-legal .age{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:2px solid var(--red);color:var(--red);font-weight:800;font-size:.8rem;margin-bottom:.8rem}
.footer-legal p{margin-bottom:.8rem}

/* ===========================================================
   AGE GATE MODAL
   =========================================================== */
.age-gate{position:fixed;inset:0;z-index:1000;background:rgba(5,11,19,.92);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:18px}
.age-gate[hidden]{display:none}
.age-card{background:linear-gradient(180deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:22px;max-width:460px;width:100%;padding:clamp(26px,5vw,40px);text-align:center;box-shadow:var(--shadow)}
.age-card .logo{width:64px;height:64px;margin:0 auto 1rem}
.age-card .pill{display:inline-block;background:var(--red);color:#fff;font-weight:700;font-size:.78rem;padding:.3rem .9rem;border-radius:999px;letter-spacing:.08em;margin-bottom:1rem}
.age-card h2{font-size:1.5rem}
.age-card p{color:var(--muted);font-size:.92rem}
.age-card .actions{display:flex;flex-direction:column;gap:.7rem;margin-top:1.5rem}
.age-card .deny-msg{color:var(--red);font-weight:600;margin-top:1rem;display:none}

/* ===========================================================
   COOKIE BANNER
   =========================================================== */
.cookie-bar{position:fixed;left:14px;right:14px;bottom:14px;z-index:900;background:rgba(13,27,42,.97);border:1px solid var(--line);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow);display:flex;flex-wrap:wrap;align-items:center;gap:1rem;justify-content:space-between;max-width:var(--maxw);margin:0 auto}
.cookie-bar[hidden]{display:none}
.cookie-bar p{margin:0;color:var(--muted);font-size:.86rem;flex:1;min-width:240px}
.cookie-bar .c-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookie-bar .btn{padding:.6rem 1.1rem;font-size:.9rem}

/* ===========================================================
   RESPONSIVE — burger at 991px, fluid down to 300px
   =========================================================== */
@media (max-width:991px){
  .burger{display:block}
  .nav{min-height:60px}
  .nav-links{
    position:fixed;top:0;right:0;height:100dvh;width:min(330px,88vw);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.2rem;
    background:linear-gradient(180deg,#13283f,#0d1b2a);border-left:1px solid var(--line);
    padding:84px 24px 28px;transform:translateX(100%);
    transition:transform .32s cubic-bezier(.4,0,.2,1),visibility .32s;
    z-index:150;box-shadow:-24px 0 60px rgba(0,0,0,.5);overflow-y:auto;-webkit-overflow-scrolling:touch;
    visibility:hidden;pointer-events:none;
  }
  .nav-links.open{transform:translateX(0);visibility:visible;pointer-events:auto}
  .nav-links li{width:100%}
  .nav-links a{display:block;width:100%;padding:.85rem .2rem;font-size:1.05rem;border-bottom:1px solid var(--line)}
  .nav-cta{margin:1.2rem 0 0}
  .nav-cta .btn{width:100%;padding:.95rem;font-size:1rem}
  .nav-cta a{border-bottom:none}
  .burger{z-index:160}
  .nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);z-index:140;opacity:0;visibility:hidden;transition:.3s}
  .nav-backdrop.show{opacity:1;visibility:visible}
  body.nav-locked{overflow:hidden}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .world{grid-template-columns:1fr}
  .world .mascot{order:-1}
}

@media (max-width:760px){
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media (max-width:560px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .game-card .stats{gap:.8rem}
  .cookie-bar{flex-direction:column;align-items:stretch}
  .cookie-bar .c-actions{justify-content:stretch}
  .cookie-bar .c-actions .btn{flex:1}
}

/* tighten the header on small phones */
@media (max-width:480px){
  .topstrip{font-size:.74rem;padding:6px 8px;line-height:1.35}
  .nav{min-height:56px;gap:.6rem}
  .brand{font-size:1.08rem}
  .brand img{width:30px;height:30px}
  .burger{width:42px;height:42px}
  .burger span{left:10px;right:10px}
  .burger span:nth-child(1){top:13px}
  .burger span:nth-child(2){top:20px}
  .burger span:nth-child(3){top:27px}
  .burger[aria-expanded="true"] span:nth-child(1){top:20px}
  .burger[aria-expanded="true"] span:nth-child(3){top:20px}
}

@media (max-width:360px){
  :root{--radius:14px}
  .container{padding:0 12px}
  .brand{font-size:1rem;gap:.4rem}
  .brand img{width:27px;height:27px}
  .btn{padding:.75rem 1.05rem;font-size:.95rem}
  .game-card .stats{flex-direction:column;gap:.4rem}
  .hero h1{font-size:1.9rem}
  .nav-links{width:min(300px,92vw)}
}

@media (max-width:320px){
  .nav-links{width:100vw}
  .topstrip{font-size:.68rem}
  .balance{font-size:.85rem;padding:.5rem .8rem}
}

/* ===========================================================
   ACCESSIBILITY — focus visibility & reduced motion
   =========================================================== */
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:6px}
a:focus-visible,.btn:focus-visible,.burger:focus-visible,summary:focus-visible,
input:focus-visible,textarea:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
.btn:focus-visible{outline-offset:3px}
/* visible focus ring for form fields */
input:focus,textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold)}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .ticker .track{animation:none !important}
}
