:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#172033;background:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;height:100%;margin:0}button,a{-webkit-tap-highlight-color:transparent}button{border:0;font:inherit;cursor:pointer}button:disabled{cursor:default;opacity:.42}a{color:#2563eb}.app{--accent: #2563eb;--accent-soft: #dbeafe;--accent-text: #1d4ed8;--bg: #f8fafc;--board-bg: #ffffff;--border: #d9e2ef;--grid: #172033;--muted: #eef2f7;--odd: #f1f5f9;--related: #e6edf6;--selected: #cfe2ff;--surface: #ffffff;--text: #172033;--text-muted: #64748b;--text-strong: #172033;display:grid;grid-template-rows:58px auto minmax(0,1fr) auto 28px;height:100%;overflow:hidden;color:var(--text);background:var(--bg)}.app.dark{--accent: #60a5fa;--accent-soft: #1f416a;--accent-text: #bfdbfe;--bg: #111827;--board-bg: #1f2937;--border: #475569;--grid: #d5dfed;--muted: #273449;--odd: #273449;--related: #334155;--selected: #1d4f91;--surface: #1f2937;--text: #f8fafc;--text-muted: #cbd5e1;--text-strong: #f8fafc}.topbar{grid-row:1;position:relative;display:flex;align-items:center;justify-content:space-between;min-width:0;padding:0 14px;border-bottom:1px solid var(--border);background:var(--bg)}.brand,.topbar-actions,.timer,.notice,.zoom-tools,.tool-row,.error-count,.legal-footer,.privacy-title,.back-link,.settings-warning,.more-button,.inline-stepper,.stepper,.segment button{display:flex;align-items:center}.brand{min-width:0;gap:8px;font-size:17px;font-weight:900}.brand img{width:30px;height:30px;border-radius:6px}.timer{position:absolute;left:50%;gap:5px;color:var(--text-muted);font-size:14px;font-variant-numeric:tabular-nums;font-weight:800;transform:translate(-50%)}.topbar-actions{gap:2px}.icon-button{display:inline-grid;width:38px;height:38px;place-items:center;border-radius:50%;color:var(--text-muted);background:transparent}.icon-button:not(:disabled):hover{color:var(--accent);background:var(--muted)}.notice{grid-row:2;gap:8px;padding:8px 14px;border-bottom:1px solid transparent;color:#713f12;font-size:13px;line-height:1.35;background:#fef3c7}.notice.error{color:#991b1b;background:#fee2e2}.notice span{flex:1}.notice button{display:grid;flex:0 0 auto;width:28px;height:28px;place-items:center;color:currentColor;background:transparent}.game-shell{position:relative;grid-row:3;min-height:0}.board-stage,.board-viewport{width:100%;height:100%}.board-stage{position:relative;padding:10px 14px}.board-viewport{position:relative;overflow:hidden;border:1px solid var(--border);border-radius:4px;background:var(--bg);touch-action:none;-webkit-user-select:none;user-select:none}.board{position:absolute;top:50%;left:50%;display:grid;transform-origin:center;background:var(--board-bg);will-change:transform}.cell{position:relative;display:grid;width:42px;height:42px;place-items:center;overflow:visible;background:var(--board-bg)}.cell.inactive{background:var(--bg)}.cell.related{background:var(--related)}.cell.odd{background:var(--odd)}.cell.selected{background:var(--selected)}.color-value{display:grid;width:32px;height:32px;place-items:center;border:1px solid rgba(255,255,255,.58);border-radius:5px;color:#fff;font-size:15px;font-weight:900}.number-value{position:relative;z-index:8;font-size:22px;font-weight:800;line-height:1}.number-value b{position:absolute;top:50%;left:50%;color:#dc26268c;font-size:21px;transform:translate(-50%,-50%)}.notes-grid{display:grid;width:100%;height:100%;padding:3px;font-size:8px;font-style:normal;font-weight:700}.notes-grid i{display:grid;place-items:center;font-style:normal}.grid-lines,.constraint-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.grid-lines{z-index:20}.grid-line{position:absolute;background:var(--grid)}.grid-line.horizontal{height:var(--thickness);transform:translateY(calc(var(--thickness) / -2))}.grid-line.vertical{width:var(--thickness);transform:translate(calc(var(--thickness) / -2))}.constraint-layer{z-index:30}.greater-marker{position:absolute;z-index:31}.greater-marker i{position:absolute;display:block;background:var(--grid);transform-origin:0 50%}.cage-border{position:absolute;z-index:5;top:3px;right:3px;bottom:3px;left:3px;pointer-events:none}.cage-border i{position:absolute;border-color:#466382;border-style:dashed}.cage-border .top,.cage-border .bottom{right:0;left:0;border-top-width:1px}.cage-border .top{top:0}.cage-border .bottom{bottom:0}.cage-border .left,.cage-border .right{top:0;bottom:0;border-left-width:1px}.cage-border .left{left:0}.cage-border .right{right:0}.cage-border em{position:absolute;z-index:6;top:-2px;left:2px;padding:0 2px;color:#466382;font-size:9px;font-style:normal;font-weight:900;line-height:10px;background:inherit}.consecutive{position:absolute;z-index:35;border-radius:3px;background:#16a34a}.consecutive.vertical{top:13px;right:-3px;width:6px;height:16px}.consecutive.horizontal{bottom:-3px;left:13px;width:16px;height:6px}.zoom-tools{position:absolute;right:22px;bottom:18px;gap:2px;padding:3px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:0 3px 10px #0f172a1f}.zoom-tools .icon-button{width:32px;height:32px}.zoom-value{min-width:46px;padding:0 3px;color:var(--text-muted);font-size:11px;font-weight:900;background:transparent}.solved-banner{position:absolute;bottom:22px;left:50%;z-index:50;padding:8px 12px;border-radius:6px;color:#fff;font-weight:900;background:#16a34a;transform:translate(-50%)}.controls{grid-row:4;padding:8px 14px 9px;border-top:1px solid var(--border);background:var(--surface)}.tool-row{justify-content:center;gap:5px;margin-bottom:7px}.tool-button{display:grid;min-width:58px;gap:3px;place-items:center;padding:5px 7px;border-radius:6px;color:var(--text-muted);font-size:10px;font-weight:800;background:transparent}.tool-button:not(:disabled):hover,.tool-button.active{color:var(--accent-text);background:var(--accent-soft)}.error-count{justify-content:center;gap:4px;margin:0 0 5px;color:var(--text-muted);font-size:12px;font-weight:800}.palette{display:flex;flex-wrap:wrap;justify-content:center;max-width:820px;margin:0 auto}.palette-key{display:grid;width:min(10%,54px);min-width:38px;aspect-ratio:1;padding:3px;place-items:stretch;background:transparent}.palette-key span,.palette-key b{display:grid;place-items:center;border:1px solid var(--border);border-radius:6px;font-size:20px;font-weight:900;background:var(--muted)}.palette-key span{border-color:#ffffff8c}.legal-footer{grid-row:5;justify-content:space-between;padding:0 14px;color:var(--text-muted);font-size:11px;background:var(--bg)}.modal-backdrop,.loading-overlay{position:fixed;z-index:100;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a75}.settings-panel{display:grid;grid-template-rows:auto minmax(0,1fr) auto;width:min(96vw,460px);max-height:min(94vh,820px);overflow:hidden;border-radius:8px;color:var(--text);background:var(--surface);box-shadow:0 18px 55px #0f172a47}.settings-panel header,.settings-panel footer{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;border-bottom:1px solid var(--border)}.settings-panel footer{justify-content:stretch;border-top:1px solid var(--border);border-bottom:0}.settings-panel h2{margin:0;font-size:18px}.settings-scroll{overflow-y:auto;padding:4px 12px 12px}.settings-title{justify-content:space-between;min-height:33px;margin-top:5px}.settings-title h3{margin:0;color:var(--accent);font-size:13px;font-weight:900}.chip-grid{display:flex;flex-wrap:wrap;gap:6px}.chip-grid.extra{margin-top:6px}.chip{padding:7px 10px;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:800;background:var(--muted)}.chip.active{border-color:var(--accent);color:var(--accent-text);background:var(--accent-soft)}.settings-warning{align-items:flex-start;gap:5px;margin:7px 0 0;color:#b45309;font-size:12px;line-height:1.35}.more-button{gap:2px;min-height:30px;color:var(--accent);font-size:12px;font-weight:900;background:transparent}.toggle{position:relative;display:flex;align-items:center;justify-content:space-between;min-height:36px;color:var(--text-strong);font-size:14px;font-weight:700;cursor:pointer}.toggle input{position:absolute;opacity:0}.toggle i{position:relative;width:34px;height:20px;border-radius:10px;background:var(--border)}.toggle i:after{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;content:"";transition:transform .15s ease}.toggle input:checked+i{background:var(--accent)}.toggle input:checked+i:after{transform:translate(14px)}.segment{display:flex;gap:2px;padding:3px;border-radius:7px;background:var(--muted)}.segment button{flex:1;justify-content:center;gap:5px;padding:7px 8px;border-radius:5px;color:var(--text-muted);font-size:13px;font-weight:800;background:transparent}.segment button.active{color:var(--accent-text);background:var(--surface)}.stepper{justify-content:center}.stepper b{min-width:50px;text-align:center;color:var(--text-strong);font-size:19px;font-variant-numeric:tabular-nums}.inline-stepper{justify-content:space-between;color:var(--text-strong);font-size:14px;font-weight:700}.inline-stepper .stepper b{min-width:28px}.primary-button{width:100%;padding:10px 14px;border-radius:6px;color:#fff;font-size:14px;font-weight:900;background:#2563eb}.loading-overlay{z-index:120;gap:8px;color:#1d4ed8;background:#ffffffbd}.spin{animation:spin .9s linear infinite}.privacy-page{min-height:100%;color:#1e293b;background:#f8fafc}.privacy-header,.privacy-content{width:min(100% - 32px,850px);margin:0 auto}.privacy-header{padding:22px 0 14px;border-bottom:1px solid #d9e2ef}.back-link{gap:5px;color:#2563eb;font-size:13px;font-weight:800;text-decoration:none}.privacy-title{gap:10px;margin-top:22px;color:#1d4ed8}.privacy-title p,.privacy-title h1{margin:0}.privacy-title p{color:#64748b;font-size:13px;font-weight:800}.privacy-title h1{color:#172033;font-size:30px}.privacy-date{margin:8px 0 0;color:#64748b;font-size:13px}.privacy-content{padding:12px 0 40px}.privacy-content section{padding:12px 0;border-bottom:1px solid #e5ebf3}.privacy-content h2{margin:0 0 6px;color:#172033;font-size:18px}.privacy-content p{margin:0 0 8px;color:#475569;font-size:14px;line-height:1.65}.privacy-content a{display:inline-flex;align-items:center;gap:3px}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:900px){.app{grid-template-rows:62px auto minmax(0,1fr) auto 28px}.topbar,.controls,.legal-footer{padding-right:22px;padding-left:22px}.board-stage{padding:14px 22px}}@media(max-width:520px){.brand span{max-width:116px;overflow:hidden;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.brand img{width:26px;height:26px}.timer{font-size:12px}.board-stage{padding:7px 8px}.zoom-tools{right:14px;bottom:13px}.controls{padding:5px 8px 6px}.tool-row{gap:1px;margin-bottom:4px}.tool-button{min-width:54px;padding:4px 2px;font-size:9px}.palette-key{min-width:34px;padding:2px}.palette-key span,.palette-key b{font-size:17px}.legal-footer{padding:0 8px}}
