/* =========================================================
   NEBULA DRIFT — Cosmic Arcade
   A free, browser-based entertainment experience.
   No real-money play. Virtual Stardust only.
   ========================================================= */

:root{
  /* Surfaces */
  --bg-0:#04050d;
  --bg-1:#080a1c;
  --panel:#0c0f2b;
  --panel-2:#11163e;
  --panel-glass:rgba(14,18,52,.62);

  /* Ink */
  --ink:#eef2ff;
  --muted:#9aa4d6;
  --faint:#646e9e;
  --line:rgba(140,165,255,.16);
  --line-soft:rgba(140,165,255,.08);

  /* Signature nebula hues */
  --cyan:#4fe9ff;
  --magenta:#ff4fe0;
  --violet:#9a6bff;
  --gold:#ffd166;
  --green:#62f2c2;
  --rose:#ff7a90;

  /* Glows */
  --glow-cyan:0 0 30px rgba(79,233,255,.40);
  --glow-magenta:0 0 30px rgba(255,79,224,.40);
  --glow-gold:0 0 30px rgba(255,209,102,.45);

  /* Type */
  --font-display:"Unbounded","Trebuchet MS",sans-serif;
  --font-body:"Sora","Segoe UI",system-ui,sans-serif;

  /* Layout */
  --maxw:1180px;
  --radius:18px;
  --radius-sm:12px;
  --gut:clamp(18px,4vw,40px);
}

/* ---------------- Reset ---------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg-0);
  line-height:1.65;
  font-size:clamp(15px,1.05vw,17px);
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:6px}

/* ---------------- Cosmic background ---------------- */
.space-bg{position:fixed;inset:0;z-index:-3;background:
  radial-gradient(1200px 700px at 78% -8%, rgba(154,107,255,.22), transparent 60%),
  radial-gradient(1000px 800px at 8% 18%, rgba(255,79,224,.16), transparent 55%),
  radial-gradient(1100px 900px at 50% 120%, rgba(79,233,255,.18), transparent 60%),
  linear-gradient(180deg,var(--bg-0),var(--bg-1) 55%,#06081a);
}
.space-bg::before{ /* slow drifting nebula sheen */
  content:"";position:absolute;inset:-20%;
  background:
    radial-gradient(40% 30% at 30% 30%, rgba(98,242,194,.10), transparent 70%),
    radial-gradient(45% 35% at 75% 60%, rgba(255,122,144,.10), transparent 70%);
  filter:blur(20px);
  animation:nebula 38s ease-in-out infinite alternate;
}
#starfield{position:fixed;inset:0;z-index:-2;display:block}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@keyframes nebula{
  0%{transform:translate3d(0,0,0) scale(1)}
  100%{transform:translate3d(-3%,2%,0) scale(1.08)}
}

/* ---------------- Layout helpers ---------------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(56px,8vw,104px)}
.eyebrow{font-family:var(--font-display);font-weight:600;letter-spacing:.32em;text-transform:uppercase;
  font-size:.7rem;color:var(--cyan)}
.kicker{display:inline-flex;align-items:center;gap:.55rem;padding:.4rem .85rem;border:1px solid var(--line);
  border-radius:999px;background:var(--panel-glass);backdrop-filter:blur(8px);font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green)}

.h-grad{
  background:linear-gradient(100deg,var(--cyan),var(--magenta) 48%,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
h1,h2,h3{font-family:var(--font-display);line-height:1.08;font-weight:700}
.lead{color:var(--muted);font-size:clamp(1rem,1.4vw,1.18rem);max-width:62ch}

/* ---------------- Buttons ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--font-display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  font-size:.82rem;padding:.95rem 1.6rem;border-radius:999px;position:relative;
  transition:transform .15s ease, box-shadow .25s ease, background .25s ease;
  border:1px solid var(--line);background:var(--panel-glass);color:var(--ink);backdrop-filter:blur(6px)}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.985)}
.btn--primary{
  border:0;color:#06071a;
  background:linear-gradient(110deg,var(--cyan),var(--magenta) 60%,var(--violet));
  box-shadow:0 10px 34px rgba(255,79,224,.30), inset 0 0 14px rgba(255,255,255,.25)}
.btn--primary:hover{box-shadow:0 14px 44px rgba(79,233,255,.40), inset 0 0 18px rgba(255,255,255,.35)}
.btn--gold{border:0;color:#1a1402;background:linear-gradient(110deg,var(--gold),#ff9f4d);
  box-shadow:0 10px 30px rgba(255,209,102,.35)}
.btn--ghost{background:transparent}
.btn--ghost:hover{border-color:var(--cyan);box-shadow:var(--glow-cyan)}
.btn[disabled]{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn--lg{padding:1.15rem 2.4rem;font-size:.95rem}
.btn--block{display:flex;width:100%}

/* ---------------- Nav ---------------- */
.nav{position:sticky;top:0;z-index:60;
  background:linear-gradient(180deg,rgba(6,8,22,.92),rgba(6,8,22,.55));
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  height:74px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-weight:800;
  letter-spacing:.04em;font-size:1.05rem}
