
/* ──────────────────────────────
   TOKENS
────────────────────────────── */
:root{
  --gold:#c9a96e;--gold-light:#e4cfa3;--blush:#e8c4c4;--blush-dk:#c49090;
  --cream:#faf6f0;--ivory:#f5ede0;--charcoal:#2a2420;--brown:#5c3d2e;
  --text:#4a3728;--muted:#9a8070;--white:#ffffff;
  --pad:100px;
  --ease-out-expo:cubic-bezier(.16,1,.3,1);
  --ease-in-out-quart:cubic-bezier(.76,0,.24,1);
}

/* ──────────────────────────────
   RESET
────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;font-weight:300;background:var(--cream);
     color:var(--text);overflow-x:hidden;cursor:none}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ──────────────────────────────
   CUSTOM CURSOR
────────────────────────────── */
#cursor-ring{
  position:fixed;width:36px;height:36px;
  border:1.5px solid var(--gold);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease-out-expo),
             height .3s var(--ease-out-expo),
             border-color .3s,
             background .3s,
             opacity .3s;
  mix-blend-mode:multiply;
}
#cursor-dot{
  position:fixed;width:6px;height:6px;
  background:var(--gold);border-radius:50%;
  pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:transform .08s;
}
body.cursor-hover #cursor-ring{
  width:60px;height:60px;
  border-color:var(--blush-dk);
  background:rgba(201,169,110,.06);
}
@media(hover:none){#cursor-ring,#cursor-dot{display:none}body{cursor:auto}}

/* ──────────────────────────────
   SCROLL PROGRESS BAR
────────────────────────────── */
#progress-bar{
  position:fixed;top:0;left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--blush-dk),var(--gold),var(--gold-light));
  z-index:10001;transition:width .1s linear;
}

/* ──────────────────────────────
   PRELOADER
────────────────────────────── */
#preloader{
  position:fixed;inset:0;background:var(--charcoal);
  display:flex;align-items:center;justify-content:center;
  z-index:9990;
  transition:clip-path .9s var(--ease-in-out-quart),opacity .5s;
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
}
#preloader.out{clip-path:polygon(0 0,100% 0,100% 0,0 0);opacity:0;pointer-events:none}
.pl-inner{text-align:center;color:var(--gold-light)}
.pl-script{font-family:'Great Vibes',cursive;font-size:3rem;display:block;
           animation:plPulse 1.4s ease infinite}
.pl-bar{width:160px;height:1px;background:rgba(201,169,110,.2);margin:16px auto 0;overflow:hidden;border-radius:2px}
.pl-bar-fill{height:100%;background:var(--gold);width:0%;animation:plFill 2s ease forwards}
@keyframes plPulse{0%,100%{opacity:.6;transform:scale(.97)}50%{opacity:1;transform:scale(1)}}
@keyframes plFill{0%{width:0%}100%{width:100%}}

/* ──────────────────────────────
   PETAL CANVAS
────────────────────────────── */
#petal-canvas{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  opacity:.55;
}

/* ──────────────────────────────
   GRAIN OVERLAY
────────────────────────────── */
body::before{
  content:'';position:fixed;inset:-200%;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size:180px 180px;opacity:.018;pointer-events:none;z-index:0;
  animation:grainShift 8s steps(1) infinite;
}
@keyframes grainShift{
  0%{transform:translate(0,0)}10%{transform:translate(-5%,-10%)}
  20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}
  40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}
  60%{transform:translate(15%,0%)}70%{transform:translate(0,15%)}
  80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}
  100%{transform:translate(0,0)}
}

