:root {
  --ink: #34382f;
  --forest: #3f5038;
  --sage: #758069;
  --sage-soft: #dfe2d4;
  --olive: #626d43;
  --moss: #525f3d;
  --gold: #a98d5b;
  --antique-gold: #8f7649;
  --ivory: #fbf6eb;
  --paper: #f2eadb;
  --vellum: rgba(251, 247, 237, .66);
  --mist: #ddded2;
  --envelope-paper: #626d43;
  --envelope-fibers: url("data:image/svg+xml,%3Csvg viewBox='0 0 260 260' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='paper'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.62' numOctaves='3' seed='17' stitchTiles='stitch' result='grain'/%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.018 .12' numOctaves='4' seed='8' stitchTiles='stitch' result='fiber'/%3E%3CfeBlend in='grain' in2='fiber' mode='multiply'/%3E%3CfeColorMatrix values='.52 0 0 0 .16 0 .54 0 0 .17 0 0 .45 0 .11 0 0 0 .74 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23paper)'/%3E%3C/svg%3E");
  --serif: "Cormorant Garamond", Georgia, serif;
  --display: "Pinyon Script", "Parisienne", cursive;
  --script: "Parisienne", "Pinyon Script", cursive;
  --sans: "Cormorant Garamond", Georgia, serif;
}

