/* ============================================================
   Srinivas & Padmavathi — Venkateswara Wedding Invitation
   Light-gold traditional theme · ultra-modern animations
   ============================================================ */

:root{
  --gold:        #c9a227;
  --gold-light:  #e7c873;
  --gold-deep:   #a87d22;
  --gold-soft:   #f4e4bc;
  --cream:       #fdf6e8;
  --cream-2:     #faedd4;
  --ivory:       #fffdf8;
  --maroon:      #7a1f2b;
  --maroon-deep: #5a141d;
  --kumkum:      #b3122b;
  --ink:         #3a2a1a;
  --ink-soft:    #6b5638;
  --shadow:      0 24px 60px -28px rgba(122,31,43,.35);
  --shadow-soft: 0 14px 40px -22px rgba(168,125,34,.45);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --display: 'Marcellus', serif;
  --script: 'Tangerine', cursive;
  --sanskrit: 'Tiro Devanagari Sanskrit', serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--serif);
  background:var(--cream);
  color:var(--ink);
  font-size:18px;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- Decorative paper texture ---------- */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(circle at 12% 18%, rgba(231,200,115,.18), transparent 40%),
    radial-gradient(circle at 88% 82%, rgba(231,200,115,.16), transparent 42%);
}

/* ============ LOADER ============ */
#loader{
  position:fixed; inset:0; z-index:9999;
  background:linear-gradient(160deg,#fff8ea,#f6e3bd);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:26px; transition:opacity .8s ease, visibility .8s ease;
}
#loader.hide{ opacity:0; visibility:hidden; }
.loader-mandala{
  width:90px; height:90px; border-radius:50%;
  border:3px solid transparent;
  border-top-color:var(--gold); border-right-color:var(--gold-light);
  border-bottom-color:var(--maroon); 
  animation:spin 1.1s linear infinite;
  box-shadow:0 0 0 6px rgba(201,162,39,.12), inset 0 0 0 6px rgba(201,162,39,.08);
}
.loader-text{ font-family:var(--sanskrit); color:var(--maroon); letter-spacing:1px; font-size:1.1rem; }
@keyframes spin{ to{ transform:rotate(360deg);} }

/* ============ WELCOME SCREEN ============ */
#welcome-screen{
  position:fixed; inset:0; z-index:9999;
  background:linear-gradient(160deg,#3d0c14 0%,#5a1020 40%,#2a0810 100%);
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding:20px;
  transition:opacity .8s ease, visibility .8s ease;
}
#welcome-screen.hide{ opacity:0; visibility:hidden; pointer-events:none; }
.wc-inner{ display:flex; flex-direction:column; align-items:center; gap:14px; max-width:480px; }
.wc-sanskrit{
  font-family:var(--sanskrit); color:var(--gold-light);
  font-size:1.1rem; letter-spacing:1px; opacity:.9;
}
.wc-names{
  font-family:var(--display); font-weight:400;
  font-size:clamp(2.4rem,8vw,4.2rem); color:#fff; line-height:1.1; margin:0;
}
.wc-names span{ color:var(--gold-light); font-family:var(--script); font-size:1.2em; }
.wc-date{
  font-family:var(--display); letter-spacing:3px; text-transform:uppercase;
  font-size:.78rem; color:var(--gold-soft); margin:0;
}
.wc-enter{
  margin-top:18px; padding:16px 38px; border-radius:50px;
  background:transparent; border:2px solid var(--gold);
  color:var(--gold-light); font-family:var(--display); font-size:1.15rem;
  cursor:pointer; letter-spacing:1px; display:flex; align-items:center; gap:10px;
  transition:background .3s, color .3s, transform .2s, box-shadow .3s;
  box-shadow:0 0 0 0 rgba(201,162,39,.4);
  animation:wc-pulse 2s ease-in-out infinite;
}
.wc-enter:hover{ background:var(--gold); color:#fff; transform:scale(1.05); }
.wc-music-note{ font-size:1.3rem; animation:wc-bounce .9s ease-in-out infinite alternate; }
@keyframes wc-bounce{ from{transform:translateY(-3px)} to{transform:translateY(3px)} }
@keyframes wc-pulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(201,162,39,.35); }
  50%{ box-shadow:0 0 0 14px rgba(201,162,39,0); }
}
.wc-hint{ font-size:.78rem; color:rgba(255,255,255,.45); letter-spacing:1px; margin:0; }

