@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600&family=Source+Code+Pro:wght@400;600&display=swap";
:root{--bg:#0b1220;--panel:#111a2b;--panel-border:#1c2a44;--text:#e6eefc;--muted:#8ea6cc;--accent:#6bdcff;--stage1:#ff7a59;--stage2:#7bffb4}*{box-sizing:border-box}html,body{height:100%;color:var(--text);background:radial-gradient(1200px 800px at 70% 20%,#13223d 0%,#0b1220 55%,#070b14 100%);margin:0;font-family:Space Grotesk,system-ui,-apple-system,sans-serif;overflow:hidden}main{grid-template-columns:minmax(320px,420px) 1fr;gap:16px;height:100dvh;padding:16px;display:grid}.panel{border:1px solid var(--panel-border);background:linear-gradient(#111a2be6,#0d1422e6);border-radius:14px;flex-direction:column;min-height:0;padding:16px;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000059}.panel h1{margin:0 0 8px;font-size:20px}.panel input[type=range]{width:100%;margin:6px 0 12px}.meta{color:var(--muted);margin-bottom:12px;font-size:12px}.stat{border-bottom:1px solid #8ca5cc1f;justify-content:space-between;padding:6px 0;font-size:14px;display:flex}.stat:last-child{border-bottom:none}.results{flex:1;min-height:0;max-height:none;margin-top:12px;padding-right:6px;overflow:auto}.toggle-all{width:100%;color:var(--text);cursor:pointer;background:#6bdcff1f;border:1px solid #6bdcff66;border-radius:10px;margin-top:10px;margin-bottom:6px;padding:8px 10px;font-family:inherit;font-size:.9rem;line-height:1.1}.toggle-all:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{z-index:1000;background:#070b14bf;place-items:center;display:grid;position:fixed;inset:0}.modal{background:#0f172a;border:1px solid #8ca5cc33;border-radius:16px;width:min(720px,92vw);max-height:80vh;overflow:hidden;box-shadow:0 30px 80px #00000080}.modal-header{cursor:grab;border-bottom:1px solid #8ca5cc26;justify-content:space-between;align-items:center;padding:14px 16px;font-weight:600;display:flex}.modal-header:active{cursor:grabbing}.modal-header button{color:var(--text);cursor:pointer;background:0 0;border:1px solid #8ca5cc4d;border-radius:8px;padding:6px 10px}.modal-body{gap:16px;max-height:calc(80vh - 64px);padding:16px;display:grid;overflow:auto}.modal-section{background:#ffffff05;border:1px solid #8ca5cc1f;border-radius:12px;padding:12px}.modal-title{color:var(--muted);margin-bottom:8px;font-size:14px}.modal-row{border-bottom:1px solid #8ca5cc14;justify-content:space-between;padding:6px 0;font-size:13px;display:flex}.modal-row:last-child{border-bottom:none}.modal-count{color:var(--accent)}.result-item{cursor:pointer;background:#ffffff05;border:1px solid #0000;border-radius:10px;grid-template-columns:16px 1fr 20px;align-items:center;gap:10px;padding:8px;display:grid}.result-text{gap:2px;line-height:1.2;display:grid}.name-btn{color:var(--text);text-align:left;cursor:pointer;font:inherit;background:0 0;border:none;padding:0}.name-btn:hover{color:var(--accent)}.result-item+.result-item{margin-top:6px}.result-item:hover{border-color:#6bdcff66}.swatch{border:1px solid #fff6;border-radius:50%;width:14px;height:14px}.toggle{color:#fff;border:1px solid #ffffff4d;border-radius:4px;place-items:center;width:18px;height:18px;font-size:12px;display:grid}.error{color:#ffb8a0;margin-top:8px;font-size:12px}.canvas-wrap{border:1px solid var(--panel-border);border-radius:14px;height:100%;min-height:0;position:relative;overflow:hidden}.canvas-inner{position:absolute;inset:0}.label{color:#eaf4ff;white-space:nowrap;pointer-events:none;background:#080c148c;border:1px solid #ffffff26;border-radius:8px;padding:2px 6px;font-size:11px}.line-label{color:#fff;text-shadow:0 1px 6px #000000a6;pointer-events:none;background:0 0;border:none;border-radius:0;padding:0;font-size:28px;font-weight:800}.legend{color:var(--muted);align-items:center;gap:10px;margin-top:10px;font-size:12px;display:flex}.dot{border-radius:50%;width:10px;height:10px;display:inline-block}.dot.stage1{background:var(--stage1)}.dot.stage2{background:var(--stage2)}@media (max-width:980px){html,body{overflow:auto}main{grid-template-columns:1fr;height:auto}.panel{overflow:visible}.results{max-height:280px}.canvas-wrap{height:60vh;min-height:320px}}.regen-controls{justify-content:center;align-items:center;gap:12px;margin-top:12px;display:flex}.regen-label{letter-spacing:.02em;text-transform:lowercase;color:#c7d4e6;align-items:center;gap:10px;font-size:.85rem;display:inline-flex}.regen-input{color:#eef3fb;text-align:center;background:#08101ce6;border:1px solid #7bffb48c;border-radius:999px;width:44px;height:24px;padding:0 8px;font-size:.85rem}.regen-input:focus{border-color:#7bffb4;outline:none;box-shadow:0 0 0 2px #7bffb438}.regen-input::selection{background:#7bffb459}.file-button{cursor:pointer;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:12px;display:inline-flex;position:relative}.file-input{opacity:0;cursor:pointer;position:absolute;inset:0}
