/* ═══════ RESET & BASE ═══════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
html:focus-within{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;font-weight:400;color:var(--char);background:var(--cream);line-height:1.65;overflow-x:hidden;letter-spacing:.01em}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ═══════ VARS ═══════ */
:root{
  --cream:#f6f4fa;--cream2:#eee9f3;--blush:#f0ecf6;--sage:#e8edf5;
  --rose:#8b7eb5;--rose-dk:#6f64a0;--rose-lt:#b8b0d4;
  --lavender:#d5ccee;--lavender-lt:#ede9f8;--dusty-blue:#a8bed8;--dusty-blue-lt:#dce6f2;
  --gold:#b0a0d0;--gold-lt:#d8d0e8;
  --char:#2a2640;--gray:#6e6a80;--gray-lt:#ddd8ea;
  --fs:'Great Vibes',cursive;--ff:'Cormorant Garamond',serif;--fm:'Montserrat',sans-serif;
  --sh:0 4px 24px rgba(42,38,64,.07);--sh2:0 12px 48px rgba(42,38,64,.12);
  --glow:0 0 30px rgba(139,126,181,.15);
  --r:20px;--rs:12px;
}

/* ═══════ LAYOUT ═══════ */
.w{max-width:780px;margin:0 auto;padding:0 20px}
.wl{max-width:960px;margin:0 auto;padding:0 20px}
.ws{max-width:600px;margin:0 auto;padding:0 20px}
.sec{padding:90px 0}
.sec--c{background:var(--cream2)}.sec--m{background:var(--lavender-lt)}.sec--b{background:var(--blush)}

/* ═══════ TYPOGRAPHY ═══════ */
.t-scr{font-family:var(--fs);color:var(--rose);font-size:clamp(1.4rem,3vw,1.7rem);text-align:center;margin-bottom:6px}
.t-h{font-family:var(--ff);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:400;text-align:center;margin-bottom:14px;color:var(--char);letter-spacing:.02em}
.t-sub{color:var(--gray);text-align:center;font-size:.88rem;max-width:500px;margin:0 auto 28px;line-height:1.8}

/* divider */
.dv{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:44px}
.dv span{width:64px;height:1px;background:linear-gradient(90deg,transparent,var(--rose-lt),transparent)}
.dv svg{color:var(--rose);flex-shrink:0;width:16px;height:16px;filter:drop-shadow(0 0 6px rgba(181,131,141,.3))}
.heart-svg{fill:currentColor}
@keyframes heartFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.1)}}

/* btns */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:50px;font-size:.84rem;font-weight:500;transition:all .35s cubic-bezier(.25,.46,.45,.94);letter-spacing:.03em}
.btn-p{background:linear-gradient(135deg,var(--rose),var(--rose-dk));color:#fff;border:2px solid transparent}
.btn-p:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(181,131,141,.35);filter:brightness(1.05)}
.btn-o{color:var(--rose);border:2px solid var(--rose-lt);background:rgba(255,255,255,.6);backdrop-filter:blur(4px)}
.btn-o:hover{background:var(--blush);border-color:var(--rose);transform:translateY(-2px);box-shadow:var(--sh)}
.btn-f{width:100%}

/* inline SVG icons */
.ico{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;vertical-align:middle}
.ico svg{width:100%;height:100%}

/* ═══════ ANIMATIONS ═══════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@keyframes float{0%,100%{opacity:.15;transform:translateY(0) scale(var(--s,1))}50%{opacity:.4;transform:translateY(-25px) scale(var(--s,1))}}
@keyframes spinIn{from{opacity:0;transform:rotate(-20deg) scale(.8)}to{opacity:1;transform:rotate(0) scale(1)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 8px rgba(139,126,181,.2),0 0 20px rgba(168,190,216,.1)}50%{box-shadow:0 0 16px rgba(139,126,181,.4),0 0 40px rgba(168,190,216,.2)}}

.sf{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94)}
.sf.v{opacity:1;transform:translateY(0)}

/* ═══════ LANG & MUSIC ═══════ */
.lang-btn{position:fixed;top:18px;right:18px;z-index:1001;display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:50px;border:1px solid rgba(0,0,0,.12);background:rgba(255,255,255,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);transition:all .3s}
.lang-btn:hover{color:var(--char);border-color:var(--char)}
.mus-btn{position:fixed;bottom:20px;right:20px;z-index:1001;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .3s;box-shadow:var(--sh);cursor:pointer}
.mus-btn:hover{transform:scale(1.1)}.mus-btn.on{border-color:var(--rose);box-shadow:0 0 0 4px rgba(200,144,126,.2)}

