/* ============================================================
   SHANMUKH VARUN  &  THANUJA  ·  Wedding Invitation
   ------------------------------------------------------------
   PALETTE  (Kanchipuram silk + temple gold)
     --maroon   #5C1A2B   deep silk maroon
     --maroon-2 #3A0E1B   near-black maroon (hero / dark sections)
     --emerald  #1B5E4A   temple emerald accent
     --gold     #C9A24B   gold leaf
     --gold-lt  #E8D5A0   champagne highlight
     --ivory    #F7F1E6   warm ivory paper
     --ink      #2A1A12   rich brown-black text
   TYPE
     Cormorant Garamond  · romantic display serif
     Marcellus           · roman-caps labels / monogram
     Jost                · clean modern body
     Ramabhadra/Mandali  · Telugu script
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  --maroon:#7A4F60;
  --maroon-2:#6A4453;
  --maroon-3:#573845;
  --emerald:#6E9079;
  --emerald-lt:#8FB098;
  --gold:#BE9B4E;
  --gold-deep:#937329;
  --gold-lt:#E7D6AE;
  --ivory:#FAF4EF;
  --ivory-2:#F2E8E6;
  --ink:#574350;
  --ink-soft:#8A7884;

  --blush:#F7EBE7;
  --sage:#E9EFE8;
  --cream:#FAF4EF;

  --display:'Cormorant Garamond', Georgia, serif;
  --roman:'Marcellus', 'Cormorant Garamond', serif;
  --body:'Jost', system-ui, sans-serif;
  --telugu:'Ramabhadra', 'Mandali', sans-serif;
  --telugu-body:'Mandali', sans-serif;

  --gold-grad:linear-gradient(135deg,#9C7322 0%,#E8D5A0 28%,#C9A24B 55%,#F3E6C0 78%,#A67C2E 100%);
  --name-grad:linear-gradient(135deg,#8A4A5E 0%,#A86A7C 45%,#7A4F60 100%);

  --maxw:1180px;
  --radius:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-soft:0 24px 55px -30px rgba(122,79,96,.30);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--ivory);
  color:var(--ink);
  line-height:1.65;
  font-weight:300;
  overflow-x:hidden;
  letter-spacing:.2px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
::selection{background:var(--gold);color:var(--maroon-2)}

/* ---------- Layout helpers ---------- */
.wrap{width:min(100% - 2.4rem,var(--maxw));margin-inline:auto}
.wrap--narrow{max-width:760px}
.center{text-align:center}

section{position:relative;padding:clamp(4.5rem,10vw,8rem) 0}
.section--dark{
  background:linear-gradient(180deg, var(--blush) 0%, var(--cream) 100%);
  color:var(--ink);
}
.events,.venue{background:linear-gradient(180deg, var(--sage) 0%, var(--cream) 100%)}
.section--dark .display{color:var(--maroon)}

/* gold hairline at top of each dark section */
.section--dark::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(90%,var(--maxw));height:1px;
  background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold-deep) 50%,var(--gold) 70%,transparent);
  opacity:.7;
}

/* ---------- Shared type ---------- */
.eyebrow{
  font-family:var(--roman);
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:.74rem;
  color:var(--gold-deep);
  margin-bottom:1rem;
}
/* temple gopuram crest above each section label */
.eyebrow::before{
  content:"\f664"; /* fa-gopuram */
  font-family:"Font Awesome 6 Free";font-weight:900;
  display:block;font-size:1.25rem;line-height:1;letter-spacing:normal;
  color:var(--gold);opacity:.9;margin:0 auto .85rem;
}
.section--dark .eyebrow::before{color:var(--gold-deep)}
.section--dark .eyebrow,.eyebrow--gold{color:var(--gold-deep)}
:lang(te),.eyebrow:lang(te){letter-spacing:normal}
.eyebrow[data-rev]:not(:lang(te)){}

.display{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(2.1rem,5.4vw,3.6rem);
  line-height:1.08;
  letter-spacing:.01em;
  color:var(--maroon);
  margin-bottom:.6rem;
}
.display--light{color:var(--maroon)}
.section-note{
  max-width:46ch;margin:1rem auto 0;
  color:var(--ink-soft);font-size:1.02rem;
}
.section--dark .section-note{color:var(--ink-soft)}