.brand__mark{width:36px;height:36px;flex:none;filter:drop-shadow(0 0 10px rgba(79,233,255,.6))}
.brand b{background:linear-gradient(100deg,var(--cyan),var(--magenta));-webkit-background-clip:text;
  background-clip:text;color:transparent}
.brand span{color:var(--ink)}

.nav__links{display:flex;align-items:center;gap:.4rem}
.nav__links a{padding:.55rem .9rem;border-radius:999px;font-size:.9rem;color:var(--muted);
  transition:color .2s,background .2s;font-weight:500}
.nav__links a:hover{color:var(--ink);background:var(--line-soft)}
.nav__links a[aria-current="page"]{color:var(--ink);background:var(--line-soft);
  box-shadow:inset 0 0 0 1px var(--line)}
.nav__right{display:flex;align-items:center;gap:.7rem}
.age-pill{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-display);
  font-weight:700;font-size:.72rem;letter-spacing:.06em;color:var(--gold);
  border:1px solid rgba(255,209,102,.4);border-radius:999px;padding:.35rem .7rem;
  background:rgba(255,209,102,.06)}
.nav__toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;
  align-items:center;justify-content:center;background:var(--panel-glass)}
.nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{
  content:"";display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;position:relative;
  transition:transform .25s,opacity .2s}
.nav__toggle span::before{position:absolute;top:-6px}
.nav__toggle span::after{position:absolute;top:6px}
.nav.open .nav__toggle span{background:transparent}
.nav.open .nav__toggle span::before{transform:translateY(6px) rotate(45deg)}
.nav.open .nav__toggle span::after{transform:translateY(-6px) rotate(-45deg)}

/* ---------------- Hero ---------------- */
.hero{position:relative;padding-block:clamp(56px,9vw,120px) clamp(30px,5vw,60px)}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,60px);align-items:center}
.hero h1{font-size:clamp(2.6rem,6.4vw,5rem);letter-spacing:-.01em}
.hero .lead{margin-top:1.3rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero__stats{display:flex;gap:2.2rem;margin-top:2.6rem;flex-wrap:wrap}
.stat b{display:block;font-family:var(--font-display);font-size:1.7rem;
  background:linear-gradient(100deg,var(--cyan),var(--gold));-webkit-background-clip:text;
  background-clip:text;color:transparent}
.stat span{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}

/* floating orb art */
.orb{position:relative;aspect-ratio:1;width:100%;max-width:440px;margin-inline:auto;
  animation:float 9s ease-in-out infinite}
.orb svg{width:100%;height:100%;filter:drop-shadow(0 30px 60px rgba(255,79,224,.25))}
@keyframes float{0%,100%{transform:translateY(-8px)}50%{transform:translateY(14px)}}

/* staggered intro */
.reveal{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.18s}.d3{animation-delay:.31s}
.d4{animation-delay:.44s}.d5{animation-delay:.57s}
@keyframes rise{to{opacity:1;transform:none}}

/* ============================================================
   THE GAME CONSOLE
   ============================================================ */
.console{position:relative;border-radius:26px;padding:clamp(18px,3vw,30px);
  background:
    linear-gradient(180deg,rgba(20,26,68,.78),rgba(9,12,34,.86));
  border:1px solid var(--line);
  box-shadow:0 40px 120px rgba(3,5,20,.7), inset 0 1px 0 rgba(255,255,255,.05);
  overflow:hidden}
.console::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 60% at 50% -10%, rgba(79,233,255,.16), transparent 60%)}
.console__top{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  flex-wrap:wrap;position:relative}
.console__title{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);
  font-weight:700;letter-spacing:.05em;font-size:1.05rem}
