:root{--bg-1: #f7eeff;--bg-2: #ffe6f7;--card: rgba(255, 255, 255, .84);--text: #2f1538;--muted: #6e567c;--pink: #ff5fae;--pink-dark: #b93d9c;--rose: #d798ff;--gold: #cda0ff;--shadow: 0 24px 60px rgba(128, 70, 160, .24);--radius: 28px}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:Manrope,sans-serif;color:var(--text);background:radial-gradient(circle at 15% 20%,rgba(255,122,196,.3),transparent 45%),radial-gradient(circle at 85% 15%,rgba(168,116,255,.32),transparent 45%),radial-gradient(circle at 50% 90%,rgba(210,110,255,.24),transparent 55%),linear-gradient(160deg,var(--bg-1),var(--bg-2));overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 30% 70%,rgba(255,255,255,.35),transparent 45%),radial-gradient(circle at 75% 35%,rgba(255,255,255,.25),transparent 50%);opacity:.7}.page{min-height:100vh;display:grid;place-items:center;padding:24px;transition:opacity .42s ease,transform .42s ease}.music-player{position:fixed;top:10px;right:10px;z-index:80;display:grid;grid-template-columns:42px 1fr;gap:6px 8px;align-items:center;width:min(280px,calc(100vw - 20px));padding:7px;border-radius:12px;background:#ffffffeb;border:1px solid rgba(255,255,255,.82);box-shadow:0 14px 34px #6f454a38;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.music-thumb{width:42px;height:42px;border-radius:9px;object-fit:cover;box-shadow:0 8px 18px #6f454a3d}.music-meta{min-width:0}.music-title,.music-state{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-title{font-size:.8rem;font-weight:700;color:#3a1e32}.music-state{margin-top:1px;font-size:.68rem;color:#7a5a6f}.music-controls{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.music-btn{border:0;border-radius:999px;height:26px;padding:0 8px;font:inherit;font-size:.68rem;font-weight:700;cursor:pointer;color:#4f3945;background:#fff;box-shadow:0 4px 10px #6f454a1f}.music-btn:hover{transform:translateY(-1px)}.music-btn-play{color:#fff;background:linear-gradient(135deg,var(--pink),var(--pink-dark))}.music-btn:disabled{opacity:.55;cursor:not-allowed}.is-entrance{overflow:hidden}.is-entrance .page,.is-loading .page{opacity:0;transform:scale(.985);pointer-events:none}.is-loading .entrance{opacity:0;visibility:hidden;pointer-events:none}.entrance{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,rgba(255,141,203,.22),transparent 48%),radial-gradient(circle at 82% 18%,rgba(162,108,255,.24),transparent 48%),#fcf5ffb8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:opacity .5s ease,visibility .5s ease}.entrance.is-hidden{opacity:0;visibility:hidden}.entrance-shell{width:min(760px,100%);display:grid;gap:18px;justify-items:center}.door-frame{position:relative;width:min(520px,100%);aspect-ratio:1.5 / 1;border-radius:20px;border:10px solid rgba(130,91,82,.85);background:linear-gradient(180deg,#fce8ee,#fff9f7);box-shadow:0 18px 45px #5028322e;overflow:hidden;perspective:1200px}.door-frame:after{content:"";position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px;border-radius:28px;border:1px solid rgba(255,255,255,.35);pointer-events:none}.door-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 35%,rgba(205,160,255,.68),transparent 40%),radial-gradient(circle at 50% 80%,rgba(255,120,195,.3),transparent 50%);opacity:.5;transition:opacity .9s ease}.flower-burst{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:1}.petal{position:absolute;width:14px;height:10px;border-radius:12px 12px 12px 2px;transform:rotate(-20deg);opacity:0;box-shadow:inset 0 0 0 1px #ffffff2e;animation:petalFly 1.3s cubic-bezier(.2,.8,.25,1) forwards}.petal:after{content:"";position:absolute;top:2px;right:6px;bottom:2px;left:2px;border-radius:inherit;background:#ffffff38;filter:blur(1px)}.door{position:absolute;top:0;width:50%;height:100%;background:linear-gradient(180deg,#ffffff14,#0000000f),repeating-linear-gradient(90deg,#74453cf2 0,#74453cf2 20px,#824e45f2 20px,#824e45f2 40px);border-inline:2px solid rgba(255,238,225,.2);box-shadow:inset 0 0 0 4px #ffebdc14;transition:transform 1.2s cubic-bezier(.18,.85,.2,1),box-shadow .9s ease;transform-style:preserve-3d}.door-left{left:0;transform-origin:left center}.door-right{right:0;transform-origin:right center}.door:before{content:"";position:absolute;top:14px;right:12px;bottom:14px;left:12px;border-radius:12px;border:2px solid rgba(255,236,222,.22)}.door-knob{position:absolute;top:50%;width:14px;height:14px;margin-top:-7px;border-radius:50%;background:linear-gradient(180deg,#ffd58f,#c88d37);box-shadow:0 0 0 2px #ffe9c64d}.door-left .door-knob{right:18px}.door-right .door-knob{left:18px}.entrance-copy{width:min(520px,100%);text-align:center;background:#ffffffdb;border:1px solid rgba(255,255,255,.7);border-radius:22px;box-shadow:0 14px 32px #b555781f;padding:18px 16px 16px;position:relative}.entrance-copy:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:16px;border:1px solid rgba(255,160,190,.18);pointer-events:none}.entrance-label{margin:0 0 8px;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:700}.entrance-copy h2{margin:0;font-family:Playfair Display,serif;font-size:clamp(1.7rem,4vw,2.2rem);color:#2c1923}.entrance-copy p{margin:10px auto 14px;color:var(--muted);max-width:44ch;line-height:1.5}.entrance.opening .door-left{transform:rotateY(-112deg);box-shadow:inset 0 0 0 4px #ffebdc14,12px 0 25px #00000026}.entrance.opening .door-right{transform:rotateY(112deg);box-shadow:inset 0 0 0 4px #ffebdc14,-12px 0 25px #00000026}.entrance.opening .door-glow{opacity:1}.teddy-stage{width:min(520px,100%);min-height:108px;position:relative;display:flex;justify-content:center;align-items:end;gap:22px;margin-top:-6px}.teddy{position:relative;width:82px;height:88px;filter:drop-shadow(0 10px 14px rgba(111,69,74,.16));animation:teddyBob 2.8s ease-in-out infinite}.teddy-small{width:66px;height:72px;animation-delay:.35s}.teddy .ear{position:absolute;top:6px;width:22px;height:22px;border-radius:50%;background:#d4a07f}.teddy .ear:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:50%;background:#efc4ab}.teddy .ear.left{left:8px}.teddy .ear.right{right:8px}.teddy .face{position:absolute;top:10px;left:50%;width:56px;height:52px;transform:translate(-50%);border-radius:50%;background:linear-gradient(180deg,#ddb08f,#cd9574)}.teddy .eye{position:absolute;top:18px;width:5px;height:5px;border-radius:50%;background:#2c1b20}.teddy .eye.left{left:16px}.teddy .eye.right{right:16px}.teddy .snout{position:absolute;left:50%;top:23px;width:22px;height:16px;transform:translate(-50%);border-radius:12px;background:#f4d3be}.teddy .nose{position:absolute;left:50%;top:27px;width:8px;height:6px;transform:translate(-50%);border-radius:50% 50% 60% 60%;background:#6d4348}.teddy .blush{position:absolute;top:27px;width:10px;height:6px;border-radius:999px;background:#ff7aa059}.teddy .blush.left{left:8px}.teddy .blush.right{right:8px}.teddy .body{position:absolute;left:50%;bottom:0;width:54px;height:44px;transform:translate(-50%);border-radius:48% 48% 42% 42%;background:linear-gradient(180deg,#d7a483,#c28c6b)}.teddy .body:before{content:"";position:absolute;left:50%;top:10px;width:24px;height:18px;transform:translate(-50%);border-radius:50%;background:#f0cfbb}.teddy .bow{position:absolute;left:50%;top:48px;width:10px;height:10px;transform:translate(-50%);border-radius:50%;background:#ef5e93}.teddy .bow:before,.teddy .bow:after{content:"";position:absolute;top:1px;width:11px;height:8px;background:#ff7aa8;border-radius:70% 30%}.teddy .bow:before{right:7px;transform:rotate(-18deg)}.teddy .bow:after{left:7px;transform:scaleX(-1) rotate(-18deg)}.teddy-small .face{width:46px;height:42px}.teddy-small .body{width:42px;height:34px}.teddy-small .ear{width:18px;height:18px}.tiny-heart{position:absolute;width:10px;height:10px;transform:rotate(45deg);background:#ff5f928c;border-radius:2px;animation:floatHeart 3.2s ease-in-out infinite}.tiny-heart:before,.tiny-heart:after{content:"";position:absolute;width:10px;height:10px;background:inherit;border-radius:50%}.tiny-heart:before{top:-5px;left:0}.tiny-heart:after{left:5px;top:0}.tiny-heart.h1{left:20%;top:18px}.tiny-heart.h2{right:22%;top:8px;animation-delay:.7s}.tiny-heart.h3{left:50%;top:2px;animation-delay:1.2s}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,rgba(255,141,203,.22),transparent 45%),radial-gradient(circle at 80% 15%,rgba(162,108,255,.24),transparent 45%),#fcf5ffb8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .42s ease,visibility .42s ease}.loading-screen.is-active{opacity:1;visibility:visible;pointer-events:auto}.loading-screen.is-hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-card{width:min(460px,100%);background:#ffffffe6;border:1px solid rgba(255,255,255,.7);border-radius:24px;box-shadow:0 18px 40px #b555782e;padding:22px 20px 20px;text-align:center;animation:fadeUp .5s ease-out both}.loading-label{margin:0 0 8px;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:700}.loading-title{margin:0;font-family:Playfair Display,serif;font-size:clamp(1.6rem,4vw,2rem);color:#2e1824}.loading-text{margin:10px 0 14px;color:var(--muted);line-height:1.5}.loading-bar{height:10px;width:100%;background:#e8427914;border-radius:999px;overflow:hidden;border:1px solid rgba(232,66,121,.08)}.loading-bar span{display:block;height:100%;width:0%;border-radius:inherit;background:linear-gradient(135deg,var(--pink),#ff84ab);box-shadow:0 0 20px #e842794d;transition:width .18s linear}.loading-percent{margin:10px 0 0;color:#8a5f70;font-weight:700;font-size:.95rem}.card{width:min(700px,100%);position:relative;background:var(--card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.72);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 24px 26px;text-align:center;animation:fadeUp .6s ease-out both;overflow:hidden}.card.is-changing{animation:swapIn .32s ease}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;background:radial-gradient(circle at 12% 10%,rgba(255,255,255,.55),transparent 32%),radial-gradient(circle at 88% 12%,rgba(255,213,137,.18),transparent 35%)}.eyebrow{margin:0 0 10px;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}h1{margin:0;font-family:Playfair Display,serif;font-weight:700;font-size:clamp(2rem,5vw,3rem);line-height:1.05;color:#2e1824}.message{margin:14px auto 0;max-width:52ch;line-height:1.6;color:var(--muted);font-size:1rem}.illustration{position:relative;width:190px;height:130px;margin:24px auto 8px}.heart{position:absolute;width:68px;height:68px;background:linear-gradient(145deg,#ff7ba3,#ff4b84);transform:rotate(-45deg);border-radius:14px 14px 4px 4px;box-shadow:0 12px 24px #e8427947;animation:pulse 2.2s ease-in-out infinite}.heart:before,.heart:after{content:"";position:absolute;width:68px;height:68px;background:inherit;border-radius:50%}.heart:before{top:-34px;left:0}.heart:after{top:0;left:34px}.heart-left{left:28px;top:30px}.heart-right{left:92px;top:12px;transform:rotate(-45deg) scale(.9);filter:saturate(.9);animation-delay:.25s}.sparkle{position:absolute;width:10px;height:10px;background:var(--gold);transform:rotate(45deg);border-radius:2px;animation:twinkle 1.8s ease-in-out infinite}.s1{top:14px;left:18px}.s2{top:94px;left:164px;width:8px;height:8px;animation-delay:.3s}.s3{top:6px;left:146px;width:12px;height:12px;animation-delay:.6s}.mini-teddy-row{display:flex;align-items:center;justify-content:center;gap:10px;margin:4px 0 8px}.mini-teddy{width:24px;height:20px;border-radius:12px 12px 10px 10px;background:linear-gradient(180deg,#d7a483,#c58f70);position:relative;box-shadow:0 4px 10px #6f454a1f}.mini-teddy:before,.mini-teddy:after{content:"";position:absolute;top:-6px;width:10px;height:10px;border-radius:50%;background:#d7a483}.mini-teddy:before{left:1px}.mini-teddy:after{right:1px}.mini-ribbon{width:34px;height:8px;border-radius:999px;background:linear-gradient(90deg,#ff5f9226,#ff5f928c,#ff5f9226)}.actions{position:relative;width:min(420px,100%);margin:10px auto 0;min-height:96px}.btn{border:0;border-radius:999px;padding:12px 18px;font:inherit;font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease,opacity .18s ease}.btn:focus-visible{outline:3px solid rgba(255,93,143,.35);outline-offset:2px}.btn-yes{color:#fff;background:linear-gradient(135deg,var(--pink),var(--pink-dark));box-shadow:0 10px 24px #e842794d}.btn-yes:hover{transform:translateY(-2px);box-shadow:0 14px 28px #e842795c}.btn-reset-floating{position:fixed;right:18px;bottom:18px;z-index:60;color:#5a2d3a;background:#fffffff2;border:1px solid rgba(139,107,120,.28);box-shadow:0 10px 26px #6f454a33}.btn-reset-floating:hover{transform:translateY(-2px)}.btn-no{color:#4f3945;background:#ffffffeb;border:1px solid rgba(139,107,120,.15);position:absolute;top:52px;left:calc(50% + 46px);z-index:2;transition:left .12s ease,top .12s ease,transform .12s ease,opacity .12s ease,filter .12s ease}.actions .btn-yes{position:absolute;top:0;left:50%;transform:translate(-50%);z-index:3}.hint{margin:14px 0 0;color:var(--muted);font-size:.92rem}.bg-hearts{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.heart-burst-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;pointer-events:none;overflow:hidden}.flower-screen-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:36;pointer-events:none;overflow:hidden}.burst-heart{position:absolute;width:16px;height:16px;transform:rotate(45deg);border-radius:3px;opacity:0;animation:screenHeartBurst 1.7s cubic-bezier(.18,.85,.25,1) forwards;box-shadow:0 4px 10px #e842792e}.burst-heart:before,.burst-heart:after{content:"";position:absolute;width:16px;height:16px;background:inherit;border-radius:50%}.burst-heart:before{top:-8px;left:0}.burst-heart:after{left:8px;top:0}.screen-petal{position:absolute;width:16px;height:12px;border-radius:14px 14px 14px 2px;opacity:0;box-shadow:inset 0 0 0 1px #ffffff2e;animation:screenPetalBurst 2.2s cubic-bezier(.18,.85,.25,1) forwards}.screen-petal:after{content:"";position:absolute;top:2px;right:6px;bottom:2px;left:2px;border-radius:inherit;background:#fff3;filter:blur(1px)}.bg-hearts span{position:absolute;width:14px;height:14px;background:#ff5d8f29;transform:rotate(45deg);border-radius:2px;animation:drift 12s linear infinite}.bg-hearts span:before,.bg-hearts span:after{content:"";position:absolute;width:14px;height:14px;background:inherit;border-radius:50%}.bg-hearts span:before{top:-7px;left:0}.bg-hearts span:after{left:7px;top:0}.bg-hearts span:nth-child(1){left:8%;top:105%;animation-duration:13s}.bg-hearts span:nth-child(2){left:24%;top:108%;animation-duration:10s;animation-delay:-2s}.bg-hearts span:nth-child(3){left:42%;top:106%;animation-duration:11s;animation-delay:-4s}.bg-hearts span:nth-child(4){left:60%;top:107%;animation-duration:14s;animation-delay:-6s}.bg-hearts span:nth-child(5){left:78%;top:104%;animation-duration:12s;animation-delay:-3s}.bg-hearts span:nth-child(6){left:91%;top:109%;animation-duration:9s;animation-delay:-5s}.celebrate .card{animation:pop .45s ease-out both}.celebrate h1{color:#d8336f}.celebrate .message{color:#533b47}.celebrate .hint{color:#d8336f;font-weight:700}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes swapIn{0%{opacity:.65;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(.98)}60%{transform:scale(1.01)}to{transform:scale(1)}}@keyframes pulse{0%,to{transform:rotate(-45deg) scale(1)}50%{transform:rotate(-45deg) scale(1.06)}}@keyframes twinkle{0%,to{opacity:.35;transform:rotate(45deg) scale(.85)}50%{opacity:1;transform:rotate(45deg) scale(1.15)}}@keyframes drift{0%{transform:translateY(0) rotate(45deg) scale(1);opacity:0}10%{opacity:1}90%{opacity:.7}to{transform:translateY(-120vh) rotate(45deg) scale(1.2);opacity:0}}@keyframes teddyBob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes floatHeart{0%,to{transform:rotate(45deg) translateY(0);opacity:.45}50%{transform:rotate(45deg) translateY(-6px);opacity:1}}@keyframes petalFly{0%{opacity:0;transform:translate(var(--sx, 0),var(--sy, 0)) rotate(var(--rot, 0deg)) scale(.6)}12%{opacity:1}to{opacity:0;transform:translate(calc(var(--sx, 0px) + var(--tx, 0px)),calc(var(--sy, 0px) + var(--ty, 0px))) rotate(calc(var(--rot, 0deg) + var(--spin, 120deg))) scale(1)}}@keyframes screenHeartBurst{0%{opacity:0;transform:translate(var(--sx, 0px),var(--sy, 0px)) rotate(45deg) scale(.6)}10%{opacity:1}to{opacity:0;transform:translate(calc(var(--sx, 0px) + var(--tx, 0px)),calc(var(--sy, 0px) + var(--ty, 0px))) rotate(45deg) scale(var(--scale, 1.1))}}@keyframes screenPetalBurst{0%{opacity:0;transform:translate(var(--sx, 0px),var(--sy, 0px)) rotate(var(--rot, 0deg)) scale(.55)}12%{opacity:1}to{opacity:0;transform:translate(calc(var(--sx, 0px) + var(--tx, 0px)),calc(var(--sy, 0px) + var(--ty, 0px))) rotate(calc(var(--rot, 0deg) + var(--spin, 180deg))) scale(var(--scale, 1))}}@media (max-width: 620px){.music-player{top:8px;right:8px;left:8px;width:auto;max-width:none}.door-frame{border-width:8px;border-radius:16px}.card{padding:22px 18px;border-radius:22px}.teddy-stage{gap:14px;min-height:92px}.teddy-big{transform:scale(.9)}.teddy-small{transform:scale(.88)}.actions{min-height:118px}.actions .btn-yes{top:0}.btn-no{top:60px;left:calc(50% - 38px)}.btn-reset-floating{right:12px;bottom:12px;padding:10px 15px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}
