/* ============================================
   Play Picks — Kinetic / Motion-first system
   ============================================ */

:root{
  --bg-0:#070617;
  --bg-1:#0d0a23;
  --bg-2:#15103a;
  --ink:#f5f3ff;
  --ink-soft:#c8c3e8;
  --ink-mute:#8b86b8;
  --line:rgba(255,255,255,0.08);
  --line-strong:rgba(255,255,255,0.14);
  --accent:#a78bfa;
  --accent-2:#22d3ee;
  --accent-3:#f472b6;
  --accent-4:#facc15;
  --glow:0 0 60px rgba(167,139,250,0.35);
  --radius:18px;
  --radius-sm:10px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-spring:cubic-bezier(.5,1.6,.4,1);
  --speed:.45s;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth}

body{
  background:var(--bg-0);
  color:var(--ink);
  font-family:'Raleway',sans-serif;
  font-size:16px;
  line-height:1.7;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
}

/* Animated background mesh */
.bg-mesh{
  position:fixed;
  inset:-20%;
  z-index:-2;
  pointer-events:none;
  filter:blur(80px);
  opacity:.55;
}
.bg-mesh::before,
.bg-mesh::after,
.bg-mesh .blob{
  content:"";
  position:absolute;
  width:55vmax;
  height:55vmax;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--accent),transparent 60%);
  animation:float1 22s ease-in-out infinite;
  will-change:transform;
}
.bg-mesh::before{top:-10%;left:-15%}
.bg-mesh::after{
  bottom:-20%;right:-10%;
  background:radial-gradient(circle at 60% 40%,var(--accent-2),transparent 60%);
  animation:float2 28s ease-in-out infinite;
}
.bg-mesh .blob{
  top:40%;left:55%;
  background:radial-gradient(circle at 50% 50%,var(--accent-3),transparent 65%);
  animation:float3 26s ease-in-out infinite;
}
.bg-grid{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
}
.bg-noise{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.55'/></svg>");
}

@keyframes float1{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(6vw,4vh) scale(1.08)}
  66%{transform:translate(-4vw,6vh) scale(.95)}
}
@keyframes float2{
  0%,100%{transform:translate(0,0) scale(1) rotate(0)}
  50%{transform:translate(-8vw,-6vh) scale(1.12) rotate(40deg)}
}
@keyframes float3{
  0%,100%{transform:translate(-50%,-50%) scale(1)}
  50%{transform:translate(-40%,-55%) scale(1.18)}
}

/* Typography */
h1,h2,h3,.site-logo{
  font-family:'Cormorant Garamond',serif;
  color:var(--ink);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-.01em;
}
h1{font-size:clamp(2.5rem,6vw,5rem);margin-bottom:24px}
h2{font-size:clamp(1.9rem,3.6vw,3rem);margin-bottom:18px}
h3{font-size:clamp(1.2rem,1.6vw,1.45rem);margin-bottom:10px}
p{margin-bottom:14px;color:var(--ink-soft)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  text-transform:uppercase;letter-spacing:.22em;
  font-size:11px;font-weight:600;color:var(--accent);
  padding:8px 14px;border:1px solid rgba(167,139,250,0.35);
  border-radius:999px;margin-bottom:18px;
  background:rgba(167,139,250,0.06);
  backdrop-filter:blur(6px);
}
.eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 12px var(--accent);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{50%{opacity:.4;transform:scale(.85)}}

a{color:var(--accent);text-decoration:none;transition:color var(--speed) var(--ease)}
a:hover{color:var(--accent-2)}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* Buttons */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  color:#0a0820;font-weight:700;font-size:14px;letter-spacing:.04em;
  text-transform:uppercase;
  padding:14px 28px;border:none;border-radius:999px;cursor:pointer;
  font-family:'Raleway',sans-serif;text-align:center;
  overflow:hidden;isolation:isolate;
  transition:transform var(--speed) var(--ease-spring),
             box-shadow var(--speed) var(--ease);
  box-shadow:0 10px 30px rgba(167,139,250,0.35);
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,var(--accent-2),var(--accent-4));
  opacity:0;transition:opacity var(--speed) var(--ease);
}
.btn:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 18px 40px rgba(34,211,238,.4);color:#0a0820;text-decoration:none}
.btn:hover::before{opacity:1}
.btn::after{
  content:"→";font-size:18px;
  transform:translateX(0);transition:transform var(--speed) var(--ease-spring);
}
.btn:hover::after{transform:translateX(6px) rotate(-8deg)}
.btn-block{width:100%}

