/* =========================================================
   Aspire — shared styles
   Gradient Modern + Glassmorphism + Tech Forward
   ========================================================= */
:root{
  --abyss:#0B0A23;
  --iris:#7B6CF6;
  --iris-soft:#A99BFF;
  --aqua:#2FE0C8;
  --coral:#FF7E6B;
  --sun:#FFC371;
  --haze:#ECE9FF;
  --haze-dim:#B9B4DF;
  --glass:rgba(255,255,255,0.055);
  --glass-strong:rgba(255,255,255,0.09);
  --glass-line:rgba(255,255,255,0.14);
  --glass-line-soft:rgba(255,255,255,0.08);

  --font-display:"Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;
  --font-body:"Hanken Grotesque", ui-sans-serif, system-ui, sans-serif;
  --font-mono:"Space Mono", ui-monospace, monospace;

  --maxw:1180px;
  --r-lg:28px;
  --r-md:20px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto;} }

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--haze);
  background:var(--abyss);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ---------- aurora background ---------- */
.sky{position:fixed; inset:0; z-index:-2; background:var(--abyss); overflow:hidden;}
.sky::before{
  content:""; position:absolute; left:0; right:0; top:0; height:100%;
  background:linear-gradient(180deg,
    #0B0A23 0%, #100D2B 24%, #14112F 46%, #1B1431 64%, #2A1838 82%, #3E2230 100%);
}
.blob{position:fixed; border-radius:50%; filter:blur(72px); z-index:-1; will-change:transform;}
.b1{width:46vw; height:46vw; left:-10vw; top:-6vw; background:radial-gradient(circle,var(--iris),transparent 68%); opacity:.5;}
.b2{width:40vw; height:40vw; right:-8vw; top:16vh; background:radial-gradient(circle,var(--aqua),transparent 66%); opacity:.38;}
.b3{width:50vw; height:50vw; left:8vw; top:62%; background:radial-gradient(circle,var(--coral),transparent 66%); opacity:.40;}
.b4{width:44vw; height:44vw; right:-6vw; bottom:-8vw; background:radial-gradient(circle,var(--sun),transparent 66%); opacity:.38;}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(4vw,3vh)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-3vw,4vh)}}
.b1{animation:drift1 26s ease-in-out infinite;}
.b2{animation:drift2 30s ease-in-out infinite;}
.b3{animation:drift1 34s ease-in-out infinite reverse;}
.b4{animation:drift2 28s ease-in-out infinite reverse;}
.grain{position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%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");}
@media (prefers-reduced-motion:reduce){ .blob{animation:none!important;} }

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
section{position:relative; padding:96px 0;}
@media(max-width:720px){ section{padding:64px 0;} }

.eyebrow{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--iris-soft); display:inline-flex; align-items:center; gap:10px; margin:0 0 18px;
}
.eyebrow::before{content:""; width:26px; height:1px; background:linear-gradient(90deg,var(--iris-soft),transparent);}
.eyebrow.center{justify-content:center;}

h1,h2,h3{font-family:var(--font-display); font-weight:700; line-height:1.04; letter-spacing:-.02em; margin:0;}
h2{font-size:clamp(1.9rem,4.4vw,3.1rem);}
h3{font-size:clamp(1.2rem,2.2vw,1.5rem); letter-spacing:-.01em;}
p{margin:0;}
.lede{font-size:clamp(1.02rem,1.4vw,1.18rem); color:var(--haze-dim); max-width:60ch;}
.grad-text{background:linear-gradient(105deg,var(--iris-soft) 0%,var(--aqua) 42%,var(--sun) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;}

.glass{
  background:var(--glass); border:1px solid var(--glass-line-soft); border-radius:var(--r-lg);
  backdrop-filter:blur(18px) saturate(140%); -webkit-backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset, 0 30px 60px -30px rgba(0,0,0,.6);
}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; gap:10px; font-family:var(--font-body); font-weight:600;
  font-size:.98rem; padding:14px 26px; border-radius:999px; cursor:pointer; text-decoration:none;
  border:1px solid transparent; transition:transform .25s ease, box-shadow .25s ease, background .25s ease;}
