:root{--bg: #1a1b1f;--panel: #22242a;--panel-border: #2e3138;--text: #d8dde3;--text-dim: #8a8f99;--dot: #8b939b;--line: #4fb3f0;--danger: #e0664b}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Inter,system-ui,sans-serif;font-size:14px;overflow:hidden;-webkit-font-smoothing:antialiased}#app{display:grid;grid-template-columns:260px 1fr;height:100vh;width:100vw}.sidebar{background:var(--panel);border-right:1px solid var(--panel-border);padding:22px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.sidebar__header h1{margin:0 0 6px;font-size:18px;font-weight:600;letter-spacing:.2px}.sidebar__sub{margin:0;color:var(--text-dim);font-size:12px;line-height:1.5}.control{display:flex;flex-direction:column;gap:8px}.control label{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--text-dim)}.control__value{color:var(--text);font-variant-numeric:tabular-nums;font-weight:500}.control--row{flex-direction:row;align-items:center;justify-content:space-between}.control--row label{color:var(--text-dim)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:#34373f;border-radius:999px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text);cursor:pointer;border:2px solid var(--panel);box-shadow:0 0 0 1px #34373f;transition:transform .12s ease}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text);cursor:pointer;border:2px solid var(--panel)}input[type=color]{width:44px;height:28px;border:none;border-radius:6px;background:transparent;cursor:pointer;padding:0}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:1px solid #34373f;border-radius:6px}.actions{display:flex;gap:8px;margin-top:4px}.btn{flex:1;padding:8px 12px;border-radius:8px;border:1px solid #34373f;background:transparent;color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background .12s ease,border-color .12s ease}.btn:hover{background:#2a2d34}.btn--ghost{color:var(--text-dim)}.btn--danger{border-color:#4a2a26;color:var(--danger)}.btn--full{width:100%;margin-top:8px}.btn--danger:hover{background:#2e1f1d}.sound{border-top:1px solid var(--panel-border);padding-top:16px}.toggle{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--text);cursor:pointer}.toggle input{width:14px;height:14px;accent-color:var(--line);cursor:pointer;margin:0}.sidebar__footer{margin-top:auto}.hint{margin:0;font-size:11px;color:var(--text-dim);line-height:1.5}.canvas-wrap{position:relative;overflow:hidden}#canvas{display:block;width:100%;height:100%;cursor:crosshair;-webkit-user-select:none;user-select:none;touch-action:none}.dot{fill:var(--dot);transition:fill .18s ease,r .18s ease}.dot--near{fill:#b8bec7}.dot--flash{animation:dot-flash .5s ease-out}@keyframes dot-flash{0%{fill:#fff;filter:drop-shadow(0 0 6px rgba(255,255,255,.9))}to{fill:var(--dot);filter:drop-shadow(0 0 0 rgba(255,255,255,0))}}.path-stroke{fill:none;stroke-linejoin:round;stroke-linecap:round;pointer-events:none}.path-stroke--live{opacity:.95}.path-stroke--committed{animation:draw-in .35s ease-out}.path-hit{fill:none;stroke:transparent;stroke-width:24;stroke-linejoin:round;stroke-linecap:round;pointer-events:stroke;cursor:pointer}.path-stroke--playing{animation:playing-pulse 1.7s ease-in-out infinite}@keyframes playing-pulse{0%,to{opacity:1}50%{opacity:.55}}.playhead{stroke:#fff;pointer-events:none;opacity:0;transition:opacity .25s ease}.playhead--on{opacity:1}@keyframes draw-in{0%{stroke-dasharray:var(--dash, 2000);stroke-dashoffset:var(--dash, 2000);opacity:0}to{stroke-dasharray:var(--dash, 2000);stroke-dashoffset:0;opacity:1}}.start-marker{fill:none;stroke-width:2;opacity:0;transition:opacity .15s ease}.start-marker--show{opacity:.8}
