/* ============================================================
   Vooked — coming soon. Palette + type from the product's identity.
   ============================================================ */
:root{
  --pine:#0b3b34; --pine-700:#0e5045; --pine-600:#0e5f50;
  --brand:#0e6f5c; --brand-dark:#0a5647; --emerald:#1cad91;
  --paper:#f5f3ee; --paper2:#efece5;
  --ink:#16211d; --ink-soft:#3c4a44; --muted:#5f6f68; --muted-faint:#8a988f;
  --line:#e6ebe7; --gold:#d9a029;
  --cream:#eaf4f0; --cream-dim:#bcd6cd;

  --serif:"Instrument Serif",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,Menlo,monospace;

  --maxw:1200px;
  --gutter:clamp(1.1rem,4vw,2.4rem);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--emerald);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* Fine film grain for warmth (very subtle) */
.grain{
  position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- shared ---------- */
.eyebrow{
  font-family:var(--mono);font-size:.72rem;font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brand);
}
.eyebrow--light{color:var(--emerald)}
.logo{height:100%;width:auto;display:block}

/* ---------- one content column: every aligned block shares this exact
   left edge + width (content is --maxw wide, gutter on each side) ---------- */
.nav-wrap,.hero-inner,.features,.how-inner,.business-inner,.foot{
  width:100%;max-width:calc(var(--maxw) + 2 * var(--gutter));
  margin-inline:auto;padding-inline:var(--gutter);
}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;color:#fff;
  padding-block:1.1rem;
  transition:background .4s ease,backdrop-filter .4s ease,padding .4s ease,box-shadow .4s ease;
}
.nav.is-scrolled{
  background:rgba(9,42,37,.82);backdrop-filter:blur(12px);
  padding-block:.7rem;
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav-brand{height:31px}
.nav-links{display:flex;align-items:center;gap:1.6rem;font-size:.9rem;font-weight:500}
.nav-links a{color:var(--cream-dim);transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{
  color:#fff !important;border:1px solid rgba(255,255,255,.24);
  padding:.5rem 1rem;border-radius:999px;transition:border-color .2s,background .2s;
}
.nav-cta:hover{border-color:var(--emerald);background:rgba(28,173,145,.14)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;background:var(--pine);color:#fff;
  display:flex;flex-direction:column;justify-content:center;
  padding-block:clamp(7rem,13vh,9rem) clamp(3rem,6vh,5rem);
  overflow:hidden;isolation:isolate;
}
#scene{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-veil{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 90% at 22% 42%, rgba(11,59,52,.82) 0%, rgba(11,59,52,.35) 42%, rgba(11,59,52,0) 70%),
    linear-gradient(180deg, rgba(9,40,35,.55) 0%, rgba(9,40,35,0) 24%, rgba(9,40,35,.35) 100%);
}
.hero-inner{position:relative;z-index:2}
.hero-content{max-width:min(680px,100%)}

.hero-eyebrow{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;color:var(--cream-dim)}
.hero-eyebrow .coord{color:var(--emerald)}
.hero-eyebrow .dot{color:var(--emerald);opacity:.7}

.badge{
  display:inline-flex;align-items:center;gap:.5rem;margin-top:1.1rem;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:#eafff8;background:rgba(28,173,145,.12);border:1px solid rgba(28,173,145,.4);
  padding:.4rem .8rem;border-radius:999px;
}
.badge-pulse{width:7px;height:7px;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 0 rgba(28,173,145,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(28,173,145,.55)}70%{box-shadow:0 0 0 10px rgba(28,173,145,0)}100%{box-shadow:0 0 0 0 rgba(28,173,145,0)}}

.hero-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(3rem,8.4vw,6.6rem);line-height:.94;letter-spacing:-.01em;
  margin:1.5rem 0 0;text-shadow:0 2px 30px rgba(0,0,0,.28);
}
.hero-title .line{display:block;overflow:hidden;padding-bottom:.04em}
.hero-title .line-in{display:block;will-change:transform}
.hero-title em{font-style:italic;color:#8fe3cd}

.hero-sub{
  margin-top:1.6rem;max-width:34em;font-size:clamp(1rem,1.4vw,1.2rem);
  line-height:1.7;color:#dbeae4;
}

/* notify form — a flex "field" pill: input + button always share one height */
.notify{margin-top:2rem;max-width:34rem}
.notify-field{
  display:flex;align-items:stretch;gap:6px;padding:6px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:14px;
  transition:border-color .2s,background .2s;
}
.notify-field:focus-within{border-color:var(--emerald);background:rgba(28,173,145,.08)}
.notify-field input{
  flex:1;min-width:0;font-family:var(--sans);font-size:1rem;color:#fff;
  background:transparent;border:0;padding:.9rem 1rem;
}
.notify-field input:focus{outline:none}
.notify-field input::placeholder{color:rgba(219,234,228,.55)}
.notify-field button{
  flex:none;font-family:var(--sans);font-weight:700;font-size:.95rem;color:#fff;cursor:pointer;
  background:var(--emerald);border:0;border-radius:9px;padding:0 1.5rem;
  transition:background .2s,transform .15s ease;
}
.notify-field button:hover{background:#31c4a8}
.notify-field button:active{transform:translateY(1px)}
.notify-note{margin-top:.8rem;font-size:.82rem;color:rgba(219,234,228,.65)}
.notify-done{margin-top:.9rem;font-size:.95rem;font-weight:600;color:var(--emerald)}

.scroll-cue{
  position:relative;z-index:2;margin-top:3.4rem;
  display:inline-flex;align-items:center;gap:.8rem;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-dim);
}
.scroll-cue-line{width:54px;height:1px;background:linear-gradient(90deg,var(--emerald),transparent);position:relative;overflow:hidden}
.scroll-cue-line::after{content:"";position:absolute;inset:0;width:20px;background:var(--emerald);animation:cue 2s infinite}
@keyframes cue{0%{transform:translateX(-24px)}100%{transform:translateX(60px)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--pine-700);color:var(--cream);overflow:hidden;
  border-block:1px solid rgba(255,255,255,.06);
  padding:1.15rem 0;
}
.marquee-track{
  display:inline-flex;align-items:center;gap:1.6rem;white-space:nowrap;
  font-family:var(--serif);font-size:1.6rem;
  animation:scroll 42s linear infinite;will-change:transform;
}
.marquee-track i{color:var(--emerald);font-style:normal;font-size:.7em}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   FEATURES
   ============================================================ */
.features{padding-block:clamp(4.5rem,9vw,8rem)}
.section-head{max-width:36rem;margin-bottom:clamp(2.5rem,5vw,4.5rem)}
.section-title{
  font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.01em;
  font-size:clamp(2rem,4.6vw,3.4rem);margin-top:.9rem;color:var(--ink);
}

.feat{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,5vw,5rem);align-items:center;
  padding:clamp(2rem,4vw,3.5rem) 0;
}
.feat + .feat{border-top:1px solid var(--line)}
.feat--reverse .feat-copy{order:2}
.feat--reverse .feat-media{order:1}
.feat-kicker{color:var(--brand)}
.feat-title{
  font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.01em;
  font-size:clamp(1.9rem,3.6vw,3rem);margin:.8rem 0 0;color:var(--ink);
}
.feat-body{margin-top:1.1rem;max-width:30em;font-size:1.06rem;line-height:1.72;color:var(--ink-soft)}

