/* =====================================================
   PushUp Synth — marketing site
   80s synthwave. Neon pink + cyan on deep navy/black.
   ===================================================== */

:root{
  /* core palette */
  --bg:           #05010f;
  --bg-2:         #0a0420;
  --bg-3:         #120831;
  --ink:          #f5edff;
  --ink-dim:      #c2b6dc;
  --ink-faint:    #8d83a8;

  /* neons */
  --pink:         #ff2ec4;
  --pink-2:       #ff5ad0;
  --pink-glow:    rgba(255,46,196,.55);
  --cyan:         #00f0ff;
  --cyan-2:       #6df6ff;
  --cyan-glow:    rgba(0,240,255,.55);
  --violet:       #a44bff;

  /* gradients */
  --grad-neon:    linear-gradient(95deg, #ff2ec4 0%, #ff5ad0 35%, #a44bff 70%, #00f0ff 100%);
  --grad-pink:    linear-gradient(135deg, #ff2ec4 0%, #ff5ad0 100%);
  --grad-cyan:    linear-gradient(135deg, #00f0ff 0%, #6df6ff 100%);

  /* type */
  --font-display: "Anton", "Bebas Neue", Impact, system-ui, sans-serif;
  --font-heavy:   "Anton", "Bebas Neue", Impact, system-ui, sans-serif;
  --font-body:    "Space Grotesk", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  --font-label:   "Space Grotesk", ui-sans-serif, system-ui, sans-serif;

  /* layout */
  --maxw:         1240px;
  --gutter:       clamp(20px, 4vw, 56px);
  --radius:       18px;
  --radius-lg:    28px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img,video{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; padding:0; margin:0; }

/* =====================================================
   Background layers (fixed, behind everything)
   ===================================================== */
.bg{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(164,75,255,.25), transparent 60%),
    radial-gradient(80% 60% at 90% 90%, rgba(0,240,255,.18), transparent 60%),
    radial-gradient(80% 60% at 5% 80%, rgba(255,46,196,.20), transparent 65%),
    linear-gradient(180deg, #05010f 0%, #08031c 40%, #05010f 100%);
}

.bg-image{
  position:absolute; inset:0;
  background:url("background2.jpg") center/cover no-repeat;
  opacity:.32;
  mix-blend-mode:screen;
  filter:saturate(1.15) contrast(1.05);
  mask-image:linear-gradient(180deg, #000 0%, #000 65%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 65%, transparent 100%);
}

/* perspective grid floor */
.bg-grid{
  position:absolute; left:50%; bottom:-10%;
  width:240vw; height:80vh;
  transform:translateX(-50%) perspective(700px) rotateX(62deg);
  transform-origin:50% 0%;
  background-image:
    linear-gradient(rgba(255,46,196,.45) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,240,255,.35) 1px, transparent 1px);
  background-size:5vw 5vw;
  mask-image:radial-gradient(closest-side at 50% 0%, #000 30%, transparent 78%);
  -webkit-mask-image:radial-gradient(closest-side at 50% 0%, #000 30%, transparent 78%);
  animation:gridScroll 14s linear infinite;
  opacity:.55;
  filter:drop-shadow(0 0 12px rgba(255,46,196,.4));
}
@keyframes gridScroll{
  from{ background-position:0 0, 0 0; }
  to  { background-position:0 5vw, 0 0; }
}

/* sun on horizon */
.bg-sun{
  position:absolute;
  left:50%; bottom:30vh;
  width:min(620px, 70vw); aspect-ratio:1;
  transform:translate(-50%, 50%);
  border-radius:50%;
  background:
    linear-gradient(180deg, #ff66dd 0%, #ff2ec4 45%, #a44bff 78%, #5b1e9a 100%);
  filter:blur(.4px) drop-shadow(0 0 80px rgba(255,46,196,.55));
  opacity:.55;
}
.bg-sun::after{
  /* horizontal slats */
  content:"";
  position:absolute; inset:0;
  border-radius:inherit;
  background:repeating-linear-gradient(
    180deg,
    transparent 0,
    transparent 14%,
    rgba(5,1,15,.95) 14%,
    rgba(5,1,15,.95) 18%
  );
  mask-image:linear-gradient(180deg, transparent 30%, #000 55%);
  -webkit-mask-image:linear-gradient(180deg, transparent 30%, #000 55%);
}

.bg-scan{
  position:absolute; inset:0;
  background:repeating-linear-gradient(
    180deg,
    rgba(255,255,255,.018) 0,
    rgba(255,255,255,.018) 1px,
    transparent 1px,
    transparent 3px
  );
  mix-blend-mode:overlay;
  pointer-events:none;
}

.bg-vignette{
  position:absolute; inset:0;
  background:radial-gradient(120% 90% at 50% 50%, transparent 50%, rgba(0,0,0,.55) 100%);
}

/* =====================================================
   Reveal animation
   ===================================================== */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1) var(--d, 0s),
             transform .9s cubic-bezier(.2,.7,.2,1) var(--d, 0s);
  will-change:opacity, transform;
}
.reveal.is-in{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .bg-grid{ animation:none; }
}

/* =====================================================
   Nav
   ===================================================== */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding:14px var(--gutter);
  background:linear-gradient(180deg, rgba(5,1,15,.85), rgba(5,1,15,.55) 70%, transparent);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
}
.nav-brand{
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-label);
  font-weight:700;
  letter-spacing:.04em;
  font-size:15px;
}
.nav-logo{ width:32px; height:32px; border-radius:8px; filter:drop-shadow(0 0 10px var(--pink-glow)); }
.nav-word{ color:var(--ink); }

.nav-links{
  margin-left:auto;
  display:flex; gap:22px;
  font-size:14px; color:var(--ink-dim);
}
.nav-links a{ position:relative; padding:6px 2px; transition:color .2s; }
.nav-links a:hover{ color:var(--ink); }
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--grad-neon);
  transform:scaleX(0); transform-origin:left;
  transition:transform .25s;
}
.nav-links a:hover::after{ transform:scaleX(1); }

@media (max-width: 880px){
  .nav-links{ display:none; }
  .nav{ justify-content:space-between; }
}

/* Language switcher */
.lang-switcher{ position:relative; }
.lang-switcher summary{
  list-style:none;
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.03);
  color:var(--ink-dim);
  font-family:var(--font-label);
  font-weight:600;
  font-size:12px;
  letter-spacing:.1em;
  cursor:pointer;
  transition:border-color .2s, color .2s, background .2s;
}
.lang-switcher summary::-webkit-details-marker{ display:none; }
.lang-switcher summary:hover{
  color:var(--ink);
  border-color:rgba(255,90,208,.4);
  background:rgba(255,90,208,.05);
}
.lang-glyph{ font-size:13px; }
.lang-switcher[open] summary{ color:var(--ink); border-color:rgba(255,90,208,.4); }
.lang-list{
  position:absolute; right:0; top:calc(100% + 8px);
  min-width:200px;
  padding:8px;
  border-radius:14px;
  background:linear-gradient(180deg, rgba(15,5,35,.97), rgba(8,3,24,.97));
  border:1px solid rgba(255,90,208,.25);
  box-shadow:0 20px 60px -10px rgba(0,0,0,.6), 0 0 40px -20px var(--pink-glow);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  z-index:60;
  max-height:70vh;
  overflow-y:auto;
}
.lang-list li{ list-style:none; }
.lang-list a{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:9px 12px;
  border-radius:8px;
  color:var(--ink-dim);
  transition:background .15s, color .15s;
}
.lang-list a:hover{
  color:var(--ink);
  background:rgba(255,90,208,.08);
}
.lang-list a.is-current{
  color:var(--pink);
  background:rgba(255,46,196,.08);
}
.lang-list-code{
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.18em;
  opacity:.7;
}
.lang-list-name{ font-size:14px; }
@media (max-width: 600px){
  .lang-list{ right:auto; left:0; }
}

/* =====================================================
   Buttons
   ===================================================== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 22px;
  border-radius:14px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:15px;
  letter-spacing:.01em;
  cursor:pointer;
  transition:transform .2s ease, box-shadow .25s ease, background .25s ease;
  border:1px solid transparent;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }

.btn-primary{
  color:#06010f;
  background:var(--grad-pink);
  box-shadow:
    0 0 0 1px rgba(255,90,208,.6),
    0 10px 40px -8px var(--pink-glow),
    0 0 80px -16px var(--pink-glow);
}
.btn-primary:hover{
  box-shadow:
    0 0 0 1px rgba(255,255,255,.4),
    0 14px 50px -8px var(--pink-glow),
    0 0 100px -10px var(--pink-glow);
}
.btn-app-icon{
  width:36px; height:36px;
  border-radius:9px;
  flex:0 0 auto;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(255,255,255,.18);
}
.btn-xl .btn-app-icon{ width:44px; height:44px; border-radius:11px; }
.btn-stack{ display:flex; flex-direction:column; line-height:1; gap:2px; text-align:left; }
.btn-small{ font-family:var(--font-label); font-weight:600; font-size:10px; letter-spacing:.14em; text-transform:uppercase; opacity:.85; }
.btn-big{ font-family:var(--font-label); font-weight:700; font-size:18px; letter-spacing:.005em; }

.btn-ghost{
  background:rgba(255,255,255,.04);
  color:var(--ink);
  border:1px solid rgba(255,255,255,.12);
}
.btn-ghost:hover{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,90,208,.45);
  box-shadow:0 0 30px -10px var(--pink-glow);
}

.btn-mini{
  padding:9px 14px;
  font-size:13px;
  border-radius:10px;
  color:#06010f;
  background:var(--grad-pink);
  box-shadow:0 0 24px -6px var(--pink-glow);
}
.btn-mini-icon{ font-size:10px; }

.btn-xl{ padding:18px 30px; border-radius:18px; }
.btn-xl .btn-big{ font-size:22px; letter-spacing:.005em; }

/* =====================================================
   Type
   ===================================================== */
.display{
  font-family:var(--font-display);
  font-weight:400;
  line-height:.9;
  letter-spacing:.005em;
  font-size:clamp(48px, 7.2vw, 104px);
  margin:0;
  text-transform:uppercase;
  white-space:nowrap;
  transform:skewX(-8deg); transform-origin:left;
}
.display .line{ display:block; width:max-content; }
.display .glow{
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  filter:drop-shadow(0 0 26px var(--pink-glow));
}
@media (max-width: 600px){
  .display{ font-size:clamp(34px, 10vw, 56px); }
}

/* CJK & long-string languages: allow breaking + shrink display */
html[lang="ja"] .display{
  font-size:clamp(34px, 5vw, 76px);
  white-space:normal;
  line-break:strict;
  letter-spacing:0;
}
html[lang="ja"] .display .line{ width:auto; }
html[lang="ja"] .finalcta .display{ font-size:clamp(40px, 7vw, 104px); }
html[lang="ja"] h2.skew{ font-size:clamp(28px, 4.4vw, 52px); }
html[lang="ja"] .backdown-title{ font-size:clamp(22px, 2.8vw, 36px); white-space:normal; }
html[lang="ja"] .backdown-line{ width:auto; }

h2{
  font-family:var(--font-heavy);
  font-weight:400;
  line-height:.95;
  font-size:clamp(34px, 5.4vw, 64px);
  letter-spacing:.005em;
  margin:0 0 10px;
  text-transform:uppercase;
}
h2.skew{ transform:skewX(-8deg); transform-origin:left; }
.pink{ color:var(--pink); text-shadow:0 0 18px var(--pink-glow); }
.cyan{ color:var(--cyan); text-shadow:0 0 18px var(--cyan-glow); }

h3{
  font-family:var(--font-body);
  font-weight:700;
  font-size:19px;
  margin:0 0 8px;
  letter-spacing:.01em;
}

.lede{
  font-size:clamp(16px, 1.4vw, 19px);
  color:var(--ink-dim);
  max-width:42em;
  margin:0;
}
.lede em{ font-style:normal; color:var(--cyan); }

.lede-goal{
  margin:18px 0 0;
  padding:14px 18px;
  border-left:2px solid var(--pink);
  background:linear-gradient(90deg, rgba(255,46,196,.10), transparent 70%);
  color:var(--ink);
  font-size:15px;
  line-height:1.5;
  max-width:42em;
  box-shadow:-12px 0 24px -16px var(--pink-glow);
}
.goal-label{
  display:inline-block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--pink);
  text-shadow:0 0 10px var(--pink-glow);
  margin-right:10px;
}
.eyebrow{
  display:inline-block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--cyan);
  text-shadow:0 0 12px var(--cyan-glow);
  padding:6px 12px;
  border:1px solid rgba(0,240,255,.35);
  border-radius:999px;
  margin-bottom:18px;
}

