/* =========================================================================
   Varun & Jasmine  -  Wedding Website
   Aesthetic: "Mughal palace at golden hour" - ivory parchment, gold leaf,
   jewel tones (maroon / emerald / amethyst), ornate, editorial elegance.
   ========================================================================= */

/* ----------  Design tokens  ---------- */
:root{
  --ink:#2b2117;            /* primary text - warm near-black */
  --ink-soft:#5c4d3a;       /* secondary text */
  --cream:#f8f1e2;          /* base parchment */
  --cream-2:#f2e7cf;        /* deeper parchment */
  --paper:#fffaf0;          /* card paper */
  --maroon:#7a1f2e;         /* deep red */
  --maroon-deep:#5b1622;
  --emerald:#1f6b4f;
  --amethyst:#5b2a86;
  --gold:#c9a227;
  --gold-soft:#e9cf7a;
  --gold-deep:#9c7314;          /* decorative strokes only */
  --gold-ink:#7a560c;           /* gold text on light (>=4.5:1 on cream/paper) */
  --line:rgba(122,31,46,.16);

  --gold-grad:linear-gradient(135deg,#f6e3a1 0%,#c9a227 38%,#9c7314 62%,#e9cf7a 82%,#8a6310 100%);
  --gold-grad-btn:linear-gradient(135deg,#f6e3a1 0%,#edd07a 45%,#d9b53e 100%); /* light face for dark btn text (>=4.5:1) */
  --gold-grad-ink:linear-gradient(135deg,#6e4d0c 0%,#85620f 50%,#9c7314 100%); /* text on light - all stops >=3.8:1 */

  --maxw:1180px;
  --gutter:clamp(20px,5vw,72px);
  --radius:6px;
  --shadow-1:0 10px 30px -18px rgba(43,33,23,.45);
  --shadow-2:0 26px 60px -30px rgba(43,33,23,.55);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----------  Reset  ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--body,"EB Garamond",Georgia,serif);
  color:var(--ink);background:var(--cream);
  font-size:clamp(17px,1.05vw + 12px,20px);line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
:root{
  --display:"Cormorant Garamond",Georgia,serif;
  --script:"Great Vibes",cursive;
  --label:"Cinzel","Cormorant Garamond",serif;
  --body:"EB Garamond",Georgia,serif;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
h1,h2,h3,h4{margin:0;font-weight:600;line-height:1.12}
main:focus{outline:none}

body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1200px 800px at 50% -10%,rgba(201,162,39,.10),transparent 60%),
    radial-gradient(900px 700px at 110% 10%,rgba(91,42,134,.06),transparent 55%),
    radial-gradient(900px 700px at -10% 80%,rgba(31,107,79,.06),transparent 55%),
    var(--cream);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}

/* ----------  Skip link  ---------- */
a.skip-link{position:fixed;left:-999px;top:0;z-index:100}
a.skip-link:focus{left:12px;top:12px}

/* ----------  Layout helpers  ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(72px,9vw,140px);position:relative}
.section--tight{padding-block:clamp(48px,6vw,96px)}
.center{text-align:center}

.eyebrow{font-family:var(--label);text-transform:uppercase;letter-spacing:.42em;font-size:.72rem;color:var(--maroon);font-weight:600;margin:0 0 .9rem}
.section-title{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,5vw,3.6rem);letter-spacing:.01em}
.script{font-family:var(--script);font-weight:400;line-height:1}
.gold-text{
  color:var(--maroon);                         /* fallback if clip unsupported */
  background:var(--gold-grad-ink);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.lede{max-width:62ch;margin-inline:auto;color:var(--ink-soft)}

.flourish{display:flex;align-items:center;justify-content:center;gap:.8rem;margin:1.4rem auto 0;color:var(--gold-deep)}
.flourish::before,.flourish::after{content:"";height:1px;width:min(90px,18vw);background:linear-gradient(90deg,transparent,var(--gold-deep))}
.flourish::after{background:linear-gradient(270deg,transparent,var(--gold-deep))}
.flourish svg{width:30px;height:18px}

/* ----------  Buttons  ---------- */
.btn{
  --bg:var(--maroon);--fg:#fdf6e7;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:.92em 1.75em;border-radius:999px;
  font-family:var(--label);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  background:var(--bg);color:var(--fg);box-shadow:var(--shadow-1);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .35s var(--ease),border-color .35s var(--ease),color .35s var(--ease);
  position:relative;isolation:isolate;overflow:hidden;border:1px solid transparent;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* Primary — pressed gold leaf: top sheen + bevel + warm glow + a shine that sweeps behind the text */
.btn--gold{
  --fg:#3a2407;color:#3a2407;background:var(--gold-grad-btn);
  border-color:rgba(122,86,12,.5);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),inset 0 -2px 5px rgba(122,86,12,.28),
             0 9px 24px -9px rgba(156,115,20,.7),0 2px 5px -2px rgba(122,86,12,.4);
}
.btn--gold::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(255,255,255,.6),rgba(255,255,255,0) 46%)}
.btn--gold::after{content:"";position:absolute;top:0;bottom:0;left:0;width:55%;z-index:-1;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.7),transparent);
  transform:translateX(-190%);transition:transform .85s var(--ease)}
