:root {
  --ink: #11110f;
  --ink-soft: #1b1a17;
  --ivory: #f4f0e8;
  --paper: #eae3d7;
  --champagne: #d2c0a2;
  --gold: #bda175;
  --taupe: #8d8171;
  --graphite: #383732;
  --mocha: #6b5546;
  --greige: #b5aa9b;
  --line-dark: rgba(17, 17, 15, .18);
  --line-light: rgba(244, 240, 232, .19);
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "Manrope", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ink);
  color: var(--ivory);
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
img { display: block; width: 100%; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.grain {
  position: fixed;
  inset: 0;
  z-index: 20;
  pointer-events: none;
  opacity: .045;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E");
}

.hero {
  --hero-shift: 0px;
  min-height: 100svh;
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: var(--ink);
}
.hero::before {
  content: "";
  position: absolute;
  inset: -7%;
  background: url("assets/hero-dinner.png") center calc(50% + var(--hero-shift)) / cover no-repeat;
  transform: scale(1.02);
  transition: background-position .08s linear;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 50%, rgba(210, 192, 162, .2), transparent 29%),
    linear-gradient(180deg, rgba(5,5,4,.52), rgba(5,5,4,.13) 45%, rgba(5,5,4,.61));
}
.nav {
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  right: 0;
  height: 84px;
  padding: 0 clamp(22px, 5vw, 80px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(rgba(7, 7, 6, .26), transparent);
  backdrop-filter: blur(10px);
}
.monogram-image {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  opacity: .88;
}
.monogram-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: sepia(.25) saturate(.82) brightness(1.18) drop-shadow(0 0 13px rgba(210, 192, 162, .24));
}
.nav-links {
  display: flex;
  gap: 36px;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.nav-links a {
  position: relative;
  transition: color .25s, letter-spacing .25s;
}
.nav-links a::before,
.nav-links a::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--champagne), transparent);
  transform: translateX(-50%);
  transition: width .3s ease;
}
.nav-links a::before { top: -9px; }
.nav-links a::after { bottom: -9px; }
.nav-links a:hover {
  color: var(--champagne);
  letter-spacing: .2em;
}
.nav-links a:hover::before,
.nav-links a:hover::after { width: 100%; }
.menu-button { display: none; }
.hero-content {
  position: relative;
  z-index: 2;
  padding: 118px 20px 100px;
  text-align: center;
}
.hero-content::before {
  content: "";
  position: absolute;
  inset: 22px -42px 38px;
  z-index: -1;
  border: 1px solid rgba(244, 240, 232, .12);
  background: radial-gradient(circle at 50% 48%, rgba(200, 177, 134, .2), transparent 62%);
  box-shadow: 0 28px 95px rgba(0,0,0,.27), 0 0 80px rgba(189,161,117,.13);
  backdrop-filter: blur(2px);
  opacity: .84;
}
.hero-crest {
  width: clamp(78px, 8vw, 118px);
  margin: 0 auto 26px;
  opacity: .86;
  filter: sepia(.22) saturate(.82) brightness(1.18) drop-shadow(0 10px 28px rgba(0,0,0,.34)) drop-shadow(0 0 18px rgba(210, 192, 162, .18));
}
.eyebrow {
  margin: 0 0 28px;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: .32em;
  text-transform: uppercase;
}
.hero-eyebrow {
  margin-bottom: 18px;
  font-size: 13px;
  letter-spacing: .36em;
}
.hero-divider {
  width: min(210px, 42vw);
  height: 1px;
  margin: 0 auto 34px;
  display: block;
  background: linear-gradient(90deg, transparent, rgba(210,192,162,.88), transparent);
}
.hero h1 {
  margin: 0;
  font: 400 clamp(64px, 10vw, 150px)/.72 var(--serif);
  letter-spacing: -.045em;
  text-shadow: 0 4px 25px rgba(0,0,0,.4), 0 0 46px rgba(200,177,134,.12);
}
.hero h1 span { display: block; }
.hero h1 i {
  display: block;
  margin: .15em 0 .13em;
  color: var(--champagne);
  font-size: .4em;
  font-weight: 400;
}
.hero-meta {
  width: fit-content;
  margin: 55px auto 0;
  padding: 15px 22px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  border: 1px solid rgba(244, 240, 232, .18);
  background: rgba(12, 12, 10, .24);
  backdrop-filter: blur(14px);
  box-shadow: 0 0 38px rgba(189,161,117,.1);
  font: 500 12px/1 var(--serif);
  letter-spacing: .22em;
  text-transform: uppercase;
}
.diamond { color: var(--champagne); }
.scroll-hint {
  position: absolute;
  z-index: 4;
  bottom: 25px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  font-size: 8px;
  letter-spacing: .25em;
  text-transform: uppercase;
}
.scroll-hint i {
  width: 1px;
  height: 32px;
  background: linear-gradient(var(--ivory), transparent);
}

