/* =========================================================
   ReelPlay — free arcade reels
   Aesthetic: warm "candy arcade" / neo-brutalist toy
   ========================================================= */

:root{
  --cream:#FBF0DC;
  --cream-2:#F6E6C7;
  --paper:#FFFDF8;
  --ink:#2A1A12;
  --ink-soft:#6B5444;
  --line:#2A1A12;

  --cherry:#E94E36;
  --cherry-dark:#C73A22;
  --tangerine:#FF9E1B;
  --lime:#74B83A;
  --berry:#E84393;
  --grape:#7A4BB8;
  --teal:#1FA89B;
  --gold:#F4C430;

  --radius:20px;
  --radius-sm:12px;
  --maxw:1180px;
  --shadow:5px 5px 0 var(--ink);
  --shadow-lg:8px 8px 0 var(--ink);
  --shadow-sm:3px 3px 0 var(--ink);
  --border:3px solid var(--ink);

  --font-display:'Lilita One', 'Bungee', Impact, system-ui, sans-serif;
  --font-body:'Nunito', 'Segoe UI', system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
}

/* Decorative background */
.bg-dots{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background-image:radial-gradient(rgba(42,26,18,.07) 1.5px, transparent 1.6px);
  background-size:26px 26px;
}
.blob{position:fixed; z-index:-1; border-radius:50%; filter:blur(48px); opacity:.30; pointer-events:none}
.blob.b1{width:420px;height:420px;background:var(--cherry);top:-120px;right:-100px}
.blob.b2{width:380px;height:380px;background:var(--lime);bottom:-140px;left:-120px}
.blob.b3{width:300px;height:300px;background:var(--tangerine);top:40%;left:55%}

a{color:var(--cherry-dark);font-weight:700}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* Headings */
h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.05;letter-spacing:.3px}
h1{font-size:clamp(2.4rem,6vw,4.4rem);margin:.2em 0}
h2{font-size:clamp(1.8rem,4vw,2.8rem);margin:.1em 0 .4em}
h3{font-size:1.3rem;margin:.2em 0}
.eyebrow{font-family:var(--font-display);color:var(--cherry-dark);letter-spacing:2px;text-transform:uppercase;font-size:.9rem}

/* ---------- Top disclaimer bar ---------- */
.topbar{
  background:var(--cherry);color:#fff;text-align:center;
  font-weight:800;font-size:.82rem;letter-spacing:.3px;
  padding:8px 14px;border-bottom:3px solid var(--ink);
}
.topbar strong{font-family:var(--font-display);font-weight:400;letter-spacing:1px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:var(--cream);
  border-bottom:3px solid var(--ink);
}
.header-inner{display:flex;align-items:center;gap:18px;padding:12px 22px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none;color:var(--ink)}
.brand .mark{
  width:46px;height:46px;display:grid;place-items:center;font-size:1.5rem;
  background:var(--gold);border:var(--border);border-radius:14px;box-shadow:var(--shadow-sm);transform:rotate(-4deg)
}
.brand .name{font-family:var(--font-display);font-size:1.7rem;line-height:1}
.brand .name b{color:var(--cherry-dark)}
.brand .tag{display:block;font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft);font-weight:800}

.nav{display:flex;gap:6px;margin-left:auto}
.nav a{
  text-decoration:none;color:var(--ink);font-weight:800;font-size:.95rem;
  padding:8px 14px;border-radius:11px;border:3px solid transparent;transition:.15s
}
.nav a:hover{background:var(--paper);border-color:var(--ink);box-shadow:var(--shadow-sm)}
.nav a.active{background:var(--ink);color:var(--cream)}

.header-actions{display:flex;align-items:center;gap:10px;margin-left:8px}

/* 18+ badge */
.badge18{
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:#fff;border:3px solid var(--cherry);color:var(--cherry-dark);
  font-family:var(--font-display);font-size:.8rem;box-shadow:var(--shadow-sm);flex:none
}
.badge18.sm{width:36px;height:36px;font-size:.7rem}

/* account chip */
.acct-chip{
  display:none;align-items:center;gap:8px;cursor:pointer;
  background:var(--lime);border:var(--border);border-radius:12px;
  padding:6px 12px;box-shadow:var(--shadow-sm);font-weight:800;color:var(--ink)
}
.acct-chip .av{width:26px;height:26px;border-radius:50%;background:var(--paper);border:2px solid var(--ink);display:grid;place-items:center;font-size:.9rem}
.acct-chip small{display:block;font-size:.66rem;color:var(--ink);opacity:.8;line-height:1}
.acct-chip.show{display:flex}

