:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}html,body{touch-action:none;height:100dvh;margin:0;padding:0;overflow:hidden}#root{width:100%;height:100%;margin:0;padding:0}.app{width:100vw;height:100dvh;position:relative;overflow:hidden}.color-palette{z-index:10;left:50%;bottom:max(12px, env(safe-area-inset-bottom));background:#0009;border-radius:12px;gap:5px;padding:6px 8px;display:flex;position:absolute;transform:translate(-50%)}.color-swatch{cursor:pointer;border:2px solid #ffffff4d;border-radius:8px;width:40px;height:40px;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.08)}.color-swatch.selected{border-color:#fff;transform:scale(1.1)}.validation-panel{z-index:10;background:#0009;border-radius:12px;min-width:200px;padding:16px;position:absolute;top:24px;right:24px}.color-counts{flex-direction:column;gap:6px;margin-bottom:12px;display:flex}.count-row{align-items:center;gap:8px;display:flex}.count-swatch{border:1px solid #ffffff4d;border-radius:4px;flex-shrink:0;width:18px;height:18px}.count-value{color:#fff;font-family:system-ui,sans-serif;font-size:14px}.count-error{color:#ff5858;font-weight:700}.error-list{margin-bottom:12px}.error-message{color:#ff5858;margin:4px 0;font-family:system-ui,sans-serif;font-size:12px}.solve-button{color:#fff;cursor:pointer;background:#3b8bd4;border:none;border-radius:8px;width:100%;margin-bottom:8px;padding:10px;font-size:14px;font-weight:700;transition:background .15s,opacity .15s}.solve-button:disabled{opacity:.5;cursor:not-allowed;background:#555}.solve-button:not(:disabled):hover{background:#2f73b3}.solve-result-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.solve-result-panel{color:#fff;text-align:center;background:#2a2a2a;border-radius:16px;width:90%;max-width:480px;padding:32px;font-family:system-ui,sans-serif;position:relative}.close-button{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;font-size:18px;position:absolute;top:12px;right:12px}.close-button:hover{opacity:1}.move-count{color:#999;margin-bottom:16px}.moves-list{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:16px;display:flex}.move-badge{background:#3b8bd4;border-radius:6px;padding:6px 12px;font-family:monospace;font-size:14px;font-weight:700}.error-text{color:#ff5858;margin-top:12px}.note{color:#777;margin-top:16px;font-size:13px}.tutorial-panel{text-align:center;color:#fff;z-index:20;min-width:280px;bottom:24px;left:50%;bottom:max(12px, env(safe-area-inset-bottom));background:#2a2a2a;border-radius:16px;padding:24px 32px;font-family:system-ui,sans-serif;position:absolute;transform:translate(-50%)}.step-counter{color:#999;margin-bottom:8px;font-size:13px}.next-move-button{color:#fff;cursor:pointer;background:#3b8bd4;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:700}.next-move-button:disabled{opacity:.6;cursor:not-allowed;background:#555}.next-move-button:hover:not(:disabled){background:#2f73b3}.progress-bar-track{background:#444;border-radius:2px;width:100%;height:4px;margin-bottom:16px;overflow:hidden}.progress-bar-fill{background:#3b8bd4;height:100%;transition:width .3s}.tutorial-controls{justify-content:center;gap:10px;display:flex}.nav-button,.autoplay-button{color:#fff;cursor:pointer;background:#444;border:none;border-radius:8px;padding:10px 16px;font-size:13px;font-weight:700}.nav-button:disabled,.autoplay-button:disabled{opacity:.4;cursor:not-allowed}.nav-button:hover:not(:disabled){background:#555}.autoplay-button.active{background:#3b8bd4}.autoplay-button:hover:not(:disabled){background:#2f73b3}.restart-button{color:#fff;cursor:pointer;background:#639922;border:none;border-radius:8px;margin-top:16px;padding:10px 20px;font-size:14px;font-weight:700}.restart-button:hover{background:#4f7a1b}.reset-coloring-button{color:#ccc;cursor:pointer;background:0 0;border:1px solid #555;border-radius:8px;margin-top:12px;padding:8px 16px;font-size:13px}.reset-coloring-button:hover{background:#333}.end-screen-controls{justify-content:center;gap:10px;margin-top:8px;display:flex}.move-instruction{justify-content:center;align-items:center;gap:10px;margin-bottom:4px;display:flex}.color-pastille{border:2px solid #fff6;border-radius:50%;flex-shrink:0;width:24px;height:24px}.instruction-text{color:#fff;font-size:18px;font-weight:500}.move-notation-hint{color:#777;margin-bottom:16px;font-family:monospace;font-size:13px}@media (width<=600px){.app-header{top:10px}.app-logo{font-size:18px}.app-title{font-size:15px}.validation-panel{width:94%;min-width:unset;inset:auto auto 88px 50%;bottom:calc(88px + env(safe-area-inset-bottom));padding:8px 10px;transform:translate(-50%)}.color-counts{flex-flow:wrap;justify-content:space-between;gap:4px;margin-bottom:8px}.count-row{flex-direction:column;align-items:center;gap:2px}.count-swatch{width:16px;height:16px}.count-value{font-size:10px}.solve-button,.clear-button{flex:1;width:auto;margin-top:0;padding:8px 4px;font-size:11px;display:inline-block}.validation-panel>.solve-button{width:100%;margin-bottom:6px}.validation-buttons-row{gap:6px;display:flex}.color-palette{gap:5px;padding:6px 8px;bottom:12px}.color-swatch{width:28px;height:28px}.tutorial-panel{width:92%;min-width:unset;bottom:12px;bottom:max(12px, env(safe-area-inset-bottom));padding:16px 20px}.instruction-text{font-size:15px}.tutorial-controls{flex-wrap:wrap}.nav-button,.autoplay-button{padding:8px 12px;font-size:12px}.end-screen-controls{flex-direction:column}}.clear-button{color:#ccc;cursor:pointer;background:0 0;border:1px solid #555;border-radius:8px;width:100%;margin-top:8px;padding:8px;font-size:13px}.clear-button:hover{background:#333}.app-header{z-index:30;pointer-events:none;align-items:center;gap:10px;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%)}.app-logo{font-size:28px;line-height:1}.app-title{color:#fff;text-shadow:0 2px 6px #00000080;margin:0;font-family:system-ui,sans-serif;font-size:22px;font-weight:700}@media (width<=600px){.app-header{top:10px}.app-logo{font-size:20px}.app-title{font-size:16px}}.welcome-overlay{z-index:200;background:#000000bf;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.welcome-modal{color:#fff;background:#2a2a2a;border-radius:16px;width:90%;max-width:440px;padding:32px;font-family:system-ui,sans-serif}.welcome-modal h2{text-align:center;color:#fff;margin-top:0;margin-bottom:20px}.welcome-steps{margin:0 0 24px;padding-left:20px;line-height:1.6}.welcome-steps li{margin-bottom:12px}.welcome-close-button{color:#fff;cursor:pointer;background:#3b8bd4;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:700}.welcome-close-button:hover{background:#2f73b3}@media (width<=600px){.welcome-modal{padding:24px}}.validation-buttons-row{flex-direction:column;gap:8px;display:flex}.validation-buttons-row .clear-button{margin-top:0}.ad-slot{z-index:25;pointer-events:auto;position:absolute}.ad-slot-desktop{width:160px;min-height:300px;top:80px;left:16px}.ad-slot-mobile{display:none}@media (width<=600px){.ad-slot-desktop{display:none}.ad-slot-mobile{width:90%;max-width:320px;min-height:60px;display:block;position:absolute;top:48px;left:50%;transform:translate(-50%)}}.legal-overlay{z-index:300;background:#000000bf;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.legal-modal{color:#fff;background:#2a2a2a;border-radius:16px;width:100%;max-width:600px;max-height:85vh;padding:32px;font-family:system-ui,sans-serif;position:relative;overflow-y:auto}.legal-modal h2{color:#fff;margin-top:0;margin-bottom:20px}.legal-modal h3{color:#3b8bd4;margin-top:20px;margin-bottom:6px;font-size:15px}.legal-modal section:first-of-type h3{margin-top:0}.legal-modal p{color:#ddd;margin:0 0 8px;font-size:14px;line-height:1.6}.legal-modal a{color:#3b8bd4}.legal-last-updated{color:#777;margin-top:24px;font-size:12px}@media (width<=600px){.legal-modal{padding:20px}}.legal-link{z-index:15;color:#ffffff59;cursor:pointer;background:0 0;border:none;padding:4px;font-family:system-ui,sans-serif;font-size:11px;position:absolute;bottom:4px;left:8px}.legal-link:hover{color:#ffffffb3}@media (width<=600px){.legal-link{font-size:9px;bottom:2px;left:4px}}.language-switcher{z-index:30;background:#0006;border-radius:8px;gap:4px;padding:4px;display:flex;position:absolute;top:16px;right:16px}.lang-button{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-size:12px;font-weight:600}.lang-button.active{color:#fff;background:#3b8bd4}.lang-button:hover:not(.active){color:#fff}@media (width<=600px){.language-switcher{top:8px;right:8px}.lang-button{padding:4px 8px;font-size:11px}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
