:root{
  --blue-900:#0a1230;
  --blue-800:#16244e;
  --blue-700:#1b2f63;
  --blue-600:#23407a;
  --blue-500:#2f4f8f;
  --blue-200:#bcd0f5;
  --blue-100:#dbe6fb;
  --cream:#f7f4ec;
  --gold:#e6c25e;
  --gold-2:#d4ad4e;
  --gold-soft:rgba(230,194,94,.5);
  --ink:#1a2440;
  --maxw:600px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',sans-serif;
  background:var(--blue-800);
  color:var(--cream);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
section{position:relative;padding:84px 20px;overflow:hidden}
.wrap{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
.center{text-align:center}
.script-h{font-family:'Great Vibes',cursive;font-weight:400;color:var(--gold);font-size:clamp(40px,12vw,62px);line-height:1;margin-bottom:14px}
.kicker,.eyebrow{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:4px;color:var(--blue-200);font-size:13px}
.sub{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--blue-100);max-width:34ch;margin:0 auto 22px}
.sub.small{font-size:15px;color:var(--blue-200)}

/* ---------- top bar ---------- */
#topbar{
  position:fixed;top:0;left:0;width:100%;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 20px;
  background:linear-gradient(to bottom,rgba(10,18,48,.92),rgba(10,18,48,0));
  transform:translateY(-100%);transition:transform .4s ease;
}
#topbar.show{transform:translateY(0)}
.tb-mono{font-family:'Cormorant Garamond',serif;font-weight:600;letter-spacing:2px;color:var(--cream);font-size:18px}
.tb-mono span{color:var(--gold);margin:0 2px}
.tb-rsvp{
  font-family:'Jost',sans-serif;text-decoration:none;color:var(--blue-900);
  background:var(--gold);border-radius:30px;padding:6px 18px;font-size:13px;letter-spacing:1px;
}

/* ---------- hero ---------- */
#hero{
  height:100svh;min-height:600px;padding:0;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  text-align:center;background:var(--blue-800);
}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;touch-action:pan-y}
.hero-frame{position:absolute;inset:16px;border:1px solid var(--gold-soft);border-radius:8px;z-index:2;pointer-events:none}
.hero-top{position:absolute;top:14%;left:0;right:0;z-index:3;pointer-events:none;text-align:center;font-family:'Great Vibes',cursive;font-size:clamp(30px,9vw,42px);color:var(--gold);line-height:1}
.hero-inner{position:relative;z-index:3;margin-top:auto;pointer-events:none;padding:0 20px}
.eyebrow{display:block;line-height:1.7;margin-bottom:14px;font-weight:600;color:var(--cream);font-size:15px}
.inviters{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px;color:var(--blue-200);margin-bottom:16px}
.inviters span{font-style:normal;color:var(--gold);letter-spacing:1px}
.names{font-family:'Great Vibes',cursive;font-weight:400;color:var(--cream);font-size:clamp(48px,16vw,86px);line-height:.92}
.names span{display:block}
.divider{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px 0}
.divider span{width:46px;height:1px;background:var(--gold-soft)}
.divider i{width:8px;height:8px;background:var(--gold);transform:rotate(45deg)}
.date{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:3px;color:var(--blue-200);font-size:15px}
.hero-place{font-family:'Cormorant Garamond',serif;letter-spacing:1.5px;color:var(--gold);font-size:15px;margin-top:7px}
.countdown{display:flex;gap:14px;justify-content:center;margin-top:18px}
.countdown div{display:flex;flex-direction:column;align-items:center;min-width:46px}
.countdown b{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:30px;color:var(--gold)}
.countdown i{font-style:normal;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--blue-200)}
.tap-hint{position:relative;z-index:3;font-family:'Cormorant Garamond',serif;font-size:12px;letter-spacing:1.5px;color:#90a4cd;margin-top:18px;pointer-events:none}
.scroll-hint{position:relative;z-index:3;margin:14px auto 26px;width:26px;height:42px;border:1px solid var(--gold-soft);border-radius:14px;display:flex;justify-content:center;padding-top:8px}
.scroll-hint span{width:4px;height:8px;background:var(--gold);border-radius:2px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-4px)}50%{opacity:1}100%{opacity:0;transform:translateY(10px)}}

/* ---------- verse ---------- */
#verse{background:var(--blue-900);text-align:center}
.verse-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(22px,6vw,30px);color:var(--cream);margin:14px auto;max-width:24ch;line-height:1.5}
.verse-ref{font-family:'Cormorant Garamond',serif;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-size:13px}