.btn-ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--line-strong);
  box-shadow:none;
}
.btn-ghost:hover{background:rgba(255,255,255,.05);color:var(--ink)}

/* Cookie banner */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;z-index:50;
  padding:16px 22px;
  background:rgba(13,10,35,.85);
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  backdrop-filter:blur(20px);
  font-size:14px;color:var(--ink-soft);
  box-shadow:0 24px 60px rgba(0,0,0,.45);
  transform:translateY(0);
  animation:slideUp .7s var(--ease-spring) .4s both;
}
@keyframes slideUp{from{transform:translateY(140%);opacity:0}}
.cookie-banner .cookie-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;flex-wrap:wrap;max-width:1100px;margin:0 auto;
}
.cookie-banner button{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#0a0820;border:none;border-radius:999px;
  padding:9px 22px;cursor:pointer;font-size:13px;
  font-family:'Raleway',sans-serif;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  transition:transform var(--speed) var(--ease-spring);
}
.cookie-banner button:hover{transform:translateY(-2px) scale(1.05)}

/* Header */
header.site-header{
  position:sticky;top:0;z-index:40;
  padding:18px 0;
  background:rgba(7,6,23,.6);
  backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid transparent;
  transition:border-color .35s var(--ease),background .35s var(--ease);
}
header.site-header.scrolled{
  border-bottom-color:var(--line);
  background:rgba(7,6,23,.85);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px}
.site-logo{
  font-size:1.65rem;text-transform:uppercase;
  letter-spacing:.18em;font-weight:700;
  background:linear-gradient(135deg,var(--accent),var(--accent-2) 60%,var(--accent-3));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;
  animation:logoshift 9s linear infinite;
}
@keyframes logoshift{to{background-position:200% 0}}
.site-logo a{color:inherit;text-decoration:none}
.nav-links{display:flex;gap:32px;list-style:none;align-items:center}
.nav-links a{
  position:relative;
  text-transform:uppercase;font-size:12px;
  color:var(--ink-soft);letter-spacing:.18em;font-weight:500;
  padding:6px 0;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-4px;
  height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transition:right .45s var(--ease-spring);
}
.nav-links a:hover{color:var(--ink);text-decoration:none}
.nav-links a:hover::after{right:0}

/* Mobile menu trigger */
.menu-toggle{
  display:none;
  width:44px;height:44px;
  background:transparent;border:1px solid var(--line-strong);
  border-radius:12px;cursor:pointer;
  align-items:center;justify-content:center;
  transition:border-color var(--speed) var(--ease),
             background var(--speed) var(--ease);
  position:relative;z-index:60;
}
.menu-toggle:hover{border-color:var(--accent);background:rgba(167,139,250,.08)}
.menu-toggle span{
  display:block;width:20px;height:2px;background:var(--ink);
  position:relative;border-radius:2px;
  transition:transform .45s var(--ease-spring),
             background .25s var(--ease);
}
.menu-toggle span::before,
.menu-toggle span::after{
  content:"";position:absolute;left:0;width:20px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .45s var(--ease-spring),top .25s var(--ease) .15s;
}
.menu-toggle span::before{top:-7px}
.menu-toggle span::after{top:7px}
.menu-toggle.is-open span{background:transparent}
.menu-toggle.is-open span::before{top:0;transform:rotate(45deg)}
.menu-toggle.is-open span::after{top:0;transform:rotate(-45deg)}