/* ──────────────────────────────
   NAVBAR
────────────────────────────── */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:22px 60px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s,box-shadow .5s,padding .5s;
}
#navbar.scrolled{
  background:rgba(250,246,240,.96);backdrop-filter:blur(14px);
  box-shadow:0 2px 40px rgba(42,36,32,.08);padding:14px 60px;
}
.nav-logo{
  font-family:'Great Vibes',cursive;font-size:2rem;color:var(--charcoal);
  transition:color .3s;
}
.nav-logo:hover{color:var(--gold)}
.nav-links{display:flex;gap:40px}
.nav-links a{
  font-size:11px;font-weight:500;letter-spacing:3px;text-transform:uppercase;
  color:var(--charcoal);position:relative;transition:color .3s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--gold);transition:width .4s var(--ease-out-expo);
}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:none;background:none;border:none}
.nav-hamburger span{display:block;width:24px;height:1px;background:var(--charcoal);transition:.4s}
.mobile-nav{
  display:none;position:fixed;top:0;right:-100%;bottom:0;width:280px;
  background:var(--cream);z-index:999;padding:80px 40px;
  flex-direction:column;gap:30px;
  box-shadow:-4px 0 40px rgba(0,0,0,.12);transition:right .5s var(--ease-out-expo);
}
.mobile-nav.open{right:0}
.mobile-nav a{font-size:13px;letter-spacing:2px;text-transform:uppercase;font-weight:500;color:var(--charcoal)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:998}
.mobile-overlay.show{display:block}
@media(max-width:768px){
  #navbar{padding:16px 24px}#navbar.scrolled{padding:12px 24px}
  .nav-links{display:none}.nav-hamburger{display:flex}.mobile-nav{display:flex}
}

/* ──────────────────────────────
   TYPOGRAPHY HELPERS
────────────────────────────── */
.section-tag{
  font-family:'Jost',sans-serif;font-size:11px;font-weight:500;
  letter-spacing:5px;text-transform:uppercase;color:var(--gold);
  display:block;margin-bottom:12px;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3rem);color:var(--charcoal);font-weight:600;
}
.divider{display:flex;align-items:center;gap:12px;margin:20px auto 50px;justify-content:center}
.divider::before,.divider::after{content:'';height:1px;width:60px;
  background:linear-gradient(to right,transparent,var(--gold))}
.divider::after{background:linear-gradient(to left,transparent,var(--gold))}
.divider-icon{color:var(--gold);font-size:14px}

/* ──────────────────────────────
   SPLIT TEXT (char by char)
────────────────────────────── */
.split-char{
  display:inline-block;opacity:0;transform:translateY(60px) rotateX(-20deg);
  transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo);
}
.split-char.in{opacity:1;transform:translateY(0) rotateX(0)}

/* ──────────────────────────────
   REVEAL ANIMATIONS
────────────────────────────── */
.reveal{opacity:0;transform:translateY(50px);
  transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo)}
.reveal.from-left{transform:translateX(-60px)}
.reveal.from-right{transform:translateX(60px)}
.reveal.from-scale{transform:scale(.9);opacity:0}
.reveal.visible{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}
[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}
[data-delay="5"]{transition-delay:.5s}[data-delay="6"]{transition-delay:.6s}

/* ──────────────────────────────
   CLIP WIPE (section entrances)
────────────────────────────── */
.clip-wipe{
  clip-path:polygon(0 100%,100% 100%,100% 100%,0 100%);
  transition:clip-path 1s var(--ease-out-expo);
}
.clip-wipe.visible{clip-path:polygon(0 0%,100% 0%,100% 100%,0 100%)}

/* ──────────────────────────────
   HERO
────────────────────────────── */
#hero{
  min-height:100vh;position:relative;overflow:hidden;
  display:flex;align-items:center;
  background:linear-gradient(150deg,#fdf3e7 0%,#f5e4d0 50%,#eedbc8 100%);
  padding:130px 60px 80px;
}
/* Animated gradient orbs */
.hero-orb{
  position:absolute;border-radius:50%;
  filter:blur(80px);pointer-events:none;animation:orbDrift 12s ease-in-out infinite;
}
.hero-orb.o1{
  width:600px;height:600px;top:-100px;right:-100px;
  background:radial-gradient(circle,rgba(232,196,196,.5),transparent 70%);
  animation-delay:0s;
}
.hero-orb.o2{
  width:500px;height:500px;bottom:-150px;left:-100px;
  background:radial-gradient(circle,rgba(201,169,110,.25),transparent 70%);
  animation-delay:-6s;
}
.hero-orb.o3{
  width:300px;height:300px;top:30%;right:30%;
  background:radial-gradient(circle,rgba(232,196,196,.3),transparent 70%);
  animation-delay:-3s;
}
@keyframes orbDrift{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-40px) scale(1.05)}
  66%{transform:translate(-20px,30px) scale(.96)}
}

.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;max-width:1200px;margin:0 auto;width:100%;
  position:relative;z-index:2;
}
.hero-content{}

