:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#e8ecf4;-webkit-font-smoothing:antialiased;background:#0f1117;font-family:system-ui,Segoe UI,Roboto,sans-serif}body{touch-action:manipulation;min-height:100svh;margin:0}#root{min-height:100svh}h1,h2{margin:0;font-weight:600}:root{--board-size:min(88vmin, 640px);--sq:calc(var(--board-size) / 8)}*{box-sizing:border-box}.start-screen{text-align:center;max-width:520px;margin:0 auto;padding:2rem 1.5rem 3rem}.start-screen h1{margin-bottom:1.5rem;font-size:2.4rem}.start-screen h2{opacity:.7;text-align:left;margin:1.4rem 0 .6rem;font-size:1rem}.choice-row{gap:.6rem;display:flex}.choice-row button{flex:1;padding:.9rem;font-size:1.05rem}.difficulty-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.difficulty-grid button{flex-direction:column;align-items:center;gap:.2rem;padding:.7rem .4rem;font-size:.85rem;display:flex}.difficulty-grid .lvl-num{opacity:.6;font-size:.7rem}button{color:#e8ecf4;cursor:pointer;background:#1f2433;border:1px solid #333a4d;border-radius:10px;transition:background .15s,border-color .15s,transform .1s}button:hover{border-color:#4ade80}button:active{transform:scale(.97)}button.active{background:#2563eb;border-color:#60a5fa}.start-btn{background:#16a34a;border-color:#22c55e;width:100%;margin-top:2rem;padding:1rem;font-size:1.15rem}.portal-link{color:#93c5fd;opacity:.85;font-size:.9rem;text-decoration:none;display:inline-block}.portal-link:hover{text-decoration:underline}.start-screen .portal-link{margin-bottom:.5rem}.portal-link.sm{opacity:.7;font-size:.75rem}.game-screen{max-width:var(--board-size);margin:0 auto;padding:1rem}.game-ui{margin-bottom:.8rem}.status-bar{flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.5rem;display:flex}.status-text{font-size:1.15rem;font-weight:600}.thinking{color:#fbbf24;font-size:.85rem;animation:1s infinite blink}.badge{background:#1f2433;border:1px solid #333a4d;border-radius:999px;padding:.15rem .6rem;font-size:.75rem}@keyframes blink{50%{opacity:.4}}.captured-row{gap:1rem;min-height:1.8rem;margin-bottom:.6rem;display:flex}.captured{flex-wrap:wrap;align-items:center;gap:.1rem;display:flex}.cap-label{opacity:.5;margin-right:.3rem;font-size:.7rem}.captured .piece{font-size:1.3rem}.controls{gap:.5rem;display:flex}.controls button{flex:1;padding:.6rem}.board2d{width:var(--board-size);height:var(--board-size);-webkit-user-select:none;user-select:none;border:3px solid #1f2433;border-radius:6px;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);display:grid;overflow:hidden}.sq{cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.sq.light{background:#e8d2a8}.sq.dark{background:#9a6b43}.sq.selected{background:#6ee7a0!important}.sq.lastmove:after{content:"";background:#c9b45873;position:absolute;inset:0}.sq.check{background:radial-gradient(circle,#ef4444 30%,#0000 70%)!important}.piece{font-size:calc(var(--sq) * .82);z-index:2;pointer-events:none;line-height:1;transition:transform .12s}.sq:hover .piece{transform:translateY(-2px)scale(1.05)}.piece.white{color:#f7f5ef;-webkit-text-stroke:1.5px #3a3026;text-shadow:0 2px 3px #00000073,0 0 1px #0009}.piece.black{color:#26252b;-webkit-text-stroke:1.5px #0c0c10;text-shadow:0 2px 3px #00000080,0 0 2px #ffffff40}.target-dot{z-index:1;background:#22c55e99;border-radius:50%;width:28%;height:28%;position:absolute}.target-ring{z-index:1;border:4px solid #22c55eb3;border-radius:50%;position:absolute;inset:6%}.capture-flash{z-index:3;pointer-events:none;background:radial-gradient(circle,#fde047 0%,#f97316 40%,#0000 70%);animation:.5s ease-out forwards flash;position:absolute;inset:0}@keyframes flash{0%{opacity:1;transform:scale(.3)}to{opacity:0;transform:scale(1.6)}}.board3d{width:var(--board-size);height:var(--board-size);touch-action:none;border-radius:6px;overflow:hidden}.replay-controls{margin-top:.5rem}.replay-controls button{font-size:1rem}.end-overlay{z-index:100;cursor:pointer;justify-content:center;align-items:center;animation:.3s ease-out overlay-in;display:flex;position:fixed;inset:0;overflow:hidden}@keyframes overlay-in{0%{opacity:0}}.end-overlay.win{background:radial-gradient(circle,#2563eb80,#080a14eb)}.end-overlay.lose{background:radial-gradient(circle,#3c141499,#000000f2)}.end-overlay.draw{background:#0f1117eb}.end-center{text-align:center;z-index:2}.end-title{margin:0;font-size:4.5rem;animation:.6s cubic-bezier(.18,1.4,.5,1) both title-pop}.end-title.win{color:#fbbf24;text-shadow:0 0 24px #fbbf24cc}.end-title.lose{color:#ef4444;text-shadow:0 0 18px #ef444499;animation:.6s both title-pop,.5s .6s 2 shake}.end-title.draw{color:#cbd5e1}@keyframes title-pop{0%{opacity:0;transform:scale(.2)}}@keyframes shake{25%{transform:translate(-10px)}75%{transform:translate(10px)}}.end-subtitle{opacity:.85;margin:.6rem 0 1.6rem;font-size:1.2rem}.end-hint{opacity:.6;font-size:.95rem;animation:1.4s infinite blink}.end-menu{cursor:default;flex-direction:column;gap:.6rem;width:220px;margin:0 auto;display:flex}.end-menu button{padding:.8rem;font-size:1.05rem}.confetti-layer{z-index:1;pointer-events:none;position:absolute;inset:0}.confetti{border-radius:2px;width:10px;height:16px;animation-name:confetti-fall;animation-timing-function:linear;animation-iteration-count:infinite;position:absolute;top:-20px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-20px)translate(0)rotate(0)}to{transform:translateY(105vh) translateX(var(--drift)) rotate(540deg);opacity:.9}}.falling-king{color:#555;filter:grayscale();font-size:2rem;animation-name:confetti-fall;animation-timing-function:ease-in;animation-iteration-count:infinite;position:absolute;top:-40px}