/* Mobile menu drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:55;
  background:radial-gradient(ellipse at top right,var(--bg-2),var(--bg-0) 75%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;
  clip-path:circle(0% at calc(100% - 44px) 44px);
  transition:clip-path .8s var(--ease-spring);
  pointer-events:none;
}
.mobile-menu.is-open{
  clip-path:circle(150% at calc(100% - 44px) 44px);
  pointer-events:auto;
}
.mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:6px;text-align:center}
.mobile-menu a{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem;font-weight:700;
  color:var(--ink);letter-spacing:-.01em;
  padding:8px 24px;
  opacity:0;transform:translateY(24px);
  transition:opacity .5s var(--ease) .15s,
             transform .55s var(--ease-spring) .15s,
             color .25s var(--ease);
}
.mobile-menu.is-open a{opacity:1;transform:translateY(0)}
.mobile-menu li:nth-child(2) a{transition-delay:.22s}
.mobile-menu li:nth-child(3) a{transition-delay:.29s}
.mobile-menu li:nth-child(4) a{transition-delay:.36s}
.mobile-menu li:nth-child(5) a{transition-delay:.43s}
.mobile-menu li:nth-child(6) a{transition-delay:.5s}
.mobile-menu a:hover{color:var(--accent);text-decoration:none}
.mobile-menu .mm-footer{
  margin-top:30px;color:var(--ink-mute);font-size:13px;
  letter-spacing:.18em;text-transform:uppercase;
}

/* Sections */
section{position:relative;padding:120px 0;overflow:hidden}
section .container{position:relative;z-index:2}