/* ═══════ HERO ═══════ */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;overflow:hidden}
.hero__grad{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,var(--lavender-lt) 0%,var(--cream) 40%,var(--dusty-blue-lt) 100%);transition:opacity 1s}
.hero__vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
@media(min-width:768px){.hero__vid{width:600px;left:50%;transform:translateX(-50%);right:auto;border-radius:0 0 var(--r) var(--r);box-shadow:var(--sh2)}}
.hero__grad::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 25%,rgba(139,126,181,.08),transparent 55%),radial-gradient(ellipse at 70% 75%,rgba(168,190,216,.08),transparent 55%)}
.hero__ov{position:absolute;inset:0;background:rgba(246,244,250,.35);z-index:2}
.hero__fl{position:absolute;inset:0;pointer-events:none;z-index:3}
.hero__fl span{position:absolute;color:var(--rose-lt);animation:float var(--dur,5s) ease-in-out infinite;animation-delay:var(--del,0s)}
.hero__c{position:relative;z-index:4;text-align:center;padding:40px 20px 20px;margin-top:0;animation:fadeUp .9s ease .3s both}
.hero__pre{font-size:.72rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gray);margin-bottom:14px}
.hero__h1{font-family:var(--fs);font-size:clamp(2.4rem,7.5vw,4.2rem);color:var(--char);line-height:1.2;margin-bottom:8px;font-weight:400;letter-spacing:0.02em}
.hero__h1 .amp{margin:0 .2em;font-size:.45em;color:var(--rose-lt);display:inline-block;vertical-align:middle;opacity:.5}
.hero__dt{position:absolute;bottom:150px;left:0;right:0;text-align:center;font-family:var(--fs);font-size:clamp(1.2rem,4vw,1.8rem);font-weight:400;letter-spacing:.05em;text-transform:none;color:var(--char);z-index:5;animation:fadeUp 1s ease .6s both;text-shadow:0 0 12px var(--lavender),0 0 24px var(--lavender)}
/* Play button */
.hero__play{position:absolute;bottom:36px;left:0;right:0;margin:0 auto;width:fit-content;z-index:5;display:flex;flex-direction:column;align-items:center;gap:12px;animation:fadeUp 1s ease .8s both;cursor:pointer;background:none;border:none}
.hero__play.hide{display:none}
.hero__play-circle{width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:var(--rose);box-shadow:0 4px 30px rgba(139,126,181,.25),0 0 0 0 rgba(139,126,181,.3);transition:all .3s;animation:playPulse 2s infinite}
.hero__play:hover .hero__play-circle{transform:scale(1.1);box-shadow:0 6px 40px rgba(139,126,181,.35)}
.hero__play-text{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray);text-shadow:0 1px 4px rgba(255,255,255,.8)}
.hero__scroll-hint{position:absolute;bottom:30px;left:0;right:0;display:none;flex-direction:column;align-items:center;gap:8px;color:#fff;z-index:10;opacity:0;animation:fadeUp .8s ease .3s both}
.hero__scroll-hint.show{display:flex}
.hero__scroll-hint span{font-size:.9rem;letter-spacing:.22em;text-transform:uppercase;color:var(--lavender);text-shadow:0 2px 10px rgba(139,126,181,.6),0 0 20px rgba(139,126,181,.3);font-weight:500}
.hero__scroll-hint svg{width:22px;height:22px;animation:bounce 2s infinite;opacity:.9;color:var(--lavender);filter:drop-shadow(0 2px 6px rgba(139,126,181,.5))}
@keyframes playPulse{0%{box-shadow:0 4px 30px rgba(139,126,181,.25),0 0 0 0 rgba(139,126,181,.3)}70%{box-shadow:0 4px 30px rgba(139,126,181,.25),0 0 0 20px rgba(139,126,181,0)}100%{box-shadow:0 4px 30px rgba(139,126,181,.25),0 0 0 0 rgba(139,126,181,0)}}

/* ═══════ INVITATION ═══════ */
.inv__title{font-family:var(--fs);font-size:clamp(2rem,6vw,3.2rem);color:var(--char);margin-bottom:10px;opacity:0;transform:translateY(20px)}
.sf.v .inv__title{animation:invFadeUp .8s ease forwards}
.inv__text{font-family:var(--ff);font-style:italic;font-size:clamp(.92rem,2.5vw,1.05rem);color:var(--gray);line-height:2.2;max-width:520px;margin:0 auto 20px;opacity:0;transform:translateY(20px)}
.sf.v .inv__text{animation:invFadeUp .8s ease .3s forwards}
.inv__cta{font-family:var(--ff);font-size:clamp(.95rem,2.5vw,1.1rem);font-weight:600;color:var(--rose-dk);max-width:520px;margin:0 auto;line-height:1.9;letter-spacing:.01em;opacity:0;transform:translateY(20px)}
.sf.v .inv__cta{animation:invFadeUp .8s ease .6s forwards}
.inv__names{font-family:var(--fs);font-size:clamp(1.8rem,5vw,2.6rem);color:var(--char);margin-top:24px;margin-bottom:10px;opacity:0;transform:translateY(20px)}
.inv__names .amp{color:var(--rose);font-size:.6em;margin:0 .15em}
.sf.v .inv__names{animation:invFadeUp .8s ease .8s forwards}
@keyframes invFadeUp{to{opacity:1;transform:translateY(0)}}

/* ═══════ COUNTDOWN ═══════ */
.hg{display:flex;justify-content:center;margin-bottom:36px;position:relative}
.hg::after{content:'';position:absolute;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(168,190,216,.2),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:hgGlow 3s ease-in-out infinite;pointer-events:none}
@keyframes hgGlow{0%,100%{opacity:.4;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.6)}}
.hg__svg{filter:drop-shadow(0 6px 28px rgba(139,126,181,.2)) drop-shadow(0 0 12px rgba(168,190,216,.15));animation:hgFloat 5s ease-in-out infinite;position:relative;z-index:1}
@keyframes hgFloat{0%,100%{transform:translateY(0) rotate(0)}30%{transform:translateY(-6px) rotate(.8deg)}70%{transform:translateY(-3px) rotate(-.8deg)}}
.cd{display:flex;align-items:center;justify-content:center;gap:6px}
.cd__item{display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(255,255,255,.7);backdrop-filter:blur(8px);border:1px solid var(--lavender);border-radius:var(--r);padding:10px 0;width:92px;height:92px;box-shadow:var(--sh);text-align:center}
.cd__num{font-family:var(--ff);font-size:clamp(2rem,5vw,2.8rem);font-weight:500;color:var(--rose);line-height:1;margin-bottom:8px}
.cd__lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gray)}
.cd__sep{font-family:var(--ff);font-size:2rem;color:var(--rose-lt);padding:0 2px}