.btn-primary{color:#150f2e; background:linear-gradient(100deg,var(--aqua),var(--iris-soft) 60%,var(--sun));
  box-shadow:0 14px 36px -12px rgba(123,108,246,.7);}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 22px 48px -14px rgba(47,224,200,.6);}
.btn-ghost{color:var(--haze); background:var(--glass); border-color:var(--glass-line); backdrop-filter:blur(12px);}
.btn-ghost:hover{background:var(--glass-strong); transform:translateY(-2px);}
:focus-visible{outline:2px solid var(--aqua); outline-offset:3px; border-radius:6px;}

/* ---------- app coming-soon badges ---------- */
.app-badges{display:flex; gap:12px; flex-wrap:wrap;}
.app-badge{display:inline-flex; align-items:center; gap:12px; padding:11px 18px; border-radius:16px;
  background:var(--glass); border:1px solid var(--glass-line-soft); backdrop-filter:blur(12px);
  color:var(--haze); text-decoration:none; transition:border-color .25s ease, transform .25s ease;}
.app-badge:hover{border-color:var(--glass-line); transform:translateY(-2px);}
.app-badge svg{flex:0 0 auto;}
.app-badge .bt{display:flex; flex-direction:column; line-height:1.15;}
.app-badge .bt small{font-family:var(--font-mono); font-size:9.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--aqua);}
.app-badge .bt strong{font-family:var(--font-display); font-weight:600; font-size:.98rem;}

/* ---------- nav ---------- */
header.nav{position:sticky; top:0; z-index:60;}
.nav-inner{margin:16px auto 0; max-width:var(--maxw); width:calc(100% - 32px);
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:12px 14px 12px 22px; border-radius:999px;
  background:rgba(13,11,38,.5); border:1px solid var(--glass-line-soft);
  backdrop-filter:blur(20px) saturate(150%); -webkit-backdrop-filter:blur(20px) saturate(150%);
  transition:background .3s ease, box-shadow .3s ease;}
.nav-scrolled .nav-inner{background:rgba(13,11,38,.78); box-shadow:0 20px 50px -28px rgba(0,0,0,.8);}
.brand{display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:700;
  font-size:1.18rem; letter-spacing:-.01em; color:var(--haze); text-decoration:none;}
.mark{width:30px; height:30px; border-radius:9px; position:relative;
  background:linear-gradient(135deg,var(--iris),var(--aqua) 55%,var(--sun)); box-shadow:0 0 22px -4px var(--iris);}
.mark::after{content:""; position:absolute; inset:7px; border-radius:50%; background:rgba(11,10,35,.85);}
.navlinks{display:flex; gap:26px; align-items:center;}
.navlinks a{color:var(--haze-dim); text-decoration:none; font-size:.92rem; transition:color .2s; position:relative;}
.navlinks a:hover, .navlinks a.active{color:var(--haze);}
.navlinks a.active::after{content:""; position:absolute; left:0; right:0; bottom:-7px; height:2px; border-radius:2px;
  background:linear-gradient(90deg,var(--aqua),var(--iris-soft));}
.nav-cta{display:flex; gap:10px; align-items:center;}
.nav-cta .btn{padding:11px 20px; font-size:.9rem;}
.menu-btn{display:none; background:none; border:0; color:var(--haze); cursor:pointer; padding:8px;}
@media(max-width:920px){
  .navlinks{display:none;}
  .menu-btn{display:inline-flex;}
  .navlinks.open{display:flex; flex-direction:column; position:absolute; top:74px; left:16px; right:16px;
    padding:20px; gap:16px; background:rgba(13,11,38,.94); border:1px solid var(--glass-line-soft);
    border-radius:22px; backdrop-filter:blur(20px);}
}

/* ---------- page header (lite hero for inner pages) ---------- */
.page-head{padding:72px 0 48px; text-align:center;}
.page-head h1{font-size:clamp(2.2rem,5vw,3.6rem); font-weight:800; max-width:18ch; margin:0 auto;}
.page-head .lede{margin:22px auto 0; text-align:center;}

