:root {
  --ink: #271715;
  --wine: #4a1722;
  --wine-deep: #2d0d14;
  --teal: #113d3b;
  --teal-deep: #0c2928;
  --gold: #c79c51;
  --gold-light: #f0d39c;
  --ivory: #fbf7ef;
  --cream: #f2eadc;
  --muted: #8e7971;
  --line: rgba(73, 36, 32, .16);
  --shadow: 0 25px 60px rgba(38, 19, 16, .15);
  --heading: 'Cormorant Garamond', Georgia, serif;
  --script: 'Great Vibes', cursive;
  --body: 'DM Sans', Arial, sans-serif;
  --radius: 22px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 90px; }
body { margin: 0; color: var(--ink); background: var(--ivory); font-family: var(--body); overflow-x: hidden; }
body.menu-open, body.lightbox-open { overflow: hidden; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.page-loader { position: fixed; z-index: 1000; inset: 0; display: grid; place-items: center; background: var(--wine-deep); color: var(--gold-light); transition: opacity .6s ease, visibility .6s ease; }
.page-loader span { font: 5rem var(--script); opacity: 0; transform: scale(.7); animation: loaderIn .8s .1s forwards; }
body.loaded .page-loader { opacity: 0; visibility: hidden; pointer-events: none; }
@keyframes loaderIn { to { opacity: 1; transform: scale(1); } }

.petal-field { position: fixed; z-index: 8; inset: 0; pointer-events: none; overflow: hidden; mix-blend-mode: multiply; }
.petal-field i { position: absolute; left: var(--left); top: -8vh; font-style: normal; color: rgba(195, 143, 70, .40); font-size: var(--size); animation: fall var(--duration) var(--delay) linear infinite; }
@keyframes fall { from { transform: translate3d(0,-10vh,0) rotate(0deg); } to { transform: translate3d(6vw,115vh,0) rotate(310deg); } }

.site-header { position: absolute; z-index: 30; width: 100%; top: 0; left: 0; display: flex; align-items: center; justify-content: space-between; padding: 1.35rem clamp(1.25rem, 4vw, 5rem); color: #fff; }
.brand-mark { width: 52px; height: 52px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.5); border-radius: 50%; font: 1.5rem var(--script); letter-spacing: .05em; transition: transform .35s ease, background .35s ease; }
.brand-mark:hover { background: rgba(255,255,255,.12); transform: rotate(-8deg); }
.site-nav { display: flex; align-items: center; gap: clamp(1rem, 2.2vw, 2.25rem); font-size: .73rem; text-transform: uppercase; letter-spacing: .14em; font-weight: 600; }
.site-nav a { position: relative; padding: .55rem 0; opacity: .92; }
.site-nav a:not(.nav-rsvp)::after { content: ''; position: absolute; left: 0; bottom: 0; width: 0; height: 1px; background: var(--gold-light); transition: width .3s ease; }
.site-nav a:hover::after { width: 100%; }
.nav-rsvp { border: 1px solid rgba(255,255,255,.65); padding: .7rem 1rem !important; transition: background .25s ease, color .25s ease; }
.nav-rsvp:hover { color: var(--wine); background: var(--gold-light); }
.menu-toggle { display: none; width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.55); background: rgba(0,0,0,.12); padding: 10px; }
.menu-toggle span { display: block; height: 1px; background: #fff; margin: 4px 0; transition: transform .3s ease, opacity .2s ease; }

.hero { position: relative; min-height: 100svh; isolation: isolate; display: grid; place-items: center; color: #fff; overflow: hidden; }
.hero-image { position: absolute; inset: 0; z-index: -2; background-size: cover; background-position: center 36%; transform: scale(1.05); animation: heroScale 16s ease-in-out infinite alternate; }
.hero-grain { position: absolute; inset: 0; z-index: -1; opacity: .16; background-image: radial-gradient(rgba(255,255,255,.7) .55px, transparent .55px); background-size: 5px 5px; mix-blend-mode: soft-light; }
@keyframes heroScale { to { transform: scale(1.13); } }
.hero-content { width: min(840px, 92vw); text-align: center; padding: 8rem 0 6rem; }
.eyebrow { margin: 0 0 .75rem; font-size: .69rem; line-height: 1.4; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; }
.eyebrow.gold { color: var(--gold); }
.hero-family { margin: 0 0 1rem; font: 1.45rem var(--script); color: var(--gold-light); }
.hero h1 { display: flex; align-items: center; justify-content: center; gap: .9rem; margin: 0; font: 600 clamp(3.5rem, 8vw, 7.4rem)/.80 var(--heading); letter-spacing: -.035em; text-shadow: 0 4px 18px rgba(0,0,0,.2); }
.hero h1 span { display: block; }
.hero h1 i { font: clamp(4rem, 8vw, 7.4rem)/.7 var(--script); color: var(--gold-light); font-weight: 400; transform: translateY(.1em); }
.hero-divider { display: flex; align-items: center; gap: .8rem; justify-content: center; margin: 2.4rem auto 1.4rem; color: var(--gold-light); }
.hero-divider span { width: clamp(50px, 10vw, 115px); height: 1px; background: currentColor; opacity: .8; }
.hero-divider b { font-size: .9rem; }
.hero-date { margin: 0; font: 500 clamp(1.08rem, 2.2vw, 1.45rem) var(--heading); letter-spacing: .1em; text-transform: uppercase; }
.hero-date em { color: var(--gold-light); padding: 0 .4rem; font-style: normal; }
.hero-note { width: min(540px, 88vw); margin: 1.25rem auto 0; font-size: .88rem; line-height: 1.8; color: rgba(255,255,255,.82); }
.hero-actions { margin-top: 2rem; display: flex; flex-wrap: wrap; justify-content: center; gap: .8rem; }
.button { border: 1px solid transparent; display: inline-flex; justify-content: center; align-items: center; gap: .6rem; min-height: 46px; padding: .75rem 1.35rem; text-transform: uppercase; letter-spacing: .12em; font-size: .67rem; font-weight: 700; transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease; }
.button:hover { transform: translateY(-3px); }
.button:focus-visible, .gallery-item:focus-visible, .event-calendar:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, .menu-toggle:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
.button-gold { color: #382015; background: linear-gradient(110deg, #e6c585, #b7863e 50%, #efcf90); box-shadow: 0 9px 28px rgba(10,0,0,.18); background-size: 200% auto; animation: shimmer 6s linear infinite; }
.button-gold:hover { background-position: right center; box-shadow: 0 13px 30px rgba(10,0,0,.28); }
@keyframes shimmer { to { background-position: 200% center; } }
.button-outline { color: #fff; border-color: rgba(255,255,255,.68); background: rgba(255,255,255,.04); }
.button-outline:hover { background: #fff; color: var(--wine); }
.button-dark { color: #fff; background: var(--wine); width: 100%; }
.button-dark:hover { background: var(--teal); }
.scroll-cue { position: absolute; bottom: 1.7rem; display: grid; place-items: center; gap: .4rem; font-size: .57rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.75); }
.scroll-cue b { width: 1px; height: 32px; background: var(--gold-light); animation: scrollLine 1.6s infinite ease-in-out; }
@keyframes scrollLine { 50% { transform: scaleY(.38); transform-origin: top; opacity: .45; } }

.countdown-section { position: relative; overflow: hidden; padding: clamp(5rem, 9vw, 8rem) 1rem; text-align: center; background: radial-gradient(circle at 50% 20%, #fffdf8, var(--cream)); }
.section-leaf { position: absolute; color: rgba(174,124,54,.2); font: clamp(9rem, 20vw, 21rem) var(--script); line-height: 1; }
.leaf-left { left: -4vw; top: 7%; transform: rotate(-20deg); }
.leaf-right { right: -4vw; bottom: -5%; transform: rotate(155deg); }
.section-intro, .section-heading { position: relative; z-index: 1; text-align: center; }
.section-heading { max-width: 700px; margin: 0 auto clamp(2.7rem, 5vw, 4.5rem); }
.section-intro h2, .section-heading h2 { margin: 0; font: 600 clamp(2.8rem, 5.7vw, 5rem)/.9 var(--heading); letter-spacing: -.035em; }
.section-intro h2 em, .section-heading h2 em { font-family: var(--script); font-weight: 400; color: var(--wine); }
.countdown-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(4, minmax(95px, 150px)); justify-content: center; gap: clamp(.65rem, 2vw, 1.6rem); margin: 2.7rem auto 0; }
.countdown-grid > div { padding: 1.3rem .5rem; background: rgba(255,255,255,.65); border: 1px solid rgba(187,145,83,.27); box-shadow: 0 16px 32px rgba(80,51,31,.07); }
.countdown-grid strong { display: block; font: 600 clamp(2.55rem, 5.5vw, 4.5rem)/.85 var(--heading); color: var(--wine); }
.countdown-grid strong.tick { animation: numberPop .35s ease; }
@keyframes numberPop { 50% { transform: translateY(-7px); color: var(--gold); } }
.countdown-grid span { display: block; margin-top: .6rem; font-size: .57rem; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: var(--muted); }

.section-pad { padding: clamp(5rem, 10vw, 9rem) clamp(1.2rem, 5vw, 5.5rem); }
.story-section { background: var(--ivory); }
.story-timeline { width: min(1120px, 100%); margin: 0 auto; }
.story-card { display: grid; grid-template-columns: minmax(240px, .9fr) minmax(300px, 1fr); align-items: center; gap: clamp(1.8rem, 6vw, 6.5rem); margin: 0 auto clamp(3rem, 8vw, 7.5rem); }
.story-card:last-child { margin-bottom: 0; }
.story-card.reverse figure { order: 2; }
.story-card figure { position: relative; margin: 0; }
.story-card figure::before { content: ''; position: absolute; width: 83%; aspect-ratio: 1; left: -6%; bottom: -6%; border: 1px solid var(--gold); z-index: 0; }
.story-card.reverse figure::before { left: auto; right: -6%; }
.story-card figure::after { content: '✦'; position: absolute; right: -1rem; top: 1rem; display: grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; background: var(--wine); color: var(--gold-light); font-size: .8rem; }
.story-card.reverse figure::after { right: auto; left: -1rem; }
.story-card img { position: relative; z-index: 1; width: 100%; aspect-ratio: 4 / 4.5; object-fit: cover; box-shadow: var(--shadow); }
.story-text { position: relative; }
.story-year { font-size: .64rem; font-weight: 700; letter-spacing: .19em; text-transform: uppercase; color: var(--gold); }
.story-text h3 { margin: .6rem 0 1rem; font: 600 clamp(2.2rem, 4vw, 3.45rem)/.91 var(--heading); letter-spacing: -.035em; color: var(--wine); }
.story-text p { max-width: 430px; margin: 0; color: #63534e; font-size: .94rem; line-height: 1.95; }
.story-flourish { display: inline-block; margin-top: 1.25rem; color: var(--gold); font-size: 1.45rem; }

.quote-section { position: relative; min-height: min(700px, 72vw); display: grid; place-items: center; color: #fff; overflow: hidden; }
.quote-photo { position: absolute; inset: 0; z-index: -1; background-size: cover; background-position: center; transform: scale(1.02); }
.quote-overlay { text-align: center; padding: 4rem 1rem; }
.quote-overlay blockquote { margin: 1.1rem 0 1.4rem; font: 500 clamp(3rem, 7vw, 6.4rem)/.85 var(--heading); letter-spacing: -.04em; }
.quote-overlay blockquote em { font-family: var(--script); font-weight: 400; color: var(--gold-light); }
.quote-overlay > span { font-size: .68rem; text-transform: uppercase; letter-spacing: .23em; color: var(--gold-light); }

.events-section { background: #fbf8f2; }
.event-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; max-width: 1280px; margin: 0 auto; }
.event-card { position: relative; min-height: 405px; padding: 2rem 1.5rem 1.45rem; overflow: hidden; background: #fff; border: 1px solid rgba(129,86,58,.14); box-shadow: 0 14px 34px rgba(48,20,19,.08); transition: transform .35s ease, box-shadow .35s ease; }
.event-card::before { content: ''; position: absolute; inset: 10px; border: 1px solid rgba(195,156,84,.28); pointer-events: none; }
.event-card:hover { transform: translateY(-8px); box-shadow: 0 22px 45px rgba(48,20,19,.16); }
.event-card:nth-child(even) { background: var(--teal); color: #fff; }
.event-card:nth-child(even)::before { border-color: rgba(237,202,135,.44); }
.event-icon { position: relative; color: var(--gold); font-size: 1.85rem; }
.event-number { position: absolute; right: 1.35rem; top: 1.3rem; margin: 0; font: 500 1.1rem var(--heading); color: var(--gold); }
.event-card h3 { position: relative; margin: 1.75rem 0 .75rem; font: 600 clamp(1.85rem, 3vw, 2.45rem)/.95 var(--heading); color: var(--wine); }
.event-card:nth-child(even) h3 { color: #fff; }
.event-rule { position: relative; width: 40px; height: 1px; background: var(--gold); margin-bottom: 1.25rem; }
.event-card p { position: relative; }
.event-date { margin: 0; font-size: .79rem; font-weight: 700; text-transform: uppercase; letter-spacing: .11em; }
.event-time { margin: .35rem 0 1rem; color: var(--gold); font: 500 1.15rem var(--heading); letter-spacing: .06em; }
.event-venue { min-height: 44px; margin: 0; font-size: .77rem; line-height: 1.65; color: #746361; }
.event-card:nth-child(even) .event-venue { color: rgba(255,255,255,.72); }
.event-dress { font-size: .71rem; line-height: 1.65; color: #746361; }
.event-card:nth-child(even) .event-dress { color: rgba(255,255,255,.76); }
.event-dress b { color: var(--wine); }
.event-card:nth-child(even) .event-dress b { color: var(--gold-light); }
.event-calendar { position: absolute; bottom: 1.5rem; left: 1.5rem; right: 1.5rem; border-top: 1px solid rgba(121,79,49,.2); padding-top: .85rem; display: flex; align-items: center; justify-content: space-between; font-size: .62rem; text-transform: uppercase; letter-spacing: .11em; font-weight: 700; color: var(--wine); }
.event-card:nth-child(even) .event-calendar { color: var(--gold-light); border-color: rgba(255,255,255,.22); }
.event-calendar span { font-size: 1.1rem; transition: transform .25s ease; }
.event-calendar:hover span { transform: translateX(5px); }

.gallery-section { background: var(--teal-deep); color: #fff; }
.gallery-section .section-heading h2 em { color: var(--gold-light); }
.gallery-grid { width: min(1280px, 100%); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 165px; gap: .7rem; }
.gallery-item { position: relative; border: 0; padding: 0; overflow: hidden; background: #192f2d; color: #fff; text-align: left; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s cubic-bezier(.2,.8,.2,1), filter .45s ease; }
.gallery-item::after { content: ''; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(4,18,16,.85), rgba(4,18,16,0) 62%); opacity: .75; transition: opacity .3s ease; }
.gallery-item span { position: absolute; z-index: 1; left: 1rem; right: 1rem; bottom: 1rem; display: grid; gap: .25rem; transform: translateY(8px); transition: transform .3s ease; }
.gallery-item i { font-size: .57rem; font-style: normal; letter-spacing: .13em; text-transform: uppercase; color: var(--gold-light); }
.gallery-item b { font: 500 1.2rem var(--heading); }
.gallery-item:hover img { transform: scale(1.1); filter: brightness(.85); }
.gallery-item:hover span { transform: translateY(0); }
.gallery-item-1 { grid-row: span 3; grid-column: span 2; }
.gallery-item-2 { grid-row: span 2; }
.gallery-item-3 { grid-row: span 2; }
.gallery-item-4 { grid-row: span 2; }
.gallery-item-5 { grid-column: span 2; grid-row: span 2; }

.venue-section { position: relative; min-height: 580px; display: grid; align-items: center; color: #fff; overflow: hidden; }
.venue-image { position: absolute; inset: 0; z-index: -1; background-size: cover; background-position: center 40%; }
.venue-content { width: min(680px, 92vw); margin-left: clamp(1.2rem, 10vw, 10rem); padding: 5.5rem 0; }
.venue-content h2 { margin: .65rem 0 .75rem; font: 600 clamp(3.2rem, 7vw, 6.4rem)/.82 var(--heading); letter-spacing: -.05em; }
.venue-rule { width: 90px; height: 1px; background: var(--gold-light); margin: 1.35rem 0; }
.venue-address { max-width: 470px; margin: 0; line-height: 1.9; font-size: .96rem; color: rgba(255,255,255,.85); }
.venue-note { margin: 1rem 0 0; max-width: 470px; color: var(--gold-light); font: 1.18rem var(--heading); }
.venue-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }

.rsvp-section { background: var(--cream); }
.rsvp-wrap { max-width: 1160px; margin: 0 auto; display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2.25rem, 8vw, 8rem); align-items: center; }
.rsvp-copy h2 { margin: 0 0 1.15rem; font: 600 clamp(3rem, 5vw, 5rem)/.86 var(--heading); letter-spacing: -.04em; color: var(--wine); }
.rsvp-copy h2 em { color: var(--teal); font-family: var(--script); font-weight: 400; }
.rsvp-copy > p:not(.eyebrow) { max-width: 420px; margin: 0; font-size: .92rem; line-height: 1.95; color: #6b5a54; }
.contact-card { display: inline-grid; gap: .25rem; margin-top: 1.7rem; padding: 1.1rem 1.3rem; border-left: 2px solid var(--gold); background: rgba(255,255,255,.45); }
.contact-card span { font-size: .6rem; letter-spacing: .14em; font-weight: 700; text-transform: uppercase; color: var(--muted); }
.contact-card a { color: var(--wine); font: 600 1.35rem var(--heading); }
.rsvp-form { padding: clamp(1.5rem, 3vw, 2.65rem); background: #fffdfa; box-shadow: var(--shadow); border-top: 3px solid var(--gold); }
.rsvp-form label, .wish-form label { display: grid; gap: .45rem; margin-bottom: 1rem; color: #67554e; font-size: .67rem; text-transform: uppercase; letter-spacing: .11em; font-weight: 700; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.rsvp-form input, .rsvp-form textarea, .rsvp-form select, .wish-form input, .wish-form textarea { width: 100%; padding: .8rem .85rem; border: 1px solid #e4d7c5; border-radius: 0; outline: 0; background: #fff; color: var(--ink); font: .84rem var(--body); letter-spacing: 0; text-transform: none; transition: border .2s ease, box-shadow .2s ease; }
.rsvp-form textarea, .wish-form textarea { min-height: 98px; resize: vertical; }
.rsvp-form input:focus, .rsvp-form select:focus, .rsvp-form textarea:focus, .wish-form input:focus, .wish-form textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(199,156,81,.12); }
.form-status { min-height: 1.25em; margin: .75rem 0 0; font-size: .75rem; color: var(--teal); line-height: 1.5; }

.wishes-section { background: #fffdf9; }
.wishes-wrap { width: min(1100px, 100%); margin: 0 auto; display: grid; grid-template-columns: minmax(260px, .85fr) minmax(300px, 1.15fr); gap: clamp(1.5rem, 5vw, 5rem); align-items: start; }
.wish-form { padding: 1.45rem; background: var(--teal); box-shadow: 0 18px 44px rgba(17,61,59,.18); }
.wish-form label { color: rgba(255,255,255,.77); }
.wish-form input, .wish-form textarea { border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.07); color: #fff; }
.wish-form input::placeholder, .wish-form textarea::placeholder { color: rgba(255,255,255,.52); }
.wish-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.wish-card { min-height: 150px; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: 1.25rem; border: 1px solid rgba(163,111,68,.18); background: #fff; box-shadow: 0 10px 24px rgba(75,42,27,.06); }
.wish-card span { color: var(--gold); font-size: 1rem; }
.wish-card p { margin: .55rem 0 .75rem; color: #604d46; font: 1.1rem/1.35 var(--heading); }
.wish-card strong { color: var(--wine); font-size: .62rem; text-transform: uppercase; letter-spacing: .14em; }
.placeholder-wish { background: #faf4e9; }
.new-wish { animation: newWish .55s ease both; }
@keyframes newWish { from { transform: scale(.94); opacity: 0; } to { transform: scale(1); opacity: 1; } }

.site-footer { position: relative; overflow: hidden; padding: 4.7rem 1rem 2rem; color: rgba(255,255,255,.78); background: var(--wine-deep); text-align: center; }
.site-footer::before, .site-footer::after { content: '❧'; position: absolute; top: 10px; font: 14rem var(--script); color: rgba(199,156,81,.10); }
.site-footer::before { left: 5vw; transform: rotate(-25deg); }.site-footer::after { right: 5vw; transform: scaleX(-1) rotate(-25deg); }
.footer-mark { position: relative; width: 78px; height: 78px; display: grid; place-items: center; margin: 0 auto 1rem; border: 1px solid rgba(240,211,156,.65); border-radius: 50%; color: var(--gold-light); font: 2.2rem var(--script); }
.footer-names { position: relative; margin: 0; font: 500 2rem var(--heading); color: #fff; }
.site-footer > p:not(.footer-names) { position: relative; max-width: 550px; margin: .7rem auto 0; font-size: .77rem; line-height: 1.7; }
.site-footer .footer-date { color: var(--gold-light); font-size: .62rem; text-transform: uppercase; letter-spacing: .16em; font-weight: 700; }
.footer-actions { position: relative; display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; margin: 1.7rem 0; }
.footer-actions a, .footer-actions button { color: var(--gold-light); border: 0; padding: 0; background: transparent; font-size: .62rem; font-family: var(--body); letter-spacing: .13em; text-transform: uppercase; }
.footer-actions button { border-left: 1px solid rgba(255,255,255,.35); padding-left: 1rem; }
.site-footer small { position: relative; color: rgba(255,255,255,.42); font-size: .61rem; letter-spacing: .08em; }

.floating-rsvp { position: fixed; z-index: 20; right: 1rem; bottom: 1rem; display: inline-flex; gap: .45rem; align-items: center; padding: .78rem 1rem; color: #fff; background: var(--wine); box-shadow: 0 13px 28px rgba(44,15,18,.27); font-size: .64rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; transition: transform .25s ease, background .25s ease; }
.floating-rsvp:hover { background: var(--teal); transform: translateY(-4px); }
.floating-rsvp span { color: var(--gold-light); }

.lightbox { position: fixed; z-index: 200; inset: 0; display: none; grid-template-columns: 1fr auto 1fr; place-items: center; gap: .7rem; padding: 1.2rem; background: rgba(5,10,9,.94); }
.lightbox.open { display: grid; animation: fadeIn .2s ease both; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.lightbox figure { grid-column: 2; margin: 0; max-width: min(78vw, 960px); max-height: 88vh; text-align: center; }
.lightbox img { max-width: 100%; max-height: 80vh; width: auto; margin: 0 auto; object-fit: contain; box-shadow: 0 20px 55px rgba(0,0,0,.42); }
.lightbox figcaption { padding-top: .7rem; color: var(--gold-light); font: 1.15rem var(--heading); }
.lightbox button { width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.4); color: #fff; background: rgba(255,255,255,.08); font-size: 2rem; transition: background .2s ease; }
.lightbox button:hover { background: rgba(199,156,81,.45); }
.lightbox-close { position: absolute; right: 1.2rem; top: 1.2rem; }
.lightbox-prev { grid-column: 1; }.lightbox-next { grid-column: 3; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s ease, transform .75s cubic-bezier(.2,.75,.3,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.motion-paused *, .motion-paused *::before, .motion-paused *::after { animation-play-state: paused !important; }

@media (max-width: 1000px) {
  .event-grid { grid-template-columns: repeat(2, 1fr); max-width: 700px; }
  .gallery-grid { grid-template-columns: repeat(3, 1fr); }
  .rsvp-wrap { grid-template-columns: 1fr; max-width: 750px; }
  .rsvp-copy { text-align: center; }.rsvp-copy > p:not(.eyebrow) { margin-left: auto; margin-right: auto; }.contact-card { text-align: left; }
}
@media (max-width: 760px) {
  .site-header { padding: 1rem 1.15rem; }
  .menu-toggle { display: block; z-index: 2; }
  .site-nav { position: fixed; inset: 0; z-index: 1; display: flex; flex-direction: column; justify-content: center; gap: 1.25rem; background: rgba(45,13,20,.98); transform: translateX(100%); transition: transform .35s ease; font: 500 1.1rem var(--heading); letter-spacing: .1em; }
  .site-nav.open { transform: translateX(0); }
  .site-nav a { opacity: 1; }
  .nav-rsvp { padding: .85rem 1.5rem !important; }
  .hero h1 { flex-direction: column; gap: .15rem; font-size: clamp(3.4rem, 15vw, 5.4rem); line-height: .78; }
  .hero h1 i { font-size: 4.3rem; line-height: .3; }
  .hero-content { padding-top: 9rem; padding-bottom: 7rem; }
  .hero-note { font-size: .78rem; }
  .hero-actions { flex-direction: column; align-items: center; }.hero-actions .button { min-width: 220px; }
  .scroll-cue { display: none; }
  .countdown-grid { grid-template-columns: repeat(2, minmax(110px, 1fr)); max-width: 330px; }
  .story-card, .story-card.reverse { grid-template-columns: 1fr; gap: 1.5rem; }
  .story-card.reverse figure { order: 0; }
  .story-text { text-align: center; }.story-text p { margin-left: auto; margin-right: auto; }
  .quote-section { min-height: 520px; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 140px; }
  .gallery-item-1 { grid-row: span 2; grid-column: span 2; }.gallery-item-5 { grid-column: span 2; }
  .venue-content { margin-left: 1.25rem; margin-right: 1.25rem; width: auto; }
  .venue-content h2 { font-size: clamp(3rem, 13vw, 4.7rem); }
  .wishes-wrap { grid-template-columns: 1fr; max-width: 640px; }.wish-list { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 500px) {
  .section-pad { padding: 4.4rem 1.1rem; }
  .section-heading h2, .section-intro h2 { font-size: 2.75rem; }
  .event-grid { grid-template-columns: 1fr; }.event-card { min-height: 370px; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .gallery-grid { grid-auto-rows: 118px; gap: .45rem; }.gallery-item span { left: .7rem; right: .7rem; bottom: .7rem; }.gallery-item b { font-size: 1.03rem; }
  .wish-list { grid-template-columns: 1fr; }
  .lightbox { grid-template-columns: 44px 1fr 44px; padding: .55rem; gap: .2rem; }.lightbox figure { max-width: 100%; }.lightbox img { max-height: 74vh; }.lightbox-close { right: .7rem; top: .7rem; }.lightbox button { width: 37px; height: 37px; }
  .footer-actions button { border-left: none; padding-left: 0; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}


/* Premium motion and event themes added for Arpit & Shivangi. */
.scroll-progress { position: fixed; inset: 0 0 auto; z-index: 1200; height: 3px; pointer-events: none; background: rgba(45,13,20,.12); }
.scroll-progress span { display: block; width: 0; height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-light), var(--wine)); box-shadow: 0 0 12px rgba(240,211,156,.9); transition: width .08s linear; }

.hero-image, .quote-photo, .venue-image, .invitation-photo { will-change: transform; transform: translate3d(0, var(--parallax-y, 0px), 0) scale(1.04); }
.hero-image { animation: heroKenBurns 18s ease-in-out infinite alternate; }
@keyframes heroKenBurns { 0% { transform: translate3d(0, var(--parallax-y, 0px), 0) scale(1.04); } 100% { transform: translate3d(0, calc(var(--parallax-y, 0px) - 9px), 0) scale(1.12); } }
.hero-content.visible { animation: heroArrival 1.25s .15s cubic-bezier(.16,.82,.2,1) both; }
@keyframes heroArrival { 0% { opacity: 0; transform: translateY(26px) scale(.98); filter: blur(3px); } 100% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); } }
.hero-orbit { position: absolute; z-index: 1; border: 1px solid rgba(240,211,156,.28); border-radius: 50%; pointer-events: none; animation: orbitSpin 20s linear infinite; }
.hero-orbit::before, .hero-orbit::after { content: '✦'; position: absolute; color: var(--gold-light); font-size: .8rem; text-shadow: 0 0 12px rgba(240,211,156,.9); }
.hero-orbit-one { width: min(60vw, 820px); aspect-ratio: 1; left: -21vw; top: -24vw; }
.hero-orbit-one::before { top: 7%; left: 66%; }.hero-orbit-one::after { right: 7%; bottom: 22%; }
.hero-orbit-two { width: min(35vw, 510px); aspect-ratio: 1; right: -13vw; bottom: -15vw; border-style: dashed; animation-direction: reverse; animation-duration: 28s; }
.hero-orbit-two::before { left: 8%; top: 25%; }.hero-orbit-two::after { right: 26%; top: 5%; }
@keyframes orbitSpin { to { transform: rotate(360deg); } }
.hero-sparkles { position: absolute; inset: 0; z-index: 2; pointer-events: none; overflow: hidden; }
.hero-sparkles i { position: absolute; left: var(--left); top: var(--top); color: rgba(240,211,156,.8); font-style: normal; font-size: var(--size); text-shadow: 0 0 13px rgba(240,211,156,.85); animation: heroSparkle var(--duration) var(--delay) ease-in-out infinite; }
@keyframes heroSparkle { 0%,100% { opacity: .18; transform: scale(.65) rotate(0deg); } 45% { opacity: 1; transform: scale(1.2) rotate(90deg); } 70% { opacity: .38; transform: scale(.8) rotate(180deg); } }

.button-invitation { color: var(--gold-light); border-color: rgba(240,211,156,.72); background: rgba(7,15,13,.20); }
.button-invitation:hover { color: var(--wine); background: var(--gold-light); border-color: var(--gold-light); }

.invitation-section { position: relative; overflow: hidden; background: radial-gradient(circle at 6% 6%, rgba(199,156,81,.18), transparent 32%), linear-gradient(145deg, #fcf8f1, #efe5d3); }
.invitation-section::before { content: ''; position: absolute; width: 390px; height: 390px; right: -100px; top: -150px; border-radius: 50%; border: 1px dashed rgba(167,104,63,.24); animation: orbitSpin 36s linear infinite; }
.invitation-card { position: relative; width: min(1080px, 100%); min-height: 410px; margin: 0 auto; display: grid; grid-template-columns: minmax(250px, .8fr) minmax(320px, 1.2fr); overflow: hidden; background: #fffdfa; box-shadow: 0 28px 65px rgba(50,25,17,.14); }
.invitation-card::before { content: ''; position: absolute; inset: 12px; z-index: 3; pointer-events: none; border: 1px solid rgba(199,156,81,.48); }
.invitation-photo { position: absolute; inset: 0 auto 0 0; width: 42%; background-size: cover; background-position: center; }
.invitation-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(45,13,20,.12), rgba(45,13,20,.56)); }
.invitation-copy { position: relative; z-index: 2; grid-column: 2; padding: clamp(3.1rem, 7vw, 5.7rem) clamp(2rem, 6vw, 5.5rem); }
.invitation-copy h2 { margin: .3rem 0 1.1rem; color: var(--wine); font: 600 clamp(3rem, 5.5vw, 5.3rem)/.82 var(--heading); letter-spacing: -.05em; }
.invitation-copy h2 em { color: var(--teal); font: 400 1.02em var(--script); }
.invitation-copy > p:not(.eyebrow) { max-width: 430px; margin: 0; color: #6a574f; font-size: .9rem; line-height: 1.85; }
.invitation-meta { display: flex; align-items: center; gap: .8rem; margin: 1.35rem 0 1.65rem; color: var(--wine); font-size: .63rem; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.invitation-meta b { color: var(--gold); font-size: 1rem; }
.invitation-seal { position: absolute; z-index: 4; top: 26px; left: calc(42% - 42px); display: grid; place-items: center; width: 84px; height: 84px; border: 2px solid var(--gold-light); border-radius: 50%; color: var(--gold-light); background: var(--wine); box-shadow: 0 12px 24px rgba(0,0,0,.22); font: 1.8rem var(--script); transform: rotate(-9deg); animation: sealFloat 4.5s ease-in-out infinite; }
@keyframes sealFloat { 50% { transform: translateY(-8px) rotate(8deg); } }

.reveal { transition-delay: var(--reveal-delay, 0ms); }
.story-card figure { overflow: visible; }
.story-card figure img { transition: transform .8s cubic-bezier(.2,.8,.2,1), filter .55s ease; }
.story-card:hover img { transform: translateY(-7px) scale(1.025); filter: saturate(1.08); }
.quote-photo { transition: transform .4s ease-out; }
.gallery-item:nth-child(3n) img { animation: galleryBreathe 8s ease-in-out infinite alternate; }
@keyframes galleryBreathe { to { transform: scale(1.075); } }

.event-card.tilt-card { transform-style: preserve-3d; will-change: transform; }
.event-card.event-card--haldi { background: radial-gradient(circle at 15% 12%, #fff6b7 0 3%, transparent 14%), radial-gradient(circle at 80% 20%, rgba(255,207,57,.72), transparent 42%), linear-gradient(145deg, #ffef8e, #ffc957 58%, #f1ad30); color: #5c3104; box-shadow: 0 20px 46px rgba(220,151,20,.25); }
.event-card.event-card--haldi::before { border-color: rgba(117,67,0,.30); }
.event-card.event-card--haldi::after { content: '✦  ✦  ✦'; position: absolute; right: 1rem; bottom: 3.7rem; color: rgba(255,255,255,.68); font-size: .95rem; letter-spacing: .42rem; animation: haldiGlow 2.8s ease-in-out infinite; }
.event-card.event-card--haldi > * { position: relative; z-index: 1; }
.event-card.event-card--haldi h3, .event-card.event-card--haldi .event-dress b, .event-card.event-card--haldi .event-calendar { color: #623604; }
.event-card.event-card--haldi .event-venue, .event-card.event-card--haldi .event-dress { color: rgba(86,47,0,.75); }
.event-card.event-card--haldi .event-calendar { border-color: rgba(99,54,4,.25); }
@keyframes haldiGlow { 50% { transform: scale(1.2) rotate(5deg); opacity: .3; } }

.event-card.event-card--mehendi { background: linear-gradient(145deg, #f7f1d7, #d9e6bf); color: #24401e; }
.event-card.event-card--mehendi::before { border-color: rgba(44,100,44,.28); }
.event-card.event-card--mehendi h3, .event-card.event-card--mehendi .event-dress b, .event-card.event-card--mehendi .event-calendar { color: #1f5431; }
.event-card.event-card--mehendi .event-venue, .event-card.event-card--mehendi .event-dress { color: rgba(31,84,49,.74); }
.event-card.event-card--mehendi .event-calendar { border-color: rgba(31,84,49,.23); }

.event-card.event-card--sangeet { overflow: hidden; color: #fff; background: radial-gradient(circle at 25% 12%, rgba(255,225,141,.58), transparent 18%), radial-gradient(circle at 90% 72%, rgba(115,70,235,.62), transparent 42%), linear-gradient(135deg, #140b3a, #46176e 48%, #0d3b6e); background-size: 180% 180%; box-shadow: 0 18px 52px rgba(56,25,112,.35); animation: sangeetGlow 7.5s ease-in-out infinite; }
.event-card.event-card--sangeet::before { border-color: rgba(255,231,160,.58); }
.event-card.event-card--sangeet::after { content: '✦  ✧  ✦  ✧  ✦'; position: absolute; z-index: 0; top: 18%; left: -1.25rem; width: 120%; color: rgba(255,232,170,.77); letter-spacing: .52rem; font-size: 1.05rem; white-space: nowrap; animation: sangeetStars 5s linear infinite; }
.event-card.event-card--sangeet > * { position: relative; z-index: 1; }
.event-card.event-card--sangeet h3 { color: #fff; text-shadow: 0 2px 10px rgba(0,0,0,.26); }
.event-card.event-card--sangeet .event-venue, .event-card.event-card--sangeet .event-dress { color: rgba(255,255,255,.80); }
.event-card.event-card--sangeet .event-dress b, .event-card.event-card--sangeet .event-calendar { color: var(--gold-light); }
.event-card.event-card--sangeet .event-calendar { border-color: rgba(255,255,255,.24); }
@keyframes sangeetGlow { 50% { background-position: 100% 100%; box-shadow: 0 25px 60px rgba(77,34,158,.55), 0 0 28px rgba(240,211,156,.28); } }
@keyframes sangeetStars { 0% { transform: translateX(-8%) rotate(-2deg); opacity: .25; } 50% { opacity: 1; } 100% { transform: translateX(9%) rotate(2deg); opacity: .25; } }

.event-card.event-card--wedding { background: linear-gradient(140deg, #fffdf8, #f2e5cf); color: var(--wine); }
.event-card.event-card--wedding::before { border-color: rgba(151,101,40,.34); }
.event-card.event-card--wedding h3, .event-card.event-card--wedding .event-dress b, .event-card.event-card--wedding .event-calendar { color: var(--wine); }
.event-card.event-card--wedding .event-calendar { border-color: rgba(121,79,49,.2); }

@media (max-width: 760px) {
  .hero-orbit-one { width: 105vw; left: -50vw; top: -45vw; }.hero-orbit-two { width: 70vw; right: -32vw; bottom: -32vw; }
  .invitation-card { grid-template-columns: 1fr; min-height: 0; }.invitation-photo { position: relative; width: 100%; height: 240px; }.invitation-copy { grid-column: 1; padding: 3rem 1.55rem 3.3rem; }.invitation-seal { left: auto; right: 1.1rem; top: 205px; width: 72px; height: 72px; font-size: 1.55rem; }
}
@media (max-width: 500px) {
  .hero-actions .button-invitation { min-width: 220px; }.invitation-copy h2 { font-size: 3.2rem; }.invitation-meta { flex-wrap: wrap; gap: .45rem; }.event-card.event-card--sangeet::after { letter-spacing: .25rem; font-size: .83rem; }
}
@media (prefers-reduced-motion: reduce) {
  .scroll-progress span { transition: none; }.hero-image, .quote-photo, .venue-image, .invitation-photo { transform: none !important; }.hero-orbit, .hero-sparkles i, .invitation-seal, .gallery-item img, .event-card, .event-card::after { animation: none !important; }
}
