/* ============================================================
   WEDDING INVITATION — style.css
   Apeksha & Darshan · 5 January 2027
   Royal + Modern + Luxury Indian Wedding
   ============================================================ */

/* ── CSS Variables ── */
:root {
  --gold:        #c9a84c;
  --gold-light:  #e8c97a;
  --gold-dark:   #8a6820;
  --gold-shine:  #f5e0a0;
  --ivory:       #faf6ef;
  --champagne:   #f0e6d0;
  --rose-gold:   #c9826b;
  --maroon:      #6b1f2a;
  --maroon-deep: #3d0f16;
  --blush:       #f7e8e4;
  --cream:       #fdf8f2;
  --text-dark:   #2a1a0e;
  --text-mid:    #5a3e28;
  --text-light:  #8a7060;
  --glass-bg:    rgba(250,246,239,0.18);
  --glass-border:rgba(201,168,76,0.3);
  --shadow-gold: 0 8px 40px rgba(201,168,76,0.18);
  --radius:      18px;
  --trans:       0.45s cubic-bezier(.4,0,.2,1);
}

/* ── Reset & Base ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Jost',sans-serif;
  background:var(--cream);
  color:var(--text-dark);
  overflow-x:hidden;
  cursor:none;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:none;border:none;background:none}
::selection{background:rgba(201,168,76,.3);color:var(--maroon)}

/* ── Custom Scrollbar ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--champagne)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}

/* ── Cursor Glow ── */
.cursor-glow{
  position:fixed;
  width:28px;height:28px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,76,.6) 0%,transparent 70%);
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .08s ease,width .2s,height .2s;
  mix-blend-mode:screen;
}

/* ── Floating Petals ── */
.petals-container{
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  overflow:hidden;
}
.petal{
  position:absolute;
  width:10px;height:10px;
  background:radial-gradient(circle,rgba(201,130,107,.55),rgba(201,168,76,.25));
  border-radius:50% 0 50% 0;
  animation:petalFall linear infinite;
  opacity:0;
}
@keyframes petalFall{
  0%  {opacity:0;transform:translateY(-20px) rotate(0deg)}
  5%  {opacity:.7}
  95% {opacity:.4}
  100%{opacity:0;transform:translateY(110vh) rotate(720deg)}
}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 2.5rem;
  transition:background var(--trans),backdrop-filter var(--trans),box-shadow var(--trans);
}
.nav.scrolled{
  background:rgba(253,248,242,.85);
  backdrop-filter:blur(16px);
  box-shadow:0 2px 24px rgba(201,168,76,.12);
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;font-weight:600;
  color:var(--gold);letter-spacing:.06em;
}
.nav-logo span{color:var(--rose-gold)}
.nav-links{
  display:flex;gap:2.2rem;list-style:none;
}
.nav-links a{
  font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-mid);font-weight:500;
  position:relative;
  transition:color var(--trans);
}
.nav-links a::after{
  content:'';position:absolute;bottom:-3px;left:0;right:0;
  height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:center;
  transition:transform var(--trans);
}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{transform:scaleX(1)}
.music-btn{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--gold-light);
  color:var(--gold);font-size:.9rem;
  transition:all var(--trans);
}
.music-btn:hover{background:var(--gold);color:var(--cream)}

/* ── HERO ── */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background:linear-gradient(145deg,var(--maroon-deep) 0%,var(--maroon) 35%,#8b2a3a 65%,var(--maroon-deep) 100%);
}
.hero-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;
}

/* Corners */
.corner{
  position:absolute;
  width:160px;height:160px;
  pointer-events:none;
  opacity:.55;
  background-image:
    linear-gradient(var(--gold-light),var(--gold-light)),
    linear-gradient(var(--gold-light),var(--gold-light));
  background-size:100% 1.5px,1.5px 100%;
  background-repeat:no-repeat;
}
.corner-tl{top:28px;left:28px;background-position:top left,top left}
.corner-tr{top:28px;right:28px;
  background-image:linear-gradient(var(--gold-light),var(--gold-light)),linear-gradient(var(--gold-light),var(--gold-light));
  background-size:100% 1.5px,1.5px 100%;
  background-position:top right,top right;
}
.corner-bl{bottom:28px;left:28px;
  background-size:100% 1.5px,1.5px 100%;
  background-position:bottom left,bottom left;
}
.corner-br{bottom:28px;right:28px;
  background-size:100% 1.5px,1.5px 100%;
  background-position:bottom right,bottom right;
}

