*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0d1a;--surface:#161626;--border:#2a2a4a;--text:#e2e8f0;--muted:#94a3b8;--accent:#3b82f6;--p1:#ef4444;--p1-glow:#ef44448c;--p2:#eab308;--p2-glow:#eab3088c;--board:#1e40af;--board-bg:#1e40af;--cell-bg:#0d0d1a;--radius:12px;font-family:Segoe UI,system-ui,sans-serif}:root.light{--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--accent:#2563eb;--p1:#dc2626;--p1-glow:#dc262666;--p2:#ca8a04;--p2-glow:#ca8a0466;--board:#1d4ed8;--board-bg:#1d4ed8;--cell-bg:#dbeafe}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}button{cursor:pointer;font-family:inherit}*,:before,:after{transition:background-color .2s,border-color .2s,color .2s}.app{flex-direction:column;min-height:100vh;padding:0 1rem;display:flex}.app-header{text-align:center;padding:1.5rem 0 1rem;position:relative}.theme-toggle{cursor:pointer;border:none;border-radius:999px;width:148px;height:44px;padding:0;transition:background .45s cubic-bezier(.4,0,.2,1);position:absolute;top:1.2rem;right:0;overflow:hidden;box-shadow:0 2px 10px #00000040}.theme-toggle.theme-light{color:#1e293b;background:#e2e8f0}.theme-toggle.theme-dark{color:#e2e8f0;background:#1e293b}.theme-toggle-knob{border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:left .45s cubic-bezier(.4,0,.2,1),background .45s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:0}.theme-toggle.theme-light .theme-toggle-knob{background:#fff;left:calc(100% - 44px);box-shadow:0 1px 6px #0003}.theme-toggle.theme-dark .theme-toggle-knob{background:#0f172a;left:0;box-shadow:0 1px 6px #0006}.theme-toggle-label{letter-spacing:.05em;white-space:nowrap;font-size:.78rem;font-weight:700;position:absolute;top:50%;transform:translateY(-50%)}.theme-toggle.theme-light .theme-toggle-label{left:14px;right:50px}.theme-toggle.theme-dark .theme-toggle-label{left:50px;right:14px}.theme-toggle:hover{opacity:.88}.app-title{letter-spacing:-.5px;justify-content:center;align-items:center;gap:.6rem;font-size:2.2rem;font-weight:800;display:flex}.disc{width:28px;height:28px;box-shadow:0 0 10px 2px var(--shadow-color,#0006);border-radius:50%;display:inline-block}.disc.red{background:var(--p1);--shadow-color:var(--p1-glow)}.disc.yellow{background:var(--p2);--shadow-color:var(--p2-glow)}.app-sub{color:var(--muted);margin-top:.3rem;font-size:.85rem}.game-layout{flex:1;grid-template-columns:180px 1fr 180px;align-items:start;gap:1.5rem;width:100%;max-width:980px;margin:0 auto;display:grid}.main-area{flex-direction:column;align-items:center;gap:1rem;display:flex}.sidebar{flex-direction:column;gap:1rem;padding-top:1rem;display:flex}.app-footer{text-align:center;color:var(--muted);padding:1rem 0 1.5rem;font-size:.78rem}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.75rem;font-size:.75rem;font-weight:700}.panel-note{color:var(--muted);margin-bottom:.5rem;font-size:.7rem;font-style:italic}.btn-group{gap:.4rem;display:flex}.btn-group.vertical{flex-direction:column}.pill-btn{border:1px solid var(--border);color:var(--muted);background:0 0;border-radius:999px;padding:.35rem .9rem;font-size:.82rem;font-weight:500;transition:all .15s}.pill-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.pill-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pill-btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);border:none;padding:.65rem 2rem;font-size:1rem;font-weight:700;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-ghost{color:var(--muted);border:1px solid var(--border);border-radius:var(--radius);background:0 0;padding:.5rem 1.5rem;font-size:.88rem;transition:border-color .15s,color .15s}.btn-ghost:hover{border-color:var(--muted);color:var(--text)}.ghost-btn{color:var(--muted);background:0 0;border:none;margin-top:.5rem;padding:.3rem 0;font-size:.72rem;text-decoration:underline;display:block}.ghost-btn:hover{color:var(--text)}.action-row{justify-content:center;gap:.75rem;min-height:2.5rem;display:flex}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;margin-bottom:.6rem;display:grid}.stat-box{background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;min-width:0;padding:.5rem;display:flex}.stat-num{font-size:1.4rem;font-weight:800;line-height:1}.stat-lbl{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.stat-box.win .stat-num{color:#4ade80}.stat-box.loss .stat-num{color:var(--p1)}.stat-box.draw .stat-num{color:var(--muted)}.win-rate{color:var(--muted);margin-bottom:.25rem;font-size:.78rem}.win-rate strong{color:var(--text)}.legend{flex-direction:column;gap:.4rem;margin-top:.85rem;display:flex}.legend-item{align-items:center;gap:.5rem;font-size:.8rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;display:inline-block}.legend-dot.p1{background:var(--p1);box-shadow:0 0 6px var(--p1-glow)}.legend-dot.p2{background:var(--p2);box-shadow:0 0 6px var(--p2-glow)}.game-info{justify-content:center;align-items:center;gap:.75rem;min-height:2.4rem;display:flex}.status-msg{font-size:1rem;font-weight:600}.status-msg.terminal{font-size:1.3rem;font-weight:800}@keyframes thinkPulse{0%,to{opacity:1}50%{opacity:.5}}.thinking-pulse{animation:1s ease-in-out infinite thinkPulse}.wasm-badge{color:#60a5fa;letter-spacing:.05em;background:#1e3a5f;border:1px solid #2563eb;border-radius:999px;padding:.15rem .55rem;font-size:.68rem;font-weight:700}.board-wrap{transition:opacity .2s}.board-wrap.thinking{opacity:.92}.preview-row{gap:8px;height:44px;margin-bottom:2px;padding:0 12px;display:flex}.preview-cell{pointer-events:none;flex:1;justify-content:center;align-items:flex-end;display:flex}.preview-piece{opacity:.55;border-radius:50%;width:44px;height:44px;transition:opacity .1s}.preview-piece.p1{background:var(--p1)}.preview-piece.p2{background:var(--p2)}.board-grid{background:var(--board);border-radius:16px;gap:8px;padding:12px;display:flex;box-shadow:0 10px 40px #00005099,inset 0 2px 4px #ffffff0f}.board-col{cursor:pointer;border-radius:8px;flex-direction:column;gap:8px;padding:2px;transition:background .12s;display:flex}.board-col.hovered{background:#ffffff0f}.cell{background:var(--cell-bg);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 3px 8px #00000080}.cell.winning{box-shadow:inset 0 2px 6px #0000004d,0 0 0 2px #ffffff59}.piece{border-radius:50%;width:52px;height:52px;position:absolute}.piece.p1{background:radial-gradient(circle at 36% 34%,#f87171,#b91c1c);box-shadow:0 2px 8px #00000059,inset 0 -2px 5px #0003}.piece.p2{background:radial-gradient(circle at 36% 34%,#fde047,#a16207);box-shadow:0 2px 8px #00000059,inset 0 -2px 5px #0003}@keyframes dropIn{0%{transform:translateY(calc(-1 * var(--drop-px,350px)))}80%{transform:translateY(4px)}91%{transform:translateY(-3px)}to{transform:translateY(0)}}.piece.just-placed{animation:dropIn calc(max(.28s, var(--drop-px,300px) / 1400px * .55s)) cubic-bezier(.35, 0, .65, 1) forwards}@keyframes winPop{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.piece.win-flash{animation:.55s ease-in-out infinite winPop}@media (width<=760px){.game-layout{grid-template-rows:auto auto auto;grid-template-columns:1fr}.sidebar{flex-flow:wrap}.panel{flex:1;min-width:140px}.cell{width:44px;height:44px}.piece{width:38px;height:38px}.preview-piece{width:34px;height:34px}}.ttt-grid{background:var(--board-bg);border-radius:14px;grid-template-rows:repeat(3,100px);grid-template-columns:repeat(3,100px);gap:6px;padding:12px;display:grid;box-shadow:0 6px 28px #00000080}.ttt-no-hover .ttt-cell{cursor:default}.ttt-cell{background:var(--cell-bg);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;width:100px;height:100px;transition:background .12s;display:flex;position:relative;box-shadow:inset 0 3px 8px #00000073}.ttt-cell:not(.p1):not(.p2):hover{background:#ffffff14}.ttt-cell.p1:before,.ttt-cell.p1:after{content:"";background:radial-gradient(circle,#f87171,#b91c1c);border-radius:4px;width:62px;height:7px;position:absolute;box-shadow:0 2px 8px #0000004d}.ttt-cell.p1:before{transform:rotate(45deg)}.ttt-cell.p1:after{transform:rotate(-45deg)}.ttt-cell.p2:before{content:"";background:0 0;border:7px solid #fde047;border-radius:50%;width:62px;height:62px;position:absolute;box-shadow:0 0 0 1px #a16207,inset 0 0 0 1px #a16207,0 2px 8px #00000059}.ttt-cell.winning{animation:.55s ease-in-out infinite winPop;box-shadow:inset 0 2px 6px #0000004d,0 0 0 2px #fff6}.game-tabs{justify-content:center;gap:8px;margin-bottom:18px;display:flex}.game-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:2px solid #ffffff26;border-radius:24px;padding:8px 22px;font-size:.95rem;font-weight:600;transition:all .15s}.game-tab:hover{color:var(--text);border-color:#ffffff4d}.game-tab.active{color:var(--text);background:#ffffff1f;border-color:#ffffff73}@media (width<=760px){.ttt-grid{grid-template-rows:repeat(3,80px);grid-template-columns:repeat(3,80px)}.ttt-cell{width:80px;height:80px}.ttt-cell.p1:before,.ttt-cell.p1:after{width:48px}.ttt-cell.p2:before{width:48px;height:48px}}