/* ---------- story ---------- */
#story{background:var(--blue-800)}
.story-row{display:flex;flex-direction:column;gap:18px;margin-top:30px;align-items:center}
.story-img{width:100%;border-radius:10px;overflow:hidden;border:1px solid var(--gold-soft)}
.story-img img{width:100%;height:320px;object-fit:cover}
.story-text h3{font-family:'Cormorant Garamond',serif;font-weight:600;color:var(--gold);font-size:24px;margin-bottom:6px}
.story-text p{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--blue-100)}

/* ---------- details ---------- */
#details{background:var(--blue-900)}
.detail-cards{display:flex;flex-direction:column;gap:16px;margin:28px 0}
.card{background:rgba(47,79,143,.18);border:1px solid var(--gold-soft);border-radius:12px;padding:24px}
.card-ic{font-size:24px;color:var(--gold);display:block;margin-bottom:8px}
.card h3{font-family:'Cormorant Garamond',serif;text-transform:uppercase;letter-spacing:3px;font-size:14px;color:var(--blue-200);font-weight:500;margin-bottom:8px}
.card p{font-family:'Cormorant Garamond',serif;font-size:19px;color:var(--cream)}
.mini-btn{display:inline-block;margin-top:12px;font-size:12px;letter-spacing:1px;color:var(--gold);border:1px solid var(--gold-soft);border-radius:20px;padding:5px 14px;text-decoration:none}
.program{margin:10px auto 28px;max-width:360px;text-align:left}
.program-h{font-family:'Cormorant Garamond',serif;color:var(--gold);text-align:center;font-size:22px;margin-bottom:14px}
.timeline{list-style:none}
.timeline li{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid rgba(188,208,245,.15);font-family:'Cormorant Garamond',serif}
.timeline b{color:var(--gold);min-width:54px}
.timeline span{color:var(--blue-100);font-size:18px}