.hero-content{
  position:relative;z-index:2;
  text-align:center;
  padding:6rem 1.5rem 3rem;
  display:flex;flex-direction:column;align-items:center;gap:1.1rem;
}
.hero-pre{
  font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-light);font-weight:400;
}
.hero-monogram{
  display:flex;align-items:center;gap:.7rem;
  font-family:'Great Vibes',cursive;
  font-size:5rem;color:var(--gold-shine);
  filter:drop-shadow(0 0 18px rgba(201,168,76,.5));
  line-height:1;
}
.hero-monogram i{font-size:1.6rem;color:var(--rose-gold);animation:heartbeat 2s ease-in-out infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}

.hero-tagline{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,6vw,4.2rem);
  font-weight:300;font-style:italic;
  color:var(--ivory);
  line-height:1.15;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.hero-sub{
  font-size:.88rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(240,230,208,.75);font-weight:300;
}
.hero-names{
  display:flex;align-items:center;gap:2rem;
  margin-top:.4rem;
}
.name-card{display:flex;flex-direction:column;gap:.2rem;text-align:center}
.name-label{
  font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-light);opacity:.8;
}
.name-value{
  font-family:'Great Vibes',cursive;
  font-size:3.2rem;color:var(--gold-shine);
  line-height:1;
  filter:drop-shadow(0 0 12px rgba(201,168,76,.45));
}
.name-amp{
  font-family:'Cormorant Garamond',serif;
  font-size:2.5rem;color:var(--rose-gold);
  font-style:italic;margin-top:.3rem;
}

/* Save the Date Card */
.save-date-card{
  position:relative;
  background:linear-gradient(135deg,rgba(201,168,76,.18),rgba(245,224,160,.12));
  border:1px solid rgba(201,168,76,.4);
  border-radius:14px;
  padding:1.4rem 2.8rem;
  overflow:hidden;
  backdrop-filter:blur(10px);
  animation:floatCard 4s ease-in-out infinite;
}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.save-text{
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-light);margin-bottom:.2rem;
}
.save-day{
  font-family:'Cormorant Garamond',serif;
  font-size:4rem;font-weight:600;line-height:1;
  color:var(--gold-shine);
}
.save-month-year{
  font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--champagne);
}
.save-month-year span{color:var(--gold-light)}
.save-shimmer{
  position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 30%,rgba(245,224,160,.15) 50%,transparent 70%);
  animation:shimmerSlide 2.8s ease-in-out infinite;
}
@keyframes shimmerSlide{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}

/* Scroll Indicator */
.scroll-indicator{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:rgba(240,230,208,.55);font-size:.65rem;
  letter-spacing:.22em;text-transform:uppercase;
  animation:fadeInUp 1s 1.5s both;
}
.scroll-line{
  width:1.5px;height:46px;
  background:rgba(201,168,76,.2);
  border-radius:1px;overflow:hidden;
}
.scroll-dot{
  width:100%;height:30%;
  background:var(--gold-light);
  border-radius:1px;
  animation:scrollDrop 1.6s ease-in-out infinite;
}
@keyframes scrollDrop{0%{transform:translateY(-100%)}100%{transform:translateY(400%)}}

/* ── DIVIDERS ── */
.divider{
  text-align:center;
  padding:1.4rem 0;
  background:var(--cream);
}
.divider-ornament{
  font-size:1rem;color:var(--gold);
  letter-spacing:.5rem;
  opacity:.6;
}

/* ── SECTION COMMONS ── */
.section-pre{
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--rose-gold);margin-bottom:.5rem;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,5vw,3.4rem);
  font-weight:400;font-style:italic;
  color:var(--maroon);
  line-height:1.1;margin-bottom:.6rem;
}
.section-desc{
  font-size:.9rem;color:var(--text-light);
  max-width:500px;margin:0 auto 2.4rem;
  line-height:1.7;
}