.hero-eyebrow{
  display:block;overflow:hidden;max-width:520px;
  margin-bottom:34px;color:var(--muted);
}
.hero-eyebrow-inner{
  display:block;transform:translateY(100%);
  animation:slideUp .9s var(--ease-out-expo) .6s forwards;
}
.hero-verse-line{
  display:block;font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.05rem,1.6vw,1.35rem);font-style:italic;
  line-height:1.55;color:rgba(42,36,32,.66);
}
.hero-verse-ref{
  display:block;margin-top:8px;
  font-size:9px;letter-spacing:3px;text-transform:uppercase;
  color:var(--gold);
}
@keyframes slideUp{to{transform:translateY(0)}}

.hero-names{
  font-family:'Great Vibes',cursive;
  font-size:clamp(5rem,9vw,8.2rem);
  font-weight:400;line-height:.82;color:#4a1f0c;
  margin-top:0;perspective:800px;
}
.hero-name-line{
  opacity:0;transform:translateY(42px);
  transition:opacity .9s var(--ease-out-expo),transform .9s var(--ease-out-expo);
}
.hero-name-line.in{opacity:1;transform:translateY(0)}
.hero-name-line:first-child{margin-bottom:8px}
.hero-name-line:last-child{margin-top:18px}
.hero-name-line:first-child::first-letter,
.hero-name-line:last-child::first-letter{
  font-size:1.12em;
}
.hero-amp{
  font-family:'Great Vibes',cursive;
  font-size:clamp(3.2rem,6.5vw,5.4rem);
  color:#c99184;display:block;line-height:.78;margin:2px 0 6px 14px;
}

.hero-date{
  font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--muted);
  margin-top:22px;overflow:hidden;
}
.hero-date-inner{display:block;transform:translateY(100%);
  animation:slideUp .7s var(--ease-out-expo) 1.6s forwards}

/* Countdown */
.countdown{display:flex;gap:16px;margin-top:38px;opacity:0;
  animation:fadeUp .8s var(--ease-out-expo) 1.8s forwards}
.cd-item{
  text-align:center;min-width:68px;
  background:rgba(255,255,255,.55);backdrop-filter:blur(12px);
  border:1px solid rgba(201,169,110,.25);border-radius:10px;
  padding:14px 16px;position:relative;overflow:hidden;
}
.cd-item::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  animation:shimmer 2s ease-in-out infinite;
}
@keyframes shimmer{0%,100%{opacity:0;transform:scaleX(.5)}50%{opacity:1;transform:scaleX(1)}}
.cd-num{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;
        color:var(--charcoal);line-height:1}
.cd-label{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);
          margin-top:4px;display:block}
.countdown.countdown-today{display:block;max-width:420px}
.today-card{
  position:relative;overflow:hidden;text-align:center;
  padding:24px 34px;border-radius:16px;
  background:rgba(255,255,255,.62);backdrop-filter:blur(14px);
  border:1px solid rgba(201,169,110,.32);
  box-shadow:0 18px 48px rgba(90,60,40,.12);
}
.today-card::before{
  content:'';position:absolute;inset:8px;border:1px solid rgba(201,169,110,.22);
  border-radius:12px;pointer-events:none;
}
.today-kicker{
  display:block;font-size:10px;letter-spacing:5px;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px;
}
.today-title{
  display:block;font-family:'Great Vibes',cursive;
  font-size:clamp(2.6rem,5vw,4rem);line-height:.95;color:#4a1f0c;
}
.today-time{
  display:block;margin-top:12px;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);
}

/* Hero buttons */
.hero-btns{display:flex;gap:16px;margin-top:36px;opacity:0;
  animation:fadeUp .8s var(--ease-out-expo) 2s forwards}
