:root{
  --base:#160b1b; --base2:#241131;
  --lilac:#cdb0ef; --wisteria:#b690de; --blush:#f6c4d8; --cream:#f7efe8;
  --muted:rgba(247,239,232,.62); --glow:rgba(180,131,224,.6);
  --display:'Fraunces',serif; --body:'Hanken Grotesk',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{
  font-family:var(--body);
  background:radial-gradient(120% 90% at 50% -10%, #2c1640 0%, var(--base) 55%, #0a060d 100%);
  color:var(--cream);position:fixed;inset:0;-webkit-font-smoothing:antialiased;
  filter:brightness(.18) saturate(.5);transition:filter 1s ease;
}

#purpleGlow{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .8s ease;
  background:radial-gradient(60% 45% at 50% 42%, rgba(180,131,224,.55), rgba(146,86,200,.18) 45%, transparent 72%);}
#purpleGlow.bloom{animation:bloom 2.4s ease-in-out infinite}
@keyframes bloom{0%,100%{opacity:.9}50%{opacity:1}}

.petals{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.petal{position:absolute;top:-8vh;width:14px;height:14px;
  background:radial-gradient(circle at 30% 30%, var(--blush), var(--wisteria));
  border-radius:80% 0 80% 0;opacity:0;filter:blur(.3px);animation:fall linear infinite}
@keyframes fall{
  0%{transform:translateY(-10vh) translateX(0) rotate(0)}
  10%{opacity:.7}90%{opacity:.6}
  100%{transform:translateY(110vh) translateX(40px) rotate(420deg);opacity:0}
}

#stage{position:fixed;inset:0;z-index:3}
.scene{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:64px 28px 130px;opacity:0;visibility:hidden;
  transform:translateY(22px) scale(.99);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1)
}
.scene.active{opacity:1;visibility:visible;transform:none}

.eyebrow{font-family:var(--body);font-weight:500;letter-spacing:.34em;text-transform:uppercase;
  font-size:11px;color:var(--lilac);margin-bottom:18px;opacity:.85}
h1{font-family:var(--display);font-weight:500;line-height:1.02;font-size:clamp(40px,12vw,72px);letter-spacing:-.01em}
h1 em{font-style:italic;color:var(--blush)}
h2{font-family:var(--display);font-weight:500;font-size:clamp(28px,8vw,44px);line-height:1.08}
.lead{font-size:clamp(16px,4.4vw,19px);color:var(--muted);max-width:30ch;line-height:1.6;margin-top:18px;font-weight:300}
.glow-text{text-shadow:0 0 30px var(--glow), 0 0 60px rgba(180,131,224,.25)}

.reveal{opacity:0;transform:translateY(14px)}
.scene.active .reveal{animation:rise .8s cubic-bezier(.2,.8,.2,1) forwards}
.scene.active .reveal.d1{animation-delay:.15s}
.scene.active .reveal.d2{animation-delay:.35s}
.scene.active .reveal.d3{animation-delay:.55s}
.scene.active .reveal.d4{animation-delay:.75s}
@keyframes rise{to{opacity:1;transform:none}}

/* ---------- candles ---------- */
.candle-row{display:flex;gap:clamp(14px,5vw,26px);justify-content:center;align-items:flex-end;margin:14px 0 6px}
.candle{display:flex;flex-direction:column;align-items:center;cursor:pointer}
.flame-wrap{height:54px;display:flex;align-items:flex-end;justify-content:center}
.flame{width:16px;height:0;border-radius:50% 50% 50% 50%/60% 60% 40% 40%;
  background:linear-gradient(to top,#b483e0,#d9b3ff 50%,#f3e3ff);
  transform-origin:bottom center;opacity:0;transition:height .25s ease, opacity .2s ease}
.candle.lit .flame{height:30px;opacity:1;animation:flicker .18s infinite alternate;
  box-shadow:0 0 18px 7px rgba(180,131,224,.75), 0 0 46px 16px rgba(146,86,200,.45)}
@keyframes flicker{
  from{transform:scaleY(1) rotate(-2deg) translateX(-1px)}
  to{transform:scaleY(1.12) rotate(2deg) translateX(1px)}
}
.stick{width:18px;height:84px;border-radius:6px;
  background:linear-gradient(180deg,#e9b8d6,#bf8ec9 60%,#9c6fb0);position:relative;box-shadow:inset -3px 0 6px rgba(0,0,0,.25)}
.stick::before{content:"";position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  width:2px;height:7px;background:#3a2a22;border-radius:2px}
.splash-hint{margin-top:24px;font-size:13px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;transition:.4s}

.cam-optin{margin-top:30px;display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;
  border:1px solid rgba(247,239,232,.16);background:rgba(255,255,255,.03);font-size:13px;color:var(--muted);cursor:pointer;user-select:none}
.cam-optin .dot{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--lilac);transition:.25s}
.cam-optin.on{border-color:var(--lilac);color:var(--cream)}
.cam-optin.on .dot{background:var(--lilac);box-shadow:0 0 10px var(--glow)}

/* ---------- photo frame ---------- */
.frame{width:min(76vw,330px);aspect-ratio:4/5;border-radius:18px;overflow:hidden;
  background:linear-gradient(135deg,#3a2148,#241131);
  box-shadow:0 26px 60px rgba(0,0,0,.5),0 0 0 1px rgba(247,239,232,.06),0 0 50px rgba(180,131,224,.2);
  display:grid;place-items:center;color:var(--muted)}
.frame img{width:100%;height:100%;object-fit:cover;display:block}
.frame .ph{font-size:13px;line-height:1.7;padding:20px;text-align:center}
.frame .ph .big{font-size:30px;display:block;margin-bottom:8px;opacity:.6}
.caption{font-family:var(--display);font-style:italic;font-size:clamp(18px,5vw,24px);margin-top:22px;max-width:24ch}

/* ---------- reasons ---------- */
#reasonText{font-family:var(--display);font-style:italic;font-size:clamp(24px,7vw,34px);
  max-width:18ch;line-height:1.2;min-height:2.4em;display:flex;align-items:center}
.counter{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:26px}
.tap-hint{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* ---------- ask ---------- */
.ask-box{width:min(82vw,360px);margin-top:6px;display:flex;flex-direction:column;gap:16px;align-items:center}
.ask-q{font-family:var(--display);font-style:italic;font-size:clamp(22px,6vw,30px);max-width:18ch;line-height:1.25;color:var(--blush)}
.ask-input{width:100%;min-height:100px;resize:none;border-radius:16px;padding:16px 18px;
  font-family:var(--body);font-size:16px;color:var(--cream);line-height:1.5;
  background:rgba(255,255,255,.05);border:1px solid rgba(247,239,232,.2);outline:none}
.ask-input::placeholder{color:rgba(247,239,232,.4)}
.ask-input:focus{border-color:var(--lilac);box-shadow:0 0 0 3px rgba(180,131,224,.25)}
.ask-save{border:none;cursor:pointer;font-family:var(--body);font-weight:600;font-size:16px;
  padding:13px 28px;border-radius:999px;color:#231032;
  background:linear-gradient(135deg,var(--lilac),var(--wisteria));
  box-shadow:0 10px 30px rgba(180,131,224,.45);transition:transform .18s}
.ask-save:active{transform:scale(.95)}
.ask-done{font-family:var(--display);font-style:italic;color:var(--blush);
  font-size:clamp(20px,5.5vw,26px);max-width:20ch;opacity:0;transform:translateY(8px);transition:.6s}
.ask-done.show{opacity:1;transform:none}

/* ---------- present + yes/no ---------- */
.present-line{font-family:var(--display);font-size:clamp(20px,5.4vw,27px);line-height:1.5;font-style:italic;max-width:28ch;color:var(--cream)}
.question{font-family:var(--display);font-size:clamp(22px,6vw,30px);margin:30px 0 8px;max-width:22ch;color:var(--blush)}
.yn{position:relative;width:100%;max-width:420px;height:130px;margin-top:10px}
.ynbtn{position:absolute;top:34px;border:none;cursor:pointer;font-family:var(--body);font-weight:600;
  font-size:17px;padding:14px 30px;border-radius:999px;transition:transform .18s ease, width .2s, font-size .2s}
#yesBtn{left:50%;transform:translateX(-115%);background:linear-gradient(135deg,var(--lilac),var(--wisteria));
  color:#231032;box-shadow:0 10px 30px rgba(180,131,224,.5)}
#noBtn{left:50%;transform:translateX(15%);background:rgba(255,255,255,.06);color:var(--muted);border:1px solid rgba(247,239,232,.2)}
.yn-after{font-family:var(--display);font-style:italic;font-size:clamp(22px,6vw,30px);color:var(--blush);
  opacity:0;transform:translateY(8px);transition:.7s;margin-top:8px}
.yn-after.show{opacity:1;transform:none}
.no-hint{font-size:.75rem;letter-spacing:.14em;color:var(--muted);margin-top:14px;font-style:italic}

/* ---------- carousel ---------- */
.carousel-frame{position:relative}
.carousel-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity .9s ease;border-radius:18px}
.carousel-img.active{opacity:1}
.carousel-dots{display:flex;gap:8px;justify-content:center;margin-top:10px}
.cdot{width:7px;height:7px;border-radius:50%;background:rgba(205,176,239,.3);transition:.4s}
.cdot.on{background:var(--lilac);width:20px;border-radius:4px}

/* ---------- finale ---------- */
#typed{font-family:var(--display);font-size:clamp(22px,6vw,30px);line-height:1.5;max-width:24ch;min-height:5em;white-space:pre-wrap}
#typed .cursor{display:inline-block;width:2px;height:1em;background:var(--blush);
  margin-left:2px;vertical-align:-2px;animation:blink .8s step-end infinite}
@keyframes blink{50%{opacity:0}}
#confetti{position:fixed;inset:0;pointer-events:none;z-index:4}
.save-clip{margin-top:30px;display:inline-flex;gap:10px;align-items:center;padding:13px 22px;border-radius:999px;
  border:1px solid var(--lilac);background:rgba(180,131,224,.14);color:var(--cream);font-size:14px;text-decoration:none;
  opacity:0;transform:translateY(8px);transition:.6s}
.save-clip.show{opacity:1;transform:none}

/* reply buttons */
.reply{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:28px;
  opacity:0;transform:translateY(8px);transition:.6s;pointer-events:none}
.reply.show{opacity:1;transform:none;pointer-events:auto}
.reply-btn{border:1px solid rgba(247,239,232,.22);background:rgba(255,255,255,.05);color:var(--cream);
  font-family:var(--body);font-weight:600;font-size:16px;padding:13px 26px;border-radius:999px;cursor:pointer;transition:transform .18s}
.reply-btn.primary{border:none;color:#231032;
  background:linear-gradient(135deg,var(--lilac),var(--wisteria));box-shadow:0 10px 30px rgba(180,131,224,.45)}
.reply-btn:active{transform:scale(.95)}
.endview{display:none;flex-direction:column;align-items:center}

/* ---------- navigation ---------- */
#nav{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:6;display:flex;align-items:center;gap:14px;
  padding:9px 14px;border-radius:999px;background:rgba(30,16,40,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(247,239,232,.12);box-shadow:0 12px 34px rgba(0,0,0,.4),0 0 26px rgba(180,131,224,.14);
  opacity:0;visibility:hidden;transition:.5s}
#nav.show{opacity:1;visibility:visible}
.navbtn{width:40px;height:40px;border-radius:50%;border:1px solid rgba(247,239,232,.18);background:rgba(255,255,255,.04);
  color:var(--cream);font-size:18px;cursor:pointer;display:grid;place-items:center;transition:.25s}
.navbtn:active{transform:scale(.9)}
.navbtn:disabled{opacity:.25;cursor:default}
.dots{display:flex;gap:7px;align-items:center;max-width:46vw;overflow:hidden}
.dot-i{width:7px;height:7px;border-radius:999px;background:rgba(247,239,232,.28);transition:.35s;flex:0 0 auto}
.dot-i.on{width:22px;background:var(--lilac);box-shadow:0 0 10px var(--glow)}

/* ---------- recording indicator ---------- */
#rec{position:fixed;top:16px;left:16px;z-index:7;display:none;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;
  background:rgba(20,10,26,.6);backdrop-filter:blur(8px);font-size:12px;letter-spacing:.06em}
#rec .rdot{width:9px;height:9px;border-radius:50%;background:#ff5d6c;animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.3}}
#mute{position:fixed;top:16px;right:16px;z-index:7;width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(247,239,232,.16);background:rgba(20,10,26,.5);backdrop-filter:blur(8px);
  color:var(--cream);font-size:16px;cursor:pointer;display:none;place-items:center}

@media (max-width:360px){.dots{max-width:40vw}#nav{gap:10px}}