.nav-acct{display:none}
.nav-acct.show{display:inline-block}

.hamburger{display:none;width:46px;height:46px;border:var(--border);background:var(--paper);border-radius:12px;box-shadow:var(--shadow-sm);cursor:pointer;font-size:1.3rem}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-body);font-weight:800;font-size:1rem;cursor:pointer;
  border:var(--border);border-radius:14px;padding:13px 26px;background:var(--paper);
  color:var(--ink);box-shadow:var(--shadow);transition:transform .08s, box-shadow .08s;
  display:inline-flex;align-items:center;gap:9px;text-decoration:none
}
.btn:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--ink)}
.btn:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink)}
.btn.primary{background:var(--cherry);color:#fff}
.btn.lime{background:var(--lime);color:#fff}
.btn.gold{background:var(--gold)}
.btn.ghost{background:transparent;box-shadow:none}
.btn.ghost:hover{background:var(--paper);box-shadow:var(--shadow-sm)}
.btn.big{font-size:1.25rem;padding:16px 40px;border-radius:16px}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}
.btn.block{width:100%;justify-content:center}

/* ---------- Pages ---------- */
.page{display:none;animation:fade .35s ease}
.page.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
section.pad{padding:54px 0}

/* card */
.card{background:var(--paper);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}

/* ---------- HOME / hero ---------- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center;padding:48px 0 16px}
.hero .lead{font-size:1.15rem;color:var(--ink-soft);max-width:40ch;font-weight:600}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.pill{display:inline-flex;align-items:center;gap:7px;background:var(--cream-2);border:3px solid var(--ink);border-radius:999px;padding:7px 14px;font-weight:800;font-size:.82rem;box-shadow:var(--shadow-sm)}
.pill-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* Game machine */
.machine{
  background:linear-gradient(180deg,var(--cherry),var(--cherry-dark));
  border:4px solid var(--ink);border-radius:28px;box-shadow:var(--shadow-lg);
  padding:22px;position:relative
}
.machine::before{content:"";position:absolute;inset:10px;border:3px dashed rgba(255,255,255,.35);border-radius:20px;pointer-events:none}
.machine-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;color:#fff}
.machine-top .ttl{font-family:var(--font-display);font-size:1.3rem;letter-spacing:1px;text-shadow:2px 2px 0 rgba(0,0,0,.25)}
.machine-top .lvtag{background:var(--gold);color:var(--ink);border:3px solid var(--ink);border-radius:10px;padding:4px 10px;font-weight:900;font-size:.85rem;box-shadow:var(--shadow-sm)}

.reels{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;background:var(--ink);padding:14px;border-radius:18px;border:3px solid #000}
.reel{
  background:var(--paper);border-radius:14px;height:120px;display:grid;place-items:center;
  font-size:4rem;border:3px solid var(--ink);overflow:hidden;user-select:none
}
.reel.blur{filter:blur(2px);opacity:.85}
.reel.pop{animation:pop .32s ease}
@keyframes pop{0%{transform:scale(.7)}60%{transform:scale(1.18)}100%{transform:scale(1)}}

.status{
  margin:14px 0 4px;background:#fff;border:3px solid var(--ink);border-radius:12px;
  padding:12px 14px;text-align:center;font-weight:800;min-height:50px;display:grid;place-items:center
}
.status.hit{background:var(--gold)}
.status.grand{background:var(--lime);color:#fff;font-family:var(--font-display);letter-spacing:1px;font-size:1.15rem}

.machine-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}
.mstat{background:rgba(255,255,255,.92);border:3px solid var(--ink);border-radius:12px;padding:8px;text-align:center}
.mstat b{display:block;font-family:var(--font-display);font-size:1.35rem;color:var(--cherry-dark);line-height:1}
.mstat span{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft)}

.levelbar{height:18px;background:#fff;border:3px solid var(--ink);border-radius:999px;overflow:hidden;margin:6px 0 2px}
.levelbar > i{display:block;height:100%;background:repeating-linear-gradient(45deg,var(--lime),var(--lime) 10px,#69a833 10px,#69a833 20px);width:0%;transition:width .5s}
.level-meta{display:flex;justify-content:space-between;color:#fff;font-weight:800;font-size:.8rem}

.play-row{margin-top:14px}

/* how to play */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.step{background:var(--paper);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.step .num{width:40px;height:40px;border-radius:12px;background:var(--berry);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:1.3rem;border:3px solid var(--ink);box-shadow:var(--shadow-sm);margin-bottom:10px}

.paytable{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.pay{display:flex;align-items:center;gap:8px;background:var(--cream-2);border:3px solid var(--ink);border-radius:12px;padding:8px 12px;font-weight:800;box-shadow:var(--shadow-sm)}
.pay .sym{font-size:1.5rem}

/* section heads */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:18px}

/* ---------- Leaderboard ---------- */
.board{border:var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--paper)}
.board .row{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:12px;padding:14px 18px;border-bottom:3px solid var(--ink);font-weight:800}
.board .row:last-child{border-bottom:none}
.board .row.head{background:var(--ink);color:var(--cream);font-family:var(--font-display);letter-spacing:1px}
.board .row.you{background:var(--gold)}
.rank{font-family:var(--font-display);font-size:1.3rem;width:46px;height:46px;display:grid;place-items:center;background:var(--cream-2);border:3px solid var(--ink);border-radius:12px}
.row.head .rank{background:transparent;border:none;color:var(--cream)}
.rank.g1{background:var(--gold)}.rank.g2{background:#D7D2C7}.rank.g3{background:var(--tangerine);color:#fff}
.pname{display:flex;align-items:center;gap:10px}
.pname .av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;border:3px solid var(--ink);font-size:1.05rem}
.pscore{font-family:var(--font-display);font-size:1.25rem;color:var(--cherry-dark)}
.row.head .pscore{color:var(--cream);font-size:1rem}

/* ---------- Rewards ---------- */
.rewards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.reward{background:var(--paper);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;position:relative;transition:transform .12s}
.reward .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:1.7rem;border:3px solid var(--ink);box-shadow:var(--shadow-sm);background:var(--cream-2);margin-bottom:10px}
.reward.locked{opacity:.62;filter:grayscale(.4)}
.reward.locked .ico{background:#E7E0D2}
.reward .tagline{font-size:.85rem;color:var(--ink-soft);font-weight:600}
.reward .state{position:absolute;top:14px;right:14px;font-size:.7rem;font-weight:900;text-transform:uppercase;letter-spacing:1px;padding:3px 9px;border:3px solid var(--ink);border-radius:999px}
.reward.unlocked .state{background:var(--lime);color:#fff}
.reward.locked .state{background:#E7E0D2}
.reward.unlocked{transform:none}
.reward.unlocked:hover{transform:translate(-2px,-2px)}

/* ---------- About / generic content ---------- */
.prose{max-width:780px}
.prose p{margin:0 0 16px}
.prose h3{margin-top:26px}
.prose ul{padding-left:22px}
.prose li{margin:6px 0}
.fact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin:20px 0}
.fact{background:var(--paper);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;text-align:center}
.fact b{display:block;font-family:var(--font-display);font-size:2.1rem;color:var(--cherry-dark);line-height:1}
.fact span{font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft)}
.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.value{background:var(--cream-2);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}
.value .vico{font-size:1.6rem}

/* notice / disclaimer block */
.notice{
  border:var(--border);border-left:12px solid var(--cherry);border-radius:var(--radius);
  background:#FFF3EE;padding:18px 22px;box-shadow:var(--shadow);margin:18px 0
}
.notice.warn{background:#FFF7E6;border-left-color:var(--tangerine)}
.notice strong{font-family:var(--font-display);font-weight:400;letter-spacing:.5px}

/* legal meta */
.legal-meta{font-size:.85rem;color:var(--ink-soft);font-weight:700;margin-bottom:10px}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-line{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:2px dashed var(--ink)}
.contact-line .ci{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;border:3px solid var(--ink);background:var(--cream-2);font-size:1.2rem;flex:none}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--cream);border-top:4px solid #000;margin-top:50px}
.footer-disc{background:var(--cherry-dark);color:#fff;text-align:center;font-weight:800;font-size:.85rem;padding:12px 16px;border-bottom:3px solid #000;display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap}
.footer-main{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:30px;padding:42px 0}
.footer-main h4{font-family:var(--font-display);font-weight:400;font-size:1.15rem;color:var(--gold);letter-spacing:.5px;margin:0 0 14px}
.footer-main a{display:block;color:var(--cream);text-decoration:none;opacity:.85;padding:5px 0;font-weight:700;cursor:pointer}
.footer-main a:hover{opacity:1;color:var(--gold)}
.footer-brand .fb-top{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.footer-brand p{opacity:.8;font-size:.92rem;max-width:34ch}
.footer-bottom{border-top:2px solid rgba(255,255,255,.18);padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:.82rem;opacity:.85}

/* ---------- Cookie banner ---------- */
.cookie{
  position:fixed;left:22px;bottom:22px;z-index:80;max-width:420px;
  background:var(--paper);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:20px;display:none
}
.cookie.show{display:block;animation:fade .3s ease}
.cookie h4{font-family:var(--font-display);font-weight:400;margin:0 0 6px}
.cookie p{font-size:.88rem;margin:0 0 14px}
.cookie .ck-btns{display:flex;gap:10px;flex-wrap:wrap}
.cookie .ck-btns .btn{padding:10px 18px}

/* ---------- Modal ---------- */
.overlay{position:fixed;inset:0;background:rgba(42,26,18,.55);z-index:90;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(2px)}
.overlay.show{display:flex;animation:fade .25s ease}
.modal{background:var(--paper);border:4px solid var(--ink);border-radius:24px;box-shadow:var(--shadow-lg);max-width:460px;width:100%;padding:28px;position:relative;max-height:92vh;overflow:auto}
.modal .x{position:absolute;top:14px;right:14px;border:3px solid var(--ink);background:var(--cream-2);border-radius:10px;width:38px;height:38px;cursor:pointer;font-size:1.1rem;box-shadow:var(--shadow-sm)}
.modal .mhead{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.modal .mhead .mi{width:50px;height:50px;border-radius:14px;background:var(--gold);border:3px solid var(--ink);display:grid;place-items:center;font-size:1.5rem;box-shadow:var(--shadow-sm)}
.modal p.sub{color:var(--ink-soft);font-weight:600;margin:0 0 18px}
.field{margin-bottom:14px}
.field label{display:block;font-weight:800;margin-bottom:6px;font-size:.92rem}
.field input[type=text],.field input[type=email]{
  width:100%;border:3px solid var(--ink);border-radius:12px;padding:12px 14px;font-size:1rem;font-family:var(--font-body);font-weight:600;background:#fff
}
.field input:focus{outline:none;box-shadow:var(--shadow-sm)}
.check{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px;font-size:.88rem;font-weight:600}
.check input{width:22px;height:22px;flex:none;margin-top:2px;accent-color:var(--cherry)}
.err{color:var(--cherry-dark);font-weight:800;font-size:.85rem;margin:-4px 0 10px;display:none}
.err.show{display:block}
.modal .fineprint{font-size:.74rem;color:var(--ink-soft);margin-top:12px;text-align:center}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{background:var(--ink);color:var(--cream);border:3px solid var(--gold);border-radius:14px;padding:12px 20px;font-weight:800;box-shadow:var(--shadow);animation:toastIn .4s ease}
@keyframes toastIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ---------- Confetti ---------- */
.confetti{position:fixed;inset:0;pointer-events:none;z-index:110;overflow:hidden}
.confetti i{position:absolute;top:-12px;width:11px;height:16px;border-radius:2px;animation:drop linear forwards}
@keyframes drop{to{transform:translateY(105vh) rotate(540deg);opacity:.9}}

/* ---------- Support chat ---------- */
.chat-fab{
  position:fixed;right:22px;bottom:22px;z-index:85;
  width:64px;height:64px;border-radius:20px;border:4px solid var(--ink);
  background:var(--lime);color:#fff;font-size:1.7rem;cursor:pointer;box-shadow:var(--shadow-lg);
  display:grid;place-items:center;transition:transform .1s
}
.chat-fab:hover{transform:translate(-2px,-2px)}
.chat-fab:active{transform:translate(2px,2px)}
.chat-panel{
  position:fixed;right:22px;bottom:22px;z-index:86;width:360px;max-width:calc(100vw - 28px);
  height:520px;max-height:calc(100vh - 40px);background:var(--paper);border:4px solid var(--ink);
  border-radius:22px;box-shadow:var(--shadow-lg);display:none;flex-direction:column;overflow:hidden
}
.chat-panel.show{display:flex;animation:fade .25s ease}
.chat-head{background:var(--lime);color:#fff;padding:14px 16px;display:flex;align-items:center;gap:10px;border-bottom:3px solid var(--ink)}
.chat-head .dot{width:11px;height:11px;border-radius:50%;background:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.4)}
.chat-head .ch-ttl{font-family:var(--font-display);font-weight:400;letter-spacing:.5px;font-size:1.05rem}
.chat-head small{display:block;font-size:.66rem;opacity:.9;font-weight:700}
.chat-head .ch-x{margin-left:auto;background:transparent;border:none;color:#fff;font-size:1.3rem;cursor:pointer}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--cream)}
.msg{max-width:82%;padding:10px 14px;border:3px solid var(--ink);border-radius:14px;font-size:.9rem;font-weight:600;line-height:1.45}
.msg.bot{background:#fff;align-self:flex-start;border-bottom-left-radius:4px}
.msg.user{background:var(--gold);align-self:flex-end;border-bottom-right-radius:4px}
.chat-quick{display:flex;gap:7px;flex-wrap:wrap;padding:0 16px 8px;background:var(--cream)}
.chat-quick button{font-size:.74rem;font-weight:800;background:var(--cream-2);border:3px solid var(--ink);border-radius:999px;padding:6px 11px;cursor:pointer;box-shadow:var(--shadow-sm)}
.chat-input{display:flex;gap:8px;padding:12px;border-top:3px solid var(--ink);background:var(--paper)}
.chat-input input{flex:1;border:3px solid var(--ink);border-radius:12px;padding:10px 12px;font-family:var(--font-body);font-weight:600;font-size:.92rem}
.chat-input input:focus{outline:none}
.chat-input button{border:3px solid var(--ink);background:var(--cherry);color:#fff;border-radius:12px;width:46px;font-size:1.1rem;cursor:pointer;box-shadow:var(--shadow-sm)}
.chat-note{font-size:.66rem;color:var(--ink-soft);text-align:center;padding:0 12px 10px;background:var(--paper);font-weight:700}

/* ---------- Responsive ---------- */
/* Prevent horizontal overflow on small screens (decorative blobs) */
html,body{overflow-x:hidden;max-width:100%}
img,svg,video{max-width:100%;height:auto}

@media (max-width:960px){
  .hero{grid-template-columns:1fr;gap:24px}
  .footer-main{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav{
    position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:3px solid var(--ink);
    flex-direction:column;gap:0;padding:8px 14px 14px;display:none
  }
  .nav.open{display:flex}
  .nav a{border-radius:10px}
  .nav a.active{background:var(--ink)}
  .hamburger{display:block}
  .header-actions .acct-chip small{display:none}
  .steps{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr}
  .board .row{grid-template-columns:50px 1fr auto;padding:12px}
  .cookie{left:14px;right:14px;bottom:96px;max-width:none}
  .machine-stats{grid-template-columns:repeat(3,1fr)}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;justify-content:center}
  .btn.big{padding:14px 24px;font-size:1.12rem}
  .hero{padding:28px 0 8px}
  section.pad{padding:40px 0}
  .machine-top .ttl{font-size:1.12rem}
  .fact-grid{grid-template-columns:repeat(2,1fr)}
  body{font-size:16px}
}

/* Small phones */
@media (max-width:480px){
  .container{padding:0 16px}
  h1{font-size:clamp(1.95rem,8vw,2.6rem)}
  .hero .lead{font-size:1.05rem}
  .eyebrow{font-size:.82rem;letter-spacing:1.5px}
  .machine{padding:16px;border-radius:22px}
  .machine::before{inset:8px}
  .machine-top .ttl{font-size:1rem}
  .reels{gap:8px;padding:10px;border-radius:14px}
  .reel{height:92px;font-size:3rem;border-radius:12px}
  .machine-stats{gap:8px}
  .mstat b{font-size:1.15rem}
  .btn.big{padding:12px 18px;font-size:1.04rem;border-radius:14px}
  .fact b{font-size:1.7rem}
  .fact{padding:14px}
  section.pad{padding:34px 0}
  .card{padding:20px}
  .topbar{font-size:.72rem;padding:7px 10px}
  .chat-panel{right:10px;left:10px;bottom:10px;width:auto;max-width:none;height:74vh;max-height:74vh}
  .chat-fab{right:14px;bottom:14px}
  .cookie{bottom:88px}
}

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

/* SPA nav: anchors without href still behave like clickable links */
[data-page],[data-support]{cursor:pointer}
[data-page]:focus-visible,[data-support]:focus-visible{outline:3px solid var(--ink);outline-offset:2px}

/* Accessibility: skip-to-content link (visible on keyboard focus) */
.skip-link{position:absolute;left:-9999px;top:auto;z-index:200;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 12px 0;font-weight:800;text-decoration:none}
.skip-link:focus{left:0;top:0}
