:root{--bg:#0f0e17;--surface:#1a1a2e;--surface-light:#232347;--x-color:#ff6b6b;--x-glow:#ff6b6b88;--o-color:#4ecdc4;--o-glow:#4ecdc488;--text:#fffffe;--text-dim:#a7a9be;--accent:#e53170;--gold:gold;--radius:16px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Poppins,sans-serif;overflow-x:hidden}.stars{z-index:0;pointer-events:none;background:radial-gradient(1px 1px at 10% 20%,#fff9,#0000),radial-gradient(1px 1px at 30% 65%,#fff6,#0000),radial-gradient(1.5px 1.5px at 50% 10%,#ffffffb3,#0000),radial-gradient(1px 1px at 70% 40%,#ffffff80,#0000),radial-gradient(1px 1px at 85% 75%,#ffffff4d,#0000),radial-gradient(1.5px 1.5px at 15% 80%,#ffffff80,#0000),radial-gradient(1px 1px at 60% 90%,#fff6,#0000),radial-gradient(1px 1px at 90% 15%,#fff9,#0000),radial-gradient(1.5px 1.5px at 40% 45%,#ffffff4d,#0000),radial-gradient(1px 1px at 25% 35%,#ffffff80,#0000);animation:4s ease-in-out infinite alternate twinkle;position:fixed;inset:0}@keyframes twinkle{0%{opacity:.5}to{opacity:1}}.app{z-index:1;flex-direction:column;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex;position:relative}.btn-hub-back{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-dim);cursor:pointer;background:#1a1a2ee6;border:1px solid #ffffff1a;border-radius:10px;padding:.5rem 1rem;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .2s;position:fixed;top:1rem;left:1rem}.btn-hub-back:hover{color:var(--text);background:#1a1a2ef2;border-color:#ffffff40}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}}@keyframes celebrate{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.title{letter-spacing:.05em;gap:.4em;margin-bottom:2rem;font-size:3rem;font-weight:800;animation:.6s ease-out slideDown;display:flex}.x-marker{color:var(--x-color);text-shadow:0 0 10px var(--x-glow);font-weight:700}.o-marker{color:var(--o-color);text-shadow:0 0 10px var(--o-glow);font-weight:700}.pulse{animation:1s ease-in-out infinite pulse}.setup{animation:.5s ease-out fadeIn}.setup-card{background:var(--surface);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #ffffff14;flex-direction:column;gap:1.5rem;width:min(420px,90vw);padding:2.5rem 2rem;display:flex;box-shadow:0 20px 60px #00000080}.setup-card h2{text-align:center;color:var(--text-dim);font-size:1.3rem;font-weight:600}.input-group{flex-direction:column;gap:.5rem;display:flex}.input-group label{align-items:center;gap:.5em;font-size:.95rem;font-weight:600;display:flex}.input-group .marker{font-size:1.2rem}.input-group input{background:var(--surface-light);color:var(--text);border:2px solid #ffffff0f;border-radius:10px;outline:none;padding:.8rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .3s,box-shadow .3s}.input-group input:focus{border-color:var(--accent);box-shadow:0 0 15px #e5317033}.input-group input::placeholder{color:var(--text-dim);opacity:.5}.btn-start{background:linear-gradient(135deg, var(--accent), #ff6b6b);color:#fff;cursor:pointer;letter-spacing:.03em;border:none;border-radius:12px;margin-top:.5rem;padding:.9rem;font-family:inherit;font-size:1.1rem;font-weight:700;transition:transform .2s,box-shadow .2s}.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 25px #e5317066}.btn-start:active{transform:translateY(0)}.btn-play-again{background:linear-gradient(135deg, var(--accent), #ff6b6b);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:.7rem 1.8rem;font-family:inherit;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s;animation:.3s ease-out fadeIn}.btn-play-again:hover{transform:translateY(-2px);box-shadow:0 8px 25px #e5317066}.btn-play-again:active{transform:translateY(0)}.btn-back{color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:12px;padding:.7rem 1.5rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.btn-back:hover{color:var(--text);background:#ffffff08;border-color:#ffffff40}.btn-waiting{opacity:.6;cursor:wait!important}.mode-card{gap:1.2rem}.mode-btn{background:var(--surface-light);cursor:pointer;color:var(--text);border:2px solid #ffffff0f;border-radius:14px;flex-direction:column;align-items:center;gap:.3rem;padding:1.5rem;font-family:inherit;transition:all .25s;display:flex}.mode-btn:hover{border-color:#ffffff26;transform:translateY(-3px);box-shadow:0 10px 30px #0000004d}.mode-btn:active{transform:translateY(0)}.mode-btn-local:hover{border-color:var(--x-color);box-shadow:0 10px 30px #ff6b6b26}.mode-btn-online:hover{border-color:var(--o-color);box-shadow:0 10px 30px #4ecdc426}.mode-icon{font-size:2rem}.mode-label{font-size:1.15rem;font-weight:700}.mode-desc{color:var(--text-dim);font-size:.8rem}.lobby-card{gap:1rem}.lobby-tabs{background:var(--surface-light);border-radius:10px;gap:0;display:flex;overflow:hidden}.lobby-tab{color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex:1;padding:.7rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.lobby-tab.active{background:var(--accent);color:#fff}.lobby-form{flex-direction:column;gap:1rem;display:flex}.lobby-subtext{text-align:center;color:var(--text-dim);font-size:.9rem}.room-code-display{justify-content:center;padding:1rem;display:flex}.room-code{letter-spacing:.3em;color:var(--gold);text-shadow:0 0 30px #ffd7004d;-webkit-user-select:all;user-select:all;font-family:Courier New,monospace;font-size:3rem;font-weight:800}.input-code{text-align:center;letter-spacing:.3em;text-transform:uppercase;font-weight:700;font-size:1.4rem!important}.waiting-dots{justify-content:center;gap:.5rem;display:flex}.waiting-dots span{background:var(--o-color);border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite bounce}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}.lobby-error{text-align:center;color:var(--x-color);font-size:.85rem;font-weight:600;animation:.2s fadeIn}.game{flex-direction:column;align-items:center;gap:1.5rem;width:min(500px,95vw);animation:.5s ease-out fadeIn;display:flex}.game-actions{flex-wrap:wrap;justify-content:center;gap:.8rem;display:flex}.scoreboard{justify-content:center;gap:.5rem;width:100%;display:flex}.score-item{background:var(--surface);border:1px solid #ffffff0f;border-radius:12px;flex-direction:column;align-items:center;gap:.2rem;min-width:100px;padding:.6rem 1.2rem;transition:all .3s;display:flex}.score-item.active{border-color:#ffffff26;transform:translateY(-3px);box-shadow:0 0 20px #ffffff0d}.score-marker{font-size:1.2rem}.score-name{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:.75rem;overflow:hidden}.score-label{color:var(--text-dim);font-size:.75rem}.score-value{font-size:1.5rem;font-weight:800}.score-you .score-name{color:var(--gold)}.turn-indicator{background:var(--surface);text-align:center;border:1px solid #ffffff0f;border-radius:12px;justify-content:center;align-items:center;min-height:52px;padding:.8rem 1.5rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex}.turn-indicator.result{background:linear-gradient(135deg, var(--surface), var(--surface-light));border-color:var(--gold);box-shadow:0 0 30px #ffd70026}.turn-text{align-items:center;gap:.4em;animation:.3s fadeIn;display:flex}.win-text{color:var(--gold);align-items:center;gap:.4em;animation:.5s ease-out celebrate;display:flex}.draw-text{color:var(--text-dim);animation:.3s fadeIn}.overlay-card{background:var(--surface);border-radius:var(--radius);text-align:center;border:1px solid #ffffff14;flex-direction:column;gap:1rem;max-width:400px;padding:2.5rem 2rem;animation:.3s ease-out fadeIn;display:flex}.overlay-card h2{color:var(--x-color)}.overlay-card p{color:var(--text-dim)}.board-waiting{opacity:.7;transition:opacity .3s}.opponent-turn-text{opacity:.8}@media (pointer:coarse){.btn-start,.btn-back,.btn-play-again,.lobby-tab,.mode-btn{min-height:48px}.input-group input{min-height:48px;font-size:16px}}@media (width<=480px){.app{padding:1.2rem .8rem}.title{margin-bottom:1.2rem;font-size:2.2rem}.setup-card{gap:1rem;width:min(420px,95vw);padding:1.5rem 1rem}.setup-card h2{font-size:1.1rem}.scoreboard{gap:.3rem}.score-item{min-width:70px;padding:.4rem .6rem}.score-value{font-size:1.2rem}.score-name{max-width:70px;font-size:.65rem}.turn-indicator{padding:.6rem 1rem;font-size:.95rem}.game{gap:1rem}.game-actions{gap:.4rem}.btn-start{padding:.8rem;font-size:1rem}.btn-back{padding:.6rem 1rem;font-size:.8rem}.btn-hub-back{padding:.4rem .8rem;font-size:.7rem;top:.5rem;left:.5rem}.room-code{font-size:2.2rem}.lobby-tabs{font-size:.8rem}.mode-btn{padding:1.2rem}.mode-icon{font-size:1.6rem}.mode-label{font-size:1rem}.overlay-card{margin:0 .5rem;padding:1.5rem 1rem}}@media (width<=360px){.title{font-size:1.8rem}.setup-card{padding:1.2rem .8rem}.score-item{min-width:60px;padding:.3rem .4rem}}.title-tic{color:var(--x-color);text-shadow:0 0 20px var(--x-glow)}.title-tac{color:var(--text)}.title-toe{color:var(--o-color);text-shadow:0 0 20px var(--o-glow)}.board{aspect-ratio:1;background:var(--surface);border-radius:var(--radius);border:1px solid #ffffff0f;grid-template-columns:repeat(3,1fr);gap:8px;width:min(380px,85vw);padding:12px;display:grid;box-shadow:0 20px 60px #0000004d}.board-disabled .cell-empty{cursor:default}.cell{background:var(--surface-light);cursor:pointer;aspect-ratio:1;border:2px solid #ffffff0a;border-radius:12px;justify-content:center;align-items:center;padding:15%;transition:all .2s;display:flex;position:relative;overflow:hidden}.cell-empty:hover{background:#ffffff0f;border-color:#ffffff1a;transform:scale(1.03)}.cell-empty:active{transform:scale(.97)}.cell-x{border-color:#ff6b6b26}.cell-o{border-color:#4ecdc426}.cell-win{animation:1s ease-in-out infinite alternate winGlow}.cell-win.cell-x{border-color:var(--x-color);box-shadow:0 0 25px var(--x-glow);background:#ff6b6b1f}.cell-win.cell-o{border-color:var(--o-color);box-shadow:0 0 25px var(--o-glow);background:#4ecdc41f}@keyframes winGlow{0%{filter:brightness()}to{filter:brightness(1.3)}}.cell-pop .mark{animation:.35s cubic-bezier(.34,1.56,.64,1) pop}@keyframes pop{0%{opacity:0;transform:scale(0)rotate(-20deg)}to{opacity:1;transform:scale(1)rotate(0)}}.mark{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.mark-svg{width:100%;height:100%}.x-line{stroke:var(--x-color);stroke-width:10px;stroke-linecap:round;filter:drop-shadow(0 0 6px var(--x-glow));stroke-dasharray:85;stroke-dashoffset:85px;animation:.3s ease-out forwards drawLine}.x-line-2{animation-delay:.1s}@keyframes drawLine{to{stroke-dashoffset:0}}.o-circle{fill:none;stroke:var(--o-color);stroke-width:8px;stroke-linecap:round;filter:drop-shadow(0 0 6px var(--o-glow));stroke-dasharray:189;stroke-dashoffset:189px;animation:.4s ease-out forwards drawCircle}@keyframes drawCircle{to{stroke-dashoffset:0}}@media (width<=480px){.board{border-radius:12px;gap:5px;width:min(340px,92vw);padding:8px}.cell{border-radius:8px;padding:12%}}@media (width<=360px){.board{gap:4px;width:95vw;padding:6px}}@media (pointer:coarse){.cell{min-height:0}}.title-word{color:var(--gold);text-shadow:0 0 20px #ffd70080}.title-clash{color:var(--accent);text-shadow:0 0 20px #e5317080}.wc-game{gap:.8rem;max-width:600px}.wc-scores{justify-content:center;align-items:center;gap:.8rem;width:100%;display:flex}.wc-player{background:var(--surface);border:1px solid #ffffff0f;border-radius:10px;flex-direction:column;align-items:center;gap:.1rem;min-width:110px;padding:.5rem 1rem;transition:all .3s;display:flex}.wc-player.active{border-color:var(--gold);box-shadow:0 0 15px #ffd70026}.wc-player.you .wc-player-name{color:var(--gold)}.wc-player-name{color:var(--text-dim);font-size:.75rem}.wc-player-score{font-size:1.8rem;font-weight:800}.wc-bag-count{color:var(--text-dim);text-align:center;font-size:.75rem}.wc-result{color:var(--gold);text-align:center;font-size:1.3rem;font-weight:700;animation:.5s ease-out celebrate}.wc-board{aspect-ratio:1;background:var(--surface);border:1px solid #ffffff0f;border-radius:10px;grid-template-columns:repeat(13,1fr);gap:2px;width:min(520px,95vw);padding:4px;display:grid}.wc-cell{aspect-ratio:1;cursor:pointer;background:var(--surface-light);color:var(--text);border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-family:inherit;font-size:clamp(.5rem,2.2vw,.85rem);transition:all .15s;display:flex;position:relative}.wc-cell:hover:not(.wc-cell-filled):not(.wc-cell-disabled){background:#ffffff14}.wc-cell-disabled{cursor:default;opacity:.7}.bonus-2l{background:#1a4a6b}.bonus-3l{background:#1a5a3a}.bonus-2w{background:#6b3a1a}.bonus-3w{background:#6b1a2a}.bonus-center{background:#4a3a6b}.wc-bonus-label{color:#ffffff80;font-size:clamp(.35rem,1.5vw,.6rem);font-weight:700;line-height:1}.wc-cell-filled{cursor:default;background:#c4973a}.wc-cell-pending{background:#d4a74a;animation:.2s ease-out tilePlace;box-shadow:0 0 8px #d4a74a80}@keyframes tilePlace{0%{transform:scale(.7)}to{transform:scale(1)}}.wc-tile-letter{color:#1a1a2e;align-items:baseline;gap:1px;font-size:clamp(.55rem,2.5vw,.95rem);font-weight:800;display:flex}.wc-tile-blank{opacity:.8;font-style:italic}.wc-tile-value{opacity:.7;font-size:clamp(.3rem,1vw,.5rem);font-weight:600}.wc-rack{background:var(--surface);border:1px solid #ffffff0f;border-radius:10px;justify-content:center;gap:6px;min-height:56px;padding:.6rem;display:flex}.wc-rack-tile{cursor:pointer;background:#c4973a;border:2px solid #a07a2a;border-radius:6px;justify-content:center;align-items:center;width:44px;height:44px;font-family:inherit;transition:all .15s;display:flex;position:relative}.wc-rack-tile:hover{transform:translateY(-4px);box-shadow:0 6px 15px #0006}.wc-rack-selected{border-color:var(--gold);transform:translateY(-6px);box-shadow:0 6px 20px #ffd70066}.wc-rack-letter{color:#1a1a2e;align-items:baseline;gap:1px;font-size:1.2rem;font-weight:800;display:flex}.wc-rack-value{color:#1a1a2e;opacity:.6;font-size:.55rem;font-weight:600}.wc-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.wc-waiting-turn{color:var(--text-dim);font-size:.9rem;animation:1.5s ease-in-out infinite pulse}.wc-challenge-bar{background:var(--surface);border:1px solid var(--gold);border-radius:10px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.8rem;padding:.6rem 1rem;font-size:.85rem;animation:.3s fadeIn;display:flex}.btn-challenge{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.4rem 1rem;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s}.btn-challenge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e5317066}.btn-accept{color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:8px;padding:.4rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s}.btn-accept:hover{color:var(--text);border-color:#ffffff4d}.wc-challenge-banner{text-align:center;border-radius:10px;padding:.6rem 1rem;font-size:.9rem;font-weight:600;animation:.3s fadeIn}.wc-challenge-banner.success{border:1px solid var(--o-color);color:var(--o-color);background:#4ecdc426}.wc-challenge-banner.fail{border:1px solid var(--x-color);color:var(--x-color);background:#ff6b6b26}.wc-message{color:var(--x-color);text-align:center;font-size:.85rem;font-weight:600;animation:.2s fadeIn}.wc-blank-picker{background:var(--surface);border:1px solid var(--gold);text-align:center;border-radius:10px;padding:.8rem;animation:.2s fadeIn}.wc-blank-picker p{color:var(--text-dim);margin-bottom:.5rem;font-size:.85rem}.wc-blank-letters{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.wc-blank-btn{color:#1a1a2e;cursor:pointer;background:#c4973a;border:1px solid #a07a2a;border-radius:4px;width:30px;height:30px;font-family:inherit;font-size:.75rem;font-weight:700;transition:all .15s}.wc-blank-btn:hover{background:#d4a74a;transform:scale(1.1)}.wc-lobby-players{text-align:center}.wc-lobby-players h3{color:var(--text-dim);margin-bottom:.5rem;font-size:.85rem}.wc-player-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.wc-player-item{background:var(--surface-light);border-radius:8px;align-items:center;gap:.6rem;padding:.5rem .8rem;font-size:.9rem;display:flex}.wc-player-num{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;font-weight:700;display:flex}.wc-host-badge{color:var(--gold);background:#ffd70026;border-radius:10px;margin-left:auto;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.wc-waiting-host{flex-direction:column;align-items:center;gap:.5rem;display:flex}.wc-scores-multi{flex-wrap:wrap;justify-content:center;gap:.4rem;width:100%;display:flex}.wc-player-score-card{background:var(--surface);border:1px solid #ffffff0f;border-radius:10px;flex-direction:column;align-items:center;gap:.1rem;min-width:80px;padding:.4rem .8rem;transition:all .3s;display:flex}.wc-player-score-card.active{border-color:var(--player-color);box-shadow:0 0 12px color-mix(in srgb, var(--player-color) 30%, transparent)}.wc-player-score-card.left{opacity:.4}.wc-psm-name{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:.65rem;overflow:hidden}.wc-player-score-card.active .wc-psm-name{color:var(--player-color)}.wc-psm-score{font-size:1.4rem;font-weight:800}@media (width<=480px){.wc-game{gap:.5rem}.wc-board{border-radius:6px;gap:1px;width:min(520px,98vw);padding:2px}.wc-cell{border-radius:2px}.wc-rack{flex-wrap:wrap;gap:4px;padding:.4rem}.wc-rack-tile{border-radius:4px;width:38px;height:38px}.wc-rack-letter{font-size:1rem}.wc-rack-value{font-size:.45rem}.wc-scores{gap:.4rem}.wc-player{min-width:80px;padding:.4rem .6rem}.wc-player-score{font-size:1.4rem}.wc-scores-multi{gap:.3rem}.wc-player-score-card{min-width:60px;padding:.3rem .5rem}.wc-psm-name{max-width:60px;font-size:.55rem}.wc-psm-score{font-size:1.1rem}.wc-bag-count{font-size:.65rem}.wc-actions{gap:.4rem}.wc-challenge-bar{gap:.5rem;padding:.5rem .8rem;font-size:.75rem}.wc-challenge-banner{font-size:.8rem}.wc-blank-picker{padding:.6rem}.wc-blank-btn{width:28px;height:28px;font-size:.7rem}.wc-result{font-size:1.1rem}}@media (width<=360px){.wc-board{border-radius:0;width:100vw}.wc-rack-tile{width:34px;height:34px}.wc-player-score-card{min-width:50px;padding:.2rem .4rem}.wc-psm-name{max-width:50px;font-size:.5rem}.wc-psm-score{font-size:.95rem}}@media (pointer:coarse){.wc-rack-tile{min-width:40px;min-height:40px}.wc-rack-tile:hover{transform:none}.wc-rack-selected{transform:translateY(-4px)}.wc-cell:hover:not(.wc-cell-filled):not(.wc-cell-disabled){background:var(--surface-light)}.btn-challenge,.btn-accept{min-height:44px;padding:.5rem 1.2rem}.wc-blank-btn{width:36px;height:36px;font-size:.85rem}}:root{--color-bg:#0d0b14;--color-bg-card:#161224;--color-bg-card-hover:#1e1832;--color-bg-input:#1a1528;--color-accent:#e8785e;--color-accent-light:#f09a7e;--color-gold:#ffd369;--color-teal:#4ecdc4;--color-green:#5ee09c;--color-coral:#ff6b6b;--color-purple:#a78bfa;--color-blue:#7ec8e3;--color-white:#fafafa;--color-muted:#ffffff80;--color-dimmed:#ffffff26;--color-border:#ffffff14;--font-family:"Outfit", -apple-system, sans-serif;--font-display:"Syne", "Outfit", sans-serif;--font-xs:11px;--font-sm:12px;--font-base:14px;--font-md:15px;--font-lg:17px;--font-xl:20px;--font-2xl:24px;--font-3xl:28px;--font-4xl:36px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--space-3xl:32px;--space-4xl:40px;--radius-sm:8px;--radius-md:12px;--radius-lg:14px;--radius-xl:16px;--radius-round:20px;--radius-pill:9999px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-standard:cubic-bezier(.4, 0, .2, 1);--ease-spring:cubic-bezier(.22, 1, .36, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #00000040;--shadow-lg:0 8px 32px #0000004d;--shadow-glow-accent:0 0 20px #e8785e4d;--shadow-glow-gold:0 0 20px #ffd3694d;--shadow-glow-teal:0 0 20px #4ecdc44d;--z-base:0;--z-card:10;--z-nav:100;--z-modal:1000;--nav-height:80px;--max-width:430px;--header-top:56px}.bottom-nav{width:100%;max-width:430px;padding:var(--space-sm) 0 28px;-webkit-backdrop-filter:blur(24px);z-index:var(--z-nav);background:#0d0b14d9;border-top:1px solid #ffffff0f;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{align-items:center;gap:var(--space-xs);color:var(--color-muted);font-size:var(--font-xs);cursor:pointer;transition:all .3s var(--ease-standard);letter-spacing:.5px;font-weight:400;font-family:var(--font-family);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:0 0;border:none;flex-direction:column;display:flex;position:relative}.nav-item:active{transform:scale(.92)}.nav-item--active{color:var(--color-accent);font-weight:600}.nav-item__icon{border-radius:var(--radius-pill);width:36px;height:28px;transition:all .3s var(--ease-standard);justify-content:center;align-items:center;display:flex}.nav-item--active .nav-item__icon{background:color-mix(in srgb, var(--color-accent) 15%, transparent);box-shadow:0 0 12px #e8785e33}.nav-item--active .nav-item__icon svg{filter:drop-shadow(0 0 4px #e8785e66)}.nav-item__label{font-size:var(--font-xs);transition:color .3s var(--ease-standard)}@media (width>=768px){.bottom-nav{max-width:720px}}@media (width>=1024px){.bottom-nav{max-width:960px;padding:var(--space-sm) var(--space-3xl);justify-content:flex-end;gap:var(--space-xs);background:#0d0b14eb;border-top:none;border-bottom:1px solid #ffffff0f;top:0;bottom:auto}.nav-item{gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);flex-direction:row}.nav-item__label{font-size:var(--font-sm)}}@media (width>=1280px){.bottom-nav{max-width:1100px}}.btn{border-radius:var(--radius-lg);width:100%;font-size:16px;font-weight:700;font-family:var(--font-family);cursor:pointer;letter-spacing:.3px;border:none;padding:15px;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn:active{transform:scale(.98)}.btn--primary{background:var(--color-accent);color:var(--color-bg);box-shadow:0 4px 15px #e8785e4d}.btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 25px #e8785e80}.btn--primary:active{transform:scale(.98);box-shadow:0 2px 8px #e8785e33}.btn--secondary{border:1px solid var(--color-border);color:var(--color-white);background:0 0}.btn--secondary:hover{background:#ffffff08;border-color:#fff3}.btn--secondary:active{transform:scale(.98)}.btn--social{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-white);justify-content:center;align-items:center;gap:10px;font-size:15px;font-weight:500;display:flex}.btn--social:hover{border-color:#ffffff26;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.btn--social:active{transform:scale(.98);box-shadow:0 2px 6px #0003}.btn--danger{color:var(--color-coral);background:0 0;border:1px solid #ff6b6b4d}.btn--danger:active{transform:scale(.98)}.input-group{margin-bottom:0}.input-label{font-size:var(--font-sm);color:var(--color-muted);margin-bottom:6px;display:block}.input{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-white);font-size:var(--font-md);font-family:var(--font-family);box-sizing:border-box;outline:none;padding:14px 16px;transition:border-color .2s,box-shadow .2s}.input::placeholder{color:#ffffff40}.input:hover{border-color:#ffffff26}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #e8785e26}textarea.input{resize:vertical;min-height:120px}select.input{appearance:none}.top-bar{padding-top:var(--header-top);padding-bottom:var(--space-lg);align-items:center;gap:var(--space-md);display:flex}.top-bar__back{color:var(--color-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:all .2s;display:flex}.top-bar__back:hover{color:var(--color-white);transform:translate(-2px)}.top-bar__back:active{transform:scale(.9)}.top-bar__title{font-size:var(--font-lg);color:var(--color-white);letter-spacing:-.3px;font-weight:600}.login{padding:var(--space-4xl) var(--space-2xl);flex-direction:column;justify-content:center;min-height:100vh;animation:.4s fadeIn;display:flex;position:relative;overflow:hidden}.login__glow{background:radial-gradient(circle, color-mix(in srgb, var(--color-accent) 18%, transparent) 0%, transparent 65%);pointer-events:none;filter:blur(20px);border-radius:50%;width:360px;height:360px;animation:5s ease-in-out infinite pulseGlow;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.login__glow:after{content:"";pointer-events:none;filter:blur(10px);background:radial-gradient(circle,#ffd36924 0%,#0000 65%);border-radius:50%;width:280px;height:280px;animation:5s ease-in-out -2.5s infinite pulseGlow;position:absolute;top:40px;left:55%}.login__logo{text-align:center;animation:scaleIn .7s var(--ease-spring) both;margin-bottom:48px;position:relative}.login__logo-icon{width:88px;height:88px;margin-bottom:var(--space-lg)}.login__logo-title{font-family:var(--font-display);letter-spacing:-1px;background:linear-gradient(90deg, var(--color-gold) 0%, var(--color-white) 30%, var(--color-gold) 50%, var(--color-white) 70%, var(--color-gold) 100%);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;font-size:34px;font-weight:800;line-height:1.1;animation:5s linear infinite shimmer}.login__logo-gold{color:var(--color-gold)}.login__logo-white{color:var(--color-white)}.login__logo-domain{font-family:var(--font-display);color:var(--color-accent);letter-spacing:3px;margin-top:var(--space-xs);font-size:20px;font-weight:600}.login__logo-tagline{color:var(--color-muted);font-size:var(--font-md);margin-top:var(--space-xl);line-height:1.6}.login__actions{gap:var(--space-md);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:var(--radius-round);padding:var(--space-2xl);animation:slideUp .6s var(--ease-spring) .2s both;background:#161224a6;border:1px solid #ffffff14;flex-direction:column;display:flex;position:relative}.login__actions .btn--primary{transition:all var(--duration-normal) ease}.login__actions .btn--primary:hover{transform:translateY(-2px);box-shadow:0 4px 24px #e8785e73}.login__actions .btn--social{transition:all var(--duration-normal) ease}.login__actions .btn--social:hover{border-color:#fff3;transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.login__divider{align-items:center;gap:var(--space-lg);margin:var(--space-sm) 0;display:flex}.login__divider-line{background:linear-gradient(90deg, transparent, var(--color-border), transparent);flex:1;height:1px}.login__divider-text{color:var(--color-dimmed);text-transform:uppercase;letter-spacing:1px;font-size:13px;font-family:var(--font-display);font-weight:600}.login__legal{text-align:center;font-size:var(--font-xs);color:var(--color-dimmed);margin-top:var(--space-3xl);letter-spacing:.3px;animation:slideUp .6s var(--ease-spring) .35s both;line-height:1.6}.login__form{gap:var(--space-lg);margin-top:var(--space-xl);padding:0 var(--space-2xl) var(--space-4xl);flex-direction:column;display:flex}.login__forgot{color:var(--color-accent);font-size:var(--font-base);cursor:pointer;font-family:var(--font-family);margin-top:var(--space-xs);transition:color var(--duration-fast) ease;background:0 0;border:none}.login__forgot:hover{color:var(--color-accent-light)}.login__error{color:var(--color-accent);font-size:var(--font-sm);text-align:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#e8785e1a;border:1px solid #e8785e33}.btn--coming-soon{opacity:.45;cursor:not-allowed;position:relative}.btn--coming-soon:hover{box-shadow:none;border-color:inherit;transform:none}.coming-soon-badge{font-size:var(--font-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;position:absolute;right:12px}@media (width>=1024px){.login{align-items:center}.login__logo-title{font-size:52px}.login__logo{margin-bottom:64px}.login__actions{width:100%;max-width:440px}.login__glow{width:500px;height:500px}}.home{min-height:100vh;padding-bottom:100px}.home__hero{padding:var(--header-top) var(--space-xl) var(--space-xl);background:linear-gradient(165deg, color-mix(in srgb, var(--color-accent) 12%, var(--color-bg)) 0%, color-mix(in srgb, var(--color-gold) 5%, var(--color-bg)) 50%, var(--color-bg) 100%);border-bottom:1px solid color-mix(in srgb, var(--color-accent) 10%, transparent);position:relative;overflow:hidden}.home__hero-orb{pointer-events:none;filter:blur(60px);border-radius:50%;position:absolute}.home__hero-orb--1{background:var(--color-accent);opacity:.12;width:200px;height:200px;animation:8s ease-in-out infinite float;top:-40px;right:-40px}.home__hero-orb--2{background:var(--color-gold);opacity:.08;width:150px;height:150px;animation:10s ease-in-out infinite reverse float;bottom:-20px;left:-30px}.home__hero-top{z-index:1;margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex;position:relative}.home__brand{align-items:center;gap:var(--space-md);display:flex}.home__logo{width:36px;height:36px}.home__wordmark{font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:-.3px;gap:5px;font-weight:700;display:flex}.home__wordmark-gold{color:var(--color-gold)}.home__wordmark-white{color:var(--color-white)}.home__avatar-btn{cursor:pointer;transition:border-color var(--duration-normal) var(--ease-standard), transform var(--duration-normal) var(--ease-standard);background:0 0;border:2px solid #ffffff1f;border-radius:50%;padding:2px}.home__avatar-btn:hover{border-color:#ffffff40;transform:scale(1.08)}.home__hero-body{z-index:1;position:relative}.home__headline{font-family:var(--font-display);letter-spacing:-.5px;color:var(--color-white);animation:slideUp .6s var(--ease-spring) both;font-size:24px;font-weight:800;line-height:1.2}.home__headline-accent{background:linear-gradient(90deg, var(--color-gold), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.home__online-strip{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);animation:slideUp .6s var(--ease-spring) .1s both;display:flex}.home__online-avatars{display:flex}.home__online-avatar{box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 12%, var(--color-bg));margin-left:-6px}.home__online-avatar:first-child{margin-left:0}.home__online-text{font-size:var(--font-sm);color:var(--color-muted)}.home__online-dot{background:var(--color-green);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulseGlow;transform:none;box-shadow:0 0 8px #5ee09c80}@keyframes pulseGlowDot{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.home__online-dot{animation:2s ease-in-out infinite pulseGlowDot}.home__featured{margin:calc(var(--space-xl) * -1) var(--space-xl) 0;padding:var(--space-xl) var(--space-xl);border-radius:var(--radius-round);cursor:pointer;background:linear-gradient(135deg, color-mix(in srgb, var(--card-color) 22%, var(--color-bg-card)), color-mix(in srgb, var(--card-color) 6%, var(--color-bg-card)));border:1px solid color-mix(in srgb, var(--card-color) 30%, transparent);box-shadow:0 8px 40px color-mix(in srgb, var(--card-color) 15%, transparent);transition:transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-slow) var(--ease-standard);animation:slideUp .5s var(--ease-spring) .15s both;z-index:2;position:relative;overflow:hidden}.home__featured:hover{box-shadow:0 16px 48px color-mix(in srgb, var(--card-color) 25%, transparent), inset 0 1px 0 #ffffff14;transform:translateY(-4px)scale(1.01)}.home__featured-pattern{background:repeating-linear-gradient(-45deg, transparent, transparent 12px, color-mix(in srgb, var(--card-color) 5%, transparent) 12px, color-mix(in srgb, var(--card-color) 5%, transparent) 13px);pointer-events:none;opacity:.6;position:absolute;inset:0}.home__featured-content{align-items:center;gap:var(--space-lg);z-index:1;display:flex;position:relative}.home__featured-icon{border-radius:var(--radius-md);background:color-mix(in srgb, var(--card-color) 18%, transparent);width:52px;height:52px;color:var(--card-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid color-mix(in srgb, var(--card-color) 20%, transparent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.home__featured-info{flex:1}.home__featured-label{font-family:var(--font-display);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:1.5px;color:var(--card-color);opacity:.8;font-weight:700}.home__featured-name{font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:-.3px;margin-top:2px;font-weight:800}.home__featured-desc{font-size:var(--font-sm);color:var(--color-muted);margin-top:var(--space-xs)}.home__featured-play{font-family:var(--font-display);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:1px;color:var(--color-bg);background:var(--card-color);padding:6px var(--space-lg);border-radius:var(--radius-pill);transition:transform var(--duration-fast) ease, box-shadow var(--duration-normal) ease;flex-shrink:0;font-weight:700}.home__featured:hover .home__featured-play{box-shadow:0 4px 16px color-mix(in srgb, var(--card-color) 40%, transparent);transform:scale(1.05)}.home__section-bar{padding:var(--space-2xl) var(--space-xl) var(--space-md);animation:slideUp .5s var(--ease-spring) .2s both;justify-content:space-between;align-items:center;display:flex}.home__section-title{font-family:var(--font-display);font-size:var(--font-lg);font-weight:700}.home__section-count{font-family:var(--font-display);font-size:var(--font-sm);color:var(--color-muted);background:var(--color-dimmed);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-weight:700;display:flex}.home__games-grid{gap:var(--space-md);padding:0 var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.home__game-card:last-child:nth-child(odd){grid-column:1/-1;justify-self:center;max-width:50%}.home__game-card{padding:var(--space-xl) var(--space-lg) var(--space-lg);text-align:center;align-items:center;gap:var(--space-sm);background:linear-gradient(155deg, color-mix(in srgb, var(--card-color) 14%, var(--color-bg-card)), var(--color-bg-card) 70%);border:1px solid color-mix(in srgb, var(--card-color) 12%, transparent);border-radius:var(--radius-round);cursor:pointer;transition:transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-standard), border-color var(--duration-normal) var(--ease-standard);animation:slideUp .5s var(--ease-spring) both;flex-direction:column;display:flex;position:relative;overflow:hidden}.home__game-pattern{pointer-events:none;opacity:.4;position:absolute;inset:0}.home__game-card--word .home__game-pattern{background-image:radial-gradient(color-mix(in srgb, var(--card-color) 15%, transparent) 1.5px, transparent 1.5px);background-size:14px 14px}.home__game-card--trivia .home__game-pattern{background:repeating-radial-gradient(circle at 70% 30%, transparent, transparent 18px, color-mix(in srgb, var(--card-color) 6%, transparent) 18px, color-mix(in srgb, var(--card-color) 6%, transparent) 19px)}.home__game-card--memory .home__game-pattern{background-image:linear-gradient(45deg, color-mix(in srgb, var(--card-color) 6%, transparent) 25%, transparent 25%), linear-gradient(-45deg, color-mix(in srgb, var(--card-color) 6%, transparent) 25%, transparent 25%), linear-gradient(45deg, transparent 75%, color-mix(in srgb, var(--card-color) 6%, transparent) 75%), linear-gradient(-45deg, transparent 75%, color-mix(in srgb, var(--card-color) 6%, transparent) 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px}.home__game-card--connect .home__game-pattern{background-image:radial-gradient(circle, color-mix(in srgb, var(--card-color) 10%, transparent) 8px, transparent 8px);background-size:28px 28px}.home__game-card--math .home__game-pattern{background:repeating-linear-gradient(-55deg, transparent, transparent 8px, color-mix(in srgb, var(--card-color) 7%, transparent) 8px, color-mix(in srgb, var(--card-color) 7%, transparent) 9px)}.home__game-card:hover{border-color:color-mix(in srgb, var(--card-color) 35%, transparent);box-shadow:0 12px 32px color-mix(in srgb, var(--card-color) 22%, transparent), inset 0 1px 0 #ffffff0f;transform:translateY(-6px)scale(1.02)}.home__game-card:active{transform:translateY(-2px)scale(.98)}.home__game-icon{z-index:1;background:color-mix(in srgb, var(--card-color) 15%, transparent);width:56px;height:56px;color:var(--card-color);border:1px solid color-mix(in srgb, var(--card-color) 15%, transparent);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.home__game-name{z-index:1;font-family:var(--font-display);font-size:var(--font-md);letter-spacing:-.3px;font-weight:700;position:relative}.home__game-desc{z-index:1;font-size:var(--font-sm);color:var(--color-muted);line-height:1.3;position:relative}.home__game-tag{z-index:1;border-radius:var(--radius-pill);font-family:var(--font-display);background:color-mix(in srgb, var(--card-color) 12%, transparent);color:var(--card-color);letter-spacing:.5px;padding:2px 10px;font-size:10px;font-weight:600;display:inline-block;position:relative}.home__join{margin:var(--space-2xl) var(--space-xl) 0;align-items:center;gap:var(--space-lg);background:linear-gradient(135deg, color-mix(in srgb, var(--color-teal) 12%, var(--color-bg-card)), var(--color-bg-card));border:1px solid color-mix(in srgb, var(--color-teal) 20%, transparent);border-radius:var(--radius-round);padding:var(--space-lg) var(--space-xl);cursor:pointer;transition:transform var(--duration-normal) var(--ease-out), box-shadow var(--duration-normal) var(--ease-standard);animation:slideUp .5s var(--ease-spring) .45s both;display:flex;position:relative;overflow:hidden}.home__join-glow{background:var(--color-teal);opacity:.06;filter:blur(40px);pointer-events:none;border-radius:50%;width:120px;height:120px;position:absolute;top:50%;left:20%;transform:translateY(-50%)}.home__join:hover{box-shadow:0 8px 28px color-mix(in srgb, var(--color-teal) 18%, transparent), inset 0 1px 0 #ffffff0f;transform:translateY(-3px)}.home__join-icon{border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-teal) 16%, transparent);width:44px;height:44px;color:var(--color-teal);z-index:1;border:1px solid color-mix(in srgb, var(--color-teal) 15%, transparent);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.home__join-text{z-index:1;flex:1;position:relative}.home__join-title{font-family:var(--font-display);font-size:var(--font-md);font-weight:700}.home__join-sub{font-size:var(--font-sm);color:var(--color-muted);margin-top:1px}.home__join-arrow{font-size:var(--font-xl);color:var(--color-teal);opacity:.6;transition:transform var(--duration-normal) ease, opacity var(--duration-normal) ease;z-index:1;position:relative}.home__join:hover .home__join-arrow{opacity:1;transform:translate(4px)}@media (width>=768px){.home__hero{padding:var(--header-top) var(--space-3xl) var(--space-4xl)}.home__headline{font-size:36px}.home__hero{padding-bottom:var(--space-3xl)}.home__hero-top{margin-bottom:var(--space-2xl)}.home__games-grid{padding:0 var(--space-3xl);gap:var(--space-lg);grid-template-columns:repeat(3,1fr)}.home__game-card:last-child:nth-child(odd){grid-column:auto;justify-self:auto;max-width:100%}.home__featured{margin-left:var(--space-3xl);margin-right:var(--space-3xl);padding:var(--space-2xl) var(--space-2xl)}.home__featured-icon{border-radius:var(--radius-lg);width:72px;height:72px}.home__featured-name{font-size:var(--font-xl)}.home__featured-play{font-size:var(--font-sm);padding:var(--space-sm) var(--space-xl)}.home__section-bar{padding-left:var(--space-3xl);padding-right:var(--space-3xl)}.home__join{margin-left:var(--space-3xl);margin-right:var(--space-3xl)}}@media (width>=1024px){.home{padding-bottom:var(--space-4xl)}.home__hero{padding:80px var(--space-4xl) var(--space-4xl)}.home__headline{font-size:44px}.home__hero{padding-bottom:var(--space-4xl)}.home__hero-top{margin-bottom:var(--space-3xl)}.home__hero-orb--1{width:320px;height:320px}.home__hero-orb--2{width:240px;height:240px}.home__games-grid{padding:0 var(--space-4xl);grid-template-columns:repeat(3,1fr)}.home__game-card{padding:var(--space-2xl) var(--space-xl) var(--space-xl)}.home__game-icon{width:64px;height:64px}.home__game-name{font-size:var(--font-lg)}.home__featured{margin-left:var(--space-4xl);margin-right:var(--space-4xl);padding:var(--space-3xl)}.home__featured-icon{border-radius:var(--radius-lg);width:80px;height:80px}.home__featured-name{font-size:var(--font-2xl)}.home__section-bar{padding-left:var(--space-4xl);padding-right:var(--space-4xl)}.home__join{margin-left:var(--space-4xl);margin-right:var(--space-4xl);max-width:520px}}.card{background:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-md);border:1px solid var(--color-border);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.card:hover{border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 8px 24px #0003}.card:active{transform:scale(.99)}.badge{border-radius:var(--radius-round);font-size:var(--font-xs);letter-spacing:.5px;padding:3px 10px;font-weight:600;display:inline-block}.leaderboard{padding:0 var(--space-xl) 100px;min-height:100vh}.leaderboard__header{padding-top:var(--header-top);padding-bottom:var(--space-lg);animation:slideUp .5s var(--ease-spring) both}.leaderboard__title{font-family:var(--font-display);font-size:var(--font-4xl);letter-spacing:-1px;background:linear-gradient(90deg, var(--color-gold), var(--color-accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.leaderboard__subtitle{font-size:var(--font-base);color:var(--color-muted);margin-top:var(--space-xs)}.leaderboard__tabs{gap:var(--space-sm);margin-bottom:var(--space-2xl);animation:slideUp .5s var(--ease-spring) 80ms both;display:flex}.leaderboard__tab{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-pill);font-size:13px;font-weight:600;font-family:var(--font-display);cursor:pointer;text-transform:capitalize;letter-spacing:.3px;transition:all var(--duration-normal) ease;border:1px solid #0000}.leaderboard__tab--active{background:linear-gradient(135deg, var(--color-accent), color-mix(in srgb, var(--color-accent) 80%, var(--color-gold)));color:var(--color-bg);box-shadow:0 4px 16px #e8785e59}.leaderboard__tab--inactive{background:var(--color-bg-card);color:var(--color-muted)}.leaderboard__tab--inactive:hover{background:var(--color-bg-card-hover);color:var(--color-white);border-color:var(--color-border)}.leaderboard__podium{justify-content:center;align-items:flex-end;gap:var(--space-md);margin-bottom:var(--space-3xl);animation:scaleIn .7s var(--ease-spring) .15s both;padding:0 10px;display:flex}.leaderboard__podium-item{flex-direction:column;flex:1;align-items:center;display:flex}.leaderboard__podium-avatar-wrap{margin-bottom:var(--space-sm);transition:transform .3s var(--ease-out);border-radius:50%}.leaderboard__podium-item:hover .leaderboard__podium-avatar-wrap{transform:scale(1.1)translateY(-4px)}.leaderboard__podium-avatar-wrap--first{box-shadow:0 0 0 3px var(--color-gold), 0 0 20px #ffd36966}.leaderboard__podium-item:first-child .leaderboard__podium-avatar-wrap{box-shadow:0 0 0 2px silver,0 0 12px #c0c0c04d}.leaderboard__podium-item:nth-child(3) .leaderboard__podium-avatar-wrap{box-shadow:0 0 0 2px #cd7f32,0 0 12px #cd7f324d}.leaderboard__podium-name{font-family:var(--font-display);margin-bottom:var(--space-xs);font-size:13px;font-weight:700}.leaderboard__podium-pts{font-size:var(--font-xs);color:var(--color-gold);margin-bottom:var(--space-sm);font-weight:600}.leaderboard__podium-bar{border-radius:var(--radius-md) var(--radius-md) 0 0;width:100%;padding-top:var(--space-md);background:linear-gradient(to top, color-mix(in srgb, var(--bar-color) 22%, transparent), color-mix(in srgb, var(--bar-color) 4%, transparent));border:1px solid color-mix(in srgb, var(--bar-color) 22%, transparent);border-bottom:none;flex-direction:column;justify-content:flex-start;align-items:center;transition:box-shadow .3s;display:flex;position:relative;overflow:hidden}.leaderboard__podium-bar:after{content:"";pointer-events:none;background:linear-gradient(105deg,#0000 30%,#ffffff0a 45%,#ffffff14 50%,#ffffff0a 55%,#0000 70%) 0 0/200% 100%;animation:4s ease-in-out infinite shimmer;position:absolute;inset:0}.leaderboard__podium-item:nth-child(2) .leaderboard__podium-bar{box-shadow:inset 0 1px 20px #ffffff0a,0 0 24px #ffd36940,0 0 48px #ffd3691a}.leaderboard__podium-medal{z-index:1;filter:drop-shadow(0 2px 4px #0000004d);font-size:24px;position:relative}.leaderboard__rankings{animation:slideUp .5s var(--ease-spring) .24s both}.leaderboard__rank-item{align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-sm);border-bottom:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--duration-normal) ease;animation:slideInRight .4s var(--ease-spring) both;display:flex}.leaderboard__rank-item:hover{background:#ffffff08;transform:translate(6px)}.leaderboard__rank-num{width:28px;font-family:var(--font-display);font-size:var(--font-base);font-weight:800}.leaderboard__rank-num--top{color:var(--color-gold);text-shadow:0 0 12px #ffd36980}.leaderboard__rank-num--rest{color:var(--color-dimmed)}.leaderboard__rank-info-col{flex:1}.leaderboard__rank-name{font-size:var(--font-md);font-weight:600}.leaderboard__rank-meta{font-size:var(--font-sm);color:var(--color-muted)}.leaderboard__rank-pts{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-gold);font-weight:800}.leaderboard__child-badge{font-size:var(--font-xs);margin-left:var(--space-xs);vertical-align:middle}.leaderboard__podium-item .leaderboard__child-badge{margin-left:0;margin-bottom:var(--space-xs)}.leaderboard__stats{margin-top:var(--space-2xl);animation:slideUp .5s var(--ease-spring) .32s both}.leaderboard__stats-title{font-family:var(--font-display);font-size:var(--font-base);margin-bottom:var(--space-lg);color:var(--color-gold);font-weight:700}.leaderboard__stats-grid{gap:var(--space-md);text-align:center;grid-template-columns:1fr 1fr 1fr;display:grid}.leaderboard__stats-grid>div{padding:var(--space-lg) var(--space-sm);border-radius:var(--radius-md);border:1px solid var(--color-border);background:linear-gradient(135deg,#ffffff06,#ffffff01);transition:transform .2s,border-color .2s}.leaderboard__stats-grid>div:hover{border-color:#ffffff1f;transform:translateY(-2px)}.leaderboard__stats-val{font-family:var(--font-display);font-size:24px;font-weight:800}.leaderboard__stats-grid>div:first-child .leaderboard__stats-val{color:var(--color-gold)}.leaderboard__stats-grid>div:nth-child(2) .leaderboard__stats-val{color:var(--color-teal)}.leaderboard__stats-grid>div:nth-child(3) .leaderboard__stats-val{color:var(--color-coral)}.leaderboard__stats-label{font-size:var(--font-xs);color:var(--color-muted);margin-top:2px}@media (width>=768px){.leaderboard{padding:0 var(--space-3xl) 100px}.leaderboard__title{font-size:44px}.leaderboard__podium{gap:var(--space-lg);max-width:520px;margin-left:auto;margin-right:auto}}@media (width>=1024px){.leaderboard{padding:0 var(--space-4xl) var(--space-4xl)}.leaderboard__header{padding-top:80px}.leaderboard__podium{max-width:580px}.leaderboard__stats-val{font-size:var(--font-3xl)}.leaderboard__stats-grid>div{padding:var(--space-xl) var(--space-lg)}}.settings{padding:0 var(--space-xl) 100px;min-height:100vh}.settings__header{padding-top:var(--header-top);padding-bottom:var(--space-2xl);animation:slideUp .45s var(--ease-spring) both}.settings__title{font-family:var(--font-display);font-size:var(--font-3xl);letter-spacing:-.5px;font-weight:700}.settings__user{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--space-lg);animation:slideUp .5s var(--ease-spring) 60ms both;background:#16122499;border:1px solid #ffffff14;display:flex;position:relative;overflow:hidden}.settings__user:before{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#4ecdc40f 0%,#4ecdc405 50%,#0000 100%);position:absolute;inset:0}.settings__user-info{z-index:1;position:relative}.settings__user-name{font-family:var(--font-display);font-size:var(--font-lg);font-weight:700}.settings__user-email{color:var(--color-muted);font-size:13px}.settings__section{margin-bottom:var(--space-2xl);animation:slideUp .5s var(--ease-spring) both}.settings__section:first-child{animation-delay:.12s}.settings__section:nth-child(2){animation-delay:.18s}.settings__section:nth-child(3){animation-delay:.24s}.settings__section:nth-child(4){animation-delay:.3s}.settings__section:nth-child(5){animation-delay:.36s}.settings__section:nth-child(6){animation-delay:.42s}.settings__section-label{font-family:var(--font-display);font-size:var(--font-sm);color:var(--color-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--space-xs);padding-left:var(--space-xs);font-weight:600}.settings__section>.card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.settings__row{padding:var(--space-md) var(--space-lg);align-items:center;gap:var(--space-lg);cursor:pointer;transition:background .2s,transform .2s;display:flex}.settings__row:not(:last-child){border-bottom:1px solid var(--color-border)}.settings__row:hover{background:#ffffff08;transform:translate(2px)}.settings__row:active{transform:scale(.99)}.settings__row-icon{color:var(--color-muted);align-items:center;transition:filter .2s,text-shadow .2s;display:flex}.settings__row:hover .settings__row-icon{filter:drop-shadow(0 0 6px)}.settings__row-icon--accent{color:var(--color-gold)}.settings__row:hover .settings__row-icon--accent{filter:drop-shadow(0 0 8px #ffd36980)}.settings__row-content{flex:1}.settings__row-label{font-size:var(--font-md);font-weight:500}.settings__row-label--accent{color:var(--color-gold)}.settings__row-sub{font-size:var(--font-sm);color:var(--color-muted);margin-top:1px}.settings__row-chevron{color:var(--color-muted);margin-left:auto;transition:transform .2s}.settings__row:hover .settings__row-chevron{transform:translate(2px)}.settings__row:has(.settings__row-icon--accent){border-left:2px solid var(--color-gold);background:linear-gradient(90deg,#ffd3690d 0%,#ffd36905 60%,#0000 100%)}.settings__row:has(.settings__row-icon--accent):hover{background:linear-gradient(90deg,#ffd36917 0%,#ffd3690a 60%,#ffffff05 100%)}.settings__signout{width:100%;margin-top:var(--space-sm);margin-bottom:var(--space-lg);animation:slideUp .5s var(--ease-spring) .4s both}.settings__signout.btn--danger:hover{background:#ff6b6b0f;border-color:#ff6b6b73;box-shadow:0 0 15px #ff6b6b33}.settings__signout-error{text-align:center;color:var(--color-accent);font-size:var(--font-sm);margin-top:var(--space-xs);margin-bottom:var(--space-lg)}.settings__version{text-align:center;font-size:var(--font-sm);color:var(--color-dimmed);padding-bottom:var(--space-xl);letter-spacing:1px;animation:slideUp .5s var(--ease-spring) .46s both}@media (width>=768px){.settings{padding:0 var(--space-3xl) 100px}.settings__title{font-size:var(--font-4xl)}.settings__sections-wrap{gap:var(--space-2xl);grid-template-columns:1fr 1fr;display:grid}}@media (width>=1024px){.settings{padding:0 var(--space-4xl) var(--space-4xl)}.settings__user{max-width:480px}.settings__signout{max-width:320px}.settings__header{padding-top:80px}}.family{min-height:100vh;padding:0 20px 100px;animation:.3s fadeIn}.family__info{text-align:center;margin-top:8px;padding:24px}.family__info-emoji{margin-bottom:8px;font-size:42px}.family__info-title{font-size:20px;font-weight:700}.family__info-detail{color:var(--color-muted);margin-top:4px;font-size:13px}.family__info-code{color:var(--color-gold);font-weight:600}.family__invite-section{text-align:center;margin-top:16px;padding:20px 24px}.family__invite-label{color:var(--color-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-size:12px;font-weight:600}.family__invite-code{color:var(--color-gold);letter-spacing:4px;margin-bottom:16px;font-family:monospace;font-size:28px;font-weight:700}.family__invite-actions{justify-content:center;gap:12px;display:flex}.family__invite-btn{align-items:center;gap:6px;padding:8px 16px;font-size:14px;display:flex}.family__invite-btn--copied{color:var(--color-teal)}.family__invite{justify-content:center;align-items:center;gap:8px;margin-top:16px;margin-bottom:24px;display:flex}.family__section-label{color:var(--color-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;padding-left:4px;font-size:12px;font-weight:600}.family__section-label--danger{color:var(--color-coral);margin-top:32px}.family__member{align-items:center;gap:12px;padding:14px 16px;display:flex}.family__member:not(:last-child){border-bottom:1px solid var(--color-border)}.family__member-avatar{font-size:28px}.family__member-name{font-size:15px;font-weight:600}.family__member-stats{color:var(--color-muted);font-size:12px}.family__danger-row{cursor:pointer;align-items:center;gap:14px;padding:15px 16px;display:flex}.family__danger-row:not(:last-child){border-bottom:1px solid var(--color-border)}.family__danger-icon{color:var(--color-coral)}.family__danger-label{font-size:15px;font-weight:500}.family__danger-label--red{color:var(--color-coral)}.family__danger-chevron{color:var(--color-muted);margin-left:auto}.family__create-input{border:1px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);box-sizing:border-box;border-radius:10px;outline:none;padding:12px 14px;font-size:15px;transition:border-color .2s}.family__create-input:focus{border-color:var(--color-teal)}.family__create-error{color:var(--color-coral);margin-top:8px;margin-bottom:0;font-size:13px}.family__role-toggle{all:unset;cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;min-width:44px;min-height:44px;margin-left:auto;display:flex}.family__role-toggle:active{opacity:.6}.family__role-toggle--loading{opacity:.4;pointer-events:none}.family__member-remove{all:unset;color:var(--color-coral);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;min-width:36px;min-height:36px;margin-left:4px;transition:opacity .15s;display:flex}.family__member-remove:hover{opacity:.7}.family__member-remove:active{opacity:.5}.family__confirm-overlay{flex-direction:column;align-items:center;gap:10px;width:100%;padding:4px 0;display:flex}.family__confirm-text{text-align:center;color:var(--color-text);margin:0;font-size:14px;font-weight:600}.family__confirm-actions{gap:10px;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%,to{opacity:.15;transform:translate(-50%)scale(1)}50%{opacity:.25;transform:translate(-50%)scale(1.15)}}@keyframes radioDotPulse{0%,to{box-shadow:0 0 #ffd36966}50%{box-shadow:0 0 8px 3px #ffd36940}}.subscription{min-height:100vh;padding:0 20px 100px;animation:.3s fadeIn}.subscription__hero{text-align:center;padding:16px 0 28px;animation:.5s both slideUp;position:relative}.subscription__hero-emoji{margin-bottom:8px;font-size:48px;display:inline-block;position:relative}.subscription__hero-emoji:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(circle,#ffd36933 0%,#e8785e14 40%,#0000 70%);border-radius:50%;width:120px;height:120px;animation:4s ease-in-out infinite pulseGlow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.subscription__hero-title{color:var(--color-gold);text-shadow:0 0 20px #ffd3694d;font-size:24px;font-weight:800}.subscription__hero-desc{color:var(--color-muted);margin-top:6px;font-size:14px}.subscription__feature{cursor:default;align-items:center;gap:12px;padding:10px 0;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex}.subscription__feature:hover{transform:translate(4px)}.subscription__feature:not(:last-child){border-bottom:1px solid var(--color-border)}.subscription__feature-icon{font-size:20px;transition:transform .25s cubic-bezier(.4,0,.2,1)}.subscription__feature:hover .subscription__feature-icon{transform:scale(1.1)}.subscription__feature-text{font-size:14px;font-weight:500}.subscription__hero+.card{animation:.5s .1s both slideUp}.subscription__plan{cursor:pointer;align-items:center;padding:18px 20px;transition:border-color .25s,box-shadow .25s;display:flex;position:relative}.subscription__plan:hover{border-color:#ffffff2e}.subscription__plan--selected{border-color:var(--color-gold);border-width:2px;box-shadow:0 0 20px #ffd36940}.subscription__plan--selected:hover{border-color:var(--color-gold);box-shadow:0 0 28px #ffd3694d}.subscription__hero+.card+div{animation:.5s .2s both slideUp}.subscription__radio{border:2px solid var(--color-muted);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-right:14px;transition:border-color .25s;display:flex}.subscription__radio--selected{border-color:var(--color-gold)}.subscription__radio-dot{background:var(--color-gold);border-radius:6px;width:12px;height:12px;animation:2s ease-in-out infinite radioDotPulse}.subscription__plan-label{font-size:16px;font-weight:700}.subscription__plan-sub{color:var(--color-muted);font-size:12px}.subscription__plan-price{color:var(--color-gold);margin-left:auto;font-size:20px;font-weight:800}.subscription__best-value{background:linear-gradient(135deg, var(--color-gold) 0%, #ffb347 100%);color:var(--color-bg);border-radius:var(--radius-pill);padding:3px 10px;font-size:10px;font-weight:700;position:absolute;top:-10px;right:16px;box-shadow:0 0 12px #ffd3694d}.subscription__cta{margin-top:20px}.subscription__cta.btn--primary{transition:all .25s;box-shadow:0 4px 15px #ffd36940}.subscription__cta.btn--primary:hover{transform:translateY(-1px);box-shadow:0 0 25px #ffd36966}.subscription__cta.btn--primary:active{transform:scale(.98);box-shadow:0 2px 8px #ffd36926}.subscription__cancel-text{text-align:center;color:var(--color-muted);margin-top:10px;font-size:12px}.subscription__current{margin-top:24px;animation:.5s .3s both slideUp}.subscription__current-label{color:var(--color-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-size:12px;font-weight:600}.subscription__current-row{justify-content:space-between;align-items:center;display:flex}.subscription__current-name{font-size:16px;font-weight:700}.subscription__current-info{color:var(--color-muted);font-size:12px}.legal{min-height:100vh;padding:0 20px 100px;animation:.3s fadeIn}.legal__content{line-height:1.7}.legal__date{color:var(--color-muted);margin-bottom:16px;font-size:12px}.legal__section{margin-bottom:20px}.legal__section-title{margin-bottom:6px;font-size:15px;font-weight:700}.legal__section-body{color:var(--color-muted);font-size:14px}.contact{min-height:100vh;padding:0 20px 100px;animation:.3s fadeIn}.contact__hero{text-align:center;padding:16px 0 28px}.contact__hero-emoji{margin-bottom:8px;font-size:42px}.contact__hero-title{font-size:22px;font-weight:700}.contact__hero-desc{color:var(--color-muted);margin-top:6px;font-size:14px}.contact__form{flex-direction:column;gap:14px;display:flex}.contact__other{text-align:center;margin-top:28px}.contact__other-title{margin-bottom:12px;font-size:14px;font-weight:600}.contact__other-links{color:var(--color-muted);font-size:14px;line-height:2}.avatar-picker__grid{gap:var(--space-md);padding:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.avatar-picker__item{aspect-ratio:1;border:2px solid var(--color-border);background:var(--avatar-color);cursor:pointer;transition:all .2s var(--ease-standard);border-radius:50%;outline:none;justify-content:center;align-items:center;padding:0;display:flex}.avatar-picker__item:hover:not(:disabled){border-color:#ffffff4d;transform:scale(1.08)}.avatar-picker__item:active:not(:disabled){transform:scale(.95)}.avatar-picker__item--selected{border-color:var(--color-accent);box-shadow:0 0 0 3px #e8785e66}.avatar-picker__item:disabled{opacity:.5;cursor:not-allowed}.avatar-picker__emoji{font-size:28px;line-height:1}@media (width<=360px){.avatar-picker__grid{grid-template-columns:repeat(3,1fr)}}@media (width>=768px){.avatar-picker__grid{gap:var(--space-lg);grid-template-columns:repeat(6,1fr)}.avatar-picker__emoji{font-size:32px}}@media (width>=1024px){.avatar-picker__grid{grid-template-columns:repeat(6,1fr)}}.profile{padding:0 var(--space-xl) 100px;min-height:100vh;animation:.3s fadeIn}.profile__loading{padding-top:var(--space-4xl);justify-content:center;display:flex}.profile__spinner{border:3px solid var(--color-dimmed);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.profile__error-card{margin-top:var(--space-lg)}.profile__error{color:var(--color-coral);font-size:var(--font-base);text-align:center;padding:var(--space-lg)}.profile__hero{align-items:center;gap:var(--space-sm);margin-top:var(--space-lg);margin-bottom:var(--space-2xl);animation:slideUp .5s var(--ease-spring) 60ms both;flex-direction:column;display:flex}.profile__hero-name{font-family:var(--font-display);font-size:var(--font-2xl);letter-spacing:-.5px;margin-top:var(--space-sm);font-weight:700}.profile__section-label{font-family:var(--font-display);font-size:var(--font-sm);color:var(--color-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:var(--space-xs);padding-left:var(--space-xs);animation:slideUp .5s var(--ease-spring) .12s both;font-weight:600}.profile__section-label+.card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);animation:slideUp .5s var(--ease-spring) .18s both;overflow:hidden}.profile__row{padding:var(--space-md) var(--space-lg);justify-content:space-between;align-items:center;display:flex}.profile__row:not(:last-child){border-bottom:1px solid var(--color-border)}.profile__row-label{font-size:var(--font-md);color:var(--color-muted)}.profile__row-value{font-size:var(--font-md);text-align:right;text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-weight:500;overflow:hidden}.profile__row-value--editable{cursor:pointer;align-items:center;gap:var(--space-xs);display:inline-flex}.profile__edit-icon{font-size:var(--font-sm);color:var(--color-muted);transition:color .15s}.profile__row-value--editable:hover .profile__edit-icon{color:var(--color-accent)}.profile__row--editing{align-items:flex-start;gap:var(--space-sm);flex-direction:column}.profile__edit-group{gap:var(--space-sm);flex-direction:column;width:100%;display:flex}.profile__edit-group .input{width:100%}.profile__edit-actions{gap:var(--space-sm);justify-content:flex-end;display:flex}.profile__edit-actions .btn{padding:var(--space-xs) var(--space-md);font-size:var(--font-sm)}.profile__save-error{color:var(--color-coral);font-size:var(--font-sm)}.profile__avatar-card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);margin-bottom:var(--space-2xl);animation:slideUp .5s var(--ease-spring) .12s both}.profile__avatar-status{justify-content:center;align-items:center;gap:var(--space-sm);padding:0 var(--space-lg) var(--space-lg);font-size:var(--font-sm);color:var(--color-muted);display:flex}.profile__avatar-status--success{color:var(--color-green)}.profile__avatar-status--error{color:var(--color-coral)}.profile__spinner--small{border-width:2px;width:16px;height:16px}@media (width>=768px){.profile{padding:0 var(--space-3xl) 100px}}@media (width>=1024px){.profile{padding:0 var(--space-4xl) var(--space-4xl)}.profile__hero{margin-top:var(--space-2xl)}}.join-family{min-height:100vh;padding:0 20px 100px;animation:.3s fadeIn}.join-family__prompt{text-align:center;color:var(--color-muted);margin-bottom:16px;font-size:14px}.join-family__form{flex-direction:column;gap:12px;padding:4px 0;display:flex}.join-family__error{color:var(--color-coral);text-align:center;margin:0;font-size:13px}.join-family__preview{text-align:center;padding:8px 0}.join-family__preview-emoji{margin-bottom:8px;font-size:42px}.join-family__preview-name{margin-bottom:4px;font-size:20px;font-weight:700}.join-family__preview-count{color:var(--color-muted);margin-bottom:20px;font-size:13px}.join-family__actions{flex-direction:column;gap:10px;display:flex}.join-family__cancel{color:var(--color-muted);cursor:pointer;font-size:14px;font-family:var(--font-family);background:0 0;border:none;padding:10px}.join-family__cancel:hover{color:var(--color-white)}.join-family__success{text-align:center;padding:8px 0}.join-family__success-emoji{margin-bottom:12px;font-size:48px}.join-family__success-title{color:var(--color-green);margin-bottom:4px;font-size:20px;font-weight:700}.join-family__success-detail{color:var(--color-muted);margin-bottom:20px;font-size:14px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{touch-action:manipulation;-webkit-tap-highlight-color:transparent}body{color:#fafafa;background:#0d0b14;min-height:100dvh;font-family:Outfit,-apple-system,sans-serif}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.screen-enter{animation:fadeIn .3s var(--ease-spring) both}input::placeholder,textarea::placeholder{color:#ffffff40}::-webkit-scrollbar{display:none}select option{color:#fafafa;background:#1a1528}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}button,[role=button],a,input,select,textarea{min-height:44px}.app-shell{color:#fafafa;background:#0d0b14;max-width:430px;min-height:100dvh;margin:0 auto;font-family:Outfit,-apple-system,sans-serif;position:relative;overflow-x:hidden}.app-shell:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 25% 0,#e8785e12 0%,#0000 50%),radial-gradient(at 75% 5%,#4ecdc40d 0%,#0000 45%),radial-gradient(at 50% 95%,#a78bfa0d 0%,#0000 40%);width:100%;max-width:430px;height:100%;position:fixed;top:0;left:50%;transform:translate(-50%)}.app-shell>*{z-index:1;position:relative}@media (width>=768px){.app-shell,.app-shell:after{max-width:720px}}@media (width>=1024px){.app-shell,.app-shell:after{max-width:960px}}@media (width>=1280px){.app-shell,.app-shell:after{max-width:1100px}}.app-loading{justify-content:center;align-items:center;display:flex}.app-loading__content{align-items:center;gap:var(--space-xl);flex-direction:column;display:flex}.app-loading__logo{opacity:.9;width:64px;height:64px}.app-loading__spinner{border:2px solid var(--color-dimmed);border-top-color:var(--color-accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite app-spin}@keyframes app-spin{to{transform:rotate(360deg)}}