/* ═══════ TIMELINE ═══════ */
.tl{position:relative;max-width:700px;margin:0 auto;padding:20px 0}
.tl__line{position:absolute;left:18px;top:0;bottom:30px;width:2px;background:linear-gradient(to bottom,var(--rose-lt),var(--lavender),transparent)}
.tl__i{position:relative;padding-left:54px;margin-bottom:44px}
.tl__i:last-of-type{margin-bottom:0}
.tl__dot{position:absolute;left:12px;top:6px;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--rose-lt));border:3px solid var(--cream2);z-index:1;transition:transform .6s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 12px rgba(181,131,141,.25)}
.sf.v .tl__dot{transform:scale(1.3)}
.tl__c{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--r);padding:28px;box-shadow:var(--sh);border:1px solid rgba(181,131,141,.08);transition:all .4s cubic-bezier(.25,.46,.45,.94)}
.tl__c:hover{box-shadow:var(--sh2),var(--glow);transform:translateY(-4px)}
.tl__yr{font-family:var(--fs);font-size:2rem;color:var(--rose);display:block;margin-bottom:2px}
.tl__h3{font-family:var(--ff);font-size:1.45rem;font-weight:500;margin-bottom:8px}
.tl__p{font-family:var(--ff);font-style:italic;color:var(--gray);line-height:1.9;font-size:1rem}
.tl__end{text-align:center;margin-top:20px;color:var(--rose)}
@media(min-width:768px){
  .tl__line{left:50%;transform:translateX(-50%)}
  .tl__i{padding-left:0;width:50%}
  .tl__i[data-s="l"]{padding-right:38px;text-align:right}
  .tl__i[data-s="r"]{padding-left:38px;margin-left:50%}
  .tl__i[data-s="l"] .tl__dot{right:-7px;left:auto}
  .tl__i[data-s="r"] .tl__dot{left:-8px}
}

