:root{color:#22172b;background:#fff7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;padding-bottom:env(safe-area-inset-bottom);margin:0;overflow-x:hidden}button,a{-webkit-tap-highlight-color:transparent}.confetti{pointer-events:none;z-index:20;position:fixed;inset:0;overflow:hidden}.confetti span{background:var(--paper);opacity:.85;width:10px;height:16px;transform:rotate(var(--spin));border-radius:2px;animation:linear infinite confetti-fall;position:absolute;top:-18px}.balloons{z-index:12;pointer-events:none;position:fixed;inset:0;overflow:hidden}.balloons span{background:radial-gradient(circle at 30% 22%, #ffffffd9, transparent 18%), var(--balloon);opacity:.55;border-radius:50% 50% 46% 46%;width:44px;height:58px;animation:ease-in infinite balloon-rise;position:absolute;bottom:-120px}.balloons span:after{content:"";background:#ffffff8c;width:1px;height:70px;position:absolute;top:56px;left:50%}@keyframes balloon-rise{0%{transform:translateY(120px)rotate(-4deg)}50%{transform:translate(18px,-45vh)rotate(5deg)}to{transform:translate(-14px,-118vh)rotate(-6deg)}}@keyframes confetti-fall{0%{transform:translateY(-30px)rotate(0)}to{transform:translate(24px,108vh)rotate(720deg)}}.music-dock{z-index:30;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffc7;border:1px solid #ffffffb8;border-radius:8px;grid-template-columns:44px minmax(0,1fr) 22px;align-items:center;gap:12px;width:min(360px,100vw - 32px);padding:12px 14px;display:grid;position:fixed;bottom:22px;right:22px;box-shadow:0 18px 54px #2a173a33}.music-dock p,.music-dock span{text-overflow:ellipsis;white-space:nowrap;margin:0;display:block;overflow:hidden}.music-dock p{font-size:.9rem;font-weight:800}.music-dock span{color:#72586d;margin-top:2px;font-size:.76rem}.icon-button,.button{cursor:pointer;border:0;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.icon-button{border-radius:50%;width:44px;height:44px}.primary,.button.solid{color:#fff;background:#d61f69}.hero{isolation:isolate;color:#fff;background:linear-gradient(120deg,#1f0b33e0,#c71f6680),url(https://images.unsplash.com/photo-1513151233558-d860c5398176?auto=format&fit=crop&w=1800&q=80) 50%/cover;place-items:center;min-height:92vh;padding:72px clamp(22px,5vw,78px) 112px;display:grid;position:relative}.hero:after{content:"";z-index:-1;background:linear-gradient(#0000,#fff7fb);height:22vh;position:absolute;inset:auto 0 0}.hero-content{z-index:3;text-align:center;justify-items:center;max-width:900px;display:grid;position:relative}.hero-side-photos{z-index:2;pointer-events:none;position:absolute;inset:0;overflow:hidden}.side-photo{aspect-ratio:4/5;background:#ffffffeb;border-radius:18px;width:clamp(120px,15vw,220px);padding:7px;animation:5.8s ease-in-out infinite side-photo-float;position:absolute;box-shadow:0 24px 70px #00000057,0 0 0 1px #ffffff73}.side-photo:before{content:"";z-index:-1;filter:blur(18px);opacity:.5;background:linear-gradient(135deg,#ffd166cc,#ff4d8dbf,#4cc9f0b3);border-radius:24px;position:absolute;inset:-10px}.side-photo img{object-fit:cover;border-radius:12px;width:100%;height:100%;display:block}.side-photo.one{top:13vh;left:clamp(14px,4vw,64px);transform:rotate(-10deg)}.side-photo.two{width:clamp(104px,13vw,185px);animation-delay:-1.8s;bottom:14vh;left:clamp(70px,12vw,190px);transform:rotate(8deg)}.side-photo.three{animation-delay:-.8s;top:14vh;right:clamp(14px,4vw,64px);transform:rotate(10deg)}.side-photo.four{width:clamp(104px,13vw,185px);animation-delay:-2.4s;bottom:13vh;right:clamp(70px,12vw,190px);transform:rotate(-8deg)}@keyframes side-photo-float{0%,to{translate:0}50%{translate:0 -16px}}.badge,.section-heading span{letter-spacing:0;align-items:center;gap:8px;font-weight:800;display:inline-flex}.badge{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff24;border:1px solid #ffffff6b;border-radius:999px;padding:10px 14px}h1,h2,p{margin-top:0}h1{letter-spacing:0;text-shadow:0 10px 32px #00000052;max-width:900px;margin-bottom:24px;font-family:Brush Script MT,Segoe Script,Lucida Handwriting,cursive;font-size:clamp(4.1rem,11vw,9rem);line-height:.92}.hero p{color:#ffffffe6;max-width:680px;margin:26px auto 0;font-size:clamp(1.08rem,2vw,1.35rem);line-height:1.65}.hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:34px;display:flex}.button{border-radius:8px;gap:10px;min-height:48px;padding:13px 18px;font-weight:850}.button.soft{color:#fff;background:#ffffff2e;border:1px solid #ffffff6b}.hero-centerpiece{aspect-ratio:1;background:#ffffff2e;border:8px solid #ffffffeb;border-radius:50%;width:min(360px,76vw);margin:0 auto;position:relative;overflow:hidden;box-shadow:0 28px 80px #00000059,0 0 0 18px #ffffff1f}.hero-centerpiece img{object-fit:cover;width:100%;height:100%;display:block}.flower-rain{z-index:2;pointer-events:none;position:absolute;inset:0;overflow:hidden}.flower-rain span{filter:drop-shadow(0 4px 8px #63144138);background:radial-gradient(circle at 50% 18%,#fff6fb 0 28%,#0000 30%),radial-gradient(circle at 18%,#ffd1e3 0 28%,#0000 30%),radial-gradient(circle at 82%,#ff9fc2 0 28%,#0000 30%),radial-gradient(circle at 50% 82%,#ffc7da 0 28%,#0000 30%),radial-gradient(circle,#ffd166 0 18%,#0000 20%);animation:linear infinite flower-fall;position:absolute;top:-24px}@keyframes flower-fall{0%{opacity:0;transform:translateY(-24px)rotate(0)}12%{opacity:1}to{opacity:.9;transform:translate3d(var(--drift), 420px, 0) rotate(520deg)}}.scroll-cue{color:#ffffffc2;text-transform:uppercase;letter-spacing:.12em;font-size:.84rem;font-weight:800;position:absolute;bottom:34px;left:clamp(22px,5vw,78px)}.section{padding:86px clamp(20px,5vw,76px)}.section-heading{max-width:760px;margin-bottom:34px}.section-heading span{color:#d61f69;font-size:.9rem}.section-heading h2{letter-spacing:0;margin:8px 0 0;font-size:clamp(2.1rem,5vw,4rem);line-height:1}.gallery-layout{grid-template-columns:minmax(0,1.45fr) minmax(240px,.55fr);align-items:stretch;gap:22px;display:grid}.slideshow{gap:18px;display:grid}.feature-frame{background:#1a101f;border-radius:8px;min-height:500px;position:relative;overflow:hidden;box-shadow:0 24px 80px #441c452e}.feature-frame img,.thumb img{object-fit:cover;width:100%;height:100%}.slideshow-frame{min-height:640px}.slide{opacity:0;transition:opacity .65s,transform .9s;position:absolute;inset:0;transform:scale(1.025)}.slide.active{opacity:1;transform:scale(1)}.slide-arrow{z-index:4;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#14091994;border:1px solid #ffffff94;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 14px 36px #0000003d}.slide-arrow.previous{left:16px}.slide-arrow.next{right:16px}.feature-caption{color:#fff;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#140919b8;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;max-width:calc(100% - 36px);padding:14px 16px;font-weight:850;line-height:1.35;display:flex;position:absolute;bottom:18px;left:18px;right:18px}.feature-caption span{align-items:center;gap:10px;min-width:0;display:inline-flex}.feature-caption strong{color:#ffd166;flex:none}.slideshow-controls{justify-content:space-between;align-items:center;gap:16px;display:flex}.slide-dots{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.dot{cursor:pointer;background:#22172b38;border:0;border-radius:50%;width:10px;height:10px;padding:0}.dot.active{background:#d61f69;border-radius:999px;width:28px}.thumb-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.thumb-strip{scrollbar-color:#d61f69 #22172b1f;grid-auto-columns:minmax(110px,160px);grid-auto-flow:column;gap:12px;padding:2px 2px 10px;display:grid;overflow-x:auto}.thumb{cursor:pointer;opacity:.76;background:#fff;border:4px solid #0000;border-radius:8px;min-height:180px;padding:0;transition:transform .18s,opacity .18s,border-color .18s;overflow:hidden}.thumb:hover,.thumb.active{opacity:1;border-color:#d61f69;transform:translateY(-3px)}.wish-band{color:#fff;background:linear-gradient(135deg,#140b2beb,#097181d1),url(https://images.unsplash.com/photo-1527529482837-4698179dc6ce?auto=format&fit=crop&w=1800&q=80) 50%/cover;padding:96px clamp(20px,5vw,76px)}.wish-content{max-width:980px}.section-heading.light span{color:#ffd166}.wish-copy{gap:18px;max-width:820px;display:grid}.wish-copy p{margin:0;font-size:clamp(1.15rem,2vw,1.55rem);line-height:1.65}.signature{color:#ffd166;margin-top:36px;font-size:1.25rem;font-weight:900}.cake-moment{color:#fff;text-align:center;background:radial-gradient(circle at 20% 20%,#ffd16638,#0000 28%),linear-gradient(135deg,#3c1053,#ad1d6b 48%,#0f7c8d);justify-items:center;padding:92px clamp(20px,5vw,76px);display:grid;position:relative;overflow:hidden}.cake-moment:before{content:"";pointer-events:none;opacity:.32;background-image:radial-gradient(circle,#ffffffbf 0 2px,#0000 3px),radial-gradient(circle,#ffd166b3 0 2px,#0000 3px);background-position:10px 20px,60px 80px;background-size:90px 90px,130px 130px;position:absolute;inset:0}.cake-moment .section-heading,.birthday-cake,.cake-message{z-index:2;position:relative}.birthday-cake{cursor:pointer;filter:drop-shadow(0 28px 45px #00000052);background:0 0;border:0;align-content:end;justify-items:center;width:min(420px,86vw);min-height:300px;padding:0;display:grid}.candles{justify-content:center;gap:22px;display:flex;transform:translateY(18px)}.candle{background:repeating-linear-gradient(135deg,#fff 0 8px,#ff73a6 8px 14px);border-radius:6px;width:16px;height:64px;position:relative}.candle i{background:radial-gradient(circle at 50% 72%,#fff7b5 0 18%,#ffd166 32%,#ff7a00 70%);border-radius:50% 50% 45% 45%;width:18px;height:28px;animation:.7s ease-in-out infinite alternate flame;position:absolute;top:-28px;left:50%;transform:translate(-50%)}.wished .candle i{opacity:0;transition:opacity .35s,transform .45s;transform:translate(-50%)translateY(-16px)scale(.2)}@keyframes flame{0%{transform:translate(-50%)rotate(-5deg)scale(.95)}to{transform:translate(-50%)rotate(6deg)scale(1.08)}}.cake-top{background:radial-gradient(circle at 18% 20%,#fff 0 8px,#0000 9px),radial-gradient(circle at 48% 35%,#fff 0 7px,#0000 8px),radial-gradient(circle at 78% 24%,#fff 0 8px,#0000 9px),linear-gradient(#fff4f8,#ffafd0);border-radius:28px 28px 14px 14px;width:82%;height:62px}.cake-body{background:linear-gradient(90deg,#0000 0 18%,#ffffff61 18% 21%,#0000 21% 48%,#ffffff52 48% 51%,#0000 51%),linear-gradient(#ff6ea8,#d61f69);border-radius:14px 14px 26px 26px;justify-content:space-around;align-items:end;width:72%;height:118px;padding:18px 32px;display:flex}.cake-body span{background:#ffd166;border-radius:50%;width:38px;height:38px;box-shadow:72px -18px #06d6a0,-68px -22px #4cc9f0}.cake-plate{background:#fffc;border-radius:999px;width:92%;height:24px}.cake-message{color:#ffffffe6;max-width:680px;margin:24px auto 0;font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.6}.surprise-section{background:linear-gradient(#fff7fbf5,#e8f9f7e6)}.surprise-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.surprise-card{background:linear-gradient(#fffffff0,#ffffffd1),radial-gradient(circle at 100% 0,#ffd16647,#0000 42%);border:1px solid #22172b14;border-radius:8px;min-height:260px;padding:24px;transition:transform .18s,box-shadow .18s;box-shadow:0 22px 55px #2a173a1a}.surprise-card:hover{transform:translateY(-5px);box-shadow:0 28px 70px #2a173a24}.surprise-card div{color:#fff;background:#d61f69;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:inline-flex}.surprise-card h3{color:#22172b;margin:26px 0 12px;font-size:1.3rem}.surprise-card p{color:#5b475f;margin:0;font-size:1rem;line-height:1.6}.moment-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.moment{background:#fff;border:1px solid #22172b1a;border-radius:8px;min-height:180px;padding:22px;box-shadow:0 18px 50px #432a4f14}.moment strong{color:#d61f69;font-size:2rem}.moment p{color:#3d2a45;margin:26px 0 0;font-size:1.05rem;font-weight:800;line-height:1.45}.finale{text-align:center;color:#fff;background:linear-gradient(#0000002e,#0000008a),url(https://images.unsplash.com/photo-1519671482749-fd09be7ccebf?auto=format&fit=crop&w=1800&q=80) 50%/cover;place-items:center;min-height:60vh;padding:90px 22px 130px;display:grid}.finale div{max-width:780px}.finale h2{letter-spacing:0;margin:16px 0;font-size:clamp(2.4rem,6vw,5.2rem);line-height:.98}.finale p{color:#ffffffe0;max-width:620px;margin:0 auto;font-size:1.2rem;line-height:1.6}@media (width<=900px){.hero{min-height:92vh;padding-top:86px}.hero-side-photos{opacity:.48}.gallery-layout{grid-template-columns:1fr}.feature-frame{min-height:420px}.slideshow-frame{min-height:560px}.thumb-grid,.moment-grid,.surprise-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.music-dock{left:12px;right:12px;bottom:max(12px, env(safe-area-inset-bottom));grid-template-columns:42px minmax(0,1fr);width:auto;padding:10px 12px}.music-dock>svg{display:none}.music-dock p,.music-dock span{white-space:normal}.music-dock p{font-size:.84rem}.music-dock span{font-size:.72rem;line-height:1.25}.icon-button{width:42px;height:42px}.hero{background-position:top;align-items:center;min-height:100svh;padding:64px 18px 128px}.hero-side-photos{opacity:.38}.side-photo{border-radius:14px;width:96px;padding:5px}.side-photo img{border-radius:10px}.side-photo.one{top:82px;left:-34px}.side-photo.two{width:82px;bottom:138px;left:18px}.side-photo.three{top:88px;right:-34px}.side-photo.four{width:82px;bottom:140px;right:18px}h1{margin-bottom:18px;font-size:clamp(3.2rem,17vw,4.8rem);line-height:.98}.hero p{font-size:1rem;line-height:1.5}.badge{max-width:100%;padding:9px 11px;font-size:.82rem;line-height:1.25}.hero-actions{flex-direction:column;align-items:stretch;margin-top:24px}.button{width:100%;min-height:46px;padding:12px 14px}.hero-centerpiece{border-width:6px;width:min(270px,72vw);box-shadow:0 20px 54px #00000052,0 0 0 10px #ffffff1f}.section,.wish-band,.cake-moment{padding:66px 18px}.section-heading{margin-bottom:24px}.section-heading h2,.finale h2{font-size:clamp(2rem,12vw,3.05rem);line-height:1.04}.feature-frame{aspect-ratio:4/5;min-height:auto}.slideshow-frame{aspect-ratio:3/4;min-height:auto}.slide-arrow{width:40px;height:40px}.slide-arrow.previous{left:10px}.slide-arrow.next{right:10px}.feature-caption{max-width:calc(100% - 20px);padding:11px 12px;font-size:.86rem;bottom:10px;left:10px;right:10px}.feature-caption span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.slideshow-controls{flex-direction:column;align-items:stretch}.slide-dots{justify-content:center}.dot{width:9px;height:9px}.dot.active{width:24px}.thumb-grid,.moment-grid,.surprise-grid{grid-template-columns:1fr}.birthday-cake{width:min(330px,92vw);min-height:252px}.candles{gap:15px}.candle{width:13px;height:52px}.candle i{width:15px;height:24px}.cake-body{height:96px;padding:15px 24px}.surprise-card{min-height:210px;padding:20px}.balloons span{opacity:.38;width:34px;height:46px}.thumb-strip{grid-auto-columns:minmax(88px,112px);gap:9px}.thumb{aspect-ratio:4/5;min-height:auto}.wish-copy p{font-size:1.03rem;line-height:1.58}.signature{font-size:1.05rem}.moment{min-height:150px;padding:18px}.moment p{margin-top:18px}.finale{min-height:72vh;padding:72px 18px 118px}.finale p{font-size:1rem;line-height:1.55}}@media (width<=380px){h1{font-size:2.9rem}.scroll-cue{display:none}}
