@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@500;600;700&family=Baloo+2:wght@500;600;700;800&display=swap";html,body,#app{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;font-family:"Baloo 2",system-ui,-apple-system,Segoe UI,Roboto,sans-serif}:root{--bg-0:#fff5fb;--bg-1:#ffe9f4;--panel:#fff;--panel-2:#fff0f7;--line:#1f1c2e14;--line-strong:#1f1c2e29;--fg:#2a2440;--muted:#7a6b8a;--light:#fff0f7;--light-2:#ffd6ec;--dark:#ff7eb6;--dark-2:#ff5fa2;--sel:#ffd54fb3;--target:#1f1c2e38;--capture:#ff5f82b3;--last:#ffd54f8c;--check:#ff4c648c;--accent:#ff3d8a;--accent-2:#ff95c2;--good:#2eb33e;--bad:#ff4d6d;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-pill:999px;--shadow-sm:0 2px 8px #1f1c2e14;--shadow-md:0 8px 22px #1f1c2e1f;--shadow-pop:0 14px 36px #1f1c2e2e;--btn-h:52px;--btn-h-lg:60px;--font-display:"Fredoka", "Baloo 2", system-ui, sans-serif;--font-body:"Baloo 2", system-ui, sans-serif;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);--bottom-bar-h:68px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:radial-gradient(1100px 600px at 50% -10%, #1f2638 0%, transparent 55%), radial-gradient(700px 500px at 90% 110%, #2a1e30 0%, transparent 60%), var(--bg-0);color:var(--fg);font-feature-settings:"cv11", "ss01";-webkit-font-smoothing:antialiased;min-height:100vh;font:16px/1.55 Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif}.app{max-width:1080px;margin:0 auto;padding:32px 20px 56px}.hdr{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.brand{align-items:center;gap:12px;display:flex}.brand .logo{color:var(--accent);filter:drop-shadow(0 2px 8px #d4a55a66);font-size:34px;line-height:1}.brand-text{flex-direction:column;gap:2px;display:flex}.hdr h1{letter-spacing:.3px;background:linear-gradient(135deg,#fff 0%,#c7cdd9 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:26px;font-weight:700;line-height:1.1}.tagline{color:var(--muted);letter-spacing:.3px;font-size:12px;font-weight:500}.hdr-right{align-items:center;gap:10px;display:flex}.mode{background:var(--panel);border:1px solid var(--line);border-radius:999px;gap:2px;padding:4px;display:inline-flex;box-shadow:0 4px 16px #00000059}.mode button{all:unset;color:var(--muted);cursor:pointer;border-radius:999px;align-items:center;min-height:36px;padding:9px 16px;font-size:14px;font-weight:500;transition:color .15s,background .15s,transform .1s;display:inline-flex}.mode button:hover{color:var(--fg)}.mode button.on{background:linear-gradient(180deg, var(--accent-2), var(--accent));color:#1a120a;font-weight:600;box-shadow:0 2px 8px #d4a55a59,inset 0 1px #fff6}.status{color:var(--fg);font-variant-numeric:tabular-nums;letter-spacing:.1px;margin:8px 0 18px;font-size:15px;font-weight:500}.tactics-wrap{grid-template-columns:1fr 280px;align-items:start;gap:24px;display:grid}@media (width<=760px){.tactics-wrap{grid-template-columns:1fr}}.board-wrap{flex-direction:column;gap:10px;display:flex}.turn-bar{justify-content:center;align-items:center;gap:14px;margin-bottom:6px;display:flex}.turn-side{border:1px solid var(--line);background:var(--panel);color:var(--muted);opacity:.55;border-radius:999px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:600;transition:opacity .2s,border-color .2s,background .2s,transform .2s;display:inline-flex}.turn-side.active{opacity:1;border-color:var(--accent);color:var(--fg);box-shadow:0 0 0 1px var(--accent), 0 4px 14px #d4a55a40;background:linear-gradient(#d4a55a2e,#d4a55a0d);transform:scale(1.04)}.turn-king{font-size:22px;line-height:1}.turn-king.white{color:#fafafa;text-shadow:0 0 2px #0000008c,0 1px #0006}.turn-king.black{color:#1f1f1f;text-shadow:0 0 2px #fff9}.turn-vs{letter-spacing:1px;color:var(--muted);text-transform:uppercase;opacity:.7;font-size:11px;font-weight:700}.turn-bar.over .turn-side{opacity:.4;box-shadow:none;transform:none}.captured{border:1px solid var(--line);background:#ffffff08;border-radius:8px;flex-wrap:wrap;align-items:center;gap:2px;min-height:32px;padding:6px 10px;display:flex}.cap-piece{justify-content:center;align-items:center;width:22px;height:22px;margin-right:-3px;line-height:1;display:inline-flex}.cap-img{width:100%;height:100%;display:block}.cap-piece.white .cap-img{filter:drop-shadow(0 0 1px #0009)}.cap-piece.black .cap-img{filter:drop-shadow(0 0 1px #fff9)}.cap-empty{color:var(--muted);opacity:.7;font-size:12px;font-style:italic}.board{aspect-ratio:1;width:100%;max-width:680px;box-shadow:0 24px 60px #0000008c, 0 0 0 1px var(--line-strong), 0 0 0 6px var(--panel), 0 0 0 7px var(--line-strong);border-radius:12px;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);margin:0 auto;transition:box-shadow .4s,transform .4s;display:grid;overflow:hidden}.board.glow{box-shadow:0 24px 60px #0000008c, 0 0 0 1px var(--good), 0 0 0 6px var(--panel), 0 0 0 7px var(--good), 0 0 30px #6cc28a59}.board.shake{animation:.4s ease-in-out shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.sq{all:unset;cursor:pointer;font-size:calc(clamp(30px, 7vw, 56px) * var(--piece-scale,1));-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;line-height:1;transition:filter .1s;display:flex;position:relative}.sq.light{background:linear-gradient(135deg, var(--light) 0%, var(--light-2) 100%)}.sq.dark{background:linear-gradient(135deg, var(--dark) 0%, var(--dark-2) 100%)}.sq.sel{background:linear-gradient(135deg, var(--accent-2), var(--accent))!important}.sq.last{box-shadow:inset 0 0 0 4px var(--last)}.sq.check{background:linear-gradient(135deg,#e88,#c66)!important}.sq.target:after,.sq.capture:after{content:"";pointer-events:none;position:absolute;inset:0}.sq.target:after{background:radial-gradient(circle at center, var(--target) 18%, transparent 22%)}.sq.capture:after{box-shadow:inset 0 0 0 4px var(--capture);border-radius:50%;margin:5px}.sq:hover{filter:brightness(1.08)}.piece{pointer-events:none;z-index:1;width:calc(clamp(30px, 7vw, 56px) * var(--piece-scale,1));height:calc(clamp(30px, 7vw, 56px) * var(--piece-scale,1));justify-content:center;align-items:center;transition:transform .12s ease-out;display:inline-flex}.piece-img{filter:drop-shadow(0 1px 2px #00000059);width:100%;height:100%;display:block}.piece.black .piece-img{filter:drop-shadow(0 0 1px #fff9)drop-shadow(0 1px 2px #0006)}.sq:hover .piece{transform:translateY(-2px)scale(1.04)}.sq.sel .piece{transform:scale(1.06)}.coord{opacity:.55;pointer-events:none;letter-spacing:.5px;font-size:10px;font-weight:700;position:absolute}.sq.light .coord{color:var(--dark-2)}.sq.dark .coord{color:var(--light)}.coord.rank{top:4px;left:5px}.coord.file{bottom:3px;right:6px}.controls{justify-content:center;align-items:center;gap:10px;margin-top:6px;display:flex}.btn{background:var(--panel);color:var(--fg);border:1px solid var(--line);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;min-height:44px;padding:11px 22px;font-size:14px;font-weight:600;transition:background .12s,border-color .12s,transform 50ms;display:inline-flex}.btn:hover:not(:disabled){background:var(--panel-2);border-color:var(--line-strong)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:linear-gradient(180deg, var(--accent-2), var(--accent));color:#1a120a;border-color:#0000;font-weight:600;box-shadow:0 2px 8px #d4a55a4d,inset 0 1px #ffffff59}.btn.primary:hover:not(:disabled){filter:brightness(1.06)}.btn.ghost{background:0 0}.thinking{color:var(--muted);align-items:center;gap:6px;font-size:12px;font-style:italic;display:inline-flex}.thinking:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.puzzle-card{background:linear-gradient(180deg, var(--panel) 0%, var(--bg-1) 100%);border:1px solid var(--line);border-radius:14px;flex-direction:column;gap:14px;padding:20px;display:flex;box-shadow:0 8px 24px #00000059}.puzzle-head{justify-content:space-between;align-items:center;display:flex}.puzzle-tag{letter-spacing:.8px;text-transform:uppercase;color:var(--accent-2);background:#d4a55a1f;border:1px solid #d4a55a40;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.puzzle-num{color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px;font-weight:600}.puzzle-prompt{color:var(--fg);margin:0;font-size:14px;line-height:1.5}.verdict{text-align:center;border:1px solid var(--line);border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600;transition:all .2s}.verdict.idle{color:var(--muted);background:#ffffff05}.verdict.solved{color:var(--good);background:#6cc28a1f;border-color:#6cc28a4d}.verdict.wrong{color:var(--bad);background:#e074761f;border-color:#e074764d}.puzzle-hint{color:var(--muted);border-left:3px solid var(--accent);background:#d4a55a0f;border-radius:0 6px 6px 0;margin:0;padding:10px 12px;font-size:13px;font-style:italic;line-height:1.5}.puzzle-stats{grid-template-columns:1fr 1fr;gap:8px;display:grid}.puzzle-stats>div{border:1px solid var(--line);background:#ffffff08;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:10px;display:flex}.puzzle-stats b{color:var(--accent-2);font-variant-numeric:tabular-nums;font-size:22px;font-weight:700}.puzzle-stats span{letter-spacing:.8px;text-transform:uppercase;color:var(--muted);font-size:10px}.puzzle-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.puzzle-actions .btn.primary{grid-column:1/-1}.ftr{text-align:center;color:var(--muted);opacity:.5;letter-spacing:.4px;margin-top:32px;font-size:11px}.gear{all:unset;background:var(--panel);border:1px solid var(--line);width:38px;height:38px;color:var(--muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:color .15s,background .15s,transform .4s;display:inline-flex;box-shadow:0 4px 16px #00000059}.gear:hover{color:var(--accent-2);background:var(--panel-2);transform:rotate(45deg)}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:100;background:#05080ea6;justify-content:center;align-items:center;padding:20px;animation:.18s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{background:linear-gradient(180deg, var(--panel) 0%, var(--bg-1) 100%);border:1px solid var(--line-strong);border-radius:18px;width:100%;max-width:560px;max-height:calc(100vh - 40px);padding:24px;animation:.22s cubic-bezier(.2,.8,.2,1) slideUp;overflow-y:auto;box-shadow:0 30px 80px #0009}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-head{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.modal-head h2{letter-spacing:.2px;margin:0;font-size:18px;font-weight:700}.modal-close{all:unset;width:30px;height:30px;color:var(--muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:22px;line-height:1;transition:background .15s,color .15s;display:inline-flex}.modal-close:hover{color:var(--fg);background:#ffffff0f}.modal-sub{color:var(--muted);margin:0 0 20px;font-size:13px}.size-section{border:1px solid var(--line);background:#ffffff05;border-radius:12px;margin-bottom:22px;padding:16px}.size-head{justify-content:space-between;align-items:baseline;margin-bottom:14px;display:flex}.size-head h3{color:var(--fg);letter-spacing:.2px;margin:0;font-size:13px;font-weight:600}.size-value{color:var(--accent-2);font-variant-numeric:tabular-nums;font-size:13px;font-weight:700}.size-row{align-items:center;gap:14px;display:flex}.size-icon{color:var(--muted);-webkit-user-select:none;user-select:none;flex-shrink:0;line-height:1}.size-icon.small{font-size:16px}.size-icon.large{font-size:26px}.size-slider{appearance:none;cursor:pointer;background:#ffffff14;background-image:linear-gradient(90deg, var(--accent) 0%, var(--accent) var(--fill,50%), #ffffff14 var(--fill,50%));border-radius:999px;outline:none;flex:1;height:6px}.size-slider::-webkit-slider-thumb{appearance:none;background:linear-gradient(180deg, var(--accent-2), var(--accent));border:2px solid var(--bg-1);cursor:grab;border-radius:50%;width:18px;height:18px;transition:transform .1s;box-shadow:0 2px 6px #0006}.size-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.size-slider::-moz-range-thumb{background:linear-gradient(180deg, var(--accent-2), var(--accent));border:2px solid var(--bg-1);cursor:grab;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #0006}.size-reset{all:unset;color:var(--muted);cursor:pointer;text-underline-offset:2px;margin-left:8px;font-size:11px;text-decoration:underline;transition:color .15s}.size-reset:hover{color:var(--accent-2)}.theme-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.theme-card{all:unset;border:1px solid var(--line);cursor:pointer;background:#ffffff05;border-radius:12px;flex-direction:column;padding:8px;transition:border-color .15s,transform .1s,background .15s;display:flex}.theme-card:hover{border-color:var(--line-strong);background:#ffffff0a;transform:translateY(-2px)}.theme-card.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset, 0 8px 20px #0000004d;background:#ffffff0d}.theme-preview{aspect-ratio:1;border-radius:8px;margin-bottom:8px;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000004d}.theme-mini{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;display:grid;position:absolute;inset:0}.theme-mini span{width:100%;height:100%;display:block}.theme-check{color:#14110a;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:800;display:inline-flex;position:absolute;top:6px;right:6px;box-shadow:0 2px 6px #0006}.theme-label{justify-content:space-between;align-items:center;padding:0 4px;display:flex}.theme-name{color:var(--fg);letter-spacing:.1px;font-size:13px;font-weight:600}.theme-dot{border-radius:50%;width:10px;height:10px;box-shadow:0 0 0 2px #ffffff14}body{background:linear-gradient(135deg,#ffe9f4 0%,#fff5fb 45%,#e3f6ff 100%) fixed}.app{padding:28px 20px 80px}.brand{gap:14px}.brand .logo{filter:drop-shadow(0 4px 12px #ff3d8a59);animation:3.4s ease-in-out infinite brand-bob;font-size:46px!important}@keyframes brand-bob{0%,to{transform:translateY(0)rotate(-3deg)}50%{transform:translateY(-4px)rotate(3deg)}}.brand-title,.brand h1{font-family:var(--font-display);letter-spacing:.2px;background:linear-gradient(180deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;font-weight:700}.tagline{font-family:var(--font-body);color:var(--muted);font-weight:600}.mode{box-shadow:var(--shadow-sm);background:var(--panel)!important;border:2px solid var(--line)!important;border-radius:var(--radius-pill)!important;padding:6px!important}.mode button{font-family:var(--font-display);color:var(--muted);min-height:44px;transition:transform .15s,background .2s,color .2s,box-shadow .2s;border-radius:var(--radius-pill)!important;padding:10px 22px!important;font-size:15px!important;font-weight:700!important}.mode button:hover{color:var(--accent);transform:translateY(-1px)}.mode button.on{transform:translateY(-1px);background:linear-gradient(135deg, var(--accent), var(--accent-2))!important;color:#fff!important;box-shadow:0 6px 16px #ff3d8a59,inset 0 1px #ffffff59!important}.btn{box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .2s,border-color .2s;font-family:var(--font-display)!important;min-height:var(--btn-h)!important;border-radius:var(--radius-pill)!important;border:2px solid var(--line)!important;color:var(--fg)!important;background:#fff!important;padding:12px 24px!important;font-size:15px!important;font-weight:700!important}.btn:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent-2)!important}.btn:active:not(:disabled){transform:scale(.96)!important}.btn.primary{background:linear-gradient(135deg, var(--accent), var(--accent-2))!important;color:#fff!important;min-height:var(--btn-h-lg)!important;border-color:#0000!important;padding:14px 28px!important;font-size:16px!important;box-shadow:0 8px 22px #ff3d8a59,inset 0 1px #ffffff59!important}.btn.primary:hover:not(:disabled){box-shadow:0 12px 30px #ff3d8a6b,inset 0 1px #fff6!important}.btn.ghost{border-color:var(--line-strong)!important;background:0 0!important}.panel,.captured,.controls{border-radius:var(--radius-lg)!important}.captured{box-shadow:var(--shadow-sm);border:2px solid var(--line)!important;background:#fff!important;padding:14px 16px!important}.turn-side{font-family:var(--font-display);border:2px solid var(--line);background:#fff;padding:10px 18px;font-weight:700;border-radius:var(--radius-pill)!important;font-size:15px!important}.turn-side.active{box-shadow:0 8px 20px #ff3d8a59;background:linear-gradient(135deg, var(--accent), var(--accent-2))!important;color:#fff!important;border-color:#0000!important;transform:scale(1.08)!important}.status,.thinking{font-family:var(--font-body);color:var(--muted)!important}.thinking{color:var(--accent)!important;font-size:14px!important;font-style:normal!important;font-weight:600!important}.modal,.settings-card{border-radius:var(--radius-lg)!important;border:2px solid var(--line)!important;box-shadow:var(--shadow-pop)!important;background:#fff!important}.modal-head h2,.settings-card h2{font-family:var(--font-display);color:var(--fg);font-weight:700}.modal-close{width:40px;height:40px;border-radius:var(--radius-pill)!important;background:var(--panel-2)!important}.modal-close:hover{background:var(--accent-2)!important;color:#fff!important}.theme-card{border-radius:var(--radius-md)!important;border:2px solid var(--line)!important;background:#fff!important}.theme-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent-2)!important}.theme-card.on{border-color:var(--accent)!important;box-shadow:0 0 0 3px #ff3d8a2e, var(--shadow-md)!important}.theme-name{font-family:var(--font-display);font-weight:700!important}.puzzle-card{box-shadow:var(--shadow-sm);border-radius:var(--radius-lg)!important;border:2px solid var(--line)!important;background:#fff!important}.puzzle-prompt{font-family:var(--font-display);font-weight:700;color:var(--fg)!important}.puzzle-tag{font-family:var(--font-display);font-weight:700;border-radius:var(--radius-pill)!important;background:linear-gradient(135deg, var(--accent-2), var(--accent))!important;color:#fff!important}.verdict{font-family:var(--font-display);font-weight:700;border-radius:var(--radius-md)!important}.ftr{font-family:var(--font-body);color:var(--muted);margin-top:32px;font-weight:600}.board-frame,.board{border-radius:var(--radius-md)!important}.mascot{align-items:center;gap:12px;display:inline-flex;position:relative}.mascot-body{filter:drop-shadow(0 6px 14px #ff3d8a40);animation:3.2s ease-in-out infinite mascot-bob;display:inline-flex}.mascot-svg{display:block}.mascot-thinking .mascot-body{animation:.9s ease-in-out infinite mascot-shake}.mascot-happy .mascot-body{animation:.6s ease-in-out 2 mascot-jump}.mascot-sad .mascot-body{animation:1.6s ease-in-out infinite mascot-droop}@keyframes mascot-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes mascot-shake{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes mascot-jump{0%,to{transform:translateY(0)}40%{transform:translateY(-12px)scale(1.05)}}@keyframes mascot-droop{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(2px)rotate(-2deg)}}.mascot-bubble{border:2px solid var(--accent);max-width:220px;color:var(--fg);font-family:var(--font-display);border-radius:var(--radius-md);box-shadow:var(--shadow-md);background:#fff;padding:10px 14px;font-size:14px;font-weight:700;animation:.25s ease-out bubble-pop;position:relative}.mascot-bubble:before{content:"";border:8px solid #0000;border-right-color:var(--accent);width:0;height:0;position:absolute;top:50%;left:-10px;transform:translateY(-50%)}.mascot-bubble:after{content:"";border:6px solid #0000;border-right-color:#fff;width:0;height:0;position:absolute;top:50%;left:-6px;transform:translateY(-50%)}@keyframes bubble-pop{0%{opacity:0;transform:scale(.7)translate(-6px)}to{opacity:1;transform:scale(1)translate(0)}}.celebrate-host{pointer-events:none;z-index:9999;position:fixed;inset:0;overflow:hidden}.confetti{will-change:transform, top;transform-origin:50%;border-radius:3px;position:absolute}@keyframes confetti-fall{0%{transform:translateX(0) rotate(var(--rot-start,0deg));opacity:1;top:-24px}to{transform:translateX(var(--drift,0px)) rotate(var(--rot-end,360deg));opacity:1;top:110vh}}.celebrate-msg{font-family:var(--font-display);background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);opacity:0;text-align:center;white-space:nowrap;padding:18px 36px;font-size:clamp(28px,6vw,56px);font-weight:700;transition:opacity .25s,transform .35s cubic-bezier(.34,1.56,.64,1);position:absolute;top:32%;left:50%;transform:translate(-50%,-50%)scale(.6)}.celebrate-msg.show{opacity:1;transform:translate(-50%,-50%)scale(1)}.difficulty-tabs{background:var(--panel);border:2px solid var(--line);border-radius:var(--radius-pill);width:fit-content;box-shadow:var(--shadow-sm);gap:8px;margin-bottom:16px;padding:6px;display:flex}.difficulty-tabs button{font-family:var(--font-display);color:var(--muted);border-radius:var(--radius-pill);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;min-height:40px;padding:8px 18px;font-size:14px;font-weight:700;transition:transform .15s,background .2s,color .2s,box-shadow .2s;display:inline-flex}.difficulty-tabs button:hover{color:var(--accent);transform:translateY(-1px)}.difficulty-tabs button.on{color:#fff;background:linear-gradient(135deg, var(--accent), var(--accent-2));box-shadow:0 4px 12px #ff3d8a52,inset 0 1px #ffffff4d}.toggle-row{background:var(--panel-2);border:2px solid var(--line);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:16px;margin:16px 0 8px;padding:14px 16px;display:flex}.toggle-row .label{font-family:var(--font-display);align-items:center;gap:8px;font-size:15px;font-weight:700;display:inline-flex}.toggle-switch{border-radius:var(--radius-pill);background:var(--line-strong);cursor:pointer;border:none;width:52px;height:30px;padding:0;transition:background .2s;position:relative}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:24px;height:24px;transition:left .2s cubic-bezier(.34,1.56,.64,1);position:absolute;top:3px;left:3px;box-shadow:0 2px 6px #0003}.toggle-switch.on{background:linear-gradient(135deg, var(--accent), var(--accent-2))}.toggle-switch.on:after{left:25px}.bottom-nav{z-index:50;padding:8px 8px calc(8px + var(--safe-bottom));padding-left:calc(8px + var(--safe-left));padding-right:calc(8px + var(--safe-right));border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);background:linear-gradient(#ffffffeb 0%,#fff 30% 100%);justify-content:space-around;gap:4px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -6px 20px #1f1c2e1a}.bottom-nav button{border-radius:var(--radius-md);min-height:56px;color:var(--ink,#2a1e30);font-family:var(--font-display);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;transition:transform .12s,background .16s;display:flex}.bottom-nav button.on{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;box-shadow:var(--shadow-sm);transform:scale(1.04)}.bottom-nav .bn-icon{font-size:22px;line-height:1}.bottom-nav .bn-label{letter-spacing:.2px;font-size:11px;font-weight:700}html,body{overscroll-behavior-y:contain}.board,.sq{touch-action:manipulation}.settings-backdrop{-webkit-overflow-scrolling:touch;overflow-y:auto}button{-webkit-tap-highlight-color:transparent}@media (width<=760px){.hdr{flex-wrap:wrap;gap:8px}.hdr-right .mode{display:none}.bottom-nav{display:flex}.app{padding-bottom:calc(var(--bottom-bar-h) + var(--safe-bottom) + 16px);padding-top:calc(20px + var(--safe-top))}}@media (width<=600px){.brand-title{font-size:22px!important}.brand .tagline{display:none}.brand .logo{font-size:34px!important}.mascot{right:12px;bottom:calc(var(--bottom-bar-h) + var(--safe-bottom) + 12px);z-index:40;transform-origin:100% 100%;transform:scale(.85);position:fixed!important}.mascot-bubble{max-width:160px;font-size:13px;right:80px}.board-wrap{padding:0}.board{max-width:100%}.controls{flex-wrap:wrap;gap:8px}.btn{min-height:48px;padding:12px 18px;font-size:15px}.btn.primary{min-height:52px!important;font-size:15px!important}.captured{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:4px;max-width:100%;min-height:36px;padding:6px 8px;overflow-x:auto}.cap-piece{flex-shrink:0;width:22px;height:22px}.turn-bar{padding:8px 12px}.turn-side{padding:6px 10px}.turn-king{font-size:26px}.difficulty-tabs{gap:6px;padding:4px}.difficulty-tabs button{flex:1;min-height:44px;padding:8px 6px;font-size:13px}.puzzle-actions{flex-wrap:wrap;gap:8px}.puzzle-actions .btn{flex:calc(50% - 8px)}.puzzle-card{padding:14px}.settings-card{height:100dvh;max-height:100dvh;padding:calc(16px + var(--safe-top)) calc(16px + var(--safe-right)) calc(16px + var(--safe-bottom)) calc(16px + var(--safe-left));border-radius:0!important;width:100%!important;max-width:100%!important}.settings-card .theme-grid{grid-template-columns:repeat(2,1fr)}.status{padding:8px 12px;font-size:13px}.ftr{padding-bottom:calc(var(--bottom-bar-h) + var(--safe-bottom) + 8px);font-size:11px}}@media (width<=380px){.brand-title{font-size:20px!important}.mascot{transform:scale(.75)}.bottom-nav .bn-label{font-size:10px}.btn{padding:10px 14px;font-size:14px}}@media (hover:none) and (pointer:coarse){.btn:hover,.mode button:hover,.bottom-nav button:hover{transform:none}.btn:active,.mode button:active,.bottom-nav button:active{transition:transform 80ms;transform:scale(.96)}.sq:active{filter:brightness(1.1)}}.zombie-wrap{flex-direction:column;gap:12px;display:flex}.zombie-hud{color:#d8ffd8;background:linear-gradient(135deg,#2a3d2a,#1a2b1a);border-radius:14px;flex-direction:column;gap:8px;padding:14px 16px;display:flex;box-shadow:inset 0 0 0 1px #78ff782e}.zh-row-primary{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.zh-tile{background:#0000002e;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:64px;padding:10px 6px;display:flex;box-shadow:inset 0 0 0 1px #78ff781f}.zh-tile-value{color:#f0fff0;text-shadow:0 0 10px #78ff7866;letter-spacing:.5px;font-size:26px;font-weight:800;line-height:1}.zh-tile-cap{letter-spacing:.8px;text-transform:uppercase;color:#9be29b;font-size:10px}.zh-piece-svg{filter:drop-shadow(0 0 6px #a0ffa073);width:38px;height:38px}.zh-score .zh-tile-value{color:#ffe88c;text-shadow:0 0 10px #ffc85073}.zh-wave .zh-tile-value{color:#d8c0ff;text-shadow:0 0 10px #b482ff73}.zh-bombs .zh-tile-value{color:#ffb89a;text-shadow:0 0 10px #ff8c5a73}.zh-row-badges{flex-wrap:wrap;gap:8px;min-height:0;display:flex}.zh-row-badges:empty{display:none}.zh-badge{letter-spacing:.4px;text-transform:uppercase;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:700;animation:.32s cubic-bezier(.32,1.5,.4,1) zh-badge-pop;display:inline-flex}.zh-badge-combo{color:#fff8e8;background:linear-gradient(135deg,#ff9a3c,#ff5a1a);animation:.32s cubic-bezier(.32,1.5,.4,1) zh-badge-pop,.9s ease-in-out .32s infinite alternate zh-badge-throb;box-shadow:0 0 14px #ff8c328c}.zh-badge-freeze{color:#07355a;background:linear-gradient(135deg,#b8efff,#4ab6ff);box-shadow:0 0 14px #78c8ff8c}.zh-badge-morph{color:#1c0a3d;background:linear-gradient(135deg,#d8c0ff,#8a5dff);box-shadow:0 0 14px #aa78ff8c}@keyframes zh-badge-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes zh-badge-throb{0%{box-shadow:0 0 10px #ff8c3273}to{box-shadow:0 0 22px #ffc85ad9}}@media (width<=520px){.zh-row-primary{grid-template-columns:repeat(2,1fr)}.zh-tile{min-height:56px}.zh-tile-value{font-size:22px}.zh-piece-svg{width:32px;height:32px}}.zombie-card{border:2px solid #3cb43c59}.zombie-card .puzzle-tag{color:#d8ffd8;background:linear-gradient(135deg,#2f6e2f,#1a4a1a)}.zombie-tips{color:var(--muted);flex-direction:column;gap:4px;margin:8px 0;padding:0;font-size:13px;list-style:none;display:flex}.zombie-tips li:before{content:"•  ";color:#4a9d4a}.piece.zombie .piece-img{filter:hue-rotate(85deg)saturate(2.4)brightness(.85)drop-shadow(0 0 6px #50dc508c)drop-shadow(0 1px 2px #00000080);animation:2.4s ease-in-out infinite zombie-bob}.piece.zombie.weak .piece-img{filter:hue-rotate(-15deg)saturate(2.2)brightness(.95)drop-shadow(0 0 8px #ff5050b3)drop-shadow(0 1px 2px #00000080);animation:.7s ease-in-out infinite zombie-flash}@keyframes zombie-bob{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-2px)rotate(2deg)}}@keyframes zombie-flash{0%,to{opacity:1}50%{opacity:.6}}.hp-bar{background:#00000073;border-radius:2px;height:4px;position:absolute;bottom:2px;left:12%;right:12%;overflow:hidden;box-shadow:0 0 0 1px #0006}.hp-fill{background:linear-gradient(90deg,#ff4d4d 0%,#ffb347 40%,#6dff6d 100%);height:100%;transition:width .25s ease-out;display:block}.piece.zombie.weak .hp-bar{box-shadow:0 0 0 1px #ff4d4d,0 0 6px #ff4d4d}.zombie-board-wrap .sq{position:relative}.zombie-board-wrap .sq.capture{outline-offset:-3px;border-radius:4px;outline:3px solid #ff5050b3}.board.zombie{max-width:760px}.board.zombie .sq{font-size:calc(clamp(20px, 5vw, 40px) * var(--piece-scale,1))}.board.zombie .piece,.board.zombie .piece-img{width:calc(clamp(20px, 5vw, 44px) * var(--piece-scale,1));height:calc(clamp(20px, 5vw, 44px) * var(--piece-scale,1))}.tile-glyph{pointer-events:none;z-index:0;filter:drop-shadow(0 0 4px #0006);justify-content:center;align-items:center;font-size:70%;display:flex;position:absolute;inset:0}.sq.tile-fire{animation:.7s infinite alternate fire-flicker;box-shadow:inset 0 0 18px #ffe664bf;background:radial-gradient(circle,#ffb347 0%,#ff5e3a 55%,#b32a00 100%)!important}.tile-glyph.fire{filter:drop-shadow(0 0 6px #ffae42);font-size:140%;animation:.9s ease-in-out infinite fire-bounce}@keyframes fire-flicker{0%{box-shadow:inset 0 0 16px #ffe66499}to{box-shadow:inset 0 0 24px #ffc832f2}}@keyframes fire-bounce{0%,to{transform:scale(1)rotate(-3deg)}50%{transform:scale(1.12)rotate(3deg)}}.sq.tile-safe{animation:1.6s ease-in-out infinite safe-pulse;box-shadow:inset 0 0 16px #b4f0ffd9;background:radial-gradient(circle,#b5f0ff 0%,#6cd6ff 55%,#2a8cd8 100%)!important}.tile-glyph.safe{filter:drop-shadow(0 0 6px #6cd6ff);font-size:140%}@keyframes safe-pulse{0%,to{box-shadow:inset 0 0 12px #b4f0ff99}50%{box-shadow:inset 0 0 22px #b4f0ff}}.sq.tile-tele{box-shadow:inset 0 0 18px hsla(var(--tele-hue,270), 100%, 80%, .7);animation:2.5s linear infinite tele-spin;background:radial-gradient(circle at center, hsl(var(--tele-hue,270), 100%, 80%) 0%, hsl(var(--tele-hue,270), 90%, 55%) 55%, hsl(var(--tele-hue,270), 80%, 30%) 100%)!important}.tile-glyph.tele{filter:drop-shadow(0 0 6px hsl(var(--tele-hue,270), 100%, 80%));font-size:130%;animation:2.5s linear infinite tele-rotate}@keyframes tele-spin{0%{box-shadow:inset 0 0 12px hsla(var(--tele-hue,270), 100%, 80%, .5)}to{box-shadow:inset 0 0 28px hsla(var(--tele-hue,270), 100%, 80%, 1)}}@keyframes tele-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sq.tele-flash{animation:.6s ease-out tele-flash-anim}@keyframes tele-flash-anim{0%{filter:brightness(2.2)drop-shadow(0 0 12px #fff)}to{filter:none}}.sq.tile-ice{animation:2s ease-in-out infinite ice-shimmer;box-shadow:inset 0 0 16px #c8f0ffd9;background:radial-gradient(circle,#e8fbff 0%,#b8efff 55%,#7fc8f5 100%)!important}.tile-glyph.ice{filter:drop-shadow(0 0 6px #b8efff);font-size:140%}@keyframes ice-shimmer{0%,to{box-shadow:inset 0 0 12px #c8f0ff99}50%{box-shadow:inset 0 0 24px #c8f0ff}}.sq.tile-gold{animation:1.4s ease-in-out infinite gold-pulse;box-shadow:inset 0 0 16px #ffdc64d9;background:radial-gradient(circle,#fff4b5 0%,#ffd24a 55%,#d49510 100%)!important}.tile-glyph.gold{filter:drop-shadow(0 0 8px #ffd24a);font-size:140%}@keyframes gold-pulse{0%,to{box-shadow:inset 0 0 12px #ffdc64a6}50%{box-shadow:inset 0 0 26px #ffdc64}}.board.zombie.frozen:after{content:"";pointer-events:none;z-index:1;background:linear-gradient(135deg,#78c8ff2e,#3c96e614);position:absolute;inset:0}.zombie-board-wrap .piece{z-index:2}.zombie-board-wrap .sq.threat:after{content:"";pointer-events:none;z-index:1;background:#ff3c3c38;border:2px solid #ff3c3cd9;border-radius:6px;position:absolute;inset:5%;box-shadow:inset 0 0 12px #ff3c3c59}.zombie-board-wrap .sq.planned{box-shadow:inset 0 0 0 3px #ff4646d9,inset 0 0 22px #ff464659}.zombie-board-wrap .sq.planned:before{content:"";pointer-events:none;z-index:1;background:radial-gradient(circle,#ff5a5a8c 0%,#ff5a5a2e 60%,#0000 100%);border-radius:50%;animation:1.4s ease-in-out infinite planned-pulse;position:absolute;inset:22%}@keyframes planned-pulse{0%,to{opacity:.65;transform:scale(.85)}50%{opacity:1;transform:scale(1.05)}}.zombie-board-wrap .sq.bomb-ring:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#ffc8502e 0%,#ff503c0d 70%,#0000 100%);border-radius:50%;position:absolute;inset:14%}.zombie-board-wrap .sq.bomb-flash{animation:.7s ease-out bomb-flash-anim}@keyframes bomb-flash-anim{0%{box-shadow:inset 0 0 24px #fff,0 0 24px #ffce4a;background:radial-gradient(circle,#fff 0%,#ffce4a 30%,#ff5e3a 70%,#b32a00 100%)!important}60%{background:radial-gradient(circle,#ffd277 0%,#ff8a4a 60%,#0000 100%)!important}to{background:inherit;box-shadow:none}}.zombie-actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.zombie-actions .btn{flex:calc(50% - 4px)}.zombie-actions .btn.primary{flex:100%}.zombie-threat-btn{color:#f0d8ff;background:linear-gradient(135deg,#3a2a4a,#2a1a3a);border:1px solid #c878ff66}.zombie-threat-btn.active{color:#fff;background:linear-gradient(135deg,#8a3aaa,#6a1a8a);box-shadow:0 0 14px #c878ff8c}.zombie-bomb-btn{color:#ffe0d0;background:linear-gradient(135deg,#6a2a2a,#4a1010);border:1px solid #ff783c80}.zombie-bomb-btn:hover:not(:disabled){background:linear-gradient(135deg,#ad3a2a,#6e1010);box-shadow:0 0 14px #ff783c8c}.zombie-share-btn{color:#d8ecff;background:linear-gradient(135deg,#2a4a6a,#103048);border:1px solid #78c8ff66}.zombie-share-btn:hover:not(:disabled){background:linear-gradient(135deg,#3a7aaa,#1a5080);box-shadow:0 0 14px #78c8ff8c}.zombie-pieces-layer{pointer-events:none;z-index:4;position:absolute;inset:0}.zombie-pieces-layer .anim-piece{will-change:transform;justify-content:center;align-items:center;transition:transform .22s cubic-bezier(.32,0,.2,1);display:flex;position:absolute;top:0;left:0;transform:translate(0)}.zombie-pieces-layer .anim-piece-user{z-index:2}.zombie-pieces-layer .anim-piece.hover{z-index:3}.zombie-pieces-layer .anim-piece.hover .piece.zombie .piece-img{filter:hue-rotate(85deg)saturate(2.6)brightness(1.05)drop-shadow(0 0 10px #8cff8cf2)drop-shadow(0 1px 2px #0009)}.zombie-pieces-layer .anim-piece.fresh{animation:.45s ease-out zombie-spawn-pop}@keyframes zombie-spawn-pop{0%{opacity:0;filter:brightness(2.4)drop-shadow(0 0 18px #6dff6d)}to{opacity:1;filter:none}}.zombie-pieces-layer .anim-piece.fresh .piece.zombie .piece-img{animation:.45s cubic-bezier(.32,1.5,.4,1) zombie-spawn-scale}@keyframes zombie-spawn-scale{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}
