:root{--bg: #0b0c10;--panel: #14161d;--panel-2: #1b1e27;--border: #262a35;--text: #e8e8ec;--muted: #8b90a0;--accent: #6ee7b7;--accent-2: #38bdf8;--danger: #f87171;--warn: #fbbf24;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:var(--bg);color:var(--text)}#app{display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:baseline;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--border);background:var(--panel)}.brand{font-weight:700;font-size:1.15rem}.logo{font-size:1.2rem}.tagline{color:var(--muted);font-size:.85rem}.layout{display:flex;flex:1;min-height:0}.stage{flex:1;display:flex;flex-direction:column;min-width:0;padding:1rem;gap:.75rem}#stage-canvas{flex:1;min-height:0;width:100%;background:#11131a;border:1px solid var(--border);border-radius:12px;display:block}.playback{display:flex;align-items:center;gap:.75rem}.timeline{display:flex;flex-direction:column;gap:.5rem}.tl-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.tl-pick{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.35rem}.tl-info{font-size:.78rem;color:var(--muted);margin-left:auto;font-variant-numeric:tabular-nums}.tl-canvas{width:100%;height:150px;display:block;background:var(--panel);border:1px solid var(--border);border-radius:8px;touch-action:none}.seek{flex:1;accent-color:var(--accent-2)}.time{color:var(--muted);font-variant-numeric:tabular-nums;min-width:3.5rem;text-align:right}.panel{width:320px;flex-shrink:0;overflow-y:auto;border-left:1px solid var(--border);background:var(--panel);padding:1rem;display:flex;flex-direction:column;gap:1.25rem}.section h2{margin:0 0 .6rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.upload{display:flex;flex-direction:column;gap:.25rem;cursor:pointer;padding:1rem;text-align:center;border:1.5px dashed var(--border);border-radius:10px;background:var(--panel-2);transition:border-color .15s,background .15s}.upload:hover,.upload.drag{border-color:var(--accent-2);background:#1d2230}.upload-cta{font-weight:600;font-size:.9rem}.upload-hint{color:var(--muted);font-size:.75rem}.status{margin-top:.6rem;font-size:.8rem;line-height:1.4;padding:.5rem .65rem;border-radius:8px;background:var(--panel-2);color:var(--muted)}.status.idle{color:var(--muted)}.status.work{color:var(--accent-2);border-left:3px solid var(--accent-2)}.status.warm{color:var(--warn);border-left:3px solid var(--warn)}.status.ok{color:var(--accent);border-left:3px solid var(--accent)}.status.err{color:var(--danger);border-left:3px solid var(--danger)}.ctl{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.4rem .6rem;font-size:.82rem;margin-bottom:.7rem}.ctl input[type=range]{grid-column:1 / -1;accent-color:var(--accent);width:100%}.ctl output{color:var(--muted);font-variant-numeric:tabular-nums}.ctl-row{display:flex;gap:.75rem}.ctl.color{display:flex;align-items:center;gap:.4rem}.ctl.color input{inline-size:2rem;block-size:1.6rem;padding:0;border:none;background:none}.ctl.check{display:flex;align-items:center;gap:.5rem;margin-top:.6rem;cursor:pointer}.ctl.check input{accent-color:var(--accent);width:auto}.ctl.check input:disabled+span{color:var(--muted)}.select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:.25rem .4rem;font:inherit;font-size:.82rem}.hint{color:var(--muted);font-size:.72rem;margin:.35rem 0 0}.bg-row{margin-top:.7rem}.ctl-row .btn{flex:1}#btn-reset-all{width:100%;margin-top:.4rem}#stage-canvas.editing{cursor:crosshair}.btn{appearance:none;cursor:pointer;font:inherit;font-size:.85rem;padding:.5rem .9rem;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text)}.btn:hover{border-color:var(--muted)}.btn.primary{background:var(--accent);color:#04130c;border-color:var(--accent);font-weight:600;width:100%}.btn.primary:disabled{opacity:.5;cursor:not-allowed}@media(max-width:780px){.layout{flex-direction:column}.panel{width:auto;border-left:none;border-top:1px solid var(--border)}}
