.fade,.unwrap-stage{animation:.6s fadeIn}.card,.scratch-card{background:rgba(255,255,255,.08)}.card-face,.envelope-flap{backface-visibility:hidden}.blur,.envelope-mouth,.envelope::after,.promise-intro-sub,.promise-line,.promise-title-badge,.unwrap::before,.wax-seal::after,.wheel::after,.wheel::before{pointer-events:none}.blush-stage,.calendar-unit,.counter-stage,.entry-stage,.gift-stage,.password-box,.password-box input,.preload-stage,.promise-stage,.ribbon-text,.scratch-text,.unwrap-stage,.wheel-result-box,.wheel-stage{text-align:center}#hx-canvas,.memory-stage,.promise-stage,.scratch-wrapper,.truth-stage,.wheel-container,body.lock-scroll{touch-action:none}.paper-text{overscroll-behavior:contain}#unwrapBtn,button{padding:14px 28px}.counter-stage,.memory-stage,.preload-stage{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.scratch-text,.unwrap{display:flex;align-items:center}#wheelResult{display:block;margin-top:18px;width:100%;max-width:520px}.unwrap{min-height:100svh;width:100%;color:#fff;justify-content:center;font-family:system-ui,-apple-system,sans-serif}.promise-stage,.promise-title-badge{font-family:"Cormorant Garamond",serif}.unwrap-stage{width:100%;max-width:680px;padding:clamp(20px,4vw,40px);display:flex;flex-direction:column}h1,h2,p{margin:0 0 16px}button{background:#ec4899;border:none;color:#fff;border-radius:999px;font-size:16px;cursor:pointer}button.secondary{background:0 0;border:1px solid rgba(255,255,255,.3)}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.scratch-card{padding:80px 40px;border-radius:20px;cursor:pointer}.counter{font-size:32px;font-weight:600}.card{padding:32px;border-radius:16px;margin-top:20px}.ribbon-wrap,.scratch-wrapper{margin:0 auto;border-radius:20px;width:100%;overflow:hidden}.scratch-wrapper{position:relative;max-width:520px;aspect-ratio:16/10;background:#000}.scratch-text{position:absolute;inset:0;justify-content:center;font-size:18px;padding:24px;z-index:1}.card-face,.ribbon-wrap{display:flex;align-items:center}#scratchCanvas{position:absolute;inset:0;z-index:2;width:100%;height:100%}.ribbon-wrap{position:relative;max-width:360px;height:240px;background:linear-gradient(135deg,#111827,#020617);justify-content:center}.gift-box{background:rgba(255,255,255,.08)}.ribbon{top:50%;left:0;width:100%;height:28px;transform:translateY(-50%);cursor:grab;transition:opacity .3s}.envelope-flap{clip-path:polygon(0 0,100% 0,50% 100%);transform-origin:top center}.ribbon-text{position:absolute;bottom:18px;width:100%;font-size:14px;opacity:.7}.blur{filter:blur(6px)}.password-overlay{position:fixed;inset:0;backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom);z-index:999}.password-box{background:#020617;width:90%;max-width:360px}.entry-stage{animation:.8s fadeIn}.entry-text{opacity:.65;margin-bottom:24px;font-size:15px}.entry-sub{opacity:.35;margin-top:22px;font-size:13px}.envelope{box-shadow:0 24px 50px rgba(0,0,0,.45),inset 0 0 0 1px rgba(0,0,0,.04)}.envelope::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(0,0,0,.012),rgba(0,0,0,.012) 1px,transparent 1px,transparent 3px);opacity:.8}.envelope-paper{inset:12px;background:#fffdfa;box-shadow:0 10px 18px rgba(0,0,0,.12),inset 0 0 0 1px rgba(0,0,0,.04)}.envelope-flap{background:#efe9dd}.wax-seal{filter:drop-shadow(0 12px 18px rgba(0,0,0,.45));filter:none!important}.wax-seal:active{transform:translateX(-50%) rotate(-6deg) scale(.95)}.wax-seal svg{transition:transform .35s,opacity .35s;transform-origin:center;filter:none;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.35),transparent 55%)}@keyframes waxCrack{0%{transform:scale(1) rotate(0);opacity:1}40%{transform:scale(1.08) rotate(-4deg)}100%{transform:scale(.4) rotate(12deg);opacity:0}}.envelope-front{box-shadow:inset 0 1px 0 rgba(0,0,0,.04)}.envelope-paper{box-shadow:0 12px 20px rgba(0,0,0,.12),inset 0 0 0 1px rgba(0,0,0,.04)}.envelope{position:relative;width:360px;height:220px;margin:0 auto;box-shadow:0 28px 60px rgba(0,0,0,.45),0 8px 16px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.6),inset 0 -1px 0 rgba(0,0,0,.04);overflow:hidden;box-shadow:0 22px 40px rgba(0,0,0,.35),0 8px 12px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.5)}.envelope-flap{position:absolute;top:0;left:0;width:100%;height:120px;transition:transform .7s cubic-bezier(.22,.61,.36,1);z-index:4}.envelope.open .envelope-flap{transform:rotateX(175deg)}.envelope-front{position:absolute;bottom:0;left:0;width:100%;height:60%;border-radius:0 0 10px 10px;z-index:2}.envelope-flap{box-shadow:inset 0 -1px 0 rgba(0,0,0,.06)}.envelope-front{box-shadow:inset 0 2px 0 rgba(255,255,255,.4),inset 0 -1px 0 rgba(0,0,0,.06)}.envelope-paper{position:absolute;left:14px;right:14px;bottom:14px;height:160px;transform:translateY(60px);transition:transform .8s cubic-bezier(.22,.61,.36,1);z-index:1;box-shadow:0 18px 30px rgba(0,0,0,.18),inset 0 0 0 1px rgba(0,0,0,.04)}.wax-seal::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 1px 2px rgba(0,0,0,.25),inset 0 -2px 3px rgba(0,0,0,.25),inset 0 2px 2px rgba(255,255,255,.25)}.wax-seal svg defs radialGradient stop:first-child{stop-color:#ffb3b3}.wax-seal svg path{filter:drop-shadow(0 1px 1px rgba(0,0,0,.35)) drop-shadow(0 0 0 rgba(0,0,0,0));stroke:rgba(255,255,255,0.35);stroke-width:.6px}.wax-seal.crack svg{animation:.35s forwards waxCrack;filter:drop-shadow(0 2px 3px rgba(0,0,0,.35))}.wax-seal::after,.wax-seal::before{display:none!important}.envelope{background:linear-gradient(180deg,#f6efe4 0,#eadfce 55%,#e4d6c2 100%);border-radius:10px;box-shadow:0 34px 60px rgba(0,0,0,.45),0 12px 20px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.7),inset 0 -2px 0 rgba(0,0,0,.06)}.envelope-flap{background:linear-gradient(180deg,#f2e7d8 0,#e7d7c3 100%);box-shadow:inset 0 -2px 3px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.5)}.envelope-front{background:linear-gradient(180deg,#eadfce 0,#e2d3be 100%);box-shadow:inset 0 2px 0 rgba(255,255,255,.35),inset 0 -2px 0 rgba(0,0,0,.08)}.envelope-mouth{position:absolute;top:96px;left:0;width:100%;height:28px;z-index:3;background:linear-gradient(to bottom,rgba(0,0,0,.28),rgba(0,0,0,0))}.envelope-paper{background:linear-gradient(180deg,#fffef9 0,#f3eee4 100%);box-shadow:0 22px 32px rgba(0,0,0,.22),inset 0 0 0 1px rgba(0,0,0,.04),inset 0 2px 0 rgba(255,255,255,.6);border-radius:4px}.envelope-paper::after{content:"";position:absolute;inset:0;border-radius:4px;box-shadow:inset 0 0 8px rgba(0,0,0,.05);pointer-events:none}.envelope.open .envelope-paper{clip-path:inset(22px 0 0 0);transform:translateY(-6px)}.password-overlay{background:rgba(0,0,0,.55);backdrop-filter:blur(8px);animation:.5s fadeIn}.password-box{background:linear-gradient(180deg,#050712 0,#020617 100%);padding:36px 32px 40px;border-radius:18px;box-shadow:0 30px 60px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.06)}.password-title{font-size:17px;font-weight:500;margin-bottom:8px}.password-sub{font-size:14px;opacity:.55;margin-bottom:22px}.password-box input{width:100%;margin-top:16px;background:rgba(255,255,255,.08);color:#fff;padding:14px 16px;border-radius:12px;border:none;font-size:16px;letter-spacing:1px;outline:0;transition:background .3s,box-shadow .3s}.password-box input::placeholder{color:rgba(255,255,255,.35)}.password-box input:focus{background:rgba(255,255,255,.12);box-shadow:0 0 0 2px rgba(236,72,153,.25)}.password-hint{font-size:12px;opacity:.35;margin-top:10px;margin-bottom:24px}.password-box button{margin-top:16px;background:linear-gradient(135deg,#ec4899,#f472b6);border-radius:999px;font-size:15px;font-weight:500;box-shadow:0 10px 18px rgba(236,72,153,.35),inset 0 1px 0 rgba(255,255,255,.35);transition:transform .2s,box-shadow .2s}.card-face,.flip-unit span{font-weight:600;letter-spacing:1px}.bloom-btn:hover,.password-box button:hover{transform:translateY(-1px)}.password-box button:active{transform:translateY(0);box-shadow:0 6px 12px rgba(236,72,153,.3)}.scratch-hidden-image{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;border-radius:20px;z-index:0}@media (max-width:480px){.unwrap-stage{padding:24px 16px;display:flex;flex-direction:column;align-items:center}.entry-stage{width:100%;display:flex;flex-direction:column;align-items:center}.envelope{width:100%;max-width:340px}}.flip-grid{display:flex;flex-direction:column;gap:18px;align-items:center}.flip-row{display:flex;gap:14px}.flip-row.small{gap:12px}.flip-unit{background:rgba(255,255,255,.06);border-radius:14px;padding:18px 16px;min-width:78px;box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 10px 20px rgba(0,0,0,.35);transition:transform .6s}.flip-unit span{display:block;font-size:28px}.flip-row.small .flip-unit span{font-size:22px}.flip-unit label{font-size:11px;opacity:.5;margin-top:4px;display:block}.flip-unit.flip{transform:rotateX(360deg)}.counter-title{font-size:18px;opacity:.85;margin-bottom:34px}.calendar-grid{display:flex;justify-content:center;gap:18px;margin-bottom:18px}.calendar-grid.small{gap:14px}.calendar-unit{perspective:1200px}.calendar-card{position:relative;width:88px;height:78px;transform-style:preserve-3d}.calendar-grid.small .calendar-card{width:78px;height:68px}.card-face{position:absolute;inset:0;background:linear-gradient(180deg,#0b1220 0,#020617 100%);border-radius:16px;justify-content:center;font-size:30px;box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 14px 26px rgba(0,0,0,.55)}.blush-final,.memory-heading{font-weight:500}.calendar-grid.small .card-face{font-size:24px}.card-back{transform:rotateX(180deg)}.calendar-card.flip{animation:.7s cubic-bezier(.22,.61,.36,1) calendarFlip}@keyframes calendarFlip{from{transform:rotateX(0)}to{transform:rotateX(-180deg)}}.calendar-label{display:block;margin-top:8px;font-size:11px;opacity:.45}.counter-sub{margin:28px 0 24px;font-size:14px;opacity:.5}.memory-stage,.truth-stage{text-align:center;max-width:520px;margin:0 auto}.memory-title{font-size:18px;opacity:.85;margin-bottom:40px}.memory-card{background:rgba(255,255,255,.06);border-radius:22px;padding:40px 32px;box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 24px 50px rgba(0,0,0,.45);animation:.6s fadeIn}.memory-date{font-size:13px;opacity:.5;margin-bottom:12px}.memory-heading{font-size:22px;margin-bottom:14px}.memory-text{font-size:15px;opacity:.75;max-width:100%;overflow-wrap:break-word;word-break:break-word;line-height:1.5;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.gift-box,.truth-result,.unwrap{overflow:hidden}.memory-hint{margin-top:28px;font-size:12px;opacity:.35}.memory-card.fade-out{opacity:0;transform:translateY(12px);transition:opacity .4s,transform .4s}.memory-card.fade-in{opacity:1;transform:translateY(0);transition:opacity .4s,transform .4s}.memory-image-wrap{margin:22px 0 20px;border-radius:16px;overflow:hidden;background:rgba(255,255,255,.04);box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 14px 28px rgba(0,0,0,.45)}.exit-btn,.wheel,.wheel::after,.wheel::before{border-radius:50%}.memory-image-wrap img{width:100%;height:auto;display:block;object-fit:cover;max-height:320px;transition:transform .6s}@media (hover:hover){.memory-image-wrap img:hover{transform:scale(1.02)}}.memory-image-wrap.loading{min-height:220px;display:flex;align-items:center;justify-content:center;background:linear-gradient(110deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 37%,rgba(255,255,255,.04) 63%);background-size:200% 100%;animation:1.2s linear infinite shimmer}@keyframes shimmer{to{background-position:-200% 0}}.memory-image-wrap.loading img{opacity:0}.preload-stage{max-width:420px;margin:0 auto;animation:.6s fadeIn}.preload-sub{font-size:14px;opacity:.6}.preload-fill{transition:width .4s}.preload-percent{font-size:13px;opacity:.5}.heart-loader{width:120px;margin:30px auto 20px}.scratch-stage #scratch-cta,.wheel-result{margin-top:20px}.heart-loader svg{width:100%;display:block}#heartFill{transition:transform .4s;animation:2s linear infinite wave;transform-origin:bottom}@keyframes wave{0%,100%{transform:translateX(0)}50%{transform:translateX(-6px)}}.heart-pulse{animation:2.4s ease-in-out infinite pulseSlow;transform-origin:center}@keyframes pulseSlow{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes pulseMid{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}@keyframes pulseFast{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes waveMove{0%,100%{d:path("M0 90 Q25 88 50 90 T100 90 V90 H0 Z")}50%{d:path("M0 88 Q25 92 50 88 T100 90 V90 H0 Z")}}#heartWave{animation:1.8s ease-in-out infinite waveMove}.wheel-stage{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px}.wheel-title{font-size:18px;opacity:.85;margin-bottom:30px}.wheel-result{font-size:16px;opacity:.85;min-height:22px}.wheel{width:100%;height:100%;background:conic-gradient(#ec4899 0deg 72deg,#f472b6 72deg 144deg,#fb7185 144deg 216deg,#f43f5e 216deg 288deg,#e11d48 288deg 360deg);transition:transform 4s cubic-bezier(.22,.61,.36,1);box-shadow:0 24px 40px rgba(0,0,0,.45),inset 0 0 0 6px rgba(255,255,255,.08);box-shadow:0 26px 46px rgba(0,0,0,.5),inset 0 0 0 6px rgba(255,255,255,.08),inset 0 0 24px rgba(0,0,0,.35);outline:rgba(255,255,255,.04) solid 1px}.wheel-pointer{top:-10px;border-bottom:16px solid #fff;position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:18px solid #fff}.blush-line,.promise-line{transform:translateY(8px)}.wheel-container{position:relative;width:240px;height:240px;margin:0 auto}.wheel::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18),transparent 60%);opacity:.4}.wheel::before{content:"";position:absolute;inset:14%;background:radial-gradient(circle,rgba(255,255,255,.25),transparent 65%)}.wheel-result-box{margin-top:18px;display:grid;place-items:center;box-sizing:border-box;font-size:16px;font-weight:500;line-height:1.4;box-shadow:0 14px 28px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.25)}.wheel-result-box p{margin:0}.wheel-result-text{display:block;margin:0;padding:0;line-height:1.4}.counter-stage,.entry-stage,.memory-stage,.preload-stage{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.wheel-stage{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.exit-btn{position:fixed;top:18px;right:18px;z-index:1000;width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-size:20px;text-decoration:none;color:rgba(255,255,255,.85);background:rgba(255,255,255,.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 10px 20px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.35);transition:background .25s,transform .25s,box-shadow .25s}.heart,.truth-heart{color:#fb7185;pointer-events:none}.exit-btn:hover{background:rgba(255,255,255,.14);transform:translateY(-1px);box-shadow:0 14px 28px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.4)}.exit-btn:active{transform:translateY(0);box-shadow:0 8px 16px rgba(0,0,0,.35)}.blush-stage{max-width:520px;margin:0 auto;position:relative}.blush-card{box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 24px 50px rgba(0,0,0,.45);background:rgba(255,255,255,.06);border-radius:22px;padding:44px 36px;box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 26px 52px rgba(0,0,0,.45);margin-bottom:36px;position:relative}.blush-line{font-size:16px;line-height:1.65;opacity:0;margin-bottom:14px}.blush-cta{margin-top:8px}.heart{font-size:16px;opacity:.25;position:fixed;bottom:-24px;opacity:.3;animation:linear forwards floatHeart;filter:blur(.2px)}body.blush-bg{background:radial-gradient(circle at center,rgba(236,72,153,.18),rgba(2,6,23,.95) 65%),linear-gradient(135deg,#020617,#111827);transition:background 2.5s}.blush-card.shimmer{animation:3s ease-in-out infinite blushGlow}.blush-card.inner-glow::before{content:"";position:absolute;inset:0;border-radius:22px;background:radial-gradient(circle at center,rgba(236,72,153,.22),transparent 70%);pointer-events:none}@keyframes blushGlow{50%{box-shadow:0 26px 52px rgba(0,0,0,.45),0 0 28px rgba(236,72,153,.35);box-shadow:0 26px 52px rgba(0,0,0,.45),0 0 42px rgba(236,72,153,.45)}0%,100%{box-shadow:0 26px 52px rgba(0,0,0,.45),0 0 0 rgba(236,72,153,0)}}@keyframes floatHeart{0%,from{transform:translateY(0) scale(.8);opacity:0}10%{opacity:.35;opacity:.4}to{transform:translateY(-110vh) scale(1.2);opacity:0}100%{transform:translateY(-120vh) scale(1.25);opacity:0}}.hx-success.hx-visible,.truth-title{opacity:.9}.truth-sub{opacity:.55}.truth-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.truth-box{position:relative;background:radial-gradient(circle at top,rgba(236,72,153,.35),rgba(255,255,255,.04)),linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.04));box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 24px 44px rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center}.truth-box::after{content:"";position:absolute;inset:0;border-radius:22px;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.35),transparent 55%);opacity:.25;pointer-events:none}.truth-box:hover{transform:translateY(-6px)}.truth-box::before{content:"";position:absolute;inset:-2px;border-radius:24px;background:linear-gradient(135deg,#ec4899,#f472b6,#ec4899);opacity:0;transition:opacity .4s}.truth-box:hover::before{opacity:.35}.truth-box.locked{opacity:.25;pointer-events:none;transform:scale(.95)}.truth-reveal{margin-top:42px;display:none}.truth-reveal.show{display:block}.truth-message{background:rgba(255,255,255,.08);border-radius:24px;padding:42px 34px;box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 28px 60px rgba(0,0,0,.55);font-size:16px;line-height:1.7;opacity:.95}.truth-note{margin-top:22px;font-size:13px;opacity:.45}.truth-next{margin-top:28px}.truth-title{font-size:20px;margin-bottom:6px}.truth-sub{font-size:14px;opacity:.6;margin-bottom:36px}.truth-boxes{display:flex;gap:22px;justify-content:center}.truth-box{width:90px;height:130px;border-radius:22px;cursor:pointer;background:linear-gradient(180deg,#ec4899,#a855f7);box-shadow:0 18px 36px rgba(236,72,153,.45),inset 0 1px 0 rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;transition:transform .4s,box-shadow .4s,opacity .4s}.truth-box:hover{transform:translateY(-6px) scale(1.05)}.truth-number{font-size:26px;font-weight:600;opacity:.9}.truth-box.dim{opacity:.25;transform:scale(.95)}.truth-result.show{display:block;animation:.6s fadeUp}.truth-result .line{font-size:15px;margin-bottom:12px}.truth-cta{margin-top:22px}.delay{animation-delay:.4s}.delay2{animation-delay:.8s}.delay3{animation-delay:1.2s}.delay4{animation-delay:1.6s}@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.truth-result{box-shadow:0 28px 56px rgba(236,72,153,.45);margin-top:42px;padding:36px 32px;border-radius:26px;background:radial-gradient(circle at center,rgba(236,72,153,.38) 0,rgba(147,51,234,.25) 35%,rgba(15,23,42,.92) 70%);box-shadow:0 0 60px rgba(236,72,153,.45),0 0 120px rgba(147,51,234,.25);display:none;position:relative}.truth-heart{position:absolute;font-size:14px;opacity:.55;animation:linear forwards truthHeartFloat;filter:blur(.15px)}@keyframes truthHeartFloat{0%{transform:translateY(0) translateX(0) scale(.9);opacity:.4}20%{opacity:.65}100%{transform:translateY(140%) translateX(0) scale(1.15);opacity:.2}}.truth-result.heartbeat{animation:1.6s ease-in-out infinite heartbeatGlow}@keyframes heartbeatGlow{0%,100%{box-shadow:0 0 0 rgba(236,72,153,0),0 24px 50px rgba(0,0,0,.45)}20%{box-shadow:0 0 28px rgba(236,72,153,.45),0 24px 50px rgba(0,0,0,.45)}40%{box-shadow:0 0 12px rgba(236,72,153,.25),0 24px 50px rgba(0,0,0,.45)}60%{box-shadow:0 0 34px rgba(236,72,153,.55),0 24px 50px rgba(0,0,0,.45)}}.promise-stage{max-width:560px;margin:0 auto}.promise-intro{font-size:18px;opacity:.85;margin-bottom:48px}.promise-line{font-size:clamp(15px, 1.8vw, 17px);line-height:1.55;margin-bottom:8px;opacity:0;transition:opacity .9s,transform .9s}.blush-cta,.promise-cta{transition:opacity 1.2s}.bloom-text.show,.missing-btn.show,.promise-line.show{opacity:1;transform:translateY(0)}.promise-line::after{content:"";display:block;width:0%;height:1px;background:linear-gradient(90deg,#ec4899,transparent);margin:8px auto 0;transition:width 1.8s}.promise-line.show::after{width:62%}.promise-cta{margin-top:12px;opacity:0}.promise-line strong{font-family:Allura,cursive;font-size:30px;letter-spacing:.5px;font-weight:400;line-height:1.25;color:#fff;text-shadow:0 2px 10px rgba(236,72,153,.25)}.promise-intro-sub{font-size:17px;opacity:.85;margin-bottom:48px}.gold-dust{position:fixed;top:-20px;width:5px;height:5px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,160,.9),rgba(255,215,160,.1));opacity:.45;pointer-events:none;filter:blur(.4px);animation:linear forwards goldFall}.gift-box,.gift-table,.unwrap{position:relative}@keyframes goldFall{from{transform:translateY(0) scale(.8);opacity:0}15%{opacity:.7}to{transform:translateY(110vh) scale(1.1);opacity:0}}.promise-title-badge{letter-spacing:.4px;box-shadow:0 8px 20px rgba(255,215,160,.25),inset 0 1px 0 rgba(255,255,255,.4);display:inline-block;padding:12px 22px;margin-bottom:18px;font-size:15px;letter-spacing:.6px;color:#f9e6c3;border-radius:999px;background:linear-gradient(135deg,rgba(255,215,160,.22),rgba(255,255,255,.05));border:1px solid rgba(255,215,160,.45);box-shadow:0 10px 26px rgba(255,215,160,.25),inset 0 1px 0 rgba(255,255,255,.45)}.promise-final-line,.promise-final-text{font-size:clamp(20px, 3.5vw, 26px);line-height:1.25}@keyframes goldFlow{0%,100%{background-position:0 50%}50%{background-position:100% 60%}}.unwrap::before{content:"";position:fixed;inset:-40%;background:linear-gradient(120deg,transparent 20%,rgba(255,215,160,.25) 35%,rgba(255,235,190,.45) 45%,rgba(255,215,160,.25) 55%,transparent 70%);background-size:300% 300%;opacity:0;pointer-events:none;z-index:0;filter:blur(28px);transform:translateZ(0);transition:opacity 1.6s}body.promise-confirmed .unwrap::before{opacity:1;animation:16s linear infinite goldShimmerFlow}@keyframes goldShimmerFlow{0%,100%{background-position:0 50%}50%{background-position:100% 50%}}.promise-final-text{font-family:"Homemade Apple",cursive;margin-top:4px;margin-bottom:14px;opacity:0;transform:translateY(14px);transition:opacity 1.4s,transform 1.4s;color:#fde68a;text-shadow:0 0 18px rgba(255,215,160,.45),0 0 36px rgba(255,215,160,.25)}.gift-box::before,.knot-core,.ribbon-knot{transform:translate(-50%,-50%)}.promise-next-btn{opacity:0;pointer-events:none;transition:opacity 1.2s}.promise-confirmed .promise-stage{padding-bottom:24px}.promise-final-line{margin-top:14px;margin-bottom:16px}.promise-line:last-of-type{margin-bottom:2px}@media (max-height:700px){.promise-cta{margin-top:16px}.promise-line{margin-bottom:12px}.promise-final-text{font-size:20px;margin-bottom:12px;margin-top:2px}}.gift-stage{display:flex;flex-direction:column;align-items:center;justify-content:center}.gift-table{padding:40px}.gift-box{width:280px;height:190px;border-radius:16px;background:linear-gradient(180deg,#1c2533 0,#0b1220 100%);box-shadow:0 30px 60px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.08),inset 0 -6px 12px rgba(0,0,0,.6)}.gift-box::after,.gift-box::before,.gift-lid,.ribbon,.ribbon-knot{position:absolute}.gift-box::after{content:"";inset:0;background:radial-gradient(circle at 20% 15%,rgba(255,255,255,.06),transparent 60%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.03),transparent 65%);pointer-events:none}.gift-lid{top:0;left:0;height:38%;width:100%;background:linear-gradient(180deg,#263349,#1a2438);box-shadow:inset 0 -2px 0 rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.12)}.gift-box::before{content:"";top:50%;left:50%;width:90px;height:32px;background:radial-gradient(ellipse at center,rgba(0,0,0,.35),transparent 70%);pointer-events:none}.ribbon{background:linear-gradient(135deg,#ff6aa9 0,#ff8fc2 35%,#ff5fa2 60%,#e11d74 100%);box-shadow:inset 0 1px 1px rgba(255,255,255,.45),inset 0 -3px 5px rgba(0,0,0,.45);filter:saturate(1.05)}.ribbon.horizontal{height:22px;width:100%;top:50%;transform:translateY(-50%)}.ribbon.vertical{width:22px;height:100%;left:50%;transform:translateX(-50%)}.ribbon-knot{top:50%;left:50%;width:64px;height:48px;z-index:5;animation:4.8s ease-in-out infinite ribbonBreath}.gift-heart,.wax-seal{left:50%;z-index:6;position:absolute;cursor:pointer}.bow{position:absolute;width:42px;height:26px;background:linear-gradient(135deg,#ff9ac8,#ff5fa2);box-shadow:inset 0 2px 2px rgba(255,255,255,.35),inset 0 -4px 6px rgba(0,0,0,.35),0 6px 12px rgba(0,0,0,.45)}.bow.left{left:-6px;transform:rotate(-18deg) skewX(-8deg)}.bow.right{right:-6px;transform:rotate(16deg) skewX(8deg)}.knot-core{background:radial-gradient(circle at 30% 30%,#ffd1e6,#e11d74);box-shadow:inset 0 2px 3px rgba(255,255,255,.4),inset 0 -3px 6px rgba(0,0,0,.45),0 3px 6px rgba(0,0,0,.5)}.gift-hint{margin-top:28px;font-size:14px;opacity:.5}@keyframes ribbonBreath{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.02)}}.ribbon.horizontal::after,.ribbon.vertical::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.25),transparent 35%,rgba(0,0,0,.35) 75%);opacity:.35;pointer-events:none}.ribbon-knot::after{content:"";position:absolute;inset:-6px;border-radius:50%;background:radial-gradient(circle,rgba(0,0,0,.35),transparent 65%);z-index:-1;filter:blur(6px)}.bow{border-radius:18px 18px 26px 26px;transform-origin:center}.bow.left{transform:rotate(-22deg) skewX(-10deg) scaleY(.92)}.bow.right{transform:rotate(18deg) skewX(10deg) scaleY(.9)}.gift-lid{box-shadow:inset 0 -3px 6px rgba(0,0,0,.6),0 6px 14px rgba(0,0,0,.45)}.gift-box:hover .ribbon-knot{animation-play-state:paused;transform:translate(-50%,-52%) scale(1.03)}#unwrapBtn:not([disabled]):hover,.gift-box:hover{transform:translateY(-2px)}.knot-core{position:absolute;top:50%;left:50%;width:22px;height:16px;transform:translate(-50%,-50%) rotate(-6deg);background:linear-gradient(180deg,#ffd1e6 0,#ff7ab8 55%,#e11d74 100%);border-radius:8px;box-shadow:inset 0 2px 2px rgba(255,255,255,.45),inset 0 -3px 5px rgba(0,0,0,.45),0 2px 4px rgba(0,0,0,.5)}#cursor-dot,.gift-heart{transform:translate(-50%,-50%)}.heart-card,.hx-card{width:min(420px,90vw);background:linear-gradient(180deg,#0b1220,#020617);text-align:center}.gift-heart{top:50%;font-size:58px;line-height:1;color:#fb7185;pointer-events:none;text-shadow:0 2px 2px rgba(0,0,0,.35),inset 0 -2px 2px rgba(0,0,0,.25);filter:drop-shadow(0 6px 12px rgba(0,0,0,.45));animation:3.6s ease-in-out infinite heartBreath;pointer-events:auto}#heartCanvas.active,.bloom-stage,.next-btn.show,.promise-cta,.promise-next-btn{pointer-events:auto}@keyframes heartBreath{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.08)}}.gift-heart::after{content:"";position:absolute;inset:-14px;background:radial-gradient(circle,rgba(236,72,153,.45),transparent 70%);filter:blur(10px);z-index:-1}#heartCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:8}.hearts-layer,.next-btn,.scroll-shadow{pointer-events:none}#heartPopup{position:fixed;inset:0;background:rgba(2,6,23,.75);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity .5s}#heartPopup.show,#hx-popup.hx-show{opacity:1}.heart-card{border-radius:22px;padding:28px;box-shadow:0 40px 80px rgba(0,0,0,.65)}#popupHeartCanvas{width:100%;height:260px}#hx-popup{position:fixed;inset:0;background:rgba(2,6,23,.78);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:100000;opacity:0;transition:opacity .45s}.hx-card{border-radius:24px;padding:30px 26px 34px;box-shadow:0 42px 90px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.06)}.hx-title{font-size:15px;opacity:.7;margin-bottom:18px}#hx-canvas{width:100%;height:260px;display:block}.hx-success{margin-top:18px;font-size:14px;line-height:1.5;opacity:0;transition:opacity .8s}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}50%{transform:translateX(6px)}75%{transform:translateX(-4px)}}.wax-seal{top:92px;transform:translateX(-50%) rotate(-6deg);width:56px;filter:drop-shadow(0 10px 14px rgba(0,0,0,.45)) drop-shadow(0 2px 0 rgba(255,255,255,.25))}.paper{width:min(92%,560px);min-height:70svh;max-height:86svh;background:radial-gradient(circle at 18% 22%,rgba(0,0,0,.035),transparent 42%),radial-gradient(circle at 82% 28%,rgba(0,0,0,.03),transparent 42%),#f7f2e9;border-radius:10px;padding:38px 30px 24px;box-shadow:0 30px 80px rgba(0,0,0,.45),inset 0 0 0 1px rgba(0,0,0,.04);display:flex;flex-direction:column}.missing-btn,.next-btn{border:none;transform:translateY(10px);opacity:0}.pop-in{animation:.9s cubic-bezier(.22,.9,.35,1) forwards paperPop}@keyframes paperPop{0%{opacity:0;transform:scale(.92) translateY(30px)}100%{opacity:1;transform:scale(1) translateY(0)}}.paper-text{flex:1;font-family:Caveat,cursive;font-size:1.35rem;line-height:1.85;color:#3b2f2f;white-space:pre-wrap;opacity:0;scrollbar-width:none;-ms-overflow-style:none}.paper-text::-webkit-scrollbar{display:none}.hearts-layer{position:absolute;inset:0;z-index:1}.fall-heart{position:absolute;top:-20px;color:rgba(255,80,80,.55);animation:8s linear forwards fallDown}@keyframes fallDown{to{transform:translateY(110vh)}}.missing-btn{margin:28px auto 0;display:block;text-transform:lowercase;background:0 0;font-family:"Playfair Display",serif;font-size:14px;letter-spacing:.12em;text-transform:lowercase;color:rgba(60,45,45,.7);transition:opacity 1s,transform 1s;cursor:pointer}.bloom-btn,.next-btn{background:linear-gradient(135deg,#ec4899,#f472b6);font-weight:500}.letter-footer{padding-top:18px;text-align:center}.scroll-shadow{position:absolute;left:0;right:0;height:22px;opacity:0;transition:opacity .3s;z-index:5}.scroll-shadow.top{top:0;background:linear-gradient(to bottom,rgba(0,0,0,.18),transparent)}.scroll-shadow.bottom{bottom:64px;background:linear-gradient(to top,rgba(0,0,0,.18),transparent)}.letter-next{margin-top:22px;display:flex;justify-content:center}.bloom-stage,.letter-stage{flex-direction:column;position:relative;display:flex;width:100%}.next-btn{color:#fff;padding:14px 32px;border-radius:999px;font-size:15px;box-shadow:0 10px 18px rgba(236,72,153,.35),inset 0 1px 0 rgba(255,255,255,.35);transition:opacity 1s,transform 1s}.next-btn.show{opacity:1;transform:translateY(0)}.letter-stage{align-items:center;justify-content:flex-start;overflow:visible}.paper{transform:translateY(-24px)}.password-box{margin-bottom:28vh;transition:margin-bottom .35s}.password-box.keyboard-up{margin-bottom:46vh;transform:translateY(-8px)}.password-box button{width:auto!important;display:inline-block!important;padding:12px 22px!important;white-space:nowrap}.bloom-stage{align-items:center;justify-content:center;text-align:center;overflow:hidden}.bloom-text{font-family:"Cormorant Garamond",serif;font-size:clamp(20px, 3vw, 26px);line-height:1.45;color:#fde68a;margin-bottom:28px;max-width:520px;opacity:0;transform:translateY(12px);transition:opacity 1.2s,transform 1.2s}.bloom-btn{position:relative;z-index:2;color:#fff;border:none;padding:14px 34px;border-radius:999px;font-size:16px;cursor:pointer;box-shadow:0 14px 28px rgba(236,72,153,.45),inset 0 1px 0 rgba(255,255,255,.35);transition:transform .2s,box-shadow .2s}#cursor-dot,#petalCanvas,.bloom-emoji{position:fixed;pointer-events:none}.bloom-btn:active{transform:translateY(0);box-shadow:0 8px 18px rgba(236,72,153,.35)}.bloom-footer{margin-top:48px;font-size:13px;opacity:0;transition:opacity 1.4s}.bloom-footer.show{opacity:.6}.bloom-emoji{will-change:transform;will-change:transform;z-index:9999}#petalCanvas{inset:0;z-index:0;opacity:.7;filter:blur(2px)}.scratch-stage{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;max-width:520px;margin:0 auto}.scratch-stage .scratch-subtitle,.scratch-stage .scratch-title{width:100%;text-align:center;margin:0}.scratch-stage .scratch-title{margin-bottom:8px}.scratch-stage .scratch-subtitle{margin-bottom:16px}.scratch-stage .scratch-wrapper{width:100%;max-width:420px;aspect-ratio:16/10;margin-top:12px;flex-shrink:0}.wheel-result-box{outline:red solid 1px;background:rgba(255,255,255,.06);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.12);color:#fff;border-radius:16px;padding:22px 26px;box-shadow:0 10px 30px rgba(0,0,0,.4),inset 0 0 20px rgba(255,255,255,.05);transition:.3s;border-left:4px solid #ec4899}.unwrap,body,html{background:radial-gradient(circle at 75% 40%,#1a1f4a 0,#050816 65%)!important}#cursor-dot,#cursor-glow,#cursor-trail{position:fixed;pointer-events:none;z-index:999999!important}#cursor-dot{z-index:999999!important;font-size:14px;color:#ff4d9a;text-shadow:0 0 6px rgba(255,77,154,.9),0 0 14px rgba(255,77,154,.7),0 0 24px rgba(255,77,154,.5)}#cursor-glow{width:34px;height:34px;background:radial-gradient(circle,rgba(255,77,154,.35),transparent);border-radius:50%}#cursor-trail{width:80px;height:80px;background:radial-gradient(circle,rgba(255,77,154,.15),transparent);border-radius:50%;filter:blur(12px);opacity:.6}body.lock-scroll{overflow:hidden!important}body.allow-scroll{touch-action:auto;overflow-y:auto!important}.promise-stage,.unwrap-stage{touch-action:pan-y}.lock-scroll{overflow:hidden;height:100vh}.allow-scroll{overflow-y:auto;height:auto}body,html{margin:0!important;padding:0!important;height:100%!important}.bloom-stage,.blush-stage,.counter-stage,.entry-stage,.gift-stage,.memory-stage,.preload-stage,.promise-stage,.truth-stage{min-height:100svh!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;padding:24px 16px!important;box-sizing:border-box!important}.letter-stage,.wheel-stage{justify-content:flex-start!important}.letter-stage,.promise-stage,.truth-stage,.unwrap-stage{touch-action:pan-y!important}.scratch-wrapper,.wheel-container{touch-action:none!important}.letter-stage{min-height:100svh!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:24px 16px!important}.paper{margin-top:0!important;transform:none!important}.paper-text{padding:12px 6px 24px!important;overflow-y:auto!important}.promise-intro-sub,.promise-line,.promise-title-badge{pointer-events:none!important}.promise-cta,.promise-next-btn,button{pointer-events:auto!important}*{-webkit-tap-highlight-color:transparent}.entry-stage{width:100%!important;max-width:100%!important;display:flex!important;flex-direction:column!important;align-items:center!important}.entry-sub,.entry-text{width:100%!important;max-width:520px!important;text-align:center!important;overflow-wrap:break-word;word-break:break-word}.envelope{width:min(360px,92vw)!important;max-width:360px!important;min-width:360px!important;flex-shrink:0!important;box-sizing:border-box!important}@media (max-width:480px){.promise-intro,.promise-line{font-size:16px}.promise-line{line-height:1.6}.envelope{width:88vw!important;min-width:unset!important;max-width:360px!important}}.unwrap,body,html{background-attachment:fixed!important}.bloom-stage,.blush-stage,.counter-stage,.entry-stage,.gift-stage,.letter-stage,.memory-stage,.preload-stage,.promise-stage,.truth-stage,.unwrap,.unwrap-stage,.wheel-stage{background:0 0!important}#preloadStatus{transition:opacity .45s;min-height:24px}.preload-stage{position:relative;width:100%;display:flex;justify-content:center;align-items:center}.preload-card{width:min(520px,92vw);padding:34px;border-radius:32px;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 20px 80px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.12);text-align:center;max-width:480px!important}.preload-card::before{content:"";position:absolute;inset:1px;border-radius:31px;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.1),transparent 30%)}.audio-icon{width:62px;height:62px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}.audio-icon svg{width:32px;height:32px;fill:none;stroke:#ff63b6;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.audio-text{color:#fff;font-size:.95rem;font-weight:600;margin-bottom:12px}.volume-row{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#ffb5da;font-size:.85rem}#unwrapBtn,.preload-title{color:#fff;font-weight:700}.volume-icon{width:18px;height:18px;fill:none;stroke:#ff63b6;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.preload-title{line-height:1.3;margin-bottom:14px}.preload-sub{color:rgba(255,255,255,.72);margin-bottom:22px}.preload-bar{width:100%;height:10px;overflow:hidden;border-radius:999px;background:rgba(255,255,255,.08)}.preload-fill{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,#ff5ca8,#ff8ec8);box-shadow:0 0 20px rgba(255,92,168,.7)}.preload-percent{margin-top:14px;color:#ffb5da;font-weight:600}#unwrapBtn{margin-top:26px;border:none;border-radius:999px;background:linear-gradient(135deg,#ff4fa2,#ff77bf);box-shadow:0 12px 35px rgba(255,79,162,.35);transition:.3s}#unwrapBtn[disabled]{opacity:.45;pointer-events:none}@media (max-width:768px){.scratch-stage{padding-bottom:70px}.scratch-subtitle,.scratch-title{flex-shrink:0;width:min(92vw,520px);text-align:center}.scratch-wrapper{position:relative;flex-shrink:0;width:min(86vw,340px);aspect-ratio:1.72/1;min-height:190px;max-height:190px;margin:0 auto;border-radius:24px;overflow:hidden}#scratchCanvas,.scratch-hidden-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.scratch-stage .scratch-wrapper{position:relative!important;width:380px!important;height:220px!important;min-width:380px!important;max-width:380px!important;min-height:220px!important;max-height:220px!important;aspect-ratio:auto!important;margin:18px auto 0!important;border-radius:24px!important;overflow:hidden!important}.preload-card{width:min(340px,88vw)!important;padding:22px 20px!important;border-radius:26px!important}.audio-hint{margin-bottom:18px!important}.audio-icon{width:46px!important;height:46px!important;margin:0 auto 8px!important}.audio-icon svg{width:22px!important;height:22px!important}.audio-text{font-size:.78rem!important;margin-bottom:8px!important}.volume-row{padding:8px 12px!important;font-size:.75rem!important;gap:6px!important}.volume-icon{width:14px!important;height:14px!important}.preload-title{font-size:1.1rem!important;line-height:1.35!important;margin-bottom:10px!important}.preload-sub{font-size:.85rem!important;margin-bottom:16px!important}.preload-bar{height:7px!important}.preload-percent{margin-top:10px!important;font-size:.85rem!important}#unwrapBtn{min-width:120px!important;padding:12px 22px!important;font-size:.9rem!important;margin-top:18px!important}}.audio-hint{margin-bottom:22px!important}.preload-title{font-size:1.8rem!important}#unwrapBtn{min-width:130px!important}