.section{
  position:relative;
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(80px, 12vw, 160px) var(--gutter);
}
.section-head{
  max-width:880px;
  margin-bottom:56px;
}
.section-sub{
  color:var(--ink-dim);
  margin-top:18px;
  font-size:17px;
  max-width:60ch;
}

/* =====================================================
   HERO
   ===================================================== */
.hero{
  position:relative;
  max-width:var(--maxw);
  margin:0 auto;
  padding:clamp(40px, 8vw, 90px) var(--gutter) clamp(60px, 10vw, 140px);
}
.hero-grid{
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, .85fr);
  grid-template-areas:
    "headline phone"
    "body     phone";
  column-gap:clamp(24px, 4vw, 60px);
  row-gap:24px;
  align-items:center;
}
.hero-headline{ grid-area:headline; align-self:end; }
.hero-phone   { grid-area:phone; }
.hero-body    { grid-area:body; align-self:start; }
@media (max-width: 980px){
  .hero-grid{
    grid-template-columns:1fr;
    grid-template-areas:
      "headline"
      "phone"
      "body";
  }
  .hero-headline, .hero-body{ align-self:auto; }
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns:1fr; }
}


.hero-copy h1{ margin-top:6px; }
.hero-copy .lede{ margin-top:22px; }

.cta-row{
  display:flex; flex-wrap:wrap; gap:14px;
  margin-top:34px;
}


