: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}@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:scale(.95)}to{opacity:1;transform:scale(1)}}@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}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0e17;--surface:#1a1a2e;--surface-light:#232347;--text:#fffffe;--text-dim:#a7a9be;--accent:#e53170}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Poppins,sans-serif}.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);animation:4s ease-in-out infinite alternate twinkle;position:fixed;inset:0}.hub{z-index:1;flex-direction:column;align-items:center;min-height:100vh;padding:3rem 1.5rem;display:flex;position:relative}.hub-header{text-align:center;margin-bottom:3rem;animation:.6s ease-out slideDown}.hub-title{background:linear-gradient(135deg,#ff6b6b,gold,#4ecdc4);-webkit-text-fill-color:transparent;letter-spacing:.02em;-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:800}.hub-subtitle{color:var(--text-dim);margin-top:.5rem;font-size:1.1rem}.hub-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;width:min(900px,100%);animation:.5s ease-out .2s both fadeIn;display:grid}.game-card{background:var(--surface);text-align:center;color:inherit;cursor:pointer;border:1px solid #ffffff0f;border-radius:20px;flex-direction:column;align-items:center;gap:.8rem;padding:2rem;text-decoration:none;transition:all .3s;display:flex}.game-card:hover{border-color:var(--card-color,#ffffff26);box-shadow:0 20px 50px var(--card-glow,#0000004d);transform:translateY(-6px)}.game-card:active{transform:translateY(-2px)}.game-card-icon{font-size:3rem;line-height:1}.game-card-name{font-size:1.4rem;font-weight:700}.game-card:hover .game-card-name{color:var(--card-color,var(--text))}.game-card-desc{color:var(--text-dim);font-size:.85rem;line-height:1.4}.game-card-players{background:var(--surface-light);color:var(--text-dim);border-radius:20px;margin-top:auto;padding:.3rem .8rem;font-size:.7rem;font-weight:600}.game-card-coming{opacity:.5;cursor:default;border-style:dashed}.game-card-coming:hover{box-shadow:none;border-color:#ffffff0f;transform:none}.hub-footer{color:var(--text-dim);opacity:.5;margin-top:auto;padding-top:3rem;font-size:.75rem}@media (width<=480px){.hub{padding:2rem 1rem}.hub-header{margin-bottom:2rem}.hub-title{font-size:2.5rem}.hub-subtitle{font-size:.95rem}.hub-grid{grid-template-columns:1fr;gap:1rem}.game-card{border-radius:16px;padding:1.5rem}.game-card-icon{font-size:2.4rem}.game-card-name{font-size:1.2rem}}@media (width<=360px){.hub-title{font-size:2rem}.game-card{padding:1.2rem}}@media (pointer:coarse){.game-card{min-height:140px}}
