@import "https://fonts.googleapis.com/css2?family=Dancing+Script:wght@400;500;600;700&family=Poppins:wght@300;400;500;600;700&display=swap";
:root{--pink-light:#fce4ec;--pink-main:#f48fb1;--pink-deep:#ec407a;--pink-dark:#c2185b;--pink-accent:#ff80ab;--rose-gold:#e8a0bf;--blush:#fadadd;--cream:#fff5f7;--white:#fff;--text-dark:#4a1942;--text-soft:#7b3f6e;--gold:#d4a574;--gold-light:#f0d9b5;--dark-bg:#1a0a2e;--dark-surface:#2d1b4e;--purple-deep:#4a1d6e;--purple-glow:#7c3aed;--celebration-pink:#ff69b4;--celebration-gold:gold}*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-tap-highlight-color:transparent;height:100%;font-family:Poppins,sans-serif;overflow:hidden}.page1-bg{background:linear-gradient(135deg,#fce4ec 0%,#f8bbd0 30%,#f48fb1 60%,#ec407a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hearts-container{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.heart{opacity:0;filter:drop-shadow(0 0 6px #ec407a4d);animation:linear infinite floatHeart;position:absolute;bottom:-60px}.heart svg{width:100%;height:100%}@keyframes floatHeart{0%{opacity:0;transform:translateY(0)translate(0)rotate(0)scale(.5)}10%{opacity:.9;transform:translateY(-10vh)translate(10px)rotate(15deg)scale(1)}30%{opacity:.8;transform:translateY(-30vh)translate(-15px)rotate(-10deg)}50%{opacity:.7;transform:translateY(-50vh)translate(20px)rotate(20deg)}70%{opacity:.5;transform:translateY(-70vh)translate(-10px)rotate(-15deg)}90%{opacity:.2;transform:translateY(-90vh)translate(15px)rotate(10deg)}to{opacity:0;transform:translateY(-110vh)translate(0)rotate(25deg)scale(.3)}}.sparkle{background:var(--white);pointer-events:none;border-radius:50%;width:4px;height:4px;animation:3s ease-in-out infinite sparkle;position:absolute}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}.page-container{z-index:1;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:relative}.white-strip{-webkit-backdrop-filter:blur(20px);text-align:center;z-index:10;background:#ffffffed;border:1px solid #fff9;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;width:90%;max-width:680px;min-height:220px;padding:48px 40px;transition:all .5s;display:flex;position:relative;overflow:visible;box-shadow:0 8px 32px #ec407a26,0 2px 8px #0000000d,inset 0 1px #fffc}.white-strip:before{content:"";background:linear-gradient(135deg, var(--pink-accent), var(--rose-gold), var(--gold-light), var(--pink-main));z-index:-2;opacity:.5;border-radius:26px;position:absolute;inset:-2px}.white-strip:after{content:"";z-index:-1;background:#ffffffed;border-radius:24px;position:absolute;inset:0}.strip-deco-top,.strip-deco-bottom{background:linear-gradient(90deg, transparent, var(--pink-main), transparent);border-radius:2px;width:60px;height:2px;position:absolute;left:50%;transform:translate(-50%)}.strip-deco-top{top:16px}.strip-deco-bottom{bottom:16px}.mini-heart-float{opacity:.6;pointer-events:none;z-index:5;font-size:1rem;animation:4s ease-in-out infinite miniFloat;position:absolute}@keyframes miniFloat{0%,to{opacity:.4;transform:translateY(0)rotate(0)}50%{opacity:.8;transform:translateY(-15px)rotate(10deg)}}.message-wrapper{justify-content:center;align-items:center;width:100%;min-height:120px;display:flex;position:relative}.message{flex-direction:column;align-items:center;gap:12px;width:100%;transition:all .8s cubic-bezier(.4,0,.2,1);display:flex;position:absolute}.message.active{opacity:1;z-index:2;position:relative;transform:translateY(0)scale(1)}.message.exit-up{opacity:0;position:absolute;transform:translateY(-40px)scale(.95)}.message.enter-down{opacity:0;position:absolute;transform:translateY(40px)scale(.95)}.message.hidden{opacity:0;pointer-events:none;position:absolute;transform:translateY(40px)scale(.95)}.message-emoji{font-size:2.5rem;line-height:1;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.message-text{color:var(--text-dark);letter-spacing:.5px;max-width:500px;font-family:Dancing Script,cursive;font-size:2rem;font-weight:600;line-height:1.4}.message-sub{color:var(--text-soft);letter-spacing:.3px;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:400}.progress-container{gap:10px;margin-top:24px;display:flex}.progress-dot{background:var(--pink-light);border:2px solid var(--pink-main);border-radius:50%;width:10px;height:10px;transition:all .5s}.progress-dot.active{background:var(--pink-deep);transform:scale(1.3);box-shadow:0 0 12px #ec407a66}.progress-dot.completed{background:var(--pink-main)}.timer-bar-container{background:var(--pink-light);border-radius:3px;width:100%;max-width:200px;height:3px;margin-top:16px;overflow:hidden}.timer-bar{background:linear-gradient(90deg, var(--pink-main), var(--pink-deep));border-radius:3px;height:100%;transition:width .3s linear}.options-container{flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;margin-top:16px;display:flex;position:relative}.option-btn{cursor:pointer;letter-spacing:.5px;white-space:nowrap;border:none;border-radius:50px;padding:14px 36px;font-family:Poppins,sans-serif;font-size:1rem;font-weight:600;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.option-btn:before{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.option-btn:hover:before{left:100%}.option-yes{background:linear-gradient(135deg, var(--pink-deep), #d81b60);color:var(--white);transform-origin:50%;max-width:90%;box-shadow:0 4px 20px #ec407a66}.option-yes:hover{filter:brightness(1.05);box-shadow:0 8px 30px #ec407a99}.option-yes:active{filter:brightness(.95)}.option-no{color:var(--text-soft);border:2px solid var(--pink-main);background:0 0}.option-no:hover{background:var(--pink-light);color:var(--pink-dark)}.no-btn-outside{z-index:20;position:absolute;bottom:-70px;left:50%;transform:translate(-50%)}.page2-bg{background:linear-gradient(135deg,#1a0a2e 0%,#2d1b4e 40%,#4a1d6e 100%);min-height:100vh;transition:background 1.5s;position:relative;overflow:hidden}.page2-bg.deco-on{background:linear-gradient(135deg,#1a0a2e 0%,#3d1b5e 30%,#6a2c8e 60%,#4a1d6e 100%)}.page2-bg.lights-on{background:linear-gradient(135deg,#1a0a2e 0%,#2d1b4e 25%,#5a2d7e 55%,#3d1b5e 100%)}.page2-bg.all-on{background:linear-gradient(135deg,#1a0520 0%,#3b0764 20%,#7c3aed 50%,#a855f7 75%,#ec4899 100%)}.page2-bg.cake-phase{background:linear-gradient(135deg,#1a0520 0%,#3b0764 30%,#ec4899 70%,#f472b6 100%)}.page2-bg.messages-phase{background:linear-gradient(135deg,#fce4ec 0%,#f8bbd0 30%,#f48fb1 60%,#ec407a 100%)}.page2-container{z-index:1;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex;position:relative}.toggles-section{flex-direction:column;align-items:center;gap:24px;animation:.8s forwards fadeSlideUp;display:flex}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.toggles-title{color:var(--white);text-shadow:0 0 30px #a855f780;margin-bottom:8px;font-family:Dancing Script,cursive;font-size:2.2rem;font-weight:700}.toggles-subtitle{color:#ffffffb3;margin-bottom:16px;font-size:1rem}.toggles-grid{flex-wrap:wrap;justify-content:center;gap:20px;display:flex}.toggle-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:12px;width:160px;height:160px;transition:all .5s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.toggle-card:before{content:"";opacity:0;background:linear-gradient(135deg,#ec407a33,#a855f733);border-radius:20px;transition:opacity .5s;position:absolute;inset:0}.toggle-card:hover{border-color:#ffffff4d;transform:translateY(-4px)}.toggle-card:hover:before{opacity:1}.toggle-card.activated{border-color:var(--pink-accent);background:#ec407a40;transform:scale(1.05);box-shadow:0 0 30px #ec407a4d,inset 0 0 20px #ec407a1a}.toggle-card.activated:before{opacity:1}.toggle-icon{font-size:2.5rem;transition:transform .5s}.toggle-card.activated .toggle-icon{transform:scale(1.2)rotate(10deg)}.toggle-label{color:#fffc;letter-spacing:.5px;font-size:.9rem;font-weight:600;transition:color .5s}.toggle-card.activated .toggle-label{color:var(--white)}.toggle-status{color:#ffffff80;background:#ffffff1a;border-radius:20px;padding:3px 12px;font-size:.7rem;font-weight:500;transition:all .5s}.toggle-card.activated .toggle-status{background:var(--pink-deep);color:var(--white)}.toggle-check{background:var(--pink-deep);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:absolute;top:8px;right:8px;transform:scale(0)}.toggle-card.activated .toggle-check{transform:scale(1)}.confetti-container{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.confetti-piece{opacity:0;border-radius:2px;width:10px;height:14px;animation:linear infinite confettiFall;position:absolute;top:-20px}@keyframes confettiFall{0%{opacity:0;transform:translateY(0)rotate(0)rotateX(0)}10%{opacity:1}90%{opacity:.8}to{opacity:0;transform:translateY(110vh)rotate(720deg)rotateX(360deg)}}.lights-container{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.fairy-light{filter:blur(1px);border-radius:50%;width:8px;height:8px;animation:ease-in-out infinite twinkle;position:absolute}@keyframes twinkle{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.3)}}.music-notes-container{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.music-note{opacity:0;font-size:1.5rem;animation:linear infinite noteFloat;position:absolute;bottom:-40px}@keyframes noteFloat{0%{opacity:0;transform:translateY(0)translate(0)rotate(0)}15%{opacity:.8}85%{opacity:.3}to{opacity:0;transform:translateY(-110vh)translate(40px)rotate(360deg)}}.balloons-container{pointer-events:none;z-index:2;position:fixed;inset:0;overflow:hidden}.balloon{opacity:0;animation:ease-out forwards balloonRise;position:absolute;bottom:-120px}.balloon-body{filter:drop-shadow(0 4px 8px #00000026);border-radius:50%/40% 40% 60% 60%;width:50px;height:62px;position:relative}.balloon-body:after{content:"";border-left:6px solid #0000;border-right:6px solid #0000;border-top:10px solid inherit;width:0;height:0;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.balloon-string{background:#fff6;width:1px;height:80px;margin:0 auto;position:relative}@keyframes balloonRise{0%{opacity:0;transform:translateY(0)translate(0)}10%{opacity:1}50%{transform:translateY(-60vh)translate(20px)}to{opacity:.8;transform:translateY(-120vh)translate(-10px)}}.anniversary-banner{z-index:100;text-align:center;background:linear-gradient(#0006 0%,#0000 100%);padding:20px 16px;animation:1s cubic-bezier(.34,1.56,.64,1) forwards bannerSlideDown;position:fixed;top:0;left:0;right:0}@keyframes bannerSlideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.banner-text{color:var(--white);text-shadow:0 0 40px #ff69b499,0 0 80px #a855f74d;letter-spacing:2px;font-family:Dancing Script,cursive;font-size:3rem;font-weight:700}.banner-sparkle{font-size:1.5rem;animation:1.5s ease-in-out infinite pulse}.cake-section{z-index:10;flex-direction:column;align-items:center;gap:24px;animation:.8s forwards fadeSlideUp;display:flex}.cake-container{flex-direction:column;justify-content:flex-end;align-items:center;width:200px;height:220px;display:flex;position:relative}.cake{flex-direction:column;align-items:center;width:180px;display:flex;position:relative}.cake-layer{border:2px solid #ffffff73;border-radius:8px 8px 4px 4px;position:relative;box-shadow:inset 0 -6px 12px #00000014}.cake-layer-1{z-index:1;background:linear-gradient(#ffd6e7,#ff9cc3);border-radius:20px;width:180px;height:50px}.cake-layer-2{z-index:2;background:linear-gradient(#fff3cd,#ffdca8);border-radius:20px;width:140px;height:45px;margin-bottom:-15px}.cake-layer-3{z-index:3;background:linear-gradient(#ffe6f1,#ffb3d1);border-radius:45px 45px 15px 15px;width:90px;height:50px;margin-bottom:-20px}.cake-frosting{background:linear-gradient(#fff,#ffe9f5);border-radius:18px;width:88%;height:14px;display:block;position:absolute;top:-8px;left:6%;box-shadow:0 2px 6px #ffffffe6}.cake-frosting:before,.cake-frosting:after{content:"";background:#ffe9f5;border-radius:50%;width:10px;height:10px;position:absolute;bottom:-6px}.cake-frosting:before{left:22%}.cake-frosting:after{right:22%}.candles-row{z-index:2;gap:16px;margin-bottom:-2px;display:flex;position:relative}.candle{flex-direction:column;align-items:center;display:flex}.candle-body{background:linear-gradient(#fff9c4,#ffee58);border-radius:2px;width:6px;height:30px}.candle-flame{filter:drop-shadow(0 0 6px #ff9800)drop-shadow(0 0 12px #ffeb3b);background:radial-gradient(#fff 10%,#ffeb3b 40%,#ff9800 70%,#0000 100%);border-radius:50%/60% 60% 40% 40%;width:10px;height:14px;animation:.3s ease-in-out infinite alternate flicker}@keyframes flicker{0%{transform:scaleY(1)scaleX(1)rotate(-2deg)}to{transform:scaleY(1.1)scaleX(.9)rotate(2deg)}}.candle-flame.blown-out{opacity:0;transition:opacity .5s;animation:none}.cake-text{color:var(--white);text-shadow:0 0 20px #ff69b480;margin-top:16px;font-family:Dancing Script,cursive;font-size:1.4rem;font-weight:600}.cut-cake-btn{color:#4a1942;cursor:pointer;letter-spacing:1px;background:linear-gradient(135deg,gold,#ffb300,#ff8f00);border:none;border-radius:50px;padding:16px 48px;font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;transition:all .4s;animation:2s ease-in-out infinite cakeBtnPulse;box-shadow:0 4px 24px #ffd70066}.cut-cake-btn:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 8px 36px #ffd70099}@keyframes cakeBtnPulse{0%,to{box-shadow:0 4px 24px #ffd70066}50%{box-shadow:0 4px 36px #ffd700b3}}.cake.cut .cake-layer-1,.cake.cut .cake-layer-2,.cake.cut .cake-layer-3{animation:.8s forwards cakeSplit}@keyframes cakeSplit{0%{opacity:1;transform:scaleX(1)}50%{transform:scaleX(1.1)}to{opacity:1;transform:scaleX(1)}}.love-messages-section{z-index:10;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:680px;animation:.8s forwards fadeSlideUp;display:flex}.p2-white-strip{-webkit-backdrop-filter:blur(20px);text-align:center;background:#ffffffed;border:1px solid #fff9;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;width:90%;max-width:680px;min-height:220px;padding:48px 40px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #ec407a26,0 2px 8px #0000000d}.finale-slideshow{aspect-ratio:3/4;border:1px solid #ffffff80;border-radius:18px;width:min(100%,330px);margin-top:10px;position:relative;overflow:hidden;box-shadow:0 14px 36px #ec407a47}.finale-slide-image{object-fit:cover;width:100%;height:100%;transition:opacity .35s;animation:.8s fadeSlideIn;display:block}.finale-slide-image.loading{opacity:.7}.finale-slide-image.loaded{opacity:1}@keyframes fadeSlideIn{0%{opacity:.35;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}.finale-slide-overlay{color:#fff;text-align:left;background:linear-gradient(#0000,#2a0a236b,#2a0a23db);padding:18px 14px 16px;position:absolute;inset:auto 0 0}.finale-slide-title{text-shadow:0 2px 10px #0006;margin-bottom:2px;font-family:Dancing Script,cursive;font-size:1.55rem;line-height:1.1}.finale-slide-caption{letter-spacing:.2px;opacity:.95;font-size:.8rem;font-weight:500}.finale-slide-dots{gap:6px;display:flex;position:absolute;top:10px;right:10px}.finale-slide-dot{background:#ffffff8c;border-radius:50%;width:7px;height:7px;transition:transform .3s,background .3s}.finale-slide-dot.active{background:#ffd9ec;transform:scale(1.3)}.celebration-burst{z-index:200;pointer-events:none;animation:.6s ease-out forwards burstFlash;position:fixed;inset:0}@keyframes burstFlash{0%{background:#ffd70099}to{background:0 0}}.page-transition{background:var(--pink-deep);z-index:1000;justify-content:center;align-items:center;animation:1.2s ease-in-out transitionPulse;display:flex;position:fixed;inset:0}@keyframes transitionPulse{0%{opacity:0}30%{opacity:1}70%{opacity:1}to{opacity:0}}.transition-heart{font-size:4rem;animation:.6s ease-in-out infinite pulse}@media (max-width:768px){.toggles-grid{gap:14px}.toggle-card{width:140px;height:140px}.toggle-icon{font-size:2rem}.banner-text{font-size:2.2rem}.cake-container{transform:scale(.85)}}@media (max-width:600px){.white-strip,.p2-white-strip{border-radius:20px;width:92%;min-height:180px;padding:36px 20px}.message-text{font-size:1.5rem}.message-emoji{font-size:2rem}.option-btn{padding:12px 28px;font-size:.9rem}.toggles-title{font-size:1.8rem}.toggles-subtitle{font-size:.85rem}.toggle-card{width:120px;height:120px}.toggle-icon{font-size:1.8rem}.toggle-label{font-size:.75rem}.toggle-status{font-size:.6rem}.banner-text{letter-spacing:1px;font-size:1.8rem}.banner-sparkle{font-size:1.2rem}.cake-container{transform:scale(.75)}.cut-cake-btn{padding:14px 36px;font-size:1rem}.finale-slideshow{border-radius:16px;width:min(100%,280px)}.finale-slide-overlay{padding:14px 12px}.finale-slide-title{font-size:1.35rem}.finale-slide-caption{font-size:.75rem}}@media (max-width:380px){.white-strip,.p2-white-strip{padding:28px 14px}.message-text{font-size:1.3rem}.toggles-grid{flex-direction:column;align-items:center}.toggle-card{flex-direction:row;gap:16px;width:90%;max-width:200px;height:100px;padding:0 20px}.banner-text{font-size:1.5rem}}