.stat-strip{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:18px;
  margin-top:48px;
  padding-top:30px;
  border-top:1px solid rgba(255,255,255,.08);
}
.stat-strip li{
  display:flex; flex-direction:column; gap:4px;
}
.stat-strip strong{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(28px, 3.2vw, 40px);
  letter-spacing:.005em;
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 0 18px var(--pink-glow));
  transform:skewX(-8deg); transform-origin:left;
}
.stat-strip span{
  font-family:var(--font-label);
  font-weight:600;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-faint);
}

/* hero phones — two tilted */
.hero-phone{
  position:relative;
  display:flex; justify-content:center; align-items:center;
  gap:18px;
  min-height:640px;
  overflow:visible;
}
.hero-phone .phone-tilt-left,
.hero-phone .phone-tilt-right{
  flex:0 0 auto;
  width:290px;
  max-width:46vw;
}
.hero-phone .phone-tilt-left{
  transform:rotate(-6deg) translateX(40px);
}
.hero-phone .phone-tilt-right{
  transform:rotate(6deg) translateX(-10px) translateY(48px);
  z-index:2;
}
@media (max-width: 1180px){
  .hero-phone .phone-tilt-left,
  .hero-phone .phone-tilt-right{ width:270px; }
}
@media (max-width: 980px){
  .hero-phone{ min-height:520px; }
  .hero-phone .phone-tilt-left,
  .hero-phone .phone-tilt-right{ width:38%; max-width:none; }
}
@media (max-width: 520px){
  .hero-phone{ gap:14px; min-height:420px; }
  .hero-phone .phone-tilt-left,
  .hero-phone .phone-tilt-right{ width:42%; }
}

.phone{
  position:relative;
  width:300px; max-width:78%;
  aspect-ratio: 9 / 19.5;
  background:linear-gradient(150deg, #1a1424 0%, #0b0517 60%, #050111 100%);
  border-radius:46px;
  padding:11px;
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,.08),
    inset 0 0 0 3px rgba(0,0,0,.5),
    0 30px 80px -20px rgba(255,46,196,.45),
    0 50px 100px -30px rgba(0,240,255,.35),
    0 0 0 1px rgba(255,90,208,.18);
}
.phone-screen{
  position:relative;
  width:100%; height:100%;
  border-radius:34px;
  overflow:hidden;
  background:#000;
}
.phone-screen video{
  width:100%; height:100%;
  object-fit:cover;
}
.phone-glow{
  position:absolute; inset:-12% -8%;
  background:
    radial-gradient(40% 40% at 50% 50%, var(--pink-glow), transparent 70%),
    radial-gradient(60% 50% at 70% 80%, var(--cyan-glow), transparent 70%);
  filter:blur(40px);
  z-index:-1;
}
.phone-floor{
  position:absolute;
  bottom:-30px; left:50%; transform:translateX(-50%);
  width:70%; height:30px;
  background:radial-gradient(50% 100% at 50% 0%, rgba(255,46,196,.55), transparent 70%);
  filter:blur(8px);
}