/* ============ MUSIC BUTTON ============ */
#music-btn{
  position:fixed; bottom:28px; right:28px; z-index:999;
  width:52px; height:52px; border-radius:50%;
  background:linear-gradient(135deg,var(--maroon),#7a1f2b);
  border:2px solid var(--gold); color:var(--gold-light);
  font-size:1.4rem; cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 28px -6px rgba(122,31,43,.55), 0 0 0 0 rgba(201,162,39,.4);
  transition:transform .25s, box-shadow .25s;
  animation:music-pulse 2.4s ease-in-out infinite;
}
#music-btn:hover{ transform:scale(1.12); box-shadow:0 8px 34px -6px rgba(122,31,43,.7), 0 0 0 8px rgba(201,162,39,.18); }
#music-btn .music-icon{ transition:opacity .2s, transform .2s; position:absolute; }
#music-btn .music-icon.playing{ opacity:1; transform:scale(1); }
#music-btn .music-icon.paused{ opacity:0; transform:scale(0.6); }
#music-btn.is-paused .music-icon.playing{ opacity:0; transform:scale(0.6); }
#music-btn.is-paused .music-icon.paused{ opacity:1; transform:scale(1); }
@keyframes music-pulse{
  0%,100%{ box-shadow:0 6px 28px -6px rgba(122,31,43,.55), 0 0 0 0 rgba(201,162,39,.35); }
  50%{ box-shadow:0 6px 28px -6px rgba(122,31,43,.55), 0 0 0 10px rgba(201,162,39,0); }
}

/* ============ SCROLL PROGRESS ============ */
#scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-light),var(--maroon));
  z-index:1000; transition:width .1s linear;
  box-shadow:0 0 12px rgba(201,162,39,.6);
}

/* ============ NAV ============ */
#navbar{
  position:fixed; top:0; left:0; width:100%; z-index:900;
  padding:18px 0; transition:all .45s cubic-bezier(.16,1,.3,1);
}
#navbar.scrolled{
  background:rgba(253,246,232,.82); backdrop-filter:blur(14px);
  box-shadow:0 8px 30px -18px rgba(122,31,43,.4);
  padding:10px 0;
}
.nav-inner{
  max-width:1200px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo{
  font-family:var(--display); font-size:1.7rem; letter-spacing:2px; color:var(--maroon);
}
.nav-logo span{ color:var(--gold); margin:0 2px; }
.nav-links{ list-style:none; display:flex; gap:34px; align-items:center; }
.nav-links a{
  font-family:var(--display); font-size:.82rem; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--ink-soft); position:relative; transition:color .3s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-6px; width:0; height:1.5px;
  background:var(--gold); transition:width .35s ease;
}
.nav-links a:hover{ color:var(--maroon); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{
  padding:9px 20px; border:1.4px solid var(--gold); border-radius:40px;
  color:var(--maroon)!important; background:rgba(201,162,39,.08);
}
.nav-cta::after{ display:none; }
.nav-cta:hover{ background:var(--gold); color:#fff!important; box-shadow:var(--shadow-soft); }
.hamburger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; }
.hamburger span{ width:26px; height:2px; background:var(--maroon); transition:.3s; border-radius:2px; }

/* ============ HERO ============ */
#hero{
  position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:120px 20px 80px; overflow:hidden;
}
.hero-bg{
  position:absolute; inset:-10% 0; z-index:0;
  will-change:transform; transform:translateZ(0); backface-visibility:hidden;
  background:
    radial-gradient(circle at 50% 30%, rgba(255,253,248,.6), transparent 55%),
    linear-gradient(160deg, #fff8ea 0%, #f7e6c0 45%, #f1dcae 100%);
}
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(201,162,39,.05) 0 2px, transparent 2px 22px),
    repeating-linear-gradient(-45deg, rgba(122,31,43,.04) 0 2px, transparent 2px 22px);
  mask-image:radial-gradient(circle at 50% 40%, #000, transparent 75%);
}
.hero-veil{
  position:absolute; inset:0; z-index:1;
  background:radial-gradient(ellipse at 50% 0%, transparent 40%, rgba(122,31,43,.06) 100%);
}
.hero-content{ position:relative; z-index:3; max-width:760px; }