/* Hero */
.hero{padding-top:140px;padding-bottom:120px}
.hero-inner{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:60px;
  align-items:center;
}
.hero .hero-text{max-width:620px;position:relative}
.hero h1{
  position:relative;
}
.hero h1 .word{
  display:inline-block;overflow:hidden;vertical-align:bottom;
}
.hero h1 .word span{
  display:inline-block;
  transform:translateY(110%);
  animation:wordIn 1s var(--ease-spring) forwards;
}
.hero h1 .word:nth-child(2) span{animation-delay:.1s}
.hero h1 .word:nth-child(3) span{animation-delay:.2s}
.hero h1 .word:nth-child(4) span{animation-delay:.3s}
.hero h1 .accent{
  background:linear-gradient(120deg,var(--accent),var(--accent-3) 50%,var(--accent-4));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;
  animation:wordIn 1s var(--ease-spring) forwards,
            shimmer 8s linear infinite;
}
@keyframes wordIn{to{transform:translateY(0)}}
@keyframes shimmer{to{background-position:200% 0}}
.hero p{
  max-width:640px;font-size:1.05rem;
  opacity:0;animation:fadeUp .9s var(--ease) .55s forwards;
}
.hero-cta{
  display:flex;gap:14px;flex-wrap:wrap;margin-top:28px;
  opacity:0;animation:fadeUp .9s var(--ease) .75s forwards;
}
.hero-marquee{
  margin-top:90px;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
}
.hero-marquee .track{
  display:flex;gap:60px;width:max-content;
  animation:marquee 28s linear infinite;
  font-family:'Cormorant Garamond',serif;font-size:2.2rem;
  color:var(--ink-mute);font-style:italic;
}
.hero-marquee .track span{display:inline-flex;align-items:center;gap:60px}
.hero-marquee .track span::after{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 12px var(--accent);
}
@keyframes marquee{to{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* Floating orb in hero (background accent) */
.hero-orb{
  position:absolute;top:38%;right:-220px;
  width:520px;height:520px;
  background:conic-gradient(from 0deg,var(--accent),var(--accent-2),var(--accent-3),var(--accent-4),var(--accent));
  border-radius:50%;
  filter:blur(60px);
  opacity:.5;
  transform:translateY(-50%);
  animation:orbSpin 30s linear infinite,orbFloat 10s ease-in-out infinite;
  z-index:0;
  pointer-events:none;
}
@keyframes orbSpin{to{transform:translateY(-50%) rotate(360deg)}}
@keyframes orbFloat{50%{translate:0 40px}}

/* Hero visual — phone + floating chips */
.hero-visual{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  max-width:520px;
  margin-left:auto;
  z-index:2;
  opacity:0;
  animation:fadeUp 1.1s var(--ease) .55s forwards;
}

.hero-glow{
  position:absolute;inset:8%;
  background:radial-gradient(circle at 50% 50%,rgba(167,139,250,.45),transparent 65%);
  filter:blur(40px);z-index:0;
  animation:glowPulse 7s ease-in-out infinite;
}
@keyframes glowPulse{50%{opacity:.55;transform:scale(1.06)}}

.hero-phone{
  position:absolute;
  top:50%;left:50%;
  width:62%;
  aspect-ratio:9/19;
  transform:translate(-50%,-50%) rotate(-6deg);
  z-index:2;
  animation:phoneFloat 9s ease-in-out infinite;
  will-change:transform;
}
.hero-phone-frame{
  position:relative;width:100%;height:100%;
  border-radius:38px;
  padding:10px;
  background:linear-gradient(160deg,#1a1538,#0a0820);
  border:1px solid var(--line-strong);
  box-shadow:
    0 40px 80px -20px rgba(0,0,0,.7),
    0 0 0 1px rgba(255,255,255,.04) inset,
    0 30px 60px -15px rgba(167,139,250,.35);
  overflow:hidden;
}
.hero-phone-frame::before{
  content:"";position:absolute;inset:0;border-radius:38px;
  background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 40%);
  pointer-events:none;z-index:3;
}
.hero-phone-frame .notch{
  position:absolute;top:14px;left:50%;
  transform:translateX(-50%);
  width:90px;height:22px;
  background:#070617;border-radius:14px;z-index:4;
  box-shadow:0 0 0 1px rgba(255,255,255,.05) inset;
}
.hero-phone-frame .notch::after{
  content:"";position:absolute;top:8px;right:18px;
  width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle,#22d3ee,#1a1538);
  opacity:.7;
}
.hero-phone-frame img{
  width:100%;height:100%;object-fit:cover;
  border-radius:30px;display:block;
}
@keyframes phoneFloat{
  0%,100%{transform:translate(-50%,-50%) rotate(-6deg)}
  50%{transform:translate(-50%,calc(-50% - 14px)) rotate(-3deg)}
}

/* Chips (floating game icons) */
.hero-chip{
  position:absolute;
  width:84px;height:84px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid var(--line-strong);
  padding:8px;
  backdrop-filter:blur(14px);
  box-shadow:0 18px 40px -12px rgba(0,0,0,.6);
  z-index:3;
  will-change:transform;
}
.hero-chip img{
  width:100%;height:100%;
  object-fit:cover;border-radius:16px;
  display:block;
}
.hero-chip::before{
  content:"";position:absolute;inset:-1px;border-radius:22px;
  background:linear-gradient(135deg,rgba(167,139,250,.4),transparent 60%);
  opacity:0;transition:opacity .4s var(--ease);
  pointer-events:none;z-index:-1;filter:blur(8px);
}
.hero-chip:hover::before{opacity:1}
.hero-chip.c1{top:6%;left:4%;animation:chipFloat 7s ease-in-out infinite}
.hero-chip.c2{top:14%;right:2%;width:72px;height:72px;animation:chipFloat 6s ease-in-out .6s infinite reverse}
.hero-chip.c3{bottom:18%;left:0%;width:78px;height:78px;animation:chipFloat 8s ease-in-out .3s infinite}
.hero-chip.c4{bottom:6%;right:6%;animation:chipFloat 7.5s ease-in-out .9s infinite reverse}
@keyframes chipFloat{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-18px) rotate(4deg)}
}

/* Decorative stars */
.hero-stars{position:absolute;inset:0;pointer-events:none;z-index:1}
.hero-stars span{
  position:absolute;width:4px;height:4px;border-radius:50%;
  background:var(--ink);box-shadow:0 0 8px var(--accent-2);
  opacity:.7;animation:twinkle 3.5s ease-in-out infinite;
}
.hero-stars span:nth-child(1){top:8%;right:30%;animation-delay:0s}
.hero-stars span:nth-child(2){top:22%;left:18%;width:3px;height:3px;animation-delay:.6s}
.hero-stars span:nth-child(3){top:48%;right:18%;animation-delay:1.2s}
.hero-stars span:nth-child(4){bottom:30%;right:36%;width:3px;height:3px;animation-delay:1.8s}
.hero-stars span:nth-child(5){bottom:14%;left:24%;animation-delay:2.4s}
.hero-stars span:nth-child(6){top:62%;left:8%;width:2px;height:2px;animation-delay:.3s}
@keyframes twinkle{
  0%,100%{opacity:.2;transform:scale(.7)}
  50%{opacity:1;transform:scale(1.2)}
}

