*{box-sizing:border-box}:root,body[data-theme=light]{--bg:#f3f1ec;--text:#2b2b2b;--muted:#6b6b6b;--btn-bg:#2b2b2b;--btn-text:#fff;--btn-hover:#444;--input-bg:#fff;--input-border:#c8c4bb;--board-line:#2b2b2b;--board-grid:#0000002e}body[data-theme=dark]{--bg:#1c1c20;--text:#e8e6e1;--muted:#a3a09a;--btn-bg:#e8e6e1;--btn-text:#1c1c20;--btn-hover:#cfccc5;--input-bg:#2a2a30;--input-border:#4a4a52;--board-line:#15151a;--board-grid:#0000004d}body{background:var(--bg);color:var(--text);justify-content:center;margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;transition:background .2s,color .2s;display:flex}.app{text-align:center;max-width:640px;padding:24px 16px 48px}.titlebar{justify-content:center;align-items:center;gap:12px;display:flex}h1{margin:0 0 4px;font-size:2.2rem}.crown{color:#b8860b}.icon-button{border:1px solid var(--input-border);background:var(--input-bg);cursor:pointer;border-radius:50%;width:38px;height:38px;font-size:1.1rem;line-height:1}.rules{color:var(--muted);margin:0 0 20px;font-size:.95rem}.controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-bottom:12px;display:flex}.controls.secondary{color:var(--muted);margin-bottom:20px}.controls label{align-items:center;gap:6px;font-weight:600;display:flex}.controls .toggle{cursor:pointer;font-weight:500}.controls input[type=number]{border:1px solid var(--input-border);background:var(--input-bg);width:60px;color:var(--text);border-radius:6px;padding:6px 8px;font-size:1rem}.controls select{border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);cursor:pointer;border-radius:6px;padding:6px 8px;font-size:1rem}.controls button{background:var(--btn-bg);color:var(--btn-text);cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:.95rem}.controls button:hover:not(:disabled){background:var(--btn-hover)}.controls button:disabled{opacity:.5;cursor:default}.timer{font-variant-numeric:tabular-nums;min-width:48px;font-weight:600}.view-tabs{background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;gap:4px;margin-bottom:18px;padding:4px;display:inline-flex}.view-tabs button{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px 16px;font-size:.9rem}.view-tabs button.active{background:var(--btn-bg);color:var(--btn-text)}.viz{--viz-empty:#e3e0d9}.viz-steps{flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:18px;display:flex}.viz-step{border:1px solid var(--input-border);background:var(--input-bg);color:var(--text);cursor:pointer;border-radius:999px;padding:6px 12px;font-size:.85rem;transition:background .15s}.viz-step:hover{border-color:var(--board-line)}.viz-step.active{background:var(--btn-bg);color:var(--btn-text);border-color:var(--btn-bg)}.viz-board{aspect-ratio:1;--n:12;width:min(88vw,540px);margin:0 auto;display:grid}.viz-cell{min-width:0;min-height:0;font-size:calc(min(88vw, 540px) / var(--n) * .55);color:#2b2b2b;justify-content:center;align-items:center;line-height:1;display:flex;overflow:hidden}.viz-cell.changed{box-shadow:inset 0 0 0 3px #c0182b}.viz-info{max-width:540px;margin:16px auto 0}.viz-stat{font-variant-numeric:tabular-nums;margin:0 0 6px;font-weight:700}.viz-blurb{color:var(--muted);margin:6px 0 0;font-size:.92rem;line-height:1.5}.spark{color:#c0182b;margin:4px auto 8px;display:block}.viz-nav{justify-content:center;align-items:center;gap:16px;margin-top:16px;display:flex}.viz-nav button{background:var(--btn-bg);color:var(--btn-text);cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:.9rem}.viz-nav button:disabled{opacity:.4;cursor:default}.viz-progress{font-variant-numeric:tabular-nums;color:var(--muted);min-width:48px}.board{--cell:calc(59px - var(--n) * 1.25px);width:min(88vw, calc(var(--n) * var(--cell)));aspect-ratio:1;-webkit-user-select:none;user-select:none;margin:0 auto;display:grid}.cell{appearance:none;min-width:0;min-height:0;font-size:calc(min(88vw / var(--n), var(--cell)) * .55);cursor:pointer;color:#2b2b2b;justify-content:center;align-items:center;margin:0;padding:0;line-height:1;display:flex;overflow:hidden}.cell.conflict{color:#c0182b;background-image:repeating-linear-gradient(45deg,#c0182b26 0 4px,#0000 4px 8px)!important}.banner{border-radius:8px;margin-top:18px;padding:12px;font-weight:600}.banner.solved{color:#1d6b2f;background:#d8f0d3}.banner.revealed{color:#4a3d8f;background:#e8e4f5}.error{color:#c0182b;font-weight:600}