/* Deity frame */
.deity-frame{
  position:relative; width:200px; height:250px; margin:0 auto 26px;
}
.deity-img{
  width:100%; height:100%; object-fit:cover; border-radius:50% 50% 48% 48%/ 60% 60% 40% 40%;
  border:4px solid var(--gold);
  box-shadow:0 18px 50px -18px rgba(122,31,43,.6), inset 0 0 0 2px #fff8;
  position:relative; z-index:2;
}
.deity-halo{
  position:absolute; inset:-26px; z-index:1; border-radius:50%;
  background:radial-gradient(circle, rgba(231,200,115,.85), rgba(231,200,115,0) 68%);
  animation:halo 4s ease-in-out infinite;
}
@keyframes halo{ 0%,100%{ transform:scale(1); opacity:.85;} 50%{ transform:scale(1.12); opacity:1;} }
.deity-arch{
  position:absolute; left:50%; top:-22px; transform:translateX(-50%);
  width:115%; height:60px; z-index:3; pointer-events:none;
  background:radial-gradient(ellipse at 50% 100%, transparent 60%, var(--gold) 61%, var(--gold-deep) 64%, transparent 66%);
  opacity:.5;
}

.sanskrit{
  font-family:var(--sanskrit); color:var(--maroon); font-size:1.35rem; letter-spacing:1px; margin-bottom:14px;
}
.hero-pre{ font-size:1.05rem; color:var(--ink-soft); font-style:italic; margin-bottom:18px; }
.hero-names{
  font-family:var(--display); font-weight:400; line-height:1; margin:6px 0 4px;
  display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:nowrap;
}
.hero-names .name{
  font-size:clamp(2.2rem,6.5vw,5rem);
  background:linear-gradient(180deg,var(--maroon),#9a2e3a 60%, var(--gold-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  white-space:nowrap;
}
.hero-names .amp{
  font-family:var(--script); font-size:clamp(2.6rem,7.5vw,5.8rem); color:var(--gold);
  line-height:0; transform:translateY(.08em);
}
.hero-divider{ display:flex; align-items:center; justify-content:center; gap:14px; margin:18px auto; max-width:340px; }
.hero-divider .line{ flex:1; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.hero-divider .om{ width:30px; height:30px; color:var(--gold-deep); }
.hero-invite{ font-style:italic; color:var(--ink-soft); font-size:1.1rem; margin-bottom:24px; }

.hero-date{
  display:inline-flex; align-items:center; gap:16px; margin:0 auto 8px;
  padding:10px 0; border-top:1.5px solid var(--gold); border-bottom:1.5px solid var(--gold);
}
.hero-date .d-day{ font-family:var(--display); letter-spacing:4px; text-transform:uppercase; font-size:.95rem; color:var(--ink-soft);}
.hero-date .d-num{ font-family:var(--display); font-size:3.4rem; color:var(--maroon); line-height:.9; }
.hero-date .d-meta{ font-family:var(--display); letter-spacing:3px; text-transform:uppercase; font-size:.85rem; color:var(--ink-soft); text-align:left; }
.hero-muhurtham{ color:var(--maroon); font-weight:500; letter-spacing:.5px; margin-bottom:30px; }

/* Countdown */
.countdown{ display:flex; gap:14px; justify-content:center; margin-bottom:34px; flex-wrap:wrap; }
.cd-block{
  min-width:84px; padding:16px 10px; border-radius:16px;
  background:rgba(255,255,255,.55); backdrop-filter:blur(8px);
  border:1px solid rgba(201,162,39,.4); box-shadow:var(--shadow-soft);
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.cd-num{ font-family:var(--display); font-size:2.2rem; color:var(--maroon); line-height:1; }
.cd-label{ font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--ink-soft); }

/* Buttons */
.btn-gold{
  display:inline-block; cursor:pointer; border:none;
  font-family:var(--display); letter-spacing:2.5px; text-transform:uppercase; font-size:.82rem;
  padding:16px 40px; border-radius:50px; color:#fff8e7;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold),var(--gold-light));
  background-size:200% 200%; box-shadow:0 14px 34px -12px rgba(168,125,34,.7);
  position:relative; overflow:hidden; transition:transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s;
}
.btn-gold::before{
  content:""; position:absolute; top:0; left:-120%; width:60%; height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.6),transparent);
  transform:skewX(-20deg); transition:left .7s;
}
.btn-gold:hover{ transform:translateY(-3px) scale(1.02); box-shadow:0 22px 44px -14px rgba(168,125,34,.8); }
.btn-gold:hover::before{ left:130%; }
.btn-gold.full{ width:100%; }