.console__title i{width:9px;height:9px;border-radius:50%;background:var(--green);
  box-shadow:0 0 12px var(--green);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.meters{display:flex;gap:.8rem;flex-wrap:wrap}
.meter{min-width:120px;border:1px solid var(--line);border-radius:14px;padding:.55rem .85rem;
  background:rgba(8,11,32,.6)}
.meter label{display:block;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.meter b{font-family:var(--font-display);font-size:1.25rem;color:var(--ink);letter-spacing:.02em}
.meter b .unit{color:var(--gold);font-size:.9rem}

/* reels */
.reels{position:relative;margin-block:clamp(18px,3vw,26px);display:grid;
  grid-template-columns:repeat(3,1fr);gap:clamp(10px,2vw,18px)}
.reel{position:relative;height:300px;border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg,#070a22,#0b1030);
  border:1px solid var(--line);
  box-shadow:inset 0 0 50px rgba(0,0,0,.7), inset 0 0 0 1px rgba(255,255,255,.03)}
.reel::before,.reel::after{content:"";position:absolute;left:0;right:0;height:64px;z-index:3;pointer-events:none}
.reel::before{top:0;background:linear-gradient(180deg,#0b1030,transparent)}
.reel::after{bottom:0;background:linear-gradient(0deg,#0b1030,transparent)}
.reel__strip{position:absolute;left:0;right:0;top:0;display:flex;flex-direction:column;will-change:transform}
.tile{height:100px;display:flex;align-items:center;justify-content:center;flex:none}
.tile svg{width:62px;height:62px;filter:drop-shadow(0 0 10px currentColor)}
/* center result line */
.reels__line{position:absolute;left:6px;right:6px;top:50%;height:100px;transform:translateY(-50%);
  border-radius:14px;border:1px solid rgba(255,209,102,.35);z-index:2;pointer-events:none;
  box-shadow:0 0 0 1px rgba(255,209,102,.08), inset 0 0 30px rgba(255,209,102,.05)}
.reel.matched{animation:reelGlow 1.1s ease}
@keyframes reelGlow{0%{box-shadow:inset 0 0 50px rgba(0,0,0,.7)}
  35%{box-shadow:0 0 40px var(--gold), inset 0 0 40px rgba(255,209,102,.4)}
  100%{box-shadow:inset 0 0 50px rgba(0,0,0,.7)}}

/* controls */
.controls{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center}
.stake{display:flex;flex-direction:column;gap:.5rem}
.stake > span{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.stake__opts{display:flex;gap:.45rem;flex-wrap:wrap}
.chip{font-family:var(--font-display);font-weight:600;font-size:.85rem;padding:.5rem .9rem;border-radius:12px;
  border:1px solid var(--line);background:rgba(8,11,32,.6);color:var(--muted);transition:all .2s}
.chip:hover{color:var(--ink);border-color:var(--cyan)}
.chip[aria-pressed="true"]{color:#06071a;background:linear-gradient(110deg,var(--cyan),var(--magenta));
  border-color:transparent;box-shadow:var(--glow-cyan)}
.action{display:flex;gap:.7rem;align-items:center}

.result{margin-top:1.1rem;min-height:2.6rem;display:flex;align-items:center;justify-content:center;
  gap:.6rem;text-align:center;font-family:var(--font-display);font-weight:600;letter-spacing:.03em;
  font-size:1.05rem;color:var(--muted);transition:color .25s}
.result.good{color:var(--gold);text-shadow:0 0 18px rgba(255,209,102,.5)}
.result.mega{color:var(--cyan);text-shadow:0 0 22px rgba(79,233,255,.6);font-size:1.25rem}

.console__foot{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;
  flex-wrap:wrap;margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--line-soft)}
.log{display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;color:var(--muted);min-width:200px}
.log b{color:var(--faint);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.2rem}
.log span{display:flex;justify-content:space-between;gap:1rem}
.log .pos{color:var(--green)}
.icon-btn{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:.45rem .8rem;transition:all .2s}
.icon-btn:hover{color:var(--ink);border-color:var(--cyan)}
.icon-btn svg{width:16px;height:16px}

.note{font-size:.78rem;color:var(--faint);max-width:46ch}

/* burst overlay for alignment */
.burst{position:absolute;inset:0;z-index:5;pointer-events:none;display:grid;place-items:center;opacity:0}
.burst.show{animation:burst 1.4s ease forwards}
.burst svg{width:80%;max-width:520px;opacity:.9}
@keyframes burst{0%{opacity:0;transform:scale(.6)}25%{opacity:1}100%{opacity:0;transform:scale(1.25)}}

/* ---------------- Feature cards ---------------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.card{border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;
  background:linear-gradient(180deg,rgba(16,20,56,.6),rgba(9,12,34,.55));
  backdrop-filter:blur(6px);transition:transform .25s,border-color .25s,box-shadow .25s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-4px);border-color:var(--line);box-shadow:0 24px 60px rgba(3,5,20,.55)}
.card__ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;margin-bottom:1rem;
  background:rgba(79,233,255,.1);border:1px solid var(--line)}
.card__ico svg{width:26px;height:26px;color:var(--cyan)}
.card h3{font-size:1.2rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.95rem}

/* section heading block */
.head{max-width:64ch;margin-bottom:2.6rem}
.head h2{font-size:clamp(1.9rem,4vw,3rem);margin-block:.7rem .8rem}

/* ---------------- About ---------------- */
.about__hero{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,56px);align-items:center}
.factbox{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--panel-glass)}
.factbox .row{display:flex;justify-content:space-between;gap:1rem;padding:.95rem 1.2rem;
  border-bottom:1px solid var(--line-soft);font-size:.92rem}
.factbox .row:last-child{border-bottom:0}
.factbox .row span{color:var(--faint)}
.factbox .row b{font-family:var(--font-display);font-weight:600}

.timeline{position:relative;margin-top:1rem;padding-left:1.6rem}
.timeline::before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(180deg,var(--cyan),var(--magenta),transparent)}
.tl{position:relative;padding:.2rem 0 1.5rem 0}
.tl::before{content:"";position:absolute;left:-1.6rem;top:.45rem;width:12px;height:12px;border-radius:50%;
  background:var(--bg-0);border:2px solid var(--cyan);box-shadow:0 0 12px var(--cyan)}
.tl b{font-family:var(--font-display);color:var(--gold);font-size:.85rem;letter-spacing:.1em}
.tl h4{font-family:var(--font-display);font-size:1.1rem;margin:.2rem 0 .3rem}
.tl p{color:var(--muted);font-size:.92rem}

.team{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:1rem}
.member{text-align:center;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1rem;
  background:var(--panel-glass)}
.avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 1rem;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:#06071a;
  background:linear-gradient(135deg,var(--cyan),var(--magenta))}
.member h4{font-family:var(--font-display);font-size:1.02rem}
.member span{font-size:.8rem;color:var(--faint)}

.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}

/* ---------------- Legal / article pages ---------------- */
.page-head{padding-block:clamp(46px,7vw,84px) 1rem;border-bottom:1px solid var(--line-soft)}
.page-head h1{font-size:clamp(2.1rem,5vw,3.4rem)}
.page-head p{color:var(--muted);margin-top:.8rem;max-width:60ch}
.updated{font-size:.78rem;color:var(--faint);letter-spacing:.06em;margin-top:1rem;text-transform:uppercase}

.legal{display:grid;grid-template-columns:240px 1fr;gap:clamp(24px,4vw,52px);align-items:start;
  padding-block:clamp(34px,5vw,60px)}
.toc{position:sticky;top:90px;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem;background:var(--panel-glass);font-size:.88rem}
.toc b{display:block;font-family:var(--font-display);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--faint);margin-bottom:.8rem}
.toc a{display:block;padding:.4rem 0;color:var(--muted);border-bottom:1px solid var(--line-soft)}
.toc a:last-child{border-bottom:0}
.toc a:hover{color:var(--cyan)}