/* Section header */
.sect-head{max-width:760px;margin-bottom:60px}
.sect-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* Cards */
.card{
  position:relative;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.015));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  backdrop-filter:blur(14px);
  overflow:hidden;
  transition:transform .55s var(--ease-spring),
             border-color .35s var(--ease),
             box-shadow .55s var(--ease);
}
.card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(167,139,250,.18),transparent 45%);
  opacity:0;transition:opacity .45s var(--ease);
  pointer-events:none;
}
.card:hover{
  transform:translateY(-6px);
  border-color:var(--line-strong);
  box-shadow:0 30px 60px -20px rgba(0,0,0,.5);
}
.card:hover::before{opacity:1}

/* Games grid — 2 columns on desktop */
.games-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:28px;
  margin-top:48px;
}
.game-card{display:flex;flex-direction:column;padding:32px}
.game-head{display:flex;align-items:center;gap:18px;margin-bottom:18px}
.game-head img{
  width:78px;height:78px;border-radius:18px;object-fit:cover;
  border:1px solid var(--line-strong);
  transition:transform .55s var(--ease-spring);
}
.game-card:hover .game-head img{transform:rotate(-6deg) scale(1.08)}
.game-title-block h3{margin-bottom:8px;color:var(--ink)}
.badge{
  display:inline-block;
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  color:#0a0820;font-size:10px;
  padding:4px 12px;border-radius:999px;
  text-transform:uppercase;letter-spacing:.15em;font-weight:700;
  margin-right:10px;
}
.muted{color:var(--ink-mute);font-size:13px}
.game-desc{margin:14px 0 20px;color:var(--ink-soft)}
.shots{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px;
}
.shots img{
  width:100%;height:170px;object-fit:cover;
  border-radius:12px;border:1px solid var(--line);
  transition:transform .6s var(--ease),filter .4s var(--ease);
}
.shots img:hover{transform:scale(1.04);filter:brightness(1.08) saturate(1.15)}
.game-card .btn{margin-top:auto}

/* About */
.about-content{max-width:880px}
.about-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:start;
}
.about-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
}
.stat{padding:24px;border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.025)}
.stat .num{
  font-family:'Cormorant Garamond',serif;font-size:3rem;line-height:1;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-weight:700;display:block;margin-bottom:6px;
}
.stat .lbl{font-size:13px;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.14em}

/* Features (4-col grid) */
.feature-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;
}
.feature{padding:30px}
.feature .icon{
  width:54px;height:54px;border-radius:14px;
  display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(135deg,rgba(167,139,250,.2),rgba(34,211,238,.15));
  border:1px solid var(--line-strong);
  color:var(--accent);
  transition:transform .6s var(--ease-spring),border-color .35s var(--ease),color .35s var(--ease);
}
.feature .icon svg{width:26px;height:26px}
.feature:hover .icon{color:var(--accent-2)}
.feature:hover .icon{transform:rotate(-8deg) scale(1.08);border-color:var(--accent)}
.feature h3{font-size:1.25rem}
.feature p{font-size:.94rem;color:var(--ink-soft);margin:0}

