@font-face{font-family:NewYork-Regular;src:url(/fonts/NewYork.ttf)format("truetype");font-weight:400;font-style:normal}@font-face{font-family:SFMono-Regular;src:url(/fonts/SF-Mono-Regular.otf)format("opentype");font-weight:400;font-style:normal}@font-face{font-family:SFPro-Regular;src:url(/fonts/SF-Pro.ttf)format("truetype");font-weight:400;font-style:normal}@font-face{font-family:SFPro-Italic;src:url(/fonts/SF-Pro-Italic.ttf)format("truetype");font-weight:400;font-style:italic}:root{--my-pink:#edafca;--my-pink-dark:#d697b2;--my-pink-light:#f6d6e5;--white:#fff}*{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{width:100%;height:100dvh;color:var(--white);background-color:#000;font-family:SFPro-Regular,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}#root{justify-content:center;align-items:center;width:100%;height:100dvh;display:flex;overflow:hidden}@keyframes pulse{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}to{opacity:.8;transform:scale(1)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}@keyframes earPulse{0%{transform:scale(1)translate(-50%,-50%);box-shadow:0 0 #edafca66}70%{transform:scale(1.05)translate(-50%,-50%);box-shadow:0 0 0 20px #edafca00}to{transform:scale(1)translate(-50%,-50%);box-shadow:0 0 #edafca00}}.phone-container{width:100%;max-width:480px;height:100%;padding:calc(max(20px, min(50px, 6vh), env(safe-area-inset-top))) 20px calc(max(20px, min(40px, 5vh), env(safe-area-inset-bottom))) 20px;background-color:#000;flex-direction:column;justify-content:space-between;margin:0 auto;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 40px #00000080}.bg-image{object-fit:cover;z-index:0;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.top-panel{z-index:10;flex-direction:column;align-items:center;gap:15px;display:flex;position:relative}.title{text-align:center;color:#fff;text-shadow:0 2px 8px #0006;letter-spacing:.5px;font-family:NewYork-Regular,Georgia,serif;font-size:min(34px,4.5vh);font-weight:800}.new-game-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);background:#ffffff40;border:1px solid #ffffff4d;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-family:SFPro-Regular,sans-serif;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;box-shadow:0 4px 12px #00000026}.new-game-btn:active{background:#ffffff59;transform:scale(.95)}.new-game-btn svg{fill:#fff;width:16px;height:16px}.speaker-toggle{cursor:pointer;-webkit-backdrop-filter:blur(8px);background:#edafca4d;border:1px solid #edafca66;border-radius:25px;margin-top:5px;padding:4px;display:inline-flex;box-shadow:0 4px 10px #0000001a}.toggle-option{color:#fffc;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.toggle-option.active{color:#fff;background:#edafca;box-shadow:0 2px 6px #edafca66}.display-container{z-index:10;justify-content:center;align-items:center;width:100%;height:min(80px,9vh);display:flex;position:relative}.display-number{color:#fff;letter-spacing:2px;text-shadow:0 2px 10px #00000080;text-align:center;min-height:min(52px,6.5vh);font-family:SFMono-Regular,monospace;font-size:min(44px,5.5vh);font-weight:700}.keypad-container{z-index:10;flex-direction:column;align-items:center;gap:min(12px,1.5vh);width:100%;display:flex;position:relative}.keypad-row{justify-content:center;gap:min(15px,4vw);width:100%;display:flex}.key-btn{background-color:var(--my-pink);color:#fff;cursor:pointer;touch-action:manipulation;border:none;border-radius:50%;justify-content:center;align-items:center;width:min(78px,8.5vh,18vw);height:min(78px,8.5vh,18vw);font-family:SFMono-Regular,monospace;font-size:min(34px,3.8vh,8vw);font-weight:700;transition:all .1s;display:flex;box-shadow:0 4px 10px #0003,inset 0 2px 4px #fff3}.key-btn:active{background-color:var(--my-pink-dark);transform:scale(.92);box-shadow:0 2px 4px #0003}.key-btn.backspace{font-size:min(26px,3vh,6.5vw)}.key-btn svg{fill:#fff;stroke:#fff;width:min(28px,3.2vh,7vw);height:min(28px,3.2vh,7vw)}.dial-container{z-index:10;justify-content:center;width:100%;padding-bottom:min(25px,3vh);display:flex;position:relative}.dial-btn{cursor:pointer;touch-action:manipulation;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:min(82px,9vh,19vw);height:min(82px,9vh,19vw);transition:all .15s;display:flex;overflow:hidden;box-shadow:0 6px 15px #0000004d}.dial-btn:active{transform:scale(.9);box-shadow:0 2px 6px #0000004d}.dial-btn img{object-fit:cover;width:100%;height:100%}.alert-overlay{-webkit-backdrop-filter:blur(15px);z-index:100;background:#0006;justify-content:center;align-items:center;width:100%;height:100%;padding:30px;display:flex;position:absolute;top:0;left:0}.ios-alert{-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border:1px solid #fff3;border-radius:14px;flex-direction:column;width:100%;max-width:290px;animation:.2s cubic-bezier(.1,.8,.3,1) pulse;display:flex;overflow:hidden;box-shadow:0 10px 30px #00000040}.alert-body{text-align:center;padding:20px 16px}.alert-title{color:#000;margin-bottom:4px;font-family:SFPro-Regular,sans-serif;font-size:17px;font-weight:600}.alert-message{color:#000;font-family:SFPro-Regular,sans-serif;font-size:13px;line-height:1.35}.alert-buttons{border-top:.5px solid #00000026;display:flex}.alert-btn{cursor:pointer;text-align:center;color:#007aff;background:0 0;border:none;flex:1;padding:12px 10px;font-family:SFPro-Regular,sans-serif;font-size:17px;transition:background-color .1s}.alert-btn:active{background-color:#0000000d}.alert-btn.cancel{color:#007aff;border-right:.5px solid #00000026}.alert-btn.confirm{color:#ff3b30;font-weight:600}.earpiece-overlay{-webkit-backdrop-filter:blur(10px);z-index:90;color:#fff;text-align:center;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:40px;display:flex;position:absolute;top:0;left:0}.earpiece-badge{background:#edafca33;border-radius:50%;justify-content:center;align-items:center;width:130px;height:130px;margin-bottom:30px;display:flex;position:relative}.earpiece-badge:after{content:"";transform-origin:50%;border:2px solid #edafca;border-radius:50%;width:130px;height:130px;animation:2s ease-in-out infinite earPulse;position:absolute;top:50%;left:50%}.earpiece-badge svg{fill:#edafca;width:60px;height:60px;animation:2s ease-in-out infinite float}.earpiece-title{color:#edafca;margin-bottom:12px;font-family:NewYork-Regular,Georgia,serif;font-size:24px;font-weight:700}.earpiece-text{color:#fffc;font-family:SFPro-Regular,sans-serif;font-size:15px;line-height:1.4}.earpiece-close-hint{color:#fff6;cursor:pointer;background:#ffffff1a;border-radius:15px;margin-top:40px;padding:6px 14px;font-family:SFPro-Italic,sans-serif;font-size:12px}.fireworks-overlay{z-index:200;cursor:pointer;background:#000;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.fireworks-video{object-fit:cover;width:100%;height:100%}.fireworks-close-hint{color:#fff;-webkit-backdrop-filter:blur(5px);pointer-events:none;background:#0009;border:1px solid #fff3;border-radius:25px;padding:10px 20px;font-size:14px;animation:1.5s infinite pulse;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.pwa-instructions-overlay{-webkit-backdrop-filter:blur(15px);z-index:150;background:#000000b3;justify-content:center;align-items:flex-end;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.pwa-card{-webkit-backdrop-filter:blur(30px);width:100%;padding:30px 24px calc(max(24px, env(safe-area-inset-bottom))) 24px;color:#000;background:#fffffff2;border-top-left-radius:20px;border-top-right-radius:20px;flex-direction:column;animation:.3s cubic-bezier(.1,.8,.3,1) slide-up;display:flex;box-shadow:0 -10px 30px #0000004d}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.pwa-title{color:#edafca;font-family:NewYork-Regular,Georgia,serif;font-size:24px;font-weight:700}.pwa-close-btn{color:#0000004d;cursor:pointer;background:0 0;border:none;padding:4px;font-size:24px}.pwa-intro{color:#333;margin-bottom:20px;font-size:14px;line-height:1.4}.pwa-steps{flex-direction:column;gap:15px;display:flex}.pwa-step{color:#222;align-items:center;gap:14px;font-size:14px;display:flex}.pwa-step-num{color:#fff;background:#edafca;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;display:flex}.pwa-step-text{flex-grow:1}.share-icon,.add-home-icon{vertical-align:middle;color:#007aff;background:#f0f0f0;border-radius:6px;margin:0 4px;padding:4px;display:inline-flex}.share-icon svg,.add-home-icon svg{width:18px;height:18px}.pwa-footer{text-align:center;margin-top:25px}.pwa-ok-btn{color:#fff;cursor:pointer;background:#edafca;border:none;border-radius:25px;padding:12px 30px;font-size:15px;font-weight:600;transition:all .2s;box-shadow:0 4px 10px #edafca66}.pwa-ok-btn:active{background:var(--my-pink-dark);transform:scale(.95)}@media (width<=900px) and (orientation:landscape){.landscape-warning-overlay{display:flex!important}}.landscape-warning-overlay{z-index:9999;color:#fff;text-align:center;background-color:#000;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:none;position:fixed;top:0;left:0}.landscape-warning-icon{margin-bottom:20px;font-size:48px;animation:2s ease-in-out infinite rotate-phone}@keyframes rotate-phone{0%{transform:rotate(0)}50%{transform:rotate(-90deg)}to{transform:rotate(0)}}.landscape-warning-title{color:#edafca;margin-bottom:10px;font-family:NewYork-Regular,Georgia,serif;font-size:24px}.landscape-warning-text{color:#fffc;max-width:320px;font-family:SFPro-Regular,sans-serif;font-size:15px;line-height:1.4}