.light-section {
  background: var(--ivory);
  color: var(--ink);
}
.dark-section {
  background: var(--ink);
  color: var(--ivory);
}
.intro {
  min-height: 95svh;
  padding: clamp(90px, 12vw, 170px) 7vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.ornament {
  width: 124px;
  margin-bottom: 48px;
  opacity: .9;
  filter: sepia(.18) saturate(.82) brightness(.96) drop-shadow(0 8px 22px rgba(17,17,15,.12));
}
.intro h2 {
  max-width: 950px;
  margin: 0;
  font: 400 clamp(38px, 5.8vw, 78px)/1.06 var(--serif);
  letter-spacing: -.025em;
}
.intro-copy {
  max-width: 560px;
  margin: 38px 0 0;
  color: #565148;
}
.date-display {
  width: min(570px, 100%);
  margin-top: 70px;
  padding-top: 30px;
  border-top: 1px solid var(--line-dark);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 25px;
  font: 500 11px/1.3 var(--serif);
  letter-spacing: .16em;
  text-transform: uppercase;
}
.date-display strong {
  color: var(--gold);
  font: 400 60px/1 var(--serif);
}

.schedule { padding: clamp(95px, 12vw, 170px) 7vw; }
.section-heading { margin-bottom: 70px; text-align: center; }
.section-heading h2 {
  margin: 0;
  font: 400 clamp(52px, 6.5vw, 88px)/1 var(--serif);
  letter-spacing: -.035em;
}
.section-heading > p:last-child,
.section-heading > p:not(.eyebrow) {
  max-width: 620px;
  margin: 20px auto 0;
  color: #625d55;
}
.timeline {
  max-width: 920px;
  margin: 0 auto;
  position: relative;
}
.timeline::before {
  content: "";
  position: absolute;
  top: 20px;
  bottom: 25px;
  left: 132px;
  width: 1px;
  background: var(--line-dark);
}
.timeline-item {
  position: relative;
  min-height: 132px;
  display: grid;
  grid-template-columns: 95px 74px 1fr;
  align-items: start;
}
.timeline-item time { padding-top: 5px; font: 400 28px/1 var(--serif); }
.timeline-dot {
  position: relative;
  z-index: 1;
  justify-self: center;
  width: 10px;
  height: 10px;
  margin-top: 10px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 9px var(--ivory);
}
.timeline-item h3 { margin: 0; font: 500 29px/1 var(--serif); }
.timeline-item p { margin: 10px 0 0; color: #716b62; }
.timeline-note {
  max-width: 540px;
  margin: 18px auto 0;
  padding-top: 28px;
  border-top: 1px solid var(--line-dark);
  text-align: center;
  color: #625d55;
  font-style: italic;
}

.venue {
  min-height: 760px;
  display: grid;
  grid-template-columns: 46% 54%;
  border-top: 1px solid var(--line-dark);
}
.venue-card {
  padding: clamp(90px, 10vw, 150px) 8vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.venue-card h2 { margin: 0 0 25px; font: 400 clamp(55px, 7vw, 95px)/.95 var(--serif); }
.venue-card > p:not(.eyebrow) { max-width: 470px; color: #625d55; }
.venue-card address {
  max-width: 520px;
  margin: 25px 0;
  font: italic 400 20px/1.5 var(--serif);
}
.venue-note {
  margin-bottom: 40px;
  font-size: 14px;
}
.button {
  width: fit-content;
  min-width: 210px;
  padding: 16px 28px;
  border: 1px solid currentColor;
  background: transparent;
  cursor: pointer;
  text-align: center;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .18em;
  text-transform: uppercase;
  transition: background .25s, color .25s, transform .25s, border-color .25s, opacity .25s;
}
.button:hover { transform: translateY(-2px); }
.button:disabled { opacity: .55; cursor: wait; }
.button-dark { color: var(--ink); }
.button-dark:hover { background: var(--ink); color: var(--ivory); }
.button-light { color: var(--ivory); }
.button-light:hover { background: var(--ivory); color: var(--ink); }
.venue-map {
  position: relative;
  min-height: 620px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    linear-gradient(rgba(17,17,15,.18), rgba(17,17,15,.28)),
    #d4ccbe;
}
.venue-map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(.48) sepia(.1) contrast(.92) brightness(.88);
}
.map-fallback {
  position: relative;
  z-index: 1;
  width: min(440px, calc(100% - 48px));
  padding: 38px;
  border: 1px solid rgba(17, 17, 15, .16);
  background: rgba(244, 240, 232, .83);
  box-shadow: 0 30px 90px rgba(17,17,15,.18);
  backdrop-filter: blur(18px);
  opacity: .94;
}
.map-label {
  display: block;
  margin-bottom: 20px;
  color: #766d5f;
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
}
.map-fallback h3 {
  margin: 0;
  font: 400 48px/1 var(--serif);
}
.map-fallback p { margin: 18px 0 28px; color: #5f594f; }

.dress-code {
  min-height: 760px;
  display: grid;
  grid-template-columns: 45% 55%;
}
.dress-copy {
  padding: clamp(90px, 11vw, 165px) 7vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.dress-copy h2,
.lookbook-heading h2 {
  max-width: 600px;
  margin: 0 0 38px;
  font: 400 clamp(45px, 5.8vw, 82px)/.96 var(--serif);
  letter-spacing: -.035em;
}
.dress-copy > p:not(.eyebrow) {
  max-width: 530px;
  color: #bbb4a8;
}
.dress-moodboard {
  min-height: 620px;
  padding: clamp(55px, 7vw, 95px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-content: center;
  background:
    radial-gradient(circle at 50% 45%, rgba(191,159,108,.17), transparent 43%),
    linear-gradient(150deg, #26231f, #0a0a09 70%);
}
.fabric-card {
  min-height: 178px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 2px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 40px rgba(0,0,0,.18);
  transform: translateY(0);
  transition: transform .35s ease, box-shadow .35s ease, filter .35s ease;
}
.fabric-card::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .28;
  background-image:
    linear-gradient(135deg, rgba(255,255,255,.45) 0 1px, transparent 1px 10px),
    radial-gradient(circle at 20% 15%, rgba(255,255,255,.28), transparent 28%),
    linear-gradient(110deg, transparent 30%, rgba(255,255,255,.18) 47%, transparent 62%);
  mix-blend-mode: soft-light;
}
.fabric-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.18), transparent 34%, rgba(0,0,0,.16));
}
.fabric-card span {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 14px;
  z-index: 1;
  opacity: .72;
  transform: translateY(8px);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  transition: opacity .3s, transform .3s;
}
.fabric-card:hover {
  transform: translateY(-5px);
  filter: saturate(1.05);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 24px 60px rgba(0,0,0,.25);
}
.fabric-card:hover span {
  opacity: 1;
  transform: translateY(0);
}
.fabric-card.dark { background: linear-gradient(135deg, #0a0a09, #191815); }
.fabric-card.graphite { background: linear-gradient(135deg, #2d2d2a, var(--graphite)); }
.fabric-card.greige { background: linear-gradient(135deg, #8f8577, var(--greige)); color: var(--ink); }
.fabric-card.mocha { background: linear-gradient(135deg, #4d382f, var(--mocha)); }
.fabric-card.champagne { background: linear-gradient(135deg, #aa936f, var(--champagne)); color: var(--ink); }
.fabric-card.ivory { background: linear-gradient(135deg, #d8d0c2, var(--ivory)); color: var(--ink); }

.lookbook {
  padding: clamp(85px, 10vw, 135px) 0;
  overflow: hidden;
  border-top: 1px solid rgba(244,240,232,.1);
}
.lookbook[hidden] { display: none; }
.lookbook-heading {
  max-width: 760px;
  margin: 0 auto 55px;
  padding: 0 7vw;
  text-align: center;
}
.lookbook-heading h2 { margin-left: auto; margin-right: auto; }
.lookbook-heading p:not(.eyebrow) { color: #bbb4a8; }
.lookbook-track {
  display: flex;
  gap: 18px;
  width: max-content;
  padding: 0 7vw 18px;
  animation: lookbook-scroll 34s linear infinite;
}
.lookbook-track:hover { animation-play-state: paused; }
.look-card {
  width: clamp(220px, 24vw, 340px);
  height: clamp(310px, 34vw, 460px);
  flex: 0 0 auto;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(244,240,232,.12);
  background: #211f1b;
  box-shadow: 0 24px 70px rgba(0,0,0,.28);
}
.look-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 45% 20%, rgba(255,255,255,.28), transparent 16%),
    linear-gradient(145deg, rgba(255,255,255,.14), transparent 42%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 1px, transparent 1px 14px);
  mix-blend-mode: soft-light;
}
.look-card span {
  position: absolute;
  left: 22px;
  bottom: 22px;
  font: 400 25px/1 var(--serif);
}
.look-black { background: linear-gradient(160deg, #080807, #282622); }
.look-silk { background: linear-gradient(160deg, #a79270, #eee1ca); color: var(--ink); }
.look-mocha { background: linear-gradient(160deg, #3d2c25, #8b6a55); }
.look-ivory { background: linear-gradient(160deg, #cfc4b4, #f6f1e8); color: var(--ink); }
.look-graphite { background: linear-gradient(160deg, #22221f, #55534d); }
.look-greige { background: linear-gradient(160deg, #8f8474, #c6bbaa); color: var(--ink); }
@keyframes lookbook-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% + 45vw)); }
}

.rsvp {
  padding: clamp(95px, 12vw, 170px) 7vw;
  background:
    radial-gradient(circle at 50% 20%, rgba(189,161,117,.15), transparent 32%),
    linear-gradient(180deg, #11110f, #0a0a09);
}
.rsvp .section-heading > p:not(.eyebrow) { color: #bbb4a8; }
.rsvp-form {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(28px, 5vw, 56px);
  border: 1px solid rgba(244, 240, 232, .15);
  background: rgba(244, 240, 232, .055);
  box-shadow: 0 30px 90px rgba(0,0,0,.24);
  backdrop-filter: blur(18px);
}
.rsvp-form > label, fieldset { display: block; margin: 0 0 34px; }
.rsvp-form label > span, legend {
  display: block;
  margin-bottom: 10px;
  color: var(--champagne);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.rsvp-form input[type="text"],
.rsvp-form input[type="number"],
.rsvp-form textarea {
  width: 100%;
  padding: 13px 0;
  border: 0;
  border-bottom: 1px solid rgba(244, 240, 232, .22);
  border-radius: 0;
  outline: none;
  background: transparent;
  color: var(--ivory);
  font: 400 22px var(--serif);
  transition: border-color .2s, color .2s;
}
.rsvp-form input:focus, .rsvp-form textarea:focus { border-color: var(--gold); }
fieldset { padding: 0; border: 0; }
.radio { display: flex; align-items: center; gap: 12px; margin: 14px 0; cursor: pointer; }
.radio input { accent-color: var(--champagne); }
.radio span { margin: 0 !important; color: var(--ivory) !important; font-size: 14px !important; font-weight: 300 !important; letter-spacing: 0 !important; text-transform: none !important; }
.rsvp-form .button { margin-top: 8px; }
.hidden-frame {
  position: absolute;
  width: 1px;
  height: 1px;
  border: 0;
  opacity: 0;
  pointer-events: none;
}
.guest-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
}
.guest-options .radio {
  min-width: 42px;
  margin: 4px 0;
}
.form-status { min-height: 24px; color: var(--champagne); font-style: italic; }
.rsvp-contact {
  max-width: 650px;
  margin: 42px auto 0;
  text-align: center;
  color: #bbb4a8;
}
.rsvp-contact a {
  color: var(--champagne);
  border-bottom: 1px solid rgba(210,192,162,.55);
}

.countdown {
  padding: clamp(85px, 10vw, 140px) 7vw;
  text-align: center;
}
.countdown-grid {
  max-width: 850px;
  margin: 45px auto 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.countdown-grid div {
  padding: 15px;
  border-right: 1px solid var(--line-light);
}
.countdown-grid div:last-child { border-right: 0; }
.countdown-grid strong { display: block; font: 400 clamp(48px, 7vw, 90px)/1 var(--serif); }
.countdown-grid span { font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--champagne); }

footer {
  padding: 90px 25px 45px;
  background: #090908;
  text-align: center;
  color: #958d81;
  font-size: 12px;
}
.footer-crest {
  width: 70px;
  margin: 0 auto 26px;
  opacity: .55;
  filter: sepia(.22) saturate(.72) brightness(1.05);
}
.footer-names { margin: 0 0 25px; color: var(--ivory); font: 400 clamp(42px, 6vw, 75px)/1 var(--serif); }
.footer-names i { color: var(--gold); }
footer a { display: block; margin: 20px 0; color: var(--champagne); }
.footer-date { display: block; margin-top: 65px; font-size: 9px; letter-spacing: .25em; text-transform: uppercase; }

.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.15s cubic-bezier(.22,1,.36,1), transform 1.15s cubic-bezier(.22,1,.36,1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 800px) {
  .nav {
    height: 66px;
    backdrop-filter: none;
  }
  .monogram-image {
    width: 34px;
    height: 34px;
  }
  .menu-button {
    position: relative;
    z-index: 3;
    width: 34px;
    height: 34px;
    padding: 0;
    display: block;
    border: 0;
    background: none;
    color: white;
  }
  .menu-button span:not(.sr-only) {
    position: absolute;
    left: 5px;
    width: 24px;
    height: 1px;
    background: currentColor;
    transition: transform .25s, top .25s;
  }
  .menu-button span:first-child { top: 12px; }
  .menu-button span:nth-child(2) { top: 21px; }
  .menu-open .menu-button span:first-child { top: 17px; transform: rotate(45deg); }
  .menu-open .menu-button span:nth-child(2) { top: 17px; transform: rotate(-45deg); }
  .nav-links {
    position: fixed;
    z-index: 2;
    inset: 0;
    padding: 100px 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: rgba(12,12,10,.97);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-15px);
    transition: opacity .25s, transform .25s;
  }
  .nav-links a { font: 400 32px/1 var(--serif); letter-spacing: .02em; text-transform: none; }
  .nav-links a::before,
  .nav-links a::after { display: none; }
  .menu-open .nav-links { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .hero { min-height: 760px; }
  .hero::before { background-position: 50% center; }
  .hero-content { padding-top: 104px; }
  .hero-content::before { inset: 42px -10px 50px; }
  .hero-crest { width: 82px; margin-bottom: 22px; }
  .hero-eyebrow { font-size: 11px; letter-spacing: .28em; }
  .hero h1 { font-size: clamp(57px, 18vw, 78px); }
  .hero-meta {
    margin-top: 45px;
    flex-direction: column;
    gap: 12px;
    width: min(330px, 100%);
    line-height: 1.35;
  }
  .hero-meta .diamond { display: none; }
  .intro { min-height: 780px; padding-left: 24px; padding-right: 24px; }
  .ornament { width: 88px; }
  .intro h2 { font-size: 39px; }
  .date-display { gap: 10px; }
  .date-display span { font-size: 8px; }
  .date-display strong { font-size: 48px; }
  .schedule { padding-left: 25px; padding-right: 25px; }
  .timeline::before { left: 87px; }
  .timeline-item { min-height: 132px; grid-template-columns: 62px 50px 1fr; }
  .timeline-item time { font-size: 21px; }
  .timeline-item h3 { font-size: 25px; }
  .timeline-item p { font-size: 12px; line-height: 1.5; }
  .venue { grid-template-columns: 1fr; }
  .venue-card { padding: 100px 25px 70px; }
  .venue-map { min-height: 520px; margin: 0 25px 95px; }
  .map-fallback { padding: 30px 24px; }
  .map-fallback h3 { font-size: 41px; }
  .dress-code { grid-template-columns: 1fr; }
  .dress-copy { padding: 95px 25px 65px; }
  .dress-copy h2 { font-size: 51px; }
  .dress-moodboard {
    min-height: auto;
    padding: 0 25px 100px;
    grid-template-columns: repeat(2, 1fr);
    background: var(--ink);
  }
  .fabric-card { min-height: 140px; }
  .lookbook { padding-top: 20px; }
  .lookbook-heading { text-align: left; }
  .lookbook-heading h2 { margin-left: 0; font-size: 51px; }
  .lookbook-track {
    width: auto;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    animation: none;
    padding-left: 25px;
    padding-right: 25px;
  }
  .look-card {
    width: 76vw;
    height: 108vw;
    max-height: 430px;
    scroll-snap-align: center;
  }
  .rsvp { padding-left: 25px; padding-right: 25px; }
  .countdown-grid { grid-template-columns: repeat(2, 1fr); gap: 30px 0; }
  .countdown-grid div:nth-child(2) { border-right: 0; }
  .countdown-grid strong { font-size: 55px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .hero::before { transition: none; }
  .lookbook-track { animation: none; }
  .reveal { opacity: 1; transform: none; transition: none; }
}
