/* ─── RESET & VARIABLES ─── */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --gold:#C8A84C;
  --gold-light:#E2C050;
  --gold-pale:#FFFBF0;
  --cream:#FFFFFF;
  --cream-dark:#F7F7F7;
  --brown:#1E2028;
  --brown-light:#5C5F6A;
  --text:#1A1A1A;
}
html{scroll-behavior:smooth;}
body{background:var(--cream);color:var(--text);font-family:'Montserrat',sans-serif;overflow-x:hidden;}

/* ─── UTILITIES ─── */
section{padding:5rem 1.5rem;}
.container{max-width:680px;margin:0 auto;}
.container-wide{max-width:1100px;margin:0 auto;}

.eyebrow{
  font-family:'Montserrat',sans-serif;font-size:0.65rem;
  letter-spacing:0.4em;text-transform:uppercase;
  color:var(--gold);text-align:center;
  margin-bottom:0.75rem;display:block;
}
.section-title{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:clamp(2.5rem,7vw,4.5rem);font-weight:400;
  line-height:1.15;text-align:center;color:var(--brown);
}
.section-title em{color:var(--gold);font-style:normal;}
.divider{display:flex;align-items:center;gap:1rem;margin:2rem auto;max-width:400px;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.divider-diamond{width:8px;height:8px;background:var(--gold);transform:rotate(45deg);flex-shrink:0;}
.couple-name{font-family:'Cormorant Garant',serif;font-style:italic;font-size:clamp(1.8rem,5vw,2.8rem);color:var(--brown);text-align:center;line-height:1.3;}
.invite-text{font-family:'Cormorant Garant',serif;font-size:clamp(1rem,2.5vw,1.25rem);line-height:1.9;text-align:center;color:var(--brown-light);}

/* ─── SCROLL REVEAL ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.75s ease,transform 0.75s ease;}
.reveal.visible{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:0.1s;}
.reveal-delay-2{transition-delay:0.2s;}
.reveal-delay-3{transition-delay:0.3s;}
.reveal-delay-4{transition-delay:0.4s;}

/* ─── MUSIC PLAYER ─── */
#musicBtn{
  position:fixed;bottom:2rem;right:2rem;z-index:999;
  width:48px;height:48px;border-radius:50%;
  background:var(--brown);border:1px solid var(--gold);
  color:var(--gold);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.3s,color 0.3s;
}
#musicBtn svg{width:20px;height:20px;transition:opacity 0.3s;}
#musicBtn.muted svg{opacity:0.35;}
#musicBtn:hover{background:var(--gold);color:var(--brown);}
#musicBtn.playing,#musicBtn.waiting{animation:pulse 2s ease-in-out infinite;}
#musicBtn.waiting{animation-duration:1s;}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(201,151,58,0.4);}
  50%{box-shadow:0 0 0 10px rgba(201,151,58,0);}
}

/* ─── HERO ─── */
#hero{
  height:100vh;min-height:600px;
  display:flex;flex-direction:column;
  background:var(--brown);overflow:hidden;position:relative;
}
.hero-img{
  position:absolute;inset:0;
  background:url('weddd.jpg') center 40%/cover no-repeat;
  animation:heroZoom 8s ease forwards;
}
@keyframes heroZoom{from{transform:scale(1.08);}to{transform:scale(1);}}
.hero-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(10,10,10,0.3) 0%,rgba(10,10,10,0.5) 100%);
}
.hero-content{
  position:relative;z-index:2;
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:2rem;
}
.hero-label{
  font-family:'Montserrat',sans-serif;font-size:0.65rem;letter-spacing:0.45em;
  text-transform:uppercase;color:rgba(255,255,255,0.8);
  margin-bottom:1.5rem;display:block;
}
.hero-names{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:clamp(3.5rem,12vw,7rem);
  color:var(--cream);line-height:1;text-align:center;
  display:flex;align-items:center;gap:0.5em;flex-wrap:wrap;justify-content:center;
}
.hero-and{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:0.45em;
  color:var(--gold-light);align-self:center;
}
.hero-date{
  font-family:'Montserrat',sans-serif;font-size:0.8rem;letter-spacing:0.3em;
  text-transform:uppercase;color:rgba(255,255,255,0.75);
  margin-top:1.5rem;
}
.hero-scroll{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:0.5rem;
  padding-bottom:2rem;
  font-family:'Montserrat',sans-serif;font-size:0.6rem;letter-spacing:0.3em;
  text-transform:uppercase;color:rgba(255,255,255,0.5);
}
.hero-scroll-arrow{
  width:1px;height:40px;
  background:linear-gradient(to bottom,rgba(255,255,255,0.4),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{opacity:0.4;transform:scaleY(1);}50%{opacity:1;transform:scaleY(1.15);}}

/* ─── INVITATION ─── */
#invitation{
  background:var(--cream);position:relative;overflow:hidden;
  padding:5rem 1.5rem;text-align:center;
}
.invite-botanical{
  position:absolute;top:0;
  pointer-events:none;opacity:0.9;
}
.invite-botanical.left{left:0;}
.invite-botanical.right{right:0;}
@media(max-width:600px){
  .invite-botanical{display:none;}
  .hero-img{background-position:center 15%;}
}