/* Process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding:32px 28px 28px;counter-increment:step}
.step::before{
  content:"0" counter(step);
  position:absolute;top:18px;right:22px;
  font-family:'Cormorant Garamond',serif;font-size:3.4rem;line-height:1;
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  opacity:.6;font-weight:700;
}
.step h3{margin-top:30px}

/* Categories */
.categories{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat{
  padding:36px 26px;text-align:left;
  position:relative;overflow:hidden;
}
.cat .glyph{
  font-family:'Cormorant Garamond',serif;
  font-size:5rem;line-height:1;font-style:italic;
  position:absolute;right:24px;top:18px;
  color:var(--accent);opacity:.18;
  transition:transform .6s var(--ease-spring),opacity .4s var(--ease);
}
.cat:hover .glyph{transform:rotate(10deg) scale(1.15);opacity:.32}
.cat h3{margin-bottom:8px}
.cat p{margin:0;font-size:.92rem}
.cat ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.cat li{
  font-size:11px;text-transform:uppercase;letter-spacing:.12em;
  padding:5px 11px;border:1px solid var(--line);border-radius:999px;
  color:var(--ink-mute);
}

/* FAQ */
.faq{max-width:860px;margin:0 auto}
.faq-item{
  border:1px solid var(--line);border-radius:var(--radius);
  margin-bottom:14px;overflow:hidden;
  background:rgba(255,255,255,.025);
  transition:border-color .35s var(--ease);
}
.faq-item.is-open{border-color:var(--accent)}
.faq-q{
  width:100%;text-align:left;
  background:transparent;border:none;color:var(--ink);
  font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:700;
  padding:22px 26px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.faq-q .plus{
  width:32px;height:32px;flex:none;border-radius:50%;
  border:1px solid var(--line-strong);
  display:grid;place-items:center;font-size:18px;color:var(--accent);
  transition:transform .5s var(--ease-spring),background .35s var(--ease);
}
.faq-item.is-open .faq-q .plus{transform:rotate(135deg);background:rgba(167,139,250,.18)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .55s var(--ease);
  padding:0 26px;
}
.faq-item.is-open .faq-a{max-height:300px;padding:0 26px 22px}
.faq-a p{margin:0;color:var(--ink-soft)}

/* Subscribe */
.subscribe-wrap{max-width:620px;margin:0 auto}
.subscribe-wrap .card{padding:44px}
.subscribe-wrap h2,
.subscribe-wrap .sub-subtitle{text-align:center}
.subscribe-wrap .sub-subtitle{color:var(--ink-mute);margin-bottom:30px}

form .field{margin-bottom:16px}
label{display:block;font-size:12px;margin-bottom:8px;
  color:var(--ink-mute);text-transform:uppercase;letter-spacing:.14em;font-weight:600}
input[type="text"],input[type="email"],input[type="tel"]{
  width:100%;padding:14px 18px;
  border:1px solid var(--line-strong);border-radius:12px;
  font-size:15px;outline:none;
  background:rgba(255,255,255,.04);color:var(--ink);
  font-family:'Raleway',sans-serif;
  transition:border-color .35s var(--ease),background .35s var(--ease),
             box-shadow .35s var(--ease),transform .35s var(--ease);
}
input::placeholder{color:var(--ink-mute)}
input:focus{
  border-color:var(--accent);
  background:rgba(255,255,255,.07);
  box-shadow:0 0 0 4px rgba(167,139,250,.14);
}

/* Consent checkbox */
.consent{
  display:flex;gap:12px;align-items:flex-start;
  font-size:13px;color:var(--ink-soft);
  margin:18px 0 22px;line-height:1.55;
  cursor:pointer;
  user-select:none;
}
.consent input{position:absolute;opacity:0;pointer-events:none}
.consent .box{
  flex:none;width:22px;height:22px;margin-top:1px;
  border:1.5px solid var(--line-strong);border-radius:6px;
  background:rgba(255,255,255,.04);
  display:grid;place-items:center;
  transition:border-color .3s var(--ease),background .3s var(--ease),
             transform .35s var(--ease-spring);
}
.consent .box::after{
  content:"";width:10px;height:10px;border-radius:2px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  transform:scale(0);transition:transform .35s var(--ease-spring);
}
.consent input:checked + .box{border-color:var(--accent);background:rgba(167,139,250,.12)}
.consent input:checked + .box::after{transform:scale(1)}
.consent input:focus-visible + .box{box-shadow:0 0 0 4px rgba(167,139,250,.18)}
.consent:hover .box{border-color:var(--accent)}
.consent a{color:var(--accent-2)}

.success-msg{
  display:none;margin-top:18px;padding:14px;
  background:rgba(34,211,238,.1);color:var(--accent-2);
  border:1px solid rgba(34,211,238,.3);
  border-radius:12px;text-align:center;font-size:14px;
}
.success-msg.visible{display:block;animation:fadeUp .55s var(--ease) forwards}
.error-msg{
  display:none;margin-top:14px;padding:12px;
  background:rgba(244,114,182,.08);color:var(--accent-3);
  border:1px solid rgba(244,114,182,.3);
  border-radius:12px;text-align:center;font-size:13px;
}
.error-msg.visible{display:block;animation:shake .45s var(--ease)}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-6px)}
  40%,80%{transform:translateX(6px)}
}

