:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.4;font-weight:400;color:#111827;background:#fff;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px}#root{min-height:100vh}button{border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#111827;padding:8px 12px;font-size:.95rem;cursor:pointer}button:disabled{opacity:.6;cursor:not-allowed}.app{display:flex;flex-direction:column;gap:12px;width:100%;height:100vh;min-height:100vh;box-sizing:border-box;padding:16px;overflow:hidden}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.topbar h1{margin:0;font-size:1.5rem}.topbar p{margin:2px 0 0}.meta{display:flex;flex-direction:column;gap:2px;text-align:right;font-size:.9rem}.theme-toggle{margin-top:4px;align-self:flex-end;height:28px;padding:0 10px;border:1px solid #d1d5db;border-radius:999px;background:#fff;cursor:pointer;font-size:.78rem}.controls{display:flex;align-items:center;flex-wrap:wrap;gap:12px}.home-grid{display:flex;flex-direction:column;gap:12px;width:100%;max-width:520px;margin:0 auto}.home-card{display:flex;flex-direction:column;gap:8px}.home-card h2{margin:0;font-size:1.05rem}.home-card input,.home-card select,.home-card button,.controls select,.controls button{height:34px}.actions-row{display:flex;gap:8px}.room-panel{max-width:840px}.room-player{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:8px;align-items:center}.remove-bot-button{width:24px;height:24px;min-height:24px;padding:0;border-radius:999px;font-size:.95rem;font-weight:600;line-height:1;display:inline-flex;align-items:center;justify-content:center}.room-badge{margin:0;font-size:.92rem}.room-badge-button{border:0;background:transparent;padding:0;text-align:left;cursor:pointer}.content{flex:1;display:grid;grid-template-columns:1fr 320px;gap:12px;min-height:0}.side-column{display:flex;flex-direction:column;gap:12px;min-height:0}.chat-panel{display:flex;flex-direction:column;min-height:0;gap:8px}.chat-log{flex:1;min-height:140px;max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.chat-empty{margin:0;color:#6b7280;font-size:.9rem}.chat-message{margin:0;font-size:.9rem;line-height:1.35}.chat-message-mine{color:#2563eb}.chat-form{display:grid;grid-template-columns:1fr auto;gap:8px}.board-shell{border:1px solid #d1d5db;border-radius:8px;overflow:hidden;padding:10px;background:#f9fafb;height:100%;display:flex;align-items:center;justify-content:center}.board-grid{display:grid;gap:2px}.cell{width:100%;aspect-ratio:1 / 1;border:1px solid #e5e7eb;border-radius:4px;background:#fff;display:flex;align-items:center;justify-content:center;padding:0}.cell:disabled{cursor:default}.cell-highlighted{background:#eef2ff}.cell-winning{background:#fef3c7;border-color:#f59e0b;box-shadow:inset 0 0 0 1px #f59e0b}.cell-last-move{background:#ecfeff;border-color:#06b6d4;box-shadow:inset 0 0 0 1px #06b6d4}.tile{width:72%;height:72%;border-radius:4px}.tile-mine{position:relative}.tile-mine-dot{position:absolute;width:8px;height:8px;border-radius:999px;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1px #ffffffd9}.panel{border:1px solid #d1d5db;border-radius:8px;padding:12px;background:#fff}.panel h2{margin-top:0;margin-bottom:8px;font-size:1.1rem}.player-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.player-row{display:grid;grid-template-columns:12px 1fr auto auto;align-items:center;gap:8px;font-size:.92rem}.my-color-row{display:flex;align-items:center;gap:8px;margin:0 0 10px;font-size:.9rem}.player-marker{width:10px;height:10px;border-radius:999px;display:inline-block}.error{color:#dc2626}.app-footer{margin-top:auto;text-align:center;font-size:.78rem;color:#6b7280}.app-space{background:radial-gradient(circle at 20% 10%,#172554,#0b1220 55%,#070b13);color:#e5e7eb}.app-space .topbar p,.app-space .meta,.app-space .room-badge{color:#cbd5e1}.app-space .app-footer{color:#94a3b8}.app-space .panel,.app-space .board-shell{background:#0f172adb;border-color:#334155}.app-space .cell{background:#0b1530;border-color:#334155}.app-space .cell-highlighted{background:#312e81}.app-space .cell-winning{background:#fef3c7;border-color:#f59e0b;box-shadow:inset 0 0 0 1px #f59e0b}.app-space .cell-last-move{background:#0f2b4d;border-color:#22d3ee;box-shadow:inset 0 0 0 1px #22d3ee}.app-space input,.app-space select,.app-space button{background:#0f172a;color:#e2e8f0;border-color:#334155}.app-space .theme-toggle{background:#0b1530;color:#e2e8f0;border-color:#334155}.app-space .chat-empty{color:#94a3b8}.app-space .chat-message-mine{color:#93c5fd}@media(max-width:1024px){.app{height:auto;min-height:100vh;overflow:auto}.content{grid-template-columns:1fr;overflow:visible}}
