/* ===== Reset & base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  color:#fff;background:#0B0628;overflow-x:hidden;
  font-feature-settings:'cv11','ss01';
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

:root{
  --deep:#0B0628;
  --deep2:#1B0B47;
  --plum:#2A0F5C;
  --violet:#7C3AED;
  --lilac:#A78BFA;
  --orchid:#C084FC;
  --hi:#FFFFFF;
  --mute:rgba(255,255,255,0.65);
  --line:rgba(255,255,255,0.1);
  --card:rgba(255,255,255,0.04);
  --max:1200px;
}

/* ===== Animated gradient mesh background ===== */
.mesh{
  position:fixed;inset:-20vh -10vw;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 60vw 50vh at 15% 10%, rgba(167,139,250,0.45) 0%, transparent 60%),
    radial-gradient(ellipse 70vw 60vh at 110% 20%, rgba(192,132,252,0.35) 0%, transparent 60%),
    radial-gradient(ellipse 80vw 70vh at 80% 110%, rgba(67,56,202,0.55) 0%, transparent 60%),
    radial-gradient(ellipse 60vw 50vh at -10% 90%, rgba(124,58,237,0.4) 0%, transparent 60%),
    linear-gradient(180deg,#0B0628 0%, #1B0B47 50%, #0B0628 100%);
  filter:blur(40px);
  animation:meshShift 22s ease-in-out infinite alternate;
}
@keyframes meshShift{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(2%,-1%,0) scale(1.05)}
  100%{transform:translate3d(-1%,2%,0) scale(1.02)}
}
.grain{
  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='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}

/* ===== Layout ===== */
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
section{padding:120px 0;position:relative}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  background:rgba(11,6,40,0.5);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(11,6,40,0.75)}
.nav-logo{height:32px;width:auto}
.nav-links{display:flex;gap:32px;align-items:center;margin-left:auto}
.nav-links a{font-size:14px;font-weight:500;color:var(--mute);transition:color .2s ease}
.nav-links a:hover{color:#fff}
.nav-cta{
  padding:10px 18px;border-radius:999px;font-size:14px;font-weight:600;
  background:#fff;color:var(--deep2);
  margin-left:24px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(255,255,255,0.18)}
@media (max-width:720px){.nav-links{display:none}}

/* ===== Hero ===== */
.hero{padding:160px 0 100px;position:relative}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
}
@media (max-width:920px){.hero-grid{grid-template-columns:1fr;gap:48px}}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;
  background:rgba(167,139,250,0.12);
  border:1px solid rgba(167,139,250,0.3);
  font-size:13px;font-weight:600;letter-spacing:.04em;color:#E9D5FF;
  margin-bottom:24px;
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#86EFAC;box-shadow:0 0 12px #86EFAC;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

h1.title{
  font-size:clamp(48px,7vw,96px);font-weight:800;line-height:1;
  letter-spacing:-0.04em;text-wrap:balance;
}
h1 .gradient{
  background:linear-gradient(135deg,#fff 0%,#C084FC 50%,#A78BFA 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  font-size:clamp(18px,1.6vw,22px);font-weight:400;line-height:1.5;
  color:var(--mute);margin-top:24px;max-width:560px;text-wrap:pretty;
}

.cta-row{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.btn-store{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 22px;border-radius:16px;
  background:#fff;color:#0B0628;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease;
  position:relative;overflow:hidden;
}
.btn-store .icon{width:28px;height:28px;flex:0 0 28px}
.btn-store .lbl{display:flex;flex-direction:column;line-height:1.1;align-items:flex-start}
.btn-store .lbl small{font-size:11px;font-weight:500;opacity:.65;letter-spacing:.02em}
.btn-store .lbl b{font-size:18px;font-weight:700;letter-spacing:-0.01em}
.btn-store:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 24px 48px rgba(255,255,255,0.18)}
.btn-store::after{
  content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(192,132,252,0.5) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform .8s ease;
}
.btn-store:hover::after{transform:translateX(100%)}

.btn-soon{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 22px;border-radius:16px;
  background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.85);
  border:1px solid var(--line);
  cursor:default;
}
.btn-soon .icon{width:28px;height:28px;flex:0 0 28px;opacity:.85}
.btn-soon .lbl{display:flex;flex-direction:column;line-height:1.1;align-items:flex-start}
.btn-soon .lbl small{font-size:11px;font-weight:500;opacity:.65}
.btn-soon .lbl b{font-size:18px;font-weight:700;letter-spacing:-0.01em}
.badge{
  margin-left:6px;padding:3px 8px;border-radius:6px;
  background:linear-gradient(135deg,#FBBF24,#F59E0B);
  color:#1B0B47;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
}

.hero-meta{display:flex;gap:32px;margin-top:40px;flex-wrap:wrap;color:var(--mute);font-size:13px;font-weight:500}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta svg{width:16px;height:16px;flex:0 0 16px}

/* Hero phone */
.phone-stage{
  position:relative;display:flex;justify-content:center;perspective:1500px;
}
.phone-stage::before{display:none}
.phone-tilt{
  transform-style:preserve-3d;
  transition:transform .3s cubic-bezier(.2,.8,.2,1);
  will-change:transform;
}

/* Phone frame */
.phone{
  width:300px;aspect-ratio:300/650;border-radius:40px;
  padding:8px;position:relative;
  background:linear-gradient(180deg,#23232A,#0a0a0d);
  box-shadow:
    0 36px 80px rgba(0,0,0,0.55),
    0 0 0 1px rgba(255,255,255,0.06),
    inset 0 1px 0 rgba(255,255,255,0.1);
}
.phone::before{
  content:"";position:absolute;left:50%;top:14px;transform:translateX(-50%);
  width:90px;height:24px;background:#0a0a0d;border-radius:14px;z-index:2;
}
.phone-screen{
  width:100%;height:100%;border-radius:32px;overflow:hidden;background:#000;
  position:relative;
}
.phone-screen img{width:100%;height:100%;object-fit:cover;display:block}
.phone-glare{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,rgba(255,255,255,0.08) 0%,transparent 30%,transparent 70%,rgba(255,255,255,0.05) 100%);
}

@media (max-width:920px){
  .phone{width:260px}
}

.hero-composite{
  width:100%;max-width:720px;height:auto;display:block;
  margin:-40px -40px -40px 0;
  will-change:transform;
}
@media (max-width:920px){
  .hero-composite{max-width:520px;margin:0 auto}
}

/* ===== Section headers ===== */
.section-head{text-align:center;max-width:680px;margin:0 auto 64px}
.section-eyebrow{
  font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--orchid);margin-bottom:14px;
}
h2.section-title{
  font-size:clamp(36px,5vw,64px);font-weight:800;line-height:1.05;letter-spacing:-0.035em;
}
.section-sub{
  margin-top:20px;font-size:18px;color:var(--mute);line-height:1.5;text-wrap:pretty;
}