/* =====================================================
   Feature grid
   ===================================================== */
.features-layout{
  display:grid;
  grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
  gap:clamp(30px, 5vw, 70px);
  align-items:center;
}
.features-phone{
  display:flex; align-items:center; justify-content:center;
}
.features-phone .phone{
  width:300px; max-width:100%;
  transform:rotate(-4deg);
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,.08),
    inset 0 0 0 3px rgba(0,0,0,.5),
    0 30px 80px -20px rgba(255,46,196,.45),
    0 50px 100px -30px rgba(0,240,255,.35),
    0 0 0 1px rgba(255,90,208,.18);
}
@media (max-width: 980px){
  .features-layout{ grid-template-columns:1fr; }
  .features-phone .phone{ width:240px; }
}

.feature-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:18px;
}
@media (max-width: 600px){ .feature-grid{ grid-template-columns:1fr; } }

.card{
  position:relative;
  padding:28px 24px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.07);
  overflow:hidden;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.card::before{
  content:""; position:absolute; inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:var(--grad-neon);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:0; transition:opacity .3s ease;
  pointer-events:none;
}
.card:hover{
  transform:translateY(-4px);
  border-color:transparent;
  box-shadow:0 30px 60px -25px var(--pink-glow);
}
.card:hover::before{ opacity:.85; }

.card-ico{
  width:46px; height:46px;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,46,196,.12);
  color:var(--pink);
  margin-bottom:18px;
  filter:drop-shadow(0 0 12px var(--pink-glow));
}
.card-ico svg{ width:24px; height:24px; }
.card p{ color:var(--ink-dim); margin:0; font-size:15px; }
.card em{ font-style:normal; color:var(--cyan); }

/* =====================================================
   How it works
   ===================================================== */
.section-how{}

.how-steps{ display:flex; flex-direction:column; gap:18px; }
.how-steps-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
  list-style:none;
  margin:0;
  padding:0;
}
@media (max-width: 720px){
  .how-steps-grid{ grid-template-columns:1fr; }
}

.step{
  position:relative;
  padding:26px 26px 26px 96px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.06);
  list-style:none;
  min-height:140px;
}
.step-num{
  position:absolute;
  left:22px; top:18px;
  font-family:var(--font-display);
  font-size:42px;
  letter-spacing:.01em;
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 0 14px var(--pink-glow));
  transform:skewX(-8deg); transform-origin:left;
}
.step p{ color:var(--ink-dim); margin:6px 0 0; font-size:15px; }
.step strong{ color:var(--ink); }
.step em{ font-style:normal; color:var(--cyan); font-weight:600; }

/* tilted phone variants (re-used by hero-phone) */
.phone-tilt-left{
  transform:rotate(-6deg) translateX(20px);
  width:240px;
}
.phone-tilt-right{
  transform:rotate(6deg) translateX(-20px) translateY(40px);
  width:240px;
  z-index:2;
}

/* =====================================================
   Coaches
   ===================================================== */
.coach-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:18px;
}
@media (max-width: 900px){ .coach-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width: 520px){ .coach-grid{ grid-template-columns:1fr; } }

.coach{
  padding:30px 24px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,46,196,.06), rgba(0,240,255,.04));
  border:1px solid rgba(255,255,255,.08);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.coach:hover{
  transform:translateY(-4px);
  border-color:rgba(255,90,208,.4);
  box-shadow:0 30px 60px -25px var(--pink-glow);
}
.coach-badge{
  display:inline-block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:13px;
  letter-spacing:.18em;
  padding:6px 12px;
  border-radius:8px;
  background:rgba(0,0,0,.4);
  color:var(--cyan);
  border:1px solid rgba(0,240,255,.35);
  margin-bottom:16px;
  text-shadow:0 0 10px var(--cyan-glow);
}
.coach-random .coach-badge{
  color:var(--pink);
  border-color:rgba(255,90,208,.45);
  text-shadow:0 0 10px var(--pink-glow);
}
.coach p{ color:var(--ink-dim); margin:0 0 16px; font-size:15px; }

.coach-play{
  display:inline-flex; align-items:center; gap:10px;
  margin:0 0 16px;
  padding:9px 14px 9px 11px;
  border-radius:999px;
  background:rgba(0,0,0,.45);
  border:1px solid rgba(0,240,255,.3);
  color:var(--cyan);
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
  transition:transform .2s, border-color .25s, box-shadow .25s, background .25s, color .2s;
}
.coach-play:hover{
  transform:translateY(-1px);
  border-color:var(--cyan);
  box-shadow:0 0 22px -4px var(--cyan-glow);
}
.coach-random .coach-play,
.coach.is-playing .coach-play{
  color:var(--pink);
  border-color:rgba(255,90,208,.5);
  box-shadow:0 0 22px -4px var(--pink-glow);
}

