:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--cell-size: 44px;--stone-size: 38px;--star-point-size: 8px;--label-width: 24px;--label-height: 20px;--grid-edge-mask: 20px;--last-move-marker-size: 12px;--bottom-bar-height: 60px;--tab-bar-height: 48px;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--mobile-padding: 12px}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.board-container{display:flex;flex-direction:column;align-items:center}.board{background-color:#deb887;border-radius:4px;border:8px solid #8b5a2b;box-shadow:0 10px 25px #0000004d}.board-middle{display:flex;align-items:stretch}.row-labels{display:flex;flex-direction:column;justify-content:space-around}.row-label{width:var(--label-width);height:var(--cell-size);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#5a3e2b}.col-labels-row{display:flex}.col-labels-row:first-child{padding-top:6px}.col-labels-row:last-child{padding-bottom:6px}.corner-spacer{width:var(--label-width);height:var(--label-height)}.col-label{width:var(--cell-size);height:var(--label-height);text-align:center;font-size:14px;font-weight:700;color:#5a3e2b;display:flex;align-items:center;justify-content:center}.grid-wrapper{position:relative}.grid{display:flex;flex-direction:column}.grid-row{display:flex}.grid-wrapper:after{content:"";position:absolute;inset:0;background:linear-gradient(#deb887,#deb887) top / 100% var(--grid-edge-mask) no-repeat,linear-gradient(#deb887,#deb887) bottom / 100% var(--grid-edge-mask) no-repeat,linear-gradient(#deb887,#deb887) left / var(--grid-edge-mask) 100% no-repeat,linear-gradient(#deb887,#deb887) right / var(--grid-edge-mask) 100% no-repeat;pointer-events:none}.grid-wrapper:before{content:"";position:absolute;top:var(--grid-edge-mask);left:var(--grid-edge-mask);right:var(--grid-edge-mask);bottom:var(--grid-edge-mask);border:2px solid #6b4423;pointer-events:none}.intersection{width:var(--cell-size);height:var(--cell-size);display:flex;align-items:center;justify-content:center;position:relative;cursor:default;background:linear-gradient(to right,transparent 47%,#6b4423 48%,#6b4423 52%,transparent 53%),linear-gradient(to bottom,transparent 47%,#6b4423 48%,#6b4423 52%,transparent 53%)}.intersection.legal{cursor:pointer}.star-point{position:absolute;width:var(--star-point-size);height:var(--star-point-size);background-color:#6b4423;border-radius:50%;z-index:1}.stone{width:var(--stone-size);height:var(--stone-size);border-radius:50%;z-index:2;position:relative;box-shadow:2px 3px 5px #0006}.stone-black{background:radial-gradient(circle at 35% 35%,#555,#111)}.stone-white{background:radial-gradient(circle at 35% 35%,#fff,#bbb);border:1px solid #999}.last-move-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:var(--last-move-marker-size);height:var(--last-move-marker-size);border-radius:50%;border:2px solid}.stone-black .last-move-marker{border-color:#fff}.stone-white .last-move-marker{border-color:#333}.preview{width:var(--stone-size);height:var(--stone-size);border-radius:50%;z-index:2;opacity:0;transition:opacity .15s}.intersection.legal:hover .preview{opacity:.5}.preview-black{background:radial-gradient(circle at 35% 35%,#555,#111)}.preview-white{background:radial-gradient(circle at 35% 35%,#fff,#bbb);border:1px solid #999}@media(hover:none)and (pointer:coarse){.intersection.legal:active .preview{opacity:.5}.intersection.legal:hover .preview{opacity:0}}@media(max-width:768px){.board{border-width:4px;position:relative}.board-middle{position:static}.row-labels{position:absolute;top:0;height:calc(var(--cell-size) * 9);z-index:5}.row-labels:first-child{left:1px}.row-labels:last-child{right:1px}.row-label{font-size:7px;width:auto;height:var(--cell-size);padding:0;color:#5a3e2b;opacity:.7}.col-labels-row{position:absolute;left:0;width:calc(var(--cell-size) * 9);z-index:5;padding:0}.col-labels-row:first-child{top:1px;padding-top:0}.col-labels-row:last-child{bottom:1px;padding-bottom:0}.col-label{font-size:7px;width:var(--cell-size);height:auto;color:#5a3e2b;opacity:.7}.corner-spacer{display:none}}.mobile-tabs{display:flex;flex-direction:column;width:100%;flex:1;min-height:0;background-color:#16213e;border-radius:8px;overflow:hidden}.mobile-tabs-header{display:flex;height:var(--tab-bar-height);border-bottom:2px solid #0f3460}.mobile-tab{flex:1;display:flex;align-items:center;justify-content:center;min-height:48px;padding:0 1rem;background:none;border:none;color:#888;font-size:.9rem;font-weight:600;cursor:pointer;transition:color .2s,background-color .2s}.mobile-tab:active{background-color:#e945601a}.mobile-tab.active{color:#e94560;background-color:#e945601a;border-bottom:2px solid #e94560;margin-bottom:-2px}.mobile-tabs-content{flex:1;min-height:0;overflow-y:auto;padding:var(--mobile-padding)}.mobile-tabs-content .move-history{background:none;padding:0}.mobile-tabs-content .move-history h3{display:none}.mobile-tabs-content .move-list{display:flex;flex-wrap:wrap;gap:.25rem .5rem;line-height:1.4}.mobile-tabs-content .move-row{display:inline-flex;gap:.25rem;padding:0}.mobile-visualization-controls{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #0f3460}.mobile-visualization-controls .btn{flex:1;min-height:44px}.bottom-bar{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-bar-height);padding-bottom:var(--safe-area-bottom);background-color:#16213e;border-top:2px solid #0f3460;z-index:100}.bottom-bar-content{display:flex;align-items:center;justify-content:center;gap:.75rem;height:100%;padding:0 var(--mobile-padding)}.bottom-bar-btn{flex:1;max-width:100px;min-height:44px;padding:.5rem .75rem;font-size:.85rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s,opacity .2s;background-color:#0f3460;color:#eee}.bottom-bar-btn:active:not(:disabled){background-color:#1a4b7a}.bottom-bar-btn:disabled{opacity:.5;cursor:not-allowed}.bottom-bar-btn.primary{background-color:#e94560;color:#fff}.bottom-bar-btn.primary:active:not(:disabled){background-color:#d63050}.bottom-bar-btn.danger{background-color:#991b1b;color:#fff}.bottom-bar-btn.danger:active:not(:disabled){background-color:#7f1d1d}.heatmap-overlay{position:absolute;inset:0;display:flex;flex-direction:column;background-color:#000000e6;border-radius:4px;z-index:10}.heatmap-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background-color:#16213e;border-bottom:1px solid #0f3460;font-size:.9rem;font-weight:700}.heatmap-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;line-height:1;padding:0 4px}.heatmap-close:hover{color:#e94560}.heatmap-grid{flex:1;display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);gap:1px;padding:10px}.heatmap-cell{display:flex;align-items:center;justify-content:center;border-radius:2px;transition:transform .1s}.heatmap-cell:hover{transform:scale(1.1);z-index:1}.heatmap-value{font-size:.7rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8)}.heatmap-legend{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;font-size:.75rem;color:#888}.heatmap-gradient{width:100px;height:12px;background:linear-gradient(to right,#1f1fad,#1fad1f,#ad1f1f);border-radius:2px}.tree-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:80vh;background-color:#1a1a2e;border:2px solid #0f3460;border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:100;display:flex;flex-direction:column}.tree-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#16213e;border-bottom:1px solid #0f3460;font-weight:700;border-radius:6px 6px 0 0}.tree-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;line-height:1;padding:0 4px}.tree-close:hover{color:#e94560}.tree-content{flex:1;overflow-y:auto;padding:12px}.tree-empty{padding:24px;text-align:center;color:#666}.tree-node{font-size:.9rem}.tree-node-header{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;transition:background-color .15s}.tree-node-header.expandable{cursor:pointer}.tree-node-header.expandable:hover{background-color:#0f3460}.tree-expand-icon{width:12px;font-size:.7rem;color:#666}.tree-move{font-weight:700;font-family:monospace;background-color:#0f3460;padding:2px 6px;border-radius:3px;min-width:32px;text-align:center}.tree-stats{display:flex;gap:12px;margin-left:auto;font-size:.8rem}.tree-visits{color:#888}.tree-winrate{font-weight:700;min-width:50px;text-align:right}.tree-winrate.high{color:#4ade80}.tree-winrate.medium{color:#fbbf24}.tree-winrate.low{color:#f87171}.tree-bar{width:60px;height:6px;background-color:#333;border-radius:3px;overflow:hidden}.tree-bar-fill{height:100%;border-radius:3px;transition:width .3s}.tree-bar-fill.high{background-color:#4ade80}.tree-bar-fill.medium{background-color:#fbbf24}.tree-bar-fill.low{background-color:#f87171}.tree-children{border-left:1px dashed #333;margin-left:6px;padding-left:4px}.tree-backdrop{position:fixed;inset:0;background-color:#00000080;z-index:99}.app{min-height:100vh;display:flex;flex-direction:column;background-color:#1a1a2e;color:#eee}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:#16213e;border-bottom:2px solid #0f3460}.app-header h1{margin:0;font-size:1.8rem;color:#e94560}.connection-status{font-size:.9rem;padding:.4rem .8rem;border-radius:4px;background-color:#0f3460}.connection-status.connected{color:#4ade80}.connection-status.disconnected,.connection-status.error{color:#f87171}.connection-status.connecting{color:#fbbf24}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.game-setup{text-align:center;background-color:#16213e;padding:1.25rem;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:320px}.game-setup h2{margin:0 0 1rem;font-size:1.5rem;color:#e94560}.setup-form{display:flex;flex-direction:column;align-items:stretch;gap:.75rem}.players-row{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.5rem;padding:.75rem 1rem;background-color:#0f3460;border-radius:8px}.player-select{display:flex;flex-direction:column;align-items:center}.player-select label{display:flex;flex-direction:column;align-items:center;gap:.5rem}.player-label{display:flex;align-items:center;gap:.5rem;font-weight:700}.player-select select{padding:.5rem 1rem;font-size:1rem;border-radius:6px;border:2px solid #16213e;background-color:#1a1a2e;color:#eee;cursor:pointer}.player-select select:hover{border-color:#e94560}.settings-accordion{width:100%}.settings-toggle{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem 1rem;background:none;border:1px solid #0f3460;border-radius:6px;color:#888;font-size:.9rem;cursor:pointer;transition:all .2s}.settings-toggle:hover{color:#e94560;border-color:#e94560}.settings-arrow{font-size:.8rem}.settings-panel{margin-top:.75rem;padding:.75rem 1rem;background-color:#0f3460;border-radius:8px;display:flex;flex-direction:column;gap:.75rem}.settings-grid,.server-grid{display:grid;grid-template-columns:auto auto;gap:.5rem .75rem;align-items:center;justify-content:center}.setting-label{display:flex;align-items:center;gap:.25rem;color:#aaa;font-size:.9rem;justify-self:end;white-space:nowrap}.settings-grid select,.settings-grid input,.server-grid select,.server-grid input{padding:.4rem .75rem;font-size:.9rem;border-radius:6px;border:2px solid #16213e;background-color:#1a1a2e;color:#eee;justify-self:start}.settings-grid select,.server-grid select{width:120px;cursor:pointer}.settings-grid input[type=number]{width:80px;text-align:center}.server-grid input[type=text]{width:140px}.server-grid input[type=password]{width:80px}.settings-grid select:hover,.settings-grid input:hover,.server-grid select:hover,.server-grid input:hover{border-color:#e94560}.settings-grid input::placeholder,.server-grid input::placeholder{color:#555}.setting-divider{grid-column:1 / -1;text-align:center;color:#666;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding-bottom:.5rem;border-bottom:1px solid #16213e;margin-bottom:.25rem}.setting-input-with-btn{display:flex;gap:.5rem;align-items:center}.setting-input-with-btn input{width:80px}.connection-warning{color:#f87171;font-size:.85rem;margin:0}@media(max-width:480px){.game-setup{padding:1rem;max-width:100%}.players-row{gap:1rem;padding:.6rem .75rem}.player-select select{padding:.4rem .6rem;font-size:.9rem}.settings-panel{padding:.6rem .75rem}.settings-grid,.server-grid{gap:.4rem .5rem}.settings-grid select,.server-grid select{width:100px}.server-grid input[type=text]{width:110px}}.tooltip-wrapper{position:relative;display:inline-flex;align-items:center;margin-left:.4rem}.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:11px;font-weight:700;color:#888;background-color:#1a1a2e;border:1px solid #444;border-radius:50%;cursor:help;transition:all .2s}.tooltip-icon:hover{color:#e94560;border-color:#e94560}.tooltip-text{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background-color:#1a1a2e;color:#ddd;padding:.5rem .75rem;border-radius:6px;font-size:.8rem;font-weight:400;min-width:280px;max-width:400px;white-space:normal;text-align:center;box-shadow:0 4px 12px #0006;border:1px solid #333;z-index:100;transition:opacity .2s,visibility .2s}.tooltip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.tooltip-wrapper:hover .tooltip-text{visibility:visible;opacity:1}.btn{padding:.6rem 1.2rem;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#e94560;color:#fff}.btn-primary:hover:not(:disabled){background-color:#d63050}.btn-secondary{background-color:#0f3460;color:#eee}.btn-secondary:hover:not(:disabled){background-color:#1a4b7a}.btn-danger{background-color:#991b1b;color:#fff}.btn-danger:hover:not(:disabled){background-color:#7f1d1d}.btn-large{padding:.8rem 2rem;font-size:1.1rem}.game-layout{display:flex;gap:2rem;align-items:flex-start}.game-left{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.board-container{position:relative}.game-right{display:flex;flex-direction:column;gap:1.5rem;min-width:250px;max-width:300px}.controls{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.visualization-controls{display:flex;gap:.5rem;justify-content:center}.visualization-controls .btn.active{background-color:#e94560;color:#fff}.game-info{background-color:#16213e;padding:1rem 1.5rem;border-radius:8px}.players-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.player-info{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:4px;transition:background-color .2s}.player-info.active{background-color:#0f3460}.game-status{padding-top:.5rem;border-top:1px solid #0f3460}.turn-indicator{font-size:1.1rem}.ai-thinking{margin-top:.5rem;color:#fbbf24;display:flex;align-items:center;gap:.5rem;visibility:hidden}.ai-thinking.visible{visibility:visible}.thinking-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.game-over{font-size:1.2rem;color:#4ade80}.game-over .reason{font-size:.9rem;color:#888}.game-over-stats{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #0f3460;font-size:.9rem}.game-over-stats .stats-row{display:flex;justify-content:space-between;padding:.2rem 0}.game-over-stats .stats-row span:first-child{color:#888}.game-over-stats .stats-row span:last-child{font-family:monospace;color:#4ade80}.stone-black-small,.stone-white-small,.setup-stone{display:inline-block;width:20px;height:20px;border-radius:50%}.stone-black-small,.setup-stone.stone-black-small{background:radial-gradient(circle at 35% 35%,#555,#111)}.stone-white-small,.setup-stone.stone-white-small{background:radial-gradient(circle at 35% 35%,#fff,#bbb);border:1px solid #999}.player-stone{width:16px;height:16px}.move-history{background-color:#16213e;padding:1rem 1.5rem;border-radius:8px;max-height:200px;display:flex;flex-direction:column}.move-history h3{margin:0 0 .5rem;font-size:1rem;color:#888}.move-list{overflow-y:auto;flex:1;font-family:monospace;font-size:.9rem;line-height:1.8;word-wrap:break-word}.move-row{display:flex;align-items:center;gap:.5rem;padding:.15rem 0}.move-number{color:#666;min-width:1.5rem}.move{padding:.1rem .4rem;border-radius:3px}.move.black{background-color:#333;color:#fff}.move.white{background-color:#ddd;color:#333}.move.last-move{outline:2px solid #e94560}.no-moves{color:#666;font-style:italic;margin:0}.mcts-stats{background-color:#16213e;padding:1rem 1.5rem;border-radius:8px}.mcts-stats h3{margin:0 0 .5rem;font-size:1rem;color:#888}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.stat-item{display:flex;justify-content:space-between;font-size:.85rem}.stat-label{color:#888}.stat-value{font-family:monospace;color:#4ade80}.top-moves{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #0f3460}.top-moves h4{margin:0 0 .25rem;font-size:.85rem;color:#888}.top-moves ul{margin:0;padding-left:1.2rem;font-size:.8rem;font-family:monospace}.top-moves li{color:#ccc}.toast{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);color:#fff;padding:.75rem 1.5rem;border-radius:8px;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:toast-slide-in .2s ease-out}@keyframes toast-slide-in{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.toast-error{background-color:#991b1b}.toast-success{background-color:#166534}.toast-info{background-color:#1e40af}.toast-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem;padding:0;line-height:1}.toast-close:hover{opacity:.8}.game-layout.mobile{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;flex:1;min-height:0;padding-bottom:calc(var(--bottom-bar-height) + var(--safe-area-bottom) + 1rem)}.game-layout.mobile .board-section{position:relative;display:flex;flex-direction:column;align-items:center;flex-shrink:0}@media(max-width:768px){#root,.app{width:100%}:root{--cell-size: min(44px, calc((100vw - 48px) / 9));--stone-size: calc(var(--cell-size) * .864);--star-point-size: calc(var(--cell-size) * .182);--label-width: 0px;--label-height: 0px;--grid-edge-mask: calc(var(--cell-size) * .5);--last-move-marker-size: calc(var(--cell-size) * .273)}.game-layout{flex-direction:column;align-items:center}.game-right{width:100%;max-width:400px}.app-header{padding:.75rem 1rem}.app-header h1{font-size:1.4rem}.app-main{padding:1rem;flex:1;min-height:0}.visualization-controls{display:none}.toast{bottom:calc(var(--bottom-bar-height) + var(--safe-area-bottom) + 1rem)}}@media(max-width:768px)and (orientation:landscape){:root{--cell-size: min(44px, calc((100dvh - 100px) / 9))}.game-layout.mobile{flex-direction:row;align-items:flex-start;justify-content:center;gap:1rem}.game-layout.mobile .mobile-tabs{max-width:200px;flex:1}}@media(min-width:769px){:root{--cell-size: 44px;--stone-size: 38px;--star-point-size: 8px;--label-width: 24px;--label-height: 20px;--grid-edge-mask: 20px;--last-move-marker-size: 12px}}