/* Scroll hint */
.scroll-hint{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:4;
  width:26px; height:44px; border:2px solid var(--gold-deep); border-radius:20px;
}
.scroll-hint span{
  position:absolute; left:50%; top:8px; width:5px; height:5px; border-radius:50%;
  background:var(--maroon); transform:translateX(-50%); animation:scrolldot 1.6s infinite;
}
@keyframes scrolldot{ 0%{ top:8px; opacity:1;} 80%{ top:26px; opacity:0;} 100%{opacity:0;} }

/* Petals */
.petals{ position:absolute; inset:0; z-index:2; pointer-events:none; overflow:hidden; }
.petal{ position:absolute; top:-40px; font-size:18px; opacity:.85; animation:fall linear infinite; }
@keyframes fall{
  0%{ transform:translateY(-40px) rotate(0); opacity:0; }
  10%{ opacity:.9; }
  100%{ transform:translateY(110vh) rotate(420deg); opacity:0; }
}

/* ============ MARQUEE ============ */
.marquee{
  background:linear-gradient(90deg,var(--maroon-deep),var(--maroon),var(--maroon-deep));
  color:var(--gold-light); overflow:hidden; padding:13px 0; position:relative; z-index:5;
  border-top:2px solid var(--gold); border-bottom:2px solid var(--gold);
}
.marquee-track{ display:flex; width:max-content; animation:marquee 26s linear infinite; }
.marquee-track span{ font-family:var(--display); letter-spacing:3px; font-size:.92rem; padding:0 30px; white-space:nowrap; }
@keyframes marquee{ to{ transform:translateX(-50%);} }

/* ============ SECTIONS ============ */
.section{ position:relative; z-index:2; padding:100px 24px; max-width:1200px; margin:0 auto; }
.bg-cream{ background:linear-gradient(180deg,var(--ivory),var(--cream-2)); max-width:none; border-radius:0; }
.bg-cream .section-head, .bg-cream > *{ max-width:1200px; margin-left:auto; margin-right:auto; }
.section-head{ text-align:center; margin-bottom:60px; }
.eyebrow{
  display:inline-block; font-family:var(--display); letter-spacing:5px; text-transform:uppercase;
  font-size:.78rem; color:var(--gold-deep); margin-bottom:12px; position:relative; padding:0 40px;
}
.eyebrow::before,.eyebrow::after{
  content:"✦"; position:absolute; top:50%; transform:translateY(-50%); color:var(--gold); font-size:.7rem;
}
.eyebrow::before{ left:0; } .eyebrow::after{ right:0; }
.section-title{
  font-family:var(--display); font-weight:400; font-size:clamp(2.1rem,5vw,3.4rem);
  color:var(--maroon); line-height:1.1;
}
.section-sub{ color:var(--ink-soft); font-style:italic; max-width:560px; margin:14px auto 0; }