.btn--gold:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.6),inset 0 -2px 5px rgba(122,86,12,.32),
             0 15px 32px -10px rgba(156,115,20,.78),0 3px 8px -2px rgba(122,86,12,.45)}
.btn--gold:hover::after{transform:translateX(330%)}

/* Ghost on light — etched gold outline (double hairline) */
.btn--ghost{
  --fg:var(--maroon-deep);color:var(--maroon-deep);background:rgba(201,162,39,.05);
  border-color:var(--gold-deep);
  box-shadow:inset 0 0 0 1px rgba(246,227,161,.4),0 6px 16px -13px rgba(43,33,23,.5);
}
.btn--ghost:hover{background:rgba(201,162,39,.15);border-color:var(--gold);box-shadow:inset 0 0 0 1px rgba(246,227,161,.55),0 8px 20px -14px rgba(43,33,23,.55)}

/* Ghost on hero — etched glass over the palace */
.btn--ghost--hero{
  --fg:#fdf6e7;color:#fdf6e7;background:rgba(28,14,6,.28);
  -webkit-backdrop-filter:blur(8px) saturate(1.1);backdrop-filter:blur(8px) saturate(1.1);
  border:1px solid rgba(246,227,161,.5);
  box-shadow:inset 0 0 0 1px rgba(246,227,161,.16),0 10px 28px -12px rgba(0,0,0,.6);
}
.btn--ghost--hero:hover{background:rgba(28,14,6,.46);border-color:#f6e3a1;
  box-shadow:inset 0 0 0 1px rgba(246,227,161,.3),0 12px 32px -12px rgba(0,0,0,.7)}

.btn--sm{padding:.64em 1.15em;font-size:.66rem;letter-spacing:.16em}

