: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}body{margin:0;min-width:320px;min-height:100vh}#root{width: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}.welcome-container{min-height:100vh;display:flex;justify-content:center;align-items:center}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.check-banner{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#ff3c3cf2;color:#fff;padding:10px 18px;border-radius:12px;font-weight:700;font-size:14px;animation:pulseWarning 1s infinite;z-index:1000}@keyframes pulseWarning{0%{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.05)}to{transform:translate(-50%) scale(1)}}.board-area{position:relative;display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap}.opening-panel{align-self:flex-start;min-width:170px;max-width:220px;padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;text-align:left}.opening-panel-title{font-size:.8rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#64748b;margin-bottom:4px}.opening-panel-value{font-size:.95rem;font-weight:600;color:#0f172a;line-height:1.3}.captured-row{min-height:35px;display:flex;justify-content:flex-start;align-items:center}.board{display:grid;grid-template-columns:repeat(8,minmax(70px,1fr));grid-template-rows:repeat(8,minmax(70px,1fr));width:100%;max-width:600px;aspect-ratio:1 / 1;margin:20px auto;border:2px solid black;min-height:300px}.square{width:100%;height:100%;min-width:50px;min-height:50px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;overflow:hidden}.square.highlighted{border:3px solid yellow}@keyframes pulseRed{0%{box-shadow:0 0 20px #ff000080}50%{box-shadow:0 0 50px #f00c}to{box-shadow:0 0 20px #ff000080}}.king-in-check{animation:pulseRed .5s infinite;border:2px solid red}.promotion-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.promotion-box{background:#fff;padding:20px;border-radius:10px}.ai-thinking-indicator{position:absolute;right:12px;top:50%;transform:translateY(-50%);padding:10px 12px;border-radius:10px;background:#000000bf;color:#fff;font-weight:600;font-size:20px;white-space:nowrap;box-shadow:0 0 12px #fff3;animation:pulse 1.5s infinite}.thinking-dots span{display:inline-block;animation:thinkingDot 1.2s infinite}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes thinkingDot{0%,80%,to{opacity:.2}40%{opacity:1}}
