:root{--orange: #ff7a00;--orange-bright: #ff9a33;--navy: #0a1128;--navy-2: #12224a;--navy-3: #1b3c6e;--pink: #ff3d7f;--cyan: #00d4d4;--gold: #ffd23f;--text: #f3f6ff;--text-dim: #a9b6d6;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);color-scheme:dark}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;font-family:Trebuchet MS,Segoe UI,system-ui,-apple-system,sans-serif;color:var(--text);background:radial-gradient(ellipse at 50% -10%,#1c2f63 0%,transparent 55%),radial-gradient(ellipse at 90% 100%,rgba(255,61,127,.22) 0%,transparent 45%),radial-gradient(ellipse at 5% 90%,rgba(0,212,212,.16) 0%,transparent 45%),var(--navy);background-attachment:fixed;overflow-x:hidden}.app{position:relative;min-height:100%;max-width:520px;margin:0 auto;padding:calc(var(--safe-top) + 18px) 20px calc(var(--safe-bottom) + 28px);display:flex;flex-direction:column}.app-vignette{position:fixed;inset:0;pointer-events:none;z-index:0;box-shadow:inset 0 0 160px 40px #0000008c;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E")}.screen,.mute-toggle{position:relative;z-index:1}.screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;animation:fade-in .45s ease both}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.kicker{margin:0;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;color:var(--cyan)}.title{margin:0;font-size:clamp(1.8rem,8vw,2.5rem);line-height:1.05;font-weight:800;background:linear-gradient(180deg,#fff 0%,var(--gold) 60%,var(--orange) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 28px rgba(255,122,0,.35)}.subtitle{margin:0;font-size:1.05rem;font-weight:600;color:var(--orange-bright)}.birthday-message{margin:4px 0 8px;max-width:30ch;color:var(--text-dim);line-height:1.5}.btn{font:inherit;font-weight:800;border:none;border-radius:999px;padding:16px 30px;min-height:56px;color:#fff;cursor:pointer;transition:transform .08s ease,box-shadow .2s ease,filter .2s ease;touch-action:manipulation}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(180deg,var(--orange-bright),var(--orange));box-shadow:0 8px 24px #ff7a0066,inset 0 1px #fff6;font-size:1.1rem}.btn-spin{background:radial-gradient(circle at 50% 30%,var(--pink),#c81f5c);box-shadow:0 0 0 4px #ff3d7f40,0 10px 30px #ff3d7f80;font-size:1.35rem;letter-spacing:.08em;min-width:190px}.btn-spin.is-spinning{filter:saturate(.7) brightness(.85)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;border:2px solid var(--cyan);color:var(--cyan);box-shadow:0 0 18px #00d4d440;font-size:1rem}.wheel-screen{gap:22px}.wheel-heading{margin:0;font-size:1.15rem;font-weight:700;color:var(--text-dim)}.wheel{position:relative;width:min(82vw,340px);aspect-ratio:1;filter:drop-shadow(0 12px 30px rgba(0,0,0,.55));cursor:pointer;transition:transform .1s ease}.wheel[role=button]:active{transform:scale(.98)}.wheel-svg{width:100%;height:100%;display:block}.wheel-rim{fill:none;stroke:var(--gold);stroke-width:6;filter:drop-shadow(0 0 8px rgba(255,210,63,.7))}.wheel-hub{fill:var(--navy)}.wheel-hub-ring{fill:none;stroke:var(--gold);stroke-width:4;filter:drop-shadow(0 0 6px rgba(255,210,63,.8))}.wheel-hub-group{filter:drop-shadow(0 3px 8px rgba(0,0,0,.5))}.wheel-emoji{font-size:22px}.pointer{position:absolute;top:-12px;left:50%;transform:translate(-50%);z-index:3;filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}.spin-controls{display:flex;flex-direction:column;align-items:center;gap:12px}.spins-left{margin:0;font-weight:800;font-size:1.15rem;color:var(--gold);letter-spacing:.02em}.locked-banner{display:flex;flex-direction:column;align-items:center;gap:14px}.locked-line{margin:0;max-width:32ch;color:var(--text-dim);line-height:1.5}.countdown{display:flex;gap:8px}.countdown-unit{min-width:60px;padding:10px 6px;border-radius:14px;background:linear-gradient(180deg,var(--navy-3),var(--navy-2));border:1px solid rgba(0,212,212,.35);box-shadow:inset 0 1px #ffffff14,0 0 16px #00d4d41f;display:flex;flex-direction:column;gap:2px}.countdown-value{font-size:1.6rem;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 0 10px rgba(0,212,212,.6)}.countdown-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim)}.modal-backdrop{position:fixed;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;padding:24px;background:#040816b8;backdrop-filter:blur(6px);animation:fade-in .25s ease both}.modal{width:100%;max-width:360px;padding:30px 26px;border-radius:26px;text-align:center;background:linear-gradient(180deg,var(--navy-2),var(--navy));border:2px solid var(--orange);box-shadow:0 24px 60px #0009,0 0 40px #ff7a0059;animation:pop-in .35s cubic-bezier(.18,1.4,.4,1) both}.modal-locked{border-color:var(--cyan);box-shadow:0 24px 60px #0009,0 0 40px #00d4d44d}@keyframes pop-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.modal-emoji{font-size:4rem;line-height:1}.modal-locked .modal-emoji{animation:shake .6s ease-in-out}@keyframes shake{0%,to{transform:rotate(0)}20%{transform:rotate(-12deg)}40%{transform:rotate(10deg)}60%{transform:rotate(-8deg)}80%{transform:rotate(6deg)}}.modal-eyebrow{margin:12px 0 2px;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--gold)}.modal-locked .modal-eyebrow{color:var(--cyan)}.modal-title{margin:0 0 10px;font-size:1.7rem;font-weight:800}.modal-desc{margin:0 0 22px;color:var(--text-dim);line-height:1.5}.modal-teaser{border-color:var(--gold);box-shadow:0 24px 60px #0009,0 0 40px #ffd23f66}.modal-teaser .modal-emoji{animation:teaser-bounce .9s ease-in-out infinite}.modal-teaser .modal-eyebrow{color:var(--gold)}.modal-suspense{margin-bottom:6px;opacity:.85;animation:suspense-pulse 1s ease-in-out infinite}@keyframes teaser-bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.06)}}@keyframes suspense-pulse{0%,to{opacity:.4}50%{opacity:1}}.results{justify-content:flex-start;padding-top:8px;gap:16px}.results-title{margin:6px 0 4px;font-size:2rem;font-weight:800;background:linear-gradient(180deg,#fff,var(--gold),var(--orange));-webkit-background-clip:text;background-clip:text;color:transparent}.results-grid{display:flex;flex-direction:column;gap:14px;width:100%}.result-card{display:flex;gap:14px;align-items:center;text-align:left;padding:16px;border-radius:20px;background:linear-gradient(180deg,var(--navy-2),rgba(18,34,74,.6));border:1px solid rgba(255,122,0,.35);box-shadow:0 8px 22px #0000004d;transition:opacity .2s ease}.result-card.is-done{border-color:#00d4d480}.result-emoji{font-size:2.6rem;flex-shrink:0}.result-body{flex:1;display:flex;flex-direction:column;gap:6px}.result-name{margin:0;font-size:1.2rem;font-weight:800}.result-desc{margin:0;font-size:.85rem;color:var(--text-dim);line-height:1.4}.status-toggle{align-self:flex-start;margin-top:4px;font:inherit;font-weight:700;font-size:.85rem;border:none;border-radius:999px;padding:8px 16px;min-height:40px;cursor:pointer;transition:transform .08s ease}.status-toggle:active{transform:scale(.95)}.status-todo{background:#ff7a002e;color:var(--orange-bright);border:1px solid var(--orange)}.status-done{background:var(--cyan);color:var(--navy)}.results-footer{margin-top:auto;padding-top:24px}.reset-link{background:none;border:none;color:var(--text-dim);opacity:.5;font-size:.78rem;text-decoration:underline;cursor:pointer}.reset-confirm{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-dim)}.reset-yes,.reset-no{font:inherit;font-weight:700;border-radius:999px;padding:8px 14px;border:none;cursor:pointer}.reset-yes{background:var(--pink);color:#fff}.reset-no{background:var(--navy-3);color:var(--text)}.mute-toggle{position:fixed;top:calc(var(--safe-top) + 12px);right:14px;z-index:20;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#0a1128b3;backdrop-filter:blur(6px);font-size:1.1rem;cursor:pointer}.back-button{position:fixed;top:calc(var(--safe-top) + 12px);left:14px;z-index:20;height:44px;padding:0 16px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:#0a1128b3;backdrop-filter:blur(6px);color:var(--text);font:inherit;font-weight:700;font-size:.9rem;cursor:pointer}.back-button:active{transform:scale(.96)}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important}}