/* ----------  Navigation  ---------- */
.nav{
  position:fixed;inset:0 0 auto;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.15rem clamp(16px,4vw,40px);
  transition:background .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.scrolled{background:rgba(248,241,226,.9);backdrop-filter:blur(10px) saturate(1.1);box-shadow:0 1px 0 var(--line),0 10px 30px -24px rgba(43,33,23,.5)}
.nav__brand{display:flex;align-items:center;font-family:var(--display);font-weight:700;letter-spacing:.01em;font-size:clamp(1.05rem,1.6vw,1.4rem);color:#fdf6e7;text-shadow:0 1px 10px rgba(34,12,6,.85),0 0 3px rgba(34,12,6,.7)}
.nav.scrolled .nav__brand{color:var(--maroon-deep);text-shadow:none}
.nav__links{display:flex;align-items:center;gap:clamp(.8rem,1.8vw,1.7rem);list-style:none;margin:0;padding:0}
.nav__links a{font-family:var(--label);font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#fdf6e7;text-shadow:0 1px 8px rgba(34,12,6,.85),0 0 2px rgba(34,12,6,.7);position:relative;padding:.3em 0;white-space:nowrap;transition:color .3s,opacity .3s}
.nav.scrolled .nav__links a{color:var(--ink);text-shadow:none}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold-deep);transition:width .35s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__cta{margin-left:.55rem}
/* the RSVP pill is a button, not a text link — restore its padding/colour (the
   .nav__links a rule would otherwise zero its horizontal padding and recolour it) */
.nav__cta a{padding:.6em 1.3em;font-size:.66rem;letter-spacing:.14em;color:#3a2407;text-shadow:none}
.nav__cta a::after{display:none}
.nav__toggle{display:none;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center}
.nav__toggle span{display:block;width:22px;height:2px;background:#fdf6e7;position:relative;transition:.3s;filter:drop-shadow(0 1px 2px rgba(34,12,6,.7))}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:#fdf6e7;transition:.3s}
.nav__toggle span::before{top:-7px}.nav__toggle span::after{top:7px}
.nav.scrolled .nav__toggle span,.nav.scrolled .nav__toggle span::before,.nav.scrolled .nav__toggle span::after,
.nav.open .nav__toggle span::before,.nav.open .nav__toggle span::after{background:var(--ink)}
.nav.scrolled .nav__toggle span{filter:none}
.nav.open .nav__toggle span{background:transparent}
.nav.open .nav__toggle span::before{top:0;transform:rotate(45deg)}
.nav.open .nav__toggle span::after{top:0;transform:rotate(-45deg)}
body.menu-open{overflow:hidden}

/* ----------  Hero  ---------- */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;text-align:center;overflow:hidden;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 46%}
.hero__scrim{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(78% 56% at 50% 46%,rgba(28,14,6,.62),rgba(28,14,6,0) 72%),
    linear-gradient(180deg,rgba(28,14,6,.62) 0%,rgba(28,14,6,.34) 36%,rgba(28,14,6,.3) 62%,rgba(248,241,226,.5) 88%,var(--cream) 100%);
}
/* The hero content sits on an invitation-card panel so the crest pops on a deliberate
   surface and the text reads cleanly over the palace (which becomes a frame). */
.hero__inner{
  position:relative;z-index:1;max-width:700px;margin-inline:1rem;
  padding:clamp(2.8rem,6vw,4.5rem) clamp(2rem,5vw,3.5rem);
}
/* A soft parchment light that radiates from the centre and fades to nothing as it spreads.
   It lives on a layer larger than the content, so it has no box shape — it just glows. */
.hero__inner::before{
  content:"";position:absolute;z-index:-1;pointer-events:none;
  left:50%;top:50%;transform:translate(-50%,-50%);width:215%;height:200%;
  background:radial-gradient(ellipse 58% 56% at 50% 50%,
    rgba(250,245,232,.96) 0%,
    rgba(250,245,232,.9) 40%,
    rgba(249,242,227,.46) 63%,
    rgba(249,242,227,.13) 78%,
    rgba(249,242,227,0) 90%);
}
.hero__pre{font-family:var(--label);letter-spacing:.4em;text-transform:uppercase;font-size:clamp(.66rem,1.3vw,.8rem);color:var(--maroon)}
.hero__names{
  font-family:var(--script);font-size:clamp(2.2rem,6vw,3.6rem);
  color:var(--maroon);line-height:1;margin:.02em 0;padding:.22em 0;overflow-wrap:break-word;
}
.hero__names .amp{font-size:.6em;display:inline-block;margin:0 .16em;color:var(--gold-ink);-webkit-text-fill-color:var(--gold-ink)}
.hero__sub{font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(1.05rem,2.2vw,1.4rem);color:var(--ink-soft);letter-spacing:.02em}
.hero__date{margin-top:1.05rem;font-family:var(--label);letter-spacing:.14em;text-transform:uppercase;font-size:clamp(.64rem,1.15vw,.78rem);color:var(--gold-ink);text-wrap:balance}
.hero__cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}
.hero__crest{width:clamp(86px,11vw,122px);margin:0 auto .9rem;perspective:600px}
.hero__monogram{width:100%;height:auto;aspect-ratio:1;display:block;will-change:transform;transform-style:preserve-3d}
.hero__monogram.logo{filter:drop-shadow(0 8px 18px rgba(43,33,23,.34))}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:1;display:grid;justify-items:center;gap:.4rem;color:#f3e6c5;font-family:var(--label);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase}
.scrollcue span{width:1px;height:46px;background:linear-gradient(var(--gold-soft),transparent);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ----------  Arch card motif  ---------- */
.arch{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:140px 140px var(--radius) var(--radius);box-shadow:var(--shadow-1);padding:clamp(2.4rem,5vw,4rem) clamp(1.4rem,4vw,3rem) clamp(2rem,4vw,3rem)}
.arch::before{content:"";position:absolute;inset:10px;border:1px solid var(--gold-deep);opacity:.35;border-radius:130px 130px var(--radius) var(--radius);pointer-events:none}

/* ----------  Invitation  ---------- */
.invite{display:grid;place-items:center;text-align:center}
.invite .arch{max-width:720px}
.invite__couple{font-family:var(--script);font-size:clamp(2.8rem,8vw,5rem);color:var(--maroon);line-height:.95;margin:.2em 0}
.invite__amp{font-size:.5em;color:var(--gold-ink)}
.invite__families{display:grid;gap:.2rem;color:var(--ink-soft);font-size:1.02rem}
.invite__families strong{color:var(--ink);font-weight:600}
.invite__line{font-family:var(--display);font-style:italic;font-size:1.2rem;color:var(--ink)}
.meta-date{font-family:var(--label);letter-spacing:.16em;text-transform:uppercase;font-size:.8rem;color:var(--maroon)}

/* ----------  Our Story — illuminated vignette  ---------- */
.story .wrap{position:relative;isolation:isolate;padding-block:clamp(.5rem,2vw,1.4rem)}
.story__amp{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-53%);z-index:-1;pointer-events:none;
  font-family:var(--script);font-size:clamp(16rem,42vw,34rem);line-height:1;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  opacity:.09;
}
.story__lead{
  font-family:var(--display);font-style:italic;font-weight:500;
  font-size:clamp(1.5rem,2.6vw,2.2rem);line-height:1.4;color:var(--maroon);
  max-width:24ch;margin:1.5rem auto .2rem;text-wrap:balance;
}
.story__body{max-width:52ch;margin:1.15rem auto 0;color:var(--ink-soft);text-wrap:pretty}
.story__flourish--end{margin-top:1.9rem;opacity:.85;transform:rotate(180deg)}
.tl-item p{margin:.4rem 0 0;color:var(--ink-soft)}

/* ----------  Events  ---------- */
.events{display:grid;gap:clamp(1.4rem,3vw,2.2rem);grid-template-columns:repeat(2,1fr);margin-top:3rem}
.event{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.3rem);box-shadow:var(--shadow-1);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.event::before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--jewel,var(--gold)),var(--gold-soft))}
.event:hover{transform:translateY(-6px);box-shadow:var(--shadow-2)}
.event__day{font-family:var(--label);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-ink)}
.event__name{font-family:var(--display);font-size:clamp(1.5rem,3vw,2rem);color:var(--maroon);margin:.15rem 0 .1rem}
.event__name .sub{display:block;font-size:.62em;color:var(--ink-soft);font-style:italic}
.event__meta{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;color:var(--ink-soft);font-size:.95rem;margin:.7rem 0 1.1rem}
.event__meta span{display:inline-flex;align-items:center;gap:.45em}
.event__meta svg{width:15px;height:15px;color:var(--gold-ink);flex:none}
.event__desc{color:var(--ink-soft);margin:0 0 1.3rem}
.cal{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}
.cal__label{font-family:var(--label);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);width:100%}
.event__jewel{position:absolute;top:16px;right:16px;width:14px;height:14px;border-radius:50%;box-shadow:0 0 0 2px var(--paper),0 0 0 3px var(--gold)}