/* ─── COUNTDOWN ─── */
#countdown{
  background:var(--brown);text-align:center;position:relative;overflow:hidden;
}
#countdown::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(201,151,58,0.08) 0%,transparent 70%);
}
.cd-ornament{
  width:60px;height:1px;background:var(--gold);margin:0 auto 2rem;opacity:0.4;
}
.countdown-title{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:clamp(2rem,6vw,3.5rem);
  color:var(--cream);margin-bottom:2.5rem;
}
.countdown-grid{
  display:flex;align-items:center;justify-content:center;gap:0;
  flex-wrap:wrap;
}
.countdown-unit{
  display:flex;flex-direction:column;align-items:center;
  padding:1rem 1.5rem;
}
.countdown-num{
  font-family:'Cormorant Garant',serif;font-size:clamp(3rem,8vw,5rem);
  font-weight:300;color:var(--gold-light);line-height:1;
}
.countdown-word{
  font-family:'Montserrat',sans-serif;font-size:0.6rem;letter-spacing:0.35em;
  text-transform:uppercase;color:rgba(255,255,255,0.45);margin-top:0.4rem;
}
.countdown-sep{
  width:1px;height:50px;background:rgba(201,151,58,0.25);
  align-self:center;margin:0 0.25rem;
}
@media(max-width:480px){.countdown-sep{display:none;}.countdown-unit{padding:0.75rem 1rem;}}

/* ─── MEET THE COUPLE ─── */
#meet{background:var(--cream-dark);text-align:center;}
.meet-grid{
  display:flex;align-items:center;justify-content:center;
  gap:2rem;margin-top:2rem;flex-wrap:wrap;
}
.meet-card{flex:1;min-width:220px;max-width:280px;}
.meet-photo{
  width:160px;height:160px;border-radius:50%;
  background:#ddd center/cover no-repeat;
  margin:0 auto 1rem;
  border:3px solid var(--gold-light);
  box-shadow:0 0 0 6px var(--gold-pale);
}
.meet-name{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:2rem;
  color:var(--brown);margin-bottom:0.5rem;
}
.meet-desc{
  font-family:'Cormorant Garant',serif;font-size:1rem;
  line-height:1.7;color:var(--brown-light);
}
.meet-heart{
  font-size:2rem;color:var(--gold);
  animation:heartbeat 2s ease-in-out infinite;
}
@keyframes heartbeat{0%,100%{transform:scale(1);}50%{transform:scale(1.18);}}

