:root {
  color-scheme: light;
  --ivory: #f7f3ec;
  --paper: #fffdf8;
  --forest: #24382f;
  --forest-soft: #385044;
  --sage: #879989;
  --gold: #b89762;
  --terracotta: #a7604a;
  --ink: #25302a;
  --muted: #6f756f;
  --line: rgba(36, 56, 47, 0.16);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Manrope', Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--ivory); color: var(--ink); font-family: var(--sans); font-weight: 400; overflow-x: hidden; }
body.invitation-locked { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
.film-grain { position: fixed; inset: 0; pointer-events: none; opacity: .035; z-index: 99; 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='.7'/%3E%3C/svg%3E"); }

/* Envelope opening */
.envelope-scene { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; overflow: hidden; background: radial-gradient(circle at 50% 40%, #f9f6ef 0, #eee5d9 65%, #e4d8c9 100%); }
.envelope-scene::before, .envelope-scene::after { content: ''; position: absolute; width: 42vw; height: 90vh; opacity: .18; background: url("data:image/svg+xml,%3Csvg viewBox='0 0 280 700' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%2324382f' stroke-width='2'%3E%3Cpath d='M41 693C48 539 110 406 176 289 218 214 244 113 232 14'/%3E%3Cpath d='M104 475C50 441 36 387 40 341 91 359 119 408 104 475Z'/%3E%3Cpath d='M153 336C126 273 143 222 174 184 207 229 194 294 153 336Z'/%3E%3Cpath d='M202 213C185 159 205 111 238 82 261 128 244 179 202 213Z'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat; }
.envelope-scene::before { left: -9vw; bottom: -20vh; transform: rotate(13deg); }
.envelope-scene::after { right: -9vw; top: -20vh; transform: scaleX(-1) rotate(13deg); }
.envelope-intro { position: relative; z-index: 1; width: min(92vw, 660px); text-align: center; animation: introIn 1.2s ease both; }
.mini-kicker { margin: 0 0 30px; color: var(--forest-soft); font-size: 10px; letter-spacing: .38em; text-transform: uppercase; }
.envelope { position: relative; width: min(78vw, 500px); aspect-ratio: 1.6; margin: 0 auto 34px; perspective: 1400px; transform-style: preserve-3d; }
.envelope-shadow { position: absolute; z-index: 0; left: 8%; right: 8%; bottom: -30px; height: 42px; border-radius: 50%; background: rgba(54,45,34,.2); filter: blur(18px); transform: scaleX(1); }
.envelope-back { position: absolute; inset: 0; border-radius: 3px; background: #d7c8b5; }
.envelope-letter { position: absolute; z-index: 2; left: 7%; right: 7%; top: 8%; height: 80%; display: grid; align-content: center; gap: 12px; background: #fffdf8; border: 1px solid #e4d9ca; box-shadow: 0 3px 12px rgba(54,45,34,.08); transform-origin: center; }
.envelope-letter::before { content: ''; position: absolute; inset: 9px; border: 1px solid #d4c3ab; }
.envelope-letter::after { content: 'SİZİ ARAMIZDA GÖRMEKTEN MUTLULUK DUYARIZ'; position: absolute; left: 0; right: 0; bottom: 25px; color: #8f8170; font: 500 6px var(--sans); letter-spacing: .22em; }
.envelope-letter span { font-size: 9px; letter-spacing: .35em; color: var(--gold); }
.envelope-letter strong { font: 500 43px/1 var(--serif); color: var(--forest); }
.envelope-letter i { color: var(--gold); font-weight: 400; }
.envelope-front { position: absolute; z-index: 3; inset: 0; overflow: hidden; border-radius: 3px; }
.envelope-front::before, .envelope-front::after { content: ''; position: absolute; inset: 0; }
.envelope-front::before { background: #eadfce; clip-path: polygon(0 0, 52% 53%, 0 100%); }
.envelope-front::after { background: #e1d3c0; clip-path: polygon(100% 0, 48% 53%, 100% 100%); }
.envelope-flap { position: absolute; z-index: 4; inset: 0; background: linear-gradient(165deg, #f5ecdf 0%, #eadfce 70%); clip-path: polygon(0 0, 100% 0, 50% 58%); transform-origin: 50% 0; backface-visibility: hidden; }
.wax-seal { position: absolute; z-index: 6; left: 50%; top: 54%; width: 78px; height: 78px; padding: 0; display: grid; place-items: center; transform: translate(-50%, -50%); border: 0; border-radius: 47% 53% 49% 51% / 53% 46% 54% 47%; color: #edcfb6; background: radial-gradient(circle at 33% 27%, #c37a5e 0, #a25741 38%, #843e30 72%, #6e3026 100%); box-shadow: 0 7px 13px rgba(67,31,22,.3), inset 2px 3px 5px rgba(255,255,255,.14), inset -3px -4px 5px rgba(67,24,18,.22); animation: sealBreathe 2.6s ease-in-out infinite; }
.wax-seal::before { content: ''; position: absolute; inset: 8px; border: 1px solid rgba(239,207,181,.58); border-radius: 50%; box-shadow: inset 0 0 0 2px rgba(81,31,23,.12); }
.wax-seal::after { content: ''; position: absolute; inset: -12px; border: 1px solid rgba(151,75,55,.23); border-radius: 50%; opacity: 0; animation: sealRing 2.6s ease-out infinite; }
.wax-seal span { position: relative; z-index: 2; font: 500 20px var(--serif); letter-spacing: .06em; text-shadow: 0 1px rgba(63,24,17,.4); }
.wax-seal i { position: absolute; z-index: 3; top: 8px; bottom: 8px; left: 50%; width: 1px; background: #59271f; opacity: 0; transform: rotate(-17deg) scaleY(0); transform-origin: top; }
.wax-seal:hover { filter: brightness(1.08); }
.wax-seal:focus-visible { outline: 2px solid var(--forest); outline-offset: 7px; }
.envelope-intro h1 { margin: 0 0 20px; font: 500 clamp(28px, 5vw, 42px)/1.1 var(--serif); color: var(--forest); }
.envelope-intro h1 em { color: var(--gold); font-weight: 400; }
.seal-hint { display: flex; align-items: center; justify-content: center; gap: 12px; margin: 0; color: var(--forest-soft); font-size: 9px; letter-spacing: .22em; text-transform: uppercase; animation: hintBreathe 2.6s ease-in-out infinite; }
.seal-hint span { width: 25px; height: 1px; background: var(--gold); }
.envelope-scene.opened { animation: sceneDepart 3.15s cubic-bezier(.4,0,.2,1) forwards; }
.envelope-scene.opened::before { animation: foliageLeft 3s ease-in forwards; }
.envelope-scene.opened::after { animation: foliageRight 3s ease-in forwards; }
.envelope-scene.opened .wax-seal { pointer-events: none; animation: sealBreak .65s cubic-bezier(.3,.8,.4,1) forwards; }
.envelope-scene.opened .wax-seal i { animation: crackAppear .2s ease-out .08s forwards; }
.envelope-scene.opened .envelope-flap { animation: flapOpen 1.05s cubic-bezier(.2,.72,.25,1) .52s forwards; }
.envelope-scene.opened .envelope-letter { animation: letterReveal 2s cubic-bezier(.22,.72,.2,1) 1.15s forwards; }
.envelope-scene.opened .envelope { animation: envelopeSettle 2.2s cubic-bezier(.2,.7,.25,1) .65s forwards; }
.envelope-scene.opened .envelope-shadow { animation: shadowDepart 2.2s ease .65s forwards; }
.envelope-scene.opened .mini-kicker, .envelope-scene.opened h1, .envelope-scene.opened .seal-hint { animation: copyFade .4s ease forwards; }
.envelope-scene.dismissed { opacity: 0; visibility: hidden; pointer-events: none; }
body.invitation-opening main { animation: pageArrive 1.2s cubic-bezier(.2,.7,.25,1) 2.15s both; }
body.invitation-opening .site-header { animation: headerArrive .7s ease 2.55s both; }

/* Navigation + hero */
.site-header { position: fixed; z-index: 50; top: 0; left: 0; right: 0; height: 78px; display: flex; align-items: center; justify-content: space-between; padding: 0 clamp(22px, 5vw, 76px); border-bottom: 1px solid transparent; transition: background .3s, height .3s, border .3s, transform .5s; }
.site-header.scrolled { height: 64px; background: rgba(247,243,236,.92); border-color: var(--line); backdrop-filter: blur(14px); }
.monogram { font: 600 24px var(--serif); letter-spacing: .04em; }
.monogram span { color: var(--gold); font-style: italic; }
nav { display: flex; gap: clamp(22px, 4vw, 54px); }
nav a, .nav-rsvp { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; }
nav a { position: relative; }
nav a::after { content: ''; position: absolute; left: 0; right: 100%; bottom: -6px; height: 1px; background: var(--gold); transition: right .25s; }
nav a:hover::after { right: 0; }
.nav-rsvp { padding: 10px 17px; border: 1px solid var(--forest); }
.hero { position: relative; min-height: 100svh; display: grid; place-items: center; overflow: hidden; padding: 110px 24px 72px; background: radial-gradient(circle at 50% 42%, #fffdf8 0, #f7f3ec 48%, #eee8de 100%); }
.hero-content { position: relative; z-index: 2; text-align: center; }
.eyebrow { margin: 0 0 18px; color: var(--terracotta); font-size: 10px; font-weight: 600; letter-spacing: .32em; text-transform: uppercase; }
.hero-script { margin: -6px 0; font: 500 clamp(60px, 9vw, 122px)/.85 var(--serif); letter-spacing: -.045em; color: var(--forest); }
.hero-ampersand { display: block; margin: -4px 0; font: italic 400 clamp(38px, 5vw, 66px)/1 var(--serif); color: var(--gold); }
.ornament { display: flex; align-items: center; justify-content: center; gap: 12px; margin: 30px auto 19px; color: var(--gold); }
.ornament span { width: 45px; height: 1px; background: var(--gold); }
.ornament i { font-size: 17px; font-style: normal; }
.hero-date { margin: 0 0 7px; font: 500 18px var(--serif); letter-spacing: .12em; text-transform: uppercase; }
.hero-place { margin: 0; color: var(--muted); font-size: 10px; letter-spacing: .25em; text-transform: uppercase; }
.hero-actions { display: flex; justify-content: center; gap: 11px; margin-top: 32px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 0 24px; border: 1px solid var(--forest); font-size: 10px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; transition: color .25s, background .25s, transform .25s; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: #fff; background: var(--forest); }
.button-primary:hover { background: var(--forest-soft); }
.button-ghost { background: rgba(255,255,255,.4); }
.button-ghost:hover { color: #fff; background: var(--forest); }
.botanical { position: absolute; z-index: 1; width: min(28vw, 330px); color: var(--sage); opacity: .5; }
.botanical svg { width: 100%; fill: rgba(135,153,137,.08); stroke: currentColor; stroke-width: 1.3; }
.botanical-left { left: -25px; bottom: -130px; transform: rotate(7deg); }
.botanical-right { right: -25px; top: -100px; transform: scaleX(-1) rotate(7deg); }
.scroll-cue { position: absolute; z-index: 4; bottom: 24px; left: 50%; display: grid; justify-items: center; gap: 7px; transform: translateX(-50%); color: var(--muted); font-size: 8px; letter-spacing: .26em; text-transform: uppercase; }
.scroll-cue span { width: 1px; height: 27px; background: var(--gold); animation: scrollLine 1.8s ease-in-out infinite; transform-origin: top; }

/* Shared sections */
.section { max-width: 1180px; margin: 0 auto; padding: 130px clamp(24px, 6vw, 80px); }
.section h2, .countdown-section h2 { margin: 0; font: 500 clamp(42px, 6vw, 72px)/.98 var(--serif); letter-spacing: -.03em; color: var(--forest); }
.section h2 em { color: var(--terracotta); font-weight: 400; }
.story { position: relative; display: grid; grid-template-columns: 80px 1.15fr .85fr; align-items: center; gap: 50px; min-height: 680px; }
.section-number { align-self: start; color: var(--gold); font: italic 24px var(--serif); }
.story-copy > p:not(.eyebrow,.signature) { max-width: 510px; margin: 28px 0 0; color: var(--muted); font: 300 14px/1.9 var(--sans); }
.signature { margin: 23px 0 0; color: var(--terracotta); font: italic 29px var(--serif); }
.story-quote { position: relative; margin: 0; padding: 60px 12px 60px 58px; border-left: 1px solid var(--gold); color: var(--forest-soft); font: italic 400 clamp(26px, 3vw, 39px)/1.3 var(--serif); }
.story-quote span { position: absolute; top: 6px; left: 48px; color: rgba(184,151,98,.28); font: 100px/1 var(--serif); }
.countdown-section { display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: 7vw; padding: 85px max(7vw, 24px); color: #f8f4ed; background: var(--forest); }
.countdown-section .eyebrow { color: #caa889; }
.countdown-section h2 { color: #fff; font-size: clamp(36px, 5vw, 62px); }
.countdown { display: flex; align-items: center; justify-content: space-between; }
.countdown div { min-width: 80px; text-align: center; }
.countdown span { display: block; font: 400 clamp(48px, 7vw, 86px)/1 var(--serif); }
.countdown small { display: block; margin-top: 8px; color: #aeb9b2; font-size: 8px; letter-spacing: .25em; text-transform: uppercase; }
.countdown > i { width: 3px; height: 3px; border-radius: 50%; background: var(--gold); }

/* Events and timeline */
.events .section-heading { display: flex; align-items: end; justify-content: space-between; margin-bottom: 66px; }
.event-grid { display: grid; grid-template-columns: 1fr 1.12fr; gap: 24px; align-items: center; }
.event-card { position: relative; min-height: 570px; padding: 52px clamp(30px, 5vw, 68px); text-align: center; border: 1px solid var(--line); background: rgba(255,253,248,.7); }
.event-card-featured { min-height: 630px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; background: var(--forest); }
.event-index { position: absolute; top: 25px; left: 29px; color: var(--gold); font: italic 15px var(--serif); }
.event-icon { height: 42px; margin-bottom: 22px; color: var(--gold); font: 42px/1 var(--serif); }
.rings { position: relative; width: 62px; }
.rings i { position: absolute; width: 36px; height: 36px; border: 1px solid var(--gold); border-radius: 50%; }
.rings i:first-child { left: 7px; }
.rings i:last-child { left: 25px; }
.event-type { margin: 0; color: var(--terracotta); font-size: 9px; font-weight: 600; letter-spacing: .26em; text-transform: uppercase; }
.event-card-featured .event-type { color: #d6b48e; }
.event-card h3 { margin: 10px 0 3px; font: 500 clamp(42px, 5vw, 62px)/1 var(--serif); }
.event-card-featured h3 { color: #fff; }
.event-year { margin: 0 0 36px; color: var(--muted); font: italic 17px var(--serif); }
.event-card-featured .event-year { color: #abb8b1; }
.event-meta { width: 100%; max-width: 280px; padding: 20px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.event-card-featured .event-meta { border-color: rgba(255,255,255,.15); }
.event-meta p { display: flex; justify-content: space-between; gap: 20px; margin: 9px 0; font-size: 11px; }
.event-meta span { color: var(--muted); font-size: 8px; letter-spacing: .15em; text-transform: uppercase; }
.event-card-featured .event-meta span { color: #9caaa2; }
.event-card-featured > a { margin-top: 31px; padding-bottom: 5px; border-bottom: 1px solid var(--gold); color: #d6b48e; font-size: 9px; letter-spacing: .18em; text-transform: uppercase; }
.event-card-featured > a span { margin-left: 8px; }
.schedule { display: grid; grid-template-columns: .9fr 1.1fr; gap: 10vw; align-items: center; padding-top: 90px; }
.schedule-intro > p:last-child { max-width: 420px; margin-top: 26px; color: var(--muted); font-size: 13px; line-height: 1.9; }
.timeline { position: relative; margin: 0; padding: 0; list-style: none; }
.timeline::before { content: ''; position: absolute; top: 27px; bottom: 27px; left: 112px; width: 1px; background: var(--line); }
.timeline li { position: relative; display: grid; grid-template-columns: 80px 15px 1fr; gap: 25px; align-items: center; min-height: 105px; }
.timeline time { font: italic 23px var(--serif); color: var(--terracotta); }
.timeline li > span { z-index: 1; width: 9px; height: 9px; margin-left: 3px; border: 2px solid var(--ivory); outline: 1px solid var(--gold); border-radius: 50%; background: var(--gold); }
.timeline strong { display: block; font: 500 27px var(--serif); }
.timeline small { color: var(--muted); font-size: 10px; letter-spacing: .07em; }

/* Forms */
.rsvp-section { max-width: none; display: grid; grid-template-columns: .85fr 1.15fr; gap: 8vw; padding-left: max(7vw,24px); padding-right: max(7vw,24px); color: #fff; background: #ebe3d8; }
.rsvp-aside { align-self: center; color: var(--ink); }
.rsvp-aside > p:nth-of-type(2) { max-width: 480px; margin: 27px 0; color: var(--muted); font-size: 13px; line-height: 1.85; }
.rsvp-note { display: flex; align-items: center; gap: 15px; margin-top: 40px; }
.rsvp-note > span { padding-right: 15px; border-right: 1px solid var(--gold); font: 500 55px/1 var(--serif); color: var(--terracotta); }
.rsvp-note div { font: 500 20px/1.1 var(--serif); text-transform: uppercase; }
.rsvp-note small { color: var(--muted); font: 8px var(--sans); letter-spacing: .15em; }
.paper-form { display: grid; gap: 24px; padding: clamp(35px, 5vw, 65px); color: var(--ink); background: var(--paper); box-shadow: 0 30px 70px rgba(65,52,37,.11); }
.form-heading { display: flex; align-items: center; gap: 18px; margin-bottom: 5px; font: 500 28px var(--serif); }
.form-heading i { flex: 1; height: 1px; background: var(--line); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
label { display: grid; gap: 9px; color: var(--forest-soft); font-size: 9px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
input, select, textarea { width: 100%; min-height: 46px; padding: 12px 0; border: 0; border-bottom: 1px solid var(--line); border-radius: 0; outline: none; color: var(--ink); background: transparent; font-size: 13px; letter-spacing: 0; text-transform: none; transition: border .2s; }
textarea { resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: var(--gold); }
::placeholder { color: #a4a6a2; }
.form-submit { width: 100%; justify-content: space-between; margin-top: 3px; border: 0; }
.form-submit b { font-size: 18px; font-weight: 300; }
.form-message { min-height: 18px; margin: -10px 0 0; color: var(--terracotta); font-size: 11px; font-weight: 600; text-transform: none; }
.form-message.success { color: #4d795c; }

/* Memories */
.memories { max-width: 1100px; }
.centered { max-width: 620px; margin: 0 auto 55px; text-align: center; }
.centered > p:last-child { margin: 23px auto 0; color: var(--muted); font-size: 13px; line-height: 1.8; }
.memory-uploader { margin-bottom: 60px; padding: 14px; border: 1px solid var(--line); background: rgba(255,255,255,.4); }
.memory-uploader form { display: grid; grid-template-columns: .85fr 1.15fr; min-height: 310px; }
.upload-drop { position: relative; display: grid; place-items: center; min-height: 310px; overflow: hidden; border: 1px dashed rgba(36,56,47,.28); background: #eee8de; cursor: pointer; }
.upload-drop.dragging { border-color: var(--terracotta); background: #e9dfd1; }
.upload-drop input { position: absolute; width: 1px; height: 1px; opacity: 0; }
.upload-copy { position: relative; z-index: 2; display: grid; justify-items: center; gap: 8px; text-align: center; }
.upload-icon { width: 44px; height: 44px; display: grid; place-items: center; margin-bottom: 4px; border: 1px solid var(--gold); border-radius: 50%; color: var(--gold); font-size: 22px; font-weight: 300; }
.upload-copy strong { color: var(--forest); font: 500 23px var(--serif); letter-spacing: 0; text-transform: none; }
.upload-copy small { color: var(--muted); font-size: 8px; letter-spacing: .08em; text-transform: none; }
.upload-preview { position: absolute; z-index: 1; inset: 0; display: none; grid-template-columns: repeat(3, 1fr); gap: 3px; padding: 3px; background: #d8d2c8; }
.upload-preview.has-files { display: grid; }
.upload-preview.has-files::after { content: ''; position: absolute; inset: 0; background: rgba(26,42,34,.5); pointer-events: none; }
.upload-preview.has-files + .upload-copy { color: #fff; }
.upload-preview.has-files + .upload-copy strong, .upload-preview.has-files + .upload-copy small { color: #fff; text-shadow: 0 1px 5px rgba(0,0,0,.3); }
.preview-tile { position: relative; min-width: 0; overflow: hidden; background: #c9c1b5; }
.preview-tile img, .preview-tile video { width: 100%; height: 100%; display: block; object-fit: cover; }
.preview-tile > b { height: 100%; display: grid; place-items: center; color: var(--forest); font: 600 15px var(--sans); }
.preview-tile > span { position: absolute; inset: 50% auto auto 50%; width: 28px; height: 28px; display: grid; place-items: center; transform: translate(-50%,-50%); border-radius: 50%; color: #fff; background: rgba(36,56,47,.78); font-size: 10px; }
.preview-tile > small { position: absolute; z-index: 1; right: 4px; bottom: 4px; left: 4px; overflow: hidden; color: #fff; font-size: 7px; text-overflow: ellipsis; text-shadow: 0 1px 3px #000; white-space: nowrap; }
.preview-more { display: grid; place-items: center; color: #fff; background: var(--forest-soft); font: 500 28px var(--serif); }
.memory-fields { display: grid; align-content: center; gap: 24px; padding: 40px clamp(28px, 5vw, 60px); background: var(--paper); }
.memory-fields .button { border: 0; justify-content: space-between; }
.memories-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.memory-empty { grid-column: 1/-1; padding: 40px; text-align: center; color: var(--muted); font: italic 20px var(--serif); border-top: 1px solid var(--line); }
.memory-card { position: relative; margin: 0; overflow: hidden; background: #e9e1d6; }
.memory-card:nth-child(3n+2) { transform: translateY(26px); }
.memory-card img, .memory-card > video { width: 100%; aspect-ratio: .82; display: block; object-fit: cover; transition: transform .7s; }
.memory-card > video { background: #111; }
.memory-card:hover img { transform: scale(1.035); }
.memory-card figcaption { position: absolute; inset: auto 0 0; padding: 50px 20px 18px; color: white; font: italic 18px var(--serif); background: linear-gradient(transparent, rgba(23,34,29,.82)); }
.memory-file-card { width: 100%; aspect-ratio: .82; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; padding: 25px; color: var(--forest); background: linear-gradient(145deg, #eee8de, #dcd2c4); text-align: center; }
.memory-file-card b { width: 70px; height: 82px; display: grid; place-items: center; border: 1px solid var(--gold); font-size: 11px; letter-spacing: .08em; }
.memory-file-card span { max-width: 100%; overflow: hidden; font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }
.memory-file-card audio { width: 100%; }
footer { padding: 90px 24px; text-align: center; color: #dfe5df; background: var(--forest); }
.footer-monogram { font: 500 52px var(--serif); }
.footer-monogram span { color: var(--gold); font-style: italic; }
footer p { margin: 15px 0 9px; color: #c3a67f; font-size: 10px; letter-spacing: .35em; }
footer small { color: #9ba9a0; font: italic 17px var(--serif); }
.back-to-top { position: fixed; z-index: 40; right: 22px; bottom: 22px; width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.25); color: #fff; background: var(--forest); opacity: 0; transform: translateY(15px); pointer-events: none; transition: .25s; }
.back-to-top.visible { opacity: 1; transform: none; pointer-events: auto; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .85s ease, transform .85s cubic-bezier(.2,.7,.3,1); }
.reveal.is-visible { opacity: 1; transform: none; }
@keyframes introIn { from { opacity: 0; transform: translateY(18px); } }
@keyframes scrollLine { 0%,100% { transform: scaleY(.3); opacity: .35; } 50% { transform: scaleY(1); opacity: 1; } }
@keyframes sealBreathe { 0%,100% { transform: translate(-50%,-50%) scale(1); } 50% { transform: translate(-50%,-50%) scale(1.045); } }
@keyframes sealRing { 0%,35% { opacity: 0; transform: scale(.82); } 55% { opacity: .65; } 90%,100% { opacity: 0; transform: scale(1.22); } }
@keyframes hintBreathe { 0%,100% { opacity: .55; } 50% { opacity: 1; } }
@keyframes crackAppear { to { opacity: .9; transform: rotate(-17deg) scaleY(1); } }
@keyframes sealBreak {
  0% { transform: translate(-50%,-50%) rotate(0) scale(1); opacity: 1; }
  28% { transform: translate(-50%,-50%) rotate(-5deg) scale(1.08); }
  55% { transform: translate(-50%,-50%) rotate(7deg) scale(.98); opacity: 1; }
  100% { transform: translate(-47%,-30%) rotate(20deg) scale(.35); opacity: 0; }
}
@keyframes flapOpen {
  0% { z-index: 4; transform: rotateX(0); }
  48% { z-index: 4; }
  49%,100% { z-index: 1; }
  100% { transform: rotateX(180deg); }
}
@keyframes letterReveal {
  0% { z-index: 2; transform: translateY(0) scale(1); }
  45% { z-index: 3; transform: translateY(-56%) scale(1); box-shadow: 0 18px 30px rgba(54,45,34,.14); }
  70% { z-index: 5; transform: translateY(-49%) scale(1.03); opacity: 1; }
  100% { z-index: 5; transform: translateY(-45%) scale(1.62); opacity: 0; }
}
@keyframes envelopeSettle { 0% { transform: translateY(0) scale(1); } 55% { transform: translateY(22px) scale(.98); } 100% { transform: translateY(105px) scale(.9); opacity: .35; } }
@keyframes shadowDepart { to { transform: scaleX(.65); opacity: .2; } }
@keyframes copyFade { to { opacity: 0; transform: translateY(8px); } }
@keyframes foliageLeft { to { opacity: 0; transform: translate(-80px, 50px) rotate(18deg); } }
@keyframes foliageRight { to { opacity: 0; transform: translate(80px, -50px) scaleX(-1) rotate(18deg); } }
@keyframes sceneDepart { 0%,78% { opacity: 1; } 100% { opacity: 0; visibility: hidden; } }
@keyframes pageArrive { from { opacity: 0; transform: scale(1.035); filter: blur(8px); } to { opacity: 1; transform: none; filter: none; } }
@keyframes headerArrive { from { opacity: 0; transform: translateY(-15px); } to { opacity: 1; transform: none; } }

@media (max-width: 820px) {
  nav { display: none; }
  .site-header { height: 64px; padding: 0 20px; }
  .hero-script { font-size: clamp(54px, 15vw, 82px); }
  .botanical { width: 45vw; opacity: .32; }
  .story { grid-template-columns: 32px 1fr; gap: 18px; }
  .story-quote { grid-column: 2; margin-top: 20px; }
  .countdown-section, .schedule, .rsvp-section { grid-template-columns: 1fr; }
  .countdown-section { gap: 48px; }
  .events .section-heading { display: block; }
  .event-grid { grid-template-columns: 1fr; }
  .event-card, .event-card-featured { min-height: 540px; }
  .schedule { gap: 45px; }
  .memory-uploader form { grid-template-columns: 1fr; }
  .memories-list { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 540px) {
  .envelope-intro { width: 94vw; }
  .envelope { width: 88vw; }
  .wax-seal { width: 58px; height: 58px; }
  .envelope-intro h1 { font-size: 27px; }
  .section { padding: 90px 22px; }
  .hero { padding-inline: 15px; }
  .hero-script { font-size: clamp(48px, 16vw, 69px); }
  .hero-actions { flex-direction: column; width: min(300px, 90vw); margin-inline: auto; }
  .story { grid-template-columns: 1fr; }
  .section-number { display: none; }
  .story-quote { grid-column: 1; padding-left: 26px; }
  .story-quote span { left: 20px; }
  .countdown-section { padding: 70px 22px; }
  .countdown span { font-size: 43px; }
  .countdown div { min-width: 55px; }
  .countdown > i { display: none; }
  .event-card, .event-card-featured { padding-inline: 26px; }
  .field-row { grid-template-columns: 1fr; }
  .paper-form { padding: 35px 24px; }
  .rsvp-section { padding-inline: 18px; }
  .timeline::before { left: 91px; }
  .timeline li { grid-template-columns: 65px 13px 1fr; gap: 15px; }
  .timeline time { font-size: 20px; }
  .timeline strong { font-size: 23px; }
  .memories-list { grid-template-columns: 1fr; }
  .memory-card:nth-child(3n+2) { transform: none; }
  .upload-drop { min-height: 260px; }
  footer { padding-block: 70px; }
}

@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; }
}
