@import"https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@400;700;900&display=swap";:root{--bg: #050810;--surface: #0d1424;--surface2: #131d30;--border: #1e3a5f;--border2: #2a4d7a;--cyan: #00d4ff;--cyan-dim: #0099cc;--gold: #f5c518;--red: #ff4444;--green: #44ff88;--text: #c8ddf0;--text-dim: #5a7a9a;--x-color: #ff6b6b;--o-color: #4ecdc4;--glow-cyan: 0 0 12px rgba(0, 212, 255, .5);--glow-gold: 0 0 12px rgba(245, 197, 24, .5);--radius: 4px;--font-mono: "Share Tech Mono", monospace;--font-display: "Orbitron", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-mono)}.app-wrapper{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:20px 16px 40px;position:relative;overflow:hidden}.scanlines{pointer-events:none;position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.07) 2px,rgba(0,0,0,.07) 4px);z-index:100}.btn{font-family:var(--font-display);font-size:.75rem;font-weight:700;letter-spacing:.08em;padding:10px 22px;border:1.5px solid var(--border2);border-radius:var(--radius);cursor:pointer;transition:all .15s;background:transparent;color:var(--text)}.btn:active{transform:scale(.97)}.btn-primary{background:var(--cyan);color:var(--bg);border-color:var(--cyan);box-shadow:var(--glow-cyan)}.btn-primary:hover{filter:brightness(1.15)}.btn-secondary{border-color:var(--gold);color:var(--gold)}.btn-secondary:hover{background:#f5c5181a;box-shadow:var(--glow-gold)}.btn-ghost{border-color:var(--border);color:var(--text-dim)}.btn-ghost:hover{border-color:var(--border2);color:var(--text)}.btn-lg{padding:14px 32px;font-size:.85rem}.btn-sm{padding:6px 14px;font-size:.65rem}.btn-disabled,.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.input-group{display:flex;flex-direction:column;gap:6px;width:100%}.input-label{font-size:.65rem;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase}.input-field{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:1rem;padding:10px 14px;transition:border-color .15s;outline:none;width:100%}.input-field:focus{border-color:var(--cyan);box-shadow:var(--glow-cyan)}.input-field::placeholder{color:var(--text-dim)}.input-code{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.25em;text-align:center;text-transform:uppercase}.error-msg{color:var(--red);font-size:.8rem;padding:8px 12px;border:1px solid rgba(255,68,68,.3);border-radius:var(--radius);background:#ff444412;text-align:center}.home-page{display:flex;flex-direction:column;align-items:center;gap:28px;width:100%;max-width:400px;padding-top:40px}.home-hero{text-align:center}.hero-badge{display:inline-block;font-family:var(--font-display);font-size:.6rem;letter-spacing:.25em;color:var(--cyan);border:1px solid var(--cyan);border-radius:2px;padding:3px 10px;margin-bottom:14px;box-shadow:var(--glow-cyan)}.hero-title{font-family:var(--font-display);line-height:.9;font-weight:900}.title-accent{display:block;font-size:3.5rem;color:var(--cyan);text-shadow:var(--glow-cyan);letter-spacing:.08em}.title-main{display:block;font-size:2.8rem;color:var(--text);letter-spacing:.15em}.hero-sub{margin-top:10px;font-size:.75rem;color:var(--text-dim);letter-spacing:.06em}.home-card{background:var(--surface);border:1.5px solid var(--border);border-radius:8px;padding:28px 24px;display:flex;flex-direction:column;gap:18px;width:100%}.action-buttons{display:flex;flex-direction:column;gap:10px}.mode-hint{font-size:.75rem;color:var(--text-dim);text-align:center}.mode-section{display:flex;flex-direction:column;gap:14px}.games-preview{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.game-chip{font-size:.65rem;letter-spacing:.1em;padding:5px 12px;border-radius:20px;border:1px solid var(--border);color:var(--text-dim)}.game-chip.active{border-color:var(--cyan);color:var(--cyan);box-shadow:var(--glow-cyan)}.game-chip.soon{opacity:.45}.lobby-page{display:flex;flex-direction:column;gap:24px;width:100%;max-width:400px;padding-top:10px}.lobby-header{display:flex;align-items:center;justify-content:space-between}.lobby-title{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.2em;color:var(--cyan)}.room-code-block{background:var(--surface);border:1.5px solid var(--border);border-radius:8px;padding:20px;text-align:center}.code-label{font-size:.6rem;letter-spacing:.18em;color:var(--text-dim);text-transform:uppercase;margin-bottom:8px}.code-display{display:flex;align-items:center;justify-content:center;gap:12px}.code-text{font-family:var(--font-display);font-size:2.2rem;letter-spacing:.3em;color:var(--gold);text-shadow:var(--glow-gold)}.code-hint{margin-top:8px;font-size:.7rem;color:var(--text-dim)}.section-title{font-family:var(--font-display);font-size:.7rem;letter-spacing:.18em;color:var(--text-dim);margin-bottom:10px}.players-list{display:flex;flex-direction:column;gap:8px}.player-slot{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--surface2)}.player-slot.filled.me{border-color:var(--cyan)}.player-symbol{font-family:var(--font-display);font-size:1rem;width:24px;text-align:center;color:var(--cyan)}.player-name{flex:1;font-size:.9rem}.player-badges{display:flex;gap:4px}.badge{font-size:.55rem;padding:2px 7px;border-radius:3px;border:1px solid var(--border2);color:var(--text-dim);letter-spacing:.08em}.badge-me{border-color:var(--cyan);color:var(--cyan)}.player-slot.empty{border-style:dashed;justify-content:center;opacity:.6}.player-waiting{font-size:.8rem;color:var(--text-dim)}.waiting-dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.2}}.lobby-actions{display:flex;justify-content:center}.waiting-msg{font-size:.8rem;color:var(--text-dim);text-align:center}.game-page{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:420px;padding-top:10px}.game-header{display:flex;align-items:center;justify-content:space-between;width:100%}.game-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.2em;color:var(--text-dim)}.my-symbol{min-width:70px;display:flex;justify-content:flex-end}.symbol-badge{font-family:var(--font-display);font-size:.65rem;padding:4px 10px;border-radius:3px;letter-spacing:.1em}.symbol-badge.x{border:1px solid var(--x-color);color:var(--x-color)}.symbol-badge.o{border:1px solid var(--o-color);color:var(--o-color)}.scoreboard{display:flex;gap:40px;padding:12px 28px;background:var(--surface);border:1.5px solid var(--border);border-radius:6px}.score-player{display:flex;align-items:center;gap:8px;opacity:.45;transition:opacity .2s}.score-player.active-turn{opacity:1}.score-symbol{font-family:var(--font-display);font-size:1.1rem;color:var(--cyan)}.score-name{font-size:.85rem}.status-banner{width:100%;text-align:center;padding:10px 20px;border-radius:var(--radius);font-size:.85rem;letter-spacing:.06em;border:1.5px solid var(--border);transition:all .2s}.banner-your-turn{border-color:var(--cyan);color:var(--cyan);background:#00d4ff12}.banner-wait{color:var(--text-dim)}.banner-win{border-color:var(--green);color:var(--green);background:#44ff8812}.banner-lose{border-color:var(--red);color:var(--red);background:#ff444412}.banner-draw{border-color:var(--gold);color:var(--gold);background:#f5c51812}.ttt-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:320px}.ttt-cell{aspect-ratio:1;background:var(--surface);border:2px solid var(--border);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;position:relative;overflow:hidden}.ttt-cell.cell-empty:hover{border-color:var(--border2);background:var(--surface2)}.ttt-cell.cell-x{border-color:#ff6b6b80}.ttt-cell.cell-o{border-color:#4ecdc480}.ttt-cell.cell-win{background:#f5c5181a;border-color:var(--gold);box-shadow:inset 0 0 20px #f5c5181f,var(--glow-gold);animation:win-pulse .6s ease}@keyframes win-pulse{0%{transform:scale(.92)}60%{transform:scale(1.04)}to{transform:scale(1)}}.ttt-cell:disabled{cursor:not-allowed}.symbol-x,.symbol-o{font-family:var(--font-display);font-size:2rem;font-weight:900;animation:pop-in .18s cubic-bezier(.34,1.56,.64,1)}.symbol-x{color:var(--x-color);text-shadow:0 0 10px rgba(255,107,107,.5)}.symbol-o{color:var(--o-color);text-shadow:0 0 10px rgba(78,205,196,.5)}@keyframes pop-in{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}.game-over-actions{display:flex;gap:12px;margin-top:8px}@media (max-width: 380px){.title-accent{font-size:2.8rem}.title-main{font-size:2.2rem}.ttt-board{max-width:280px}.symbol-x,.symbol-o{font-size:1.6rem}}.timer-bar-wrapper{width:100%;display:flex;flex-direction:column;gap:6px}.timer-bar-labels{display:flex;justify-content:space-between;font-size:.72rem;letter-spacing:.06em}.timer-bar-who{color:var(--text-dim)}.timer-bar-seconds{font-family:var(--font-display);font-size:.8rem;font-weight:700;transition:color .3s}.timer-green{color:var(--green)}.timer-yellow{color:var(--gold)}.timer-red{color:var(--red)}.timer-bar-track{width:100%;height:6px;background:var(--surface2);border-radius:99px;overflow:hidden;border:1px solid var(--border)}.timer-bar-fill{height:100%;border-radius:99px;transition:width .1s linear,background-color .3s}.timer-fill-green{background:var(--green);box-shadow:0 0 8px #44ff8880}.timer-fill-yellow{background:var(--gold);box-shadow:0 0 8px #f5c51880}.timer-fill-red{background:var(--red);box-shadow:0 0 8px #ff444480}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.5}}.timer-pulse{animation:timer-pulse .5s infinite}.skipped-msg{width:100%;text-align:center;padding:8px 16px;border-radius:var(--radius);font-size:.8rem;color:var(--gold);border:1px solid rgba(245,197,24,.4);background:#f5c51812;animation:fade-in-out 2.5s ease forwards}.deviation-msg{color:var(--red);border-color:#f446;background:#ff444412}.notification-msg{color:var(--cyan);border-color:#00d4ff66;background:#00d4ff12}@keyframes fade-in-out{0%{opacity:0;transform:translateY(-4px)}15%{opacity:1;transform:translateY(0)}75%{opacity:1}to{opacity:0}}@keyframes flash-intended{0%,to{background:var(--surface);border-color:var(--border)}30%,70%{background:#ff444440;border-color:var(--red);box-shadow:inset 0 0 14px #ff44444d}}@keyframes flash-actual{0%,to{background:var(--surface);border-color:var(--border)}30%,70%{background:#f5c51833;border-color:var(--gold);box-shadow:inset 0 0 14px #f5c5184d}}.cell-deviated-intended{animation:flash-intended .7s ease forwards}.cell-deviated-actual{animation:flash-actual .7s ease forwards}.cell-target-ability{border-color:var(--cyan)!important;background:#00d4ff1a!important;animation:pulse-target .8s infinite alternate}.cell-target-bomb{border-color:var(--red)!important;background:#ff44441a!important;animation:pulse-target .8s infinite alternate}.cell-target-ghost{border-color:var(--gold)!important;background:#f5c51814!important;animation:pulse-target .8s infinite alternate}@keyframes pulse-target{0%{box-shadow:none}to{box-shadow:inset 0 0 12px #ffffff26}}.cell-ghost{border-color:#f5c51866!important}.symbol-ghost{font-family:var(--font-display);font-size:2rem;font-weight:900;color:var(--gold);opacity:.6;animation:ghost-pulse 1s infinite alternate}@keyframes ghost-pulse{0%{opacity:.4}to{opacity:.8}}.abilities-panel{display:flex;gap:8px;width:100%;justify-content:center}.ability-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 6px;background:var(--surface2);border:1.5px solid var(--border2);border-radius:6px;cursor:pointer;transition:all .15s;color:var(--text);max-width:90px}.ability-btn:hover:not(:disabled){border-color:var(--cyan);box-shadow:var(--glow-cyan)}.ability-btn.ability-selecting{border-color:var(--gold);background:#f5c5181a;box-shadow:0 0 12px #f5c51866}.ability-btn.ability-used{opacity:.3;cursor:not-allowed;border-color:var(--border)}.ability-btn.ability-disabled{opacity:.4;cursor:not-allowed}.ability-icon{font-size:1.3rem}.ability-label{font-size:.6rem;letter-spacing:.06em;color:var(--text-dim)}.ability-uses{font-family:var(--font-display);font-size:.65rem;color:var(--cyan)}.opp-abilities-left{font-size:.65rem;color:var(--text-dim);margin-left:6px}.timer-section{width:100%;display:flex;flex-direction:column;gap:10px}.timer-options{display:flex;gap:8px}.timer-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:var(--surface2);border:1.5px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;color:var(--text-dim)}.timer-option:hover{border-color:var(--border2);color:var(--text)}.timer-option.selected{border-color:var(--cyan);color:var(--cyan);background:#00d4ff12;box-shadow:var(--glow-cyan)}.timer-icon{font-family:var(--font-display);font-size:1.1rem;font-weight:700}.timer-label{font-size:.62rem;letter-spacing:.06em;text-align:center}.abilities-preview{display:flex;gap:10px;justify-content:center;padding:8px 0}.ability-preview-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.65rem;color:var(--text-dim)}.ability-preview-item span:first-child{font-size:1.4rem}.ability-toggle{width:100%;padding:12px;background:var(--surface2);border:1.5px dashed var(--border2);border-radius:6px;color:var(--text-dim);font-family:var(--font-display);font-size:.72rem;letter-spacing:.08em;cursor:pointer;transition:all .15s}.ability-toggle:hover{border-color:var(--cyan);color:var(--text)}.ability-toggle.enabled{border-style:solid;border-color:var(--cyan);color:var(--cyan);background:#00d4ff12;box-shadow:var(--glow-cyan)}.mode-badges{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.mode-badge{font-size:.65rem;letter-spacing:.08em;padding:4px 10px;border-radius:3px;border:1px solid var(--border2);color:var(--text-dim)}.mode-badge-random{border-color:#f5c51880;color:var(--gold)}.mode-badge-ability{border-color:#00d4ff80;color:var(--cyan)}.score-display{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:360px;margin:0 auto .75rem;padding:.5rem 1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px}.score-side{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:64px;transition:transform .15s ease}.score-left{align-items:flex-start}.score-right{align-items:flex-end}.score-name-small{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:#ffffff73;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.score-number{font-size:1.9rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;transition:text-shadow .1s ease}.score-blue{color:#60a5fa}.score-red{color:#f87171}.score-center{display:flex;flex-direction:column;align-items:center;gap:2px}.room-code-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;color:#ffffff4d;text-transform:uppercase}@keyframes scoreGlowBlue{0%{text-shadow:0 0 0px #60a5fa;transform:scale(1)}30%{text-shadow:0 0 18px #60a5fa,0 0 32px #3b82f6;transform:scale(1.35)}70%{text-shadow:0 0 12px #60a5fa;transform:scale(1.15)}to{text-shadow:0 0 0px #60a5fa;transform:scale(1)}}@keyframes scoreGlowRed{0%{text-shadow:0 0 0px #f87171;transform:scale(1)}30%{text-shadow:0 0 18px #f87171,0 0 32px #ef4444;transform:scale(1.35)}70%{text-shadow:0 0 12px #f87171;transform:scale(1.15)}to{text-shadow:0 0 0px #f87171;transform:scale(1)}}.score-glow-blue .score-number{animation:scoreGlowBlue .9s ease-out forwards}.score-glow-red .score-number{animation:scoreGlowRed .9s ease-out forwards}.btn-bot{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border:none;font-weight:700;letter-spacing:.04em;transition:opacity .2s,transform .15s}.btn-bot:hover{opacity:.88;transform:translateY(-1px)}.bot-indicator{text-align:center;font-size:.7rem;font-weight:600;letter-spacing:.08em;color:#a78bfa;text-transform:uppercase;margin-bottom:.25rem}.bot-option-group{margin-bottom:1rem}.bot-option-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff80;margin-bottom:.4rem}.bot-difficulty-btns{display:flex;gap:.5rem}.bot-hard-warning{font-size:.7rem;color:#f87171;margin-top:.4rem;text-align:center}