* { box-sizing: border-box; }
html { width: 100%; overflow-x: hidden; scroll-behavior: smooth; }
body { width: 100%; min-width: 0; margin: 0; overflow-x: hidden; color: var(--ink); background: var(--ivory); font-family: var(--serif); font-size: 19px; line-height: 1.55; }
body.locked { overflow: hidden; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; }
img { max-width: 100%; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

.paper-grain { position: fixed; inset: 0; pointer-events: none; z-index: 100; opacity: .12; 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='.22'/%3E%3C/svg%3E"); mix-blend-mode: multiply; }
.eyebrow { margin: 0 0 16px; color: var(--antique-gold); font: 400 27px/1.05 var(--script); letter-spacing: .02em; text-transform: none; }

.opening { position: fixed; inset: 0; z-index: 90; display: grid; place-items: center; align-content: center; min-height: 100vh; min-height: 100svh; padding-inline: 16px; overflow: hidden; color: var(--ivory); background: var(--forest) url("assets/villa-del-balbianello-watercolor.jpg") center/cover no-repeat; transition: opacity .8s ease, visibility 0s linear .8s; }
.opening-shade { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(16,29,25,.54), rgba(16,29,25,.2) 50%, rgba(16,29,25,.65)); backdrop-filter: saturate(.72) brightness(.72); }
.opening.opened { opacity: 0; visibility: hidden; pointer-events: none; }
.opening-eyebrow, .opening-hint { position: absolute; left: 50%; z-index: 3; width: min(92vw, 820px); text-align: center; transform: translateX(-50%); }
.opening-eyebrow {
  top: max(76px, calc(env(safe-area-inset-top) + 48px));
  margin: 0;
  color: #f0d8a6;
  font: 400 clamp(32px, 4vw, 46px)/1.15 var(--display);
  letter-spacing: .025em;
  text-transform: none;
  text-shadow: 0 2px 12px rgba(12, 25, 19, .55);
  transition: opacity .35s ease, transform .35s ease, visibility 0s linear .35s;
}
.opening.envelope-opened .opening-eyebrow { opacity: 0; visibility: hidden; transform: translate(-50%, 10px); }
.opening-eyebrow[hidden] { display: none; }
.opening-hint { bottom: max(30px, env(safe-area-inset-bottom)); margin: 0; font-style: italic; opacity: .85; letter-spacing: .08em; }

.envelope-scene { position: relative; z-index: 2; width: min(62vw, 470px, 68vh); max-width: calc(100vw - 32px); perspective: 1500px; transform: translateY(2vh); }
.envelope { position: relative; width: 100%; aspect-ratio: .86; transform: rotateX(1.2deg) rotateZ(-.12deg); transform-style: preserve-3d; filter: drop-shadow(12px 24px 18px rgba(8,15,10,.42)) drop-shadow(0 4px 3px rgba(8,15,10,.28)); }
.envelope::before { content: ""; position: absolute; z-index: -2; left: 8%; right: 8%; bottom: -3%; height: 12%; border-radius: 50%; background: rgba(8,15,10,.48); filter: blur(18px); transform: rotateX(72deg); }
.envelope-back { position: absolute; z-index: 0; inset: 41% 0 0; overflow: hidden; border: 1px solid rgba(43,50,29,.76); border-radius: 2px 2px 4px 4px; background-color: var(--envelope-paper); background-image: radial-gradient(ellipse at 22% 9%, rgba(225,228,187,.12), transparent 36%), linear-gradient(118deg, rgba(255,255,255,.055), transparent 38%, rgba(31,38,22,.16)); box-shadow: 2px 5px 0 rgba(37,43,27,.36), inset 1px 2px rgba(220,220,179,.3), inset -2px -3px rgba(38,44,26,.22); }
.envelope-liner { position: absolute; z-index: 1; inset: 2% 3% 35%; opacity: 0; background-color: #e9e5d9; background-image: linear-gradient(rgba(248,244,235,.2), rgba(115,124,99,.08)), url("assets/villa-del-balbianello-watercolor.jpg"); background-position: center; background-size: cover; clip-path: polygon(50% 0, 100% 68%, 88% 100%, 12% 100%, 0 68%); filter: drop-shadow(0 4px 3px rgba(29,40,26,.28)); transition: opacity .25s ease .45s; }
.envelope-liner::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.2), transparent 45%, rgba(55,67,47,.12)); box-shadow: inset 0 0 0 3px rgba(248,243,233,.34); }
.letter-preview { position: absolute; z-index: 2; left: 11%; right: 11%; bottom: 11%; height: 48%; padding-top: 12%; opacity: 0; color: var(--ink); text-align: center; background-color: #f5eddf; background-image: radial-gradient(circle at 22% 15%, rgba(255,255,255,.75), transparent 35%), linear-gradient(115deg, rgba(166,137,91,.04), transparent 45%, rgba(115,85,48,.06)); box-shadow: 0 -9px 18px rgba(29,38,25,.28), inset 0 0 35px rgba(138,107,69,.08); transition: transform 1.15s cubic-bezier(.2,.75,.2,1), opacity .25s ease; }
.letter-preview::before { content: ""; position: absolute; inset: 12px; border: 1px solid rgba(179,146,85,.42); }
.letter-preview span, .letter-preview i { display: block; position: relative; font-size: clamp(10px, 1.5vw, 15px); }
.letter-preview strong { display: block; position: relative; margin: 7px 0; font: 400 clamp(28px, 5vw, 52px)/.95 var(--display); }
.envelope-pocket { position: absolute; z-index: 3; inset: 42% 0 0; overflow: hidden; border-radius: 3px 3px 7px 7px; filter: drop-shadow(0 -3px 3px rgba(31,42,28,.18)); }
.pocket-side, .pocket-front { position: absolute; inset: 0; background-color: var(--envelope-paper); background-image: radial-gradient(ellipse at 28% 18%, rgba(220,221,180,.09), transparent 43%), linear-gradient(145deg, rgba(255,255,255,.045), transparent 42%, rgba(35,44,25,.2)); }
.pocket-left { right: 42%; clip-path: polygon(0 0, 100% 54%, 100% 100%, 0 100%); filter: brightness(1.025) drop-shadow(2px 0 1px rgba(224,224,181,.2)); }
.pocket-right { left: 42%; clip-path: polygon(100% 0, 0 54%, 0 100%, 100% 100%); filter: brightness(.94) drop-shadow(-2px 0 2px rgba(31,39,23,.3)); }
.pocket-front { z-index: 2; clip-path: polygon(0 39%, 50% 7%, 100% 39%, 100% 100%, 0 100%); box-shadow: inset 0 1px rgba(205,204,164,.35), inset 0 -18px 30px rgba(31,40,23,.2); filter: drop-shadow(0 -1px 1px rgba(209,208,169,.42)) drop-shadow(0 -5px 4px rgba(28,36,21,.3)); }
.envelope-back::after, .pocket-side::after, .pocket-front::after, .flap-paper::after { content: ""; position: absolute; inset: 0; opacity: .68; background-image: var(--envelope-fibers); background-size: 260px 260px; mix-blend-mode: soft-light; pointer-events: none; }
.envelope-flap { position: absolute; z-index: 5; inset: 0 0 59%; transform: rotateX(180deg); transform-origin: 50% 100%; transform-style: preserve-3d; filter: drop-shadow(3px 7px 4px rgba(24,31,18,.48)); transition: transform .8s cubic-bezier(.4,0,.2,1), z-index 0s linear .4s; }
.flap-paper { position: absolute; inset: 0; overflow: hidden; clip-path: polygon(50% 2%, 55% 5%, 94% 70%, 98% 84%, 100% 100%, 0 100%, 2% 84%, 6% 70%, 45% 5%); backface-visibility: hidden; background-color: var(--envelope-paper); background-image: radial-gradient(ellipse at 30% 75%, rgba(221,222,181,.11), transparent 46%), linear-gradient(155deg, rgba(255,255,255,.07), transparent 38%, rgba(31,39,23,.18)); filter: drop-shadow(0 1px 0 rgba(215,214,171,.48)); }
.flap-front { transform: rotateX(180deg); }
.wax-seal { position: absolute; z-index: 6; left: 50%; top: 75%; width: 82px; height: 82px; padding: 0; transform: translate(-50%,-50%); border: 0; color: #4d351c; background: transparent url("assets/gold-wax-seal.png") center/contain no-repeat; filter: sepia(.08) saturate(.9) brightness(.94) drop-shadow(5px 8px 5px rgba(25,27,16,.5)) drop-shadow(-1px -1px 1px rgba(255,226,155,.25)); cursor: pointer; transition: transform .35s ease, opacity .5s ease; }
.wax-seal::after { display: none; }
.wax-seal:hover { transform: translate(-50%,-50%) scale(1.08) rotate(-3deg); }
.seal-monogram { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; padding-top: 1px; font-family: var(--script); text-shadow: 0 1px rgba(255,231,169,.5); }
.seal-monogram i { font-style: normal; font-size: 32px; line-height: 1; }
.seal-monogram i:first-child { transform: translateX(5px) translateY(-1px); }
.seal-monogram i:last-child { transform: translateX(-5px) translateY(2px); }
.seal-monogram b { z-index: 1; margin: 0 -1px; color: #684b26; font: italic 14px var(--serif); }
.envelope.open .envelope-flap { z-index: 1; transform: rotateX(0); }
.envelope.open .envelope-liner { opacity: 1; }
.envelope.open .wax-seal { opacity: 0; transform: translate(-50%,-80%) scale(.6); pointer-events: none; }
.envelope.open .letter-preview { opacity: 1; transform: translateY(-72%); transition-delay: .5s; }

.envelope-scene:has(.photo-envelope) { width: min(94vw, 900px, 68vh); }
.envelope.photo-envelope { aspect-ratio: 1148 / 1371; overflow: visible; background: transparent; box-shadow: none; filter: drop-shadow(10px 22px 16px rgba(8,15,10,.36)); transform: rotateZ(-.12deg); }
.envelope.photo-envelope.open { aspect-ratio: 1148 / 1371; }
.envelope.photo-envelope::before { display: none; }
.photo-envelope__image { position: absolute; inset: 0; width: 100%; height: 100%; max-width: none; object-fit: contain; user-select: none; transition: opacity .68s ease, transform 1.1s cubic-bezier(.2,.72,.2,1); }
.photo-envelope__closed { z-index: 1; inset: 18.6% 0 auto; height: 62.7%; opacity: 1; object-fit: cover; clip-path: inset(17.4% 9.1% 7.4% 9.1% round .4%); transform: scale(1.12); }
.photo-envelope__open { z-index: 2; opacity: 0; transform: scale(.94) translateY(2%); }
.photo-envelope__empty, .photo-envelope__foreground { opacity: 0; }
.photo-envelope__peek { z-index: 3; }
.photo-envelope.open .photo-envelope__closed { opacity: 0; transform: scale(1.025); }
.photo-envelope.open .photo-envelope__open { opacity: 1; transform: scale(1) translateY(0); }
.photo-envelope.open .photo-envelope__empty { opacity: 0; }
.photo-envelope.open .photo-envelope__foreground { opacity: 0; }
.photo-envelope.letter-out .photo-envelope__empty { opacity: 1; }
.photo-envelope.letter-out .photo-envelope__peek { opacity: 0; }
.photo-envelope.letter-out .photo-envelope__foreground { opacity: 1; }
.envelope-scene:has(.photo-envelope.open) { transform: translateY(-4vh); }
.photo-envelope__letter { position: absolute; z-index: 4; left: 20%; right: 20%; top: 30%; height: 42%; padding: 11% 8% 5%; border: 0; opacity: 0; color: var(--ink); text-align: center; background-color: #f8f0e0; background-image: radial-gradient(circle at 22% 15%, rgba(255,255,255,.82), transparent 35%), linear-gradient(115deg, rgba(166,137,91,.06), transparent 45%, rgba(82,95,61,.08)); box-shadow: 0 -9px 18px rgba(29,38,25,.28), inset 0 0 35px rgba(138,107,69,.1); transform: translateY(24%); transition: transform 1.18s cubic-bezier(.18,.78,.2,1), opacity .18s ease, box-shadow .25s ease; }
.photo-envelope__letter::before { content: ""; position: absolute; inset: 12px; border: 1px solid rgba(143,118,73,.42); }
.photo-envelope__letter::after { content: "❧"; position: absolute; left: 50%; bottom: 9%; color: rgba(98,109,67,.48); font-size: clamp(13px, 1.6vw, 20px); transform: translateX(-50%); }
.photo-envelope__letter span, .photo-envelope__letter i { display: block; position: relative; font-size: clamp(9px, 1.35vw, 14px); letter-spacing: .09em; text-transform: uppercase; }
.photo-envelope__letter strong { display: block; position: relative; margin: 8px 0 9px; color: var(--moss); font: 400 clamp(28px, 4.4vw, 50px)/.9 var(--display); }
.photo-envelope__letter i { font-style: italic; }
.photo-envelope__letter:disabled { cursor: default; }
.photo-envelope__letter:focus-visible { outline: 2px solid rgba(246,221,160,.95); outline-offset: 6px; }
.photo-envelope.open .photo-envelope__letter { cursor: pointer; }
.photo-envelope.letter-out .photo-envelope__letter { opacity: 1; transform: translateY(-40%); }
.photo-envelope.letter-out .photo-envelope__letter:not(:disabled):hover { box-shadow: 0 -9px 18px rgba(29,38,25,.28), 0 0 0 2px rgba(246,221,160,.75), inset 0 0 35px rgba(138,107,69,.09); }
.photo-envelope__foreground { z-index: 5; clip-path: polygon(1.2% 43.5%, 27% 62.3%, 50% 68.4%, 73% 62.3%, 98.8% 43.5%, 98.8% 99.2%, 1.2% 99.2%); }
.photo-envelope__seal { position: absolute; z-index: 6; left: 50%; top: 55%; width: 18%; aspect-ratio: 1; padding: 0; transform: translate(-50%,-50%); border: 0; border-radius: 50%; background: transparent; cursor: pointer; transition: opacity .25s ease; }
.photo-envelope__seal::after { display: none; }
.photo-envelope__seal:focus-visible { outline: none; }
.photo-envelope.open .photo-envelope__seal { opacity: 0; pointer-events: none; }


.invitation { display: none; background: var(--ivory); }
.invitation.visible { display: block; animation: revealInvitation 1s both; }
@keyframes revealInvitation { from { opacity: 0; } to { opacity: 1; } }
.nav { position: fixed; z-index: 30; top: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: space-between; height: 76px; padding: 0 5vw; color: var(--ivory); transition: color .4s, background .4s, box-shadow .4s; }
.nav.scrolled { color: var(--ink); background: rgba(248,242,230,.91); box-shadow: 0 1px 0 rgba(39,55,47,.09); backdrop-filter: blur(10px); }
.monogram { text-decoration: none; font: 400 34px/.9 var(--display); }
.monogram span { margin: 0 3px; font: italic 20px var(--serif); }
.nav-links { display: flex; gap: 32px; }
.nav-links a { position: relative; text-decoration: none; font: 600 13px var(--sans); letter-spacing: .12em; text-transform: uppercase; }
.nav-links a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 1px; background: currentColor; transition: right .3s; }
.nav-links a:hover::after { right: 0; }

.hero { position: relative; display: grid; place-items: center; min-height: 100vh; min-height: 100svh; padding-inline: 14px; overflow: hidden; color: var(--ivory); text-align: center; background: var(--forest) url("assets/villa-del-balbianello-watercolor.jpg") center/cover no-repeat fixed; }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31,43,31,.23), rgba(31,43,31,.12) 42%, rgba(31,43,31,.42)); }
.hero::after { content: ""; position: absolute; inset: 0; opacity: .28; background: radial-gradient(circle at 18% 18%, rgba(251,246,235,.52), transparent 24%), radial-gradient(circle at 78% 70%, rgba(226,229,216,.42), transparent 28%); pointer-events: none; }
.hero-glow { position: absolute; width: 60vw; height: 60vw; border-radius: 50%; background: rgba(245,232,198,.18); filter: blur(80px); }
.hero-copy {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: min(90vw, 560px);
  min-height: min(84vh, 790px);
  margin: 100px 0 54px;
  padding: clamp(70px, 8vw, 104px) clamp(42px, 6vw, 76px);
  color: var(--ink);
  background: #fbf4e5;
  background-image:
    radial-gradient(circle at 50% 12%, rgba(255,255,255,.82), transparent 34%),
    linear-gradient(120deg, rgba(255,255,255,.5), transparent 38%, rgba(98,109,67,.07)),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='p'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23p)' opacity='.18'/%3E%3C/svg%3E");
  box-shadow: 0 30px 85px rgba(25,39,31,.3), inset 0 0 38px rgba(143,118,73,.08);
}
.hero-copy::before {
  content: "";
  position: absolute;
  inset: 16px;
  border: 1px solid rgba(143,118,73,.32);
  box-shadow: inset 0 0 0 9px rgba(251,246,235,.28);
  pointer-events: none;
}
.hero-copy::after { display: none; }
.hero-ornament {
  position: absolute;
  z-index: 0;
  top: clamp(12px, 1.5vw, 18px);
  bottom: clamp(12px, 1.5vw, 18px);
  left: 50%;
  width: auto;
  height: calc(100% - clamp(24px, 3vw, 36px));
  max-width: calc(100% + clamp(6px, 1.2vw, 14px));
  transform: translateX(-50%);
  object-fit: contain;
  opacity: .47;
  mix-blend-mode: multiply;
  pointer-events: none;
}
.hero-card-content { position: relative; z-index: 1; width: min(100%, 290px); padding: 102px 0 132px; transform: translateY(-4px); }
.invitation-kicker {
  margin: 0 0 13px;
  color: var(--moss);
  font: 400 clamp(21px, 2.25vw, 28px)/1.05 var(--display);
  letter-spacing: .02em;
  text-transform: none;
}
.invitation-title {
  margin: 0 0 30px;
  color: var(--moss);
  font: 400 clamp(16px, 1.65vw, 21px)/1 var(--display);
  letter-spacing: .03em;
  text-transform: none;
}
.invitation-title::after {
  content: "";
  display: block;
  width: 58px;
  height: 1px;
  background: rgba(82,95,61,.42);
}
.invitation-title::after { margin: 13px auto 0; }
.hero h1 {
  margin: 0 0 30px;
  color: var(--moss);
  font: 400 clamp(41px, 4.35vw, 54px)/.9 var(--display);
  letter-spacing: 0;
  text-transform: none;
  text-shadow: none;
  white-space: nowrap;
}
.hero h1 span {
  display: inline;
  margin: 0 7px;
  color: var(--antique-gold);
  font-family: Georgia, "Times New Roman", serif;
  font-size: .52em;
  font-style: normal;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0;
  text-transform: none;
}
.couple-lockup { margin: 24px 0 0; color: var(--forest); font: 400 clamp(46px, 5.8vw, 74px)/.92 var(--display); }
.couple-lockup span { color: var(--gold); font: italic .68em var(--serif); }
.invitation-line {
  max-width: 210px;
  margin: 15px auto 12px;
  color: #3c4036;
  font: 400 clamp(16px, 1.65vw, 19px)/1.16 var(--script);
  letter-spacing: .01em;
}
.date-simple {
  width: fit-content;
  margin: 0 auto 18px;
  padding: 4px 30px 6px;
  border-top: 1px solid rgba(82,95,61,.38);
  border-bottom: 1px solid rgba(82,95,61,.38);
  color: var(--moss);
  font: 400 clamp(15px, 1.45vw, 19px)/1 var(--display);
  letter-spacing: .02em;
}
.venue { margin: 0 auto; max-width: 230px; font: 400 clamp(14px, 1.4vw, 18px)/1.08 var(--display); letter-spacing: .01em; }
.venue br { display: block; }
.text-link { font: 600 9px var(--sans); letter-spacing: .12em; text-transform: uppercase; text-underline-offset: 6px; }
.hero-scroll-link { position: absolute; z-index: 2; left: 50%; bottom: -42px; transform: translateX(-50%); width: max-content; color: var(--ivory); text-shadow: 0 1px 8px rgba(18,30,24,.55); }
.text-link span { display: inline-block; margin-left: 7px; animation: bob 1.8s ease-in-out infinite; }
@keyframes bob { 50% { transform: translateY(5px); } }

