:root{--bg:#0f1419;--bg-2:#161c24;--bg-3:#1f2630;--ink:#e6e8eb;--ink-dim:#8b96a3;--ink-faint:#5a6573;--rule:#28303a;--accent:#7aa2f7;--accent-2:#b4c4f0}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,monospace;font-weight:400}body{background-image:radial-gradient(80% 60% at 50% 0,#7aa2f70f,#0000 60%),radial-gradient(60% 40% at 100% 100%,#5078ff0d,#0000 60%);min-height:100vh}a{color:var(--accent)}h1{letter-spacing:-.035em;margin:0 0 1.25rem;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:clamp(3rem,8vw,5rem);font-weight:600;line-height:1}h1 .word{display:inline}h1 .w1{color:var(--ink)}h1 .w2{color:var(--accent);font-weight:600}.lede{color:var(--ink-dim);margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:1rem;line-height:1.6}.topbar{border-bottom:1px solid var(--rule);justify-content:space-between;align-items:center;max-width:760px;margin:0 auto;padding:1.25rem 1.75rem;display:flex}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:space-between;width:22px;height:16px;padding:0;display:flex}.hamburger span{background:var(--ink-dim);border-radius:1px;width:100%;height:1.5px;transition:background .12s;display:block}.hamburger:hover span{background:var(--ink)}.brand{color:var(--ink);align-items:center;gap:.6rem;font-weight:500;text-decoration:none;display:inline-flex}.brand-logo{object-fit:contain;border-radius:3px;flex-shrink:0;width:24px;height:24px}.brand-name{letter-spacing:.02em;font-size:.95rem}.spectrum-bar{opacity:.85;z-index:10;background:linear-gradient(270deg,#850085 0%,#00f 14%,#0ff 28%,#0f0 42%,#ff0 56%,red 84%,#850000 100%);width:100%;height:3px;position:sticky;top:0}.sidebar-backdrop{opacity:0;pointer-events:none;z-index:50;background:#00000080;transition:opacity .22s;position:fixed;inset:0}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.sidebar{background:var(--bg-2);border-right:1px solid var(--rule);z-index:60;flex-direction:column;width:280px;max-width:85vw;height:100vh;transition:transform .24s cubic-bezier(.25,.8,.3,1);display:flex;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 8px 40px #0006}.sidebar.open{transform:translate(0)}.sidebar-header{border-bottom:1px solid var(--rule);justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;display:flex}.sidebar-title{letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);font-size:.7rem}.sidebar-close{color:var(--ink-dim);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.6rem;line-height:1;transition:color .12s;display:flex}.sidebar-close:hover{color:var(--ink)}.sidebar-nav{flex-direction:column;flex:1;padding:1rem 0;display:flex;overflow-y:auto}.sidebar-link{color:var(--ink-dim);letter-spacing:.05em;border-left:2px solid #0000;align-items:center;gap:.75rem;padding:.85rem 1.5rem;font-size:.9rem;text-decoration:none;transition:color .12s,background .12s,border-color .12s;display:flex}.sidebar-link:hover{color:var(--ink);background:var(--bg-3)}.sidebar-link.active{color:var(--accent);background:var(--bg-3);border-left-color:var(--accent)}.sidebar-link-bullet{color:var(--ink-faint);font-size:.7rem;transition:color .12s}.sidebar-link.active .sidebar-link-bullet{color:var(--accent)}.sidebar-section{flex-direction:column;display:flex}.sidebar-section+.sidebar-section{border-top:1px solid var(--rule);margin-top:.75rem;padding-top:.75rem}.sidebar-section-title{letter-spacing:.25em;text-transform:uppercase;color:var(--ink-faint);padding:.4rem 1.5rem;font-size:.65rem}.shell{max-width:760px;margin:0 auto;padding:4rem 1.75rem 6rem}.masthead{margin-bottom:3.5rem}.footer{border-top:1px solid var(--rule);letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:3rem;padding-top:1.5rem;font-size:.65rem;display:flex}.footer .dot{opacity:.5}.footer-link{color:var(--ink-faint);border-bottom:1px solid #0000;text-decoration:none;transition:color .12s,border-color .12s}.footer-link:hover{color:var(--accent);border-bottom-color:var(--accent)}.footer-theme{opacity:.5;align-items:center;gap:.4rem;margin-left:auto;transition:opacity .16s;display:inline-flex}.footer-theme:hover{opacity:1}.footer-theme input[type=color]{appearance:none;border:1px solid var(--rule);cursor:pointer;background:0 0;border-radius:50%;width:18px;height:18px;padding:0;overflow:hidden}.footer-theme input[type=color]::-webkit-color-swatch-wrapper{padding:0}.footer-theme input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}.footer-theme button{color:var(--ink-faint);cursor:pointer;background:0 0;border:none;padding:0 .2rem;font-size:.85rem;line-height:1}.footer-theme button:hover{color:var(--ink)}.panel{background:var(--bg-2);border:1px solid var(--rule);border-radius:2px;margin-bottom:1.25rem;padding:1.75rem 1.75rem 2rem;position:relative}.panel p{color:var(--ink-dim);margin:0;font-size:.95rem;line-height:1.65}.panel p+p{margin-top:.9rem}.panel-title{letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);align-items:baseline;gap:.75rem;margin:0 0 1.5rem;font-size:.75rem;font-weight:500;display:flex}.panel-title .num{color:var(--accent);font-weight:500}.btn{color:#0a1020;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:none;border-radius:2px;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:500;text-decoration:none;transition:transform .12s,background .12s;display:inline-flex}.btn:hover:not(:disabled){background:var(--accent-2);transform:translateY(-1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-arrow{font-size:1rem}.btn-secondary{color:var(--ink);border:1px solid var(--rule);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--bg-3);border-color:var(--ink-faint)}.icon-btn{border:1px solid var(--rule);width:22px;height:22px;color:var(--ink-dim);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.85rem;line-height:1;transition:color .12s,border-color .12s;display:inline-flex}.icon-btn:hover:not(:disabled){color:var(--ink);border-color:var(--ink-faint)}.icon-btn-danger:hover:not(:disabled){color:#ff7070;border-color:#ff7070}.icon-btn:disabled{opacity:.3;cursor:not-allowed}.circle-btn{border:1px dashed var(--rule);width:32px;height:32px;color:var(--ink-dim);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.2rem;font-weight:300;line-height:1;transition:color .12s,border-color .12s;display:inline-flex}.circle-btn:hover{color:var(--accent);border-color:var(--accent)}.circle-btn-large{width:40px;height:40px;font-size:1.3rem}.dropzone{border:1px dashed var(--rule);cursor:pointer;text-align:left;border-radius:2px;padding:2.25rem 1.5rem;transition:border-color .16s,background .16s,transform .16s;display:block}.dropzone:hover{border-color:var(--ink-faint);background:var(--bg-3)}.dropzone.drag{border-color:var(--accent);background:#7aa2f70d}.dropzone.has-file{border-style:solid;border-color:var(--accent)}.dropzone-inner{align-items:center;gap:1.25rem;display:flex}.dz-icon{color:var(--accent);background:#7aa2f71a;border-radius:50%;flex-shrink:0;place-items:center;width:3rem;height:3rem;font-size:2rem;display:grid}.dz-text{flex-direction:column;gap:.35rem;min-width:0;display:flex}.dz-primary{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:500;overflow:hidden}.dz-secondary{color:var(--ink-faint);letter-spacing:.08em;font-size:.7rem}.form{flex-direction:column;gap:1rem;display:flex}.controls{border-top:1px solid #ffffff14;margin-top:1.5rem;padding-top:1.25rem}.controls-summary{cursor:pointer;text-transform:uppercase;letter-spacing:.15em;color:var(--ink-dim);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.8rem;list-style:none;display:flex}.controls-summary::-webkit-details-marker{display:none}.controls-chevron{transition:transform .2s}.controls[open] .controls-chevron{transform:rotate(90deg)}.controls[open] .controls-summary{margin-bottom:.6rem}.controls-hint{opacity:.55;margin:0 0 1.2rem;font-size:.85rem}.control{margin-bottom:1.1rem}.control label{cursor:pointer;margin-bottom:.35rem;display:block}.control-name{font-size:.92rem;font-weight:500;display:block}.control-desc{opacity:.55;margin-top:.1rem;font-size:.8rem;line-height:1.4;display:block}.control-row{align-items:center;gap:.85rem;display:flex}.control-row input[type=range]{appearance:none;cursor:pointer;background:0 0;flex:1;height:22px}.control-row input[type=range]::-webkit-slider-runnable-track{background:var(--bg-3);border-radius:2px;height:4px}.control-row input[type=range]::-moz-range-track{background:var(--bg-3);border-radius:2px;height:4px}.control-row input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);width:8px;height:18px;box-shadow:0 0 0 2px var(--bg-2);border:none;border-radius:4px;margin-top:-7px}.control-row input[type=range]::-moz-range-thumb{background:var(--accent);width:8px;height:18px;box-shadow:0 0 0 2px var(--bg-2);border:none;border-radius:4px}.control-row output{text-align:right;opacity:.85;min-width:3.5ch;font-size:.85rem}.switch-label{cursor:pointer;grid-template-columns:auto 1fr;align-items:start;column-gap:.75rem;display:grid}.switch-label input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.switch-track{background:var(--bg-3);border:1px solid var(--rule);border-radius:999px;flex-shrink:0;grid-row:1/span 2;width:40px;height:22px;margin-top:.15rem;transition:background .16s,border-color .16s;position:relative}.switch-track:after{content:"";background:var(--ink-dim);border-radius:50%;width:16px;height:16px;transition:transform .16s,background .16s;position:absolute;top:2px;left:2px}.switch-label input[type=checkbox]:checked~.switch-track{background:var(--accent);border-color:var(--accent)}.switch-label input[type=checkbox]:checked~.switch-track:after{background:#fff;transform:translate(18px)}.switch-label input[type=checkbox]:focus-visible~.switch-track{outline:2px solid var(--accent);outline-offset:2px}.switch-label .control-name,.switch-label .control-desc{grid-column:2}.progress-track{background:var(--bg-3);height:4px;margin-bottom:.85rem;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));width:0%;height:100%;transition:width .32s}.progress-meta{letter-spacing:.1em;color:var(--ink-dim);text-transform:uppercase;justify-content:space-between;font-size:.7rem;display:flex}.result-panel video{background:#000;border-radius:2px;width:100%;margin-bottom:1.25rem;display:block}#live-canvas{background:#000;border-radius:2px;width:100%;height:auto;margin-bottom:1rem;display:block}.live-controls{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.mic-status{text-transform:uppercase;letter-spacing:.15em;color:var(--ink-dim);font-size:.75rem}.notes-preview{border:1px solid var(--rule);border-radius:2px;max-width:100%;max-height:300px;margin:1.25rem auto 0;display:block}.chord-header{justify-content:space-between;align-items:center;gap:1.25rem;margin-bottom:1.25rem;display:flex}.chord-header-text{flex:1;min-width:0}.chord-header-text .panel-title{margin-bottom:2rem}.chord-header-text p{color:var(--ink-dim);margin:0;font-size:.9rem;line-height:1.5}.lissajous{border:1px solid var(--rule);background:#000;border-radius:2px;flex-shrink:0;width:120px;height:120px;display:block}.note-graph{background:var(--bg-3);border:1px solid var(--rule);border-radius:2px;padding:.75rem;position:relative}.note-graph svg{width:100%;height:auto;display:block}.note-tooltip{background:var(--bg);border:1px solid var(--rule);pointer-events:none;white-space:nowrap;z-index:5;border-radius:3px;align-items:center;gap:.6rem;padding:.5rem .7rem;display:flex;position:absolute;top:-8px;transform:translate(-50%,-100%)}.note-tooltip-swatch{border:1px solid var(--rule);border-radius:2px;flex-shrink:0;width:24px;height:24px}.note-tooltip-text{flex-direction:column;gap:.2rem;display:flex}.note-tooltip-pitch{color:var(--ink);font-size:.9rem;font-weight:500}.note-tooltip-detail{color:var(--ink-faint);font-size:.7rem}.piano{-webkit-user-select:none;user-select:none;background:var(--bg-3);border-radius:2px;height:180px;padding:8px;display:flex;position:relative}.piano-key{cursor:pointer;border:1px solid var(--rule);letter-spacing:.1em;text-transform:uppercase;padding:0;font-family:inherit;font-size:.7rem;transition:background 80ms,transform 80ms;position:relative}.piano-key.white{color:#333;z-index:1;background:#f0f0f0;border-radius:0 0 4px 4px;flex:1;justify-content:center;align-items:flex-end;padding-bottom:.5rem;display:flex}.piano-key.white:hover{background:#e0e8f5}.piano-key.white.active{background:var(--accent-2);transform:translateY(2px)}.piano-key.black{color:#aaa;z-index:2;background:#1a1a1a;border-radius:0 0 3px 3px;justify-content:center;align-items:flex-end;width:6%;height:60%;padding-bottom:.4rem;display:flex;position:absolute}.piano-key.black:nth-of-type(2){left:10.5%}.piano-key.black:nth-of-type(4){left:23%}.piano-key.black:nth-of-type(7){left:47%}.piano-key.black:nth-of-type(9){left:59%}.piano-key.black:nth-of-type(11){left:71.5%}.piano-key.black:hover{background:#2a2a2a}.piano-key.black.active{background:var(--accent);transform:translateY(2px)}.piano-key-label{font-weight:500}.song-panels{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.song-panel{background:var(--bg-3);border:1px solid var(--rule);cursor:grab;border-radius:3px;width:100%;padding:.75rem;transition:opacity .12s,transform .12s,border-color .12s}.song-panel.playing{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);transform:translateY(-2px)}.song-panel.dragging{opacity:.4;cursor:grabbing}.song-panel.drag-over{border-color:var(--accent);transform:translate(4px)}.song-panel input,.song-panel select,.song-panel button{cursor:pointer}.song-panel-header{color:var(--ink-dim);align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.75rem;display:flex}.song-panel-num{color:var(--accent);letter-spacing:.05em}.song-panel-beats{background:var(--bg-2);color:var(--ink);border:1px solid var(--rule);cursor:pointer;border-radius:2px;flex:1;padding:.2rem .4rem;font-family:JetBrains Mono,monospace;font-size:.75rem}.song-panel-actions{gap:.25rem;display:flex}.song-panel-colors{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.song-color-swatch{width:32px;height:32px;position:relative}.song-color-swatch input[type=color]{border:1px solid var(--rule);cursor:pointer;background:0 0;border-radius:50%;width:100%;height:100%;padding:0}.song-color-swatch input[type=color]::-webkit-color-swatch-wrapper{padding:0}.song-color-swatch input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}.song-color-remove{background:var(--bg);border:1px solid var(--rule);width:14px;height:14px;color:var(--ink-dim);cursor:pointer;opacity:0;border-radius:50%;place-items:center;padding:0;font-size:.7rem;line-height:1;transition:opacity .12s;display:grid;position:absolute;top:-4px;right:-4px}.song-color-swatch:hover .song-color-remove{opacity:1}.song-color-remove:hover{color:#ff7070;border-color:#ff7070}.drag-handle{color:var(--ink-faint);letter-spacing:-2px;cursor:grab;-webkit-user-select:none;user-select:none;margin-right:.25rem;font-size:.8rem;display:inline-block}.song-add-row{justify-content:center;align-items:center;gap:.75rem;display:flex}.panel.panel-image-drag{border-color:var(--accent);background:var(--bg-3)}.panel.panel-image-drag:before{content:"Drop image to add as panel";background:var(--bg);color:var(--accent);border:1px solid var(--accent);letter-spacing:.15em;text-transform:uppercase;z-index:1;pointer-events:none;border-radius:2px;padding:.75rem 1.25rem;font-size:.8rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.song-section-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.song-section-header .panel-title{margin:0}.song-clear-btn{flex-shrink:0;width:28px;height:28px;font-size:1rem}.song-playback-controls{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.song-playback-info{color:var(--ink-dim);font-family:JetBrains Mono,monospace;font-size:.85rem}.loop-btn.active,.loop-btn.active .btn-arrow{color:var(--accent);border-color:var(--accent)}.song-empty{text-align:center;background:var(--bg-3);border:1px dashed var(--rule);border-radius:2px;padding:2rem 1.5rem}.song-empty p{color:var(--ink-faint);letter-spacing:.02em;margin:0;font-size:.9rem}.chord-builder{flex-direction:column;gap:1rem;display:flex}.chord-builder-row{align-items:center;gap:.75rem;display:flex}.chord-builder-label{letter-spacing:.15em;text-transform:uppercase;color:var(--ink-dim);flex-shrink:0;width:50px;font-size:.7rem}.chord-builder-options{flex-wrap:wrap;gap:.3rem;display:flex}.chord-pill{background:var(--bg-3);border:1px solid var(--rule);color:var(--ink-dim);cursor:pointer;letter-spacing:.05em;border-radius:14px;padding:.3rem .7rem;font-family:JetBrains Mono,monospace;font-size:.75rem;transition:color .12s,border-color .12s,background .12s}.chord-pill:hover{color:var(--ink);border-color:var(--ink-faint)}.chord-pill.active{color:var(--bg);background:var(--accent);border-color:var(--accent)}.chord-preview-swatches{align-items:center;gap:4px;margin-left:auto;margin-right:.75rem;display:inline-flex}.chord-preview-swatch{border:1px solid #00000040;border-radius:50%;flex-shrink:0;width:18px;height:18px}.warning{color:#f3e3b6;background:#fbbf2414;border-left:3px solid #fbbf24;border-radius:2px;margin-top:1.2rem;padding:.85rem 1rem;font-size:.92rem;line-height:1.45}.warning strong{color:#fcd34d;letter-spacing:.02em}.processing-indicator{background:var(--bg-3);border:1px solid var(--rule);color:var(--ink-dim);border-radius:2px;align-items:center;gap:.75rem;margin-top:1.25rem;padding:.75rem 1rem;font-size:.9rem;display:flex}.processing-indicator.success{color:var(--ink);border-color:var(--accent)}.processing-indicator .check{color:var(--accent);font-size:1.1rem;font-weight:600}.spinner{border:2px solid var(--rule);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.8s linear infinite spinner-rotate}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.modal-backdrop{z-index:100;background:#000000a6;justify-content:center;align-items:center;animation:.16s modal-fade-in;display:flex;position:fixed;inset:0}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-2);border:1px solid var(--rule);border-radius:3px;width:90%;max-width:420px;padding:1.75rem;animation:.2s cubic-bezier(.25,.8,.3,1) modal-slide-in;box-shadow:0 12px 40px #00000080}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-title{letter-spacing:.15em;text-transform:uppercase;color:var(--ink);margin:0 0 1rem;font-size:.85rem}.modal-body{color:var(--ink-dim);margin:0 0 1.5rem;font-size:.9rem;line-height:1.5}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.modal-danger-btn{color:#fff;background:#c44}.modal-danger-btn:hover:not(:disabled){background:#d65555;transform:translateY(-1px)}@media (width<=520px){.shell{padding:2.5rem 1.25rem 4rem}.panel{padding:1.25rem}.dropzone-inner{flex-direction:column;align-items:flex-start;gap:.85rem}}