.btn-gold{display:inline-block;cursor:pointer;font-family:'Jost',sans-serif;letter-spacing:2px;text-transform:uppercase;font-size:13px;color:var(--blue-900);background:var(--gold);border:none;border-radius:30px;padding:13px 30px;text-decoration:none;transition:transform .15s ease,background .2s}
.btn-gold:hover{background:#f0d27a}
.btn-gold:active{transform:scale(.97)}
.btn-gold.sm{padding:9px 22px;font-size:12px}

/* ---------- gallery ---------- */
#gallery{background:var(--blue-800)}
.masonry{columns:2;column-gap:12px;margin-top:26px}
.masonry img{width:100%;margin-bottom:12px;border-radius:10px;border:1px solid rgba(230,194,94,.3);cursor:pointer;transition:transform .25s ease,box-shadow .25s}
.masonry img:hover{transform:translateY(-3px)}

/* ---------- puzzle ---------- */
#play{background:var(--blue-900)}
.puzzle-stage{display:flex;justify-content:center;margin-top:8px}
#pz-board{position:relative;width:270px;height:270px;border-radius:10px;overflow:hidden;border:1px solid var(--gold-soft);background:var(--blue-700)}
#pz-spark{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:9}
.puzzle-controls{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:18px}
.moves{font-family:'Cormorant Garamond',serif;letter-spacing:1px;color:var(--blue-200);font-size:16px}
.moves b{color:var(--gold)}

/* ---------- blessing ---------- */
#blessing{background:var(--blue-800)}
.blessing-form{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:420px;margin:0 auto 26px}
.blessing-form input{flex:1 1 100%;font-family:'Cormorant Garamond',serif;font-size:16px;padding:12px 16px;border-radius:30px;border:1px solid var(--gold-soft);background:rgba(255,255,255,.06);color:var(--cream)}
.blessing-form input::placeholder{color:#8ea4cf}
.candle-wall{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:10px}
.candle{width:120px;background:rgba(47,79,143,.16);border:1px solid var(--gold-soft);border-radius:10px;padding:14px 10px 12px;text-align:center;animation:rise .5s ease both}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.flame{width:14px;height:22px;margin:0 auto 8px;background:radial-gradient(ellipse at 50% 70%,#fff 0%,var(--gold) 35%,#e8861f 75%,transparent 78%);border-radius:50% 50% 48% 48%/60% 60% 40% 40%;transform-origin:50% 90%;animation:flick 1.3s ease-in-out infinite alternate;box-shadow:0 0 14px 3px rgba(230,194,94,.55)}
@keyframes flick{0%{transform:rotate(-3deg) scaleY(1)}100%{transform:rotate(3deg) scaleY(1.08)}}
.candle .c-msg{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:var(--cream);line-height:1.4}
.candle .c-name{font-family:'Jost',sans-serif;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-top:6px}

/* ---------- quiz ---------- */
#quiz{background:var(--blue-900)}
.quiz-app{max-width:440px;margin:18px auto 0}
.q-card{background:rgba(47,79,143,.16);border:1px solid var(--gold-soft);border-radius:14px;padding:24px}
.q-prog{font-family:'Jost';font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--blue-200);margin-bottom:10px}
.q-text{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--cream);margin-bottom:16px}
.q-opts{display:flex;flex-direction:column;gap:10px}
.q-opt{font-family:'Cormorant Garamond',serif;font-size:17px;text-align:left;color:var(--cream);background:rgba(255,255,255,.05);border:1px solid var(--gold-soft);border-radius:10px;padding:12px 16px;cursor:pointer;transition:background .2s}
.q-opt:hover{background:rgba(230,194,94,.12)}
.q-opt.right{background:rgba(110,200,140,.22);border-color:#7fd6a0}
.q-opt.wrong{background:rgba(220,90,90,.22);border-color:#e08a8a}
.q-result img{width:100%;border-radius:12px;border:1px solid var(--gold-soft);margin:14px 0}
.q-score{font-family:'Great Vibes',cursive;font-size:40px;color:var(--gold)}

/* ---------- rsvp ---------- */
#rsvp{background:var(--blue-800)}
.rsvp-form{display:flex;flex-direction:column;gap:12px;max-width:420px;margin:0 auto}
.rsvp-form input,.rsvp-form textarea{font-family:'Cormorant Garamond',serif;font-size:16px;padding:13px 16px;border-radius:12px;border:1px solid var(--gold-soft);background:rgba(255,255,255,.06);color:var(--cream);width:100%;resize:none}
.rsvp-form input::placeholder,.rsvp-form textarea::placeholder{color:#8ea4cf}
.seg{display:flex;gap:8px}
.seg-btn{flex:1;font-family:'Jost';letter-spacing:1px;font-size:13px;color:var(--blue-100);background:rgba(255,255,255,.05);border:1px solid var(--gold-soft);border-radius:12px;padding:12px;cursor:pointer;transition:.2s}
.seg-btn.active{background:var(--gold);color:var(--blue-900);font-weight:500}
.rsvp-thanks{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;color:var(--gold);margin-top:18px}

/* ---------- footer ---------- */
footer{background:var(--blue-900);text-align:center;padding:54px 20px 70px;border-top:1px solid rgba(230,194,94,.2)}
.f-mono{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:30px;letter-spacing:3px;color:var(--cream)}
.f-mono span{color:var(--gold)}
.f-names{font-family:'Great Vibes',cursive;font-size:30px;color:var(--gold);margin:6px 0}
.f-date{font-family:'Cormorant Garamond',serif;letter-spacing:3px;text-transform:uppercase;color:var(--blue-200);font-size:13px}
.f-actions{display:flex;gap:12px;justify-content:center;margin:22px 0 16px}
.ghost-btn{font-family:'Jost';font-size:13px;letter-spacing:1px;color:var(--gold);background:transparent;border:1px solid var(--gold-soft);border-radius:30px;padding:9px 22px;cursor:pointer;text-decoration:none}
.f-credit{font-family:'Cormorant Garamond',serif;font-style:italic;color:#7d8db0;font-size:14px}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,14,34,.95);display:flex;align-items:center;justify-content:center}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92vw;max-height:84vh;border-radius:10px;border:1px solid var(--gold-soft)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:transparent;border:none;color:var(--cream);cursor:pointer}
.lb-close{top:18px;right:22px;font-size:38px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);font-size:52px;color:var(--gold);padding:0 18px}
.lb-prev{left:4px}.lb-next{right:4px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

@media(min-width:560px){
  .story-row{flex-direction:row;text-align:left}
  .story-row.reverse{flex-direction:row-reverse}
  .story-img{flex:1}
  .story-text{flex:1}
  .detail-cards{flex-direction:row}
  .detail-cards .card{flex:1}
  .masonry{columns:3}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .flame,.scroll-hint span{animation:none}
  html{scroll-behavior:auto}
}