.section { padding: 130px max(6vw, 24px); }
.section-heading { max-width: 620px; }
.section-heading.centered { margin: 0 auto 65px; text-align: center; }
.section-heading h2 { margin: 0; font: 400 clamp(64px, 8vw, 108px)/.88 var(--display); }
.story { background: linear-gradient(135deg, #fbf6eb, #ede6d7 58%, #e5e8dc); }
.story .section-heading { max-width: none; }
.story .section-heading h2 { white-space: nowrap; font-size: 68px; line-height: .9; }
.story-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 80px; background: transparent; }
.story-card { position: relative; min-height: 350px; padding: 58px 38px; background: rgba(251,246,235,.82); border: 1px solid rgba(143,118,73,.2); box-shadow: 0 18px 45px rgba(50,64,46,.08); }
.story-card::before { content: ""; position: absolute; inset: 12px; border: 1px solid rgba(98,109,67,.14); pointer-events: none; }
.story-card:nth-child(2) { background: rgba(223,226,212,.86); }
.chapter { position: absolute; top: 30px; right: 30px; color: rgba(82,95,61,.16); font: 400 72px/.8 var(--display); }
.story-photo {
  position: relative;
  z-index: 1;
  margin: 0 0 34px;
  padding: 8px;
  background: rgba(251,246,235,.72);
  border: 1px solid rgba(143,118,73,.18);
  box-shadow: 0 12px 28px rgba(50,64,46,.11);
}
.story-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: contain;
  object-position: center;
  background: rgba(251,246,235,.42);
}
.story-year { color: var(--antique-gold); font: 600 13px var(--sans); letter-spacing: .18em; }
.story-card h3 { margin: 62px 0 16px; font: 400 43px/.9 var(--display); }
.story-photo + .story-year + h3 { margin-top: 34px; }
.story-card p:last-child { line-height: 1.65; }

