/* =========================================================
   MACOURA & GUILLAUME — Château de Chambly
   Cinematic photographic wedding invitation · daylight
   ========================================================= */

:root {
  --c-paper:   #f6efe1;
  --c-cream:   #efe5d2;
  --c-ink:     #2c2a22;
  --c-ink-soft:#5b5648;
  --c-sage:    #7c8a6a;
  --c-sage-dk: #5c6a4c;
  --c-gold:    #b08a4a;
  --c-gold-dk: #8a6a36;
  --c-gold-lt: #d8b977;
  --c-sky:     #9bb0bd;

  --ff-display: "Italiana", "Cormorant Garamond", serif;
  --ff-serif:   "Cormorant Garamond", "EB Garamond", serif;
  --ff-mono:    "JetBrains Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--c-paper);
  color: var(--c-ink);
  font-family: var(--ff-serif);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}
section { position: relative; overflow-x: clip; }
img, svg { display: block; max-width: 100%; }

/* Lenis */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-stopped { overflow: clip; }

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--c-paper);
  display: flex; align-items: center; justify-content: center;
  flex-direction: column;
  transition: opacity 1.4s ease;
}
.preloader__crest {
  width: 60px; height: 60px;
  margin-bottom: 26px;
  opacity: 0; animation: fadeIn 1.4s 0.2s forwards;
}
.preloader__bar {
  width: 200px; height: 1px;
  background: rgba(138, 106, 54, 0.18);
  position: relative; overflow: hidden;
}
.preloader__bar::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, var(--c-gold), transparent);
  transform: translateX(-100%);
  animation: shimmer 2.2s ease-in-out infinite;
}
.preloader__count {
  margin-top: 20px;
  font-family: var(--ff-mono);
  font-size: 10px; letter-spacing: 0.4em;
  color: var(--c-gold-dk); text-transform: uppercase;
}
@keyframes shimmer { 50%,100% { transform: translateX(100%); } }
@keyframes fadeIn { to { opacity: 1; } }

/* =========================================================
   FIXED CHROME
   ========================================================= */
.chrome {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 50; pointer-events: none;
  padding: 26px 36px;
  display: flex; justify-content: space-between; align-items: flex-start;
  color: #fff;
  mix-blend-mode: difference;
}
.chrome__monogram {
  font-family: var(--ff-display);
  font-size: 21px; letter-spacing: 0.22em;
  display: inline-flex; align-items: center;
}
.chrome__monogram em {
  font-family: "Parisienne", cursive;
  font-style: normal; font-weight: 400;
  opacity: 0.95; font-size: 1.5em;
  letter-spacing: 0; margin: 0 0.08em;
  transform: translateY(0.06em);
}
.chrome__meta {
  font-family: var(--ff-mono);
  font-size: 9.5px; letter-spacing: 0.3em;
  text-transform: uppercase; text-align: right; line-height: 1.8;
}

/* Audio toggle */
.audio-toggle {
  position: fixed; bottom: 26px; right: 26px;
  z-index: 60; width: 44px; height: 44px;
  display: grid; place-items: center;
  background: rgba(246, 239, 225, 0.7);
  border: 1px solid rgba(138, 106, 54, 0.4);
  border-radius: 50%; cursor: pointer;
  backdrop-filter: blur(8px); pointer-events: auto;
  transition: border-color 0.4s, background 0.4s;
}
.audio-toggle:hover { border-color: var(--c-gold); background: rgba(239, 229, 210, 0.9); }
.audio-toggle__bars { display: flex; gap: 3px; align-items: end; height: 14px; }
.audio-toggle__bars span {
  display: block; width: 2px; background: var(--c-gold-dk);
  border-radius: 1px; animation: bars 1.4s ease-in-out infinite;
}
.audio-toggle__bars span:nth-child(1) { height: 50%; animation-delay: 0s; }
.audio-toggle__bars span:nth-child(2) { height: 100%; animation-delay: 0.15s; }
.audio-toggle__bars span:nth-child(3) { height: 70%; animation-delay: 0.3s; }
.audio-toggle__bars span:nth-child(4) { height: 90%; animation-delay: 0.45s; }
.audio-toggle.is-muted .audio-toggle__bars span { animation-play-state: paused; opacity: 0.4; }
@keyframes bars { 0%,100% { transform: scaleY(0.5); } 50% { transform: scaleY(1); } }

