: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;padding:0;min-width:320px;height:100%;overflow:hidden}#root{height:100%}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}}.about-overlay{position:fixed;inset:0;z-index:200;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.about-modal{background:#2a2a2a;border-radius:12px;max-width:600px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000080}.about-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #3a3a3a}.about-header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.about-close{width:32px;height:32px;padding:0;font-size:24px;line-height:1;color:#888;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.about-close:hover{color:#fff;background:#3a3a3a}.about-content{flex:1;overflow-y:auto;padding:24px}.about-content section{margin-bottom:24px}.about-content section:last-child{margin-bottom:0}.about-content h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#fff}.about-content p{margin:0 0 12px;font-size:14px;line-height:1.6;color:#bbb}.about-content p:last-child{margin-bottom:0}.about-content a{color:#4a9eff;text-decoration:none}.about-content a:hover{text-decoration:underline}.about-content ul,.about-content ol{margin:0 0 12px;padding-left:24px;color:#bbb}.about-content li{margin-bottom:8px;font-size:14px;line-height:1.5}.about-content .win{color:#4ade80;font-weight:500}.about-content .loss{color:#f87171;font-weight:500}.about-content .draw{color:#fbbf24;font-weight:500}.about-content .unknown{color:#9ca3af;font-weight:500}.about-footer{padding:16px 24px;border-top:1px solid #3a3a3a;display:flex;justify-content:flex-end}.about-close-button{padding:10px 24px;font-size:14px;font-weight:500;color:#fff;background:#4a9eff;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.about-close-button:hover{background:#3b8ee6}@media(max-width:600px){.about-modal{max-height:90vh}.about-header{padding:16px 20px}.about-content{padding:20px}.about-footer{padding:12px 20px}}.board{display:flex;flex-direction:column;gap:8px;padding:16px;background:#2a2a2a;border-radius:12px}.board-row{display:flex;gap:8px}.cell{width:128px;height:128px;background:#3a3a3a;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .15s ease;border:3px solid transparent}.cell:hover{background:#4a4a4a}.cell.selectable{border-color:#666}.cell.selectable:hover{border-color:#888}.cell.selected{border-color:#4a9eff;background:#3a4a5a}.cell.valid-destination{background:#3a5a3a;border-color:#5a5}.cell.valid-destination:hover{background:#4a6a4a}.cell.hover-source{background:#5a4a3a;border-color:#f39c12;box-shadow:0 0 12px #f39c1266}.cell.hover-destination{background:#3a5a4a;border-color:#2ecc71;box-shadow:0 0 12px #2ecc7166}.piece-stack{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.piece{border-radius:50%;position:absolute;border:2px solid rgba(0,0,0,.2)}.piece.small{width:38px;height:38px}.piece.medium{width:70px;height:70px}.piece.large{width:100px;height:100px}.piece.player-1{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 2px 4px #0000004d}.piece.player-2{background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 2px 4px #0000004d}.cell.winning-cell{background:#4a5a3a;border-color:#8c8;box-shadow:0 0 16px #88cc8880;animation:winning-pulse 1.5s ease-in-out infinite}@keyframes winning-pulse{0%,to{box-shadow:0 0 16px #88cc8880}50%{box-shadow:0 0 24px #8c8c}}.site-header{position:sticky;top:0;z-index:100;background:#1a1a1a;border-bottom:1px solid #333;box-shadow:0 2px 8px #0000004d}.header-content{max-width:1200px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.header-spacer{flex:1}.header-title{flex:1;margin:0;font-size:20px;font-weight:600;color:#fff;text-align:center;white-space:nowrap}.header-nav{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:16px}.header-button{padding:6px 14px;font-size:14px;font-weight:500;color:#4a9eff;background:transparent;border:1px solid #4a9eff;border-radius:6px;cursor:pointer;transition:all .15s ease}.header-button:hover{background:#4a9eff1a;color:#6ab0ff;border-color:#6ab0ff}.header-link{font-size:14px;font-weight:500;color:#aaa;text-decoration:none;transition:color .15s ease}.header-link:hover{color:#fff}@media(max-width:700px){.header-content{padding:0 16px;height:48px}.header-title{font-size:16px}.header-nav{gap:12px}.header-button{padding:4px 10px;font-size:12px}.header-link{font-size:12px}}.history-panel{background:#2a2a2a;border-radius:12px;padding:16px;min-width:200px;max-height:calc(100vh - 180px);display:flex;flex-direction:column}.history-header{font-weight:700;margin-bottom:12px;color:#fff;font-size:14px}.history-controls{display:flex;gap:8px;margin-bottom:12px}.history-controls button{flex:1;padding:8px 12px;font-size:12px}.history-controls button:disabled{opacity:.4;cursor:not-allowed}.history-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.history-entry{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .15s ease;font-size:13px;color:#aaa}.history-entry:hover{background:#3a3a3a}.history-entry.current{background:#3a4a5a;color:#fff;border-left:3px solid #4a9eff}.history-entry.player-1 .move-notation{color:#e74c3c}.history-entry.player-2 .move-notation{color:#3498db}.move-number{min-width:36px;font-weight:500}.move-notation{flex:1;font-family:monospace}.history-empty{color:#666;font-size:12px;text-align:center;padding:20px 0}.history-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #3a3a3a}.history-actions button{flex:1;font-size:12px}.moves-panel{background:#2a2a2a;border-radius:12px;padding:16px;min-width:220px;max-height:calc(100vh - 180px);display:flex;flex-direction:column;overflow-y:auto}.moves-header{font-size:16px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}.moves-count{font-weight:400;color:#888;font-size:14px}.moves-subheader{font-size:16px;font-weight:700;margin-bottom:12px}.moves-subheader.player-1{color:#e74c3c}.moves-subheader.player-2{color:#3498db}.moves-empty{color:#666;font-style:italic;padding:12px 0}.moves-section{margin-bottom:12px}.section-header{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid #3a3a3a}.moves-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.move-entry{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .1s ease}.move-entry:hover{background:#3a3a3a}.move-notation{font-family:monospace;font-size:13px}.move-type{font-size:11px;color:#666}.eval-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase}.eval-badge.eval-win{background:#2d5a2d;color:#7dff7d}.eval-badge.eval-loss{background:#5a2d2d;color:#ff7d7d}.eval-badge.eval-draw{background:#4a4a2d;color:#e0e07d}.eval-badge.eval-unknown{background:#3a3a3a;color:#888}.move-entry.eval-win{border-left:3px solid #4a4}.move-entry.eval-loss{border-left:3px solid #a44}.move-entry.eval-draw{border-left:3px solid #aa4}.move-entry.eval-unknown{border-left:3px solid #555}.moves-panel::-webkit-scrollbar,.moves-list::-webkit-scrollbar{width:6px}.moves-panel::-webkit-scrollbar-track,.moves-list::-webkit-scrollbar-track{background:#1a1a1a;border-radius:3px}.moves-panel::-webkit-scrollbar-thumb,.moves-list::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:3px}.moves-panel::-webkit-scrollbar-thumb:hover,.moves-list::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.game-result{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center}.result-icon{font-size:48px;margin-bottom:12px}.result-message{font-size:18px;font-weight:700}.game-result.winner-p1{background:linear-gradient(135deg,#4a90e233,#4a90e21a);border:2px solid #4a90e2;border-radius:8px}.game-result.winner-p1 .result-message{color:#6ab0ff}.game-result.winner-p2{background:linear-gradient(135deg,#e26b4a33,#e26b4a1a);border:2px solid #e26b4a;border-radius:8px}.game-result.winner-p2 .result-message{color:#ff9b7a}.game-result.draw{background:linear-gradient(135deg,#b4b45033,#b4b4501a);border:2px solid #b4b450;border-radius:8px}.game-result.draw .result-message{color:#d4d480}.reserves{width:217px;padding:10px;box-sizing:border-box;background:#2a2a2a;border-radius:10px;opacity:.6;transition:opacity .2s ease}.reserves.active{opacity:1}.reserves.player-1 .reserves-header{color:#e74c3c}.reserves.player-2 .reserves-header{color:#3498db}.reserves-header{font-weight:700;margin-bottom:8px;font-size:13px;text-align:center}.reserves-pieces{display:flex;gap:4px;justify-content:center}.reserve-piece{display:flex;flex-direction:column;align-items:center;width:60px;height:80px;padding:4px;border-radius:6px;border:2px solid transparent;cursor:default;transition:all .15s ease}.reserve-piece.selectable{cursor:pointer;border-color:#444}.reserve-piece.selectable:hover{background:#3a3a3a;border-color:#666}.reserve-piece.selected{background:#3a4a5a;border-color:#4a9eff}.reserve-piece.hover-source{background:#5a4a3a;border-color:#f39c12;box-shadow:0 0 12px #f39c1266}.piece-preview-wrapper{flex:1;display:flex;align-items:center;justify-content:center}.piece-preview{border-radius:50%;border:2px solid rgba(0,0,0,.2)}.piece-preview.size-1{width:20px;height:20px}.piece-preview.size-2{width:34px;height:34px}.piece-preview.size-3{width:48px;height:48px}.piece-preview.player-1{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 2px 4px #0000004d}.piece-preview.player-2{background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 2px 4px #0000004d}.piece-count{font-size:12px;color:#888}.reserve-piece.depleted .piece-preview{opacity:.3}.reserve-piece.depleted .piece-count{color:#555}.app{min-height:100%;display:flex;flex-direction:column;background:#1a1a1a;color:#eee;box-sizing:border-box}.app.loading,.app.error{align-items:center;justify-content:center;padding:20px}.game-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:24px 20px}.game-layout{display:flex;gap:32px;align-items:flex-start}.left-column,.center-column{display:flex;flex-direction:column;align-items:center;gap:16px}.reserves-row{display:flex;gap:16px}.reserves-stack{display:flex;flex-direction:column;gap:16px}.result-banner{background:linear-gradient(135deg,#4a4a4a,#3a3a3a);padding:12px 24px;border-radius:12px;font-size:18px;font-weight:700;text-align:center}button{background:#4a4a4a;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;transition:background .15s ease}button:hover{background:#5a5a5a}.selection-hint{margin-top:16px;padding:8px 16px;background:#2a2a2a;border-radius:8px;font-size:13px;color:#aaa}.error p{color:#e74c3c;margin-bottom:16px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#2a2a2a;border-radius:12px;padding:24px;min-width:400px;max-width:90%}.modal-header{font-size:18px;font-weight:700;margin-bottom:16px}.notation-input{width:100%;padding:12px;border-radius:8px;border:1px solid #4a4a4a;background:#1a1a1a;color:#fff;font-family:monospace;font-size:14px;resize:vertical;box-sizing:border-box}.notation-input:focus{outline:none;border-color:#4a9eff}.modal-tabs{display:flex;gap:8px;margin-bottom:16px}.modal-tabs .tab{flex:1;padding:8px 16px;background:#3a3a3a;border-radius:6px}.modal-tabs .tab.active{background:#4a9eff}.modal-tabs .tab:hover:not(.active){background:#4a4a4a}.modal-description{font-size:12px;color:#888;margin-bottom:8px}.modal-buttons{display:flex;gap:12px;margin-top:16px;justify-content:flex-end}