.btn-primary,.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 36px;font-size:10px;letter-spacing:4px;text-transform:uppercase;
  font-weight:500;border-radius:50px;cursor:none;position:relative;overflow:hidden;
  transition:transform .3s var(--ease-out-expo),box-shadow .3s;
}
.btn-primary{background:var(--gold);color:var(--white);border:none;
  box-shadow:0 8px 30px rgba(201,169,110,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(201,169,110,.5)}
.btn-outline{background:transparent;color:var(--charcoal);border:1px solid rgba(42,36,32,.25)}
.btn-outline:hover{transform:translateY(-3px);border-color:var(--gold);color:var(--gold)}
/* Ripple */
.btn-ripple{
  position:absolute;border-radius:50%;background:rgba(255,255,255,.35);
  transform:scale(0);animation:ripple .7s linear;pointer-events:none;
}
@keyframes ripple{to{transform:scale(4);opacity:0}}

/* Hero image */
.hero-image-wrap{
  position:relative;opacity:0;
  animation:heroImgIn 1.2s var(--ease-out-expo) .8s forwards;
}
@keyframes heroImgIn{
  from{opacity:0;transform:translateY(40px) scale(.96)}
  to{opacity:1;transform:none}
}
.hero-img-frame{
  position:relative;max-width:440px;margin:0 auto;
}
.hero-img-main{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  border-radius:50% 50% 8px 8px / 55% 55% 8px 8px;
  box-shadow:30px 30px 80px rgba(90,60,40,.22);
  transition:transform .6s var(--ease-out-expo);
}
.hero-img-frame:hover .hero-img-main{transform:scale(1.02) translateY(-4px)}
.hero-img-badge{
  position:absolute;bottom:-20px;left:-30px;
  width:130px;height:130px;
  border-radius:50%;overflow:hidden;
  border:5px solid var(--cream);
  box-shadow:0 10px 40px rgba(90,60,40,.2);
  animation:badgeSpin 25s linear infinite;
}
/* Circular text ring */
.hero-ring-text{
  position:absolute;bottom:-30px;right:-30px;
  width:110px;height:110px;
  animation:ringRotate 20s linear infinite;
}
@keyframes ringRotate{to{transform:rotate(360deg)}}
.hero-ring-text text{font-size:11px;fill:var(--gold);letter-spacing:3.5px}
.hero-ring-dot{
  position:absolute;bottom:-30px;right:-30px;
  width:110px;height:110px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;
}
/* Floating shape decorations */
.hero-float{position:absolute;pointer-events:none;animation:floatY 6s ease-in-out infinite}
.hero-float.f1{top:8%;right:8%;width:80px;opacity:.35;animation-delay:0s}
.hero-float.f2{bottom:15%;left:10%;width:60px;opacity:.3;animation-delay:-3s}
.hero-float.f3{top:55%;right:3%;width:40px;opacity:.25;animation-delay:-1.5s}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(8deg)}}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

@media(max-width:900px){
  #hero{padding:110px 24px 60px}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-image-wrap{order:-1}
  .hero-img-frame{max-width:280px}
  .countdown{justify-content:center}
  .countdown.countdown-today{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center;flex-wrap:wrap}
}

/* ──────────────────────────────
   COUPLE
────────────────────────────── */
#couple{
  padding:var(--pad) 60px;background:var(--white);text-align:center;
  position:relative;overflow:hidden;
}
/* Animated rings in background */
.couple-ring-bg{
  position:absolute;border-radius:50%;border:1px solid rgba(201,169,110,.12);
  animation:ringExpand 4s ease-in-out infinite;
}
.crb1{width:300px;height:300px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:0s}
.crb2{width:500px;height:500px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:.8s}
.crb3{width:700px;height:700px;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:1.6s}
@keyframes ringExpand{
  0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:.25;transform:translate(-50%,-50%) scale(1.03)}
}

.couple-grid{
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:60px;align-items:center;max-width:1000px;margin:0 auto;
  position:relative;z-index:1;
}
.couple-card{text-align:center}
.couple-img-wrap{
  display:inline-block;position:relative;margin-bottom:24px;cursor:none;
}
.couple-img{
  width:200px;height:200px;border-radius:50%;object-fit:cover;
  border:6px solid var(--ivory);box-shadow:0 10px 50px rgba(90,60,40,.18);
  transition:transform .6s var(--ease-out-expo),box-shadow .6s;
}
.couple-img-wrap:hover .couple-img{transform:scale(1.06) translateY(-6px);
  box-shadow:0 24px 60px rgba(90,60,40,.26)}