/* ---------- Dividers ---------- */
.divider{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  margin:1.6rem auto;color:var(--gold);font-size:1rem;
}
.divider::before,.divider::after{
  content:"";height:1px;width:min(26vw,150px);
  background:linear-gradient(90deg,transparent,var(--gold));
}
.divider::after{background:linear-gradient(90deg,var(--gold),transparent)}
/* motif divider: a gold rule with a gap, and a rotated gold jewel centered in it */
.divider--motif{
  position:relative;display:block;height:30px;margin:2.4rem auto 0;
  width:min(70vw,420px);font-size:0;gap:0;
}
.divider--motif::before{ /* horizontal rule with a clear gap in the middle */
  content:"";position:absolute;top:50%;left:0;right:0;height:1px;transform:translateY(-50%);
  width:auto;
  background:linear-gradient(90deg,
    transparent,var(--gold-deep) 18%,var(--gold) 40%,
    transparent 47%,transparent 53%,
    var(--gold) 60%,var(--gold-deep) 82%,transparent);
}
.divider--motif::after{ /* centered jewel (rotated square = lozenge) */
  content:"";position:absolute;top:50%;left:50%;
  width:12px;height:12px;transform:translate(-50%,-50%) rotate(45deg);
  background:var(--gold-grad);
  box-shadow:0 0 0 3px rgba(247,241,230,.0),0 0 12px rgba(201,162,75,.6);
}
.section--dark .divider{color:var(--gold-deep)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--roman);letter-spacing:.16em;text-transform:uppercase;
  font-size:.8rem;
  padding:.95rem 1.9rem;border-radius:50px;
  position:relative;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.btn i{font-size:.85em;transition:transform .4s var(--ease)}
.btn--gold{
  background:var(--gold-grad);color:var(--maroon-2);
  box-shadow:0 14px 30px -12px rgba(166,124,46,.7);
  background-size:200% 100%;
}
.btn--gold:hover{transform:translateY(-3px);background-position:100% 0}
.btn--gold:hover i.fa-arrow-down-long{transform:translateY(3px)}
.btn--gold:hover i.fa-diamond-turn-right{transform:translateX(3px)}

/* ============================================================
   LOADER
   ============================================================ */
.loader{
  position:fixed;inset:0;z-index:9999;
  display:grid;place-items:center;
  background:radial-gradient(120% 120% at 50% 30%,var(--blush),var(--cream));
  transition:opacity .9s var(--ease),visibility .9s;
}
.loader.is-done{opacity:0;visibility:hidden}
.loader__art{text-align:center;color:var(--maroon)}
.loader__arch{width:120px;height:150px;margin-inline:auto}
.loader__arch .draw{
  fill:none;stroke:var(--gold-deep);stroke-width:1.5;
  stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:600;stroke-dashoffset:600;
  animation:draw 2.2s var(--ease) forwards;
}
@keyframes draw{to{stroke-dashoffset:0}}
.loader__mono{
  font-family:var(--display);font-size:2.4rem;letter-spacing:.1em;
  margin-top:.4rem;opacity:0;animation:fadeUp .8s 1.4s forwards;
}
.loader__mono span{color:var(--gold-deep);font-size:1.4rem;vertical-align:.2em}
.loader__tag{
  font-family:var(--telugu-body);font-size:.85rem;letter-spacing:.06em;
  opacity:0;animation:fadeUp .8s 1.7s forwards;margin-top:.3rem;
  color:var(--ink-soft);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ============================================================
   PETALS (ambient canvas)
   ============================================================ */
.petals{
  position:fixed;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:5;
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem clamp(1.2rem,4vw,2.4rem);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
}
.nav.is-scrolled{
  background:rgba(250,244,239,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding-block:.7rem;
  box-shadow:0 10px 30px -18px rgba(122,79,96,.22);
}
.nav__brand{display:inline-flex}
.nav__mono{
  font-family:var(--display);font-size:1.5rem;color:var(--maroon);
  letter-spacing:.08em;
}
.nav__mono span{color:var(--gold-deep);font-size:.95rem;vertical-align:.18em;margin:0 .1em}
.nav__links{display:flex;gap:1.7rem}
.nav__links a{
  font-family:var(--roman);font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink);position:relative;
  padding:.2rem 0;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
  background:var(--gold-deep);transition:width .4s var(--ease);
}
.nav__links a:hover{color:var(--maroon)}
.nav__links a:hover::after{width:100%}

.nav__toggle{display:none;width:42px;height:42px;flex-direction:column;
  gap:5px;align-items:center;justify-content:center}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--maroon);
  border-radius:2px;transition:transform .4s var(--ease),opacity .3s}