.coach-play-icon{
  position:relative;
  width:18px; height:18px;
  border-radius:50%;
  background:currentColor;
  flex:0 0 auto;
}
/* Play triangle */
.coach-play-icon::before,
.coach-play-icon::after{
  content:"";
  position:absolute;
  top:50%; left:50%;
  transform:translate(-45%, -50%);
  width:0; height:0;
  border-left:6px solid #06010f;
  border-top:4px solid transparent;
  border-bottom:4px solid transparent;
  transition:opacity .15s;
}
.coach-play-icon::after{ opacity:0; }
/* Pause bars when playing */
.coach.is-playing .coach-play-icon::before{ opacity:0; }
.coach.is-playing .coach-play-icon::after{
  opacity:1;
  border:none;
  width:7px; height:8px;
  background:
    linear-gradient(#06010f, #06010f) left/2px 100% no-repeat,
    linear-gradient(#06010f, #06010f) right/2px 100% no-repeat;
  transform:translate(-50%, -50%);
}

.coach-play-bars{
  display:none;
  align-items:flex-end;
  gap:2px;
  height:14px;
  margin-left:2px;
}
.coach.is-playing .coach-play-bars{ display:inline-flex; }
.coach-play-bars i{
  display:block;
  width:2px;
  background:currentColor;
  border-radius:1px;
  animation:bars 900ms ease-in-out infinite;
}
.coach-play-bars i:nth-child(1){ height:40%; animation-delay:-100ms; }
.coach-play-bars i:nth-child(2){ height:80%; animation-delay:-300ms; }
.coach-play-bars i:nth-child(3){ height:55%; animation-delay:-600ms; }
.coach-play-bars i:nth-child(4){ height:90%; animation-delay:-200ms; }
@keyframes bars{
  0%, 100%{ transform:scaleY(.35); }
  50%     { transform:scaleY(1);   }
}
@media (prefers-reduced-motion: reduce){
  .coach-play-bars i{ animation:none; }
}

.coach-tag{
  display:inline-block;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-faint);
}

/* =====================================================
   Music
   ===================================================== */
.section-music .section-head{ max-width:780px; }

.music-layout{
  display:grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  gap:clamp(30px, 5vw, 70px);
  align-items:center;
}
.music-phone{
  order:2;
  display:flex; align-items:center; justify-content:center;
}
.music-phone .phone{
  width:300px; max-width:100%;
  transform:rotate(4deg);
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,.08),
    inset 0 0 0 3px rgba(0,0,0,.5),
    0 30px 80px -20px rgba(0,240,255,.4),
    0 50px 100px -30px rgba(255,46,196,.35),
    0 0 0 1px rgba(0,240,255,.18);
}
@media (max-width: 980px){
  .music-layout{ grid-template-columns:1fr; }
  .music-phone .phone{ width:240px; }
  .music-phone{ order:-1; }
}

.music-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
@media (max-width: 800px){ .music-grid{ grid-template-columns:1fr; } }

.music-block{
  position:relative;
  padding:30px;
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}
.music-block::after{
  content:""; position:absolute; inset:-40% -40% auto auto;
  width:60%; aspect-ratio:1;
  background:radial-gradient(closest-side, var(--pink-glow), transparent 70%);
  filter:blur(20px);
  pointer-events:none;
}
.music-block:nth-child(2)::after{
  background:radial-gradient(closest-side, var(--cyan-glow), transparent 70%);
}
.music-h{
  font-family:var(--font-label);
  font-weight:700;
  font-size:13px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-faint);
  margin:0 0 22px;
}

.track-list{ display:flex; flex-direction:column; gap:12px; position:relative; z-index:1; }
.track-list li{
  display:flex; align-items:center; gap:14px;
  padding:12px 14px;
  border-radius:12px;
  background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.05);
  font-size:15px;
  font-weight:500;
}
.track-dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--pink);
  box-shadow:0 0 10px var(--pink-glow);
}
.music-block:nth-child(2) .track-dot{ background:var(--cyan); box-shadow:0 0 10px var(--cyan-glow); }

.track-list-unlock li{
  justify-content:space-between;
}
.track-name{ font-weight:600; }
.track-tier{
  font-family:var(--font-label);
  font-weight:600;
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--cyan);
  text-shadow:0 0 8px var(--cyan-glow);
}

/* =====================================================
   Levels / tiers
   ===================================================== */
.levels-layout{
  display:grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(0, 1fr);
  gap:clamp(20px, 3vw, 36px);
  align-items:stretch;
}
@media (max-width: 980px){
  .levels-layout{ grid-template-columns:1fr; }
}

.tier-ladder{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:10px;
  align-content:start;
}
.tier-final{ grid-column:1 / -1; }
@media (max-width: 1100px){ .tier-ladder{ grid-template-columns:repeat(3,minmax(0,1fr)); } }
@media (max-width: 600px){ .tier-ladder{ grid-template-columns:repeat(2,minmax(0,1fr)); } }