/* Orbit ring around photo */
.couple-orbit{
  position:absolute;inset:-12px;border-radius:50%;
  border:1px dashed rgba(201,169,110,.4);
  animation:orbitSpin 20s linear infinite;
}
.couple-orbit::after{
  content:'♦';position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  font-size:10px;color:var(--gold);
}
@keyframes orbitSpin{to{transform:rotate(360deg)}}
.couple-name{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:600;color:var(--charcoal);margin-bottom:10px}
.couple-bio{font-size:14px;line-height:1.85;color:var(--muted);max-width:260px;margin:0 auto}
.couple-desc{
  font-size:14.5px;
  line-height:1.7;
  color:var(--text);
  max-width:320px;
  margin:20px auto 0;
  font-style:italic;
  background:rgba(201,169,110,0.06);
  padding:18px 20px;
  border-radius:12px;
  position:relative;
  border-top:2px solid var(--gold);
}

.couple-icon{display:flex;flex-direction:column;align-items:center;gap:16px}
.couple-heart{font-size:3rem;color:var(--blush-dk);animation:heartbeat 1.4s ease-in-out infinite}
.couple-initials{
  width:70px;height:70px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-family:'Great Vibes',cursive;font-size:1.6rem;color:white;
  box-shadow:0 8px 30px rgba(201,169,110,.4);
}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}

@media(max-width:768px){
  #couple{padding:var(--pad) 24px}
  .couple-grid{grid-template-columns:1fr;gap:40px}
}

/* ──────────────────────────────
   STORY TIMELINE
────────────────────────────── */
#story{padding:var(--pad) 60px;background:var(--ivory);text-align:center;position:relative;overflow:hidden}
/* Background flowing shapes */
.story-blob{
  position:absolute;border-radius:60% 40% 30% 70% / 60% 30% 70% 40%;
  background:rgba(201,169,110,.06);pointer-events:none;
  animation:blobMorph 12s ease-in-out infinite;
}
.sb1{width:500px;height:500px;top:-100px;right:-100px;animation-delay:0s}
.sb2{width:400px;height:400px;bottom:-100px;left:-100px;animation-delay:-6s}
@keyframes blobMorph{
  0%,100%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}
  50%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%}
}

.story-timeline{position:relative;max-width:900px;margin:0 auto}

/* Animated line */
.story-line{
  position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:1px;background:transparent;overflow:hidden;
}
.story-line-fill{
  height:0%;width:100%;
  background:linear-gradient(to bottom,transparent,var(--gold),var(--gold-light),var(--gold));
  transition:height 1.5s var(--ease-out-expo);
}
.story-line-fill.drawn{height:100%}

.story-item{
  display:grid;grid-template-columns:1fr 60px 1fr;
  gap:0;margin-bottom:80px;align-items:center;
}
.story-item:last-child{margin-bottom:0}
.story-content{
  background:var(--white);border-radius:18px;padding:30px 36px;
  box-shadow:0 4px 40px rgba(90,60,40,.07);position:relative;
  transition:transform .5s var(--ease-out-expo),box-shadow .5s;
}
.story-content:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(90,60,40,.15)}
.story-content::after{content:'';position:absolute;top:50%;transform:translateY(-50%);border:10px solid transparent}
.story-item.story-left .story-content{grid-column:1;text-align:right}
.story-item.story-left .story-content::after{right:-20px;border-left-color:var(--white)}
.story-item.story-right .story-content{grid-column:3;text-align:left}
.story-item.story-right .story-content::after{left:-20px;border-right-color:var(--white)}
.story-item.story-left .story-img{grid-column:3;grid-row:1}
.story-item.story-right .story-img{grid-column:1;grid-row:1}
.story-item.story-left .story-dot{grid-column:2}
.story-item.story-right .story-dot{grid-column:2}

.story-img{
  width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:14px;
  box-shadow:0 8px 40px rgba(90,60,40,.15);
  transition:transform .6s var(--ease-out-expo);
}
.story-img:hover{transform:scale(1.03)}
.story-dot{
  width:18px;height:18px;background:var(--gold);border-radius:50%;
  border:3px solid var(--ivory);box-shadow:0 0 0 5px rgba(201,169,110,.3);
  margin:0 auto;z-index:1;grid-column:2;
  transition:transform .3s,box-shadow .3s;
}
.story-dot.pulse{animation:dotPulse 2s ease infinite}
@keyframes dotPulse{
  0%,100%{box-shadow:0 0 0 5px rgba(201,169,110,.3)}
  50%{box-shadow:0 0 0 12px rgba(201,169,110,.08)}
}
.story-date{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;font-weight:500}
.story-title{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--charcoal);margin-bottom:10px}
.story-text{font-size:13px;line-height:1.85;color:var(--muted)}