/* ─── GALLERY ─── */
#gallery{background:var(--cream);}
.gallery-split{
  display:flex;align-items:center;gap:4rem;
}
.gallery-text{
  flex:0 0 380px;
}
.gallery-text .eyebrow{text-align:left;}
.gallery-heading{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:clamp(2.8rem,5vw,4rem);font-weight:400;
  line-height:1.2;color:var(--brown);margin:0.5rem 0;
}
.gallery-heading span{color:var(--gold);font-size:0.75em;}
.gallery-desc{
  font-family:'Cormorant Garant',serif;font-size:1.05rem;
  line-height:1.85;color:var(--brown-light);margin-bottom:1.5rem;
}
.gallery-signature{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:1.6rem;
  color:var(--gold);
}
.carousel{
  position:relative;flex:1;min-width:0;
  border-radius:4px;overflow:hidden;
}
@media(max-width:860px){
  .gallery-split{flex-direction:column;gap:2.5rem;}
  .gallery-text{flex:none;width:100%;text-align:center;}
  .gallery-text .eyebrow{text-align:center;}
  .gallery-text .divider{margin-left:auto;margin-right:auto;}
  .carousel{flex:none;width:100%;}
}
.carousel-track{position:relative;aspect-ratio:4/3;}
.carousel-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity 0.6s ease;
}
.carousel-slide.active{opacity:1;}
.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block;}
.carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(10,10,10,0.5);border:1px solid rgba(201,151,58,0.4);
  color:var(--gold-light);font-size:1.2rem;cursor:pointer;
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;z-index:2;
}
.carousel-btn:hover{background:rgba(10,10,10,0.8);}
.carousel-btn.prev{left:1rem;}
.carousel-btn.next{right:1rem;}
.carousel-dots{
  position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);
  display:flex;gap:0.5rem;z-index:2;
}
.carousel-year{
  position:absolute;bottom:1rem;left:1rem;z-index:2;
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:1.4rem;
  color:rgba(255,255,255,0.85);
  text-shadow:0 1px 6px rgba(0,0,0,0.5);
  pointer-events:none;
}
.carousel-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.4);cursor:pointer;
  transition:background 0.2s,transform 0.2s;
}
.carousel-dot.active{background:var(--gold-light);transform:scale(1.2);}

/* ─── STORY ─── */
#story{background:var(--cream-dark);}
.story-timeline{
  position:relative;margin-top:2.5rem;
  padding-left:2rem;
}
.story-timeline::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:1px;background:linear-gradient(to bottom,transparent,var(--gold),transparent);
}
.story-item{
  position:relative;padding:0 0 2.5rem 2rem;
}
.story-item::before{
  content:'';position:absolute;left:-4px;top:6px;
  width:9px;height:9px;border-radius:50%;
  background:var(--gold);border:2px solid var(--cream-dark);
}
.story-year{
  font-family:'Cormorant Garant',serif;font-size:0.8rem;
  letter-spacing:0.2em;color:var(--gold);margin-bottom:0.25rem;
}
.story-content h3{
  font-family:'Cormorant Garant',serif;font-size:1.3rem;font-weight:600;
  color:var(--brown);margin-bottom:0.4rem;
}
.story-content p{
  font-family:'Cormorant Garant',serif;font-size:1rem;
  line-height:1.7;color:var(--brown-light);
}