/* ═══════ PROGRAM ═══════ */
.prg{margin-top:32px;padding-bottom:10px}
/* desktop */
@media(min-width:768px){
  .prg{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;position:relative;align-items:start}
  .prg::before{content:'';position:absolute;top:60px;left:calc(100%/12);right:calc(100%/12);height:2px;background:linear-gradient(90deg,var(--lavender),var(--rose-lt),var(--lavender));border-radius:1px}
  .prg__m{display:none}
}
/* mobile */
@media(max-width:767px){
  .prg__d{display:none!important}
  .prg__m{display:block;position:relative;padding-left:42px}
  .prg__m::before{content:'';position:absolute;left:22px;top:0;bottom:0;width:1px;background:var(--gray-lt)}
}
.prg__i{text-align:center;display:flex;flex-direction:column;align-items:center;position:relative}
.prg__time{background:linear-gradient(135deg,var(--rose),var(--rose-dk));color:#fff;font-size:.72rem;font-weight:600;padding:5px 14px;border-radius:20px;margin-bottom:12px;display:inline-block;box-shadow:0 2px 8px rgba(181,131,141,.25);white-space:nowrap}
.prg__ico{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.95);border:2px solid var(--lavender);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:12px;z-index:1;box-shadow:var(--sh);transition:all .35s cubic-bezier(.25,.46,.45,.94);flex-shrink:0}
.prg__i:hover .prg__ico{border-color:var(--rose);transform:scale(1.15);box-shadow:0 6px 20px rgba(181,131,141,.25)}
.prg__nm{font-family:var(--ff);font-size:.9rem;margin-bottom:2px;line-height:1.3}
.prg__ds{font-size:.68rem;color:var(--gray);padding:0 4px}
/* mobile items */
.prg__mi{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}
.prg__mi .prg__ico{flex-shrink:0;margin-bottom:0;width:42px;height:42px}
.prg__mi-body{padding-top:4px}.prg__mi-body strong{font-family:var(--ff);font-size:1.05rem;display:block;margin-bottom:2px}
.prg__mi-body small{font-size:.78rem;color:var(--gray)}

/* ═══════ GIFTS ═══════ */
.acc{border:2px solid var(--rose-lt);border-radius:var(--r);overflow:hidden;background:rgba(255,255,255,.8);backdrop-filter:blur(8px)}
.acc__hd{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 24px;background:linear-gradient(135deg,var(--lavender),var(--dusty-blue));color:#fff;font-family:var(--ff);font-size:1.15rem;transition:all .4s;border:none;cursor:pointer;border-radius:var(--r) var(--r) 0 0}.acc__hd:hover{filter:brightness(1.06);box-shadow:0 4px 20px rgba(168,190,216,.3)}
.acc__arr{transition:transform .6s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;color:#fff}.acc__arr.open{transform:rotate(180deg)}
.acc__bd{max-height:0;overflow:hidden;transition:max-height 1.2s cubic-bezier(.4,0,.15,1),padding 1s cubic-bezier(.4,0,.15,1),opacity .8s ease;padding:0 22px;opacity:0}
.acc__bd.open{max-height:700px;padding:18px 22px 24px;opacity:1}
.acc__bd p{color:var(--gray);font-size:.88rem;line-height:1.65;margin-bottom:6px}
.wish-list{list-style:none;padding:0;margin:12px 0 0}
.wish-list li{padding:10px 14px;margin-bottom:6px;background:var(--lavender-lt);border:1px solid var(--lavender);border-radius:var(--rs);color:var(--char);font-size:.88rem;display:flex;align-items:center;gap:10px;transition:all .3s}
.wish-list li:hover{background:var(--dusty-blue-lt);transform:translateX(4px)}
.wish-list li::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--rose-lt);flex-shrink:0}