/* ---------- hero (home) ---------- */
.hero{padding-top:56px; padding-bottom:56px;}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center;}
@media(max-width:920px){ .hero-grid{grid-template-columns:1fr; gap:40px;} }
.hero h1{font-size:clamp(2.5rem,5.6vw,4.4rem); font-weight:800;}
.hero .lede{margin-top:22px; font-size:clamp(1.05rem,1.6vw,1.26rem);}
.hero-cta{display:flex; gap:14px; margin-top:32px; flex-wrap:wrap; align-items:center;}
.hero-cta.center{justify-content:center;}
.coming-line{display:flex; align-items:center; gap:14px; margin-top:26px; flex-wrap:wrap;}
.coming-line .ctxt{font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--haze-dim);}
.trust-row{display:flex; gap:22px; align-items:center; margin-top:26px; flex-wrap:wrap; color:var(--haze-dim); font-size:.86rem;}
.trust-row .dot{width:5px;height:5px;border-radius:50%;background:var(--aqua);box-shadow:0 0 10px var(--aqua);}
.trust-pill{display:flex; align-items:center; gap:9px;}

/* breathing orb */
.orb-stage{position:relative; display:flex; align-items:center; justify-content:center; min-height:400px;}
.orb-card{padding:34px; width:100%; max-width:420px; text-align:center;}
.orb-wrap{position:relative; width:230px; height:230px; margin:6px auto 22px; display:flex; align-items:center; justify-content:center;}
.orb{width:170px; height:170px; border-radius:50%;
  background:radial-gradient(circle at 32% 28%,#fff6,transparent 42%),
    conic-gradient(from 200deg,var(--iris),var(--aqua),var(--sun),var(--coral),var(--iris));
  box-shadow:0 0 60px -6px var(--iris),0 0 120px -20px var(--aqua);
  animation:breathe 11s ease-in-out infinite, spin 22s linear infinite; position:relative;}
.orb::after{content:""; position:absolute; inset:14px; border-radius:50%; background:rgba(11,10,35,.55); backdrop-filter:blur(4px);}
.ring{position:absolute; border-radius:50%; border:1px solid var(--glass-line); animation:breathe 11s ease-in-out infinite;}
.ring.r1{width:210px;height:210px; opacity:.5;}
.ring.r2{width:230px;height:230px; opacity:.28; animation-delay:.2s;}
@keyframes breathe{0%,100%{transform:scale(.82);}45%,50%{transform:scale(1.06);}}
@keyframes spin{to{transform:rotate(360deg);}}
.orb.paused,.ring.paused{animation-play-state:paused;}
.breath-label{font-family:var(--font-mono); font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--aqua); min-height:18px;}
.orb-card h3{margin:4px 0 6px;}
.orb-card p{color:var(--haze-dim); font-size:.92rem;}
.orb-toggle{margin-top:16px; font-size:.82rem; color:var(--haze-dim); background:var(--glass);
  border:1px solid var(--glass-line-soft); border-radius:999px; padding:8px 16px; cursor:pointer; font-family:var(--font-body);}
.orb-toggle:hover{color:var(--haze); background:var(--glass-strong);}
@media (prefers-reduced-motion:reduce){ .orb,.ring{animation:none!important; transform:scale(.95);} }