.nav.is-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.is-open .nav__toggle span:nth-child(2){opacity:0}
.nav.is-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100svh;display:grid;place-items:center;
  text-align:center;color:var(--ink);overflow:hidden;
  padding:7rem 1.2rem 5rem;
}
.hero__bg{
  position:absolute;inset:-8% 0;z-index:0;
  /* REPLACE IMAGE: swap the gradient for url('images/hero.jpg') */
  background:
    radial-gradient(80% 60% at 50% 20%, rgba(190,155,78,.12), transparent 60%),
    linear-gradient(180deg, var(--blush) 0%, var(--cream) 45%, var(--sage) 100%);
  background-size:cover;background-position:center;
  will-change:transform;
}
/* decorative gold mandala glow behind names */
.hero__veil{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(60% 55% at 50% 42%, rgba(201,162,75,.16), transparent 65%),
    repeating-conic-gradient(from 0deg at 50% 42%,
      rgba(232,213,160,.05) 0deg 6deg, transparent 6deg 12deg);
  mask-image:radial-gradient(60% 55% at 50% 42%,#000,transparent 70%);
  -webkit-mask-image:radial-gradient(60% 55% at 50% 42%,#000,transparent 70%);
}
.hero__inner{position:relative;z-index:2;max-width:900px}
.hero__eyebrow{
  font-family:var(--roman);text-transform:uppercase;letter-spacing:.4em;
  font-size:.78rem;color:var(--gold-deep);margin-bottom:1.4rem;
}

/* Monogram — temple gopuram (signature mark) */
.monogram{position:relative;width:min(240px,66vw);aspect-ratio:240/150;margin:0 auto 2.2rem}
.monogram__arch{width:100%;height:100%;overflow:visible}
.monogram__arch .ml-stroke{
  fill:none;stroke:var(--gold);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 0 5px rgba(201,162,75,.4));
}
.monogram__arch .ml-fill{fill:var(--gold);filter:drop-shadow(0 0 5px rgba(201,162,75,.4))}
.monogram__letters{
  position:absolute;left:0;right:0;top:56%;transform:translateY(-50%);
  display:flex;align-items:center;justify-content:center;gap:.12em;white-space:nowrap;line-height:1;
  font-family:var(--display);font-size:clamp(1.7rem,5vw,2.3rem);color:var(--maroon);letter-spacing:.05em;
}
.monogram__letters .amp{
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;
  color:transparent;font-size:.62em;align-self:center;
}
.monogram--sm{width:auto;height:auto;aspect-ratio:auto;margin-bottom:.4rem}
.monogram--sm .monogram__letters{position:static;transform:none;font-size:2rem;color:var(--gold-deep)}

/* Names */
.hero__names{
  display:flex;flex-direction:column;align-items:center;
  font-family:var(--display);font-weight:500;
  line-height:1;margin:.6rem 0 1.4rem;
}
.hero__name{
  font-size:clamp(2.8rem,11vw,6.2rem);
  background:var(--name-grad);-webkit-background-clip:text;background-clip:text;
  color:transparent;
  text-shadow:0 4px 30px rgba(122,79,96,.14);
}
.hero__amp{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(1.1rem,3.4vw,1.7rem);
  text-transform:lowercase;letter-spacing:.2em;color:var(--gold-deep);
  margin:.35em 0;position:relative;
}
.hero__amp::before,.hero__amp::after{
  content:"";display:inline-block;width:40px;height:1px;vertical-align:middle;
  background:linear-gradient(90deg,transparent,var(--gold));margin:0 .9rem;
}
.hero__amp::after{background:linear-gradient(90deg,var(--gold),transparent)}

.hero__meta{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:.6rem;font-size:1rem;color:var(--ink);letter-spacing:.05em;
}
.hero__meta i{color:var(--gold);margin-right:.35rem}
.hero__meta .dot{color:var(--gold)}
.hero__venue{
  margin-top:.7rem;font-size:.96rem;color:var(--ink-soft);
  max-width:30ch;margin-inline:auto;
}
.hero__venue i{color:var(--gold);margin-right:.35rem}
.hero__cta{margin-top:2.2rem}

/* scroll cue */
.hero__scroll{
  position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);
  z-index:3;width:24px;height:42px;border:1px solid rgba(147,115,41,.5);
  border-radius:30px;display:grid;place-items:start center;padding-top:7px;
}
.hero__scroll-line{width:2px;height:8px;border-radius:2px;background:var(--gold-deep);
  animation:scrollCue 1.8s var(--ease) infinite}
