:root{--primary: #ff8fb1;--secondary: #ffd36e;--accent: #a78bfa;--ink: #2a1b3d;--bg-1: #1a0b2e;--bg-2: #2d1b4e;--bg-3: #3d1a5e;--cream: #fff8ee;--rose: #ff5e87;--serif: "Cormorant Garamond", "Georgia", serif;--hand: "Caveat", "Brush Script MT", cursive;--sans: "Inter", -apple-system, system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:var(--sans);color:var(--cream);@keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}@keyframes drift{0%{transform:translate(-10px,-10px) scale(1)}to{transform:translate(20px,30px) scale(1.15)}}@keyframes shimmer{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:1}to{transform:translateY(-110vh) rotate(40deg);opacity:0}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}@keyframes smoke{0%{opacity:.8;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-50px) scale(1.6)}}@keyframes floatBalloon{0%{transform:translateY(0) translate(0) rotate(-2deg)}50%{transform:translateY(-60vh) translate(20px) rotate(2deg)}to{transform:translateY(-120vh) translate(-10px) rotate(-3deg)}}@keyframes eq{0%,to{height:6px}50%{height:22px}}@keyframes aurora{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(4vw,-3vh,0) scale(1.08)}}@keyframes petalFall{0%{transform:translateY(-10vh) rotate(var(--rot))}to{transform:translateY(110vh) rotate(calc(var(--rot) + 360deg))}}@keyframes petalSway{0%{margin-left:0}to{margin-left:var(--sway)}}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes kenburns{0%{transform:scale(1) translate(0)}to{transform:scale(1.08) translate(-1.5%,-1%)}}@keyframes sparkleOut{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(.2);opacity:0}}}body button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}body img{display:block;max-width:100%}body .app{position:relative;min-height:100vh}body .stars{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}body .stars .star{position:absolute;border-radius:50%;background:#fff;animation:twinkle ease-in-out infinite;opacity:.85}body .stars .bokeh{display:none}body .cover{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:32px 20px;text-align:center}body .cover-inner{max-width:760px}body .eyebrow{text-transform:uppercase;letter-spacing:.32em;font-size:12px;color:#fff9;margin:0 0 18px}body .title{font-family:var(--serif);font-weight:600;font-style:italic;font-size:clamp(48px,9vw,110px);margin:0 0 16px;line-height:1.02}body .title.big{font-size:clamp(56px,11vw,140px)}body .title-name{background:linear-gradient(120deg,var(--primary),var(--secondary) 45%,var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}body .title-name.shimmer{background-size:200% 100%;animation:shimmer 6s linear infinite}body .subtitle{font-family:var(--hand);font-size:clamp(22px,3vw,30px);color:#f7e7c8;opacity:.9;margin:0 0 36px}body .hint{font-family:var(--hand);font-size:22px;color:#ffffffb3;margin-top:32px}body .countdown{display:inline-flex;align-items:flex-start;gap:10px;padding:22px 28px;border-radius:22px;background:linear-gradient(180deg,#ffffff12,#ffffff05);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 60px #00000059,inset 0 1px #ffffff14}body .cd-unit{display:flex;flex-direction:column;align-items:center;min-width:72px}body .cd-value{font-family:var(--serif);font-weight:600;font-size:clamp(36px,6vw,64px);line-height:1;background:linear-gradient(180deg,#fff,#ffd9e5);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 24px rgba(255,143,177,.4);overflow:hidden}body .cd-label{margin-top:8px;font-size:11px;text-transform:uppercase;letter-spacing:.28em;color:#ffffff8c}body .cd-sep{font-family:var(--serif);font-size:clamp(30px,5vw,54px);color:#ffffff4d;align-self:center;padding-bottom:18px}body .floating-hearts{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}body .floating-hearts span{position:absolute;bottom:-40px;color:#ff8fb18c;font-size:22px;animation:floatUp 14s linear infinite}body .experience{position:relative;z-index:1}body .envelope-wrap{min-height:100vh;display:grid;place-items:center;text-align:center;padding:40px 20px;gap:14px}body .envelope{width:min(420px,88vw);aspect-ratio:16/10;position:relative;perspective:900px;filter:drop-shadow(0 30px 50px rgba(0,0,0,.45))}body .env-body{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#fff1d9,#ffd2dc 60%,#ffb3c8);border-radius:10px;display:grid;place-items:center}body .env-flap{position:absolute;top:0;left:0;right:0;height:60%;background:linear-gradient(180deg,#ffd2dc,#ffb3c8);clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top center;border-radius:10px 10px 0 0;transition:transform .6s ease;z-index:2}body .envelope:hover .env-flap{transform:rotateX(-25deg)}body .env-seal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ff5e87,#b8244a);color:#fff;font-size:30px;display:grid;place-items:center;box-shadow:0 6px 14px #0000004d,inset 0 -4px 8px #0003;z-index:3}body .env-to{position:absolute;bottom:18px;left:50%;transform:translate(-50%);font-family:var(--hand);color:var(--ink);text-align:center}body .env-to span{display:block;font-size:14px;opacity:.7}body .env-to strong{font-size:28px;font-weight:700}body .story{position:relative}body .hero{min-height:92vh;display:grid;place-items:center;text-align:center;padding:80px 20px 40px}body .scroll-hint{margin-top:28px;font-family:var(--hand);font-size:22px;color:#fff9;animation:bob 2.4s ease-in-out infinite}body .section{max-width:1100px;margin:0 auto;padding:80px 20px;text-align:center}body .section-title{font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(34px,5vw,60px);margin:0 0 8px;background:linear-gradient(120deg,#fff,#ffd36e);-webkit-background-clip:text;background-clip:text;color:transparent}body .section-sub{font-family:var(--hand);font-size:22px;color:#ffffffbf;margin:0 0 36px}body .cake-stage{display:grid;place-items:end center;height:360px;position:relative;margin:0 auto}body .cake{position:relative;width:320px;height:320px}body .plate{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:360px;height:26px;border-radius:50%;background:radial-gradient(ellipse at center,#f4d9e6,#c9a4bd);box-shadow:0 12px 28px #00000059}body .layer{position:absolute;left:50%;transform:translate(-50%);border-radius:14px 14px 8px 8px;background:linear-gradient(180deg,#fff0f5,#ffd2dc);box-shadow:inset 0 -8px 14px #0000000f}body .layer-1{bottom:26px;width:280px;height:110px;background:linear-gradient(180deg,#ffd2dc,#ff9bb6)}body .layer-2{bottom:130px;width:220px;height:80px;background:linear-gradient(180deg,#ffe9b5,#ffd36e)}body .layer-3{bottom:206px;width:160px;height:60px;background:linear-gradient(180deg,#e7d6ff,#b9a3f5)}body .drips{position:absolute;bottom:132px;left:50%;transform:translate(-50%);width:220px;height:30px}body .drips span{position:absolute;top:0;width:14px;background:linear-gradient(180deg,#ffe9b5,#ffd36e);border-radius:0 0 50% 50%}body .candles{position:absolute;bottom:260px;left:50%;transform:translate(-50%);display:flex;gap:14px}body .candle{position:relative;width:14px;height:56px;display:grid;justify-items:center}body .stick{position:absolute;bottom:0;width:14px;height:46px;background:repeating-linear-gradient(180deg,#ff8fb1 0,#ff8fb1 6px,#ffd2dc 6px,#ffd2dc 12px);border-radius:4px;box-shadow:inset -3px 0 #00000014}body .wick{position:absolute;bottom:46px;width:2px;height:6px;background:#2a1b3d}body .flame{position:absolute;bottom:50px;width:14px;height:22px;border-radius:50% 50% 30% 30%;background:radial-gradient(circle at 50% 70%,#fff7c8,#ffb84d 60%,#ff5e87);filter:drop-shadow(0 0 12px rgba(255,184,77,.85));transform-origin:bottom center}body .smoke{position:absolute;bottom:50px;width:8px;height:30px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%);animation:smoke 1.6s ease-out forwards}body .cake-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;pointer-events:none;background:radial-gradient(circle at 50% 30%,rgba(255,184,77,.35),transparent 50%);filter:blur(10px)}body .wish-made{margin-top:20px;font-family:var(--hand);font-size:26px;color:#ffd36e}body .slides{position:relative;max-width:820px;margin:0 auto;display:grid;place-items:center;padding:20px 0 50px}body .slide-stage{position:relative;width:100%;min-height:460px;display:grid;place-items:center}body .slide-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#ffffff14;color:#fff;font-size:28px;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;transition:background .2s,transform .2s;z-index:4}body .slide-nav:hover{background:#ffffff2e;transform:translateY(-50%) scale(1.08)}body .slide-nav.prev{left:-10px}body .slide-nav.next{right:-10px}body .photo{position:relative;max-width:560px;padding:0;margin:0}body .photo img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}body .photo figcaption{margin-top:14px;font-family:var(--hand);font-size:22px;color:#ffe7c8;text-align:center}body .frame-polaroid .photo-inner{background:#fff;padding:16px 16px 56px;box-shadow:0 22px 50px #00000073;border-radius:4px}body .frame-gold .photo-inner{padding:14px;background:linear-gradient(135deg,#f7d774,#b8862a 50%,#f7d774);border-radius:6px;box-shadow:0 22px 50px #00000080,inset 0 0 0 2px #ffffff4d}body .frame-vintage .photo-inner{padding:18px;background:#f3e8d2;border:1px solid #a37c4d;box-shadow:0 22px 50px #00000073,inset 0 0 0 6px #f3e8d2,inset 0 0 0 7px #a37c4d;border-radius:2px}body .frame-vintage img{filter:sepia(.25) contrast(.95)}body .frame-tape .photo-inner{position:relative;padding:10px;background:#fff;box-shadow:0 22px 50px #00000073}body .frame-tape .photo-inner:before,body .frame-tape .photo-inner:after{content:"";position:absolute;top:-10px;width:70px;height:22px;background:#ffffff8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:0 2px 6px #0003}body .frame-tape .photo-inner:before{left:16px;transform:rotate(-8deg)}body .frame-tape .photo-inner:after{right:16px;transform:rotate(7deg)}body .frame-arch .photo-inner{padding:0;background:#fff;box-shadow:0 22px 50px #00000080;border-radius:280px 280px 8px 8px;overflow:hidden}body .frame-arch img{border-radius:280px 280px 0 0}body .dots{position:absolute;bottom:0;display:flex;gap:8px;justify-content:center;margin-top:12px}body .dot{width:8px;height:8px;border-radius:50%;background:#ffffff40;transition:all .3s}body .dot.on{background:var(--secondary);width:24px;border-radius:4px}body .notes-wall{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;padding:20px 0}body .note{position:relative;padding:28px 22px 22px;border-radius:4px;color:var(--ink);box-shadow:0 14px 28px #00000059;min-height:200px;transition:box-shadow .3s}body .note:hover{box-shadow:0 24px 40px #00000073}body .note .pin{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:16px;height:16px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ff8fb1,#b8244a);box-shadow:0 3px 6px #0006}body .note-text{font-family:var(--hand);font-size:22px;line-height:1.35;margin:0 0 14px}body .note-from{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#2a1b3d99;margin:0}body .reasons{list-style:none;padding:0;margin:0 auto;max-width:720px;text-align:left}body .reasons li{display:grid;grid-template-columns:60px 1fr;gap:18px;align-items:baseline;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.08)}body .reason-num{font-family:var(--serif);font-style:italic;font-size:28px;color:var(--secondary)}body .reason-text{font-family:var(--serif);font-size:clamp(20px,2.4vw,26px);line-height:1.4;color:#fff5dc}body .balloons{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}body .balloon{position:absolute;bottom:-120px;border-radius:50% 50% 45% 45%;filter:drop-shadow(0 6px 8px rgba(0,0,0,.3));animation:floatBalloon linear infinite}body .balloon .string{position:absolute;top:100%;left:50%;width:1px;height:80px;background:#fff6}body .music-toggle{position:fixed;bottom:24px;right:24px;z-index:10;width:52px;height:52px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:flex-end;justify-content:center;gap:3px;padding-bottom:14px}body .music-toggle .bar{width:4px;background:var(--secondary);border-radius:2px;height:6px}body .music-toggle.on .bar{animation:eq .9s ease-in-out infinite}body .music-toggle.on .bar:nth-child(2){animation-delay:.15s}body .music-toggle.on .bar:nth-child(3){animation-delay:.3s}body .music-toggle.on .bar:nth-child(4){animation-delay:.45s}body .footer{text-align:center;padding:60px 20px 80px;font-family:var(--hand);font-size:22px;color:#ffffffb3}body .footer .signature{margin-top:6px;color:var(--secondary);font-size:26px}@media (max-width: 520px){body .countdown{gap:6px;padding:16px 14px}body .cd-unit{min-width:56px}body .slide-nav.prev{left:4px}body .slide-nav.next{right:4px}body .cake{transform:scale(.85)}}body .aurora{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden;background:linear-gradient(160deg,#14071f,#1a0b2e 55%,#2a1244)}body .aurora-blob{position:absolute;width:55vmin;height:55vmin;border-radius:50%;filter:blur(50px);opacity:.55;mix-blend-mode:screen;will-change:transform;animation:aurora 26s ease-in-out infinite alternate}body .aurora-blob.a{background:radial-gradient(circle at 30% 30%,#ff5e87,transparent 65%);top:-10%;left:-10%}body .aurora-blob.b{background:radial-gradient(circle at 50% 50%,#a78bfa,transparent 65%);top:25%;right:-15%;animation-delay:-8s;animation-duration:32s}body .aurora-blob.c{background:radial-gradient(circle at 50% 50%,#ffd36e,transparent 65%);bottom:-15%;left:15%;animation-delay:-14s;animation-duration:36s}body .aurora-grain{display:none}body .cursor-trail{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;mix-blend-mode:screen}body .petals{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;overflow:hidden}body .petal{position:absolute;top:-40px;background:radial-gradient(circle at 30% 30%,#ffd9e5,#ff8fb1 70%);border-radius:80% 20% 70% 30%/50%;opacity:.85;filter:drop-shadow(0 4px 6px rgba(0,0,0,.15));animation:petalFall linear infinite,petalSway ease-in-out infinite alternate}body .petal.heart{background:none;border-radius:0;filter:drop-shadow(0 2px 4px rgba(255,94,135,.6))}body .petal.heart:before,body .petal.heart:after{content:"";position:absolute;top:0;width:100%;height:100%;background:#ff5e87;border-radius:50%}body .petal.heart:before{left:-50%}body .petal.heart:after{left:50%}body .petal.heart{transform:rotate(-45deg);overflow:visible}body .curtain{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;pointer-events:none;display:flex;align-items:center;justify-content:center}body .curtain-half{position:absolute;top:0;bottom:0;width:51%;background:linear-gradient(180deg,#1a0b2e,#3d1a5e),radial-gradient(ellipse at center,rgba(255,143,177,.2),transparent 70%);box-shadow:inset -40px 0 80px #0009}body .curtain-half.left{left:0}body .curtain-half.right{right:0;box-shadow:inset 40px 0 80px #0009}body .curtain-mono{position:relative;z-index:1;font-size:72px;color:var(--rose);text-shadow:0 0 40px rgba(255,94,135,.7)}body .marquee{margin:28px auto 0;max-width:1100px;overflow:hidden;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);padding:12px 0}body .marquee-track{display:flex;gap:0;width:max-content;animation:marquee 38s linear infinite}body .marquee-item{display:inline-flex;align-items:center;gap:24px;padding:0 24px;font-family:var(--serif);font-style:italic;font-size:22px;color:#ffffffbf;white-space:nowrap}body .marquee-dot{color:var(--secondary);font-size:14px}body .split{display:inline-block}body .split-char{display:inline-block;will-change:transform,opacity}body .title-name .split{background:inherit;-webkit-background-clip:text;background-clip:text;color:transparent}body .title-name .split-char{background:linear-gradient(120deg,var(--primary),var(--secondary) 45%,var(--accent));background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 6s linear infinite}body .photo-img-wrap{position:relative;overflow:hidden;transform-style:preserve-3d}body .kenburns{animation:kenburns 12s ease-in-out infinite alternate;transform-origin:center}body .photo-shine{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.35) 50%,transparent 60%);transform:translate(-120%);transition:transform .9s ease}body .photo:hover .photo-shine{transform:translate(120%)}body .sparkle-burst{position:absolute;left:50%;bottom:290px;width:0;height:0;pointer-events:none;z-index:5}body .sparkle-burst span{position:absolute;left:0;top:0;width:6px;height:6px;border-radius:50%;background:radial-gradient(circle,#fff 0%,#ffd36e 50%,transparent 70%);box-shadow:0 0 10px #ffd36e;animation:sparkleOut 1.2s ease-out forwards}body .note:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:inherit;background:linear-gradient(135deg,#ff8fb173,#a78bfa73);filter:blur(18px);opacity:0;transition:opacity .4s;z-index:-1}body .note:hover:after{opacity:1}body body{background:#14071f}body .app{isolation:isolate}body .cover,body .experience{position:relative;z-index:2}@media (prefers-reduced-motion: reduce){body .aurora-blob,body .stars .star,body .balloon,body .petal,body .floating-hearts span,body .kenburns,body .marquee-track,body .title-name .split-char{animation:none!important}body .cursor-trail{display:none}}
