html,body,#root{height:100%;width:100%;margin:0}body{overflow-x:hidden}:root{--cream: #f7efe2;--paper: rgba(255, 248, 239, .82);--paper-strong: rgba(255, 251, 246, .94);--beige: #ebdcc7;--blush: #d6a29d;--rose: #b97b77;--gold: #c7a86a;--ink: #2b211d;--ink-soft: #5d4a40;--ink-faint: rgba(43, 33, 29, .62);--brown: #7f5e4b;--line: rgba(106, 78, 60, .14);--shadow: 0 28px 60px rgba(64, 44, 30, .12);--shadow-soft: 0 18px 34px rgba(64, 44, 30, .09);--heading-font: "Iowan Old Style", "Baskerville Old Face", "Palatino Linotype", serif;--body-font: "Avenir Next", "Segoe UI", "Helvetica Neue", sans-serif;--script-font: "Snell Roundhand", "Segoe Script", "Brush Script MT", cursive}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:var(--ink);font-family:var(--body-font);background:radial-gradient(circle at top,#fff5e8e0,#f1e3ced1 38%,#e6d8c3eb),url(/anniversary/background/paper-grain.svg),url(/anniversary/photos/background.jpg) center/cover no-repeat;background-attachment:fixed}button,input,textarea,select{font:inherit}button{cursor:pointer}img{max-width:100%}.progressive-image{--placeholder-image: none;position:relative;display:grid;width:100%;height:100%;min-height:inherit;overflow:hidden;background:#7f5e4b14}.progressive-image>*{grid-area:1 / 1}.progressive-image__placeholder{background-image:var(--placeholder-image);background-position:center;background-repeat:no-repeat;background-size:cover;filter:blur(20px) saturate(1.02);transform:scale(1.08);opacity:1;transition:opacity .42s ease,transform .42s ease,filter .42s ease}.progressive-image__img{position:relative;z-index:1;width:100%;height:100%;min-height:inherit;object-fit:cover;display:block;opacity:0;filter:blur(16px) saturate(.94);transform:scale(1.02);transition:opacity .52s ease,transform .52s ease,filter .52s ease}.progressive-image.is-loaded .progressive-image__placeholder{opacity:0;transform:scale(1.12);filter:blur(24px)}.progressive-image.is-loaded .progressive-image__img{opacity:1;filter:none;transform:none}#root{width:100%}.app{min-height:100vh;position:relative;overflow-x:clip}.app:before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 10% 12%,rgba(214,162,157,.18),transparent 0 24%),radial-gradient(circle at 88% 14%,rgba(199,168,106,.12),transparent 0 24%),radial-gradient(circle at 50% 100%,rgba(127,94,75,.08),transparent 0 30%);z-index:0}.story{position:relative;z-index:1}.hero-section{position:relative;min-height:100vh;display:grid;place-items:center;padding:2rem 1.2rem;isolation:isolate}.hero-media,.hero-overlay,.hero-particles{position:absolute;inset:0}.hero-media .progressive-image,.hero-media .progressive-image__img,.hero-media .progressive-image__placeholder{width:100%;height:100%}.hero-media .progressive-image__img,.hero-media .progressive-image__placeholder{object-fit:cover;filter:blur(10px) saturate(.9) brightness(.7);transform:scale(1.08)}.hero-media .progressive-image.is-loaded .progressive-image__img{filter:blur(10px) saturate(.9) brightness(.7);transform:scale(1.08)}.hero-overlay{background:linear-gradient(180deg,#22171438,#221714bd),radial-gradient(circle at center,rgba(255,240,220,.1),transparent 0 45%)}.hero-particles span{position:absolute;left:var(--particle-left);top:var(--particle-top);width:12px;height:12px;border-radius:999px;background:radial-gradient(circle at 35% 35%,#fffffff2,#d7ad89a3);box-shadow:0 0 18px #f1d0ab52;opacity:.75;animation:drift 7s ease-in-out infinite;animation-delay:var(--particle-delay)}.hero-copy{position:relative;z-index:1;width:min(760px,100%);padding:clamp(2rem,4vw,3.8rem);text-align:center;color:#fff8f2}.hero-eyebrow,.hero-subtitle,.hero-tagline,.scroll-indicator{opacity:0;animation:heroFade .9s ease forwards}.hero-eyebrow{margin:0;text-transform:uppercase;letter-spacing:.3em;font-size:.78rem;animation-delay:.08s}.hero-copy h1{margin:1rem auto 0;font-family:var(--heading-font);font-size:clamp(3.2rem,8vw,6.6rem);line-height:.9;letter-spacing:-.04em;max-width:10ch;opacity:0;animation:heroFade 1s ease forwards;animation-delay:.22s}.hero-subtitle{margin:1.15rem 0 0;font-size:clamp(1.1rem,2.2vw,1.45rem);letter-spacing:.03em;animation-delay:.48s}.hero-tagline{margin:1rem auto 0;max-width:28ch;font-size:1rem;line-height:1.8;color:#fff8f2db;animation-delay:.7s}.scroll-indicator{position:absolute;left:50%;bottom:1.8rem;z-index:1;transform:translate(-50%);border:0;background:transparent;color:#fff8f2db;text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;padding-bottom:1.6rem;animation-delay:.92s}.scroll-indicator:after{content:"";position:absolute;left:50%;bottom:0;width:1px;height:16px;background:currentColor;transform:translate(-50%);animation:bounce 1.8s ease-in-out infinite}.page-shell{width:min(1160px,calc(100% - 22px));margin:0 auto;padding:1.4rem 0 6rem}.section{position:relative;padding:2.4rem 0;scroll-margin-top:1rem}.section-kicker,.memory-date,.timeline-date,.moment-eyebrow,.dream-label,.hero-eyebrow{color:var(--ink-faint)}.section-kicker,.memory-date,.timeline-date,.moment-eyebrow,.dream-label{margin:0;font-size:.73rem;text-transform:uppercase;letter-spacing:.24em}.section-header{margin-bottom:1.6rem;max-width:38rem}.section-header h2,.intro-copy h2,.memory-copy h3,.timeline-milestone h3,.moment-copy h3,.distance-copy h2,.dream-card h3,.final-letter h2,.hidden-card h2,.ending-card h2{margin:0;font-family:var(--heading-font);letter-spacing:-.03em}.section-header h2{margin-top:.6rem;font-size:clamp(2.3rem,4vw,4rem);line-height:.96}.section-body{margin:.9rem 0 0;color:var(--ink-soft);line-height:1.8}.handwritten-title{position:relative;display:inline-block;font-family:var(--script-font);font-size:clamp(2.4rem,6vw,4.4rem);font-weight:400}.handwritten-title:after{content:"";position:absolute;left:0;right:0;bottom:-.25rem;height:2px;background:linear-gradient(90deg,#b97b7733,#b97b77f2,#b97b771f);transform:scaleX(0);transform-origin:left;animation:underlineGrow 1s ease forwards;animation-delay:.5s}.intro-note,.memory-card,.timeline-track,.moment-card,.distance-panel,.dream-card,.final-letter,.ending-card,.hidden-card{position:relative;border:1px solid var(--line);background:linear-gradient(180deg,var(--paper-strong),rgba(248,239,227,.96)),url(/anniversary/background/paper-grain.svg);box-shadow:var(--shadow)}.intro-note:after,.memory-card:after,.timeline-track:after,.moment-card:after,.dream-card:after,.final-letter:after,.ending-card:after,.hidden-card:after{content:"";position:absolute;inset:14px;border-radius:inherit;border:1px solid rgba(127,94,75,.08);pointer-events:none}.intro-note{display:grid;gap:1.2rem;padding:clamp(1.3rem,3vw,2.2rem);border-radius:30px}.intro-copy{display:grid;align-content:start;gap:.65rem}.prose-block{display:grid;gap:1rem;margin-top:.7rem}.intro-copy .prose-block,.final-letter .prose-block{max-width:44rem}.final-letter .prose-block{margin-inline:auto}.prose-block p,.memory-copy p,.timeline-milestone p,.moment-copy p,.dream-card p,.hidden-card p,.ending-card p{margin:0;color:var(--ink-soft);line-height:1.78}.prose-block--light p{color:#fff6f0db}.media-frame{position:relative;margin:0;overflow:hidden;min-height:260px;border-radius:24px;background:#7f5e4b14;border:1px solid rgba(127,94,75,.14)}.media-frame .progressive-image__img{width:100%;height:100%;min-height:inherit;object-fit:cover;display:block}.media-chip{position:absolute;top:.9rem;left:.9rem;z-index:1;padding:.3rem .68rem;border-radius:999px;background:#fff8efe0;color:var(--ink);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}.media-frame figcaption{position:absolute;right:.85rem;bottom:.85rem;max-width:20rem;margin:0;padding:.55rem .75rem;border-radius:16px;background:#fff8efe6;color:var(--ink-soft);font-size:.82rem;line-height:1.5}.media-frame--polaroid{border-radius:24px}.media-frame--polaroid:before,.media-frame--paper:before{content:"";position:absolute;top:-10px;left:18px;width:74px;height:28px;background:url(/anniversary/stickers/tape-strip.svg) center/contain no-repeat;z-index:1;opacity:.86}.media-frame--polaroid:after,.media-frame--paper:after{content:"";position:absolute;top:-8px;right:18px;width:66px;height:26px;background:url(/anniversary/stickers/tape-strip.svg) center/contain no-repeat;z-index:1;opacity:.78;transform:rotate(7deg)}.media-frame--paper .progressive-image__img{object-fit:contain;background:linear-gradient(180deg,#faf4ecfa,#f3e8d9f0);padding:1.2rem}.media-frame--clean{border-radius:28px}.media-frame--wide{min-height:420px;border-radius:34px}.media-frame--empty .media-fallback{min-height:inherit}.media-fallback{display:grid;place-items:center;gap:.6rem;height:100%;padding:2rem;text-align:center;background:linear-gradient(135deg,#d6a29d1f,#c7a86a1a),url(/anniversary/background/paper-grain.svg)}.media-fallback-label{font-family:var(--heading-font);font-size:1.35rem}.media-fallback-copy{max-width:20rem;color:var(--ink-soft);line-height:1.7}.event-gallery{position:relative}.event-gallery__viewport{position:relative;min-height:260px;padding:0 2.9rem 2.6rem;display:grid;place-items:center;overflow:hidden}.event-gallery__main{position:relative;z-index:2;width:min(100%,78%)}.event-gallery__frame{min-height:260px}.event-gallery__preview{position:absolute;top:1rem;bottom:2.9rem;width:22%;overflow:hidden;border-radius:22px;opacity:.7;filter:blur(10px) saturate(.8);pointer-events:none;border:1px solid rgba(127,94,75,.1)}.event-gallery__preview:after{content:"";position:absolute;inset:0;background:#fff8ef29}.event-gallery__preview .progressive-image,.event-gallery__preview .progressive-image__img{width:100%;height:100%;object-fit:cover;display:block}.event-gallery__preview--left{left:-3%;transform:rotate(-4deg)}.event-gallery__preview--right{right:-3%;transform:rotate(4deg)}.event-gallery__arrow{position:absolute;top:calc(50% - 1.2rem);z-index:3;width:44px;height:44px;border:0;border-radius:999px;display:grid;place-items:center;background:#fff8efeb;color:var(--ink);box-shadow:0 16px 24px #402c1e24}.event-gallery__arrow span{font-size:1.8rem;line-height:1;margin-top:-2px}.event-gallery__arrow--left{left:.5rem}.event-gallery__arrow--right{right:.5rem}.event-gallery__arrow:disabled{opacity:0;pointer-events:none}.event-gallery__counter{position:absolute;left:50%;bottom:.2rem;transform:translate(-50%);padding:.38rem .72rem;border-radius:999px;background:#fff8eff0;color:var(--brown);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;z-index:3}.event-gallery.distance-media .event-gallery__viewport,.event-gallery.distance-media .event-gallery__frame{min-height:320px}.event-gallery__arrow:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.before-section{padding-top:3.1rem}.before-thread{position:absolute;left:18px;top:12.8rem;bottom:3rem;width:2px;background:linear-gradient(180deg,#b97b7724,#b97b77cc,#c7a86a61)}.memory-list{display:grid;gap:1.2rem}.memory-card{display:grid;gap:1rem;padding:1rem;border-radius:28px;margin-left:1.4rem}.memory-copy{display:grid;gap:.72rem;align-content:start}.memory-copy h3,.timeline-milestone h3,.moment-copy h3,.distance-copy h2,.dream-card h3,.final-letter h2,.hidden-card h2,.ending-card h2{font-size:clamp(1.5rem,2vw,2.2rem)}.memory-copy blockquote,.moment-copy blockquote{margin:.25rem 0 0;padding-left:1rem;border-left:2px solid rgba(185,123,119,.4);color:var(--brown);font-style:italic;line-height:1.7}.dates-section{padding-top:3.5rem}.timeline-track{border-radius:34px;padding:1.5rem}.timeline-hint{margin:0 0 1rem;color:var(--brown);font-size:.9rem;letter-spacing:.08em;text-transform:uppercase}.timeline-list{margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.8rem;position:relative}.timeline-chip{position:relative;display:grid;gap:.35rem;align-content:start;min-height:118px;width:100%;padding:1rem .95rem .95rem 1rem;border-radius:24px;text-align:left;border:1px solid rgba(127,94,75,.11);background:#fffbf5b8;box-shadow:var(--shadow-soft);transition:transform .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.timeline-dot{position:absolute;right:.95rem;top:.95rem;width:12px;height:12px;border-radius:999px;background:var(--rose);box-shadow:0 0 0 5px #b97b7729}.timeline-title{font-family:var(--heading-font);font-size:1.08rem;line-height:1.1;letter-spacing:-.02em;color:var(--ink)}.timeline-chip.is-active{border-color:#b97b7742;background:linear-gradient(180deg,#f5e7e3f5,#fff7f2f5),url(/anniversary/background/paper-grain.svg);box-shadow:0 22px 40px #402c1e24;transform:translateY(-2px)}.timeline-popup-wrap{margin-top:1rem;min-height:250px}.timeline-popup{position:relative;padding:1.35rem 1.2rem 1.2rem;border-radius:26px;border:1px solid rgba(127,94,75,.12);background:linear-gradient(180deg,#fffbf5fa,#f8efe3f5),url(/anniversary/background/paper-grain.svg);box-shadow:var(--shadow-soft);animation:popupBloom .24s ease}.timeline-popup:before{content:"";position:absolute;top:-10px;left:28px;width:74px;height:28px;background:url(/anniversary/stickers/tape-strip.svg) center/contain no-repeat;opacity:.84}.timeline-popup-kicker{margin:0;color:var(--brown);font-size:.76rem;letter-spacing:.22em;text-transform:uppercase}.timeline-popup h3{margin:.65rem 0 .7rem;font-family:var(--heading-font);font-size:clamp(1.55rem,2.3vw,2.2rem);letter-spacing:-.03em}.timeline-popup p:last-child{margin:0;color:var(--ink-soft);line-height:1.78}.timeline-popup--hint{background:linear-gradient(180deg,#fff8eefa,#f5ecddf5),url(/anniversary/background/paper-grain.svg)}.timeline-close{position:absolute;top:.8rem;right:.8rem;width:42px;height:42px;border:0;border-radius:999px;background:#7f5e4b14;color:var(--ink);text-transform:uppercase}.moments-section{padding-top:3.7rem}.moments-grid{display:grid;gap:1rem}.moments-chapters{display:grid;gap:1.6rem}.moments-chapter{display:grid;gap:1rem}.moments-chapter__header{display:grid;gap:.35rem;max-width:34rem}.moments-chapter__label{margin:0;color:var(--brown);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase}.moments-chapter__header h3{margin:0;font-family:var(--heading-font);font-size:clamp(1.55rem,2.3vw,2.2rem);letter-spacing:-.03em}.moment-card{display:grid;gap:1rem;border-radius:28px;padding:1.25rem 1.15rem;min-height:240px;align-content:start}.moment-copy{display:grid;gap:.8rem;align-content:start}.distance-section{padding-top:3.8rem}.distance-panel{display:grid;gap:1.1rem;padding:1.2rem;border-radius:34px;background:linear-gradient(180deg,#2f231eeb,#1d1512fa),url(/anniversary/background/paper-grain.svg);color:#fff7f0;box-shadow:0 26px 58px #160e0c3d}.distance-copy{display:grid;gap:1rem;align-content:start;padding:clamp(1rem,2vw,1.8rem)}.distance-copy .section-kicker,.distance-subheading{color:#fff1eabd}.distance-subheading{margin:0;font-size:1.02rem;line-height:1.7}.distance-columns{display:grid;gap:1rem}.distance-column{padding:1rem;border-radius:22px;background:#fff4ec0f;border:1px solid rgba(255,244,236,.08)}.distance-column h3{margin:0 0 .8rem;font-family:var(--heading-font);font-size:1.25rem}.distance-column ul{list-style:none;margin:0;padding:0;display:grid;gap:.65rem}.distance-column li{color:#fff6f0db;line-height:1.6}.distance-column li:before{content:"-";margin-right:.6rem;color:#ffddbcb8}.distance-quotes{display:grid;gap:.7rem}.distance-quote{padding:.95rem 1rem;border-radius:18px;background:#fff4ec14;color:#fff6f0db;font-style:italic;line-height:1.7}.distance-media{min-height:320px}.distance-media figcaption,.distance-media .media-chip{background:#221612b8;color:#fff6f0e0}.choose-section{padding-top:3.9rem}.manifesto{display:grid;gap:.3rem;margin-bottom:1.6rem}.manifesto-line{font-family:var(--heading-font);font-size:clamp(2rem,4.6vw,4rem);line-height:.98;letter-spacing:-.04em}.manifesto-line:nth-child(6),.manifesto-line:nth-child(9){color:var(--rose)}.manifesto-support{margin-top:1rem;color:var(--ink-soft);font-size:1.02rem;line-height:1.8}.choose-media{min-height:460px}.little-things-section{padding-top:3.8rem}.little-things-wrap{display:grid;gap:1.5rem}.little-notes{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:.9rem}.little-note{position:relative;min-height:132px;padding:1rem;border-radius:18px;background:linear-gradient(180deg,#fffae5fa,#f7eebcf0),url(/anniversary/background/paper-grain.svg);border:1px solid rgba(179,151,77,.18);box-shadow:var(--shadow-soft);line-height:1.65}.little-note:before{content:"";position:absolute;top:-9px;left:50%;width:66px;height:24px;transform:translate(-50%) rotate(-4deg);background:url(/anniversary/stickers/tape-strip.svg) center/contain no-repeat;opacity:.8}.little-closing{max-width:42rem;margin:0 auto;color:var(--ink-soft);font-size:1.02rem;line-height:1.9;text-align:center}.little-closing p{margin:0}.little-closing p+p{margin-top:1rem}.future-section{padding-top:3.8rem}.future-grid{display:grid;gap:1rem}.dream-card{padding:1.2rem;border-radius:26px;overflow:hidden}.dream-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(214,162,157,.16),transparent 0 34%),radial-gradient(circle at bottom left,rgba(199,168,106,.14),transparent 0 34%);pointer-events:none}.dream-card h3{margin-top:.55rem;margin-bottom:.7rem}.final-section{padding-top:3.9rem;display:grid;gap:1rem}.final-letter{border-radius:30px;padding:clamp(1.4rem,3vw,2.6rem);text-align:center}.signature{margin:1.5rem 0 0;font-family:var(--script-font);font-size:2rem;color:var(--brown)}.final-media{min-height:420px}.archive-section{padding-top:3.7rem}.archive-groups{display:grid;gap:1rem}.archive-group{position:relative;padding:1.1rem;border-radius:28px;border:1px solid var(--line);background:linear-gradient(180deg,var(--paper-strong),rgba(248,239,227,.96)),url(/anniversary/background/paper-grain.svg);box-shadow:var(--shadow-soft)}.archive-group:after{content:"";position:absolute;inset:12px;border-radius:inherit;border:1px solid rgba(127,94,75,.08);pointer-events:none}.archive-group__header{display:grid;gap:.35rem;margin-bottom:1rem}.archive-group__header>div{display:grid;gap:.35rem}.archive-group__eyebrow{margin:0;color:var(--brown);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase}.archive-group h3{margin:0;font-family:var(--heading-font);font-size:clamp(1.35rem,2vw,1.9rem)}.archive-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.archive-photo{margin:0;overflow:hidden;border-radius:20px;background:#fffbf5eb;border:1px solid rgba(127,94,75,.12);box-shadow:var(--shadow-soft);--card-tilt: var(--archive-rotation, 0deg)}.archive-photo .progressive-image__img{width:100%;aspect-ratio:4 / 5;object-fit:cover;display:block}.archive-toggle{position:relative;z-index:1;align-self:start;min-height:44px;border:1px solid rgba(127,94,75,.16);border-radius:999px;padding:.72rem 1rem;background:#fffbf5eb;color:var(--ink);box-shadow:var(--shadow-soft)}.archive-preview-note{margin:.95rem 0 0;color:var(--ink-soft);font-size:.9rem;line-height:1.6}.hidden-section{padding-top:3.2rem}.hidden-wrap{display:grid;gap:.9rem;max-width:720px;margin:0 auto}.hidden-intro{display:grid;gap:.45rem;justify-items:center;text-align:center}.hidden-intro-copy,.hidden-status{margin:0;color:var(--ink-soft);line-height:1.7}.hidden-intro-copy{max-width:32rem}.hidden-status{font-size:.92rem}.envelope-toggle{position:relative;width:100%;min-height:44px;border:0;background:transparent;padding:0;perspective:1400px}.envelope-front,.envelope-flap{display:block;width:100%;border-radius:28px}.envelope-front{position:relative;padding:8rem 1.4rem 1.3rem;background:linear-gradient(180deg,#fcf4e8fa,#f2e5d3f5),url(/anniversary/background/paper-grain.svg);border:1px solid var(--line);box-shadow:var(--shadow-soft);transition:transform .42s ease,box-shadow .42s ease,background .42s ease}.envelope-front:before{content:"";position:absolute;inset:16px;border-radius:22px;border:1px solid rgba(127,94,75,.08);pointer-events:none}.envelope-front:after{content:"";position:absolute;left:50%;bottom:1.2rem;width:min(78%,360px);height:1px;background:linear-gradient(90deg,transparent,rgba(127,94,75,.24),transparent);transform:translate(-50%);pointer-events:none}.envelope-flap{position:absolute;inset:0 0 auto;height:120px;clip-path:polygon(0 0,100% 0,50% 100%);background:linear-gradient(180deg,#f5e8d5,#e8d6bf);transform-origin:top;transition:transform .46s cubic-bezier(.2,.7,.2,1);z-index:1}.envelope-toggle.is-open .envelope-flap{transform:rotateX(180deg)}.envelope-toggle.is-open .envelope-front{transform:translateY(-6px);box-shadow:0 24px 44px #402c1e24}.envelope-seal{position:absolute;top:2.1rem;left:50%;width:64px;height:64px;transform:translate(-50%);border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg,#b97b77,#8c5d5a);color:#fff6f0;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;box-shadow:0 14px 22px #5d3e3a33;z-index:2}.envelope-toggle:not(.is-open) .envelope-seal{animation:sealPulse 2.8s ease-in-out infinite}.envelope-label{display:block;font-family:var(--heading-font);font-size:clamp(1.4rem,3vw,2.3rem);letter-spacing:-.02em;line-height:1.15;text-align:center}.hidden-panel{display:grid;grid-template-rows:0fr;opacity:0;transform:translateY(-10px) scale(.985);transition:grid-template-rows .42s ease,opacity .32s ease,transform .42s ease}.hidden-panel.is-open{grid-template-rows:1fr;opacity:1;transform:translateY(0) scale(1)}.hidden-card{overflow:hidden;margin-top:1rem;border-radius:28px;padding:1.45rem;background:radial-gradient(circle at top,rgba(214,162,157,.14),transparent 0 44%),linear-gradient(180deg,#fffbf6fa,#f7eee3f5),url(/anniversary/background/paper-grain.svg);box-shadow:0 28px 52px #402c1e21,inset 0 1px #ffffff9e}.hidden-card p{margin:0}.hidden-card h2{margin-top:.55rem;margin-bottom:.8rem}.hidden-card>p:last-child{color:var(--ink-soft);line-height:1.78}.hidden-card:focus-visible{outline:2px solid rgba(185,123,119,.7);outline-offset:5px}.hidden-signoff{margin-top:1rem!important;font-family:var(--script-font);font-size:1.8rem;color:var(--brown);text-align:right}.ending-section{padding-top:3.2rem}.ending-card{border-radius:30px;padding:2rem 1.4rem;text-align:center}.top-button{margin-top:1rem;border:0;border-radius:999px;min-height:44px;padding:.95rem 1.3rem;background:linear-gradient(135deg,#a36f6a,#795848);color:#fff8f2;box-shadow:0 18px 28px #79584838}.ending-card small{display:block;margin-top:1rem;color:var(--ink-faint)}.reveal{--reveal-shift: 26px;opacity:0;transform:translateY(var(--reveal-shift));transition:opacity .76s ease,transform .76s ease,box-shadow .2s ease;transition-delay:var(--reveal-delay, 0s)}.reveal.is-visible{--reveal-shift: 0px;opacity:1;transform:translateY(var(--reveal-shift))}.memory-card,.moment-card,.dream-card,.little-note,.archive-photo{--card-tilt: 0deg;--card-lift: 0px;transform:translateY(calc(var(--reveal-shift, 0px) + var(--card-lift))) rotate(var(--card-tilt))}.scroll-indicator:focus-visible,.archive-toggle:focus-visible,.envelope-toggle:focus-visible,.timeline-close:focus-visible,.top-button:focus-visible{outline:2px solid rgba(43,33,29,.9);outline-offset:4px}@media(hover:hover)and (pointer:fine){.top-button,.scroll-indicator,.envelope-toggle,.archive-toggle{transition:transform .18s ease,box-shadow .18s ease}.top-button:hover,.archive-toggle:hover{transform:translateY(-2px)}.memory-card,.timeline-chip,.moment-card,.little-note,.dream-card,.archive-photo,.event-gallery__arrow{transition:transform .22s ease,box-shadow .22s ease,opacity .76s ease}.memory-card:hover,.timeline-chip:hover,.moment-card:hover,.little-note:hover,.dream-card:hover,.archive-photo:hover{box-shadow:0 30px 50px #402c1e29}.memory-card:hover,.moment-card:hover,.little-note:hover,.dream-card:hover,.archive-photo:hover{--card-lift: -6px}.event-gallery__arrow:hover{transform:translateY(-2px)}.media-frame img{transition:transform .32s ease}.memory-card:hover .media-frame .progressive-image__img{transform:scale(1.03)}}@media(min-width:720px){.page-shell{width:min(1160px,calc(100% - 34px))}.intro-note{grid-template-columns:minmax(0,1.2fr) minmax(220px,.8fr);align-items:start}.little-notes,.future-grid,.distance-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.archive-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:900px){.section{padding:2.8rem 0}.memory-card,.memory-card--reverse{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);align-items:center}.memory-card--reverse .memory-copy{order:2}.memory-card--reverse .media-frame{order:1}.moments-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.timeline-list{grid-template-columns:repeat(4,minmax(0,1fr))}.timeline-popup{padding:1.6rem 1.5rem 1.4rem}.distance-panel{grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);align-items:stretch}.little-notes{grid-template-columns:repeat(3,minmax(0,1fr))}.archive-group__header{grid-template-columns:minmax(0,1fr) auto;align-items:end}.archive-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1200px){.hero-copy{transform:translateY(-2vh)}.page-shell{width:min(1180px,calc(100% - 52px))}.memory-card:nth-child(odd),.moment-card:nth-child(3n+1),.dream-card:nth-child(odd){--card-tilt: -.75deg}.memory-card:nth-child(2n),.moment-card:nth-child(3n),.dream-card:nth-child(2n){--card-tilt: .65deg}.little-note:nth-child(4n+1){--card-tilt: -1.6deg;--card-lift: -6px}.little-note:nth-child(4n+2){--card-tilt: .9deg;--card-lift: 10px}.little-note:nth-child(4n+3){--card-tilt: -.6deg;--card-lift: 4px}.little-note:nth-child(4n){--card-tilt: 1.5deg;--card-lift: -2px}.archive-photo:nth-child(5n+1){--card-tilt: -1.2deg;--card-lift: -4px}.archive-photo:nth-child(5n+2){--card-tilt: .8deg;--card-lift: 8px}.archive-photo:nth-child(5n+3){--card-tilt: -.5deg;--card-lift: 2px}.archive-photo:nth-child(5n+4){--card-tilt: 1.1deg;--card-lift: -3px}.archive-photo:nth-child(5n){--card-tilt: -.9deg;--card-lift: 5px}.event-gallery__main{width:min(100%,70%)}.event-gallery__preview{width:18%}}@media(max-width:560px){.section{padding:2rem 0}.page-shell{width:min(100%,calc(100% - 16px));padding-top:1rem}.hero-copy{padding:1.4rem}.hero-copy h1{font-size:clamp(2.8rem,14vw,4.4rem)}.intro-note,.memory-card,.timeline-track,.moment-card,.distance-panel,.dream-card,.final-letter,.ending-card,.hidden-card{border-radius:24px}.media-frame--wide,.choose-media,.final-media{min-height:280px}.media-chip{top:.7rem;left:.7rem;padding:.28rem .6rem;font-size:.68rem}.media-frame figcaption{right:.65rem;bottom:.65rem;max-width:16rem;padding:.5rem .65rem;font-size:.76rem}.timeline-chip{min-height:124px}.timeline-close{width:40px;height:40px}.event-gallery__viewport{padding-inline:1.2rem;padding-bottom:2.4rem}.event-gallery__main{width:min(100%,88%)}.event-gallery__preview{width:14%;top:1.4rem;bottom:2.8rem;filter:blur(8px) saturate(.8)}.event-gallery__preview--left{left:-4%}.event-gallery__preview--right{right:-4%}.event-gallery__arrow{width:44px;height:44px}.archive-toggle,.top-button{width:100%;justify-content:center}.hidden-wrap{gap:.75rem}.envelope-front{padding:7.4rem 1.1rem 1.1rem}.envelope-flap{height:108px}.hidden-card{padding:1.2rem}.archive-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}.event-gallery__preview{filter:blur(5px)}}@keyframes heroFade{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,8px)}}@keyframes drift{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-14px) scale(1.08)}}@keyframes underlineGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes popupBloom{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes sealPulse{0%,to{transform:translate(-50%) scale(1);box-shadow:0 14px 22px #5d3e3a33}50%{transform:translate(-50%) scale(1.05);box-shadow:0 18px 28px #5d3e3a42}}