.tier{
  position:relative;
  padding:14px 14px 14px 18px;
  border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.07);
  display:flex; align-items:center;
  overflow:hidden;
  transition:transform .25s, border-color .25s;
}
.tier:hover{ transform:translateY(-3px); border-color:rgba(255,90,208,.4); }
.tier::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:var(--pink);
  filter:drop-shadow(0 0 6px var(--pink-glow));
  opacity:.6;
}
.tier:nth-child(1)::before{ background:#3a90ff; }
.tier:nth-child(2)::before{ background:#5870ff; }
.tier:nth-child(3)::before{ background:#7d5cff; }
.tier:nth-child(4)::before{ background:#a44bff; }
.tier:nth-child(5)::before{ background:#c43aff; }
.tier:nth-child(6)::before{ background:#e02af0; }
.tier:nth-child(7)::before{ background:#ff2ec4; }
.tier:nth-child(8)::before{ background:#ff3aa4; }
.tier:nth-child(9)::before{ background:#ff4d77; }
.tier:nth-child(10)::before{ background:#ff7053; }
.tier:nth-child(11)::before{ background:#ffa040; }
.tier:nth-child(12)::before{ background:#ffd24a; }
.tier:nth-child(13)::before{
  background:linear-gradient(180deg, #ffe06a, #ff2ec4 50%, #00f0ff);
}

/* Sequential fill animation — each tier glows in turn, 2s each, 26s loop */
.tier{
  --tier-color: var(--pink);
}
.tier:nth-child(1)  { --tier-color: #3a90ff; }
.tier:nth-child(2)  { --tier-color: #5870ff; }
.tier:nth-child(3)  { --tier-color: #7d5cff; }
.tier:nth-child(4)  { --tier-color: #a44bff; }
.tier:nth-child(5)  { --tier-color: #c43aff; }
.tier:nth-child(6)  { --tier-color: #e02af0; }
.tier:nth-child(7)  { --tier-color: #ff2ec4; }
.tier:nth-child(8)  { --tier-color: #ff3aa4; }
.tier:nth-child(9)  { --tier-color: #ff4d77; }
.tier:nth-child(10) { --tier-color: #ff7053; }
.tier:nth-child(11) { --tier-color: #ffa040; }
.tier:nth-child(12) { --tier-color: #ffd24a; }

.tier::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,
    color-mix(in oklab, var(--tier-color) 28%, transparent),
    color-mix(in oklab, var(--tier-color) 14%, transparent) 70%,
    transparent);
  transform:scaleX(0);
  transform-origin:left;
  pointer-events:none;
  z-index:0;
}
.tier:nth-child(13)::after{
  background:linear-gradient(90deg,
    rgba(255,46,196,.35),
    rgba(164,75,255,.25) 50%,
    rgba(0,240,255,.30));
}

/* Animation kicks off when the ladder scrolls into view */
.tier-ladder.is-in .tier::after{
  animation:tier-fill 2s cubic-bezier(.4,.2,.2,1) forwards;
}
.tier-ladder.is-in .tier:nth-child(1)::after  { animation-delay:0s; }
.tier-ladder.is-in .tier:nth-child(2)::after  { animation-delay:2s; }
.tier-ladder.is-in .tier:nth-child(3)::after  { animation-delay:4s; }
.tier-ladder.is-in .tier:nth-child(4)::after  { animation-delay:6s; }
.tier-ladder.is-in .tier:nth-child(5)::after  { animation-delay:8s; }
.tier-ladder.is-in .tier:nth-child(6)::after  { animation-delay:10s; }
.tier-ladder.is-in .tier:nth-child(7)::after  { animation-delay:12s; }
.tier-ladder.is-in .tier:nth-child(8)::after  { animation-delay:14s; }
.tier-ladder.is-in .tier:nth-child(9)::after  { animation-delay:16s; }
.tier-ladder.is-in .tier:nth-child(10)::after { animation-delay:18s; }
.tier-ladder.is-in .tier:nth-child(11)::after { animation-delay:20s; }
.tier-ladder.is-in .tier:nth-child(12)::after { animation-delay:22s; }
.tier-ladder.is-in .tier:nth-child(13)::after { animation-delay:24s; }

@keyframes tier-fill{
  from { transform:scaleX(0); }
  to   { transform:scaleX(1); }
}

.tier-name{ position:relative; z-index:1; }

@media (prefers-reduced-motion: reduce){
  .tier-ladder.is-in .tier::after{ animation:none; transform:scaleX(1); }
}

.tier-num{
  font-family:var(--font-label);
  font-weight:700;
  font-size:12px;
  letter-spacing:.22em;
  color:var(--ink-faint);
}
.tier-name{
  font-family:var(--font-heavy);
  font-weight:400;
  font-size:18px;
  letter-spacing:.01em;
  text-transform:uppercase;
  transform:skewX(-8deg);
}
.tier-range{
  font-size:12px;
  color:var(--ink-dim);
  font-variant-numeric:tabular-nums;
}
.tier-final{
  background:linear-gradient(180deg, rgba(255,46,196,.18), rgba(0,240,255,.08));
  border-color:rgba(255,90,208,.35);
  box-shadow:0 0 30px -8px var(--pink-glow);
}
.tier-final .tier-name{
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

.backdown{
  position:relative;
  margin:0;
  padding:36px clamp(22px, 3vw, 32px);
  border-radius:var(--radius-lg);
  text-align:center;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:
    linear-gradient(180deg, rgba(255,46,196,.05), rgba(0,240,255,.03)),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent);
  border:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.backdown::before{
  content:"";
  position:absolute; left:0; right:0; top:0;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--pink) 50%, transparent);
  filter:drop-shadow(0 0 10px var(--pink-glow));
}
.backdown::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--cyan) 50%, transparent);
  filter:drop-shadow(0 0 10px var(--cyan-glow));
  opacity:.7;
}
.backdown-eyebrow{
  display:inline-block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-faint);
  margin-bottom:22px;
}
.backdown-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(28px, 3.4vw, 44px);
  line-height:.92;
  letter-spacing:.005em;
  text-transform:uppercase;
  margin:0 0 18px;
  transform:skewX(-8deg);
}
.backdown-line{ display:block; }
.backdown-line-pink{
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  filter:drop-shadow(0 0 18px var(--pink-glow));
}
.backdown-text{
  margin:0 auto;
  max-width:32ch;
  color:var(--ink-dim);
  font-size:14px;
  line-height:1.55;
}
.pill{
  font-family:var(--font-label);
  font-weight:700;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  padding:3px 8px;
  border:1px solid rgba(0,240,255,.4);
  border-radius:999px;
  color:var(--cyan);
  text-shadow:0 0 8px var(--cyan-glow);
}

/* =====================================================
   Stats section
   ===================================================== */
.section-stats{}
.stats-grid{
  display:grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap:clamp(30px, 5vw, 80px);
  align-items:center;
}
@media (max-width: 980px){
  .stats-grid{ grid-template-columns:1fr; }
  .stats-phone{ order:-1; }
}
.stats-copy .eyebrow{ margin-bottom:18px; }
.stats-copy .lede{ margin-top:14px; }
.stats-list{ margin-top:24px; display:flex; flex-direction:column; gap:10px; }
.stats-list li{
  padding-left:24px; position:relative;
  font-size:15px; color:var(--ink-dim);
}
.stats-list li::before{
  content:""; position:absolute; left:0; top:11px;
  width:10px; height:1px; background:var(--pink);
  box-shadow:0 0 6px var(--pink-glow);
}
.stats-list strong{ color:var(--ink); font-weight:600; }
.stats-list em{ font-style:normal; color:var(--cyan); }

.stats-phone{
  display:flex; justify-content:center; align-items:center;
  min-height:520px;
}
.stats-phone .phone{ transform:rotate(-3deg); }

/* =====================================================
   FAQ
   ===================================================== */
.faq{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
  align-items:start;
}
@media (max-width: 760px){
  .faq{ grid-template-columns:1fr; }
}
.faq-item{
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.07);
  overflow:hidden;
  transition:border-color .25s;
}
.faq-item[open]{ border-color:rgba(255,90,208,.35); }
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:20px 56px 20px 22px;
  position:relative;
  font-weight:600;
  font-size:16px;
  color:var(--ink);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:24px; top:50%;
  transform:translateY(-50%);
  font-family:var(--font-body);
  font-weight:300;
  font-size:26px;
  color:var(--pink);
  text-shadow:0 0 10px var(--pink-glow);
  transition:transform .25s, color .25s;
}
.faq-item[open] summary::after{ content:"−"; color:var(--cyan); text-shadow:0 0 10px var(--cyan-glow); }
.faq-item p{
  padding:0 22px 22px;
  color:var(--ink-dim);
  margin:0;
  font-size:15px;
}
.faq-item em{ font-style:normal; color:var(--cyan); }

/* =====================================================
   Final CTA — billboard finale
   ===================================================== */
.section-finalcta{
  position:relative;
  text-align:center;
  padding-top:clamp(120px, 18vw, 220px);
  padding-bottom:clamp(120px, 18vw, 220px);
  overflow:hidden;
}
.section-finalcta::before{
  content:"";
  position:absolute; left:50%; top:50%;
  width:140%; max-width:1400px; aspect-ratio:1;
  transform:translate(-50%, -50%);
  background:
    radial-gradient(closest-side, var(--pink-glow), transparent 60%),
    radial-gradient(closest-side at 70% 60%, var(--cyan-glow), transparent 65%);
  filter:blur(40px);
  opacity:.5;
  pointer-events:none;
  z-index:-1;
}
.section-finalcta::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--pink) 30%, var(--cyan) 70%, transparent);
  filter:drop-shadow(0 0 12px var(--pink-glow));
  opacity:.6;
}

.finalcta{
  display:flex; flex-direction:column; align-items:center; gap:34px;
  position:relative;
}
.finalcta .display{
  text-align:center;
  font-size:clamp(54px, 9.4vw, 132px);
  line-height:.88;
  transform:skewX(-8deg);
}
.finalcta .display .glow{
  filter:drop-shadow(0 0 36px var(--pink-glow)) drop-shadow(0 0 80px var(--pink-glow));
}
@media (max-width: 600px){
  .finalcta .display{ font-size:clamp(40px, 11.5vw, 72px); }
}

.finalcta .lede{
  max-width:32em;
  text-align:center;
  font-size:clamp(16px, 1.6vw, 22px);
}

.finalcta .btn-primary{
  margin-top:16px;
  padding:24px 40px;
  border-radius:24px;
  font-size:18px;
  box-shadow:
    0 0 0 1px rgba(255,90,208,.6),
    0 20px 80px -10px var(--pink-glow),
    0 0 140px -20px var(--pink-glow);
}
.finalcta .btn-primary .btn-app-icon{ width:54px; height:54px; border-radius:13px; }
.finalcta .btn-primary .btn-big{ font-size:26px; }
.finalcta .btn-primary .btn-small{ font-size:11px; }

/* =====================================================
   Footer
   ===================================================== */
.footer{
  position:relative;
  margin-top:60px;
  padding:64px var(--gutter) 32px;
  border-top:1px solid rgba(255,255,255,.06);
  background:
    linear-gradient(180deg, transparent 0%, rgba(5,1,15,.85) 50%);
}
.footer-grid{
  max-width:var(--maxw);
  margin:0 auto;
  display:flex;
  justify-content:center;
  text-align:center;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer-contact{ max-width:520px; }
.footer-contact .footer-mail{ display:inline-block; margin-bottom:12px; }
.footer-blurb{ margin-left:auto; margin-right:auto; }
.footer-privacy{
  display:inline-block;
  margin-top:14px;
  font-size:12px;
  letter-spacing:.06em;
  color:var(--ink-faint);
  border-bottom:1px solid rgba(255,255,255,.12);
  padding-bottom:2px;
  transition:color .2s, border-color .2s;
}
.footer-privacy:hover{ color:var(--pink); border-color:var(--pink); }

.footer-brand{ display:flex; align-items:center; gap:14px; }
.footer-logo{
  width:54px; height:54px; border-radius:14px;
  box-shadow:0 0 30px -6px var(--pink-glow);
}
.footer-product{ font-family:var(--font-label); font-weight:700; font-size:20px; letter-spacing:.01em; }
.footer-tagline{ font-family:var(--font-label); font-weight:600; font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--cyan); margin-top:6px; }

.footer-links{ display:flex; flex-direction:column; gap:10px; }
.footer-links a{ color:var(--ink-dim); font-size:14px; transition:color .2s; }
.footer-links a:hover{ color:var(--pink); }

.footer-label{
  display:block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.24em;
  color:var(--ink-faint);
  text-transform:uppercase;
  margin-bottom:8px;
}
.footer-mail{
  display:inline-block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:18px;
  letter-spacing:.005em;
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  margin-bottom:12px;
}
.footer-blurb{ color:var(--ink-dim); font-size:14px; margin:0; max-width:38ch; }

.footer-bottom{
  max-width:var(--maxw);
  margin:0 auto;
  padding-top:24px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px;
  text-align:center;
  font-size:12px;
  color:var(--ink-faint);
}
.dissolve{
  display:inline-flex; align-items:center;
  transition:opacity .2s;
}
.dissolve:hover{ opacity:.8; }
.dissolve-logo{
  height:36px;
  width:auto;
  filter:drop-shadow(0 0 12px rgba(255,255,255,.3));
}

/* =====================================================
   Small device tweaks
   ===================================================== */
@media (max-width: 520px){
  .stat-strip{ grid-template-columns:repeat(2,1fr); }
  .hero-logo{ width:60px; height:60px; }
  .hero-product{ font-size:20px; }
}

/* =====================================================
   Privacy / long-form document page
   ===================================================== */
.doc{
  position:relative;
  max-width:840px;
  margin:0 auto;
  padding:clamp(60px, 9vw, 100px) var(--gutter) 80px;
  font-size:16px;
  line-height:1.65;
}
.doc-head{
  margin-bottom:36px;
  padding-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.doc-head .eyebrow{ margin-bottom:14px; }
.doc h1{
  font-family:var(--font-heavy);
  font-weight:400;
  font-size:clamp(32px, 4.6vw, 52px);
  line-height:1;
  letter-spacing:.005em;
  margin:0 0 12px;
  text-transform:uppercase;
  transform:skewX(-6deg); transform-origin:left;
}
.doc h1 .accent{
  background:var(--grad-neon);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  filter:drop-shadow(0 0 18px var(--pink-glow));
}
.doc h2{
  font-family:var(--font-label);
  font-weight:700;
  font-size:20px;
  letter-spacing:.005em;
  text-transform:none;
  transform:none;
  margin:42px 0 12px;
  color:var(--ink);
}
.doc h2::before{
  content:"";
  display:inline-block;
  width:14px; height:1px;
  background:var(--pink);
  box-shadow:0 0 6px var(--pink-glow);
  vertical-align:middle;
  margin-right:14px;
  position:relative; top:-3px;
}
.doc h3{
  font-family:var(--font-body);
  font-weight:600;
  font-size:16px;
  margin:24px 0 8px;
  color:var(--cyan);
  text-shadow:0 0 10px var(--cyan-glow);
}
.doc p{ color:var(--ink-dim); margin:0 0 14px; }
.doc strong{ color:var(--ink); font-weight:600; }
.doc ul{ margin:0 0 18px 0; padding:0; }
.doc li{
  list-style:none;
  position:relative;
  padding:4px 0 4px 22px;
  color:var(--ink-dim);
}
.doc li::before{
  content:"";
  position:absolute;
  left:0; top:14px;
  width:10px; height:1px;
  background:var(--pink);
  box-shadow:0 0 6px var(--pink-glow);
}
.doc a{
  color:var(--cyan);
  text-shadow:0 0 8px var(--cyan-glow);
  border-bottom:1px solid rgba(0,240,255,.35);
  transition:border-color .2s;
}
.doc a:hover{ border-color:var(--cyan); }
.doc-meta{
  display:inline-block;
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-faint);
  padding:6px 12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
}
.doc-card{
  margin:24px 0 28px;
  padding:22px 26px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,46,196,.08), rgba(0,240,255,.05));
  border:1px solid rgba(255,90,208,.25);
  box-shadow:0 30px 80px -30px var(--pink-glow);
}
.doc-card p{ margin-bottom:8px; color:var(--ink); font-weight:500; }
.doc-card ul{ margin:0; }
.doc-card li{ color:var(--ink-dim); }
.doc .back-link{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-label);
  font-weight:700;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-faint);
  border:none;
  margin-bottom:36px;
  transition:color .2s;
}
.doc .back-link:hover{ color:var(--pink); border:none; }

/* =====================================================
   Consent banner
   ===================================================== */
.consent-banner{
  position:fixed;
  left:16px; right:16px; bottom:16px;
  z-index:100;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .35s ease, transform .35s ease;
  pointer-events:none;
}
.consent-banner.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.consent-inner{
  max-width:1000px;
  margin:0 auto;
  padding:16px 20px;
  display:flex; align-items:center; gap:18px;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(15,5,35,.96), rgba(8,3,24,.96));
  border:1px solid rgba(255,90,208,.3);
  box-shadow:
    0 20px 60px -10px rgba(0,0,0,.6),
    0 0 60px -20px var(--pink-glow),
    inset 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
}
.consent-text{
  flex:1;
  margin:0;
  color:var(--ink-dim);
  font-size:14px;
  line-height:1.5;
}
.consent-text strong{ color:var(--ink); font-weight:600; }
.consent-link{
  color:var(--cyan);
  border-bottom:1px solid rgba(0,240,255,.35);
  margin-left:6px;
  transition:border-color .2s;
}
.consent-link:hover{ border-color:var(--cyan); }
.consent-actions{
  display:flex; gap:10px;
  flex:0 0 auto;
}
.consent-btn{
  font-family:var(--font-label);
  font-weight:700;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  padding:11px 18px;
  border-radius:10px;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .15s, box-shadow .25s, background .25s, border-color .25s, color .2s;
  white-space:nowrap;
}
.consent-btn:hover{ transform:translateY(-1px); }
.consent-btn-decline{
  background:transparent;
  color:var(--ink-dim);
  border-color:rgba(255,255,255,.15);
}
.consent-btn-decline:hover{
  color:var(--ink);
  border-color:rgba(255,255,255,.3);
}
.consent-btn-accept{
  color:#06010f;
  background:var(--grad-pink);
  box-shadow:0 0 24px -6px var(--pink-glow);
}
.consent-btn-accept:hover{
  box-shadow:0 0 32px -4px var(--pink-glow);
}
@media (max-width: 700px){
  .consent-inner{ flex-direction:column; align-items:stretch; gap:14px; padding:18px; }
  .consent-actions{ justify-content:flex-end; }
}