/* ============ COUPLE ============ */
.couple-grid{
  display:grid; grid-template-columns:1fr auto 1fr; gap:30px; align-items:center;
}
.couple-card{
  background:var(--ivory); border-radius:24px; padding:34px 28px 36px; text-align:center;
  border:1px solid rgba(201,162,39,.3); box-shadow:var(--shadow);
  transition:transform .5s cubic-bezier(.16,1,.3,1), box-shadow .5s;
}
.couple-card:hover{ transform:translateY(-8px); box-shadow:0 34px 70px -30px rgba(122,31,43,.5); }
.couple-photo{ position:relative; width:170px; height:170px; margin:0 auto 22px; }
.couple-photo img{
  width:100%; height:100%; object-fit:cover; border-radius:50%;
  border:3px solid var(--gold); box-shadow:0 12px 30px -14px rgba(122,31,43,.5);
}
.photo-ring{
  position:absolute; inset:-10px; border-radius:50%;
  border:1.5px dashed var(--gold-deep); animation:spin 22s linear infinite;
}
.couple-card h3{ font-family:var(--display); font-size:1.7rem; color:var(--maroon); }
.role{ font-family:var(--display); letter-spacing:3px; text-transform:uppercase; font-size:.72rem; color:var(--gold-deep); margin:4px 0 14px; }
.parentage{ font-style:italic; color:var(--ink-soft); margin-bottom:14px; }
.bio{ font-size:.96rem; color:var(--ink-soft); }
.couple-knot{ text-align:center; }
.knot-circle{
  width:84px; height:84px; margin:0 auto; border-radius:50%;
  background:radial-gradient(circle,#fff,var(--gold-soft));
  display:flex; align-items:center; justify-content:center; color:var(--kumkum);
  box-shadow:var(--shadow-soft); border:1px solid var(--gold);
  animation:beat 1.8s ease-in-out infinite;
}
.knot-circle svg{ width:46px; height:46px; }
@keyframes beat{ 0%,100%{ transform:scale(1);} 50%{ transform:scale(1.12);} }
.knot-text{ font-family:var(--script); font-size:2.4rem; color:var(--gold-deep); margin-top:6px; }

/* ============ TIMELINE ============ */
.timeline{ position:relative; max-width:780px; margin:0 auto; }
.timeline::before{
  content:""; position:absolute; left:50%; top:0; bottom:0; width:2px; transform:translateX(-50%);
  background:linear-gradient(180deg,transparent,var(--gold),var(--gold-deep),var(--gold),transparent);
}
.tl-item{ position:relative; width:50%; padding:18px 40px; }
.tl-item:nth-child(odd){ left:0; text-align:right; }
.tl-item:nth-child(even){ left:50%; }
.tl-dot{
  position:absolute; top:34px; width:16px; height:16px; border-radius:50%;
  background:var(--gold); border:3px solid var(--maroon); box-shadow:0 0 0 5px rgba(201,162,39,.25);
}
.tl-item:nth-child(odd) .tl-dot{ right:-8px; }
.tl-item:nth-child(even) .tl-dot{ left:-8px; }
.tl-card{
  background:var(--ivory); border-radius:18px; padding:0 0 20px; border:1px solid rgba(201,162,39,.3);
  box-shadow:var(--shadow-soft); transition:transform .45s; overflow:hidden;
}
.tl-card:hover{ transform:scale(1.03); }
.tl-img{ height:170px; overflow:hidden; margin-bottom:14px; border-radius:18px 18px 0 0; }
.tl-img img{ width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.16,1,.3,1); }
.tl-card:hover .tl-img img{ transform:scale(1.07); }
.tl-icon{ font-size:1.6rem; display:block; margin-bottom:6px; padding:0 20px; }
.tl-date{ font-family:var(--display); letter-spacing:2px; text-transform:uppercase; font-size:.68rem; color:var(--gold-deep); padding:0 20px; display:block; }
.tl-card h3{ font-family:var(--display); color:var(--maroon); font-size:1.25rem; margin:4px 0 6px; padding:0 20px; }
.tl-card p{ color:var(--ink-soft); font-size:.96rem; padding:0 20px; }
.tl-venue{ font-style:italic; margin-bottom:14px; }
.tl-card .ev-btn{ display:inline-block; margin:0 20px; }
.tl-dot-gold{ background:var(--maroon); border-color:var(--gold); box-shadow:0 0 0 6px rgba(179,18,43,.18); }
.featured-tl{
  background:linear-gradient(160deg,#fff8ea,var(--gold-soft));
  border:2px solid var(--gold); box-shadow:0 24px 60px -26px rgba(168,125,34,.6);
}
.featured-tl h3{ font-size:1.6rem; }

/* ============ EVENTS ============ */
.events-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:30px; }
.event-card{
  background:var(--ivory); border-radius:22px; overflow:hidden;
  border:1px solid rgba(201,162,39,.3); box-shadow:var(--shadow);
  display:flex; flex-direction:column;
  transition:transform .5s cubic-bezier(.16,1,.3,1), box-shadow .5s;
}
.event-card:hover{ transform:translateY(-10px); box-shadow:0 40px 80px -34px rgba(122,31,43,.55); }
.event-card.featured{ border:2px solid var(--gold); }
.event-media{ position:relative; height:220px; overflow:hidden; }
.event-media img{ width:100%; height:100%; object-fit:cover; transition:transform .9s cubic-bezier(.16,1,.3,1); }
.event-card:hover .event-media img{ transform:scale(1.1); }
.event-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(90,20,29,.5)); }
.event-chip{
  position:absolute; top:16px; left:16px; z-index:2;
  background:rgba(255,248,231,.92); color:var(--maroon); font-family:var(--display);
  letter-spacing:2px; text-transform:uppercase; font-size:.68rem; padding:6px 14px; border-radius:30px;
  border:1px solid var(--gold);
}
.event-chip.gold{ background:linear-gradient(135deg,var(--gold-deep),var(--gold-light)); color:#fff; }
.event-body{ padding:26px 26px 28px; }
.event-body h3{ font-family:var(--display); color:var(--maroon); font-size:1.5rem; margin-bottom:14px; }
.ev-row{ display:flex; align-items:flex-start; gap:10px; font-size:.96rem; color:var(--ink-soft); margin-bottom:7px; }
.ev-row .ic{ width:18px; height:18px; flex:none; margin-top:4px; stroke:var(--gold-deep); fill:none; stroke-width:1.7; }
.ev-desc{ margin:14px 0 18px; font-style:italic; color:var(--ink-soft); font-size:.95rem; }
.ev-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.ev-btn{
  font-family:var(--display); letter-spacing:1.5px; text-transform:uppercase; font-size:.7rem;
  padding:10px 18px; border-radius:30px; border:1.4px solid var(--gold);
  background:var(--gold); color:#fff; transition:.35s;
}
.ev-btn:hover{ background:var(--maroon); border-color:var(--maroon); transform:translateY(-2px); }
.ev-btn.ghost{ background:transparent; color:var(--maroon); }
.ev-btn.ghost:hover{ background:var(--maroon); color:#fff; }

/* ============ VENUE ============ */
.venue-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:26px; }
.venue-card{
  background:var(--ivory); border-radius:20px; padding:0 0 30px; text-align:center; overflow:hidden;
  border:1px solid rgba(201,162,39,.3); box-shadow:var(--shadow-soft); transition:transform .5s, box-shadow .5s;
}
.venue-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.venue-photo{ height:200px; overflow:hidden; margin-bottom:22px; background:var(--cream-2); }
.venue-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.16,1,.3,1); }
.venue-card:hover .venue-photo img{ transform:scale(1.08); }
.venue-card h3{ font-family:var(--display); color:var(--maroon); font-size:1.35rem; margin-bottom:8px; padding:0 24px; }
.v-meta{ color:var(--gold-deep); font-size:.9rem; letter-spacing:.5px; margin-bottom:6px; padding:0 24px; }
.v-addr{ color:var(--ink-soft); font-style:italic; margin-bottom:18px; padding:0 24px; }