/* ----------  Countdown  ---------- */
.countdown{display:flex;gap:clamp(.8rem,3vw,2.4rem);justify-content:center;flex-wrap:wrap;margin-top:2.4rem}
.cd-unit{min-width:84px;text-align:center}
.cd-unit b{display:block;font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,7vw,4.4rem);color:var(--maroon);line-height:1;font-variant-numeric:tabular-nums}
.cd-unit small{font-family:var(--label);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-ink)}

/* ----------  Travel / cards grid  ---------- */
.cards{display:grid;gap:clamp(1.2rem,2.5vw,2rem);grid-template-columns:repeat(3,1fr);margin-top:2.6rem}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-1);transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-5px)}
.card h3{font-family:var(--display);font-size:1.35rem;color:var(--maroon);margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem}
.card h3 svg{width:20px;height:20px;color:var(--gold-ink);flex:none}
.card p{color:var(--ink-soft);margin:.2rem 0}
.map-embed{margin-top:2.6rem;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-1)}
.map-embed iframe{display:block;width:100%;height:clamp(280px,42vw,460px);border:0;filter:saturate(.95)}
.map-cap{padding:.85rem 1rem;background:var(--paper);font-family:var(--label);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:center;border-top:1px solid var(--line)}
.map-cap strong{color:var(--maroon)}
/* logo crest - clip the square crop to a clean circle */
/* Crest is a transparent, self-circular PNG — no clip/plate; just depth + a warm seal glow */
.logo{object-fit:contain;filter:drop-shadow(0 3px 9px rgba(43,33,23,.28))}
.footer .logo{filter:drop-shadow(0 0 20px rgba(246,227,161,.34)) drop-shadow(0 8px 16px rgba(0,0,0,.4))}
.film{max-width:420px;margin:2rem auto 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-2);border:1px solid var(--line)}
.film video{width:100%;display:block;background:#000}

/* ----------  Gallery  ---------- */
.gallery{columns:3;column-gap:14px;margin-top:2.6rem}
.gallery figure{margin:0 0 14px;break-inside:avoid;position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-1);background:var(--cream-2)}
.gallery figure:has(img){cursor:zoom-in}
.gallery figure:has(.ph){cursor:default}
.gallery img{width:100%;transition:transform .6s var(--ease)}
.gallery figure:has(img):hover img{transform:scale(1.05)}
.gallery .ph{aspect-ratio:3/4;display:grid;place-items:center;color:var(--ink-soft);font-family:var(--label);letter-spacing:.2em;font-size:.7rem;text-transform:uppercase;border:1px dashed var(--gold-deep)}
.gallery figcaption{position:absolute;inset:auto 0 0;padding:.6rem .8rem;font-family:var(--label);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#fdf6e7;background:linear-gradient(transparent,rgba(43,20,10,.7));opacity:0;transition:opacity .3s}
.gallery figure:hover figcaption,.gallery figure:focus-within figcaption{opacity:1}
.gallery__btn{display:block;width:100%;padding:0;border-radius:inherit;background:none}
.gallery__btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

.lightbox{position:fixed;inset:0;z-index:80;background:rgba(30,16,8,.92);display:none;place-items:center;padding:4vw}
.lightbox.open{display:grid}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:var(--radius);box-shadow:var(--shadow-2)}
.lightbox__close{position:absolute;top:18px;right:22px;min-width:44px;min-height:44px;display:grid;place-items:center;padding:.2rem;border-radius:50%;font-size:2.2rem;color:#f3e6c5;line-height:1;background:rgba(0,0,0,.35)}
.lightbox__close:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* ----------  Registry / FAQ  ---------- */
.registry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.4rem}
.registry-grid .card{text-align:center}
.faq{max-width:820px;margin:2.4rem auto 0;display:grid;gap:.8rem}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:.2rem 1.3rem;box-shadow:var(--shadow-1)}
.faq summary{list-style:none;cursor:pointer;padding:1rem 0;font-family:var(--display);font-size:1.2rem;color:var(--maroon);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--display);font-size:1.6rem;color:var(--gold-deep);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
.faq details p{margin:0 0 1.1rem;color:var(--ink-soft)}