.feat-media{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 30px 60px -34px rgba(11,59,52,.55);
  background:linear-gradient(135deg,var(--pine-700),var(--brand))}
.feat-media img{width:100%;height:clamp(320px,42vw,480px);object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.feat-media:hover img{transform:scale(1.04)}
.feat-media figcaption{
  position:absolute;left:14px;bottom:14px;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:#eafff8;
  background:rgba(9,40,35,.62);backdrop-filter:blur(6px);
  padding:.5rem .8rem;border-radius:10px;border:1px solid rgba(255,255,255,.12);
}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how{
  background:var(--paper2);border-block:1px solid var(--line);
  padding-block:clamp(4.5rem,9vw,8rem);
}
.how .section-head{max-width:36rem;margin:0 auto clamp(2.5rem,5vw,4rem);text-align:center}
.how .section-title{margin-inline:auto}
.steps{
  list-style:none;
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,4vw,3rem);
}
.step{position:relative;padding-top:2.6rem;border-top:2px solid var(--brand)}
.step-no{
  position:absolute;top:-.2rem;left:0;
  font-family:var(--mono);font-size:.8rem;letter-spacing:.1em;color:var(--brand);
}
.step-title{font-family:var(--serif);font-weight:400;font-size:1.9rem;color:var(--ink)}
.step-body{margin-top:.6rem;font-size:1.02rem;line-height:1.65;color:var(--ink-soft)}