/* ============ GALLERY ============ */
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:220px; gap:16px; }
.g-item{ overflow:hidden; border-radius:16px; box-shadow:var(--shadow-soft); position:relative; }
.g-item img{ width:100%; height:100%; object-fit:cover; transition:transform .9s cubic-bezier(.16,1,.3,1); }
.g-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(122,31,43,.35)); opacity:0; transition:.5s; }
.g-item:hover img{ transform:scale(1.12); }
.g-item:hover::after{ opacity:1; }
.g-tall{ grid-row:span 2; }
.g-wide{ grid-column:span 2; }

/* ============ RSVP ============ */
.rsvp-form{
  max-width:680px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:22px 20px;
  background:var(--ivory); padding:42px 38px; border-radius:24px;
  border:1px solid rgba(201,162,39,.3); box-shadow:var(--shadow);
}
.field{ position:relative; }
.field.full{ grid-column:1 / -1; }
.field input,.field select,.field textarea{
  width:100%; padding:16px 14px 8px; font-family:var(--serif); font-size:1rem; color:var(--ink);
  background:var(--cream); border:1.4px solid rgba(201,162,39,.4); border-radius:12px; outline:none;
  transition:border-color .3s, box-shadow .3s; resize:vertical;
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--gold); box-shadow:0 0 0 4px rgba(201,162,39,.16);
}
.field label{
  position:absolute; left:14px; top:15px; color:var(--ink-soft); pointer-events:none;
  transition:.25s ease; font-style:italic;
}
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label,
.field select:focus + label, .field label.floating{
  top:5px; left:12px; font-size:.7rem; letter-spacing:1px; text-transform:uppercase;
  color:var(--gold-deep); font-style:normal;
}
.form-note{ grid-column:1/-1; text-align:center; color:var(--maroon); font-style:italic; min-height:1.2em; }