/* ----------  RSVP  ---------- */
.rsvp-card{max-width:680px;margin:2.6rem auto 0;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-2);padding:clamp(1.6rem,4vw,3rem)}
.form-row{display:grid;gap:1.1rem;grid-template-columns:1fr 1fr}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem;border:0;padding:0;min-width:0}
.field.full{grid-column:1/-1}
.field > label,.field > legend{font-family:var(--label);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);padding:0}
.req{color:var(--maroon)}
.field input,.field select,.field textarea{font-family:var(--body);font-size:1rem;color:var(--ink);background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:.8em .9em;transition:border-color .3s,box-shadow .3s;max-width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-deep);box-shadow:0 0 0 3px rgba(201,162,39,.18)}
.field textarea{resize:vertical;min-height:96px}
.checkset{display:flex;flex-wrap:wrap;gap:.8rem 1.4rem;padding-top:.4rem}
.checkset label{display:flex;gap:.5rem;align-items:center;font-family:var(--body);font-size:1rem;text-transform:none;letter-spacing:0;color:var(--ink)}
.checkset input{accent-color:var(--maroon);width:18px;height:18px}
.form-note{font-size:.82rem;color:var(--ink-soft);margin-top:.4rem}
.form-status{margin-top:1rem;font-family:var(--label);letter-spacing:.08em;font-size:.85rem;min-height:1.2em}
.form-status.ok{color:var(--emerald)}
.form-status.err{color:var(--maroon)}