@media(max-width:768px){
  #story{padding:var(--pad) 24px}
  .story-line{left:22px}
  .story-item{grid-template-columns:44px 1fr;grid-template-rows:auto auto;gap:16px}
  .story-dot{grid-column:1;grid-row:1;margin:0;width:14px;height:14px}
  .story-item.story-left .story-content,
  .story-item.story-right .story-content{grid-column:2;grid-row:1;text-align:left}
  .story-content::after{display:none}
  .story-item.story-left .story-img,
  .story-item.story-right .story-img{grid-column:2;grid-row:2}
}

/* ──────────────────────────────
   GALLERY
────────────────────────────── */
#gallery{padding:var(--pad) 60px;background:var(--white);text-align:center;position:relative}
.gallery-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  max-width:1100px;margin:0 auto;
}
.gallery-item{
  overflow:hidden;border-radius:10px;position:relative;cursor:none;
  background:var(--ivory);
}
.gallery-img{
  width:100%;height:100%;min-height:200px;object-fit:cover;
  transition:transform .7s var(--ease-out-expo),filter .5s;
}
.gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(42,36,32,.65),rgba(42,36,32,.1));
  opacity:0;transition:opacity .5s;
  display:flex;align-items:flex-end;padding:24px;
}
.gallery-overlay-text{
  color:white;transform:translateY(20px);transition:transform .5s var(--ease-out-expo);
}
.gallery-overlay-text p{font-size:11px;letter-spacing:2px;text-transform:uppercase;opacity:.7}
.gallery-overlay-text h4{font-family:'Cormorant Garamond',serif;font-size:1.3rem}
.gallery-item:hover .gallery-img{transform:scale(1.1);filter:brightness(1.05)}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-item:hover .gallery-overlay-text{transform:translateY(0)}

/* Lightbox */
#lightbox{
  display:none;position:fixed;inset:0;background:rgba(20,15,10,.92);
  z-index:2000;align-items:center;justify-content:center;
  opacity:0;transition:opacity .4s;
}
#lightbox.open{display:flex;animation:lbIn .4s forwards}
@keyframes lbIn{to{opacity:1}}
#lightbox img{
  max-width:90vw;max-height:85vh;object-fit:contain;border-radius:6px;
  box-shadow:0 40px 80px rgba(0,0,0,.4);
  animation:lbImgIn .4s var(--ease-out-expo);
}
@keyframes lbImgIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.lb-close{position:absolute;top:24px;right:32px;color:white;font-size:2rem;cursor:none;background:none;border:none;transition:transform .3s}
.lb-close:hover{transform:rotate(90deg)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);color:white;font-size:2rem;cursor:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);padding:12px 20px;border-radius:50%;transition:background .3s,transform .3s}
.lb-nav:hover{background:rgba(201,169,110,.3);transform:translateY(-50%) scale(1.1)}
.lb-prev{left:24px}.lb-next{right:24px}