/* ── COUNTDOWN ── */
.countdown-section{
  padding:5rem 1.5rem;
  text-align:center;
  background:linear-gradient(160deg,var(--maroon-deep),var(--maroon));
  color:var(--ivory);
  position:relative;overflow:hidden;
}
.countdown-section::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23c9a84c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.countdown-section .section-pre{color:var(--gold-light)}
.countdown-section .section-title{color:var(--ivory)}
.countdown-grid{
  display:flex;align-items:center;justify-content:center;
  gap:1rem;flex-wrap:wrap;
  margin:2.5rem 0;
}
.cd-card{
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:14px;
  padding:1.4rem 1.8rem;
  backdrop-filter:blur(12px);
  min-width:110px;
  position:relative;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.25),inset 0 1px 0 rgba(201,168,76,.2);
}
.cd-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(245,224,160,.06) 0%,transparent 60%);
  pointer-events:none;
}
.cd-num{
  font-family:'Cormorant Garamond',serif;
  font-size:3.6rem;font-weight:600;
  color:var(--gold-shine);
  line-height:1;
  transition:transform .15s ease;
}
.cd-num.flip{transform:scaleY(1.12);color:#fff}
.cd-label{
  font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-light);margin-top:.3rem;
}
.cd-sep{
  font-family:'Cormorant Garamond',serif;
  font-size:3rem;color:var(--gold-light);
  font-weight:300;line-height:1;
  margin-bottom:1.5rem;
  opacity:.6;
}
.cd-date-display{
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem;font-style:italic;
  color:var(--champagne);letter-spacing:.08em;
  opacity:.75;
}

/* ── SCRATCH CARDS ── */
.scratch-section{
  padding:5rem 1.5rem;
  text-align:center;
  background:var(--cream);
}
.scratch-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:2rem;max-width:960px;margin:0 auto;
}
.scratch-wrapper{}
.scratch-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;font-weight:400;font-style:italic;
  color:var(--maroon);margin-bottom:.8rem;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
}
.scratch-title i{color:var(--gold);font-size:1rem}
.scratch-card-box{
  position:relative;
  border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-gold),0 2px 0 var(--gold-dark);
  height:200px;
  border:1px solid var(--gold-light);
}
.scratch-reveal{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--cream),var(--blush));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.35rem;padding:1rem;
}
.reveal-icon{font-size:2rem;color:var(--gold);margin-bottom:.3rem}
.reveal-heading{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:600;color:var(--maroon);
}
.reveal-detail{
  font-size:.88rem;color:var(--text-mid);font-weight:500;
}
.reveal-sub{font-size:.75rem;color:var(--text-light)}
.scratch-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  border-radius:16px;
  cursor:crosshair;
  touch-action:none;
}
.scratch-hint{
  position:absolute;
  bottom:.7rem;left:50%;transform:translateX(-50%);
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.75);
  pointer-events:none;
  display:flex;align-items:center;gap:.35rem;
  transition:opacity .4s;
}

/* ── EVENTS ── */
.events-section{
  padding:5rem 1.5rem;
  text-align:center;
  background:var(--champagne);
}
.events-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.5rem;max-width:1100px;margin:0 auto;
}
.event-card{
  background:var(--cream);
  border:1px solid rgba(201,168,76,.2);
  border-radius:var(--radius);
  padding:2rem 1.5rem;
  text-align:center;
  position:relative;overflow:hidden;
  transition:transform var(--trans),box-shadow var(--trans),border-color var(--trans);
}
.event-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light),var(--gold));
}
.event-card:hover{
  transform:translateY(-8px);
  box-shadow:0 24px 60px rgba(201,168,76,.2);
  border-color:var(--gold-light);
}
.featured-event{
  background:linear-gradient(160deg,var(--maroon-deep),var(--maroon));
  border-color:rgba(201,168,76,.5);
}
.featured-event .event-name,.featured-event .event-detail{color:var(--ivory)}
.featured-event .event-tag{background:rgba(201,168,76,.2);color:var(--gold-light)}
.event-icon-wrap{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-dark),var(--gold));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;
  font-size:1.3rem;color:#fff;
  box-shadow:0 6px 18px rgba(201,168,76,.35);
}
.event-name{
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;font-weight:500;font-style:italic;
  color:var(--maroon);margin-bottom:1rem;
}
.event-detail{
  font-size:.78rem;color:var(--text-light);
  display:flex;align-items:center;gap:.5rem;
  margin:.3rem 0;
  justify-content:center;
}
.event-detail i{color:var(--gold);font-size:.7rem}
.event-tag{
  margin-top:1rem;
  display:inline-block;
  padding:.25rem .9rem;
  border-radius:20px;
  background:rgba(107,31,42,.08);
  color:var(--maroon);
  font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;
}