/* Footer */
footer.site-footer{
  position:relative;
  text-align:center;color:var(--ink-mute);
  padding:60px 0 40px;font-size:13px;
  border-top:1px solid var(--line);
  margin-top:60px;
}
footer .foot-links{
  margin-bottom:16px;display:flex;flex-wrap:wrap;
  justify-content:center;gap:8px 22px;
}
footer .foot-links a{
  color:var(--ink-soft);font-size:13px;
  text-transform:uppercase;letter-spacing:.14em;
  transition:color .3s var(--ease);
}
footer .foot-links a:hover{color:var(--accent);text-decoration:none}

/* Legal & sitemap pages */
.page-content{max-width:840px;margin:0 auto}
.page-content h1{
  font-size:clamp(2.2rem,4.5vw,3.4rem);
  background:linear-gradient(120deg,var(--ink),var(--accent) 70%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.page-content h2{
  margin-top:42px;font-size:1.7rem;
  padding-left:18px;border-left:3px solid var(--accent);
}
.page-content h3{margin-top:24px;font-size:1.2rem;color:var(--ink)}
.page-content p{color:var(--ink-soft)}
.page-content ul,.page-content ol{padding-left:24px;margin-bottom:16px;color:var(--ink-soft)}
.page-content li{margin-bottom:8px}
.page-content a{color:var(--accent-2)}
.page-content a:hover{color:var(--accent)}

.info-box{
  margin:22px 0;padding:22px 26px;
  background:rgba(167,139,250,.07);
  border:1px solid rgba(167,139,250,.22);
  border-left:3px solid var(--accent);
  border-radius:14px;
}
.info-box p:last-child{margin-bottom:0}
.info-box.alt{
  background:rgba(34,211,238,.06);
  border-color:rgba(34,211,238,.22);
  border-left-color:var(--accent-2);
}

/* Reveal animation states */
.reveal{
  opacity:0;transform:translateY(40px);
  transition:opacity .9s var(--ease),transform .9s var(--ease-spring);
  will-change:opacity,transform;
}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.delay-4{transition-delay:.32s}

/* Parallax */
.parallax{will-change:transform}

/* Selection */
::selection{background:var(--accent);color:#0a0820}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-0)}
::-webkit-scrollbar-thumb{
  background:linear-gradient(var(--accent),var(--accent-3));
  border-radius:10px;border:2px solid var(--bg-0);
}

/* Tablet */
@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-visual{max-width:380px;margin:0 auto}
  .hero-orb{display:none}
  .feature-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .categories{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr;gap:36px}
}

/* Mobile */
@media (max-width:720px){
  body{font-size:15px}
  .container{padding:0 18px}
  section{padding:80px 0}
  .hero{padding-top:80px;padding-bottom:80px}
  .hero-visual{max-width:300px}
  .hero-chip.c1{width:64px;height:64px}
  .hero-chip.c2,.hero-chip.c3{width:56px;height:56px}
  .hero-chip.c4{width:64px;height:64px}
  .nav-links{display:none}
  .menu-toggle{display:inline-flex}
  .games-grid{grid-template-columns:1fr;gap:18px}
  .game-card{padding:22px}
  .feature-grid,.steps,.categories{grid-template-columns:1fr;gap:14px}
  .about-stats{grid-template-columns:repeat(2,1fr)}
  .shots img{height:140px}
  .subscribe-wrap .card{padding:28px 22px}
  .cookie-banner{left:12px;right:12px;bottom:12px;padding:14px 18px}
  .mobile-menu a{font-size:1.8rem}
  footer.site-footer{padding:46px 0 30px}
  .hero-marquee .track{font-size:1.6rem;gap:36px}
  .hero-marquee .track span::after{margin-left:36px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .bg-mesh{display:none}
  .reveal{opacity:1;transform:none}
}