@media(max-width:768px){
  #gallery{padding:var(--pad) 16px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}

/* ──────────────────────────────
   WEDDING PARTY
────────────────────────────── */
#party{padding:var(--pad) 60px;background:var(--ivory);text-align:center;position:relative}
.party-grid{
  --party-gap:18px;
  max-width:1000px;margin:0 auto;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.party-track{
  display:flex;gap:var(--party-gap);width:max-content;
  animation:partyMarquee 34s linear infinite;
}
.party-grid:hover .party-track,
.party-grid:focus-within .party-track{animation-play-state:paused}
.party-card{
  flex:0 0 212px;
  text-align:center;cursor:none;
}
.party-img-wrap{
  position:relative;display:inline-block;margin-bottom:18px;
}
.party-img{
  width:160px;height:200px;object-fit:cover;border-radius:80px 80px 0 0;
  transition:transform .5s var(--ease-out-expo);
  box-shadow:0 8px 30px rgba(90,60,40,.12);
}
.party-card:hover .party-img{transform:translateY(-10px)}
.party-img-glow{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:160px;height:50px;
  background:radial-gradient(ellipse,rgba(201,169,110,.25),transparent 70%);
  opacity:0;transition:opacity .5s;filter:blur(6px);
}
.party-card:hover .party-img-glow{opacity:1}
.party-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;color:var(--charcoal)}
@keyframes partyMarquee{to{transform:translateX(calc(-50% - (var(--party-gap) / 2)))}}

@media(max-width:768px){
  #party{padding:var(--pad) 24px}
  .party-grid{
    --party-gap:14px;
    overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  }
  .party-grid::-webkit-scrollbar{display:none}
  .party-track{animation:none}
  .party-card{flex-basis:calc((100vw - 62px)/2)}
  .party-img{width:140px;height:176px}
  .party-img-glow{width:140px}
}

/* ──────────────────────────────
   EVENTS
────────────────────────────── */
#events{padding:var(--pad) 60px;background:var(--white);text-align:center;position:relative;overflow:hidden}
/* Parallax layer */
.events-para-layer{
  position:absolute;inset:-60px;
  background:radial-gradient(ellipse at 70% 30%,rgba(232,196,196,.15),transparent 60%),
             radial-gradient(ellipse at 20% 80%,rgba(201,169,110,.08),transparent 60%);
  pointer-events:none;
}
.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;max-width:800px;margin:0 auto}
.event-card{
  border-radius:20px;overflow:hidden;
  box-shadow:0 4px 40px rgba(90,60,40,.09);
  border: 1px solid rgba(201,169,110,0.3);
  transition:transform .6s var(--ease-out-expo),box-shadow .6s;position:relative;
}
.event-card:hover{transform:translateY(-12px);box-shadow:0 28px 70px rgba(90,60,40,.18)}
.event-img-wrap{position:relative;overflow:hidden;height:220px}
.event-img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out-expo)}
.event-card:hover .event-img{transform:scale(1.1)}
.event-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,rgba(42,36,32,.4));
  opacity:0;transition:opacity .5s;
}
.event-card:hover .event-img-overlay{opacity:1}
.event-body{padding:28px;background:var(--cream);text-align:left}
.event-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--charcoal);margin-bottom:16px}
.event-detail{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.event-icon{color:var(--gold);flex-shrink:0;margin-top:2px;transition:transform .3s}
.event-card:hover .event-icon{transform:scale(1.2)}
.event-info{font-size:13px;color:var(--muted);line-height:1.6}
.event-link{
  display:inline-flex;align-items:center;gap:6px;margin-top:20px;
  font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:500;
  transition:gap .3s;
}
.event-link:hover{gap:10px}

@media(max-width:900px){
  #events{padding:var(--pad) 24px}
  .events-grid{grid-template-columns:1fr;max-width:500px; gap: 60px}
}

/* ──────────────────────────────
   FOOTER
────────────────────────────── */
#footer{
  background:var(--charcoal);padding:96px 60px 36px;
  position:relative;overflow:hidden;text-align:center;
}
/* Decorative SVG wave top */
#footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:44px;
  background:var(--ivory);clip-path:ellipse(58% 100% at 50% 0%);
  z-index:0;
}
#footer > *{position:relative;z-index:1}
.footer-inner{
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:60px;max-width:1100px;margin:0 auto;position:relative;z-index:1;
}
.footer-logo{
  font-family:'Great Vibes',cursive;font-size:3rem;
  color:var(--gold-light);display:block;margin-bottom:16px;
}
.footer-date{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.34);margin-bottom:26px}
.footer-verse{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:rgba(255,255,255,.48);max-width:520px;margin:0 auto 28px;line-height:1.7}
.footer-tagline{font-size:14px;line-height:1.85;color:rgba(255,255,255,.38);max-width:260px}
.footer-socials{display:flex;gap:12px;margin-top:24px}
.social-btn{
  width:40px;height:40px;border:1px solid rgba(255,255,255,.12);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);
  transition:.4s;cursor:none;
}
.social-btn:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px);box-shadow:0 8px 20px rgba(201,169,110,.3)}
.footer-heading{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold-light);margin-bottom:24px;font-weight:500}
.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-links a{font-size:14px;color:rgba(255,255,255,.35);transition:color .3s,padding-left .3s}
.footer-links a:hover{color:var(--gold);padding-left:6px}
.footer-contact p{font-size:13px;color:rgba(255,255,255,.35);line-height:1.85;margin-bottom:8px}
.footer-bottom{
  max-width:1100px;margin:60px auto 0;padding-top:28px;
  border-top:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1;
}
.footer-copy{font-size:1.35rem;color:var(--gold);font-family:'Great Vibes',cursive}