/* ---------- generic grids ---------- */
.cols-3{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
@media(max-width:880px){ .cols-3{grid-template-columns:1fr;} }
.mt-band{margin-top:48px;}

.stat{padding:30px 26px;}
.stat .num{font-family:var(--font-display); font-weight:800; font-size:clamp(2.1rem,4vw,2.9rem); line-height:1;}
.stat .lab{color:var(--haze-dim); margin-top:12px; font-size:.95rem;}

.step{padding:32px 28px;}
.step .idx{font-family:var(--font-mono); font-size:13px; color:var(--aqua); letter-spacing:.1em;}
.step h3{margin:14px 0 10px;}
.step p{color:var(--haze-dim); font-size:.96rem;}
.step .glyph{width:46px;height:46px;border-radius:13px; display:flex;align-items:center;justify-content:center; margin-bottom:18px;
  background:linear-gradient(135deg,rgba(123,108,246,.35),rgba(47,224,200,.25)); border:1px solid var(--glass-line);}

.feat{padding:28px 26px; transition:transform .3s ease, border-color .3s ease;}
.feat:hover{transform:translateY(-4px); border-color:var(--glass-line);}
.feat .ic{width:44px;height:44px;border-radius:12px; display:flex;align-items:center;justify-content:center; margin-bottom:18px; font-size:20px;
  background:linear-gradient(135deg,rgba(123,108,246,.3),rgba(47,224,200,.22)); border:1px solid var(--glass-line);}
.feat h3{font-size:1.1rem; margin-bottom:9px;}
.feat p{color:var(--haze-dim); font-size:.92rem;}

/* split (AI support) */
.split{display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:center;}
@media(max-width:880px){ .split{grid-template-columns:1fr; gap:36px;} }
.feature-list{margin-top:26px; display:flex; flex-direction:column; gap:18px;}
.fitem{display:flex; gap:16px; align-items:flex-start;}
.fitem .tick{flex:0 0 auto; width:30px;height:30px;border-radius:9px; display:flex;align-items:center;justify-content:center; margin-top:2px;
  background:linear-gradient(135deg,var(--iris),var(--aqua)); color:#0c0a1f; font-weight:700;}
.fitem h4{margin:0 0 3px; font-family:var(--font-display); font-weight:600; font-size:1.05rem; color:var(--haze);}
.fitem p{color:var(--haze-dim); font-size:.93rem;}
.chat{padding:24px; max-width:430px; margin-left:auto;}
.chat-top{display:flex; align-items:center; gap:12px; padding-bottom:16px; border-bottom:1px solid var(--glass-line-soft); margin-bottom:18px;}
.chat-av{width:38px;height:38px;border-radius:50%; background:radial-gradient(circle at 35% 30%,#fff5,transparent 45%),conic-gradient(from 160deg,var(--iris),var(--aqua),var(--sun)); box-shadow:0 0 16px -2px var(--aqua);}
.chat-top .who{font-family:var(--font-display); font-weight:600; font-size:.98rem;}
.chat-top .stat-on{font-family:var(--font-mono); font-size:11px; color:var(--aqua); letter-spacing:.12em;}
.bubble{padding:13px 16px; border-radius:16px; font-size:.92rem; margin-bottom:12px; max-width:84%;}
.bubble.you{margin-left:auto; background:rgba(123,108,246,.22); border:1px solid rgba(123,108,246,.35); border-bottom-right-radius:5px;}
.bubble.ai{background:var(--glass-strong); border:1px solid var(--glass-line-soft); border-bottom-left-radius:5px; color:var(--haze);}

/* stories */
.story{padding:30px 28px; display:flex; flex-direction:column; gap:18px;}
.story .q{font-size:1.02rem; color:var(--haze); line-height:1.55;}
.story .who{display:flex; align-items:center; gap:12px; margin-top:auto;}
.story .ava{width:40px;height:40px;border-radius:50%; flex:0 0 auto;}
.story .who .n{font-weight:600; font-size:.92rem;}
.story .who .m{font-size:.8rem; color:var(--haze-dim); font-family:var(--font-mono); letter-spacing:.04em;}
.stars{color:var(--sun); font-size:.9rem; letter-spacing:2px;}

/* campus */
.impact{display:grid; grid-template-columns:.9fr 1.1fr; gap:46px; align-items:center;}
@media(max-width:880px){ .impact{grid-template-columns:1fr; gap:36px;} }
.impact-stats{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.imp{padding:26px 24px;}
.imp .num{font-family:var(--font-display); font-weight:800; font-size:clamp(1.8rem,3vw,2.3rem); line-height:1;}
.imp .lab{color:var(--haze-dim); margin-top:10px; font-size:.9rem;}
.home-badge{display:inline-flex; align-items:center; gap:10px; padding:10px 18px; border-radius:999px;
  background:var(--glass); border:1px solid var(--glass-line); font-size:.86rem; color:var(--haze); margin-bottom:22px;}
.home-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--aqua); box-shadow:0 0 0 0 rgba(47,224,200,.6); animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,224,200,.55);}70%{box-shadow:0 0 0 12px rgba(47,224,200,0);}100%{box-shadow:0 0 0 0 rgba(47,224,200,0);}}

/* FAQ */
.faq{max-width:820px; margin:44px auto 0;}
details{border:1px solid var(--glass-line-soft); border-radius:var(--r-md); background:var(--glass); margin-bottom:14px; overflow:hidden; backdrop-filter:blur(12px);}
details[open]{border-color:var(--glass-line);}
summary{list-style:none; cursor:pointer; padding:22px 26px; font-family:var(--font-display); font-weight:600; font-size:1.05rem; display:flex; justify-content:space-between; align-items:center; gap:16px; color:var(--haze);}
summary::-webkit-details-marker{display:none;}
summary .chev{transition:transform .3s ease; color:var(--aqua); flex:0 0 auto;}
details[open] summary .chev{transform:rotate(45deg);}
details .ans{padding:0 26px 24px; color:var(--haze-dim); font-size:.96rem; max-width:68ch;}

/* waitlist band + CTA */
.cta-wrap{text-align:center; padding:66px 40px; border-radius:36px; position:relative; overflow:hidden;
  background:linear-gradient(140deg,rgba(255,126,107,.16),rgba(255,195,113,.14) 50%,rgba(123,108,246,.16));
  border:1px solid var(--glass-line);}
.cta-wrap h2{max-width:20ch; margin:0 auto 18px;}
.cta-wrap .lede{margin:0 auto; text-align:center;}
.cta-glow{position:absolute; width:480px;height:480px; border-radius:50%; filter:blur(80px);
  background:radial-gradient(circle,var(--sun),transparent 65%); opacity:.4; top:-180px; left:50%; transform:translateX(-50%); z-index:-1;}

/* waitlist form */
.form-card{max-width:560px; margin:0 auto; padding:40px;}
.field{margin-bottom:18px; text-align:left;}
.field label{display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--haze-dim); margin-bottom:8px;}
.field input, .field select{width:100%; padding:14px 16px; border-radius:14px; border:1px solid var(--glass-line-soft);
  background:rgba(255,255,255,.04); color:var(--haze); font-family:var(--font-body); font-size:1rem;}
