*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#09080a;--bg2:#111018;--bg3:#1e1c24;--bg4:#2a2830;--ink:#e0dae8;--ink2:#9990a8;--ink3:#5a5468;--accent:#c4893a;--accent2:#8b6f47;--amber:#c4893a;--teal:#5aaa8b;--rose:#9a6aaa;--indigo:#6a7faa;--tab-h:72px;--transport-h:72px}html,body{height:100%;background:var(--bg);color:var(--ink);font-family:DM Mono,monospace;font-weight:300;overflow:hidden}#app{display:flex;flex-direction:column;height:100vh;height:100dvh}#loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.loading-title{font-family:"Press Start 2P",monospace;font-size:14px;color:var(--accent);letter-spacing:.04em;line-height:1.6}.loading-bar-wrap{width:180px;height:1px;background:var(--bg3);border-radius:1px;overflow:hidden}.loading-bar{height:100%;width:0%;background:var(--accent);border-radius:1px;transition:width .3s ease}.loading-label{font-size:12px;color:var(--ink3);letter-spacing:.14em;text-transform:uppercase;text-align:center;max-width:340px;line-height:1.6}#transport{height:var(--transport-h);display:flex;align-items:center;gap:12px;padding:0 16px;border-bottom:1px solid var(--bg3);flex-shrink:0;background:var(--bg)}.transport-brand{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:0}.transport-cat{width:68px;height:68px;display:block;flex-shrink:0;image-rendering:pixelated;filter:drop-shadow(0 3px 8px rgba(0,0,0,.35))}.app-title{font-family:"Press Start 2P",monospace;font-weight:400;font-size:11px;color:var(--accent);letter-spacing:.04em;margin-right:2px}#play-btn{width:34px;height:34px;border-radius:2px;border:2px solid var(--accent);background:transparent;cursor:default;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;box-shadow:3px 3px #0009}#play-btn:hover,#play-btn.playing{background:var(--accent)}#play-btn:hover .play-icon,#play-btn.playing .play-icon{border-left-color:var(--bg)}#play-btn:hover .pause-icon:before,#play-btn.playing .pause-icon:before,#play-btn:hover .pause-icon:after,#play-btn.playing .pause-icon:after{background:var(--bg)}.play-icon{width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:11px solid var(--accent);margin-left:2px;transition:border-left-color .2s}.pause-icon{width:9px;height:13px;position:relative;background:transparent}.pause-icon:before,.pause-icon:after{content:"";position:absolute;top:0;width:3px;height:13px;background:var(--accent);border-radius:2px}.pause-icon:before{left:0}.pause-icon:after{right:0}.transport-group{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.transport-label{font-size:10px;color:var(--ink3);letter-spacing:.12em;text-transform:uppercase}.bpm-group{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.bpm-row{display:flex;align-items:center;gap:5px}#bpm-slider{width:60px;height:2px;cursor:default;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg3);border-radius:1px;outline:none}#bpm-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent);cursor:default}#bpm-slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--accent);cursor:default;border:none}#bpm-display{font-size:14px;color:var(--ink);min-width:26px}select.t-sel{background:transparent;border:none;font-family:DM Mono,monospace;font-size:14px;font-weight:300;color:var(--ink);cursor:default;outline:none;padding:0;-moz-appearance:none;appearance:none;-webkit-appearance:none;max-width:90px}select.t-sel option{background:var(--bg2);color:var(--ink)}.vinyl-toggle{display:flex;align-items:center;gap:6px;cursor:default;margin-left:auto;flex-shrink:0}.vinyl-label{font-size:11px;color:var(--ink3);letter-spacing:.08em}.transport-action-btn{font-family:DM Mono,monospace;font-size:10px;color:var(--ink3);background:transparent;border:1px solid var(--bg3);border-radius:18px;padding:7px 11px;cursor:default;letter-spacing:.08em;text-transform:uppercase;transition:all .15s;flex-shrink:0}.transport-action-btn:hover{border-color:#6a3a3a;color:#c89292}.toggle-track{width:28px;height:16px;border-radius:8px;border:1px solid var(--bg4);position:relative;transition:all .2s;flex-shrink:0;background:var(--bg2)}.toggle-track.on{border-color:var(--accent);background:var(--accent2)}.toggle-thumb{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--ink3);top:2px;left:2px;transition:all .2s}.toggle-track.on .toggle-thumb{left:14px;background:var(--accent)}#bar-indicator{font-size:14px;color:var(--ink2);letter-spacing:.05em;flex-shrink:0}@media (max-width:760px){.transport-brand{gap:6px}.transport-cat{width:48px;height:48px}.app-title{font-size:10px}}#content{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 16px 8px}#content::-webkit-scrollbar{width:3px}#content::-webkit-scrollbar-track{background:transparent}#content::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:2px}#tabs{height:var(--tab-h);display:flex;border-top:1px solid var(--bg3);flex-shrink:0;background:var(--bg);padding-bottom:env(safe-area-inset-bottom,0px)}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:default;border:none;background:transparent;transition:all .2s;color:var(--ink3);position:relative;min-height:44px;outline:none}.tab:focus,.tab:active,.tab:focus-visible{outline:none!important;box-shadow:none!important}.tab.active{color:var(--accent)}.tab.active:before{content:"";position:absolute;top:0;left:25%;right:25%;height:1px;background:var(--accent);box-shadow:0 0 8px var(--accent)}.tab-icon{font-size:22px;line-height:1}.tab-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-family:DM Mono,monospace}.panel{display:none}.panel.active{display:block}#panel-groove{position:relative}#panel-melody.active{display:flex}#groove-bursts{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:12}.section-title{font-family:"Press Start 2P",monospace;font-weight:400;font-size:9px;color:var(--ink2);margin-bottom:14px;letter-spacing:.03em}.bar-block{margin-bottom:16px;position:relative;z-index:1}.bar-block-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.bar-number{font-size:13px;color:var(--ink2);letter-spacing:.14em;text-transform:uppercase}.bar-playing-dot{width:5px;height:5px;border-radius:0;background:var(--accent);opacity:0;transition:opacity .15s;flex-shrink:0;box-shadow:1px 1px 0 var(--accent)}.bar-playing-dot.visible{opacity:1}.drum-rows{display:flex;flex-direction:column;gap:7px;margin-bottom:8px}.drum-row{display:flex;align-items:center;gap:8px}.drum-label-wrap{display:flex;flex-direction:column;gap:5px;flex-shrink:0;width:78px}.drum-label{font-size:12px;color:var(--ink2);letter-spacing:.08em;text-transform:uppercase}select.drum-sel{background:var(--bg2);border:1px solid var(--bg3);border-radius:3px;font-family:DM Mono,monospace;font-size:11px;color:var(--ink2);cursor:default;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:4px 6px;width:100%}select.drum-sel option{background:var(--bg2);color:var(--ink)}.drum-row-wrap{display:flex;flex-direction:column;flex:1;gap:4px}.step-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px}.step{aspect-ratio:1;border-radius:0;border:1px solid var(--bg3);background:var(--bg2);cursor:default;transition:all .1s;position:relative;min-width:0;overflow:hidden;will-change:transform,box-shadow}.step:hover{border-color:var(--bg4)}.step.active{border-color:transparent}.step.playing:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:2px;background:#ffffff2e}.drum-row[data-row=kick] .step.active{background:var(--amber);box-shadow:0 0 5px #c4893a59}.drum-row[data-row=snare] .step.active{background:var(--rose);box-shadow:0 0 5px #9a6aaa59}.drum-row[data-row=hihat] .step.active{background:var(--indigo);box-shadow:0 0 5px #6a7faa59}.chord-row{display:flex;align-items:center;gap:8px;margin-top:6px}.chord-row-label{width:78px;font-size:12px;color:var(--ink2);letter-spacing:.08em;text-transform:uppercase;flex-shrink:0}.chord-beat-cells{display:flex;flex:1;position:relative}.chord-seg{flex:1;height:50px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:1px solid var(--bg3);border-right:none;background:var(--bg2);cursor:default;transition:all .15s;position:relative;overflow:hidden;will-change:transform,box-shadow}.chord-seg:first-child{border-radius:0}.chord-seg:last-child{border-right:1px solid var(--bg3);border-radius:0}.chord-seg:hover{background:var(--bg3);z-index:2}.chord-seg.playing{border-color:var(--accent)!important;background:#c4893a1f;z-index:3}.chord-seg.playing .cs-name{color:var(--accent)}.chord-seg>*{position:relative;z-index:1}.chord-seg.held{border-left-color:transparent}.chord-seg.held .cs-beat{opacity:0}.groove-flash{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:inherit;z-index:0;mix-blend-mode:screen}.groove-flash-step{top:12%;right:12%;bottom:12%;left:12%;background:radial-gradient(circle,var(--flash-color) 0%,rgba(255,255,255,.18) 30%,rgba(255,255,255,0) 72%)}.groove-flash-chord{background:linear-gradient(90deg,rgba(255,255,255,0),var(--flash-color),rgba(255,255,255,0))}.groove-burst-dot{position:absolute;width:10px;height:10px;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);mix-blend-mode:screen}.cs-beat{position:absolute;top:3px;left:5px;font-size:8px;color:var(--ink3);opacity:.35}.cs-name{font-family:"Press Start 2P",monospace;font-size:11px;color:var(--ink);line-height:1.3;pointer-events:none}.cs-voice{font-size:11px;color:var(--ink2);letter-spacing:.06em;pointer-events:none;opacity:.85}.hold-toggle{position:absolute;top:50%;transform:translate(-50%,-50%);z-index:20;width:16px;height:16px;border-radius:50%;background:var(--bg);border:1px solid var(--bg4);display:flex;align-items:center;justify-content:center;cursor:default;font-size:8px;color:var(--ink3);transition:all .15s;-webkit-user-select:none;user-select:none}.hold-toggle:hover{border-color:var(--accent);color:var(--accent)}.hold-toggle.is-hold{border-color:var(--accent2);color:var(--accent2)}.bar-divider{height:1px;background:var(--bg3);margin-bottom:16px}.bar-controls{display:flex;align-items:center;gap:10px;padding-top:4px;position:relative;z-index:1}.bar-dots{display:flex;gap:5px;flex:1}.bar-dot{width:6px;height:6px;border-radius:0;border:1px solid var(--ink3);flex-shrink:0;transition:all .15s}.bar-dot.filled{background:var(--accent2);border-color:var(--accent2)}.bar-dot.current{box-shadow:0 0 0 2px var(--bg),0 0 0 3px var(--accent);background:var(--accent);border-color:var(--accent)}.add-bar-btn,.remove-bar-btn{font-family:DM Mono,monospace;font-size:12px;color:var(--ink3);background:transparent;border:1px solid var(--bg3);border-radius:0;padding:6px 12px;cursor:default;letter-spacing:.06em;transition:all .15s;box-shadow:3px 3px #0000008c}.add-bar-btn:hover{border-color:var(--accent2);color:var(--accent)}.remove-bar-btn:hover{border-color:#6a3a3a;color:#a07070}#chord-popover{position:fixed;z-index:9999;background:var(--bg2);border:2px solid var(--bg4);border-radius:0;padding:8px;display:none;flex-direction:column;gap:2px;box-shadow:5px 5px #000000b3;min-width:175px;max-height:340px;overflow-y:auto}#chord-popover.visible{display:flex}.cpop-section{font-size:10px;color:var(--ink3);letter-spacing:.1em;text-transform:uppercase;padding:5px 10px 3px}.cpop-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:5px;cursor:default;transition:background .12s;gap:8px}.cpop-item:hover{background:var(--bg3)}.cpop-item.active{background:var(--bg4)}.cpop-name{font-family:"Press Start 2P",monospace;font-size:10px;color:var(--ink);line-height:1.4}.cpop-feel{font-size:10px;color:var(--ink3);letter-spacing:.08em;text-transform:uppercase}.cpop-divider{height:1px;background:var(--bg3);margin:3px 0}.cpop-voice-row{display:flex;gap:4px;padding:5px 7px;flex-wrap:wrap}.cpop-voice-btn{font-family:DM Mono,monospace;font-size:10px;color:var(--ink3);background:transparent;border:1px solid var(--bg3);border-radius:0;padding:5px 9px;cursor:default;transition:all .12s;box-shadow:2px 2px #0000008c}.cpop-voice-btn:hover{border-color:var(--accent2);color:var(--ink)}.cpop-voice-btn.active{border-color:var(--accent);color:var(--accent)}#panel-melody{flex-direction:column;height:100%}.melody-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:10px}.melody-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.instrument-row{display:flex;gap:5px;flex-wrap:wrap}.melody-phrase-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.melody-sel{background:var(--bg2);border:1px solid var(--bg3);border-radius:0;font-family:DM Mono,monospace;font-size:10px;color:var(--ink2);cursor:default;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:6px 10px;min-width:84px}.melody-sel option{background:var(--bg2);color:var(--ink)}.inst-btn{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:0;border:1px solid var(--bg3);background:transparent;color:var(--ink3);cursor:default;transition:all .2s;box-shadow:3px 3px #0000008c}.inst-btn:hover{border-color:var(--accent2);color:var(--ink)}.inst-btn.active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px #c4893a26}.stroke-indicators{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.stroke-dot{width:34px;height:20px;border-radius:0;opacity:.45;cursor:default;transition:all .2s;flex-shrink:0;border:1px solid rgba(255,255,255,.12)}.stroke-dot.active{opacity:1;transform:scale(1.05)}.stroke-dot.filled{opacity:.8}.stroke-label{font-size:11px;color:var(--ink3);letter-spacing:.1em}#melody-canvas-wrap{border-radius:0;overflow:hidden;background:#000;position:relative;flex:1;min-height:260px;box-shadow:0 0 60px #000000e6;margin-bottom:10px}#melody-canvas-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:6;background:repeating-linear-gradient(0deg,rgba(0,0,0,.1) 0px,rgba(0,0,0,.1) 1px,transparent 1px,transparent 3px)}#melody-canvas-wrap:fullscreen{width:100vw;height:100vh;border-radius:0;margin-bottom:0;box-shadow:none;background:#000}#melody-canvas-wrap:fullscreen:after{display:none}#melody-canvas-wrap:fullscreen::backdrop{background:#000}#melody-canvas-wrap:fullscreen #melody-bursts{border-radius:0}#melody-canvas{display:block;width:100%;height:100%;cursor:crosshair;touch-action:none}#melody-hint{position:absolute;bottom:14px;left:0;right:0;text-align:center;font-size:18px;color:#fff3;font-family:"Press Start 2P",monospace;pointer-events:none;transition:opacity .8s;letter-spacing:.06em}#melody-bursts{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;border-radius:12px}.burst-dot{position:absolute;width:5px;height:5px;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%)}.melody-actions{display:flex;gap:7px;flex-shrink:0}.clear-btn{font-family:DM Mono,monospace;font-size:11px;color:var(--ink3);background:transparent;border:1px solid var(--bg3);border-radius:0;padding:6px 12px;cursor:default;letter-spacing:.06em;transition:all .15s;box-shadow:3px 3px #0000008c}.clear-btn:hover{border-color:#6a3a3a;color:#a07070}.clear-btn.active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px #c4893a2e}.clear-btn:disabled{opacity:.38;cursor:not-allowed;border-color:var(--bg3);color:var(--ink3);box-shadow:none}.clear-btn:disabled:hover{border-color:var(--bg3);color:var(--ink3)}#undo-stroke-btn{border-color:var(--bg4)}#undo-stroke-btn:hover{border-color:var(--accent2);color:var(--accent)}#melody-fullscreen-btn{margin-left:auto}*,*:hover,*:active,*:focus,button,a,[role=button]{cursor:default!important}.nes-btn{background-color:var(--bg3)!important;color:var(--ink2)!important;font-family:DM Mono,monospace!important;font-size:10px!important;padding:6px 10px!important;line-height:1.4!important;letter-spacing:.06em!important;text-transform:uppercase!important;margin:0!important}.nes-btn:after{box-shadow:none!important}.nes-btn:hover:not([disabled]):not(.is-disabled){background-color:var(--bg3)!important;color:var(--ink)!important}.nes-btn:focus{outline:none!important;box-shadow:inherit!important}.nes-btn.active{background-color:#c4893a26!important;color:var(--accent)!important}.nes-btn.is-error{background-color:#50141499!important;color:#a07070!important}.nes-btn.is-error:hover{background-color:#641e1ecc!important;color:#c89292!important}.nes-btn:before{border-color:var(--bg4)!important}.nes-btn,.nes-btn:hover{cursor:default!important}
