:root{font-family:-apple-system,Segoe UI,system-ui,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--bg: #ffffff;--surface: #faf7ef;--surface-2: #f1f0ec;--surface-3: #efe9da;--border: #e6e2d6;--border-strong: #d8d2c2;--ink: #1f2328;--muted: #6b7280;--accent: #d98a2b;--accent-hover: #c2781f;--accent-soft: rgba(217, 138, 43, .16);--win: #2e7d32;--winbg: #eaf4ea;--loss: #c0392b;--lossbg: #fbecea;--draw: #6b7280;--drawbg: #f1f2f4;--p1: #e0533f;--p2: #2f80c8;color:var(--ink);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}html,body{margin:0;padding:0;min-width:320px;height:100%;overflow:hidden;background:var(--bg)}#root{height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid var(--border-strong);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;color:var(--ink);cursor:pointer;transition:background .15s ease,border-color .15s ease}button:hover{background:#f3f1ea;border-color:var(--accent)}button:focus,button:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.about-overlay{position:fixed;inset:0;z-index:200;background:#14161a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.about-modal{background:#fff;border:1px solid var(--border);border-radius:12px;max-width:600px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #0000002e}.about-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.about-header h2{margin:0;font-size:20px;font-weight:600;color:var(--ink)}.about-close{width:32px;height:32px;padding:0;font-size:24px;line-height:1;color:var(--muted);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.about-close:hover{color:var(--ink);background:var(--surface-3)}.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:var(--ink)}.about-content p{margin:0 0 12px;font-size:14px;line-height:1.6;color:var(--ink)}.about-content p:last-child{margin-bottom:0}.about-content a{color:var(--accent);text-decoration:none}.about-content a:hover{color:var(--accent-hover);text-decoration:underline}.about-content ul,.about-content ol{margin:0 0 12px;padding-left:24px;color:var(--ink)}.about-content li{margin-bottom:8px;font-size:14px;line-height:1.5}.about-content .win{color:var(--win);font-weight:600}.about-content .loss{color:var(--loss);font-weight:600}.about-content .draw,.about-content .unknown{color:var(--muted);font-weight:600}.about-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.about-close-button{padding:10px 24px;font-size:14px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.about-close-button:hover{background:var(--accent-hover)}@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:var(--surface);border:1px solid var(--border);border-radius:12px}.board-row{display:flex;gap:8px}.cell{width:128px;height:128px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .15s ease;border:3px solid var(--border)}.cell:hover{background:var(--surface-2)}.cell.selectable{border-color:var(--border-strong)}.cell.selectable:hover{border-color:var(--accent)}.cell.selected{border-color:var(--accent);background:var(--accent-soft)}.cell.valid-destination{background:var(--winbg);border-color:var(--win)}.cell.valid-destination:hover{background:#dcefdc}.cell.hover-source{background:#fbf0dd;border-color:var(--accent);box-shadow:0 0 12px #d98a2b4d}.cell.hover-destination{background:var(--winbg);border-color:var(--win);box-shadow:0 0 12px #2e7d324d}.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,.18)}.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,#e0533f,#c0392b);box-shadow:0 2px 5px #00000038}.piece.player-2{background:linear-gradient(135deg,#3a93d6,#2f80c8);box-shadow:0 2px 5px #00000038}.cell.winning-cell{background:var(--winbg);border-color:var(--win);box-shadow:0 0 16px #2e7d3259;animation:winning-pulse 1.5s ease-in-out infinite}@keyframes winning-pulse{0%,to{box-shadow:0 0 16px #2e7d3259}50%{box-shadow:0 0 24px #2e7d328c}}@media(max-width:480px){.cell{width:96px;height:96px}.piece.small{width:28px;height:28px}.piece.medium{width:52px;height:52px}.piece.large{width:76px;height:76px}}@media(max-width:380px){.cell{width:80px;height:80px}.piece.small{width:24px;height:24px}.piece.medium{width:44px;height:44px}.piece.large{width:64px;height:64px}}.site-header{flex:0 0 auto;display:flex;align-items:center;gap:4px 14px;flex-wrap:wrap;padding:10px 16px 0;background:transparent}.site-header h1{margin:0;font-size:1.22rem;line-height:1.5;font-weight:700;color:var(--ink)}.tagline{font-size:.86rem;color:var(--muted)}.hlinks{margin-left:auto;display:flex;align-items:center;gap:16px;font-size:.86rem;white-space:nowrap}.hlinks a,.navbtn{color:var(--accent);text-decoration:none;font-weight:600}.navbtn{background:none;border:0;padding:0;font-family:inherit;font-size:.86rem;cursor:pointer}.hlinks a:hover,.navbtn:hover{color:var(--accent-hover);text-decoration:underline;background:none}@media(max-width:700px){.site-header{padding:10px 16px;gap:4px 14px}.tagline{display:none}.hlinks{gap:16px}}.history-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:200px;max-height:calc(100vh - 180px);display:flex;flex-direction:column;color:var(--ink)}.history-header{font-weight:700;margin-bottom:12px;color:var(--ink);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:var(--muted)}.history-entry:hover{background:var(--surface-3)}.history-entry.current{background:var(--accent-soft);color:var(--ink);border-left:3px solid var(--accent)}.history-entry.player-1 .move-notation{color:var(--p1)}.history-entry.player-2 .move-notation{color:var(--p2)}.move-number{min-width:36px;font-weight:500}.move-notation{flex:1;font-family:ui-monospace,Menlo,monospace}.history-empty{color:var(--muted);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 var(--border)}.history-actions button{flex:1;font-size:12px}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:transparent}.history-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.history-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}.moves-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:220px;max-height:calc(100vh - 180px);display:flex;flex-direction:column;overflow-y:auto;color:var(--ink)}.moves-header{font-size:16px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}.moves-count{font-weight:400;color:var(--muted);font-size:14px}.moves-subheader{font-size:16px;font-weight:700;margin-bottom:12px}.moves-subheader.player-1{color:var(--p1)}.moves-subheader.player-2{color:var(--p2)}.moves-empty{color:var(--muted);font-style:italic;padding:12px 0}.moves-section{margin-bottom:12px}.section-header{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.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:var(--surface-3)}.move-notation{font-family:ui-monospace,Menlo,monospace;font-size:13px}.move-type{font-size:11px;color:var(--muted)}.eval-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.eval-badge.eval-win{background:var(--win);color:#fff}.eval-badge.eval-loss{background:var(--loss);color:#fff}.eval-badge.eval-draw{background:#d7dade;color:#333}.eval-badge.eval-unknown{background:var(--surface-2);color:var(--muted)}.move-entry.eval-win{border-left:3px solid var(--win)}.move-entry.eval-loss{border-left:3px solid var(--loss)}.move-entry.eval-draw{border-left:3px solid #c7cbd1}.move-entry.eval-unknown{border-left:3px solid var(--border-strong)}.moves-panel::-webkit-scrollbar,.moves-list::-webkit-scrollbar{width:6px}.moves-panel::-webkit-scrollbar-track,.moves-list::-webkit-scrollbar-track{background:transparent;border-radius:3px}.moves-panel::-webkit-scrollbar-thumb,.moves-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.moves-panel::-webkit-scrollbar-thumb:hover,.moves-list::-webkit-scrollbar-thumb:hover{background:var(--muted)}.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:var(--lossbg);border:1px solid var(--p1);border-radius:8px}.game-result.winner-p1 .result-message{color:var(--p1)}.game-result.winner-p2{background:#eaf2fb;border:1px solid var(--p2);border-radius:8px}.game-result.winner-p2 .result-message{color:var(--p2)}.game-result.draw{background:var(--drawbg);border:1px solid var(--border-strong);border-radius:8px}.game-result.draw .result-message{color:var(--muted)}.reserves{width:217px;padding:10px;box-sizing:border-box;background:var(--surface);border:1px solid var(--border);border-radius:10px;opacity:.65;transition:opacity .2s ease}.reserves.active{opacity:1}.reserves.player-1 .reserves-header{color:var(--p1)}.reserves.player-2 .reserves-header{color:var(--p2)}.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:var(--border)}.reserve-piece.selectable:hover{background:var(--surface-3);border-color:var(--border-strong)}.reserve-piece.selected{background:var(--accent-soft);border-color:var(--accent)}.reserve-piece.hover-source{background:#fbf0dd;border-color:var(--accent);box-shadow:0 0 12px #d98a2b4d}.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,.18)}.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,#e0533f,#c0392b);box-shadow:0 2px 4px #00000038}.piece-preview.player-2{background:linear-gradient(135deg,#3a93d6,#2f80c8);box-shadow:0 2px 4px #00000038}.piece-count{font-size:12px;color:var(--muted)}.reserve-piece.depleted .piece-preview{opacity:.3}.reserve-piece.depleted .piece-count{color:var(--border-strong)}@media(max-width:480px){.reserves{width:auto;flex:1;min-width:0}.reserves-pieces{gap:2px}.reserve-piece{width:auto;flex:1;height:70px;padding:2px}.piece-preview.size-1{width:14px;height:14px}.piece-preview.size-2{width:24px;height:24px}.piece-preview.size-3{width:36px;height:36px}.piece-count{font-size:11px}}.app{min-height:100%;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);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:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:start;width:100%;max-width:1100px}.left-column{justify-self:end}.game-layout>.moves-panel{justify-self:start}@media(max-width:960px){.game-layout{display:flex;flex-direction:column;align-items:center;gap:16px}.left-column{justify-self:auto}.game-content{padding:16px 12px}.left-column{order:3}.center-column{order:1}.game-layout>.moves-panel{order:2;max-height:320px;width:100%;max-width:432px;box-sizing:border-box}.left-column>.history-panel{width:100%;max-width:432px;box-sizing:border-box;max-height:280px}}@media(max-width:480px){.reserves-row{width:100%}}.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:var(--surface);border:1px solid var(--border);padding:12px 24px;border-radius:12px;font-size:18px;font-weight:700;text-align:center;color:var(--ink)}button{background:#fff;color:var(--ink);border:1px solid var(--border-strong);padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;transition:background .15s ease,border-color .15s ease}button:hover{background:var(--surface-3);border-color:var(--accent)}.selection-hint{margin-top:16px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--muted)}.error p{color:var(--loss);margin-bottom:16px}.modal-overlay{position:fixed;inset:0;background:#14161a80;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px;min-width:400px;max-width:90%;box-shadow:0 20px 40px #0000002e}.modal-header{font-size:18px;font-weight:700;margin-bottom:16px}.notation-input{width:100%;padding:12px;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);font-family:monospace;font-size:14px;resize:vertical;box-sizing:border-box}.notation-input:focus{outline:none;border-color:var(--accent)}.modal-tabs{display:flex;gap:8px;margin-bottom:16px}.modal-tabs .tab{flex:1;padding:8px 16px;background:var(--surface-2);border-radius:6px}.modal-tabs .tab.active{background:var(--accent);color:#fff}.modal-tabs .tab:hover:not(.active){background:var(--surface-3)}.modal-description{font-size:12px;color:var(--muted);margin-bottom:8px}.modal-buttons{display:flex;gap:12px;margin-top:16px;justify-content:flex-end}