.field input::placeholder{color:#7a749e;}
.field input:focus, .field select:focus{outline:none; border-color:var(--aqua); box-shadow:0 0 0 3px rgba(47,224,200,.18);}
.field select{appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23B9B4DF' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center;}
.field select option{background:#15122e;}
.form-card .btn-primary{width:100%; justify-content:center; margin-top:6px;}
.form-note{font-size:.82rem; color:var(--haze-dim); margin-top:16px; text-align:center;}
.form-success{display:none; text-align:center; padding:10px 0;}
.form-success.show{display:block;}
.form-success .check{width:64px;height:64px;border-radius:50%; margin:0 auto 18px; display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--aqua),var(--iris-soft)); box-shadow:0 0 40px -8px var(--aqua);}
.form-success h3{margin-bottom:10px;}
.form-success p{color:var(--haze-dim);}
.form-hidden{display:none;}
.recap{display:flex; gap:18px; flex-wrap:wrap; justify-content:center; margin-top:36px;}
.recap .chip{display:inline-flex; align-items:center; gap:9px; padding:9px 16px; border-radius:999px; background:var(--glass); border:1px solid var(--glass-line-soft); font-size:.85rem; color:var(--haze-dim);}
.recap .chip b{color:var(--haze); font-weight:600;}

/* footer */
footer{padding:60px 0 44px; border-top:1px solid var(--glass-line-soft); margin-top:36px;}
.foot-grid{display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap;}
.foot-brand{max-width:300px;}
.foot-brand p{color:var(--haze-dim); font-size:.9rem; margin-top:14px;}
.foot-cols{display:flex; gap:64px; flex-wrap:wrap;}
.foot-col h5{font-family:var(--font-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--haze-dim); margin:0 0 16px;}
.foot-col a{display:block; color:var(--haze); text-decoration:none; font-size:.92rem; margin-bottom:11px; opacity:.85;}
.foot-col a:hover{opacity:1; color:var(--aqua);}
.foot-bottom{display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-top:48px; padding-top:24px; border-top:1px solid var(--glass-line-soft); color:var(--haze-dim); font-size:.83rem;}
.crisis-note{max-width:var(--maxw); margin:0 auto; padding:18px 24px; font-size:.82rem; color:var(--haze-dim); text-align:center; line-height:1.7;}

/* reveal */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1; transform:none;}
@media (prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none; transition:none;} }
