*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --choc-dark:#1A0A02;
  --choc-mid:#4A2208;
  --choc-warm:#7B3A0E;
  --choc-caramel:#C4813A;
  --choc-cream:#F5EAD8;
}
html{scroll-behavior:smooth}
body{background:var(--choc-dark);color:var(--choc-cream);font-family:'Lato',sans-serif;overflow-x:hidden;min-height:100vh}

/* FIXED CANVAS BG */
#choc-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.vignette{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 25%,rgba(15,4,0,0.78) 100%),
             linear-gradient(to bottom,rgba(15,4,0,0.55) 0%,transparent 20%,transparent 78%,rgba(15,4,0,0.65) 100%);
}
section,footer,nav{position:relative;z-index:2}

/* ── HERO ─────────────────────────────── */
.hero{
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:60px 24px 80px;text-align:center;overflow:hidden;
}
/* Parallax layers — needs relative positioning for transforms to work cleanly */
.logo-wrap,.brand-name,.brand-tagline,.hero-headline,.hero-sub,.form-wrap,.divider{
  position:relative;
}
.steam-container{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:3}
#hero-steam-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:3}

/* ── SHARED TRANSITION BAND ─────────── */
.section-transition{
  position:relative;z-index:5;height:0;overflow:visible;
}
.section-transition-inner{
  position:absolute;left:0;right:0;top:-260px;height:520px;pointer-events:none;z-index:10;
}
.trans-steam-canvas{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none;
}
/* Transition 1 (hero→scroll): dark top fades to transparent — no white added */
#trans-1 .trans-glow{
  position:absolute;inset:0;
  background:linear-gradient(
    to bottom,
    transparent 0%,
    rgba(196,129,58,0.03) 20%,
    rgba(215,160,80,0.09) 40%,
    rgba(230,190,130,0.16) 55%,
    rgba(240,210,160,0.28) 68%,
    rgba(245,220,175,0.18) 80%,
    transparent 100%
  );
}
/* Transition 2 (scroll→why): same but also fades to transparent */
#trans-2 .trans-glow{
  position:absolute;inset:0;
  background:linear-gradient(
    to bottom,
    transparent 0%,
    rgba(196,129,58,0.03) 20%,
    rgba(215,160,80,0.09) 40%,
    rgba(230,190,130,0.16) 55%,
    rgba(240,210,160,0.28) 68%,
    rgba(245,220,175,0.18) 80%,
    transparent 100%
  );
}
.trans-warm-radial{
  position:absolute;left:50%;top:30%;transform:translateX(-50%);
  width:90%;height:50%;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%,rgba(196,129,58,0.10) 0%,rgba(220,165,90,0.05) 42%,transparent 68%);
}
/* Fog: horizontal diffuse cloud at the seam line — no directional rise */
.trans-fog{
  position:absolute;left:-10%;right:-10%;top:34%;height:36%;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 100% at 15% 50%,rgba(225,200,158,0.42) 0%,transparent 65%),
    radial-gradient(ellipse 60% 100% at 38% 50%,rgba(232,210,170,0.38) 0%,transparent 65%),
    radial-gradient(ellipse 60% 100% at 62% 50%,rgba(228,206,164,0.40) 0%,transparent 65%),
    radial-gradient(ellipse 60% 100% at 85% 50%,rgba(230,208,166,0.38) 0%,transparent 65%);
  filter:blur(28px);
}

/* SVG LOGO SYMBOL */
.logo-wrap{position:relative;z-index:4;margin-bottom:8px;animation:fadeUp 1s ease both}
.logo-icon{width:110px;height:110px;filter:drop-shadow(0 8px 32px rgba(196,129,58,0.55))}

.brand-name{
  font-family:'Playfair Display',serif;font-size:clamp(32px,8vw,96px);font-weight:900;
  letter-spacing:-2px;color:var(--choc-cream);line-height:1;
  position:relative;z-index:4;animation:fadeUp 1s 0.1s ease both;
  text-shadow:0 4px 28px rgba(0,0,0,0.7);
}
.brand-tagline{
  font-size:clamp(9px,1.1vw,13px);font-weight:700;letter-spacing:0.35em;text-transform:uppercase;
  color:var(--choc-caramel);margin-bottom:clamp(24px,3vw,40px);position:relative;z-index:4;
  animation:fadeUp 1s 0.2s ease both;
}
.brand-tagline span{display:inline-block;width:40px;height:1px;background:var(--choc-caramel);vertical-align:middle;margin:0 12px;opacity:0.6}
.hero-headline{
  font-family:'Playfair Display',serif;font-size:clamp(18px,3.8vw,50px);font-weight:700;
  line-height:1.25;max-width:680px;position:relative;z-index:4;
  animation:fadeUp 1s 0.3s ease both;color:var(--choc-cream);
  text-shadow:0 2px 18px rgba(0,0,0,0.6);
}
.hero-headline em{font-style:italic;color:var(--choc-caramel)}
.hero-sub{
  font-size:clamp(13px,1.4vw,17px);font-weight:300;line-height:1.7;max-width:500px;margin:clamp(12px,2vw,18px) auto clamp(24px,3vw,40px);
  color:rgba(245,234,216,0.8);position:relative;z-index:4;
  animation:fadeUp 1s 0.4s ease both;text-shadow:0 1px 10px rgba(0,0,0,0.5);
}