/* ═══════ DETAILS ═══════ */
.cards-grid{display:grid;gap:24px;margin-bottom:28px;max-width:900px;margin-left:auto;margin-right:auto}
@media(min-width:768px){.cards-grid{grid-template-columns:1fr 1fr;align-items:start}}
.card{background:linear-gradient(145deg,rgba(255,255,255,.9),var(--lavender-lt));backdrop-filter:blur(8px);border:1px solid rgba(181,131,141,.1);border-radius:var(--r);padding:36px 24px;text-align:center;box-shadow:var(--sh);margin-bottom:0;transition:all .4s}.card:hover{box-shadow:var(--sh2),var(--glow);transform:translateY(-2px)}
.card__ico{font-size:2.5rem;margin-bottom:10px;display:flex;align-items:center;justify-content:center}
.card__ico svg{width:40px;height:40px}
.card__h{font-family:var(--ff);font-size:1.4rem;margin-bottom:12px;font-weight:500}
.card__info{color:var(--gray);margin-bottom:14px;line-height:2;font-size:.88rem}
.card__map{margin-bottom:14px;border-radius:12px;overflow:hidden;box-shadow:var(--sh)}
.card__map iframe{height:180px}
.card__desc{color:var(--gray);font-size:.82rem;margin-bottom:14px;line-height:1.7;max-width:460px;margin-left:auto;margin-right:auto}
.card__btns{display:flex;gap:8px;justify-content:center}
.card__btns .btn{flex:1;min-width:0;text-align:center;padding:11px 8px;font-size:.72rem;white-space:nowrap}