/* ===== Features grid ===== */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:880px){.features{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.features{grid-template-columns:1fr}}

.feat{
  position:relative;padding:32px;border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02));
  border:1px solid var(--line);
  overflow:hidden;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), border-color .3s ease;
}
.feat::before{
  content:"";position:absolute;inset:0;border-radius:24px;
  background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),rgba(167,139,250,0.18),transparent 50%);
  opacity:0;transition:opacity .4s ease;pointer-events:none;
}
.feat:hover{transform:translateY(-4px);border-color:rgba(167,139,250,0.4)}
.feat:hover::before{opacity:1}

.feat-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,var(--orchid),var(--violet));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 28px rgba(124,58,237,0.4);
  margin-bottom:24px;position:relative;z-index:1;
}
.feat-icon svg{width:28px;height:28px;color:#fff}
.feat h3{font-size:20px;font-weight:700;letter-spacing:-0.01em;margin-bottom:10px;position:relative;z-index:1}
.feat p{color:var(--mute);font-size:15px;line-height:1.55;position:relative;z-index:1}

/* ===== Screenshots carousel ===== */
.shots{position:relative;overflow:hidden;padding:80px 0}
.shots-track{
  display:flex;gap:32px;align-items:center;
  width:max-content;
  animation:scroll 60s linear infinite;
}
.shots:hover .shots-track{animation-play-state:paused}
@keyframes scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.shot-card{
  flex:0 0 280px;aspect-ratio:280/600;
  border-radius:32px;overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.06);
  position:relative;background:#000;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);
}
.shot-card img{width:100%;height:100%;object-fit:cover}
.shot-card:hover{transform:translateY(-8px) scale(1.02)}

/* fade edges */
.shots::before,.shots::after{
  content:"";position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none;
}
.shots::before{left:0;background:linear-gradient(90deg,var(--deep),transparent)}
.shots::after{right:0;background:linear-gradient(-90deg,var(--deep),transparent)}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
@media (max-width:760px){.steps{grid-template-columns:1fr}}
.step{
  position:relative;padding:36px 28px;border-radius:24px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--line);
  counter-increment:s;
}
.step::before{
  content:"0" counter(s);
  position:absolute;top:24px;right:28px;
  font-size:48px;font-weight:800;letter-spacing:-0.04em;
  background:linear-gradient(135deg,rgba(192,132,252,0.4),rgba(124,58,237,0.1));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.step h3{font-size:22px;font-weight:700;letter-spacing:-0.015em;margin-bottom:12px;max-width:14ch}
.step p{color:var(--mute);font-size:15px;line-height:1.55}

/* ===== CTA banner ===== */
.cta-banner{
  position:relative;border-radius:32px;overflow:hidden;
  padding:80px 48px;text-align:center;
  background:
    radial-gradient(ellipse 60% 80% at 50% 0%,rgba(192,132,252,0.45),transparent 70%),
    linear-gradient(135deg,#1B0B47 0%,#3A0E78 100%);
  border:1px solid rgba(167,139,250,0.25);
}
.cta-banner h2{font-size:clamp(32px,4vw,52px);font-weight:800;letter-spacing:-0.03em;line-height:1.1;text-wrap:balance}
.cta-banner p{margin-top:18px;color:rgba(255,255,255,0.78);font-size:18px;max-width:520px;margin-left:auto;margin-right:auto}
.cta-banner .cta-row{justify-content:center;margin-top:36px}

/* ===== Footer ===== */
footer{
  border-top:1px solid var(--line);padding:42px 0;margin-top:80px;
}
.foot-row{
  display:flex;align-items:center;gap:10px;color:var(--mute);font-size:14px;flex-wrap:wrap;
}
.foot-brand{height:28px;width:auto;background:transparent}
.foot-links{display:flex;gap:24px;margin-left:auto}
.foot-links a{color:var(--mute);font-size:13px;transition:color .2s ease}
.foot-links a:hover{color:#fff}

/* ===== Reveal animations ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}

/* ===== Selection ===== */
::selection{background:rgba(192,132,252,0.45);color:#fff}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .shots-track{animation:none}
}