.prose{max-width:72ch}
.prose h2{font-size:1.5rem;margin-top:2.4rem;margin-bottom:.8rem;scroll-margin-top:90px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.12rem;margin-top:1.5rem;margin-bottom:.5rem}
.prose p{color:#cdd4f3;margin-bottom:1rem}
.prose ul{margin:0 0 1.2rem 1.2rem;list-style:disc}
.prose ul li{margin-bottom:.5rem;color:#cdd4f3;padding-left:.3rem}
.prose a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--ink)}

.callout{border:1px solid rgba(255,209,102,.4);border-radius:var(--radius);padding:1.3rem 1.5rem;
  background:rgba(255,209,102,.06);margin:1.6rem 0}
.callout h3{font-family:var(--font-display);color:var(--gold);margin-bottom:.5rem;font-size:1.05rem}
.callout p{color:#e7e3cf;margin-bottom:0}

.danger{border-color:rgba(255,122,144,.4);background:rgba(255,122,144,.07)}
.danger h3{color:var(--rose)}

/* ---------------- FAQ ---------------- */
.acc{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--panel-glass)}
.acc__item{border-bottom:1px solid var(--line-soft)}
.acc__item:last-child{border-bottom:0}
.acc__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.2rem 1.4rem;font-family:var(--font-display);font-weight:600;font-size:1.02rem;text-align:left}
.acc__q:hover{background:var(--line-soft)}
.acc__q .plus{width:22px;height:22px;flex:none;position:relative;transition:transform .25s}
.acc__q .plus::before,.acc__q .plus::after{content:"";position:absolute;inset:0;margin:auto;background:var(--cyan)}
.acc__q .plus::before{width:14px;height:2px}
.acc__q .plus::after{width:2px;height:14px}
.acc__item.open .plus{transform:rotate(135deg)}
.acc__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.acc__a p{padding:0 1.4rem 1.3rem;color:var(--muted)}