@keyframes scrollCue{0%{opacity:0;transform:translateY(0)}30%{opacity:1}
  100%{opacity:0;transform:translateY(14px)}}

/* hero entrance */
.reveal-hero>*{opacity:0;transform:translateY(26px)}
.reveal-hero.is-in>*{opacity:1;transform:none;
  transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal-hero.is-in>*:nth-child(1){transition-delay:.1s}
.reveal-hero.is-in>*:nth-child(2){transition-delay:.25s}
.reveal-hero.is-in>*:nth-child(3){transition-delay:.4s}
.reveal-hero.is-in>*:nth-child(4){transition-delay:.55s}
.reveal-hero.is-in>*:nth-child(5){transition-delay:.7s}
.reveal-hero.is-in>*:nth-child(6){transition-delay:.85s}

/* ============================================================
   INVITATION
   ============================================================ */
.invitation__lead{
  font-family:var(--display);font-size:clamp(1.2rem,2.6vw,1.55rem);
  font-style:italic;color:var(--ink);max-width:48ch;margin:0 auto 1.8rem;
}
.invitation__families{
  font-size:1.05rem;line-height:2;color:var(--ink);max-width:52ch;margin-inline:auto;
}
.invitation__families strong{
  display:inline-block;font-family:var(--roman);font-weight:400;
  color:var(--gold-deep);letter-spacing:.04em;font-size:1.12rem;
}
.invitation__families .and{
  display:block;font-family:var(--display);font-style:italic;color:var(--gold-deep);
  margin:.4rem 0;font-size:1.1rem;
}
.invitation__req{display:block;margin:1.2rem 0 .3rem;font-size:.95rem;color:var(--ink-soft)}
.invitation__families em{
  font-family:var(--display);font-style:normal;font-size:1.45rem;color:var(--maroon);
}
.invitation__telugu{
  font-family:var(--telugu-body);font-size:1.15rem;color:var(--gold-deep);
  margin-top:1.8rem;line-height:1.9;
}

/* ============================================================
   STORY TIMELINE
   ============================================================ */
.story{background:linear-gradient(180deg,var(--ivory),var(--ivory-2))}
.timeline{margin-top:3.2rem;position:relative}
/* center spine */
.timeline::before{
  content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:2px;background:linear-gradient(180deg,transparent,var(--gold) 8%,var(--gold) 92%,transparent);
  opacity:.55;
}
.tl-item{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:2.4rem;
  margin-bottom:3.4rem;position:relative;
}
.tl-item::after{ /* node on the spine */
  content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:16px;height:16px;border-radius:50%;
  background:var(--gold-grad);box-shadow:0 0 0 6px var(--ivory),0 0 0 7px rgba(201,162,75,.4);
}
.tl-item:nth-child(even) .tl-media{order:2}
.tl-item:nth-child(even) .tl-card{order:1;text-align:right}
.tl-media .ph{aspect-ratio:4/3;border-radius:var(--radius)}
.tl-card{padding:1.8rem}
.tl-year{
  font-family:var(--roman);letter-spacing:.3em;font-size:.78rem;color:var(--gold-deep);
}
.tl-card h3{font-family:var(--display);font-size:1.7rem;color:var(--maroon);margin:.2rem 0 .5rem}
.tl-card p{color:var(--ink-soft);font-size:.98rem}

/* ============================================================
   EVENTS
   ============================================================ */
.events__grid{
  margin-top:3rem;display:grid;gap:1.6rem;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.ev-card{padding:2.1rem 1.8rem;text-align:center;display:flex;flex-direction:column}
.ev-card__icon{
  width:64px;height:64px;margin:0 auto 1rem;border-radius:50%;
  display:grid;place-items:center;font-size:1.4rem;color:var(--gold-deep);
  background:radial-gradient(circle at 30% 25%,rgba(190,155,78,.28),rgba(110,144,121,.18));
  border:1px solid rgba(201,162,75,.5);
}
.ev-card__te{font-family:var(--telugu);font-size:1.15rem;color:var(--gold-deep);letter-spacing:.02em}
.ev-card h3{font-family:var(--display);font-size:1.6rem;margin:.15rem 0 1rem;color:var(--maroon)}
.ev-card__facts{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;
  font-size:.92rem;color:var(--ink-soft);text-align:left}
.ev-card__facts li{display:flex;gap:.6rem;align-items:flex-start}
.ev-card__facts i{color:var(--gold);margin-top:.25rem;flex:0 0 auto}
.ev-card p{color:var(--ink-soft);font-size:.92rem;margin-top:auto}
.ev-card--feature{
  border-color:rgba(201,162,75,.55);
  box-shadow:0 0 0 1px rgba(190,155,78,.3) inset,0 30px 60px -30px rgba(122,79,96,.2);
  background:linear-gradient(160deg,rgba(190,155,78,.14),rgba(110,144,121,.12));
}
.ev-card--feature .ev-card__icon{background:var(--gold-grad);color:var(--maroon-2)}
@media(min-width:880px){
  .ev-card--feature{grid-column:span 1;transform:scale(1.02)}
}

/* ============================================================
   COUNTDOWN
   ============================================================ */
.countdown{color:var(--ink);overflow:hidden;display:grid;place-items:center;text-align:center}
.countdown__bg{
  position:absolute;inset:0;z-index:0;
  /* REPLACE IMAGE: swap for url('images/countdown.jpg') */
  background:
    radial-gradient(70% 60% at 50% 30%,rgba(143,176,152,.4),transparent),
    linear-gradient(135deg,var(--blush),var(--sage) 140%);
  background-size:cover;background-position:center;will-change:transform;
}
.countdown__veil{position:absolute;inset:0;z-index:1;background:rgba(255,255,255,.12)}
.countdown__inner{position:relative;z-index:2}
.cd{
  display:flex;align-items:center;justify-content:center;gap:clamp(.4rem,2vw,1.4rem);
  margin:2.4rem auto 1rem;flex-wrap:nowrap;
}
.cd__unit{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  min-width:clamp(64px,18vw,120px);padding:1.2rem .6rem;border-radius:16px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(147,115,41,.3);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.cd__num{
  font-family:var(--display);font-size:clamp(2.2rem,7vw,3.6rem);line-height:1;
  background:var(--name-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-variant-numeric:tabular-nums;display:inline-block;
}
.cd__num.tick{animation:tick .5s var(--ease)}
@keyframes tick{0%{transform:translateY(-6px);opacity:.3}100%{transform:none;opacity:1}}
.cd__label{font-family:var(--roman);text-transform:uppercase;letter-spacing:.2em;
  font-size:.62rem;color:var(--gold-deep)}
.cd__sep{font-family:var(--display);font-size:2rem;color:var(--gold-deep);opacity:.7;align-self:flex-start;margin-top:1.2rem}
.cd__date{font-family:var(--roman);letter-spacing:.4em;color:var(--gold-deep);font-size:1rem;margin-top:.6rem}

/* ============================================================
   FAMILY
   ============================================================ */
.family__split{
  margin-top:3rem;display:grid;gap:2rem;align-items:center;
  grid-template-columns:1fr auto 1fr;
}
.fam-card{padding:2.4rem 1.8rem;text-align:center}
.fam-card__kin{font-family:var(--roman);text-transform:uppercase;letter-spacing:.3em;
  font-size:.72rem;color:var(--gold-deep)}
.fam-card__house{
  font-family:var(--display);font-style:italic;font-size:1.2rem;color:var(--gold-deep);display:block;margin:.2rem 0 1.2rem}
.fam-card__te{font-family:var(--telugu);font-size:1.25rem;color:var(--gold-deep);margin-top:.1rem}
.fam-card__place{font-size:.82rem;color:var(--ink-soft);margin-top:.8rem;line-height:1.6;letter-spacing:.03em}
.fam-card .ph--round{width:140px;height:140px;border-radius:50%;margin:0 auto 1.2rem}
.fam-card h3{font-family:var(--display);font-size:2rem;color:var(--maroon);margin-bottom:.2rem}
.fam-card__son{font-size:.85rem;color:var(--ink-soft);letter-spacing:.1em;text-transform:uppercase}
.fam-card__parents{font-size:1.05rem;line-height:1.8;color:var(--ink);margin-top:.4rem}
.fam-card__parents span{color:var(--gold-deep);font-family:var(--display);font-style:italic}
.fam-knot{font-size:1.6rem;color:var(--gold-deep);display:grid;place-items:center;
  width:58px;height:58px;border-radius:50%;border:1px solid rgba(201,162,75,.5);
  margin:0 auto;background:radial-gradient(circle,rgba(201,162,75,.2),transparent)}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:linear-gradient(180deg,var(--ivory-2),var(--ivory))}
.gallery__grid{
  margin-top:3rem;display:grid;gap:14px;
  grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;grid-auto-flow:dense;
}
.g-item{
  position:relative;overflow:hidden;border-radius:14px;display:block;
  box-shadow:var(--shadow-soft);
}
.g-item[style*="--span:2"]{grid-row:span 2}
.g-item .ph{width:100%;height:100%;transition:transform 1.1s var(--ease)}
.g-item::after{ /* hover veil + zoom cue */
  content:"\f00e";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;inset:0;display:grid;place-items:center;color:var(--ivory);
  font-size:1.4rem;background:linear-gradient(180deg,rgba(58,14,27,0),rgba(58,14,27,.55));
  opacity:0;transition:opacity .4s var(--ease);
}
.g-item:hover .ph{transform:scale(1.08)}
.g-item:hover::after{opacity:1}

/* ============================================================
   VENUE
   ============================================================ */
.venue__card{
  margin-top:3rem;display:grid;grid-template-columns:1.1fr 1fr;overflow:hidden;padding:0;
}
.venue__card--noimg{grid-template-columns:1fr;text-align:center;max-width:720px}
.venue__card--noimg .venue__addr,
.venue__card--noimg .venue__facts{align-items:center}
.venue__card--noimg .venue__facts{display:inline-flex}
.venue__media .ph{height:100%;min-height:340px;border-radius:0}
.venue__body{padding:clamp(1.8rem,4vw,3rem)}
.venue__body h3{font-family:var(--display);font-size:clamp(1.7rem,3.4vw,2.3rem);color:var(--maroon);line-height:1.15}
.venue__addr{margin:1.2rem 0;color:var(--ink-soft);line-height:1.7}
.venue__addr i{color:var(--gold);margin-right:.4rem}
.venue__facts{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.8rem;color:var(--ink-soft)}
.venue__facts i{color:var(--gold);margin-right:.5rem}

/* ============================================================
   TRAVEL
   ============================================================ */
.travel{background:linear-gradient(180deg,var(--ivory),var(--ivory-2))}
.travel__grid{
  margin-top:3rem;display:grid;gap:1.4rem;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.trv-card{padding:2rem 1.7rem}
.trv-card__icon{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  font-size:1.2rem;color:var(--maroon-2);background:var(--gold-grad);margin-bottom:1rem;
}
.trv-card h3{font-family:var(--display);font-size:1.5rem;color:var(--maroon);margin-bottom:.5rem}
.trv-card p{color:var(--ink-soft);font-size:.96rem}
.trv-card strong{color:var(--maroon);font-weight:500}
.trv-card__contact{display:flex;flex-direction:column;gap:.4rem;margin-top:.6rem}
.trv-card__contact a{color:var(--emerald);font-weight:400;letter-spacing:.04em}
.trv-card__contact i{color:var(--gold-deep);margin-right:.4rem}

/* light cards on ivory (story/travel/gallery use .glass too) */
.story .glass,.travel .glass{
  background:rgba(255,255,255,.55);
  border:1px solid rgba(201,162,75,.35);
}
.story .tl-card h3,.travel .trv-card h3{color:var(--maroon)}

/* ============================================================
   BLESSING
   ============================================================ */
.blessing__sloka{font-family:var(--telugu);font-size:clamp(1.2rem,3.6vw,1.75rem);
  color:var(--maroon);letter-spacing:.01em;margin-bottom:1.2rem;line-height:1.7}
.blessing__quote{font-family:var(--display);font-style:italic;
  font-size:clamp(1.3rem,3vw,1.8rem);color:var(--ink);max-width:32ch;margin-inline:auto;line-height:1.5}
.blessing__sub{font-family:var(--roman);letter-spacing:.3em;text-transform:uppercase;
  font-size:.8rem;color:var(--gold-deep);margin-top:1.4rem}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:linear-gradient(180deg,var(--blush),var(--ivory-2));color:var(--ink);text-align:center;
  padding:clamp(3.5rem,7vw,5rem) 0 2.5rem;position:relative;
}
.footer::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(90%,var(--maxw));height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.footer__names{font-family:var(--display);font-size:clamp(1.8rem,5vw,2.6rem);
  color:var(--gold-deep);margin:.3rem 0 .2rem;font-weight:500}
.footer__date{font-family:var(--roman);letter-spacing:.3em;font-size:.8rem;color:var(--ink-soft)}
.footer__thanks{max-width:42ch;margin:1.4rem auto;color:var(--ink-soft);font-size:.98rem}
.footer__contact{display:flex;justify-content:center;flex-wrap:wrap;gap:1.4rem;margin-bottom:.4rem}
.footer__contact a{color:var(--gold-deep);letter-spacing:.04em;font-size:.95rem}
.footer__contact i{color:var(--gold);margin-right:.4rem}
.footer__social{display:flex;justify-content:center;gap:1rem;margin:1.6rem 0}
.footer__social a{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  border:1px solid rgba(147,115,41,.45);color:var(--gold-deep);font-size:1.05rem;
  transition:transform .4s var(--ease),background .4s,color .4s;
}
.footer__social a:hover{transform:translateY(-3px);background:var(--gold-grad);color:var(--maroon-2);border-color:transparent}
.footer__credit{font-family:var(--telugu-body);font-size:.85rem;color:var(--ink-soft);margin-top:1rem;letter-spacing:.05em}

/* ============================================================
   GLASS CARD (shared)
   ============================================================ */
.glass{
  background:rgba(255,255,255,.6);
  border:1px solid rgba(147,115,41,.28);
  border-radius:var(--radius);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:var(--shadow-soft);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;
  position:relative;
}
.glass:hover{transform:translateY(-6px);border-color:rgba(147,115,41,.5);
  box-shadow:0 36px 70px -34px rgba(122,79,96,.22)}

/* ============================================================
   IMAGE PLACEHOLDERS
   To use a real photo, replace the .ph element with:
   <img src="images/your.jpg" alt="..."> (it will fill the slot).
   ============================================================ */
.ph{
  position:relative;display:block;width:100%;border-radius:var(--radius);
  background:
    linear-gradient(135deg,rgba(190,155,78,.18),rgba(110,144,121,.18)),
    repeating-linear-gradient(45deg,rgba(201,162,75,.08) 0 12px,transparent 12px 24px),
    #efe3cc;
  overflow:hidden;
}
/* when a real photo replaces a placeholder: <img class="ph ..."> */
img.ph{object-fit:cover;height:100%}
.fam-card img.ph--round{width:140px;height:140px;object-fit:cover}
.section--dark .ph{background:
    linear-gradient(135deg,rgba(190,155,78,.18),rgba(110,144,121,.18)),
    repeating-linear-gradient(45deg,rgba(190,155,78,.08) 0 12px,transparent 12px 24px),
    #efe3cc}
.ph::after{
  content:"\f03e  " attr(data-label);
  font-family:"Font Awesome 6 Free","Jost",sans-serif;font-weight:900;
  position:absolute;inset:0;display:grid;place-items:center;
  font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(122,79,96,.5);
}
.section--dark .ph::after{color:rgba(122,79,96,.5)}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;inset:0;z-index:5000;display:grid;place-items:center;
  background:rgba(74,55,66,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;transition:opacity .4s var(--ease);
}
.lightbox[hidden]{display:none}
.lightbox.is-open{opacity:1}
.lightbox__stage{max-width:min(90vw,900px);text-align:center}
.lightbox__content{
  width:min(90vw,900px);aspect-ratio:3/2;border-radius:14px;overflow:hidden;
  box-shadow:0 40px 90px -30px #000;border:1px solid rgba(201,162,75,.4);
}
.lightbox__content .ph{height:100%}
.lightbox__content img{width:100%;height:100%;object-fit:cover}
.lightbox__caption{font-family:var(--roman);letter-spacing:.18em;text-transform:uppercase;
  font-size:.8rem;color:var(--gold-deep);margin-top:1rem}
.lightbox__close,.lightbox__nav{
  position:absolute;color:var(--gold-deep);font-size:1.3rem;width:52px;height:52px;
  border-radius:50%;display:grid;place-items:center;border:1px solid rgba(201,162,75,.4);
  background:rgba(74,55,66,.5);transition:background .3s,transform .3s}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--gold-grad);color:var(--maroon-2)}
.lightbox__close{top:1.4rem;right:1.4rem}
.lightbox__nav--prev{left:1.4rem;top:50%;transform:translateY(-50%)}
.lightbox__nav--next{right:1.4rem;top:50%;transform:translateY(-50%)}
.lightbox__nav--prev:hover{transform:translateY(-50%) scale(1.05)}
.lightbox__nav--next:hover{transform:translateY(-50%) scale(1.05)}

/* footer temple crest */
.footer__temple{font-size:1.7rem;color:var(--gold-deep);opacity:.9;margin-bottom:.4rem}

/* ============================================================
   BACKGROUND MUSIC TOGGLE
   ============================================================ */
.music-toggle{
  position:fixed;left:1.2rem;bottom:1.2rem;z-index:1500;
  width:50px;height:50px;border-radius:50%;display:grid;place-items:center;
  background:var(--gold-grad);color:var(--maroon-2);
  box-shadow:0 14px 30px -12px rgba(166,124,46,.8);
  transition:transform .4s var(--ease);
}
.music-toggle:hover{transform:translateY(-3px)}
.music-toggle__bars{display:flex;align-items:flex-end;gap:3px;height:18px}
.music-toggle__bars i{display:block;width:3px;height:5px;border-radius:2px;background:var(--maroon-2)}
/* animate the equalizer only while playing */
.music-toggle.is-playing .music-toggle__bars i{animation:eq .9s var(--ease) infinite}
.music-toggle.is-playing .music-toggle__bars i:nth-child(2){animation-delay:.15s}
.music-toggle.is-playing .music-toggle__bars i:nth-child(3){animation-delay:.3s}
.music-toggle.is-playing .music-toggle__bars i:nth-child(4){animation-delay:.45s}
@keyframes eq{0%,100%{height:5px}50%{height:16px}}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.to-top{
  position:fixed;right:1.2rem;bottom:1.2rem;z-index:1500;
  width:50px;height:50px;border-radius:50%;display:grid;place-items:center;
  background:var(--gold-grad);color:var(--maroon-2);font-size:1rem;
  box-shadow:0 14px 30px -12px rgba(166,124,46,.8);
  opacity:0;visibility:hidden;transform:translateY(14px);
  transition:opacity .4s var(--ease),transform .4s var(--ease),visibility .4s;
}
.to-top.is-show{opacity:1;visibility:visible;transform:none}
.to-top:hover{transform:translateY(-3px)}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:920px){
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(78vw,340px);
    flex-direction:column;justify-content:center;gap:1.6rem;padding:2rem;
    background:rgba(247,235,231,.98);backdrop-filter:blur(16px);
    transform:translateX(100%);transition:transform .5s var(--ease);
  }
  .nav.is-open .nav__links{transform:none}
  .nav__links a{font-size:1.05rem}
  .nav__toggle{display:flex;z-index:1001}
}
@media(max-width:760px){
  .timeline::before{left:22px}
  .tl-item{grid-template-columns:1fr;gap:1rem;padding-left:48px}
  .tl-item::after{left:22px;top:24px}
  .tl-item:nth-child(even) .tl-media{order:0}
  .tl-item:nth-child(even) .tl-card{order:0;text-align:left}
  .family__split{grid-template-columns:1fr}
  .fam-knot{transform:rotate(90deg)}
  .venue__card{grid-template-columns:1fr}
  .venue__media .ph{min-height:240px}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .cd__sep{display:none}
  .cd{gap:.5rem}
}
@media(max-width:420px){
  .cd__unit{min-width:62px;padding:.9rem .4rem}
}

/* ============================================================
   ACCESSIBILITY · reduced motion
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
  .reveal,.reveal-hero>*{opacity:1 !important;transform:none !important}
  .petals{display:none}
  .hero__scroll-line{animation:none}
}
