@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;500;700&family=Pacifico&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{-webkit-user-select:none;user-select:none;background:#0d0d0d;justify-content:center;align-items:center;height:100vh;font-family:Outfit,sans-serif;transition:background 80ms;display:flex;overflow:hidden}body.light{background:#fff}.rope-wrap{z-index:999;pointer-events:none;width:80px;height:100vh;transition:opacity .5s;position:fixed;top:0;left:50%;transform:translate(-50%)}.rope-wrap.hidden{opacity:0;pointer-events:none!important}#rope-svg{pointer-events:auto;touch-action:none;width:100%;height:100%;overflow:visible}#main-ui{opacity:0;pointer-events:none;text-align:center;pointer-events:none;width:100%;height:100%;transition:opacity 60ms;position:fixed;top:0;left:0}body.light #main-ui{opacity:1}.count-badge{color:#ff922b;white-space:nowrap;text-shadow:0 2px 12px #ff922b33;font-family:Pacifico,cursive;font-size:1.7rem;position:fixed;top:8%;left:50%;transform:translate(-50%)}#ingredient-runner{z-index:600;pointer-events:none;flex-direction:column;align-items:center;gap:4px;display:flex;position:fixed;bottom:22%;left:-220px}#ingredient-runner img{object-fit:contain;width:240px;height:240px;animation:.3s ease-in-out infinite run-bounce}@keyframes run-bounce{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-10px)rotate(2deg)}}.item-bubble{background:#fff;border-radius:20px;padding:10px 18px;font-size:3rem;animation:.2s bubble-pop;box-shadow:0 6px 20px #0000001f}@keyframes bubble-pop{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}#cook-runner{z-index:601;pointer-events:none;flex-direction:column;align-items:center;gap:4px;display:none;position:fixed;bottom:22%;left:-260px}#cook-runner img{object-fit:contain;width:240px;height:240px;animation:.3s ease-in-out infinite run-bounce}#hachi-carrier{pointer-events:none;z-index:800;width:220px;animation:.4s ease-in-out infinite carrier-bounce;position:fixed;bottom:18%;left:-280px}@keyframes carrier-bounce{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-10px)rotate(1deg)}}#cake-scene{z-index:900;text-align:center;-webkit-overflow-scrolling:touch;background:#fff8f0;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:80px;padding-bottom:60px;display:none;position:fixed;inset:0;overflow-y:auto}#cake-scene.active{display:flex}.cake-3d-wrap{perspective:1200px;margin-bottom:16px;padding-top:60px}.cake-3d{width:240px;height:155px;transform-style:preserve-3d;background:linear-gradient(135deg,#fff5f5 60%,#ffdede);border-radius:22px;position:relative;transform:rotateX(8deg)rotateY(-5deg);box-shadow:0 45px 80px #0000001f,inset 0 2px #ffffffb3}.cake-3d:after{content:"";background:repeating-linear-gradient(90deg,#ffc8c826 0 20px,#0000 20px 40px);border-radius:22px;position:absolute;inset:0}.cake-frosting{background:linear-gradient(#ffc9c9,#ffb1b1);border-radius:50%;width:100%;height:44px;position:absolute;top:-22px}.cake-candle{background:linear-gradient(#74c0fc,#a5d8ff);border-radius:7px;width:14px;height:60px;position:absolute;top:-78px;left:50%;transform:translate(-50%)}#candle-flame{transform-origin:bottom;background:radial-gradient(at 50% 100%,#ff4500 0%,#ff8c00 40%,#ffd43b 100%);border-radius:50% 50% 25% 25%;width:22px;height:36px;animation:.12s infinite alternate flame-idle;position:absolute;top:-36px;left:50%;translate:-50%;box-shadow:0 0 18px 6px #ffa00080,0 0 40px 10px #ff640033}@keyframes flame-idle{0%{transform:scaleY(1)scaleX(1)rotate(-2deg)}to{transform:scaleY(1.12)scaleX(.92)rotate(2deg)}}#candle-flame.blowing{animation:none}#mic-bar-wrap{align-items:center;gap:10px;margin-top:12px;display:flex}#mic-bar-track{background:#f0f0f0;border-radius:5px;width:180px;height:10px;overflow:hidden}#mic-bar-fill{background:linear-gradient(90deg,#a5d8ff,#ff922b);border-radius:5px;width:0%;height:100%;transition:width 50ms}.mic-label{color:#999;font-size:.8rem}.mic-hint{color:#ff922b;margin-top:6px;font-size:1rem;font-weight:600;animation:1.5s ease-in-out infinite pulse-hint}@keyframes pulse-hint{0%,to{opacity:1}50%{opacity:.4}}#wish-card{opacity:0;text-align:center;background:#fffffff2;border-radius:28px;flex-shrink:0;width:90%;max-width:400px;margin:24px auto 80px;padding:2rem;transform:translateY(30px);box-shadow:0 30px 60px #00000014}#wish-card h1{color:#ff6b9d;margin-bottom:.75rem;font-family:Pacifico,cursive;font-size:2rem}#wish-card p{color:#555;font-size:.95rem;line-height:1.75}