/* ---------------- Contact form ---------------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,52px);align-items:start}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--faint);margin-bottom:.45rem}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-size:.95rem;color:var(--ink);
  background:rgba(8,11,32,.6);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem;
  transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--cyan);
  box-shadow:0 0 0 3px rgba(79,233,255,.12)}
.field textarea{min-height:140px;resize:vertical}
.form-msg{display:none;border:1px solid rgba(98,242,194,.4);background:rgba(98,242,194,.08);
  border-radius:14px;padding:1.2rem 1.4rem;color:#d6f7ec}
.form-msg.show{display:block;animation:rise .5s ease}
.contact__info .row{display:flex;gap:.9rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line-soft)}
.contact__info .row:last-child{border-bottom:0}
.contact__info .row svg{width:22px;height:22px;color:var(--cyan);flex:none;margin-top:.15rem}
.contact__info .row b{display:block;font-family:var(--font-display);font-size:.95rem}
.contact__info .row span{color:var(--muted);font-size:.9rem}

/* ---------------- CTA strip ---------------- */
.cta-strip{border:1px solid var(--line);border-radius:26px;padding:clamp(30px,5vw,56px);
  text-align:center;position:relative;overflow:hidden;
  background:linear-gradient(135deg,rgba(79,233,255,.1),rgba(255,79,224,.1))}
.cta-strip h2{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1rem}
.cta-strip p{color:var(--muted);max-width:54ch;margin:0 auto 1.8rem}

/* ---------------- Footer ---------------- */
.footer{border-top:1px solid var(--line);margin-top:clamp(50px,8vw,90px);
  background:linear-gradient(180deg,transparent,rgba(6,8,22,.8))}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.4rem;
  padding-block:clamp(46px,6vw,72px)}
.footer__brand .brand{margin-bottom:1rem}
.footer__brand p{color:var(--muted);font-size:.9rem;max-width:34ch;margin-bottom:1.2rem}
.footer__col b{display:block;font-family:var(--font-display);font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--faint);margin-bottom:1rem}
.footer__col a{display:block;color:var(--muted);font-size:.92rem;padding:.32rem 0;transition:color .2s}
.footer__col a:hover{color:var(--cyan)}
.socials{display:flex;gap:.6rem;margin-bottom:1.3rem}
.socials a{width:40px;height:40px;border-radius:12px;border:1px solid var(--line);display:grid;
  place-items:center;color:var(--muted);transition:all .2s;background:var(--panel-glass)}