/* Dress code with shimmer/glow */
.dress{background:linear-gradient(135deg,#d5ccee,#a8bed8,#e8edf5,#b8b0d4,#dce6f2,#d5ccee);background-size:400% 400%;animation:dressGlow 5s ease-in-out infinite;border-radius:var(--r);padding:32px;text-align:center;position:relative;box-shadow:0 0 25px rgba(139,126,181,.15)}
@keyframes dressGlow{0%{background-position:0% 50%;box-shadow:0 0 20px rgba(139,126,181,.15)}25%{background-position:50% 0%}50%{background-position:100% 50%;box-shadow:0 0 45px rgba(168,190,216,.3)}75%{background-position:50% 100%}100%{background-position:0% 50%;box-shadow:0 0 20px rgba(139,126,181,.15)}}
.dress__type{font-family:var(--ff);font-size:1.15rem;color:var(--gray);margin-bottom:6px}
.dress__sub{color:var(--gray);font-size:.86rem;margin-bottom:16px}
.dress__pal{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.dress__pal span{width:46px;height:46px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 10px rgba(0,0,0,.12);transition:transform .2s}.dress__pal span:hover{transform:scale(1.25)}

/* ═══════ RSVP ═══════ */
.rsvp-form{background:rgba(255,255,255,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--r);padding:36px 28px;box-shadow:var(--sh);border:1px solid rgba(181,131,141,.08)}
.fg{margin-bottom:20px}
.fg label{display:block;font-weight:500;margin-bottom:5px;font-size:.86rem;color:var(--char)}
.fg input[type="text"],.fg input[type="email"],.fg select,.fg textarea{width:100%;padding:12px 16px;border:2px solid var(--lavender);border-radius:var(--rs);font-size:1rem;transition:all .3s;background:rgba(255,255,255,.7);color:var(--char)}.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 4px rgba(181,131,141,.1);background:#fff}.fg textarea{resize:vertical}
.rsvp-rad{display:flex;gap:12px;flex-wrap:wrap}
.rad{display:flex;align-items:center;justify-content:center;cursor:pointer;padding:14px 18px;border:2px solid var(--lavender);border-radius:var(--rs);transition:all .35s;font-size:.86rem;flex:1;background:rgba(255,255,255,.5);text-align:center;font-weight:500}
.rad:has(input:checked){border-color:var(--rose);background:linear-gradient(135deg,var(--blush),var(--lavender-lt));box-shadow:0 0 0 3px rgba(181,131,141,.15);color:var(--rose-dk)}
.rad:hover{border-color:var(--rose-lt);background:var(--lavender-lt)}
.rad input{position:absolute;opacity:0;width:0;height:0}
.rsvp-extra{max-height:0;overflow:hidden;transition:max-height .5s ease}.rsvp-extra.open{max-height:700px}
.rsvp-thx{text-align:center;padding:60px 20px;animation:fadeUp .8s ease both}
.rsvp-thx p{color:var(--gray);font-size:1.05rem;line-height:1.8;margin-bottom:10px}
.rsvp-sig{font-family:var(--fs)!important;font-size:2.2rem!important;color:var(--rose)!important;margin:22px 0!important}

/* ═══════ QUESTIONS ═══════ */
.qst{text-align:center;background:linear-gradient(135deg,#d5ccee,#a8bed8,#e8edf5,#b8b0d4,#dce6f2,#d5ccee);background-size:400% 400%;animation:dressGlow 5s ease-in-out infinite;border-radius:var(--r);padding:32px;box-shadow:0 0 25px rgba(139,126,181,.15)}
.qst h3{font-family:var(--ff);font-size:1.4rem;margin-bottom:6px}.qst>p{color:var(--gray);margin-bottom:14px;font-size:.9rem}
.qst__l{display:flex;flex-wrap:wrap;gap:18px;justify-content:center}
.qst__l a{color:var(--rose);font-weight:500;transition:color .3s;display:inline-flex;align-items:center;gap:6px}.qst__l a:hover{color:var(--rose-dk)}

/* ═══════ FOOTER ═══════ */
.ftr{background:linear-gradient(135deg,#2a2640 0%,#352d4a 50%,#2a2640 100%);color:#fff;text-align:center;padding:56px 20px}
.ftr__h{font-family:var(--fs);font-size:clamp(2.2rem,6vw,3rem);margin-bottom:6px;background:linear-gradient(135deg,var(--rose-lt),var(--gold-lt));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ftr__d{color:rgba(255,255,255,.4);font-size:.85rem;margin-bottom:24px;letter-spacing:.15em}
.ftr__love{display:flex;align-items:center;justify-content:center;gap:7px;color:rgba(255,255,255,.3);font-size:.8rem;margin-bottom:12px}
.ftr__love a{color:var(--rose-lt);text-decoration:none;transition:color .3s}.ftr__love a:hover{color:var(--gold-lt)}
.ftr__up{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.5);margin-bottom:20px;transition:all .3s}.ftr__up:hover{color:#fff;border-color:rgba(255,255,255,.5);transform:translateY(-3px)}

/* ═══════ CONFETTI ═══════ */
.cnf{position:fixed;z-index:10000;pointer-events:none}

/* ═══════ RESPONSIVE ═══════ */
/* ═══════ TABLET ═══════ */
@media(max-width:900px){
  .wl{max-width:100%;padding:0 16px}
  .cards-grid{gap:16px}
  .card{padding:28px 18px}
  .card__h{font-size:1.2rem}
  .card__map iframe{height:160px}
  .cd__item{width:82px;height:82px}
}
/* ═══════ MOBILE ═══════ */
@media(max-width:600px){
  .sec{padding:52px 0}
  .w,.wl,.ws{padding:0 16px}
  /* Hero */
  .hero{min-height:100svh}
  .hero__c{padding:30px 16px 16px}
  .hero__dt{bottom:130px}
  .hero__play{bottom:28px;gap:8px}
  .hero__play-circle{width:56px;height:56px}
  .hero__play-text{font-size:.6rem}
  .hero__scroll-hint{bottom:24px}
  .hero__scroll-hint span{font-size:.75rem}
  /* Invitation */
  .inv__text,.inv__cta{padding:0 8px}
  /* Countdown */
  .cd{gap:4px}
  .cd__item{width:72px;height:72px;padding:8px 0}
  .cd__num{font-size:1.6rem;margin-bottom:6px}
  .cd__sep{font-size:1.4rem;padding:0 1px}
  .hg__svg{width:140px;height:auto}
  /* Timeline */
  .tl{padding:14px 0}
  .tl__i{padding-left:44px;margin-bottom:30px}
  .tl__dot{left:10px}
  .tl__c{padding:20px}
  .tl__yr{font-size:1.6rem}
  .tl__h3{font-size:1.2rem}
  .tl__p{font-size:.88rem;line-height:1.7}
  /* Program */
  .prg__mi .prg__ico{width:36px;height:36px}
  .prg__mi-body strong{font-size:.95rem}
  /* Cards */
  .cards-grid{grid-template-columns:1fr}
  .card{padding:28px 18px}
  .card__ico svg{width:32px;height:32px}
  .card__h{font-size:1.2rem;margin-bottom:10px}
  .card__info{font-size:.84rem;line-height:1.9;margin-bottom:12px}
  .card__map iframe{height:150px}
  .card__btns{gap:6px}
  .card__btns .btn{padding:10px 6px;font-size:.65rem}
  /* Dress code */
  .dress__pal{gap:8px}
  .dress__pal span{width:38px;height:38px}
  /* RSVP */
  .rsvp-form{padding:22px 16px}
  .rsvp-rad{flex-direction:column}
  .rad{width:100%}
  .fg select{font-size:16px;padding:14px 16px}
  .fg select option{font-size:18px;padding:12px;min-height:44px}
  /* Gifts */
  .acc__hd{padding:14px 18px;font-size:1rem}
  .wish-list li{padding:8px 12px;font-size:.82rem}
  /* Footer */
  .ftr__love{font-size:.7rem}
  .snav{display:none}
}

/* ═══════ STICKY NAV ═══════ */
.snav{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(246,244,250,.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:10px 20px;display:flex;align-items:center;justify-content:center;transform:translateY(-100%);transition:transform .4s ease,box-shadow .3s;box-shadow:none}
.snav.vis{transform:translateY(0);box-shadow:0 2px 20px rgba(42,38,64,.08)}
.snav__links{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}
.snav__links a{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gray);padding:6px 14px;border-radius:20px;transition:all .3s;text-decoration:none}
.snav__links a:hover,.snav__links a.active{color:var(--rose-dk);background:rgba(213,204,238,.3)}

/* ═══════ CURSOR TRAIL ═══════ */
.ctrail{position:fixed;pointer-events:none;z-index:9998;color:var(--rose-lt);opacity:0;font-size:12px;transition:none}

/* ═══════ HEADING UNDERLINE ═══════ */
.t-h{position:relative;display:block;width:fit-content;margin-left:auto;margin-right:auto}
.t-h::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:2px;background:linear-gradient(90deg,var(--rose-lt),var(--dusty-blue));border-radius:1px;transition:width .8s cubic-bezier(.25,.46,.45,.94),left .8s cubic-bezier(.25,.46,.45,.94)}
.sf.v .t-h::after{width:60%;left:20%}

/* ═══════ TIMELINE DOT PULSE ═══════ */
.tl__dot::after{content:'';position:absolute;inset:-6px;border-radius:50%;background:rgba(139,126,181,.2);opacity:0;transition:opacity .4s}
.tl__i:hover .tl__dot::after{opacity:1;animation:dotPulse 1.5s ease-in-out infinite}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:.2}50%{transform:scale(1.6);opacity:0}}

/* ═══════ PROGRAM GLASSMORPHISM ═══════ */
.prg__i .prg__ico{background:rgba(255,255,255,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5)}

/* ═══════ CARD 3D TILT ═══════ */
@media(min-width:768px){.card{transition:all .4s cubic-bezier(.25,.46,.45,.94),transform .15s ease}.card:hover{transform:perspective(800px) rotateY(2deg) rotateX(-2deg) translateY(-4px)}}

/* ═══════ COUNTER SPIN ═══════ */
.cd__num{overflow:hidden}
.cd__num.spin{animation:countSpin .6s cubic-bezier(.25,.46,.45,.94)}
@keyframes countSpin{0%{transform:translateY(100%);opacity:0}100%{transform:translateY(0);opacity:1}}
