:root{color-scheme:light;font-family:Hiragino Sans,Yu Gothic,Meiryo,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background:#f5e4c3;color:#1f160f;font-size:18px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f5e4c3}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.app{min-height:100vh}.app--large{font-size:1.08rem}.setup-page,.game-page,.result-page{width:min(1540px,calc(100% - 28px));margin:0 auto}.setup-page{padding:28px 0 40px}.setup-hero{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;min-height:34vh;padding:18px 0 30px}.brand-mark,.mini-mark{display:grid;place-items:center;color:#fff8e6;background:#7c4f22;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-weight:800;box-shadow:0 14px 28px #3f261138}.brand-mark{width:clamp(112px,16vw,180px);aspect-ratio:1;border-radius:28px;font-size:clamp(3.8rem,9vw,6.4rem)}.mini-mark{width:52px;height:52px;border-radius:14px;font-size:1.8rem}.eyebrow{margin:0 0 10px;color:#5a3a1f;font-size:.9rem;font-weight:800;letter-spacing:0}h1,h2,p{overflow-wrap:anywhere}h1{margin:0;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:clamp(2.4rem,7vw,5.6rem);line-height:1.05;letter-spacing:0;color:#24170d}.lead{max-width:780px;margin:18px 0 0;color:#4a321f;font-size:clamp(1.05rem,2.2vw,1.35rem);line-height:1.75}.difficulty-section{padding:28px 0 16px;border-top:2px solid #9b6a35}.section-heading{margin-bottom:14px}.section-heading h2{margin:0;color:#24170d;font-size:1.7rem}.difficulty-selector{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;padding:8px;background:#d79a45;border:3px solid #6a4019;border-radius:8px}.difficulty-choice{display:grid;gap:6px;place-items:center;min-height:94px;padding:12px 8px;text-align:center;color:#2c1d12;background:#f2c36f;border:3px solid #6a4019;border-radius:8px;box-shadow:none}.difficulty-choice:hover,.difficulty-choice:focus-visible{border-color:#17623a;outline:4px solid #d79a45}.difficulty-choice--active{color:#fff8e6;background:#17623a;border-color:#0f3e26}.difficulty-choice strong,.difficulty-choice span{display:block}.difficulty-choice span{color:#3a2413;font-size:.95rem;font-weight:800}.difficulty-choice--active span{color:#fff8e6}.difficulty-choice strong{font-size:clamp(1rem,1.7vw,1.22rem);line-height:1.25}.setup-actions{display:flex;justify-content:center;padding:20px 0}.button,.icon-button{min-height:48px;border:2px solid #6a4019;border-radius:8px;color:#2c1d12;background:#f0b24f;font-weight:800}.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 18px}.button--primary{color:#fff8e6;background:#17623a;border-color:#0f3e26}.button--hero{min-height:62px;padding:16px 28px;font-size:1.2rem}.topbar{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;padding:14px 0;background:#f5e4c3;border-bottom:3px solid #9b6a35;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-title{display:flex;gap:12px;align-items:center}.topbar-title p,.topbar-title strong{display:block;margin:0}.topbar-title p{color:#5a3a1f;font-size:.9rem}.topbar-title strong{color:#24170d;font-size:1.2rem}.status-strip{display:flex;justify-content:center;gap:10px}.turn-pill,.thinking-pill,.check-pill{display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:8px 14px;border-radius:999px;font-weight:900}.turn-pill--human{color:#fff8e6;background:#17623a}.turn-pill--cpu,.thinking-pill{color:#fff8e6;background:#1f4f86}.check-pill{color:#fff8e6;background:#9a3f32}.topbar-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:end}.icon-button{display:inline-flex;align-items:center;gap:8px;padding:8px 11px}.icon-button svg{width:20px;height:20px}.icon-button--danger{color:#fff8e6;background:#8b1f13;border-color:#5c160e}.game-layout{display:grid;grid-template-columns:minmax(640px,1fr) minmax(300px,.38fr);gap:16px;align-items:start;padding-bottom:34px}.side-panel,.board-area,.review-current,.review-board-panel{background:#d79a45;border:3px solid #5a3517;border-radius:8px;box-shadow:0 8px 20px #442a1314}.side-panel{display:grid;gap:14px;padding:14px}.board-area{display:grid;gap:14px;justify-items:center;padding:18px}.opponent-zone,.player-zone{display:grid;grid-template-columns:minmax(180px,.42fr) minmax(0,1fr);gap:12px;width:min(100%,78vh,820px);min-width:0}.player-zone{grid-template-columns:minmax(0,1fr) minmax(180px,.42fr)}.opponent-zone .hand-pieces,.player-zone .hand-pieces{grid-template-columns:repeat(7,minmax(0,1fr))}.player-summary,.hand-panel,.thought-panel,.move-list{border-radius:8px;background:#ffe0a3;border:2px solid #6a4019;padding:14px}.player-summary h2,.hand-panel h2,.thought-panel h2,.move-list h2{margin:0 0 10px;font-size:1.08rem}.player-summary p,.thought-panel p{margin:0;line-height:1.6}.muted{color:#4a2a12}.hand-pieces{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.hand-piece{display:grid;grid-template-columns:1fr auto;align-items:center;min-height:48px;padding:8px 10px;color:#2c1d12;background:#f2c36f;border:2px solid #5a3517;border-radius:8px}.hand-piece span{font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:1.35rem;font-weight:900}.hand-piece strong{min-width:30px;text-align:center;color:#fff8e6;background:#17623a;border-radius:999px}.hand-piece--active{border-color:#8b1f13;outline:4px solid #8b1f13}.hand-piece:disabled{opacity:.58}.board-frame{width:min(100%,78vh,820px);min-width:0}.file-labels{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));padding:0 0 6px 34px;color:#4a321f;font-weight:900;text-align:center}.board-with-ranks{display:grid;grid-template-columns:26px 1fr;gap:8px}.rank-labels{display:grid;grid-template-rows:repeat(9,minmax(0,1fr));align-items:center;color:#4a321f;font-weight:900;text-align:center}.shogi-board{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));grid-template-rows:repeat(9,minmax(0,1fr));width:100%;aspect-ratio:1;border:6px solid #3a210f;background:#b86d25;box-shadow:inset 0 0 0 2px #f2c36f,0 10px 22px #3e26122e}.board-cell{position:relative;display:grid;place-items:center;width:100%;height:100%;min-width:0;min-height:0;padding:4px;overflow:hidden;border:1px solid #3a210f;background:linear-gradient(90deg,rgba(255,214,126,.24),transparent 38%,rgba(77,38,12,.24)),#d8923d}.board-cell:nth-child(odd){background:linear-gradient(90deg,rgba(255,214,126,.24),transparent 38%,rgba(77,38,12,.24)),#d8923d}.board-cell:hover:not(:disabled),.board-cell:focus-visible{z-index:3;outline:5px solid #17623a}.board-cell:disabled{color:inherit;opacity:1}.board-cell--selected{background:#f3b84b;box-shadow:inset 0 0 0 5px #17623a}.board-cell--target{background:#2f8f57}.board-cell--last{box-shadow:inset 0 0 0 5px #9a3f3294}.move-dot{position:absolute;width:34%;aspect-ratio:1;border-radius:999px;background:#fff7d8;pointer-events:none}.piece-token{position:relative;z-index:2;display:grid;place-items:center;width:78%;height:88%;color:#20130a;background:#5c371a;clip-path:polygon(50% 0%,94% 18%,82% 100%,18% 100%,6% 18%);filter:drop-shadow(0 5px 3px rgba(43,26,12,.28));transform-origin:center}.piece-token:before{position:absolute;top:4px;right:4px;bottom:4px;left:4px;content:"";background:linear-gradient(105deg,rgba(255,255,255,.42),transparent 24%),linear-gradient(90deg,rgba(128,75,28,.12),transparent 38%,rgba(128,75,28,.14)),#f4d58e;clip-path:inherit}.piece-token:after{position:absolute;top:9px;right:10px;bottom:7px;left:10px;content:"";border:1px solid rgba(92,55,26,.32);clip-path:inherit}.piece-token span{position:relative;z-index:1;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:clamp(1.25rem,4.1vw,2.45rem);font-weight:900;line-height:1;transform:translateY(4%)}.piece-token--white{color:#20130a;background:#5c371a;transform:rotate(180deg)}.piece-token--promoted{color:#9a2418;background:#6b2d20}.thought-panel{display:grid;gap:12px}.thought-head{display:flex;gap:10px;align-items:center}.thought-head h2,.thought-head p{margin:0}.thought-head p{color:#4a2a12;font-size:.9rem}.thought-list{display:grid;gap:10px;margin:0}.thought-list div{display:grid;gap:4px}.thought-list dt{color:#123d25;font-weight:900}.thought-list dd{margin:0;line-height:1.55}.spinner{width:40px;height:40px;border:5px solid #8f5a22;border-top-color:#1f4f86;border-radius:999px;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.move-list ol{display:grid;gap:6px;max-height:540px;margin:0;padding:0;list-style:none;overflow:auto}.move-list--compact ol{max-height:650px}.move-row{display:grid;grid-template-columns:38px 1fr auto;gap:8px;align-items:center;width:100%;min-height:44px;padding:8px 10px;text-align:left;color:#2c1d12;background:#ffe0a3;border:2px solid #6a4019;border-radius:6px}.move-row--active{color:#fff8e6;background:#17623a;border-color:#0f3e26}.move-row span{color:#4a2a12;font-weight:900}.move-row small{color:#123d25;font-weight:800}.move-row--active span,.move-row--active small{color:#fff8e6}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:18px;background:#24170d85}.promotion-dialog{width:min(460px,100%);padding:24px;background:#ffe0a3;border:4px solid #5a3517;border-radius:8px;box-shadow:0 24px 60px #24170d52}.promotion-dialog h2{margin:0 0 10px}.promotion-dialog p{line-height:1.65}.dialog-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.result-page{padding:26px 0 44px}.result-header{display:flex;justify-content:space-between;gap:20px;align-items:center;padding-bottom:20px;border-bottom:3px solid #9b6a35}.result-header h1{font-size:clamp(2.2rem,6vw,4.8rem)}.result-header p{margin:10px 0 0;color:#5a3a1f}.result-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.review-intro{margin:18px 0;padding:16px 18px;background:#d79a45;border:3px solid #5a3517;border-radius:8px}.review-intro h2{margin:0 0 8px}.review-intro p{margin:0;line-height:1.65;color:#1f160f}.review-layout{display:grid;grid-template-columns:minmax(460px,.95fr) minmax(320px,1fr);gap:18px;align-items:start}.review-board-panel{display:grid;gap:12px;justify-items:center;padding:16px}.review-controls{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;width:min(100%,720px)}.review-controls input{width:100%;accent-color:#17623a}.review-side{display:grid;gap:14px}.review-current{padding:16px}.review-current h2{margin:0 0 12px}.human-comment{margin:0;line-height:1.7;color:#1f160f}@media(max-width:1180px){.difficulty-selector{grid-template-columns:repeat(3,minmax(0,1fr))}.game-layout,.review-layout{grid-template-columns:1fr}.board-area{order:1}.side-panel{order:2}}@media(max-width:760px){:root{font-size:16px}.setup-page,.game-page,.result-page{width:min(100% - 16px,1480px)}.setup-hero{grid-template-columns:1fr;min-height:auto}.brand-mark{width:110px;border-radius:22px;font-size:4rem}.section-heading,.result-header{display:grid}.difficulty-selector{grid-template-columns:1fr}.topbar{position:static;grid-template-columns:1fr}.status-strip,.topbar-actions{justify-content:start}.icon-button span{display:none}.board-area,.side-panel,.review-board-panel{padding:10px}.opponent-zone,.player-zone{grid-template-columns:1fr;width:100%}.player-zone .player-summary{order:2}.board-with-ranks{grid-template-columns:20px 1fr;gap:5px}.file-labels{padding-left:25px}.shogi-board{border-width:3px}.board-cell{padding:2px}.piece-token{width:82%;height:90%}.hand-pieces{grid-template-columns:repeat(7,minmax(0,1fr))}.hand-piece{grid-template-columns:1fr;justify-items:center;padding:7px 4px}.hand-piece strong{min-width:24px}}