/* ----------  Footer  ---------- */
.footer{background:var(--maroon-deep);color:#f3e6c5;text-align:center;padding:clamp(3rem,6vw,5rem) var(--gutter)}
.footer img{width:84px;margin:0 auto 1.2rem}
.footer .script{font-size:2.6rem;color:var(--gold-soft)}
.footer p{color:#e4cfa3;opacity:.85;margin:.3rem 0}
.footer .small{font-size:.74rem;letter-spacing:.12em;opacity:.6;margin-top:1.4rem;font-family:var(--label);text-transform:uppercase}

/* ----------  Reveal animation  ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.scrollcue span{animation:none}}

.hero [data-load]{opacity:0;transform:translateY(20px)}
body.loaded .hero [data-load]{animation:rise 1.1s var(--ease) forwards}
.hero [data-load="1"]{animation-delay:.15s}.hero [data-load="2"]{animation-delay:.4s}
.hero [data-load="3"]{animation-delay:.7s}.hero [data-load="4"]{animation-delay:1s}.hero [data-load="5"]{animation-delay:1.3s}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.hero [data-load]{animation:none;opacity:1;transform:none}}

/* ----------  Responsive  ---------- */
@media (max-width:900px){
  .events,.cards,.registry-grid,.form-row{grid-template-columns:1fr}
  .gallery{columns:2}
}
@media (max-width:1080px){
  .nav__links{
    position:fixed;inset:calc(1.15rem*2 + 50px + 8px) 12px auto 12px;flex-direction:column;gap:.2rem;
    background:rgba(248,241,226,.98);backdrop-filter:blur(12px);
    border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-2);
    padding:.6rem;transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .3s var(--ease),opacity .3s var(--ease),visibility .3s var(--ease);
  }
  .nav.open .nav__links{transform:none;opacity:1;visibility:visible;pointer-events:auto}
  .nav__links a{padding:.7rem .6rem;font-size:.82rem;border-radius:var(--radius)}
  .nav__links a::after{display:none}
  .nav__links a:hover{background:rgba(201,162,39,.12)}
  .nav__links .nav__cta{margin:.3rem .6rem .4rem}
  .nav__toggle{display:flex}
}
@media (max-width:480px){
  .gallery{columns:1}
  .gallery figure:has(.ph){display:none}
  .hero__names{font-size:clamp(2.6rem,15vw,10rem)}
}
@media (max-width:400px){
  .hero__names .amp{display:block;margin:.05em auto}
}
@media (max-width:360px){
  .nav__brand{font-size:.98rem}
}
@media (max-width:340px){
  .cd-unit{min-width:54px}
  .cd-unit b{font-size:clamp(2rem,11vw,2.6rem)}
  .countdown{gap:.6rem}
}
