:root{--bg: #17171a;--bg-2: #101014;--surface: rgba(255, 255, 255, .05);--surface-2: rgba(255, 255, 255, .08);--accent: #ff7ab8;--accent-soft: #ffd6e8;--accent-deep: #e94c9a;--text: #f4f0f2;--text-muted: #c3bcc0;--font: "Inter", -apple-system, "Segoe UI", system-ui, sans-serif;--radius: 22px;--radius-pill: 999px;--card-max: 380px;--ease: cubic-bezier(.22, .85, .3, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}button,.unwrap,.tapreveal,.collect__item,.hold__core,.scratch__canvas,.heart,.burst__p{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.app{position:relative;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:max(20px,env(safe-area-inset-top)) 18px max(20px,env(safe-area-inset-bottom));background:radial-gradient(130% 90% at 50% 0%,rgba(255,122,184,.16),transparent 55%),linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);overflow:hidden}.glow{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(60% 40% at 50% 18%,rgba(233,76,154,.14),transparent 70%);animation:glowPulse 7s ease-in-out infinite}.screen{position:relative;width:100%;max-width:var(--card-max);min-height:440px;border-radius:var(--radius);background-color:var(--surface);background-size:cover;background-position:center;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px #00000073,inset 0 0 0 1px #ffffff08;overflow:hidden;animation:screenIn .6s var(--ease) both}.screen__veil{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#10101473,#101014d1)}.screen__inner{position:relative;z-index:1;min-height:440px;padding:30px 26px 26px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px}.badge{align-self:center;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-soft);background:#ff7ab824;border:1px solid rgba(255,122,184,.3);padding:5px 12px;border-radius:var(--radius-pill)}.title{font-size:clamp(26px,7.4vw,36px);font-weight:700;line-height:1.12;letter-spacing:-.02em;background:linear-gradient(180deg,#fff,var(--accent-soft));-webkit-background-clip:text;background-clip:text;color:transparent}.lines{display:flex;flex-direction:column;gap:8px}.line{font-size:clamp(15px,4.4vw,19px);line-height:1.5;color:var(--text-muted);animation:lineIn .55s var(--ease) both}.screen--intro .title{font-size:clamp(24px,7vw,32px)}.screen--final .title{font-size:clamp(40px,12vw,60px)}.screen--final .line{color:var(--text)}.timeline{display:flex;flex-direction:column;gap:10px;width:100%}.tcard{display:flex;flex-direction:column;gap:3px;text-align:left;padding:12px 16px;border-radius:14px;background:var(--surface-2);border:1px solid rgba(255,122,184,.18);animation:lineIn .55s var(--ease) both}.tcard__date{font-size:12px;color:var(--accent);letter-spacing:.06em}.tcard__text{font-size:16px;color:var(--text)}.jokes{list-style:none;display:flex;flex-direction:column;gap:9px;width:100%}.joke{font-size:clamp(14px,4.2vw,17px);color:var(--text);padding:10px 14px;border-radius:12px;background:var(--surface);border:1px dashed rgba(255,122,184,.28);animation:lineIn .5s var(--ease) both}.actions{margin-top:8px}.soft-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;color:#1a0e14;padding:14px 30px;border-radius:var(--radius-pill);background:linear-gradient(180deg,var(--accent-soft),var(--accent));box-shadow:0 8px 24px #e94c9a66;animation:btnGlow 2.8s ease-in-out infinite;transition:transform .15s var(--ease)}.soft-btn:active{transform:scale(.96)}.mute-btn{position:absolute;top:max(14px,env(safe-area-inset-top));right:16px;z-index:5;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,214,232,.25);background:#1410146b;color:var(--accent-soft);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent;transition:transform .15s var(--ease),background .2s}.mute-btn:active{transform:scale(.92)}.mute-btn svg{display:block}.hearts{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.heart{position:absolute;bottom:-30px;opacity:0;line-height:0;color:var(--accent);animation:floatUp linear infinite}.heart:nth-child(2n){color:var(--accent-soft)}.dots{display:flex;gap:7px;margin-top:20px}.dot{width:7px;height:7px;border-radius:50%;background:#fff3;transition:all .3s var(--ease)}.dot--on{background:var(--accent);width:18px;border-radius:4px}@keyframes screenIn{0%{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes lineIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes btnGlow{0%,to{box-shadow:0 8px 24px #e94c9a59}50%{box-shadow:0 8px 34px #e94c9a99}}@keyframes glowPulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes floatUp{0%{opacity:0;transform:translateY(0) rotate(0)}15%{opacity:.9}to{opacity:0;transform:translateY(-104dvh) rotate(40deg)}}.slot{width:100%;display:flex;flex-direction:column;align-items:center;gap:14px}.unwrap{position:relative;width:168px;height:168px;border:none;cursor:pointer;background:transparent;margin:6px auto 0;animation:giftBreathe 2.6s ease-in-out infinite}.unwrap__flap,.unwrap__ribbon,.unwrap__bow{position:absolute}.unwrap__flap{top:18px;width:72px;height:132px;background:linear-gradient(160deg,var(--accent-soft),var(--accent));box-shadow:0 10px 30px #e94c9a73;border-radius:10px;transition:transform .6s var(--ease),opacity .6s var(--ease)}.unwrap__flap--l{left:8px;transform-origin:left center}.unwrap__flap--r{right:8px;transform-origin:right center}.unwrap__ribbon{left:50%;top:18px;width:16px;height:132px;margin-left:-8px;background:var(--accent-deep);border-radius:6px;transition:opacity .4s}.unwrap__bow{left:50%;top:4px;transform:translate(-50%);line-height:0;color:var(--accent-deep);transition:transform .5s var(--ease),opacity .5s}.unwrap--open .unwrap__flap--l{transform:rotateY(-110deg) translate(-30px);opacity:0}.unwrap--open .unwrap__flap--r{transform:rotateY(110deg) translate(30px);opacity:0}.unwrap--open .unwrap__ribbon{opacity:0}.unwrap--open .unwrap__bow{transform:translate(-50%,-40px) scale(1.4);opacity:0}.scratch{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;border-radius:var(--radius);overflow:hidden}.scratch__canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;touch-action:none}.scratch--done .scratch__canvas{opacity:0;transition:opacity .5s var(--ease);pointer-events:none}.scratch-fallback{margin-top:10px;padding:12px 24px;border-radius:var(--radius-pill);border:1px dashed var(--accent);background:var(--surface);color:var(--text);font:inherit;cursor:pointer}.tapreveal{width:100%;flex:1 1 auto;min-height:200px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:12px 0}.screen--g-tap-reveal .screen__inner{justify-content:flex-start}.screen--g-tap-reveal .slot{flex:1 1 auto;width:100%;display:flex}.line--tap{opacity:0;transform:translateY(8px);animation:none;transition:opacity .5s var(--ease),transform .5s var(--ease)}.line--tap.line--on{opacity:1;transform:none}.collect{width:100%;display:flex;gap:10px}.collect--cards{flex-direction:column}.collect--bubbles{flex-wrap:wrap;justify-content:center}.collect__item{border:none;font:inherit;cursor:pointer;color:var(--text);background:var(--surface-2);border-radius:14px;padding:12px 16px;animation:lineIn .5s var(--ease) both;transition:transform .2s var(--ease)}.collect--cards .collect__item{width:100%;text-align:left;border:1px solid rgba(255,122,184,.2);min-height:52px}.collect--bubbles .collect__item{width:88px;height:88px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;background:radial-gradient(circle at 35% 30%,#ffd6e899,#e94c9a59);border:1px solid rgba(255,255,255,.18);animation:bubbleFloat 3.4s ease-in-out infinite,lineIn .5s var(--ease) both}.collect__item--open{background:var(--surface)}.collect--bubbles .collect__item--open{width:auto;height:auto;min-width:120px;border-radius:14px;padding:10px 14px;animation:none;font-size:13px}.collect__cover{font-size:26px;color:var(--accent-soft)}.collect__item:active{transform:scale(.94)}.collect__face{display:flex;flex-direction:column;gap:3px}.hold{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-top:8px;width:140px;height:140px}.hold__core{position:relative;width:120px;height:120px;border-radius:50%;flex:none;border:2px solid rgba(255,122,184,.4);background:#ff7ab814;cursor:pointer;overflow:hidden;touch-action:none;display:flex;align-items:center;justify-content:center;box-shadow:0 0 calc(10px + 52px * var(--p, 0)) rgba(233,76,154,calc(.3 + .55 * var(--p, 0)));will-change:box-shadow}.hold__heart{display:inline-flex;line-height:0;color:var(--accent-deep);position:relative;z-index:2;filter:drop-shadow(0 0 6px rgba(233,76,154,.6));transform:scale(calc(1 + .14 * var(--p, 0)));transform-origin:center;will-change:transform}.hold__fill{position:absolute;left:0;right:0;bottom:0;z-index:1;height:calc(100% * var(--p, 0));background:linear-gradient(0deg,var(--accent-deep),var(--accent-soft));opacity:.55}.hold__core--done{animation:holdPop .5s var(--ease)}.hint{position:absolute;left:50%;bottom:14px;transform:translate(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:4px;pointer-events:none}.hint__icon{display:inline-flex;line-height:0;color:var(--accent);animation:hintPulse 1.4s ease-in-out infinite}.hint__text{font-size:12px;color:var(--text-muted);opacity:0;transition:opacity .5s}.hint__text--on{opacity:.85}.burst{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;pointer-events:none;overflow:hidden}.burst__p{position:absolute;bottom:38%;opacity:0;line-height:0;color:var(--accent);animation-name:burstUp;animation-timing-function:cubic-bezier(.2,.7,.3,1);animation-fill-mode:forwards}.burst__p:nth-child(3n){color:var(--accent-soft)}.burst__p:nth-child(3n+1){color:var(--accent-deep)}.kinetic__w{display:inline-block;opacity:1}.screen--final .kinetic__w{opacity:0;transform:translateY(14px);animation:kineticIn .6s var(--ease) both}.screen--final .kinetic__w--on{opacity:1;transform:none;animation:none}@keyframes giftBreathe{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bubbleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes hintPulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:1}}@keyframes holdPop{0%{transform:scale(1.18)}50%{transform:scale(1.32)}to{transform:scale(1.18)}}@keyframes kineticIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes burstUp{0%{opacity:0;transform:translate(0) rotate(0)}12%{opacity:1}to{opacity:0;transform:translate(var(--dx, 0),-260px) rotate(40deg)}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.line,.tcard,.joke{opacity:1!important}.kinetic__w{opacity:1!important;transform:none!important}.collect__item{opacity:1!important}}
