:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#e2e8f0;background:radial-gradient(circle at 20% 10%,#1e293b,#0b1020 45%,#020617);line-height:1.4}*{box-sizing:border-box}body{margin:0;background:#020617}button,input,select{font:inherit}.app-shell{min-height:100dvh;display:grid;grid-template-rows:auto 1fr auto}.topbar{padding:.75rem;background:#0f172ad1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #334155;display:grid;gap:.5rem}.topbar h1{margin:0;font-size:1rem}.top-controls{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}.top-controls button{border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.5rem;padding:.35rem .7rem}.control-group{display:inline-flex;gap:.4rem;align-items:center}.controls-divider{width:1px;height:1.7rem;background:#334155;opacity:.9}.ai-dock-button{margin-left:auto;border-color:#06b6d4;background:#0ea5e9;color:#fff;font-weight:600}.status-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:.85rem}.status-row label{display:flex;align-items:center;gap:.4rem}.status-row .master-volume{min-width:14rem}.panel{padding:0;overflow:hidden;min-height:0}.workspace{display:grid;gap:.75rem;height:100%;min-height:0}.main-view{min-width:0;min-height:0;overflow:auto;padding:.75rem}.sound-column{border:1px solid #334155;background:#0b1223;border-radius:.65rem;padding:.65rem;min-height:0;overflow:auto;overflow-x:hidden}.sound-column h2{margin-top:0}.preset-select{display:grid;gap:.35rem;margin-bottom:.65rem}.preset-select span{font-size:.82rem;color:#cbd5e1}.preset-select select{border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.45rem;min-height:2rem;padding:.25rem .5rem}.osc-controls{display:grid;gap:.42rem;margin-bottom:.55rem}.osc-controls label{display:grid;grid-template-columns:4.5rem minmax(0,1fr) 2.7rem;gap:.4rem;align-items:center}.osc-controls label.waveform-row{grid-template-columns:4.5rem minmax(0,1fr)}.osc-controls select,.osc-controls input[type=range]{width:100%;min-width:0;border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.45rem}.osc-controls label span:last-child{text-align:right;font-variant-numeric:tabular-nums;font-size:.76rem}.sound-card-section{margin-bottom:.55rem}.section-toggle{width:100%;border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.45rem;min-height:2rem;padding:.3rem .55rem;text-align:center}.section-toggle.open{border-color:#06b6d4;background:#0f2233}.adsr-editor{border:1px solid #334155;border-radius:.55rem;background:#0f172a;padding:.45rem;margin-bottom:.55rem}.adsr-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.74rem;color:#cbd5e1;margin-bottom:.35rem}.adsr-svg{width:100%;height:9.6rem;display:block;touch-action:none;border-radius:.4rem}.adsr-bg{fill:#020617}.adsr-axis{stroke:#334155;stroke-width:1.4}.adsr-fill{fill:#0ea5e92e}.adsr-line{fill:none;stroke:#22d3ee;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}.adsr-hit{fill:#f8fafc;stroke:#0ea5e9;stroke-width:2;cursor:pointer}.filter-pad{border:1px solid #334155;border-radius:.55rem;background:#0f172a;padding:.45rem;margin-bottom:.55rem}.filter-pad-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.74rem;color:#cbd5e1;margin-bottom:.35rem}.filter-pad-svg{width:100%;height:9.6rem;display:block;touch-action:none;border-radius:.4rem}.filter-pad-bg{fill:#020617}.filter-axis{stroke:#334155;stroke-width:1.4}.filter-curve{fill:none;stroke:#22d3ee;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}.filter-handle{fill:#f8fafc;stroke:#0ea5e9;stroke-width:2}.mod-pads{display:grid;gap:.45rem}.mod-pad-card{border:1px solid #334155;border-radius:.55rem;background:#0f172a;padding:.35rem}.mod-pad-title{font-size:.73rem;color:#cbd5e1;margin-bottom:.25rem}.mod-pad-svg{width:100%;height:7.8rem;display:block;border-radius:.4rem;touch-action:none}.mod-pad-bg{fill:#020617}.mod-pad-axis{stroke:#334155;stroke-width:1.3}.mod-pad-cross{stroke:#22d3ee66;stroke-width:1.1}.mod-pad-handle{fill:#f8fafc;stroke:#0ea5e9;stroke-width:2}.mod-pad-label{font-size:11px;fill:#94a3b8}.timeline-row{margin-bottom:.6rem;display:grid;grid-template-columns:6rem minmax(0,1fr);gap:.45rem;align-items:center;position:relative;z-index:1}.timeline-row:last-child{margin-bottom:0}.timeline-row.muted{background:#02061761;border-radius:.4rem}.timeline-rows-wrap{position:relative}.timeline-dock{padding:.55rem .75rem .65rem;border-top:1px solid #334155;background:#0f172aeb;max-height:34dvh;overflow:auto}.timeline-controls{display:grid;gap:.4rem;margin-bottom:.6rem;padding-bottom:.1rem}.timeline-controls-left,.timeline-controls-center,.timeline-controls-right{display:flex;gap:.4rem;align-items:center;min-width:0}.timeline-controls-left{flex-wrap:nowrap;overflow-x:auto}.timeline-controls-center{justify-content:center}.timeline-controls-right{justify-content:flex-end;overflow-x:auto}.timeline-controls span{font-size:.82rem;white-space:nowrap;flex:0 0 auto}.timeline-controls label{display:flex;align-items:center;gap:.35rem;font-size:.82rem;white-space:nowrap;flex:0 0 auto}.timeline-controls select,.timeline-controls button{border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.45rem;min-height:2rem;padding:.25rem .5rem;flex:0 0 auto}.lock-active-button.on{border-color:#22d3ee;background:#083344;color:#e2e8f0}.timeline-track-label{font-size:.78rem;color:#94a3b8;text-align:left;padding-left:.2rem;white-space:nowrap;display:inline-flex;align-items:center;justify-content:flex-start;gap:.3rem}.timeline-track-label.active{color:#e2e8f0;font-weight:600}.mute-toggle{border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.35rem;min-width:1.25rem;min-height:1.25rem;padding:0;font-size:.72rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}.mute-toggle.muted{border-color:#f97316;color:#f97316}.bar-grid{overflow-x:auto;overflow-y:hidden;padding-bottom:.1rem;-ms-overflow-style:none;scrollbar-width:none}.bar-grid::-webkit-scrollbar{display:none}.bar-grid-inner{display:grid;gap:.3rem;position:relative;padding-left:.2rem;padding-right:.2rem;min-width:100%}.timeline-loop-region{position:absolute;top:-.1rem;bottom:-.1rem;left:.2rem;border-radius:.35rem;background:#22d3ee14;pointer-events:none;z-index:1}.bar-cell{min-height:1.55rem;border:1px solid #475569;border-radius:.4rem;background:#0f172a;color:#cbd5e1;font-size:.72rem;padding:.1rem .2rem;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-variant-numeric:tabular-nums}.bar-cell.active{border-color:#06b6d4;background:#083344}.bar-cell.looped{border-color:#f59e0b;box-shadow:inset 0 0 0 1px #f59e0b99}.timeline-global-sweep{position:absolute;top:0;bottom:0;width:2px;background:#22d3ee;box-shadow:0 0 10px #22d3eebf;transform:translate(-1px);pointer-events:none;z-index:4;transition:left 60ms linear}.step-grid{display:grid;gap:.35rem}.step-grid-editor{position:relative;--row-label-width: 2.8rem;--row-gap: .2rem}.editor-sweep{position:absolute;top:-.05rem;bottom:-.05rem;width:2px;background:#f97316;box-shadow:0 0 10px #f97316a6;pointer-events:none;z-index:3;transition:left 60ms linear;left:calc(var(--row-label-width) + var(--row-gap) + (var(--play-step) * ((100% - var(--row-label-width) - (16 * var(--row-gap))) / 16 + var(--row-gap))) + (((100% - var(--row-label-width) - (16 * var(--row-gap))) / 16) / 2))}.octave-shell{display:grid;gap:.35rem}.octave-shift{width:100%;border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.5rem;min-height:2.2rem;font-weight:600}.octave-shift:disabled{opacity:.45}.octave-grid-viewport{display:grid;overflow:hidden}.octave-grid-viewport .octave-layer{grid-area:1 / 1}.octave-grid-viewport.octave-transition .octave-layer{pointer-events:none}.octave-grid-viewport.octave-transition.dir-up .octave-layer.new{transform:translateY(-100%)}.octave-grid-viewport.octave-transition.dir-down .octave-layer.new{transform:translateY(100%)}.octave-grid-viewport.octave-transition.running .octave-layer{transition:transform .26s cubic-bezier(.22,.7,.2,1);will-change:transform}.octave-grid-viewport.octave-transition.running.dir-up .octave-layer.old{transform:translateY(100%)}.octave-grid-viewport.octave-transition.running.dir-up .octave-layer.new{transform:translateY(0)}.octave-grid-viewport.octave-transition.running.dir-down .octave-layer.old{transform:translateY(-100%)}.octave-grid-viewport.octave-transition.running.dir-down .octave-layer.new{transform:translateY(0)}.grid-row{display:grid;grid-template-columns:2.8rem repeat(16,minmax(0,1fr));gap:.2rem;align-items:center}.grid-row.synth-row{gap:0}.grid-row.synth-row .row-label{padding-right:.2rem}.row-label{font-size:.75rem;text-transform:none;font-weight:600}.step-cell{min-height:2rem;border:1px solid #475569;border-radius:.3rem;background:#111827;color:#e2e8f0}.step-cell.on{background:#0ea5e9;color:#fff}.synth-cell{border-color:transparent;border-radius:0;position:relative;touch-action:none}.synth-cell.note-off{background:transparent}.synth-cell.note-single,.synth-cell.note-start,.synth-cell.note-middle,.synth-cell.note-end{border-radius:0}.synth-cell.on{box-shadow:none}.synth-cell.note-start,.synth-cell.note-single{box-shadow:inset 1px 0 #0000008c}.synth-cell.note-end,.synth-cell.note-single{box-shadow:inset -1px 0 #0000008c}.synth-cell.note-single{box-shadow:inset 1px 0 #0000008c,inset -1px 0 #0000008c}.grid-row.key-white .step-cell{background:#d1d5db;border-color:#94a3b8;color:#0f172a}.grid-row.key-black .step-cell{background:#374151;border-color:#4b5563;color:#e2e8f0}.grid-row.key-c .step-cell{background:#fde68a;border-color:#f59e0b;color:#1f2937}.grid-row.key-g .step-cell{background:#c4b5fd;border-color:#8b5cf6;color:#1f2937}.grid-row.key-white .step-cell.on,.grid-row.key-black .step-cell.on,.grid-row.key-c .step-cell.on,.grid-row.key-g .step-cell.on{background:#0ea5e9;border-color:transparent;color:#fff}.grid-row.key-white .row-label{color:#d1d5db}.grid-row.key-black .row-label{color:#9ca3af}.grid-row.key-c .row-label{color:#fde68a}.grid-row.key-g .row-label{color:#c4b5fd}.grid-row.ghost-row .step-cell{opacity:.45}.grid-row.ghost-row .row-label{opacity:.55}.grid-row.ghost-row .step-cell.on{opacity:1}.sliders{display:grid;gap:.42rem}.sliders label{display:grid;grid-template-columns:4.5rem minmax(0,1fr) 2.7rem;gap:.4rem;align-items:center}.sliders label span:last-child{text-align:right;font-variant-numeric:tabular-nums;font-size:.76rem}.sliders input[type=range]{width:100%;min-width:0}.preset-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem}.ai-form{margin-top:.6rem;display:grid;grid-template-columns:1fr auto;gap:.4rem}.ai-form input{border:1px solid #475569;background:#0f172a;color:#e2e8f0;border-radius:.5rem;padding:.55rem}.candidate-list{margin-top:.7rem;display:grid;gap:.6rem}.candidate-card{background:#0f172a;border:1px solid #334155;border-radius:.6rem;padding:.7rem}.candidate-card h3{margin:0 0 .35rem}.candidate-card p{margin:0 0 .5rem;color:#94a3b8}.candidate-actions{display:flex;gap:.4rem;flex-wrap:wrap}.ai-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;border:0;background:#0206178c}.ai-sheet{position:fixed;left:0;right:0;bottom:0;z-index:31;border-top:1px solid #334155;background:#0b1223;padding:.75rem;max-height:72dvh;overflow:auto;transform:translateY(102%);transition:transform .22s ease}.ai-sheet.open{transform:translateY(0)}.ai-sheet-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.ai-sheet-header h2{margin:0}.ai-sheet-header button{border:1px solid #475569;background:#111827;color:#e2e8f0;border-radius:.45rem;padding:.3rem .6rem}@media (min-width: 900px){.app-shell{width:100%;background:#02061799}.workspace{grid-template-columns:minmax(0,1fr) 25rem;gap:0;align-items:stretch}.sound-column{border:0;border-left:1px solid #334155;border-radius:0;padding:.75rem}.timeline-dock{max-height:28dvh}.timeline-controls{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center}.ai-sheet{left:0;right:0;border-top-left-radius:.75rem;border-top-right-radius:.75rem}.preset-row{grid-template-columns:repeat(4,minmax(0,1fr))}}