/* ── LOVE STORY TIMELINE ── */
.story-section{
  padding:5rem 1.5rem;
  text-align:center;
  background:var(--cream);
}
.timeline{
  position:relative;
  max-width:860px;margin:0 auto;
  padding:1rem 0;
}
.timeline::before{
  content:'';
  position:absolute;top:0;bottom:0;left:50%;
  width:1.5px;
  background:linear-gradient(to bottom,transparent,var(--gold),var(--gold-light),var(--gold),transparent);
  transform:translateX(-50%);
}
.timeline-item{
  position:relative;
  display:flex;align-items:center;
  margin-bottom:3.5rem;
}
.timeline-item:nth-child(odd)  .tl-content{flex-direction:row}
.timeline-item:nth-child(even) .tl-content{flex-direction:row-reverse}
.tl-marker{
  position:absolute;left:50%;transform:translateX(-50%);
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-dark),var(--gold));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.85rem;
  box-shadow:0 0 0 5px var(--cream),0 0 0 7px rgba(201,168,76,.25);
  z-index:2;
}
.tl-content{
  display:flex;gap:1.5rem;align-items:center;
  width:calc(50% - 2.5rem);
  margin-left:auto;
}
.timeline-item:nth-child(odd) .tl-content{margin-left:0;margin-right:auto}
.tl-photo{
  flex-shrink:0;
  width:120px;height:120px;border-radius:12px;
  overflow:hidden;
  border:2px solid var(--gold-light);
  box-shadow:0 6px 20px rgba(201,168,76,.2);
}
.placeholder-photo{
  background:linear-gradient(135deg,var(--champagne),var(--blush));
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:.3rem;
}
.placeholder-photo span{font-size:.65rem;color:var(--text-light);text-align:center;padding:.4rem}
.tl-text{text-align:left}
.tl-date{
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);
}
.tl-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem;font-weight:500;font-style:italic;
  color:var(--maroon);margin:.3rem 0;
}
.tl-body{font-size:.83rem;color:var(--text-light);line-height:1.7}