/* Scroll cue */
.scroll-cue {
  position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%);
  z-index: 30;
  font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: 0.4em;
  color: #fff; text-transform: uppercase; mix-blend-mode: difference;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  opacity: 0; pointer-events: none;
}
.scroll-cue__line {
  width: 1px; height: 34px;
  background: linear-gradient(to bottom, rgba(255,255,255,0.7), transparent);
  position: relative; overflow: hidden;
}
.scroll-cue__line::after {
  content: ""; position: absolute; left: 0; top: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(to bottom, transparent, #fff);
  animation: drip 2.4s ease-in-out infinite;
}
@keyframes drip { to { top: 100%; } }

/* =========================================================
   OPENING — envelope + ink-sketch reveal
   ========================================================= */
.opening {
  height: 100vh; position: relative; overflow: hidden;
  background: linear-gradient(to bottom, #c9dbe4 0%, #dde6df 45%, #f1ead9 100%);
}
.opening__wash {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 50% 40% at 30% 25%, rgba(255,255,255,0.5), transparent 70%),
    radial-gradient(ellipse 60% 50% at 75% 80%, rgba(168,189,138,0.25), transparent 70%);
}

/* --- the drawn scene (hidden until opened) --- */
.opening__scene {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 4vh 24px;
  opacity: 0; filter: blur(16px); transform: scale(1.04);
  pointer-events: none;
}
.sketch {
  width: min(760px, 92vw); height: auto;
  margin-top: 2vh;
}
.sketch__wash { opacity: 0; }
.sketch__birds { opacity: 0; }

.opening__title { text-align: center; margin-top: -2vh; }

/* Monogram: names with a large "&" superimposed */
.opening__monogram {
  position: relative;
  display: inline-block;
  padding: 0.34em 0;
}
.mono__name {
  display: block;
  font-family: "Italiana", serif; font-weight: 400;
  font-size: clamp(40px, 6.4vw, 86px); line-height: 0.92;
  color: #3a5160; letter-spacing: 0.04em;
  position: relative; z-index: 1;
}
.mono__name--1 { text-align: left;  padding-right: 2.1em; margin-bottom: 0.04em; }
.mono__name--2 { text-align: right; padding-left: 2.1em; }
.mono__amp {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  font-family: "Parisienne", cursive; font-weight: 400;
  font-size: clamp(88px, 13.5vw, 168px); line-height: 1;
  color: var(--c-gold); z-index: 2;
  text-shadow: 0 6px 26px rgba(176,138,74,0.4);
  pointer-events: none;
}
.opening__date {
  font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.42em;
  color: var(--c-gold-dk); text-transform: uppercase; margin-bottom: 14px;
  opacity: 0;
}
.opening__date span { display: inline-block; padding: 0 14px; position: relative; }
.opening__date span::before, .opening__date span::after {
  content: ""; position: absolute; top: 50%; width: 48px; height: 1px;
  background: linear-gradient(to right, transparent, rgba(176,138,74,0.5), transparent);
}
.opening__date span::before { right: 100%; }
.opening__date span::after  { left: 100%; }

.opening__names {
  font-family: "Italiana", serif; font-weight: 400;
  font-size: clamp(46px, 7vw, 92px); line-height: 1.0;
  color: #3a5160; letter-spacing: 0.05em; opacity: 0;
}
.opening__names span {
  font-family: "Parisienne", cursive;
  font-style: normal; font-weight: 400;
  color: var(--c-gold); padding: 0 0.12em;
  font-size: 0.92em; vertical-align: -0.04em;
}
.opening__place {
  font-family: var(--ff-serif); font-style: italic;
  font-size: clamp(14px, 1.2vw, 17px); letter-spacing: 0.14em;
  color: var(--c-ink-soft); margin-top: 16px; opacity: 0;
}
.opening__cue {
  margin-top: 30px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.4em;
  color: var(--c-gold-dk); text-transform: uppercase; opacity: 0;
}

/* --- couple walking to meet --- */
.opening__couple {
  position: absolute; left: 50%; bottom: 55%;
  transform: translateX(-50%);
  width: min(300px, 54vw); height: clamp(64px, 11vh, 100px);
  pointer-events: none; z-index: 6;
}
.fig {
  position: absolute; bottom: 0; left: 50%;
  transform: translateX(-50%);
  opacity: 0;
}
.fig svg { height: clamp(52px, 9vh, 84px); width: auto; display: block;
  filter: drop-shadow(0 3px 5px rgba(40,50,40,0.25)); }
.fig--groom { margin-left: -2px; }
.fig--bride { margin-left: 2px; }
.couple__heart {
  position: absolute; left: 50%; bottom: 70%;
  transform: translate(-50%, 0) scale(0.4);
  opacity: 0;
}
.couple__heart svg { width: clamp(20px, 3.4vh, 30px); height: auto; }
.opening__cue-line {
  width: 1px; height: 30px; position: relative; overflow: hidden;
  background: linear-gradient(to bottom, rgba(176,138,74,0.6), transparent);
}
.opening__cue-line::after {
  content: ""; position: absolute; left: 0; top: -100%; width: 100%; height: 100%;
  background: linear-gradient(to bottom, transparent, var(--c-gold-dk));
  animation: drip 2.4s ease-in-out infinite;
}

/* --- envelope --- */
.opening__envelope {
  position: absolute; inset: 0; z-index: 5;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 34px; cursor: pointer;
}
.envelope {
  position: relative;
  width: min(340px, 78vw); height: min(226px, 52vw);
  perspective: 900px;
}
.envelope__shadow {
  position: absolute; left: 50%; bottom: -28px; transform: translateX(-50%);
  width: 78%; height: 30px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(60,70,60,0.22), transparent 70%);
  filter: blur(4px);
}
.envelope__paper {
  position: absolute; inset: 0; border-radius: 6px;
  background: linear-gradient(160deg, #f6efe1 0%, #ece0c8 100%);
  box-shadow: 0 24px 60px rgba(60,70,80,0.22), inset 0 0 0 1px rgba(176,138,74,0.35);
}
.envelope__pocket {
  position: absolute; inset: 0; border-radius: 6px; overflow: hidden;
}
.envelope__pocket::before {
  content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 100%;
  background:
    linear-gradient(to top right, #ece0c8 0%, #ece0c8 49.6%, transparent 50%),
    linear-gradient(to top left,  #ece0c8 0%, #ece0c8 49.6%, transparent 50%);
  background-size: 50% 100%, 50% 100%;
  background-position: left, right;
  background-repeat: no-repeat;
  box-shadow: inset 0 0 0 1px rgba(176,138,74,0.18);
}
.envelope__pocket::after {
  content: ""; position: absolute; left: 0; top: 0; width: 50%; height: 100%;
  border-right: 1px solid rgba(176,138,74,0.16);
  transform: skewX(0);
}
.envelope__flap {
  position: absolute; top: 0; left: 0; width: 100%; height: 0;
  border-left: calc(min(340px, 78vw) / 2) solid transparent;
  border-right: calc(min(340px, 78vw) / 2) solid transparent;
  border-top: calc(min(226px, 52vw) * 0.62) solid #efe4cc;
  transform-origin: top center; transform: rotateX(0deg);
  z-index: 4; backface-visibility: hidden;
  filter: drop-shadow(0 3px 5px rgba(120,100,60,0.18));
}
.envelope__seal {
  position: absolute; top: calc(min(226px, 52vw) * 0.42); left: 50%;
  transform: translate(-50%, -50%);
  width: 78px; height: 78px; border-radius: 50%; z-index: 6;
  display: grid; place-items: center;
  background:
    radial-gradient(circle at 38% 32%, #d8b977 0%, #b9913f 45%, #8a6a2e 100%);
  box-shadow: 0 6px 16px rgba(80,55,15,0.4), inset 0 2px 5px rgba(255,255,255,0.35), inset 0 -3px 6px rgba(60,40,10,0.4);
}
.envelope__seal svg { width: 64px; height: 64px; }

.opening__hint {
  font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.4em;
  color: var(--c-gold-dk); text-transform: uppercase;
  animation: hintPulse 2.6s ease-in-out infinite;
}
@keyframes hintPulse { 0%,100% { opacity: 0.45; } 50% { opacity: 1; } }

.opening.is-open .opening__envelope { pointer-events: none; }

/* =========================================================
   PHOTO — le lieu
   ========================================================= */
.photo {
  height: 100vh; position: relative; overflow: hidden;
  background: #6f7d5a;
}
.photo__media {
  position: absolute; inset: -6% -2%;
  background-image: url("uploads/chateau1.jpg");
  background-size: cover; background-position: center 42%;
  will-change: transform;
  transform: scale(1.08);
  animation: kenburnsHero 24s ease-in-out infinite alternate;
}
@keyframes kenburnsHero {
  0%   { transform: scale(1.08) translate(0, 0); }
  100% { transform: scale(1.16) translate(-1.5%, -2%); }
}
.photo__grade {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, rgba(30,34,22,0.30) 0%, rgba(30,34,22,0.05) 30%, rgba(30,34,22,0.34) 58%, rgba(16,20,12,0.86) 100%);
}
.photo__inner {
  position: relative; z-index: 3; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  text-align: center; padding: 0 24px 10vh; color: #fff;
}
.photo__eyebrow {
  font-family: var(--ff-mono);
  font-size: 10px; letter-spacing: 0.5em; text-transform: uppercase;
  margin-bottom: 22px; opacity: 0;
  color: #ffffff;
  text-shadow: 0 2px 12px rgba(0,0,0,0.9), 0 0 4px rgba(0,0,0,0.7);
}
.photo__eyebrow span::before, .photo__eyebrow span::after {
  background: linear-gradient(to right, transparent, rgba(255,255,255,0.95), transparent);
}
.photo__eyebrow span { display: inline-block; padding: 0 14px; position: relative; }
.photo__eyebrow span::before, .photo__eyebrow span::after {
  content: ""; position: absolute; top: 50%; width: 54px; height: 1px;
  background: linear-gradient(to right, transparent, rgba(255,255,255,0.8), transparent);
}
.photo__eyebrow span::before { right: 100%; }
.photo__eyebrow span::after  { left: 100%; }
.photo__line {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(28px, 4.4vw, 62px);
  letter-spacing: 0.02em; line-height: 1.18; opacity: 0;
  font-style: italic;
  text-shadow: 0 4px 40px rgba(0,0,0,0.4);
}

/* =========================================================
   NAMES
   ========================================================= */
.names {
  position: relative; padding: 22vh 24px 18vh;
  text-align: center;
  background:
    radial-gradient(ellipse 60% 50% at 50% 30%, rgba(216,185,119,0.12), transparent 70%),
    linear-gradient(to bottom, var(--c-paper), var(--c-cream));
}
.names__leaf {
  width: 40px; height: 40px; margin: 0 auto 40px;
  opacity: 0; 
}
.names__date {
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.5em;
  color: var(--c-gold-dk); text-transform: uppercase; margin-bottom: 54px;
}
.names__date span { display: inline-block; padding: 0 18px; position: relative; }
.names__date span::before, .names__date span::after {
  content: ""; position: absolute; top: 50%; width: 70px; height: 1px;
  background: linear-gradient(to right, transparent, rgba(176,138,74,0.55), transparent);
}
.names__date span::before { right: 100%; }
.names__date span::after  { left: 100%; }

.names__heading {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(58px, 10vw, 168px); line-height: 1.0; letter-spacing: 0.01em;
  color: var(--c-ink);
}
.names__heading .name { display: block; }
.names__heading .amp {
  display: block; font-style: italic; font-size: 0.5em;
  color: var(--c-gold); font-family: var(--ff-serif); font-weight: 400; margin: 0.08em 0;
}
.names__caption {
  margin-top: 56px;
  font-family: var(--ff-serif); font-style: italic;
  font-size: clamp(15px, 1.3vw, 19px); letter-spacing: 0.12em;
  color: var(--c-ink-soft); line-height: 1.9;
  max-width: 520px; margin-left: auto; margin-right: auto;
}
.names__caption em { font-style: italic; color: var(--c-gold-dk); }

.split-char { display: inline-block; transform: translateY(110%); opacity: 0; }
.split-mask { display: inline-block; overflow: hidden; vertical-align: top; }

/* =========================================================
   DETAILS
   ========================================================= */
.details {
  position: relative; padding: 14vh 24px 18vh;
  background: linear-gradient(to bottom, var(--c-cream), var(--c-paper));
}
.details__inner { max-width: 1180px; margin: 0 auto; }
.details__head { text-align: center; margin-bottom: 90px; }
.details__eyebrow {
  font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.5em;
  color: var(--c-gold-dk); text-transform: uppercase; margin-bottom: 22px;
}
.details__title {
  font-family: var(--ff-display); font-size: clamp(40px, 5.5vw, 78px);
  letter-spacing: 0.02em; color: var(--c-ink); font-weight: 400;
}
.details__title em { font-style: italic; color: var(--c-gold); font-family: var(--ff-serif); }

.details__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid rgba(176,138,74,0.3);
}
.details__grid--2 {
  grid-template-columns: repeat(2, 1fr);
  max-width: 760px; margin: 0 auto;
}
.detail-card {
  padding: 54px 36px; text-align: center; position: relative;
  border-right: 1px solid rgba(176,138,74,0.3);
}
.detail-card:last-child { border-right: none; }
.detail-card__num {
  font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.4em;
  color: var(--c-gold); text-transform: uppercase; margin-bottom: 26px;
}
.detail-card__title {
  font-family: var(--ff-display); font-size: 29px; letter-spacing: 0.03em;
  color: var(--c-ink); margin-bottom: 18px; font-weight: 400; line-height: 1.25;
}
.detail-card__divider { margin: 20px auto; width: 24px; height: 1px; background: var(--c-gold); opacity: 0.7; }
.detail-card__body {
  font-family: var(--ff-serif); font-size: 16px; line-height: 1.85;
  color: var(--c-ink-soft); letter-spacing: 0.02em;
}
.detail-card__body em {
  display: block; font-style: italic; color: var(--c-gold-dk);
  font-size: 14px; margin-top: 6px; letter-spacing: 0.1em;
}
.detail-card__map {
  color: var(--c-ink-soft); text-decoration: none;
  border-bottom: 1px solid rgba(176,138,74,0.45);
  transition: color 0.3s, border-color 0.3s;
}
.detail-card__map:hover { color: var(--c-gold-dk); border-color: var(--c-gold); }

/* Schedule */
.schedule { margin-top: 110px; max-width: 720px; margin-left: auto; margin-right: auto; }
.schedule__title {
  font-family: var(--ff-display); font-size: clamp(28px, 3vw, 44px);
  text-align: center; margin-bottom: 46px; color: var(--c-ink); font-weight: 400;
}
.schedule__title em { font-style: italic; color: var(--c-gold); font-family: var(--ff-serif); }
.schedule__row {
  display: grid; grid-template-columns: 110px 1fr auto;
  align-items: baseline; padding: 24px 0; gap: 24px;
  border-top: 1px solid rgba(176,138,74,0.25);
}
.schedule__row:last-child { border-bottom: 1px solid rgba(176,138,74,0.25); }
.schedule__time { font-family: var(--ff-mono); font-size: 12px; letter-spacing: 0.28em; color: var(--c-gold-dk); }
.schedule__name { font-family: var(--ff-display); font-size: 22px; letter-spacing: 0.02em; color: var(--c-ink); }
.schedule__loc { font-family: var(--ff-serif); font-style: italic; font-size: 14px; letter-spacing: 0.08em; color: var(--c-ink-soft); }

/* =========================================================
   RSVP
   ========================================================= */
.rsvp {
  position: relative; padding: 16vh 24px 12vh; text-align: center; overflow: hidden;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
}
.rsvp__media {
  position: absolute; inset: 0;
  background-image: url("uploads/chateau1.jpg");
  background-size: cover; background-position: center 35%;
  transform: scale(1.1); will-change: transform;
}
.rsvp__grade {
  position: absolute; inset: 0;
  background:
    linear-gradient(to bottom, rgba(28,30,20,0.55) 0%, rgba(28,30,20,0.4) 45%, rgba(28,30,20,0.72) 100%);
}
.rsvp__inner { position: relative; z-index: 3; width: 100%; max-width: 720px; margin: 0 auto; color: #fff; }
.rsvp__head { margin-bottom: 48px; }
.rsvp__eyebrow {
  font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: 0.36em;
  text-transform: uppercase; color: var(--c-gold-lt); margin-bottom: 22px;
  text-shadow: 0 2px 14px rgba(0,0,0,0.4);
}
.rsvp__quote {
  font-family: var(--ff-display); font-size: clamp(26px, 3.6vw, 50px);
  font-weight: 400; line-height: 1.3; letter-spacing: 0.015em;
  text-shadow: 0 3px 30px rgba(0,0,0,0.4);
}
.rsvp__quote em { font-style: italic; color: var(--c-gold-lt); }
.rsvp__btn {
  display: inline-block; position: relative; padding: 22px 60px;
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.5em;
  color: #fff; text-transform: uppercase; text-decoration: none;
  border: 1px solid rgba(255,255,255,0.6); background: rgba(255,255,255,0.06);
  backdrop-filter: blur(4px); cursor: pointer;
  transition: color 0.5s, background 0.5s, letter-spacing 0.5s, border-color 0.5s;
}
.rsvp__btn::before, .rsvp__btn::after {
  content: ""; position: absolute; width: 16px; height: 16px; border: 1px solid var(--c-gold-lt);
}
.rsvp__btn::before { top: -5px; left: -5px; border-right: none; border-bottom: none; }
.rsvp__btn::after  { bottom: -5px; right: -5px; border-left: none; border-top: none; }
.rsvp__btn:hover { color: var(--c-ink); background: var(--c-gold-lt); border-color: var(--c-gold-lt); letter-spacing: 0.58em; }

.rsvp__signature {
  margin-top: 84px; font-family: var(--ff-serif); font-style: italic;
  font-size: 15px; letter-spacing: 0.14em; color: rgba(255,255,255,0.82);
}
.rsvp__crest { margin: 40px auto 0; width: 48px; height: 48px; opacity: 0.85; }

/* =========================================================
   RSVP FORM
   ========================================================= */
.rsvp-form {
  text-align: left;
  width: 100%;
  background: rgba(246, 239, 225, 0.97);
  color: var(--c-ink);
  border: 1px solid rgba(176,138,74,0.5);
  padding: 40px clamp(22px, 4vw, 48px) 36px;
  box-shadow: 0 30px 80px rgba(20,24,16,0.4);
  display: flex; flex-direction: column; gap: 24px;
}
.rsvp-form__choice { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.choice { position: relative; cursor: pointer; }
.choice input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.choice__box {
  display: block; text-align: center; padding: 16px 12px;
  font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-ink-soft);
  border: 1px solid rgba(176,138,74,0.45);
  background: rgba(255,255,255,0.4);
  transition: all 0.3s ease;
}
.choice input:checked + .choice__box {
  background: var(--c-ink); color: var(--c-paper); border-color: var(--c-ink);
}
.choice input:focus-visible + .choice__box { outline: 2px solid var(--c-gold); outline-offset: 2px; }

.rsvp-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: end; }
.field { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.field__label {
  min-height: 26px; display: flex; align-items: center;
  font-family: var(--ff-mono); font-size: 9px; letter-spacing: 0.26em;
  text-transform: uppercase; color: var(--c-gold-dk);
}
.field__label--row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  min-width: 0;
}
#contactLabel { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.contact-toggle {
  display: inline-flex; border: 1px solid rgba(176,138,74,0.4);
  border-radius: 2px; overflow: hidden; flex: none;
}
.contact-toggle__btn {
  font-family: var(--ff-mono); font-size: 8.5px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--c-ink-soft);
  background: transparent; border: none; cursor: pointer;
  padding: 4px 9px; transition: background 0.25s, color 0.25s;
}
.contact-toggle__btn.is-active { background: var(--c-ink); color: var(--c-paper); }
.field input, .field textarea, .guest-names input {
  font-family: var(--ff-serif); font-size: 17px; color: var(--c-ink);
  min-width: 0; max-width: 100%;
  background: rgba(255,255,255,0.55);
  border: none; border-bottom: 1px solid rgba(176,138,74,0.5);
  padding: 10px 4px; width: 100%;
  transition: border-color 0.3s, background 0.3s;
}
.field textarea { resize: vertical; border: 1px solid rgba(176,138,74,0.4); padding: 10px; }
.field input::placeholder, .field textarea::placeholder, .guest-names input::placeholder { color: rgba(91,86,72,0.5); }
.field input:focus, .field textarea:focus, .guest-names input:focus {
  outline: none; border-color: var(--c-gold); background: rgba(255,255,255,0.85);
}
.field input.is-error, .guest-names input.is-error { border-color: #b1503e; background: rgba(177,80,62,0.06); }

.stepper { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.stepper__label { font-family: var(--ff-display); font-size: 22px; color: var(--c-ink); }
.stepper__control {
  display: flex; align-items: center; gap: 4px;
  border: 1px solid rgba(176,138,74,0.5); background: rgba(255,255,255,0.5);
}
.stepper__btn {
  width: 44px; height: 44px; border: none; background: transparent; cursor: pointer;
  font-size: 22px; color: var(--c-gold-dk); font-family: var(--ff-serif);
  display: grid; place-items: center; transition: background 0.25s, color 0.25s;
}
.stepper__btn:hover { background: var(--c-ink); color: var(--c-paper); }
.stepper__btn:disabled { opacity: 0.3; cursor: not-allowed; }
.stepper__btn:disabled:hover { background: transparent; color: var(--c-gold-dk); }
.stepper__value { width: 40px; text-align: center; font-family: var(--ff-mono); font-size: 16px; color: var(--c-ink); }
.stepper__hint { font-family: var(--ff-serif); font-style: italic; font-size: 14px; color: var(--c-ink-soft); margin-top: 10px; }

.guest-names { display: flex; flex-direction: column; gap: 18px; margin-top: 16px; }
.guest-names .field__label { color: var(--c-ink-soft); }
.guest-names__item { display: flex; flex-direction: column; gap: 10px; animation: guestIn 0.4s ease; }
.guest-names__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@keyframes guestIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }

.rsvp-form__actions { display: flex; justify-content: center; margin-top: 6px; }
.rsvp-form .rsvp__btn {
  color: var(--c-ink); border-color: var(--c-gold-dk); background: transparent;
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  min-width: 240px; min-height: 58px;
}
.rsvp-form .rsvp__btn:hover { color: var(--c-paper); background: var(--c-ink); border-color: var(--c-ink); }
.rsvp-form .rsvp__btn.is-loading { pointer-events: none; }
.rsvp-form .rsvp__btn.is-loading:hover { color: var(--c-ink); background: transparent; border-color: var(--c-gold-dk); letter-spacing: 0.5em; }
.btn__spinner {
  display: none; width: 16px; height: 16px;
  border: 2px solid rgba(138,106,54,0.3); border-top-color: var(--c-gold-dk);
  border-radius: 50%; animation: spin 0.7s linear infinite;
}
.rsvp__btn.is-loading .btn__label { opacity: 0.5; }
.rsvp__btn.is-loading .btn__spinner { display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }
.rsvp-form__note {
  font-family: var(--ff-serif); font-style: italic; font-size: 13px;
  color: var(--c-ink-soft); text-align: center; margin-top: -6px;
}
.rsvp-form [data-when].is-hidden { display: none; }

/* Loading overlay state */
.rsvp-loading { text-align: center; padding: 30px 0 10px; }
.rsvp-loading__spinner {
  width: 38px; height: 38px; margin: 0 auto 22px;
  border: 2px solid rgba(216,185,119,0.3); border-top-color: var(--c-gold-lt);
  border-radius: 50%; animation: spin 0.8s linear infinite;
}
.rsvp-loading__text {
  font-family: var(--ff-serif); font-style: italic; font-size: 18px;
  color: #fff; letter-spacing: 0.06em; text-shadow: 0 2px 16px rgba(0,0,0,0.4);
}

/* RECAP */
.recap {
  width: 100%;
  background: rgba(246, 239, 225, 0.98); color: var(--c-ink);
  border: 1px solid rgba(176,138,74,0.5);
  padding: 44px clamp(22px, 4vw, 48px);
  box-shadow: 0 30px 80px rgba(20,24,16,0.4);
  text-align: center;
}
.recap__check { width: 52px; height: 52px; margin: 0 auto 18px; }
.recap__check { stroke: var(--c-gold-dk); }
.recap__check circle, .recap__check path { stroke: var(--c-gold-dk); }
.recap__title { font-family: var(--ff-display); font-size: clamp(28px, 3.4vw, 42px); color: var(--c-ink); font-weight: 400; }
.recap__sub { font-family: var(--ff-serif); font-style: italic; font-size: 16px; color: var(--c-ink-soft); margin-top: 12px; line-height: 1.7; }
.recap__card {
  margin: 32px 0; padding: 30px 26px;
  border: 1px solid rgba(176,138,74,0.4);
  background: linear-gradient(to bottom, rgba(255,255,255,0.5), rgba(239,229,210,0.5));
  text-align: left;
}
.recap__brand {
  font-family: var(--ff-display); font-size: 26px; text-align: center;
  color: var(--c-ink); margin-bottom: 24px; letter-spacing: 0.02em;
}
.recap__brand span { color: var(--c-gold); font-style: italic; }
.recap__rows { display: flex; flex-direction: column; }
.recap__row {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
  padding: 12px 0; border-top: 1px solid rgba(176,138,74,0.22);
}
.recap__row span { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--c-gold-dk); white-space: nowrap; }
.recap__row b { font-family: var(--ff-serif); font-size: 16px; font-weight: 500; color: var(--c-ink); text-align: right; }
.recap__row--you b { color: var(--c-sage-dk); }
.recap__foot { font-family: var(--ff-serif); font-style: italic; font-size: 13px; color: var(--c-ink-soft); text-align: center; margin-top: 22px; }
.recap__actions { display: flex; flex-direction: column; gap: 16px; align-items: center; }
.recap .rsvp__btn { color: var(--c-ink); border-color: var(--c-gold-dk); background: transparent; }
.recap .rsvp__btn:hover { color: var(--c-paper); background: var(--c-ink); border-color: var(--c-ink); }
.recap__edit {
  font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--c-ink-soft); background: none; border: none; cursor: pointer;
  border-bottom: 1px solid transparent; padding: 4px 0; transition: color 0.3s, border-color 0.3s;
}
.recap__edit:hover { color: var(--c-ink); border-color: var(--c-gold); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 820px) {
  .chrome { padding: 16px 18px; }
  .chrome__monogram { font-size: 16px; }
  .chrome__meta { font-size: 8px; }

  .details__grid, .details__grid--2 { grid-template-columns: 1fr; }
  .detail-card { border-right: none; border-bottom: 1px solid rgba(176,138,74,0.3); }
  .detail-card:last-child { border-bottom: none; }

  .rsvp-form__choice { grid-template-columns: 1fr; }
  .rsvp-form__row { grid-template-columns: 1fr; }
  .guest-names__grid { grid-template-columns: 1fr; }

  .schedule__row { grid-template-columns: 84px 1fr; }
  .schedule__loc { grid-column: 1 / -1; padding-left: 84px; padding-top: 4px; }

  .rsvp__btn { padding: 18px 36px; letter-spacing: 0.4em; }
  .rsvp__btn:hover { letter-spacing: 0.45em; }
}

@media (prefers-reduced-motion: reduce) {
  .photo__media { animation: none; }
  * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
