/* ===================== TOKENS ===================== */
:root{
  --bg:#04050f;
  --bg-2:#080b1f;
  --panel:rgba(16,21,46,.72);
  --panel-2:rgba(11,15,34,.85);
  --line:rgba(125,160,255,.16);
  --line-bright:rgba(120,200,255,.42);
  --text:#ffffff;
  --muted:#aeb9dd;
  --muted-2:#8590b8;

  --cyan:#2ad4ff;
  --purple:#b15cff;
  --gold:#ffc83d;
  --orange:#ff9c22;
  --red:#ff6259;
  --green:#37d98a;
  --magenta:#ff5dbd;

  --maxw:1240px;
  --r:18px;
  --r-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --head:"Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  --body:"Manrope", ui-sans-serif, system-ui, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
h1,h2,h3,h4{font-family:var(--head);font-weight:800;line-height:1.05;letter-spacing:-.02em;margin:0}
p{margin:0}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ===================== BACKGROUND / STARFIELD ===================== */
.starfield{position:fixed;inset:0;z-index:-2;background:
  radial-gradient(140% 120% at 50% -10%, #0a1030 0%, #06081a 42%, #04050f 100%);}
.stars{position:absolute;inset:-50% 0;background-repeat:repeat;opacity:.0;animation:starDrift linear infinite;}
.stars-1{
  background-image:
    radial-gradient(1.5px 1.5px at 20px 30px, rgba(255,255,255,.9), transparent),
    radial-gradient(1px 1px at 120px 80px, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 200px 160px, rgba(190,225,255,.8), transparent),
    radial-gradient(1px 1px at 290px 50px, rgba(255,255,255,.6), transparent);
  background-size:320px 320px;opacity:.55;animation-duration:140s;
}
.stars-2{
  background-image:
    radial-gradient(1px 1px at 60px 120px, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 180px 40px, rgba(210,200,255,.8), transparent),
    radial-gradient(1px 1px at 250px 200px, rgba(255,255,255,.5), transparent);
  background-size:280px 280px;opacity:.4;animation-duration:200s;animation-direction:reverse;
}
.stars-3{
  background-image:
    radial-gradient(2px 2px at 40px 60px, rgba(180,220,255,.95), transparent),
    radial-gradient(2px 2px at 220px 180px, rgba(255,230,200,.85), transparent);
  background-size:420px 420px;opacity:.5;animation-duration:90s;
}
@keyframes starDrift{from{transform:translateY(0)}to{transform:translateY(160px)}}
.glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;}
.glow-purple{width:48vw;height:48vw;left:-12vw;top:-8vw;background:radial-gradient(circle,rgba(150,70,255,.55),transparent 65%);}
.glow-cyan{width:42vw;height:42vw;right:-10vw;top:2vw;background:radial-gradient(circle,rgba(30,200,255,.4),transparent 65%);}

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-flex;align-items:center;gap:.55em;font-family:var(--head);font-weight:700;
  font-size:15px;padding:13px 22px;border-radius:13px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  white-space:nowrap;
}
.btn .chev{font-size:1.15em;line-height:0;transition:transform .25s var(--ease)}
.btn:hover .chev{transform:translateX(3px)}
.btn-gold{color:#1b1300;background:linear-gradient(135deg,#ffd451,#ff9c22);
  box-shadow:0 8px 26px rgba(255,160,40,.35), inset 0 1px 0 rgba(255,255,255,.45);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 34px rgba(255,160,40,.5), inset 0 1px 0 rgba(255,255,255,.45);}
.btn-ghost{color:#fff;background:rgba(20,26,54,.55);border-color:rgba(150,110,255,.55);backdrop-filter:blur(8px);}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--purple);box-shadow:0 0 24px rgba(150,90,255,.35);}
.btn.lg{font-size:16px;padding:16px 28px}
.btn.sm{font-size:13.5px;padding:10px 16px;border-radius:11px}
.btn.full{width:100%;justify-content:center}

/* ===================== HEADER ===================== */
.site-header{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:24px;
  max-width:var(--maxw);margin:0 auto;padding:16px 30px;
}
.site-header::before{content:"";position:absolute;inset:0;z-index:-1;
  background:rgba(6,8,22,.6);backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.06);
  -webkit-mask:linear-gradient(#000,#000);}
.brand img{height:54px;width:auto;filter:drop-shadow(0 4px 14px rgba(0,0,0,.5))}
.nav-links{display:flex;gap:30px;margin-left:auto;font-family:var(--head);font-weight:600;font-size:15px}
.nav-links a{color:#dfe6ff;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--cyan),var(--purple));transition:width .28s var(--ease)}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-cta{margin-left:6px}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.25s var(--ease)}

/* ===================== LAYOUT HELPERS ===================== */
.section{max-width:var(--maxw);margin:0 auto;padding:92px 30px}
.eyebrow{font-family:var(--head);font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--cyan);margin-bottom:14px}
.section-head{text-align:center;max-width:680px;margin:0 auto 52px}
.section-head h2{font-size:clamp(30px,4vw,46px)}
.sub{color:var(--muted);font-size:18px;margin-top:14px}
.grad-text{background:linear-gradient(96deg,#ff6a5a 0%,#ffc83d 32%,#2ad4ff 64%,#b15cff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;display:block;white-space:nowrap;
  padding-bottom:0.12em;}

/* ===================== HERO ===================== */
.hero{max-width:var(--maxw);margin:0 auto;padding:64px 30px 70px;
  display:grid;grid-template-columns:1.02fr 1.18fr;gap:46px;align-items:center}
.hero h1{font-size:clamp(38px,5.2vw,62px);margin-bottom:22px}
.hero h1 .line-1{display:block;white-space:nowrap}
.hero .lede{color:#cfd8f5;font-size:19px;max-width:540px;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero-stats{display:flex;gap:30px;list-style:none;padding:0;margin:0;flex-wrap:wrap}
.hero-stats li{display:flex;flex-direction:column;gap:2px}
.hero-stats strong{font-family:var(--head);font-size:19px;background:linear-gradient(120deg,#fff,#bfe7ff);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-stats span{color:var(--muted-2);font-size:13.5px}

.hero-visual{position:relative;min-height:480px}
.video-wrap{position:relative;width:94%;margin-left:auto;border-radius:18px;overflow:hidden;
  border:2px solid rgba(40,210,255,.45);
  box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 50px rgba(40,210,255,.18);}
.video-wrap video{width:100%;display:block}
.screen-glow{position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 60px rgba(40,210,255,.12);border-radius:16px}
.tablet-wrap{position:absolute;right:-2%;bottom:-6%;width:46%;border-radius:16px;overflow:hidden;
  border:2px solid rgba(180,90,255,.6);
  box-shadow:0 24px 60px rgba(0,0,0,.65), 0 0 40px rgba(170,80,255,.28);}
.tablet-wrap img{width:100%}
.call-ball{position:absolute;left:-3%;bottom:8%;width:104px;height:104px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;text-align:center;color:#3a2400;
  background:radial-gradient(circle at 35% 28%, #ffe79a, #ffb02e 55%, #e7820f 100%);
  box-shadow:0 14px 36px rgba(0,0,0,.55), inset 0 -8px 18px rgba(150,70,0,.45), inset 0 6px 12px rgba(255,255,255,.6),
    0 0 38px rgba(255,180,50,.55);
  transition:background .45s var(--ease), box-shadow .45s var(--ease), color .45s var(--ease);}
/* B = blue, I = red, N = white, G = green, O = yellow */
.call-ball[data-color="B"]{color:#fff;
  background:radial-gradient(circle at 35% 28%, #cfe6ff, #2f86ff 55%, #1257c4 100%);
  box-shadow:0 14px 36px rgba(0,0,0,.55), inset 0 -8px 18px rgba(10,50,140,.5), inset 0 6px 12px rgba(255,255,255,.55), 0 0 38px rgba(50,130,255,.6);}
.call-ball[data-color="I"]{color:#fff;
  background:radial-gradient(circle at 35% 28%, #ffd0cb, #ff5a4d 55%, #c5211a 100%);
  box-shadow:0 14px 36px rgba(0,0,0,.55), inset 0 -8px 18px rgba(140,20,15,.5), inset 0 6px 12px rgba(255,255,255,.5), 0 0 38px rgba(255,80,70,.55);}
.call-ball[data-color="N"]{color:#1a2030;
  background:radial-gradient(circle at 35% 28%, #ffffff, #eef2fb 55%, #c3ccdd 100%);
  box-shadow:0 14px 36px rgba(0,0,0,.55), inset 0 -8px 18px rgba(120,135,165,.45), inset 0 6px 12px rgba(255,255,255,.9), 0 0 38px rgba(200,215,255,.55);}
.call-ball[data-color="G"]{color:#fff;
  background:radial-gradient(circle at 35% 28%, #c8f7d8, #2fcf73 55%, #109b4c 100%);
  box-shadow:0 14px 36px rgba(0,0,0,.55), inset 0 -8px 18px rgba(8,90,45,.5), inset 0 6px 12px rgba(255,255,255,.55), 0 0 38px rgba(45,210,120,.55);}
.call-ball[data-color="O"]{color:#3a2400;
  background:radial-gradient(circle at 35% 28%, #ffe79a, #ffc83d 55%, #e79a0f 100%);
  box-shadow:0 14px 36px rgba(0,0,0,.55), inset 0 -8px 18px rgba(150,90,0,.45), inset 0 6px 12px rgba(255,255,255,.6), 0 0 38px rgba(255,190,50,.55);}
.call-letter{font-family:var(--head);font-weight:800;font-size:15px;letter-spacing:.04em;opacity:.85;line-height:1;margin-bottom:-2px}
.call-number{font-family:var(--head);font-weight:800;font-size:42px;line-height:1;text-shadow:0 2px 0 rgba(255,255,255,.35)}
/* Ball divider above themes */
.ball-divider{display:flex;justify-content:center;padding:10px 0 40px}
.call-ball-lg{position:relative;width:130px;height:130px;left:auto;bottom:auto;}
.call-ball-lg .call-letter{font-size:18px}
.call-ball-lg .call-number{font-size:52px}
.call-number.pop{animation:ballPop .5s var(--ease)}
@keyframes ballPop{0%{transform:scale(.4);opacity:0}55%{transform:scale(1.18)}100%{transform:scale(1);opacity:1}}

/* float animations */
.float-slow{animation:floatY 7s ease-in-out infinite}
.float-fast{animation:floatY 4.6s ease-in-out infinite}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ===================== FEATURES ===================== */
.kicker{text-align:center;font-family:var(--head);font-weight:800;font-size:clamp(20px,2.6vw,30px);
  color:#eaf3ff;margin:0 0 44px;letter-spacing:-.01em}
.kicker .spark{color:var(--cyan);font-size:.8em;margin:0 .3em;filter:drop-shadow(0 0 10px rgba(40,210,255,.6))}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feature-card{
  position:relative;padding:28px 24px;border-radius:var(--r);
  background:linear-gradient(180deg,rgba(20,26,54,.78),rgba(9,12,30,.78));
  border:1px solid var(--line);overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.feature-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(140deg,rgba(120,200,255,.35),transparent 40%);
  -webkit-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}
.feature-card:hover{transform:translateY(-6px);border-color:var(--line-bright);
  box-shadow:0 18px 44px rgba(0,0,0,.5), 0 0 30px rgba(40,160,255,.12)}
.feature-card:hover::before{opacity:1}
.ficon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.ficon svg{width:28px;height:28px}
.ficon[data-tint=cyan]{color:var(--cyan);box-shadow:0 0 22px rgba(40,210,255,.25)}
.ficon[data-tint=purple]{color:var(--purple);box-shadow:0 0 22px rgba(180,90,255,.25)}
.ficon[data-tint=green]{color:var(--green);box-shadow:0 0 22px rgba(55,217,138,.25)}
.ficon[data-tint=red]{color:var(--red);box-shadow:0 0 22px rgba(255,98,89,.25)}
.ficon[data-tint=gold]{color:var(--gold);box-shadow:0 0 22px rgba(255,200,61,.25)}
.ficon[data-tint=magenta]{color:var(--magenta);box-shadow:0 0 22px rgba(255,93,189,.25)}
.feature-card h3{font-size:19px;margin-bottom:9px}
.feature-card p{color:var(--muted);font-size:15px}

/* ===================== THEMES ===================== */
.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}
.theme-card{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);
  background:var(--panel-2);transition:transform .35s var(--ease), box-shadow .35s var(--ease)}
.theme-card:hover{transform:translateY(-6px);box-shadow:0 26px 60px rgba(0,0,0,.55)}
.theme-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.theme-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.theme-card:hover .theme-media img{transform:scale(1.06)}
.theme-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(6,8,22,.55))}
.theme-body{padding:24px 26px 28px}
.theme-body h3{font-size:26px;margin-bottom:8px}
.theme-body p{color:var(--muted);font-size:15.5px;margin-bottom:18px}
.theme-card:nth-child(1){border-color:rgba(70,210,120,.4)}
.theme-card:nth-child(2){border-color:rgba(150,90,255,.45)}
.theme-soon{display:grid;place-items:center;min-height:260px;
  background:
    radial-gradient(120% 100% at 50% 0%, rgba(40,210,255,.12), transparent 60%),
    linear-gradient(180deg,rgba(18,22,48,.7),rgba(9,12,30,.7));
  border-style:dashed;border-color:rgba(125,160,255,.3)}
.soon-inner{text-align:center;padding:30px}
.soon-tag{display:inline-block;font-family:var(--head);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--cyan);border:1px solid rgba(40,210,255,.4);border-radius:999px;padding:5px 14px;margin-bottom:14px}
.soon-inner h3{font-size:24px;margin-bottom:8px}
.soon-inner p{color:var(--muted);font-size:15px;max-width:240px}

/* ===================== MOBILE ===================== */
.mobile{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.mobile-copy h2{font-size:clamp(28px,3.6vw,42px)}
.check-list{list-style:none;padding:0;margin:24px 0 28px;display:grid;gap:14px}
.check-list li{display:flex;align-items:center;gap:13px;color:#dbe3ff;font-size:16.5px}
.ck{flex:0 0 auto;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:#04201a;
  background:linear-gradient(135deg,#2ad4ff,#37d98a);box-shadow:0 0 16px rgba(55,217,170,.45)}
.ck svg{width:15px;height:15px}
.badges{display:flex;gap:14px;flex-wrap:wrap}
.store-badge{font-family:var(--head);font-weight:600;font-size:14px;color:#eaf0ff;
  border:1px solid rgba(255,255,255,.22);border-radius:12px;padding:12px 18px;background:rgba(8,11,26,.6)}
.mobile-visual{position:relative;min-height:600px}
.device-land{position:absolute;top:4%;left:0;width:100%;z-index:1;
  border:10px solid #0b0d18;border-radius:30px;overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.7), 0 0 0 2px rgba(255,255,255,.06), 0 0 56px rgba(120,80,255,.22);
  will-change:transform}
.device-land img{width:100%;display:block}
.land-glow{position:absolute;inset:0;pointer-events:none;border-radius:20px;
  box-shadow:inset 0 0 50px rgba(120,90,255,.16)}
.phone{position:absolute;border-radius:34px;overflow:hidden;border:8px solid #0b0d18;
  box-shadow:0 30px 70px rgba(0,0,0,.7), 0 0 0 2px rgba(255,255,255,.06);will-change:transform}
.phone img{width:100%}
.phone-a{width:39%;left:1%;bottom:0;z-index:3;transform:rotate(-6deg)}
.phone-b{width:39%;right:1%;bottom:5%;z-index:2;transform:rotate(6deg)}

/* ===================== HOW ===================== */
.steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:8px;align-items:stretch}
.step{position:relative;padding:34px 26px 30px;border-radius:var(--r);
  background:linear-gradient(180deg,rgba(20,26,54,.78),rgba(9,12,30,.78));
  border:1px solid var(--line);transition:transform .3s var(--ease),border-color .3s var(--ease)}
.step:hover{transform:translateY(-5px);border-color:var(--line-bright)}
.step-num{position:absolute;top:-16px;left:26px;width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--head);font-weight:800;color:#04050f;font-size:16px;
  background:linear-gradient(135deg,#2ad4ff,#b15cff);box-shadow:0 6px 18px rgba(90,120,255,.45)}
.step-icon{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin:8px 0 18px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.step-icon svg{width:30px;height:30px}
.step-icon[data-tint=cyan]{color:var(--cyan);box-shadow:0 0 24px rgba(40,210,255,.22)}
.step-icon[data-tint=purple]{color:var(--purple);box-shadow:0 0 24px rgba(180,90,255,.22)}
.step-icon[data-tint=gold]{color:var(--gold);box-shadow:0 0 24px rgba(255,200,61,.22)}
.step h3{font-size:20px;margin-bottom:9px}
.step p{color:var(--muted);font-size:15px}
.step-link{align-self:center;width:46px;height:2px;border-radius:2px;
  background:repeating-linear-gradient(90deg,rgba(120,180,255,.6) 0 7px,transparent 7px 13px)}

/* ===================== CTA BANNER ===================== */
.cta-banner{max-width:var(--maxw);margin:30px auto;padding:34px 40px;border-radius:var(--r-lg);
  display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center;position:relative;overflow:hidden;
  background:
    radial-gradient(120% 160% at 0% 0%, rgba(150,70,255,.55), transparent 55%),
    radial-gradient(120% 160% at 100% 100%, rgba(40,170,255,.45), transparent 55%),
    linear-gradient(120deg,#1a1247,#10183f);
  border:1px solid rgba(160,120,255,.4);
  box-shadow:0 30px 70px rgba(0,0,0,.5), 0 0 60px rgba(120,80,255,.18)}
.cta-banner::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:radial-gradient(2px 2px at 30% 40%,rgba(255,255,255,.6),transparent),
            radial-gradient(2px 2px at 70% 60%,rgba(255,255,255,.5),transparent),
            radial-gradient(1.5px 1.5px at 50% 20%,rgba(255,255,255,.4),transparent)}
.cta-logo img{width:120px}
.cta-text{position:relative}
.cta-text h2{font-size:clamp(24px,3vw,34px);margin-bottom:6px}
.cta-text p{color:#d8def8;margin-bottom:14px}
.cta-contacts{display:flex;gap:24px;flex-wrap:wrap;font-weight:600}
.cta-contacts a{color:#fff;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.cta-contacts a:hover{color:var(--gold)}
.ci{color:var(--gold);display:inline-flex}
.ci svg{width:18px;height:18px;display:block}
.cta-contacts a{align-items:center}
.cta-banner .btn{position:relative}

/* ===================== CONTACT ===================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.contact-intro h2{font-size:clamp(28px,3.6vw,42px)}
.contact-points{list-style:none;padding:0;margin:22px 0 26px;display:grid;gap:12px}
.contact-points li{display:flex;align-items:center;gap:14px;color:#dbe3ff;font-size:16px}
.contact-points .dot{flex:0 0 auto;width:10px;height:10px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--orange));box-shadow:0 0 12px rgba(255,180,60,.6)}
.contact-direct{display:flex;gap:24px;flex-wrap:wrap;font-weight:600}
.contact-direct a{display:inline-flex;align-items:center;gap:8px;color:#eaf0ff;white-space:nowrap}
.contact-direct a:hover{color:var(--gold)}

.contact-form{position:relative;padding:30px;border-radius:var(--r-lg);
  background:linear-gradient(180deg,rgba(18,23,50,.86),rgba(9,12,30,.9));
  border:1px solid var(--line);box-shadow:0 24px 60px rgba(0,0,0,.45)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--head);font-weight:600;font-size:13.5px;color:#c7d1f2;margin-bottom:7px}
.field input,.field textarea{width:100%;font-family:var(--body);font-size:15px;color:#fff;
  background:rgba(6,9,22,.7);border:1px solid rgba(140,170,255,.22);border-radius:12px;padding:13px 15px;
  transition:border-color .2s,box-shadow .2s;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:#717ba3}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(40,210,255,.18)}
.field input.invalid,.field textarea.invalid{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,98,89,.16)}
.form-note{color:var(--muted-2);font-size:13px;text-align:center;margin-top:14px}
.form-success{position:absolute;inset:0;border-radius:var(--r-lg);display:grid;place-content:center;text-align:center;
  gap:6px;padding:40px;background:linear-gradient(180deg,rgba(16,22,48,.97),rgba(9,12,30,.99));
  animation:fadeIn .4s var(--ease)}
.success-mark{width:64px;height:64px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;
  font-size:30px;color:#04201a;background:linear-gradient(135deg,#2ad4ff,#37d98a);
  box-shadow:0 0 30px rgba(55,217,170,.5);animation:ballPop .5s var(--ease)}
.form-success h3{font-size:24px}
.form-success p{color:var(--muted);font-size:15.5px;max-width:320px}
@keyframes fadeIn{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:none}}

/* ===================== FOOTER ===================== */
.footer{max-width:var(--maxw);margin:0 auto;padding:60px 30px 34px;border-top:1px solid rgba(255,255,255,.07)}
.footer-top{display:grid;grid-template-columns:1.3fr 2.4fr;gap:48px}
.footer-brand img{width:130px;margin-bottom:14px}
.footer-brand p{color:var(--muted);font-size:14.5px;max-width:280px}
.footer-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.footer-col h4{font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin-bottom:14px;font-family:var(--head)}
.footer-col a{display:block;color:var(--muted);font-size:14.5px;margin-bottom:10px;transition:color .2s}
.footer-col a:hover{color:var(--cyan)}
.footer-mini{color:var(--muted);font-size:14px;margin-bottom:14px}
.socials{display:flex;gap:10px}
.soc{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  color:#cbd6ff;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);transition:.25s var(--ease)}
.soc svg{width:19px;height:19px}
.soc:hover{transform:translateY(-3px);color:#fff;border-color:var(--cyan);box-shadow:0 0 20px rgba(40,210,255,.3)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  margin-top:40px;padding-top:22px;border-top:1px solid rgba(255,255,255,.06);color:var(--muted-2);font-size:13.5px}

/* ===================== REVEAL =====================
   Resting state is VISIBLE; entrance plays a finite keyframe that reverts to
   the visible base once its duration elapses. `backwards` hides during the
   stagger delay only — so no blink and no dependency on transitions ticking. */
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.reveal.in{animation:rise .68s var(--ease) backwards;animation-delay:var(--d,0s)}

/* ===================== RESPONSIVE ===================== */
@media (max-width:980px){
  .hero{grid-template-columns:1fr;gap:54px;padding-top:40px}
  .hero-visual{min-height:380px;max-width:620px}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .mobile{grid-template-columns:1fr;gap:36px}
  .mobile-visual{min-height:520px;max-width:460px;margin:0 auto;width:100%}
  .steps{grid-template-columns:1fr;gap:30px}
  .step-link{display:none}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .cta-banner{grid-template-columns:1fr;text-align:center;gap:20px;justify-items:center}
  .cta-contacts{justify-content:center}
  .footer-top{grid-template-columns:1fr;gap:34px}
}
@media (max-width:760px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .site-header{padding:14px 20px}
  .site-header.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:18px;
    padding:22px 26px;background:rgba(8,11,26,.97);border-bottom:1px solid rgba(255,255,255,.08);backdrop-filter:blur(16px)}
  .site-header.open .nav-cta{display:inline-flex;position:absolute;top:100%;right:20px;margin-top:158px}
  .section{padding:64px 22px}
  .feature-grid{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:repeat(2,1fr)}
  .footer-bottom{flex-direction:column}
  .call-ball{width:84px;height:84px}
  .call-number{font-size:34px}
}
@media (max-width:420px){
  .hero h1{font-size:33px}
  .hero h1 .line-1,.grad-text{white-space:normal}
  .theme-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .reveal.in{animation:none}
  .stars,.float-slow,.float-fast{animation:none}
}