/* ── GALLERY ── */
.gallery-section{
  padding:5rem 1.5rem;
  text-align:center;
  background:var(--champagne);
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:200px;
  gap:1rem;
  max-width:1000px;margin:0 auto;
}
.gallery-item{
  border-radius:12px;overflow:hidden;
  position:relative;
  border:1px solid rgba(201,168,76,.18);
  transition:transform var(--trans),box-shadow var(--trans);
}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}
.gallery-item:hover{transform:scale(1.02);box-shadow:0 16px 40px rgba(201,168,76,.22)}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--blush),var(--champagne),var(--blush));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.5rem;
  font-size:.78rem;color:var(--text-light);
}
.gallery-placeholder i{font-size:2rem;color:var(--gold-light)}
.gallery-overlay{
  position:absolute;inset:0;
  background:rgba(107,31,42,.45);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.4rem;
  opacity:0;transition:opacity var(--trans);
  cursor:pointer;
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(15,5,10,.92);
  backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity var(--trans);
}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox-img-wrap{
  max-width:80vw;max-height:80vh;
  border-radius:12px;overflow:hidden;
  border:1px solid rgba(201,168,76,.3);
}
.lightbox-placeholder{
  width:500px;height:350px;max-width:80vw;
  background:linear-gradient(135deg,rgba(107,31,42,.3),rgba(201,168,76,.1));
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.7rem;color:rgba(240,230,208,.6);font-size:.9rem;
}
.lightbox-placeholder i{font-size:2.5rem}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:absolute;
  color:var(--gold-light);font-size:1.1rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(201,168,76,.25);
  border-radius:50%;
  width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--trans);cursor:pointer;
}
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{
  background:var(--gold);color:var(--maroon);
}
.lightbox-close{top:1.5rem;right:1.5rem}
.lightbox-prev{left:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox-next{right:1.5rem;top:50%;transform:translateY(-50%)}

/* ── RSVP ── */
.rsvp-section{
  padding:5rem 1.5rem;
  text-align:center;
  background:var(--cream);
}
.rsvp-form-wrap{
  max-width:700px;margin:0 auto;
  background:var(--ivory);
  border:1px solid rgba(201,168,76,.25);
  border-radius:22px;
  padding:2.5rem 2rem;
  box-shadow:0 16px 60px rgba(201,168,76,.1);
  position:relative;overflow:hidden;
}
.rsvp-deco-top,.rsvp-deco-bottom{
  position:absolute;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),var(--gold-light),var(--gold),transparent);
}
.rsvp-deco-top{top:0}
.rsvp-deco-bottom{bottom:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.2rem}
.form-group{display:flex;flex-direction:column;gap:.4rem;text-align:left}
.form-group.full-width{grid-column:1/-1;margin-bottom:1.2rem}
label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light)}
input,select,textarea{
  background:rgba(240,230,208,.4);
  border:1px solid rgba(201,168,76,.25);
  border-radius:9px;
  padding:.7rem 1rem;
  font-family:'Jost',sans-serif;
  font-size:.9rem;color:var(--text-dark);
  outline:none;
  transition:border-color var(--trans),box-shadow var(--trans),background var(--trans);
  width:100%;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.12);
  background:rgba(250,246,239,.9);
}
textarea{resize:vertical;min-height:80px}
.attend-toggle{display:flex;gap:.7rem;margin-top:.1rem}
.toggle-opt{
  flex:1;position:relative;
}
.toggle-opt input{position:absolute;opacity:0;width:0;height:0}
.toggle-opt span{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.6rem .8rem;
  border:1.5px solid rgba(201,168,76,.3);
  border-radius:9px;
  font-size:.78rem;letter-spacing:.06em;
  color:var(--text-light);
  transition:all var(--trans);cursor:pointer;
}
.toggle-opt input:checked+span{
  background:var(--maroon);color:var(--gold-light);
  border-color:var(--maroon);
}
.rsvp-btn{
  width:100%;padding:1rem;
  background:linear-gradient(135deg,var(--gold-dark),var(--gold),var(--gold-light),var(--gold));
  background-size:200% 100%;
  border-radius:12px;
  font-family:'Jost',sans-serif;
  font-size:.88rem;letter-spacing:.2em;text-transform:uppercase;
  font-weight:500;color:var(--maroon-deep);
  display:flex;align-items:center;justify-content:center;gap:.7rem;
  position:relative;overflow:hidden;
  transition:background-position .5s,box-shadow var(--trans),transform var(--trans);
  box-shadow:0 6px 24px rgba(201,168,76,.3);
}
.rsvp-btn:hover{
  background-position:right center;
  box-shadow:0 10px 36px rgba(201,168,76,.45);
  transform:translateY(-2px);
}
.btn-shimmer{
  position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.28) 50%,transparent 65%);
  animation:shimmerSlide 2.2s ease-in-out infinite;
}
.rsvp-success{
  text-align:center;padding:2rem;
}
.success-heart{
  font-size:3rem;color:var(--rose-gold);
  animation:heartbeat 1.2s ease-in-out infinite;
  display:block;margin-bottom:1rem;
}
.rsvp-success h3{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem;color:var(--maroon);margin-bottom:.5rem;
}
.rsvp-success p{color:var(--text-light);font-size:.9rem}