/* ============ INVITATION ============ */
.invite-wrap{
  max-width:760px; margin:0 auto; text-align:center;
  background:var(--ivory); border-radius:26px; padding:54px 40px 46px;
  border:1px solid rgba(201,162,39,.35); box-shadow:var(--shadow);
  position:relative;
}
.invite-wrap::before, .invite-wrap::after{
  content:""; position:absolute; width:46px; height:46px; border:2px solid var(--gold);
}
.invite-wrap::before{ top:18px; left:18px; border-right:none; border-bottom:none; border-radius:8px 0 0 0; }
.invite-wrap::after{ bottom:18px; right:18px; border-left:none; border-top:none; border-radius:0 0 8px 0; }
.invite-orn{ font-size:2.2rem; color:var(--gold-deep); margin-bottom:14px; }
.invite-lead{
  font-size:1.3rem; font-style:italic; color:var(--ink-soft); line-height:1.8;
  max-width:600px; margin:0 auto 36px;
}
.invite-families{
  display:flex; align-items:center; justify-content:center; gap:30px; flex-wrap:wrap;
  padding-top:26px; border-top:1px solid rgba(201,162,39,.4);
}
.fam h4{ font-family:var(--display); color:var(--maroon); font-size:1.25rem; }
.fam p{ font-size:.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold-deep); margin-top:4px; }
.fam-sep{ color:var(--gold); font-size:1.4rem; }

/* ============ FOOTER ============ */
#footer{
  position:relative; z-index:2; text-align:center; padding:80px 24px 50px;
  background:linear-gradient(180deg,var(--maroon),var(--maroon-deep));
  color:var(--gold-soft);
}
.footer-deity{ width:110px; height:140px; margin:0 auto 22px; }
.footer-deity img{
  width:100%; height:100%; object-fit:cover; border-radius:50% 50% 46% 46%/60% 60% 40% 40%;
  border:3px solid var(--gold); box-shadow:0 0 40px -8px rgba(231,200,115,.6);
}
.foot-sanskrit{ font-family:var(--sanskrit); font-size:1.4rem; color:var(--gold-light); margin-bottom:10px; }
.foot-names{ font-family:var(--display); font-size:2.2rem; color:#fff; }
.foot-names span{ color:var(--gold-light); }
.foot-line{ letter-spacing:3px; text-transform:uppercase; font-size:.8rem; margin:6px 0 18px; color:var(--gold-soft); }
.foot-bless{ max-width:560px; margin:0 auto 22px; font-style:italic; opacity:.9; }
.foot-credit{ font-family:var(--display); letter-spacing:2px; font-size:.78rem; opacity:.7; }

/* ============ REVEAL ANIMATIONS ============ */
.reveal-up{ opacity:0; transform:translateY(40px); transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
.reveal-up.in{ opacity:1; transform:none; }
.reveal-up[data-delay="1"]{ transition-delay:.1s; }
.reveal-up[data-delay="2"]{ transition-delay:.2s; }
.reveal-up[data-delay="3"]{ transition-delay:.3s; }
.reveal-up[data-delay="4"]{ transition-delay:.4s; }
.reveal-up[data-delay="5"]{ transition-delay:.5s; }
.reveal-up[data-delay="6"]{ transition-delay:.6s; }
.reveal-up[data-delay="7"]{ transition-delay:.7s; }
.reveal-up[data-delay="8"]{ transition-delay:.8s; }
.reveal-up[data-delay="9"]{ transition-delay:.9s; }

/* ============ RESPONSIVE ============ */
@media (max-width:900px){
  .couple-grid{ grid-template-columns:1fr; }
  .couple-knot{ transform:rotate(90deg); margin:6px 0; }
  .timeline::before{ left:20px; }
  .tl-item{ width:100%; left:0!important; padding-left:54px; padding-right:0; text-align:left!important; }
  .tl-item .tl-dot{ left:12px!important; right:auto!important; }
}
@media (max-width:760px){
  body{ font-size:17px; }
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:75%; max-width:320px; flex-direction:column;
    background:var(--ivory); padding:100px 36px; gap:26px; transform:translateX(105%);
    transition:transform .45s cubic-bezier(.16,1,.3,1); box-shadow:-20px 0 60px -30px rgba(0,0,0,.5);
  }
  .nav-links.open{ transform:none; }
  .hamburger{ display:flex; z-index:901; }
  .hamburger.active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .hamburger.active span:nth-child(2){ opacity:0; }
  .hamburger.active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .section{ padding:72px 20px; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:170px; }
  .g-wide{ grid-column:span 2; }
  .rsvp-form{ grid-template-columns:1fr; padding:30px 22px; }
  .hero-date .d-num{ font-size:2.6rem; }
  .cd-block{ min-width:68px; padding:12px 6px; }
  .cd-num{ font-size:1.6rem; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; }
  .reveal-up{ opacity:1; transform:none; }
}