.socials a:hover{color:var(--cyan);border-color:var(--cyan);box-shadow:var(--glow-cyan)}
.socials svg{width:18px;height:18px}
.badges{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}
.badge{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-display);font-weight:700;
  font-size:.72rem;border-radius:10px;padding:.4rem .7rem;border:1px solid var(--line);color:var(--muted)}
.badge--age{color:var(--gold);border-color:rgba(255,209,102,.4);background:rgba(255,209,102,.06)}

.footer__bar{border-top:1px solid var(--line-soft);padding-block:1.4rem;display:flex;
  justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer__bar p{font-size:.82rem;color:var(--faint)}
.footer__bar nav{display:flex;gap:1.2rem;flex-wrap:wrap}
.footer__bar nav a{font-size:.82rem;color:var(--faint)}
.footer__bar nav a:hover{color:var(--ink)}
.disclaimer-foot{padding-bottom:2rem;font-size:.78rem;color:var(--faint);line-height:1.6;max-width:none}
.disclaimer-foot strong{color:var(--muted)}

/* ---------------- Cookie banner ---------------- */
.cookie{position:fixed;left:50%;transform:translateX(-50%) translateY(140%);bottom:18px;z-index:90;
  width:min(680px,calc(100% - 28px));border:1px solid var(--line);border-radius:20px;
  padding:1.3rem 1.4rem;background:rgba(10,13,36,.92);backdrop-filter:blur(16px);
  box-shadow:0 30px 80px rgba(2,4,16,.7);transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.cookie.show{transform:translateX(-50%) translateY(0)}
.cookie__head{display:flex;align-items:center;gap:.7rem;margin-bottom:.6rem}
.cookie__head svg{width:26px;height:26px;color:var(--gold)}
.cookie__head b{font-family:var(--font-display);font-size:1.05rem}
.cookie p{font-size:.88rem;color:var(--muted);margin-bottom:1rem}
.cookie p a{color:var(--cyan);text-decoration:underline}
.cookie__actions{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie .btn{padding:.7rem 1.3rem;font-size:.78rem}

/* expanded cookie prefs */
.cookie__prefs{display:none;margin:.4rem 0 1rem;border-top:1px solid var(--line-soft);padding-top:.9rem}
.cookie__prefs.show{display:block}
.pref{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 0}
.pref span{font-size:.85rem}
.pref small{display:block;color:var(--faint);font-size:.74rem}
.switch{position:relative;width:44px;height:24px;flex:none}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:rgba(120,140,220,.25);border-radius:999px;transition:.25s}
.slider::before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;border-radius:50%;
  background:var(--ink);transition:.25s}
.switch input:checked + .slider{background:linear-gradient(110deg,var(--cyan),var(--magenta))}
.switch input:checked + .slider::before{transform:translateX(20px)}
.switch input:disabled + .slider{opacity:.6}

/* ---------------- Responsive ---------------- */
@media (max-width:980px){
  .hero__grid,.about__hero,.contact{grid-template-columns:1fr}
  .orb{order:-1;max-width:320px}
  .legal{grid-template-columns:1fr}
  .toc{position:static}
  .grid-3,.values{grid-template-columns:1fr 1fr}
  .team{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .nav__links{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;
    gap:0;background:rgba(7,9,24,.98);backdrop-filter:blur(16px);padding:1rem var(--gut) 1.5rem;
    border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s ease;
    z-index:55}
  .nav.open .nav__links{transform:none}
  .nav__links a{padding:1rem .4rem;border-bottom:1px solid var(--line-soft);border-radius:0;font-size:1rem}
  .nav__toggle{display:flex}
  .grid-3,.grid-2,.values,.team,.footer__grid{grid-template-columns:1fr}
  .reel{height:240px}
  .tile{height:80px}.tile svg{width:48px;height:48px}
  .reels__line{height:80px}
  .controls{grid-template-columns:1fr}
  .hero__stats{gap:1.4rem}
  .footer__bar{flex-direction:column;align-items:flex-start}
}

/* ---------------- Motion preference ---------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .space-bg::before{animation:none}
  .orb{animation:none}
}
