:root{--board-size: min(80vmin, 640px);--square-size: calc(var(--board-size) / 8);--color-light: #f0d9b5;--color-dark: #b58863;--color-highlight: rgba(50, 200, 50, .35);--color-selected: rgba(255, 200, 0, .55);--color-last-from: rgba(255, 255, 0, .3);--color-last-to: rgba(255, 255, 0, .55);--color-in-check: rgba(255, 60, 60, .55);--color-text: #1c1a17;--color-text-muted: #6b5e51;--color-card-bg: #fbf7f0;--color-card-border: #d4c3a4;--color-page-bg: #ece2cc;--color-accent: #4f6e44;--color-accent-hover: #3d5635}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--color-text);background:var(--color-page-bg)}.app-shell{display:grid;grid-template-columns:1fr min-content 1fr;gap:2rem;padding:2rem clamp(1rem,4vw,4rem);min-height:100vh;align-items:start}@media(max-width:1000px){.app-shell{grid-template-columns:1fr;padding:1rem}}.app-shell h1{margin:0 0 1rem;font-weight:600;font-size:1.6rem;letter-spacing:.02em}.app-shell .subtitle{margin:0 0 1rem;color:var(--color-text-muted);font-size:.95rem}.menu-card,.sidebar-card{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:.75rem;padding:1.25rem;box-shadow:0 6px 16px #3c28140f}.menu-card label{display:block;margin:.75rem 0 .25rem;font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.menu-card select,.menu-card input[type=text]{width:100%;padding:.5rem .65rem;border:1px solid var(--color-card-border);border-radius:.4rem;font-size:.95rem;font-family:inherit;background:#fff;color:var(--color-text)}.menu-card .difficulty-elo{font-size:.8rem;color:var(--color-text-muted);margin-top:.25rem}.menu-card button{width:100%;margin-top:1rem;padding:.7rem 1rem;border:none;border-radius:.45rem;background:var(--color-accent);color:#fff;font-size:1rem;font-family:inherit;font-weight:600;cursor:pointer;transition:background-color .15s ease}.menu-card button:hover{background:var(--color-accent-hover)}.menu-card .secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-card-border)}.menu-card .secondary:hover{background:#0000000a}.board-column{display:flex;flex-direction:column;align-items:center;gap:.5rem}.board-side{display:flex;align-items:center;justify-content:space-between;width:var(--board-size);gap:.75rem;margin:.15rem 0;min-height:1.8rem}.loading-row{width:var(--board-size);font-size:.8rem;color:var(--color-text-muted);text-align:center;margin-top:.25rem}.captures{flex:1;min-width:0;display:flex;align-items:center;flex-wrap:wrap;gap:.05rem}.capture-piece{width:1.4rem;height:1.4rem;background-size:contain;background-repeat:no-repeat;background-position:center;flex:0 0 auto;margin-right:-.45rem}.material-advantage{font-size:.85rem;font-variant-numeric:tabular-nums;color:var(--color-text-muted);margin-left:.7rem;font-weight:600}.clock{background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:.4rem;padding:.4rem .8rem;font-variant-numeric:tabular-nums;font-weight:600;font-size:1.2rem;min-width:5rem;text-align:center;color:var(--color-text-muted)}.clock.running{color:var(--color-text);background:#fff;box-shadow:0 0 0 2px var(--color-accent) inset}.board{width:var(--board-size);height:var(--board-size);display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);border-radius:.5rem;overflow:hidden;box-shadow:0 10px 30px #3c281433;user-select:none;touch-action:none}.square{position:relative;display:flex;align-items:center;justify-content:center}.square.light{background:var(--color-light)}.square.dark{background:var(--color-dark)}.square .coord-label{position:absolute;font-size:.7rem;opacity:.6;pointer-events:none}.square .rank-label{top:.15rem;left:.25rem}.square .file-label{bottom:.1rem;right:.3rem}.square.light .coord-label{color:var(--color-dark)}.square.dark .coord-label{color:var(--color-light)}.square.highlight:after{content:"";position:absolute;inset:25%;background:var(--color-highlight);border-radius:50%;pointer-events:none}.square.highlight:has(.piece):after{inset:8%;background:transparent;border:4px solid var(--color-highlight);border-radius:50%}.square.selected{background-color:var(--color-selected)!important}.square.last-from{background-color:var(--color-last-from)!important}.square.last-to{background-color:var(--color-last-to)!important}.square.in-check{background-color:var(--color-in-check)!important}.piece{width:92%;height:92%;background-size:contain;background-repeat:no-repeat;background-position:center;cursor:grab}.piece.dragging{cursor:grabbing}.sidebar-card h2{margin:0 0 .5rem;font-size:1rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.status{font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.eval{font-size:.95rem;color:var(--color-text-muted);margin:0;min-height:1.3em}.move-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-wrap:wrap;gap:.35rem .5rem;max-height:28rem;overflow-y:auto;font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:.9rem}.move-list li{padding:.15rem .4rem;background:#0000000a;border-radius:.25rem}.move-list li[data-fullmove]:before{content:attr(data-fullmove) ".";color:var(--color-text-muted);margin-right:.35rem}.toolbar{display:flex;gap:.5rem;margin-top:.75rem}.toolbar button{flex:1;padding:.4rem .6rem;border:1px solid var(--color-card-border);border-radius:.35rem;background:#fff;color:var(--color-text);cursor:pointer;font-family:inherit;font-size:.9rem}.toolbar button:hover{background:#0000000a}.footer{margin-top:2rem;text-align:center;color:var(--color-text-muted);font-size:.85rem}.footer a{color:var(--color-accent)}.board-area{position:relative;width:var(--board-size);height:var(--board-size)}.game-result-banner{width:var(--board-size);display:flex;align-items:center;gap:.9rem;padding:.75rem 1rem;background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:.6rem;box-shadow:0 4px 12px #3c28141f;margin-top:.35rem;animation:gameResultFade .25s ease}.game-result-banner[hidden]{display:none}.game-result-icon{font-size:2rem;line-height:1;flex:0 0 auto}.game-result-text{flex:1;min-width:0}.game-result-title{font-size:1.15rem;font-weight:700;margin:0;color:var(--color-text);letter-spacing:.01em}.game-result-reason{font-size:.85rem;color:var(--color-text-muted);margin:.1rem 0 0}.game-result-actions{display:flex;gap:.45rem;flex:0 0 auto}.game-result-actions button{padding:.45rem .9rem;border-radius:.4rem;font-size:.85rem;font-family:inherit;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background-color .15s ease}.game-result-actions .primary{background:var(--color-accent);color:#fff}.game-result-actions .primary:hover{background:var(--color-accent-hover)}.game-result-actions .secondary{background:transparent;border-color:var(--color-card-border);color:var(--color-text)}.game-result-actions .secondary:hover{background:#0000000a}.game-result-actions button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes gameResultFade{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.game-result-banner[data-result=white]{border-left:4px solid var(--color-accent)}.game-result-banner[data-result=black]{border-left:4px solid #2b2118}.game-result-banner[data-result=draw]{border-left:4px solid var(--color-card-border)}@keyframes mateKingPulse{0%,to{background-color:#ff3c3c8c}50%{background-color:#ff3c3cd9}}body.game-ended .square.in-check{animation:mateKingPulse 1.4s ease-in-out infinite}.replay-panel{width:var(--board-size);background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:.6rem;padding:.6rem .75rem;margin-top:.35rem;display:flex;flex-direction:column;gap:.4rem;box-shadow:0 2px 8px #3c281414}.replay-panel[hidden]{display:none}.replay-row{display:flex;align-items:center;gap:.4rem}.replay-row-bottom{justify-content:space-between;font-size:.85rem;color:var(--color-text-muted)}.replay-step{flex:0 0 auto;width:2rem;height:2rem;padding:0;border-radius:.35rem;border:1px solid var(--color-card-border);background:#fff;color:var(--color-text);font-size:.9rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit}.replay-step:hover:not(:disabled){background:#0000000a}.replay-step:disabled{opacity:.4;cursor:not-allowed}.replay-slider{flex:1;min-width:0;margin:0 .2rem;accent-color:var(--color-accent)}.replay-counter{font-variant-numeric:tabular-nums;font-weight:600}.replay-move-label{flex:1;text-align:center;font-family:ui-monospace,SF Mono,Menlo,monospace;color:var(--color-text)}.replay-panel .secondary{padding:.35rem .8rem;border-radius:.4rem;font-size:.85rem;font-family:inherit;font-weight:600;cursor:pointer;border:1px solid var(--color-card-border);background:transparent;color:var(--color-text)}.replay-panel .secondary:hover{background:#0000000a}.move-list li.replay-current{background:var(--color-accent);color:#fff;border-radius:.25rem}.move-list li.replay-future{opacity:.35}body.replay-mode .board{pointer-events:none}body.replay-mode .toolbar button{opacity:.5;pointer-events:none}body.engine-thinking{cursor:progress}body.engine-thinking .board{pointer-events:none}.board-area:after{content:"";position:absolute;top:.5rem;right:.5rem;width:1.2rem;height:1.2rem;border:2.5px solid rgba(255,255,255,.6);border-top-color:var(--color-accent);border-radius:50%;opacity:0;transform:scale(.7);transition:opacity .12s ease,transform .12s ease;pointer-events:none;z-index:5}body.engine-thinking .board-area:after{opacity:1;transform:scale(1);animation:engineThinkSpin .9s linear infinite}@keyframes engineThinkSpin{to{transform:rotate(360deg)}}body.engine-thinking .eval{color:var(--color-accent);font-style:italic}body.fullscreen.engine-thinking .board-area:after{border-color:#ffffff40;border-top-color:#ffffffd9}.fullscreen-toggle{position:fixed;top:.75rem;right:.75rem;width:2.4rem;height:2.4rem;border-radius:.5rem;background:var(--color-card-bg);border:1px solid var(--color-card-border);color:var(--color-text);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:50;transition:background-color .15s ease,transform .15s ease}.fullscreen-toggle:hover{background:#fff;transform:scale(1.05)}.fullscreen-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}body.fullscreen{background:#2a2218}body.fullscreen .app-shell{grid-template-columns:1fr;padding:0;min-height:100vh;align-items:center;justify-items:center}body.fullscreen .app-shell>*:not(.board-column){display:none}body.fullscreen .loading-row,body.fullscreen .clock.untimed,body.fullscreen .replay-panel{display:none}body.fullscreen .board-column{--board-size: min(94vmin, 88vh);gap:.4rem}body.fullscreen .board-side{margin:0}body.fullscreen .fullscreen-toggle{background:#ffffff1a;border-color:#fff3;color:#ffffffd9}body.fullscreen .fullscreen-toggle:hover{background:#fff3}body.fullscreen .clock{background:#ffffff14;border-color:#ffffff26;color:#ffffffd9}body.fullscreen .clock.running{background:#ffffff2e;color:#fff}body.fullscreen .material-advantage{color:#fff9}