@media(max-width:768px){
  #footer{padding:76px 24px 32px}
  .footer-inner{grid-template-columns:1fr;gap:40px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .footer-logo{font-size:2.6rem}
  .footer-date{letter-spacing:3px;line-height:1.7}
}

/* ──────────────────────────────
   BACK TO TOP
────────────────────────────── */
#back-top{
  position:fixed;bottom:32px;right:32px;width:48px;height:48px;
  background:var(--gold);color:white;border:none;border-radius:50%;
  cursor:none;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(20px);transition:.5s var(--ease-out-expo);z-index:500;
  box-shadow:0 8px 30px rgba(201,169,110,.4);
}
#back-top.visible{opacity:1;transform:translateY(0)}
#back-top:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(201,169,110,.55);background:var(--charcoal)}

/* ──────────────────────────────
   MAGNETIC AREA
────────────────────────────── */
.magnetic{display:inline-block;transition:transform .4s var(--ease-out-expo)}

/* ──────────────────────────────
   TILT CARD
────────────────────────────── */
.tilt-card{transform-style:preserve-3d;perspective:1000px;transition:transform .1s}

/* ──────────────────────────────
   ACTIVE NAV UNDERLINE
────────────────────────────── */
.nav-links a.active{color:var(--gold)}
.nav-links a.active::after{width:100%}

/* ──────────────────────────────
   MUSIC TOGGLE
────────────────────────────── */
#music-toggle { position:fixed; bottom:32px; left:32px; width:48px; height:48px; background:var(--gold); color:white; border:none; border-radius:50%; cursor:none; display:flex; align-items:center; justify-content:center; z-index:500; box-shadow:0 8px 30px rgba(201,169,110,.4); transition:.5s var(--ease-out-expo); }
#music-toggle:hover { transform:translateY(-4px); box-shadow:0 14px 40px rgba(201,169,110,.55); background:var(--charcoal); }

.event-date-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  background: rgba(201, 169, 110, 0.08);
  padding: 12px 20px;
  border-radius: 8px;
  margin-bottom: 25px;
}
.badge-date {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.2rem;
  font-weight: 600;
  color: var(--gold);
  line-height: 1;
}
.badge-col {
  display: flex;
  flex-direction: column;
  text-align: left;
}
.badge-month {
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 2px;
  color: var(--text);
}
.badge-time {
  font-size: 0.85rem;
  color: var(--muted);
  margin-top: 2px;
}
.locations-container {
  display: flex;
  gap: 20px;
  text-align: left;
  border: 1px solid rgba(201, 169, 110, 0.2);
  border-radius: 8px;
  padding: 20px;
  background: white;
}
.location-box {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.loc-divider {
  width: 1px;
  background: rgba(201, 169, 110, 0.2);
}
.loc-header {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 2px;
  color: var(--gold);
  margin-bottom: 8px;
}
.loc-name {
  font-weight: 500;
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.4;
  margin-bottom: 4px;
}
.loc-address {
  font-size: 0.85rem;
  color: var(--muted);
  margin-bottom: 12px;
}
.loc-link {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--gold);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 1px;
  display: inline-block;
  border-bottom: 1px solid transparent;
  transition: .3s;
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.loc-link:hover {
  border-color: var(--gold);
}

@media(max-width: 600px) {
  .locations-container {
    flex-direction: column;
    gap: 15px;
    padding: 15px;
  }
  .loc-divider {
    width: 100%;
    height: 1px;
  }
}

@media(max-width: 480px) {
  .gallery-grid { grid-template-columns: 1fr; }
  #party{padding-left:18px;padding-right:18px}
  .party-grid{--party-gap:8px;max-width:100%}
  .party-card { flex-basis: 148px; }
  .party-img{width:132px;height:168px}
  .party-img-glow{width:132px}
  .party-name{font-size:1.12rem}
}

@media(prefers-reduced-motion:reduce){
  .party-track{animation:none}
  .party-grid::-webkit-scrollbar{display:none}
  .party-grid{overflow-x:auto;scroll-snap-type:x mandatory;mask-image:none;-webkit-mask-image:none}
  .party-card{scroll-snap-align:center}
}