.details { position: relative; overflow: hidden; background: #e2e5d8; background-image: linear-gradient(180deg, rgba(251,246,235,.5), rgba(226,229,216,.9)); }
.details .section-heading { max-width: none; }
.details .section-heading h2 { white-space: nowrap; }
.details::before, .details::after { content: "❧"; position: absolute; color: rgba(82,95,61,.12); font-size: 220px; }
.details::before { top: 20px; left: -40px; transform: rotate(35deg); }
.details::after { right: -30px; bottom: 20px; transform: rotate(210deg); }
.venue-watercolor { position: relative; z-index: 1; display: grid; grid-template-columns: 1.35fr .65fr; max-width: 980px; margin: 0 auto 100px; padding: 13px; background: var(--ivory); border: 1px solid rgba(143,118,73,.22); box-shadow: 0 20px 60px rgba(50,64,46,.16); }
.venue-watercolor img { display: block; width: 100%; height: 430px; object-fit: cover; }
.venue-watercolor figcaption { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 35px; color: var(--antique-gold); text-align: center; font: 600 15px/1.7 var(--sans); letter-spacing: .09em; text-transform: uppercase; }
.venue-watercolor figcaption span { margin-bottom: 22px; color: var(--moss); font: 400 54px/.9 var(--display); letter-spacing: 0; text-transform: none; }
.timeline { position: relative; max-width: 860px; margin: 0 auto 90px; }
.timeline::before { content: ""; position: absolute; top: 16px; bottom: 16px; left: 172px; width: 1px; background: rgba(39,55,47,.24); }
.timeline-item { display: grid; grid-template-columns: 142px 60px 1fr; align-items: center; margin: 44px 0; }
.timeline-item time { text-align: right; color: var(--ink); font: 400 31px/.9 var(--display); letter-spacing: 0; text-transform: none; white-space: nowrap; }
.timeline-flower { z-index: 1; display: grid; place-items: center; width: 30px; height: 30px; margin: auto; border-radius: 50%; color: var(--ivory); background: var(--moss); font-size: 11px; box-shadow: 0 0 0 6px rgba(251,246,235,.55); }
.timeline-item h3 { margin: 0 0 5px; font: 400 38px/.9 var(--display); }
.timeline-item p { margin: 0; }
.detail-cards { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 1100px; margin: 0 auto; }
.detail-card { position: relative; padding: 48px 34px; text-align: center; background: rgba(251,246,235,.76); border: 1px solid rgba(143,118,73,.2); box-shadow: 0 16px 38px rgba(50,64,46,.08); }
.detail-card::before { content: ""; position: absolute; inset: 12px; border: 1px solid rgba(98,109,67,.13); pointer-events: none; }
.card-icon { display: block; height: 52px; color: var(--moss); font-size: 39px; }
.detail-card h3 { margin: 7px 0 18px; font: 400 41px/.9 var(--display); }
.detail-card p:not(.eyebrow) { min-height: 57px; line-height: 1.5; }
.detail-card a { color: var(--moss); font: 600 13px var(--sans); letter-spacing: .1em; text-transform: uppercase; text-underline-offset: 5px; }

.rsvp {
  position: relative;
  min-height: 100vh;
  padding-top: 140px;
  background: var(--forest) url("assets/villa-del-balbianello-watercolor.jpg") center/cover fixed;
}
.rsvp::before {
  display: none;
}
.rsvp-shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: .8fr 1.2fr;
  max-width: 1120px;
  margin: 0 auto;
  padding: 0;
  border: 1px solid rgba(216,198,156,.25);
  box-shadow: 0 30px 80px rgba(15,28,24,.35);
}
.rsvp-intro {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 86px 52px 64px;
  color: var(--ivory);
  background: rgba(98,109,67,.82);
  background-image: linear-gradient(145deg, rgba(255,255,255,.06), transparent 45%, rgba(24,36,25,.18));
}
.rsvp-intro .eyebrow {
  margin: 0 0 10px;
  color: var(--ivory);
  font: 400 clamp(42px, 5vw, 68px)/.92 var(--display);
}
.rsvp-intro h2 {
  margin: 0 0 30px 26px;
  font: 400 clamp(62px, 7.2vw, 98px)/.88 var(--display);
}
.rsvp-intro > p:not(.eyebrow) { line-height: 1.7; }
.rsvp-note {
  display: flex;
  gap: 15px;
  margin-top: auto;
  padding-top: 25px;
  border-top: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.7);
  font-size: 14px;
  line-height: 1.5;
}
.rsvp-note span { color: #e5cf9e; }
.rsvp-note p { margin: 0; }
.rsvp-form {
  min-height: 650px;
  max-width: none;
  margin: 0;
  padding: 65px 60px;
  background: var(--paper);
  background-image:
    radial-gradient(circle at 18% 8%, rgba(255,255,255,.62), transparent 38%),
    linear-gradient(135deg, rgba(98,109,67,.05), transparent 44%, rgba(143,118,73,.05));
}
.form-fields { display: block; animation: stepIn .45s ease both; }
.form-fields[hidden] { display: none; }
@keyframes stepIn { from { opacity: 0; transform: translateX(12px); } }
.step-count { margin: 0; color: var(--antique-gold); font: 600 13px var(--sans); letter-spacing: .14em; text-transform: uppercase; }
fieldset { min-width: 0; padding: 0; border: 0; }
.form-fields fieldset + fieldset { margin-top: 42px; }
legend {
  width: 100%;
  max-width: 620px;
  margin: 28px 0 24px;
  color: var(--forest);
  font: 500 clamp(25px, 2.8vw, 36px)/1.18 var(--serif);
  letter-spacing: .01em;
  text-wrap: balance;
}
.field-label { display: block; margin: 23px 0 8px; color: var(--ink); font: 600 13px var(--sans); letter-spacing: .1em; text-transform: uppercase; }
input[type="text"], input[type="email"], select, textarea {
  width: 100%;
  border: 0;
  border-bottom: 1px solid rgba(39,55,47,.35);
  border-radius: 0;
  outline: 0;
  color: var(--ink);
  background: transparent;
  font: 400 19px/1.4 var(--serif);
  box-shadow: none;
  transition: border .2s, background .25s ease;
}
input[type="text"], input[type="email"], select { height: 46px; padding: 0; }
textarea { min-height: 120px; padding: 10px 0; resize: vertical; }
input:focus, select:focus, textarea:focus {
  border-color: var(--moss);
  background: rgba(251,246,235,.28);
  box-shadow: none;
}
.travel-intention { margin: 0; }
.travel-intention legend {
  margin-bottom: 22px;
}
.intention-options { display: grid; grid-template-columns: 1fr; gap: 12px; margin: 0 0 10px; }
.choice-pill { position: relative; cursor: pointer; }
.choice-pill input { position: absolute; opacity: 0; }
.choice-pill span {
  display: block;
  min-height: 78px;
  padding: 25px 26px;
  border: 1px solid rgba(39,55,47,.22);
  color: var(--ink);
  background: rgba(251,246,235,.28);
  box-shadow: none;
  transition: border-color .25s ease, background .25s ease, box-shadow .25s ease, transform .25s ease;
}
.choice-pill:hover span {
  transform: translateY(-1px);
  border-color: rgba(82,95,61,.4);
  background: rgba(251,246,235,.52);
}
.choice-pill input:focus-visible + span { outline: 2px solid rgba(169,141,91,.5); outline-offset: 3px; }
.choice-pill input:checked + span {
  border-color: var(--moss);
  color: var(--forest);
  background: rgba(98,109,67,.1);
  box-shadow: inset 0 0 0 1px var(--moss);
}
.button {
  min-width: 170px;
  height: 49px;
  margin-top: 30px;
  padding: 0 25px;
  border: 1px solid var(--forest);
  border-radius: 0;
  color: var(--ivory);
  background: var(--forest);
  font: 600 13px var(--sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: none;
  transition: transform .18s ease, background .25s ease, color .25s ease;
}
.button:hover {
  color: var(--forest);
  background: transparent;
}
.button:active { transform: scale(.97); }
.form-success { display: none; padding: 24px 0 6px; text-align: center; }
.form-success.active { display: block; animation: stepIn .5s ease both; }
.success-mark { display: grid; place-items: center; width: 68px; height: 68px; margin: 0 auto 32px; border: 1px solid var(--moss); border-radius: 50%; color: var(--moss); font-size: 25px; }
.form-success h3 { margin: 8px 0 20px; font: 400 64px/.9 var(--display); }
.form-success p:not(.eyebrow) { line-height: 1.6; }
.text-button { margin-top: 30px; padding: 10px 0; border: 0; border-bottom: 1px solid currentColor; color: var(--moss); background: transparent; font: 600 13px var(--sans); letter-spacing: .1em; text-transform: uppercase; cursor: pointer; }

.faq {
  background: linear-gradient(180deg, #fbf6eb, #ece6d8 52%, #dfe2d4);
}
.faq-shell { max-width: 880px; margin: 0 auto; }
.faq .section-heading { margin-bottom: 52px; }
.faq-group { margin-top: 44px; }
.faq-group h3 {
  margin: 0 0 18px;
  color: var(--antique-gold);
  font: 400 33px/.95 var(--display);
}
.faq-item {
  border-top: 1px solid rgba(98,109,67,.18);
}
.faq-item:last-child { border-bottom: 1px solid rgba(98,109,67,.18); }
.faq-question {
  position: relative;
  width: 100%;
  min-height: 76px;
  padding: 22px 48px 22px 0;
  border: 0;
  color: var(--forest);
  background: transparent;
  text-align: left;
  font: 400 clamp(21px, 2.35vw, 29px)/1.2 var(--script);
  letter-spacing: .01em;
  cursor: pointer;
}
.faq-question::after {
  content: "+";
  position: absolute;
  top: 50%;
  right: 8px;
  color: rgba(82,95,61,.68);
  font: 400 30px/1 var(--serif);
  transform: translateY(-50%) rotate(0);
  transition: transform .45s ease, opacity .45s ease;
}
.faq-item.open .faq-question::after { transform: translateY(-50%) rotate(45deg); opacity: .7; }
.faq-answer {
  display: grid;
  grid-template-rows: 0fr;
  color: #596245;
  transition: grid-template-rows .58s cubic-bezier(.22,.7,.2,1);
}
.faq-answer > p {
  overflow: hidden;
  margin: 0;
  padding: 0 44px 0 0;
  line-height: 1.75;
  transition: padding .58s cubic-bezier(.22,.7,.2,1), opacity .45s ease;
  opacity: 0;
}
.faq-item.open .faq-answer { grid-template-rows: 1fr; }
.faq-item.open .faq-answer > p { padding-bottom: 28px; opacity: 1; }

footer { padding: 85px 24px; color: var(--ivory); background: #15251f; text-align: center; }
.footer-monogram { margin: 0 0 18px; color: #e5cf9e; font: 400 56px/.9 var(--display); }
.footer-monogram span { font: italic 26px var(--serif); }
footer > p:nth-child(2) { font-style: italic; }
footer a { display: inline-block; margin-top: 22px; font: 600 12px var(--sans); letter-spacing: .12em; text-transform: uppercase; text-underline-offset: 6px; }
.photo-credit { margin: 34px auto 0; max-width: 700px; color: rgba(248,242,230,.55); font: 400 11px/1.6 var(--sans); letter-spacing: .04em; }
.photo-credit a { margin: 0; font: inherit; letter-spacing: inherit; text-transform: none; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s ease, transform .9s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }

@media (max-width: 820px) {
  .story-grid, .detail-cards, .rsvp-shell { grid-template-columns: 1fr; }
  .venue-watercolor { grid-template-columns: 1fr; }
  .venue-watercolor img { height: 360px; }
  .venue-watercolor figcaption { padding: 32px 20px; }
  .story-card { min-height: 285px; }
  .story-card h3 { margin-top: 35px; }
  .story .section-heading h2 { font-size: 48px; }
  .details .section-heading h2 { font-size: 78px; }
  .rsvp-intro { padding: 55px 34px; }
  .rsvp-note { margin-top: 38px; }
  .rsvp-form { min-height: auto; padding: 50px 34px; }
  .hero, .rsvp { background-attachment: scroll; }
}

@media (max-width: 560px) {
  body { font-size: 16px; }
  .nav { height: 64px; padding: 0 20px; }
  .nav-links { gap: 16px; }
  .nav-links a:first-child { display: none; }
  .envelope-scene { width: 88vw; }
  .wax-seal { width: 82px; height: 82px; }
  .seal-monogram i { font-size: 26px; }
  .hero-copy { width: calc(100vw - 28px); min-height: 720px; margin-top: 78px; padding: 70px 34px 54px; }
  .hero-copy::before { inset: 12px; }
  .hero-copy::after { display: none; }
  .hero-ornament { top: 16px; bottom: 16px; left: 50%; width: auto; height: calc(100% - 32px); max-width: calc(100% + 10px); transform: translateX(-50%); opacity: .78; }
  .hero-card-content { width: min(100%, 245px); padding-top: 88px; padding-bottom: 88px; }
  .invitation-kicker { margin-bottom: 12px; font-size: 20px; letter-spacing: .01em; }
  .invitation-title { margin-bottom: 22px; font-size: 16px; letter-spacing: .02em; }
  .invitation-title::after { margin-top: 12px; }
  .hero h1 { margin-bottom: 24px; font-size: clamp(29px, 7.8vw, 35px); letter-spacing: 0; }
  .hero h1 span { margin: 0 5px; font-size: .52em; }
  .couple-lockup { font-size: clamp(31px, 10vw, 44px); }
  .invitation-line { overflow-wrap: anywhere; }
  .date-simple { padding-inline: 16px; font-size: 16px; letter-spacing: .02em; }
  .section { padding: 90px 20px; }
  .story .section-heading h2 { font-size: 30px; }
  .details .section-heading h2 { font-size: 43px; }
  .story-grid { margin-top: 50px; }
  .story-card { padding: 42px 28px; }
  .timeline::before { left: 114px; }
  .timeline-item { grid-template-columns: 96px 46px 1fr; }
  .timeline-item time { font-size: 22px; }
  .detail-card { padding: 40px 28px; }
  .venue-watercolor { margin-bottom: 70px; padding: 9px; }
  .venue-watercolor img { height: 270px; }
  .rsvp { padding: 65px 10px; }
  .rsvp-intro, .rsvp-form { padding: 44px 25px; }
  .rsvp-intro h2, .faq .section-heading h2 { font-size: 58px; }
  legend { font-size: 27px; line-height: 1.2; }
  .choice-pill span { min-height: auto; }
  .button { min-width: 150px; padding: 0 16px; }
  .faq-question { min-height: 68px; padding-right: 36px; }
  .faq-answer > p { padding-right: 0; }
}

@media (max-width: 400px) {
  .nav-links a:nth-child(2) { display: none; }
  .postage-stamps img { width: 39px; height: 44px; }
  .hero-copy { min-height: 680px; padding-inline: 26px; }
  .hero-card-content { width: min(100%, 218px); }
  .hero h1 { font-size: clamp(27px, 7.2vw, 30px); }
  .story .section-heading h2 { font-size: 23px; }
  .details .section-heading h2 { font-size: 34px; }
  .couple-lockup { font-size: clamp(29px, 9vw, 38px); }
  .invitation-line { font-size: 15px; }
  .venue { font-size: 12px; }
  .timeline-item { grid-template-columns: 84px 40px minmax(0, 1fr); }
  .timeline::before { left: 104px; }
  .button { width: 100%; }
}

@media (max-width: 360px) {
  .story .section-heading h2 { font-size: 20px; }
  .details .section-heading h2 { font-size: 30px; }
}

@media (max-height: 680px) {
  .opening-eyebrow { top: max(56px, calc(env(safe-area-inset-top) + 34px)); }
  .envelope-scene { width: min(62vw, 440px, 58vh); transform: translateY(1vh); }
  .envelope-scene:has(.photo-envelope.open) { transform: translateY(-3vh); }
  .hero-copy { min-height: 620px; margin-top: 82px; padding-top: 54px; padding-bottom: 46px; }
  .hero-card-content { transform: scale(.92); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
