:root{color:#eef1f5;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#101114;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:#101114;min-width:320px;min-height:100vh;margin:0}button,textarea{font:inherit}button{border:0}#app{min-height:100svh}main{flex-direction:column;min-height:100svh;display:flex}.topbar{background:#15161a;border-bottom:1px solid #303238;justify-content:space-between;align-items:center;gap:18px;padding:18px 24px;display:flex}.eyebrow{color:#8f98a8;text-transform:uppercase;margin:0 0 4px;font-size:12px;font-weight:700}h1,h2,p{margin:0}h1{color:#f6f7f9;font-size:24px;font-weight:760;line-height:1.2}h2{color:#f6f7f9;font-size:18px;line-height:1.25}.topbar button{color:#06140b;cursor:pointer;background:#46b06f;border-radius:8px;flex:none;min-width:112px;padding:12px 16px;font-weight:800}.topbar button:hover:not(:disabled){background:#61c083}.topbar button:disabled{cursor:default;opacity:.55}.brief{background:#303238;border-bottom:1px solid #303238;grid-template-columns:1.4fr 1.2fr 160px;gap:1px;display:grid}.brief>div{background:#1b1c21;flex-direction:column;gap:6px;min-width:0;padding:14px 18px;display:flex}.brief strong{color:#8f98a8;font-size:12px}.brief span{color:#e5e8ed;font-size:14px;line-height:1.4}.workspace{flex:1;grid-template-columns:minmax(420px,1fr) minmax(480px,1fr);min-height:0;display:grid}.visualizer{background:#202126;flex-direction:column;gap:14px;min-width:0;padding:18px;display:flex}.panel-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.panel-header p{color:#9aa3b2;margin-top:5px;font-size:14px}.score{background:#17181d;border:1px solid #3d414a;border-radius:8px;align-items:baseline;gap:4px;padding:8px 12px;display:flex}.score span{color:#f4c430;font-size:30px;font-weight:850;line-height:1}.score small{color:#9aa3b2}.status-line{color:#cfd5df;grid-template-columns:120px 1fr;align-items:center;gap:12px;font-size:14px;display:grid}.progress{background:#111217;border:1px solid #303238;border-radius:999px;height:10px;overflow:hidden}.progress div{background:#46b06f;height:100%}.error{color:#ffb1b1;background:#8e3a3a2e;border:1px solid #8e3a3a;border-radius:8px;padding:10px 12px;font-size:14px}.board-wrap{background:#15161a;border:1px solid #303238;border-radius:8px;flex:1;place-items:center;min-height:0;padding:18px;display:grid}.grid{aspect-ratio:1;background:#343740;border-radius:8px;gap:3px;width:min(100%,560px);padding:3px;display:grid}.cell{color:#edf2f7;-webkit-user-select:none;user-select:none;border-radius:4px;place-items:center;min-width:0;min-height:0;font-size:clamp(11px,1.5vw,15px);font-weight:800;display:grid}.cell span{font-size:12px;font-weight:900}.placements{color:#dce2eb;background:#17181d;border:1px solid #303238;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;display:flex}.placements strong{color:#8f98a8}.empty{color:#9aa3b2}@media (width<=900px){.topbar{flex-direction:column;align-items:stretch;padding:16px}.brief,.workspace,.status-line{grid-template-columns:1fr}}.loading-screen{background:#101114;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.loader{border:4px solid #303238;border-top-color:#46b06f;border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-screen h2{color:#f6f7f9;font-size:20px}.loading-screen p{color:#8f98a8;font-size:14px}.stage-select-screen{background:#101114;flex-direction:column;flex:1;width:100%;max-width:1200px;margin:0 auto;padding:40px;display:flex}.stage-select-header{margin-bottom:32px}.stage-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.stage-card{text-align:left;cursor:pointer;color:#eef1f5;background:#1b1c21;border:1px solid #303238;border-radius:12px;flex-direction:column;align-items:flex-start;padding:24px;transition:transform .2s,border-color .2s;display:flex}.stage-card:hover{border-color:#46b06f;transform:translateY(-4px)}.stage-card h2{color:#f6f7f9;margin-bottom:8px;font-size:20px}.stage-card p{color:#9aa3b2;flex:1;margin-bottom:16px;font-size:14px;line-height:1.4}.stage-meta{color:#8f98a8;background:#15161a;border-radius:6px;gap:16px;width:100%;padding:8px 12px;font-size:13px;display:flex}.empty-stages{color:#8f98a8;font-size:15px}.topbar-actions{gap:12px;display:flex}.btn-secondary{color:#eef1f5!important;background:#303238!important}.btn-secondary:hover{background:#40424a!important}.editor-container.svelte-1h8xysy{color:#d8dee9;background:#17181d;border-right:1px solid #303238;flex-direction:column;flex:1;min-width:0;padding:18px;display:flex}.editor-title.svelte-1h8xysy{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.editor-title.svelte-1h8xysy span:where(.svelte-1h8xysy){color:#9aa3b2;border:1px solid #3b3e46;border-radius:6px;padding:4px 8px;font-size:12px}textarea.svelte-1h8xysy{min-height:420px;color:inherit;resize:none;background:#0f1014;border:1px solid #303238;border-radius:8px;outline:none;flex:1;padding:16px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;line-height:1.6}textarea.svelte-1h8xysy:focus{border-color:#61c083;box-shadow:0 0 0 3px #61c08324}h2.svelte-1h8xysy{margin:0;font-size:18px}@media (width<=900px){.editor-container.svelte-1h8xysy{border-bottom:1px solid #303238;border-right:0}textarea.svelte-1h8xysy{min-height:360px}}