/* HERO FORM */
.form-wrap{position:relative;z-index:4;animation:fadeUp 1s 0.5s ease both}
.waitlist-form{
  display:flex;gap:0;max-width:460px;width:100%;
  border:1.5px solid rgba(196,129,58,0.55);border-radius:60px;overflow:hidden;
  background:rgba(15,4,0,0.5);backdrop-filter:blur(14px);
  box-shadow:0 8px 40px rgba(0,0,0,0.55),inset 0 1px 0 rgba(255,255,255,0.06);
}
.waitlist-form input{
  flex:1;background:transparent;border:none;outline:none;
  padding:clamp(12px,1.5vw,16px) clamp(16px,2vw,24px);font-size:clamp(12px,1.2vw,15px);font-family:'Lato',sans-serif;color:var(--choc-cream);
}
.waitlist-form input::placeholder{color:rgba(245,234,216,0.4)}
.waitlist-form button{
  background:linear-gradient(135deg,var(--choc-caramel),var(--choc-warm));
  color:var(--choc-cream);border:none;padding:16px 28px;
  font-family:'Lato',sans-serif;font-size:clamp(10px,1.1vw,13px);font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;
  border-radius:0 60px 60px 0;transition:opacity 0.2s,transform 0.15s;white-space:nowrap;
}
.waitlist-form button:hover{opacity:0.88;transform:scale(1.02)}
.form-error{display:none;font-size:clamp(11px,1vw,13px);color:#e0714a;margin-top:10px;letter-spacing:0.3px}
.form-note{font-size:clamp(10px,1vw,12px);color:rgba(245,234,216,0.35);margin-top:12px;letter-spacing:0.5px}
.success-msg{display:none;color:var(--choc-caramel);font-family:'Playfair Display',serif;font-size:clamp(14px,1.6vw,20px);font-style:italic;animation:fadeUp 0.5s ease both}

.divider{display:flex;align-items:center;gap:16px;max-width:240px;margin:60px auto 0;opacity:0.3;position:relative;z-index:4}
.divider hr{flex:1;border:none;border-top:1px solid var(--choc-caramel)}

/* ── SCROLL VIDEO SECTION ─────────────── */
#scroll-section{position:relative}
#canvas-sticky{
  position:sticky;top:0;height:100vh;width:100%;
  overflow:hidden;
}

/* Video canvas: fixed native size, centred, never distorted */
#frame-canvas{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  /* actual px size set by JS — CSS just keeps it centred */
  z-index:2;
  border-radius:0;
  image-rendering:auto;
}
/* Sticky: pure white — the overlay gradient handles the atmospheric blend */
#canvas-sticky{
  background: #ffffff;
}

/* Left text overlay: dark on far left for readability, fades to transparent centre-right */
#canvas-sticky::after{
  content:'';
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    linear-gradient(to right,
      rgba(10,3,0,0.82) 0%,
      rgba(10,3,0,0.60) 22%,
      rgba(10,3,0,0.20) 42%,
      rgba(10,3,0,0.0) 58%
    );
}

/* Left text panel — overlaid on top of video */
.scroll-text-panel{
  position:absolute;
  left:0;top:0;width:48%;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 0 0 7vw;
  pointer-events:none;
  z-index:4;
}
.scroll-step{
  position:absolute;
  left:0;top:0;width:100%;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 4vw 0 7vw;
  opacity:0;
  transform:translateY(28px);
  filter:blur(6px);
  transition:opacity 0.75s cubic-bezier(0.25,0.46,0.45,0.94),transform 0.75s cubic-bezier(0.25,0.46,0.45,0.94),filter 0.75s cubic-bezier(0.25,0.46,0.45,0.94);
  pointer-events:none;
}
.scroll-step.active{opacity:1;transform:translateY(0);filter:blur(0px);pointer-events:auto}
.scroll-step.exit{opacity:0;transform:translateY(-20px);filter:blur(5px)}

.step-num{
  font-size:clamp(8px,0.9vw,11px);font-weight:700;letter-spacing:0.35em;text-transform:uppercase;
  color:var(--choc-caramel);margin-bottom:14px;opacity:0.9;
}
.step-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(16px,2.8vw,46px);font-weight:900;
  color:var(--choc-cream);line-height:1.15;margin-bottom:16px;
  text-shadow:0 2px 24px rgba(0,0,0,0.9);
}
.step-title em{color:var(--choc-caramel);font-style:italic}
.step-body{
  font-size:clamp(11px,1.2vw,17px);font-weight:300;line-height:1.8;
  color:rgba(245,234,216,0.8);max-width:360px;
  text-shadow:0 1px 14px rgba(0,0,0,0.85);
}

