/* ===========================================================
   AURA — ready-to-drink functional smoothies
   Layout & palette: v2 (full-bleed) · Copy: v3 · Type: Inter
   Brand-owned visuals (cups + colour only), sticky flavour
   stack, soft colour auras — cleaned for a solid landing page
   =========================================================== */

:root{
  --ink:#0f0b14; --ink-2:#21192b;
  --cream:#faf8f5; --paper:#ffffff; --paper-2:#f4efe8;
  --muted:rgba(15,11,20,.64); --line:rgba(15,11,20,.08);
  --purple:#6b36be; --purple-2:#b28cff;
  --green:#8cac46; --pink:#f47a9d; --gold:#f9a738;
  --radius-xl:40px; --radius-lg:30px; --radius:22px;
  --shadow:0 34px 100px -30px rgba(43,20,76,.15);
  --shadow-sm:0 16px 48px -20px rgba(43,20,76,.12);
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:100%;
  --pad:clamp(20px,5vw,80px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--cream)}
body{
  margin:0;color:var(--ink);overflow-x:clip;position:relative;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:400;line-height:1.55;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background:
    radial-gradient(38rem 30rem at 82% 6%, rgba(178,140,255,.25), transparent 70%),
    radial-gradient(34rem 28rem at 12% 16%, rgba(249,167,56,.20), transparent 70%),
    radial-gradient(40rem 34rem at 60% 100%, rgba(244,122,157,.15), transparent 70%),
    linear-gradient(180deg,#ffffff 0%, #faf8f5 46%, #fdfcfa 100%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-family:Outfit,sans-serif;font-weight:800;line-height:.9;letter-spacing:-.04em}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
em{font-style:normal}

/* atmosphere */
.noise{
  position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.06;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.cursor-glow{
  position:fixed;left:0;top:0;z-index:0;width:40rem;height:40rem;border-radius:50%;pointer-events:none;
  transform:translate(calc(var(--x,50vw) - 20rem), calc(var(--y,24vh) - 20rem));
  background:radial-gradient(circle, rgba(170,124,255,.16), rgba(241,154,40,.08) 42%, transparent 66%);
  opacity:0;transition:opacity .5s;
}
body.has-pointer .cursor-glow{opacity:1}

/* shared atoms */
.capsule,.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:9px 15px;border:1px solid var(--line);border-radius:999px;color:var(--ink-2);
  background:rgba(255,255,255,.5);backdrop-filter:blur(8px);
}
.eyebrow{color:var(--muted)}
.capsule::before{content:"";width:8px;height:8px;border-radius:50%;
  background:conic-gradient(var(--purple-2),var(--green),var(--pink),var(--gold),var(--purple-2))}

/* reveal-on-scroll (classes added in JS) */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ===========================================================
   NAV
   =========================================================== */
.site-nav{
  position:fixed;inset:0 0 auto;z-index:40;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:30px;
  padding:18px var(--pad);transition:background .35s,backdrop-filter .35s,padding .35s,box-shadow .35s;
}
.site-nav.scrolled{
  padding-block:11px;background:rgba(255,246,232,.8);backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--line);
}
.wordmark{font-family:'Circular Std', 'Helvetica Now Display', 'Helvetica Neue', Helvetica, sans-serif;font-weight:900;font-size:44px;letter-spacing:-.06em;line-height:1;color:var(--ink);transition:transform .3s var(--ease)}
.wordmark .kern-a{letter-spacing:-.08em}
.wordmark:hover{transform:scale(1.02)}
.site-nav nav{display:flex;justify-content:center;gap:28px}
.site-nav nav a{font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--muted);position:relative;padding:6px 0;transition:color .25s}
.site-nav nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;border-radius:2px;background:var(--purple);transition:width .3s var(--ease)}
.site-nav nav a:hover{color:var(--ink)}
.site-nav nav a:hover::after{width:100%}
.nav-cta{font-family:Outfit,sans-serif;font-size:14px;font-weight:700;color:var(--cream);background:var(--ink);padding:11px 20px;border-radius:999px;transition:all .3s var(--ease);border:1px solid transparent}
.nav-cta:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-sm);background:#000;border:1px solid rgba(255,255,255,0.2)}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative;min-height:100svh;
  padding:128px var(--pad) 56px;
  display:grid;grid-template-columns:minmax(0,1.06fr) minmax(0,.94fr);align-items:center;gap:clamp(24px,4vw,56px);
  overflow:hidden;
}
.hero::before{
  content:"aura";position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  font-weight:900;font-size:clamp(160px,28vw,500px);line-height:.75;letter-spacing:-.1em;
  color:rgba(22,19,26,.03);z-index:0;pointer-events:none;white-space:nowrap;
}
.hero-copy{position:relative;z-index:2;max-width:560px}
.hero-copy .capsule{margin-bottom:24px}
.hero h1{
  font-size:clamp(58px,8.2vw,140px);letter-spacing:-.07em;line-height:.82;margin-bottom:24px;
}
.hero h1 em{font-style:normal;color:var(--purple)}
.hero-lede{max-width:480px;color:#4f4636;font-size:clamp(16px,1.5vw,19px);line-height:1.6;margin-bottom:32px}

/* signup */
.signup{width:min(100%,520px)}
.signup label{display:block;margin-bottom:10px;font-size:13px;font-weight:600;color:var(--muted)}
.signup-row{display:grid;grid-template-columns:1fr auto;gap:6px;padding:6px;border-radius:999px;
  background:rgba(255,255,255,.9);border:1px solid var(--line);box-shadow:0 18px 50px -28px rgba(58,31,74,.3);backdrop-filter:blur(10px);transition:box-shadow .3s,border-color .3s}
.signup-row:focus-within{border-color:rgba(107,54,190,.4);box-shadow:0 18px 50px -28px rgba(107,54,190,.4)}
input{width:100%;min-width:0;border:0;outline:0;background:transparent;padding:13px 18px;font:inherit;font-size:15px;color:var(--ink)}
input::placeholder{color:#a89c84}
button{border:0;cursor:pointer;border-radius:999px;padding:14px 24px;background:var(--ink);color:var(--cream);
  font-family:Outfit,sans-serif;font-weight:700;font-size:15px;white-space:nowrap;transition:all .3s var(--ease)}
button:hover{transform:translateY(-2px) scale(1.02);background:#000;box-shadow:var(--shadow-sm)}
.form-note{margin-top:12px;color:var(--muted);font-size:13px}
[data-form].submitted button{background:var(--green)}
[data-form].submitted input{opacity:.55}

.trust{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:26px}
.trust li{position:relative;padding-left:18px;font-size:13.5px;font-weight:600;color:var(--ink-2)}
.trust li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;
  background:var(--gold)}
.trust li:nth-child(2)::before{background:var(--green)}
.trust li:nth-child(3)::before{background:var(--pink)}

/* hero stage : cups inside soft colour auras */
.hero-stage{position:relative;z-index:2;min-height:600px;display:grid;place-items:center}
.halo{position:absolute;border-radius:50%;filter:blur(58px);opacity:.55;will-change:transform;animation:drift 16s ease-in-out infinite}
.halo-purple{width:300px;height:300px;left:10%;top:10%;background:radial-gradient(circle,var(--purple-2),transparent 66%)}
.halo-green{width:250px;height:250px;right:8%;top:16%;background:radial-gradient(circle,#aacb6b,transparent 66%);animation-delay:-4s}
.halo-pink{width:280px;height:280px;right:20%;bottom:8%;background:radial-gradient(circle,var(--pink),transparent 66%);animation-delay:-8s}
.halo-gold{width:230px;height:230px;left:8%;bottom:14%;background:radial-gradient(circle,var(--gold),transparent 66%);animation-delay:-12s}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(16px,-18px) scale(1.08)}}

.hero-lineup{position:relative;z-index:3;width:100%;max-width:800px;object-fit:contain;
  filter:drop-shadow(0 34px 42px rgba(22,19,26,.24));animation:bob 6.5s ease-in-out infinite;will-change:transform}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ===========================================================
   MARQUEE
   =========================================================== */
.marquee{position:relative;z-index:3;overflow:hidden;border-block:1px solid var(--line);background:var(--ink);color:#fff}
.marquee>div{display:flex;width:max-content;gap:0;padding:16px 0;animation:scroll 38s linear infinite}
.marquee span{display:inline-flex;align-items:center;padding:0 28px;font-size:clamp(22px,3vw,42px);font-weight:900;letter-spacing:-.05em;line-height:1;text-transform:lowercase;white-space:nowrap}
.marquee span::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--purple-2);margin-left:26px}
.marquee span:nth-child(4n+2)::after{background:var(--green)}
.marquee span:nth-child(4n+3)::after{background:var(--pink)}
.marquee span:nth-child(4n)::after{background:var(--gold)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===========================================================
   FLAVOUR WORLDS  (cup + colour, no stock photography)
   =========================================================== */
.worlds{padding:clamp(72px,9vw,132px) var(--pad)}
.section-intro{max-width:1100px;margin-bottom:clamp(34px,5vw,56px)}
.section-intro .eyebrow{margin-bottom:18px}
.section-intro h2{font-size:clamp(44px,7vw,116px);letter-spacing:-.07em;line-height:.84}

.world-card{
  position:sticky;top:92px;display:grid;grid-template-columns:1.02fr .98fr;align-items:stretch;gap:clamp(24px,3vw,44px);
  padding:clamp(24px,4vw,60px);border-radius:var(--radius-xl);overflow:hidden;color:#fff;
  min-height:min(86vh,620px);margin-bottom:26px;box-shadow:var(--shadow);isolation:isolate;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.world-card:hover{
  transform:translateY(-4px);
  box-shadow:0 40px 100px -30px rgba(43,20,76,.25);
}
.world-card::before{content:"";position:absolute;inset:0;z-index:-2}
.world-card::after{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(60% 80% at 78% 24%,rgba(255,255,255,.16),transparent 60%),linear-gradient(90deg,rgba(0,0,0,.16),transparent 55%)}
.world-card.flow::before {background:linear-gradient(135deg,#150d30,#5e2aa2 60%,#2a1550)}
.world-card.focus::before{background:linear-gradient(135deg,#26371a,#7f9b3f 58%,#caa93f)}
.world-card.glow::before {background:linear-gradient(135deg,#4a1429,#ee6d9b 60%,#ffb6cd)}
.world-card.vital::before{background:linear-gradient(135deg,#5a2607,#ee8f24 58%,#ffcd80)}

/* alternate copy / photo sides */
.world-card.flow,.world-card.glow{grid-template-areas:"copy media"}
.world-card.focus,.world-card.vital{grid-template-areas:"media copy"}
.world-copy{grid-area:copy;display:flex;flex-direction:column;justify-content:center}
.world-media{grid-area:media;position:relative;margin:0;align-self:stretch;
  border-radius:24px;overflow:hidden;min-height:clamp(300px,42vh,560px);
  box-shadow:0 34px 60px -34px rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.16)}
.world-media picture{display:contents}
.world-media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.world-card:hover .world-media img{transform:scale(1.04)}

.flavor-code{margin-bottom:14px;font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.world-copy h3{font-size:clamp(46px,5.8vw,104px);letter-spacing:-.065em;line-height:.84;margin-bottom:18px}
.world-copy>p{max-width:46ch;color:rgba(255,255,255,.88);font-size:clamp(16px,1.4vw,19px);line-height:1.5}
.world-spec{margin-top:18px;font-size:12.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* full-bleed photo variant — copy floats in the image's negative space */
.world-card.is-photo{display:flex;align-items:center;padding:0;grid-template-columns:none}
.world-card.is-photo::before{display:none}
.world-card.is-photo::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg, rgba(10,8,20,.86) 0%, rgba(10,8,20,.52) 38%, rgba(10,8,20,0) 64%)}
.world-card.is-photo .world-media{position:absolute;inset:0;margin:0;border:0;border-radius:inherit;min-height:0;box-shadow:none;z-index:0;align-self:auto}
.world-card.is-photo .world-media img{width:100%;height:100%;object-fit:cover}
.world-card.is-photo:hover .world-media img{transform:scale(1.03)}
.world-card.is-photo .world-copy{position:relative;z-index:2;max-width:min(48%,560px);justify-content:center;padding:clamp(28px,5vw,76px)}
/* copy on the right (for images whose negative space is on the right) */
.world-card.is-photo.copy-right{justify-content:flex-end}
.world-card.is-photo.copy-right::after{background:linear-gradient(270deg, rgba(10,8,20,.86) 0%, rgba(10,8,20,.52) 38%, rgba(10,8,20,0) 64%)}

/* ===========================================================
   WHY AURA (bento — text benefits + ingredient close-ups)
   =========================================================== */
.benefits{padding:0 var(--pad) clamp(72px,9vw,132px)}
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:236px;gap:14px}
.panel{border-radius:var(--radius-lg);padding:30px;display:flex;flex-direction:column;justify-content:flex-end;gap:9px;box-shadow:var(--shadow-sm);color:#fff;transition:transform .4s var(--ease), box-shadow .4s var(--ease);border:1px solid rgba(255,255,255,0.08)}
.panel:hover{transform:translateY(-4px);box-shadow:0 24px 60px -20px rgba(43,20,76,.18)}
.panel span{font-weight:800;font-size:14px;letter-spacing:.12em;opacity:.7}
.panel h3{font-size:26px;letter-spacing:-.03em}
.panel p{font-size:15px;line-height:1.46;color:rgba(255,255,255,.86)}
.panel.dark{grid-column:span 2;grid-row:span 2;justify-content:center;gap:18px;
  background:radial-gradient(circle at 28% 22%,rgba(178,124,255,.4),transparent 60%),linear-gradient(140deg,#140a20,#221331)}
.panel.dark .eyebrow{align-self:flex-start;color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06)}
.panel.dark h2{font-size:clamp(32px,3.6vw,58px);letter-spacing:-.05em;line-height:.98}
.panel.purple{background:linear-gradient(140deg,#4f218d,#ac7cff)}
.panel.green {background:linear-gradient(140deg,#3a5720,#9fbd5d)}
.panel.pink  {background:linear-gradient(140deg,#9e244f,#f080a6)}
.panel.gold  {background:linear-gradient(140deg,#a85e10,#f4ab43)}
/* ingredient close-up image tiles inside the bento */
.panel.img{padding:0;overflow:hidden;position:relative;justify-content:flex-end}
.panel.img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.panel.img:hover img{transform:scale(1.06)}
.panel.img .cap{position:relative;z-index:1;margin:0;padding:16px 18px;color:#fff;font-family:Outfit,sans-serif;font-weight:700;font-size:14.5px;letter-spacing:-.01em;
  background:linear-gradient(0deg, rgba(0,0,0,.66) 0%, rgba(0,0,0,.1) 72%, transparent)}

/* ===========================================================
   WAITLIST
   =========================================================== */
.final{padding:0 var(--pad) clamp(72px,9vw,128px)}
.final-inner{
  position:relative;overflow:hidden;border-radius:48px;color:#fff;
  display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;gap:clamp(28px,4vw,64px);
  background:
    radial-gradient(circle at 18% 22%,rgba(179,127,255,.82),transparent 46%),
    radial-gradient(circle at 80% 14%,rgba(238,109,155,.7),transparent 44%),
    radial-gradient(circle at 58% 96%,rgba(241,154,40,.66),transparent 50%),
    #13091d;
  box-shadow:var(--shadow);border:1px solid rgba(255,255,255,0.08);
}
.final-copy{padding:clamp(40px,6vw,92px);display:flex;flex-direction:column;justify-content:center;text-align:left}
.final-media{position:relative;margin:0;min-height:480px;display:flex;align-items:center;justify-content:center;padding:clamp(24px,3.5vw,48px)}
.final-media img{width:auto;height:auto;max-width:100%;max-height:560px;object-fit:contain;filter:drop-shadow(0 26px 40px rgba(40,20,70,.22))}
.final-inner .capsule{color:#fff;border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.1);margin-bottom:22px;align-self:flex-start}
.final-inner h2{max-width:18ch;margin:0 0 16px;font-size:clamp(40px,4.4vw,80px);letter-spacing:-.06em;line-height:.9}
.final-copy>p{max-width:48ch;margin:0 0 30px;color:rgba(255,255,255,.78);font-size:clamp(16px,1.5vw,20px);line-height:1.5}
.final-signup{margin:0;width:min(100%,520px)}
.final-signup label{color:rgba(255,255,255,.7)}
.final-signup .signup-row{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22)}
.final-signup input{color:#fff}
.final-signup input::placeholder{color:rgba(255,255,255,.6)}
.final-signup button{background:var(--cream);color:var(--ink)}
.final-signup button:hover{background:#fff}
.final-signup .form-note{color:rgba(255,255,255,.62)}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:34px var(--pad);border-top:1px solid var(--line)}
.footer .wordmark{font-size:34px}
.footer p{color:var(--muted);font-size:14px}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1080px){
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:120px;text-align:center}
  .hero-copy{max-width:none;margin:0 auto}
  .hero-copy .capsule,.hero-lede{margin-inline:auto}
  .signup{margin-inline:auto}
  .trust{justify-content:center}
  .hero-stage{order:-1;min-height:340px}
  .hero-lineup{max-width:600px}
  .bento{grid-template-columns:1fr 1fr}
  .panel.dark{grid-row:auto;grid-column:span 2}
}
@media(max-width:720px){
  .site-nav{grid-template-columns:auto auto;gap:14px}
  .site-nav nav{display:none}
  .wordmark{font-size:34px}
  .hero h1{font-size:clamp(46px,13vw,72px)}
  .signup-row{grid-template-columns:1fr;border-radius:24px;padding:8px}
  .signup-row button{width:100%}
  .hero-stage{min-height:260px}
  .hero-lineup{max-width:460px}
  .world-card{position:relative;top:auto;grid-template-columns:1fr!important;grid-template-areas:"media" "copy"!important;min-height:0;margin-bottom:18px;text-align:center}
  .world-copy{grid-area:copy!important}
  .world-media{grid-area:media!important;min-height:300px;margin-bottom:20px}
  .world-copy>p{margin-inline:auto}
  /* full-bleed photo variant on mobile: copy sits at the bottom over a scrim */
  .world-card.is-photo{display:flex;align-items:flex-end;min-height:76vh;text-align:left}
  .world-card.is-photo::after,
  .world-card.is-photo.copy-right::after{background:linear-gradient(0deg, rgba(10,8,20,.92) 0%, rgba(10,8,20,.55) 32%, rgba(10,8,20,0) 62%)}
  .world-card.is-photo{justify-content:flex-start}
  .world-card.is-photo .world-media{min-height:0;margin-bottom:0}
  .world-card.is-photo .world-media img{object-position:center}
  .world-card.is-photo .world-copy{max-width:none;width:100%;padding:clamp(24px,6vw,40px);text-align:left}
  .world-card.is-photo .world-copy>p{margin-inline:0}
  .bento{grid-template-columns:1fr 1fr;grid-auto-rows:auto;gap:10px}
  .panel{min-height:0;grid-column:auto!important;padding:22px}
  .panel.dark{grid-column:1 / -1!important;grid-row:auto}
  .panel.img{min-height:200px}
  /* final CTA: stack copy over the machine, show the machine whole */
  .final-inner{grid-template-columns:1fr}
  .final-copy{padding:clamp(28px,7vw,40px)}
  .final-media{min-height:0;padding:clamp(8px,4vw,18px) 0 clamp(20px,5vw,30px)}
  .final-media img{max-width:80%;max-height:none}
  .footer{flex-direction:column;text-align:center;gap:12px}
}
/* TOUCH DEVICES — drop the expensive always-on effects that cause
   scroll jank on phones/tablets (fixed bg, blended grain overlay,
   animated blurred halos). Keep the cheap GPU-transform polish
   (lineup float, marquee, one-shot scroll reveals). */
@media (hover: none){
  html,body{background-attachment:scroll}
  .noise{display:none}
  .cursor-glow{display:none}
  .halo{animation:none;will-change:auto;filter:blur(46px);opacity:.5}
  .world-card:hover .world-media img{transform:none}
  .hero-lineup{animation-duration:8s}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
