*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#1a1a2e;--bg-secondary:#16213e;--bg-surface:#0f3460;--accent:#e94560;--accent-hover:#ff6b81;--text-primary:#eaeaea;--text-secondary:#a0a0b0;--border-color:#2a2a4a;--clr-piano:#4a9eff;--clr-organ:#4ae04a;--clr-guitar:#ff9f43;--clr-strings:#a55eea;--clr-bass:#e94560;--clr-pads:#00d2d3;color:var(--text-primary);background-color:var(--bg-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}html,body,#root{width:100%;height:100%}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit;font-size:inherit}.app{flex-direction:column;width:100%;height:100vh;display:flex;overflow:hidden}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:.5rem 1.25rem;display:flex}.app-header h1{color:var(--accent);letter-spacing:.02em;font-size:1.15rem;font-weight:600}.app-main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.settings-panel{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;padding:.5rem 1.25rem}.beat-grid-area{flex:1;min-height:0;padding:1rem 1.25rem;overflow:auto}.app-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0;padding:.5rem 1.25rem}.header-actions{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.config-manager{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.config-save-group,.config-select-group{align-items:center;gap:.3rem;display:flex}.config-name-input{background:var(--bg-primary);border:1px solid var(--border-color);width:140px;color:var(--text-primary);border-radius:4px;padding:.25rem .4rem;font-size:.8rem}.config-name-input::placeholder{color:var(--text-secondary);opacity:.7}.config-select{background:var(--bg-primary);border:1px solid var(--border-color);max-width:200px;color:var(--text-primary);cursor:pointer;border-radius:4px;padding:.25rem .4rem;font-size:.8rem}.config-btn{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;white-space:nowrap;border-radius:4px;padding:.3rem .6rem;font-size:.8rem;transition:background .15s,opacity .15s}.config-btn:hover:not(:disabled){background:#1a4a7a}.config-btn:disabled{opacity:.4;cursor:not-allowed}.config-save-btn:hover:not(:disabled){background:#1a7a3a}.config-delete-btn:hover:not(:disabled){background:var(--clr-drums)}.file-io{gap:.5rem;display:flex}.file-btn{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:4px;padding:.3rem .6rem;font-size:.8rem;transition:background .15s}.file-btn:hover{background:#1a4a7a}.track-settings{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.setting-group{flex-direction:column;gap:.25rem;display:flex}.setting-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.bpm-control{align-items:center;gap:.5rem;display:flex}.bpm-control input[type=range]{width:100px;accent-color:var(--accent)}.bpm-input{background:var(--bg-primary);border:1px solid var(--border-color);width:60px;color:var(--text-primary);text-align:center;border-radius:4px;padding:.25rem .4rem;font-size:.85rem}.volume-label{color:var(--text-secondary);text-align:right;min-width:45px;font-size:.75rem}.time-sig-control{align-items:center;gap:.25rem;display:flex}.time-sig-control select{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:4px;padding:.25rem .4rem;font-size:.85rem}.time-sig-sep{color:var(--text-secondary);font-size:1rem}.drum-control{border:1px solid var(--border-color);border-radius:4px;gap:0;display:flex;overflow:hidden}.drum-btn{background:var(--bg-primary);color:var(--text-secondary);border:none;border-right:1px solid var(--border-color);cursor:pointer;padding:.3rem .65rem;font-size:.8rem;transition:background .15s,color .15s}.drum-btn:last-child{border-right:none}.drum-btn.active{background:var(--accent);color:#fff}.drum-btn:hover:not(.active){background:var(--bg-surface)}.bass-btn{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;border-radius:4px;min-width:48px;padding:.3rem .65rem;font-size:.8rem;transition:background .15s,color .15s}.bass-btn.active{background:var(--clr-bass);color:#fff}.bass-btn:hover:not(.active){background:var(--bg-surface)}.beats-input{background:var(--bg-primary);border:1px solid var(--border-color);width:60px;color:var(--text-primary);text-align:center;border-radius:4px;padding:.25rem .4rem;font-size:.85rem}.beat-grid-container{flex-direction:column;gap:.5rem;min-height:120px;display:flex}.bar-labels{gap:0;display:flex}.bar-label{color:var(--text-secondary);text-align:center;flex-shrink:0;padding:.15rem 0;font-size:.75rem}.beat-grid{flex-shrink:0;position:relative}.beat-cells{gap:0;display:flex}.beat-cell{border:1px solid var(--border-color);background:var(--bg-primary);cursor:pointer;border-left:none;flex-shrink:0;width:48px;height:56px;padding:0;transition:background .1s}.beat-cell:first-child{border-left:1px solid var(--border-color);border-top-left-radius:4px;border-bottom-left-radius:4px}.beat-cell.bar-start{border-left:2px solid var(--accent)}.beat-cell:hover{background:var(--bg-surface)}.chord-block{cursor:pointer;opacity:.85;color:#fff;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box;border:none;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:100%;min-width:0;height:100%;padding:2px 4px;font-size:.75rem;line-height:1.3;transition:opacity .15s,transform .1s;display:flex;overflow:hidden}.chord-block:hover{opacity:1;transform:translateY(-1px)}.chord-block-name{align-items:baseline;gap:1px;font-size:.8rem;font-weight:600;display:flex}.chord-block-octave{opacity:.7;font-size:.6rem;font-weight:400}.chord-block-instrument{opacity:.8;font-size:.65rem}.chord-blocks-overlay{z-index:2}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;width:360px;max-width:90vw;padding:1.5rem;box-shadow:0 8px 32px #0006}.modal-title{color:var(--text-primary);margin-bottom:1rem;font-size:1rem;font-weight:600}.modal-form{flex-direction:column;gap:1rem;display:flex}.modal-field{flex-direction:column;gap:.3rem;display:flex}.modal-field label{color:var(--text-secondary);font-size:.8rem}.modal-field input[type=text],.modal-field input[type=number]{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;padding:.4rem .6rem;font-size:.9rem}.modal-field input.input-error{border-color:var(--accent)}.field-error{color:var(--accent);font-size:.75rem}.instrument-toggle{border:1px solid var(--border-color);border-radius:4px;gap:0;display:flex;overflow:hidden}.toggle-btn{background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;border:none;flex:1;padding:.4rem .8rem;font-size:.85rem;transition:background .15s,color .15s}.instrument-grid{grid-template-columns:repeat(3,1fr);gap:.25rem;display:grid}.instrument-grid .toggle-btn{padding:.4rem .5rem;font-size:.8rem}.instrument-grid .toggle-btn.active{color:#fff}.toggle-btn:hover:not(.active){background:var(--bg-surface);background:var(--bg-surface)}.octave-selector{gap:.25rem;display:flex}.octave-btn{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;text-align:center;border-radius:4px;flex:1;padding:.4rem .5rem;font-size:.85rem;transition:background .15s,color .15s}.octave-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.octave-btn:hover:not(.active){background:var(--bg-surface)}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem;display:flex}.btn{cursor:pointer;border:none;border-radius:4px;padding:.4rem 1rem;font-size:.85rem;transition:background .15s}.btn-primary{background:var(--clr-piano);color:#fff}.btn-primary:hover{background:#3d8ae0}.btn-danger{background:var(--accent);color:#fff}.btn-danger:hover{background:#d63851}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:#1a4a7a}.transport-bar{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.transport-controls{gap:.25rem;display:flex}.transport-btn{background:var(--bg-surface);width:36px;height:36px;color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:1rem;transition:background .15s;display:flex}.transport-btn:hover{background:#1a4a7a}.play-btn{background:var(--accent);border-color:var(--accent)}.play-btn:hover{background:var(--accent-hover)}.small-btn{width:28px;height:28px;font-size:.8rem}.transport-position{flex-direction:column;gap:.1rem;display:flex}.position-label{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:.8rem}.position-bar{color:var(--text-secondary);font-size:.7rem}.transport-play-from{align-items:center;gap:.4rem;margin-left:auto;display:flex}.transport-play-from label{color:var(--text-secondary);font-size:.8rem}.play-from-input{background:var(--bg-primary);border:1px solid var(--border-color);width:50px;color:var(--text-primary);text-align:center;border-radius:4px;padding:.25rem .4rem;font-size:.85rem}.beat-grid-area::-webkit-scrollbar{height:8px}.beat-grid-area::-webkit-scrollbar-track{background:var(--bg-primary)}.beat-grid-area::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.beat-grid-area::-webkit-scrollbar-thumb:hover{background:#3a3a5a}