/* ── FOOTER ── */
.footer{
  background:var(--maroon-deep);
  color:var(--champagne);
  text-align:center;
  padding:3.5rem 1.5rem;
}
.footer-monogram{
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem;font-weight:600;
  color:var(--gold-light);letter-spacing:.06em;
  margin-bottom:.6rem;
}
.footer-monogram span{color:var(--rose-gold)}
.footer-names{
  font-size:.82rem;color:rgba(240,230,208,.6);
  letter-spacing:.1em;margin:.2rem 0;
}
.footer-date{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-style:italic;
  color:var(--gold-light);margin:.4rem 0 1.2rem;
}
.footer-social{display:flex;justify-content:center;gap:1rem;margin-bottom:1.4rem}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(201,168,76,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-light);font-size:.9rem;
  transition:all var(--trans);
}
.footer-social a:hover{background:var(--gold);color:var(--maroon);border-color:var(--gold)}
.footer-love{
  font-size:.8rem;color:rgba(240,230,208,.5);margin-bottom:.3rem;
}
.footer-love i{color:var(--rose-gold);animation:heartbeat 2s ease-in-out infinite}
.footer-copy{font-size:.72rem;color:rgba(240,230,208,.3);letter-spacing:.08em}

/* ── ANIMATIONS ── */
.fade-up{
  opacity:0;transform:translateY(28px);
  animation:fadeInUp .9s forwards;
}
@keyframes fadeInUp{
  to{opacity:1;transform:translateY(0)}
}
.reveal-card{
  opacity:0;transform:translateY(32px);
  transition:opacity .7s ease,transform .7s ease;
}
.reveal-card.visible{opacity:1;transform:translateY(0)}

/* Stagger children */
.events-grid .event-card:nth-child(1){transition-delay:.05s}
.events-grid .event-card:nth-child(2){transition-delay:.12s}
.events-grid .event-card:nth-child(3){transition-delay:.19s}
.events-grid .event-card:nth-child(4){transition-delay:.26s}
.events-grid .event-card:nth-child(5){transition-delay:.33s}
.gallery-item:nth-child(1){transition-delay:.04s}
.gallery-item:nth-child(2){transition-delay:.1s}
.gallery-item:nth-child(3){transition-delay:.16s}
.gallery-item:nth-child(4){transition-delay:.22s}
.gallery-item:nth-child(5){transition-delay:.28s}
.gallery-item:nth-child(6){transition-delay:.34s}
.timeline-item:nth-child(1){transition-delay:.05s}
.timeline-item:nth-child(2){transition-delay:.15s}
.timeline-item:nth-child(3){transition-delay:.25s}
.timeline-item:nth-child(4){transition-delay:.35s}

/* ── RESPONSIVE ── */

/* Tablet */
@media(max-width:900px){
  .nav-links{display:none}
  .timeline::before{left:16px}
  .timeline-item{margin-bottom:2.5rem}
  .timeline-item:nth-child(odd) .tl-content,
  .timeline-item:nth-child(even) .tl-content{
    flex-direction:row;
    margin-left:3rem;
    width:calc(100% - 3rem);
  }
  .tl-marker{left:16px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-item.wide{grid-column:span 2}
}

/* Mobile */
@media(max-width:600px){
  .nav{padding:.8rem 1.2rem}
  .hero-monogram{font-size:3.5rem}
  .hero-names{gap:1rem}
  .name-value{font-size:2.4rem}
  .name-amp{font-size:2rem}
  .save-date-card{padding:1rem 1.8rem}
  .save-day{font-size:3rem}
  .countdown-grid{gap:.6rem}
  .cd-card{padding:1rem 1.2rem;min-width:70px}
  .cd-num{font-size:2.5rem}
  .cd-sep{font-size:2rem}
  .scratch-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .attend-toggle{flex-direction:column}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .gallery-item.wide{grid-column:span 2}
  .gallery-item.tall{grid-row:span 1}
  .tl-photo{width:90px;height:90px}
}

@media(max-width:420px){
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gallery-item.wide,.gallery-item.tall{grid-column:span 1;grid-row:span 1}
  .cd-card{min-width:60px;padding:.8rem .9rem}
  .cd-num{font-size:2rem}
}