/* ============================================================
   FOR BUSINESS
   ============================================================ */
.business{background:var(--pine);color:#fff;padding-block:clamp(4.5rem,9vw,8rem)}
.business-inner{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,6vw,5rem);align-items:center;
}
.business-title{
  font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.01em;
  font-size:clamp(2.1rem,4.6vw,3.6rem);margin:.9rem 0 0;
}
.business-body{margin-top:1.2rem;max-width:32em;font-size:1.08rem;line-height:1.72;color:#cfe6df}
.btn{
  display:inline-block;margin-top:1.8rem;font-weight:700;font-size:.98rem;
  padding:.95rem 1.6rem;border-radius:12px;transition:transform .15s ease,background .2s,box-shadow .2s;
}
.btn--paper{background:var(--emerald);color:#06251f}
.btn--paper:hover{background:#31c4a8;transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(28,173,145,.6)}

.business-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);border-radius:18px;overflow:hidden}
.stat{background:var(--pine-700);padding:1.7rem 1.4rem;display:flex;flex-direction:column;gap:.45rem}
.stat-fig{display:flex;align-items:baseline;gap:.1em}
.stat-num{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.2rem);line-height:1;color:#fff}
.stat-unit,.stat-prefix{font-family:var(--serif);font-size:1.7rem;line-height:1;color:var(--emerald)}
.stat-label{font-size:.82rem;color:#9dc4b8;line-height:1.4}

/* ============================================================
   FINAL / FOOTER
   ============================================================ */
.final{
  background:radial-gradient(120% 120% at 50% 0%, #0e5045 0%, var(--pine) 55%, #072a24 100%);
  color:#fff;padding:clamp(5rem,10vw,9rem) 0 2.5rem;text-align:center;
}
.final-inner{max-width:640px;margin-inline:auto;padding-inline:var(--gutter)}
.final-title{
  font-family:var(--serif);font-weight:400;line-height:1;letter-spacing:-.01em;
  font-size:clamp(2.6rem,7vw,5rem);margin:1rem 0 0;
}
.final-title em{font-style:italic;color:#8fe3cd}
.final-sub{margin:1.4rem auto 0;max-width:34em;font-size:1.08rem;line-height:1.7;color:#cfe6df}
.notify--big{margin:2.2rem auto 0}
.notify--big input{padding-block:1.15rem}

.foot{
  margin-top:clamp(4rem,8vw,6rem);
  padding-top:2.2rem;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.6rem;
}
.foot-brand{height:26px;color:#fff}
.foot-tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cream-dim)}
.foot-links{display:flex;gap:1.4rem;margin-left:auto;font-size:.9rem}
.foot-links a{color:var(--cream-dim);transition:color .2s}
.foot-links a:hover{color:#fff}
.foot-legal{flex-basis:100%;margin-top:.6rem;font-size:.8rem;color:#7fa298}

/* ============================================================
   scroll-reveal initial states (JS adds .is-in)
   ============================================================ */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].is-in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:860px){
  .nav-links a:not(.nav-cta){display:none}
  .feat{grid-template-columns:1fr;gap:1.6rem}
  .feat--reverse .feat-copy,.feat--reverse .feat-media{order:0}
  .business-inner{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:0}
  .step{border-top:none;border-left:2px solid var(--brand);padding:.2rem 0 1.8rem 1.4rem;margin-left:.2rem}
  .step-no{position:static;display:block;margin-bottom:.3rem}
}
/* Mobile: +50% side padding for extra breathing room (all sections read
   the --gutter token, so bumping it moves every edge in together). */
@media(max-width:640px){
  :root{--gutter:1.65rem}
}
@media(max-width:520px){
  .notify-field{flex-direction:column}
  .notify-field button{padding:.95rem}
  .marquee-track{font-size:1.25rem}
  .hero-eyebrow{font-size:.62rem;letter-spacing:.1em;gap:.35rem .5rem}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .marquee-track{animation:none}
  .badge-pulse,.scroll-cue-line::after{animation:none}
  [data-reveal]{opacity:1;transform:none;transition:none}
  .hero-title .line-in{transform:none !important}
}