.scroll-hint-bottom{
  position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  font-size:clamp(8px,0.8vw,10px);letter-spacing:0.3em;text-transform:uppercase;
  color:rgba(245,234,216,0.4);z-index:5;pointer-events:none;
  transition:opacity 0.4s;
}

/* ── WHY SECTION ──────────────────────── */
.why-section{padding:100px 24px;max-width:1000px;margin:0 auto}
.section-label{font-size:clamp(9px,0.9vw,11px);font-weight:700;letter-spacing:0.35em;text-transform:uppercase;color:var(--choc-caramel);text-align:center;margin-bottom:16px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(20px,4vw,50px);font-weight:700;text-align:center;margin-bottom:clamp(32px,5vw,60px);color:var(--choc-cream)}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.card{
  background:rgba(255,255,255,0.04);border:1px solid rgba(196,129,58,0.18);
  border-radius:20px;padding:36px 32px;
  transition:transform 0.3s,border-color 0.3s,box-shadow 0.3s;
  position:relative;overflow:hidden;backdrop-filter:blur(6px);
}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--choc-warm),var(--choc-caramel));transform:scaleX(0);transition:transform 0.3s;transform-origin:left}
.card:hover{transform:translateY(-6px);border-color:rgba(196,129,58,0.4);box-shadow:0 20px 40px rgba(0,0,0,0.45)}
.card:hover::before{transform:scaleX(1)}
.card-icon{font-size:clamp(24px,3vw,36px);margin-bottom:20px;display:block}
.card h3{font-family:'Playfair Display',serif;font-size:clamp(15px,1.8vw,22px);font-weight:700;margin-bottom:12px;color:var(--choc-cream)}
.card p{font-size:clamp(12px,1.2vw,15px);line-height:1.7;color:rgba(245,234,216,0.6)}

/* ── BOTTOM CTA ───────────────────────── */
.bottom-cta{text-align:center;padding:80px 24px 100px;position:relative}
.bottom-cta::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;height:60px;background:linear-gradient(to bottom,transparent,rgba(196,129,58,0.4))}
.bottom-cta h2{font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,44px);margin-bottom:16px;color:var(--choc-cream)}
.bottom-cta p{color:rgba(245,234,216,0.55);font-size:clamp(13px,1.3vw,16px);margin-bottom:36px}
.cta-scroll-btn{display:inline-block;background:linear-gradient(135deg,var(--choc-caramel),var(--choc-warm));color:var(--choc-cream);border:none;padding:16px 40px;font-family:'Lato',sans-serif;font-size:clamp(10px,1.1vw,13px);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border-radius:60px;text-decoration:none;transition:opacity 0.2s,transform 0.15s}
.cta-scroll-btn:hover{opacity:0.88;transform:scale(1.02)}

footer{border-top:1px solid rgba(196,129,58,0.12);padding:32px 24px;text-align:center;font-size:clamp(10px,1vw,12px);color:rgba(245,234,216,0.25);letter-spacing:1px}
footer a{color:var(--choc-caramel);text-decoration:none;opacity:0.7;transition:opacity 0.2s}
footer a:hover{opacity:1}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:700px){
  /* Hero */
  .hero{padding:72px 20px 56px}
  .logo-icon{width:82px;height:82px}
  .brand-tagline{font-size:11px;letter-spacing:0.22em}
  .brand-tagline span{width:28px}
  .hero-headline{font-size:clamp(20px,5.5vw,50px)}
  .hero-sub{font-size:14px;margin-bottom:28px}
  .divider{margin-top:40px}

  /* Form — stack vertically, 16px input prevents iOS zoom */
  .waitlist-form{flex-direction:column;border-radius:16px}
  .waitlist-form input{padding:14px 20px;font-size:16px}
  .waitlist-form button{border-radius:0 0 16px 16px;padding:14px 20px;font-size:12px;letter-spacing:1px}
  .form-note{font-size:11px}
  .success-msg{font-size:15px}

  /* Why section */
  .why-section{padding:70px 20px}
  .section-label{font-size:11px;letter-spacing:0.25em}
  .section-title{font-size:clamp(22px,6vw,50px)}
  .cards{gap:16px}
  .card{padding:28px 22px}
  .card-icon{font-size:28px;margin-bottom:14px}

  /* Bottom CTA */
  .bottom-cta{padding:60px 20px 80px}
  .bottom-cta p{font-size:14px}
  .cta-scroll-btn{font-size:12px;padding:14px 32px;letter-spacing:1px}

  /* Footer */
  footer{font-size:11px;letter-spacing:0.5px}

  /* Scroll video section (unused in current template, kept for future) */
  .scroll-text-panel{width:100%;height:55%;top:auto;bottom:0;padding:0}
  .scroll-step{padding:1.5rem 1.8rem;top:auto;bottom:0;height:100%;justify-content:flex-start;padding-top:1.5rem}
  #canvas-sticky::after{background:linear-gradient(to top,rgba(10,3,0,0.88) 0%,rgba(10,3,0,0.60) 38%,rgba(10,3,0,0.08) 62%,transparent 78%)}
}