/* ─── RSVP ─── */
#rsvp{background:var(--brown);text-align:center;}
#rsvp .eyebrow{color:var(--gold-light);}
#rsvp .section-title{color:var(--cream);}
#rsvp .divider::before,#rsvp .divider::after{background:linear-gradient(to right,transparent,rgba(229,201,122,0.4),transparent);}
#rsvp .divider-diamond{background:var(--gold-light);}
#rsvp .invite-text{color:rgba(255,255,255,0.6);}
.rsvp-form{max-width:480px;margin:0 auto;}
.rsvp-choices{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem;}
.rsvp-choice{cursor:pointer;}
.rsvp-choice input{display:none;}
.rsvp-choice-box{
  display:flex;flex-direction:column;align-items:center;gap:0.5rem;
  padding:1.25rem 2rem;border:1px solid rgba(201,151,58,0.3);
  border-radius:4px;transition:border-color 0.2s,background 0.2s;
  min-width:140px;
}
.rsvp-choice input:checked + .rsvp-choice-box{
  border-color:var(--gold);background:rgba(201,151,58,0.12);
}
.rsvp-choice-icon{font-size:1.4rem;color:var(--gold);}
.rsvp-choice-label{
  font-family:'Montserrat',sans-serif;font-size:0.75rem;
  letter-spacing:0.1em;color:rgba(255,255,255,0.7);
}
.rsvp-fields{
  max-height:0;overflow:hidden;
  transition:max-height 0.5s ease;
}
.rsvp-fields.open{max-height:200px;}
.rsvp-input{
  width:100%;padding:0.85rem 1rem;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(201,151,58,0.3);border-radius:4px;
  color:#fff;font-family:'Montserrat',sans-serif;font-size:0.9rem;
  margin-bottom:1rem;outline:none;
  transition:border-color 0.2s;
}
.rsvp-input::placeholder{color:rgba(255,255,255,0.3);}
.rsvp-input:focus{border-color:var(--gold);}
.rsvp-btn{
  width:100%;padding:0.9rem;
  background:var(--gold);border:none;border-radius:4px;
  color:var(--brown);font-family:'Montserrat',sans-serif;font-size:0.8rem;
  letter-spacing:0.3em;text-transform:uppercase;cursor:pointer;
  transition:background 0.2s,color 0.2s;
}
.rsvp-btn:hover{background:var(--gold-light);}
.rsvp-btn:disabled{opacity:0.5;cursor:default;}
.rsvp-status{
  font-family:'Montserrat',sans-serif;font-size:0.85rem;
  margin-top:1rem;color:rgba(255,255,255,0.6);
}
.rsvp-status.error{color:#e08080;}
.rsvp-done{
  opacity:0;transform:translateY(16px);
  transition:opacity 0.5s,transform 0.5s;pointer-events:none;
}
.rsvp-done.show{opacity:1;transform:none;pointer-events:auto;}
.rsvp-done-icon{font-size:2.5rem;color:var(--gold);margin-bottom:0.75rem;}
.rsvp-done h3{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:2rem;
  color:var(--cream);margin-bottom:0.5rem;
}
.rsvp-done p{
  font-family:'Cormorant Garant',serif;font-size:1rem;
  color:rgba(255,255,255,0.6);line-height:1.7;
}

/* ─── VENUE ─── */
#venue{background:var(--cream);text-align:center;}
.venue-card{
  max-width:400px;margin:0 auto;
  padding:2.5rem;
  border:1px solid var(--gold-pale);
  background:linear-gradient(135deg,#fff 0%,var(--cream) 100%);
  border-radius:4px;
}
.venue-icon{font-size:1.5rem;color:var(--gold);margin-bottom:1rem;}
.venue-name{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:2rem;
  color:var(--brown);margin-bottom:0.75rem;
}
.venue-address{
  font-family:'Cormorant Garant',serif;font-size:1.05rem;
  color:var(--brown-light);line-height:1.7;margin-bottom:1.5rem;
}
.venue-map-btn{
  display:inline-block;padding:0.65rem 1.5rem;
  border:1px solid var(--gold);color:var(--gold);
  font-family:'Montserrat',sans-serif;font-size:0.7rem;
  letter-spacing:0.25em;text-transform:uppercase;
  text-decoration:none;border-radius:2px;
  transition:background 0.2s,color 0.2s;
}
.venue-map-btn:hover{background:var(--gold);color:#fff;}

/* ─── DETAILS ─── */
#details{background:var(--cream-dark);text-align:center;}
.details-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1.5rem;margin-top:2rem;
}
.detail-card{
  padding:2rem 1.5rem;
  background:var(--cream);border:1px solid var(--gold-pale);
  border-radius:4px;
}
.detail-icon{font-size:1.5rem;margin-bottom:0.75rem;}
.detail-card h3{
  font-family:'Cormorant Garant',serif;font-size:1.1rem;font-weight:600;
  color:var(--brown);margin-bottom:0.4rem;
}
.detail-card p{
  font-family:'Cormorant Garant',serif;font-size:0.95rem;
  color:var(--brown-light);line-height:1.6;
}

/* ─── FOOTER ─── */
#footer{
  background:var(--brown);text-align:center;
  padding:4rem 1.5rem;
}
.footer-names{
  font-family:'Cormorant Garant',serif;font-style:italic;font-size:clamp(2.5rem,8vw,4rem);
  color:var(--cream);margin-bottom:0.5rem;
}
.footer-date{
  font-family:'Montserrat',sans-serif;font-size:0.7rem;letter-spacing:0.4em;
  color:rgba(255,255,255,0.4);margin-bottom:1.5rem;
}
.footer-divider{
  width:60px;height:1px;background:var(--gold);
  margin:0 auto 1.5rem;opacity:0.4;
}
.footer-city{
  font-family:'Montserrat',sans-serif;font-size:0.65rem;letter-spacing:0.35em;
  text-transform:uppercase;color:rgba(255,255,255,0.3);
}
