:root{--bg-base: #0e0e12;--bg-panel: #16161e;--bg-card: #1c1c27;--bg-hover: #22222f;--border: #2a2a3a;--border-light: #34344a;--accent: #7c3aed;--accent-dim: #4c1d95;--accent-glow: rgba(124,58,237,.35);--kick-color: #ef4444;--kick-dim: #7f1d1d;--bass-color: #22d3ee;--bass-dim: #164e63;--bass-accent: #f59e0b;--rest-color: #1e1e2a;--text-primary: #e5e5f0;--text-secondary: #8888a8;--text-muted: #4a4a65;--green: #10b981;--yellow: #f59e0b;--red: #ef4444;--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--font-mono: "JetBrains Mono", "Fira Mono", monospace;--font-ui: "Inter", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-ui);background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:24px}.auth-card{width:100%;max-width:400px;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px}.auth-logo{font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:8px;color:var(--text-primary)}.auth-logo span{color:var(--accent)}.auth-title{font-size:18px;font-weight:600;color:var(--text-secondary);margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:var(--red);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:8px}.auth-submit{width:100%;margin-top:8px;height:40px;font-size:14px}.auth-footer{margin-top:20px;text-align:center;font-size:13px;color:var(--text-secondary)}.auth-footer a{color:var(--accent)}.auth-footer a:hover{text-decoration:underline}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:14px}.app-shell{display:grid;grid-template-columns:220px 1fr;grid-template-rows:48px 1fr;height:100vh;overflow:hidden}.topbar{grid-column:1 / -1;background:var(--bg-panel);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;z-index:10}.topbar-logo{font-family:var(--font-mono);font-weight:700;font-size:13px;letter-spacing:.08em;color:var(--accent);text-transform:uppercase}.topbar-logo span{color:var(--text-secondary)}.sidebar{background:var(--bg-panel);border-right:1px solid var(--border);padding:16px 0;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:12px 16px 4px}.nav-link{display:flex;align-items:center;gap:10px;padding:8px 16px;border-radius:0;color:var(--text-secondary);font-size:13px;transition:background .15s,color .15s;border-left:2px solid transparent}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--bg-hover);color:var(--accent);border-left-color:var(--accent)}.nav-icon{font-size:15px;width:18px;text-align:center}.page-content{overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.page-title{font-size:20px;font-weight:600;color:var(--text-primary)}.page-subtitle{font-size:12px;color:var(--text-secondary);margin-top:2px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:none;transition:background .15s,box-shadow .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 0 0 var(--accent-glow)}.btn-primary:hover{background:#6d28d9;box-shadow:0 0 12px var(--accent-glow)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--border)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-light)}.btn-danger{background:transparent;color:var(--red);border:1px solid var(--red)}.btn-danger:hover{background:#ef44441a}.btn-sm{padding:4px 10px;font-size:12px}.btn-lg{padding:10px 20px;font-size:15px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:7px 10px;font-size:13px;transition:border-color .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238888a8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.form-textarea{resize:vertical;min-height:80px;font-family:var(--font-mono);font-size:12px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.badge-accent{background:var(--accent-dim);color:var(--accent)}.badge-green{background:#10b98126;color:var(--green)}.badge-yellow{background:#f59e0b26;color:var(--yellow)}.badge-red{background:#ef444426;color:var(--red)}.badge-muted{background:var(--bg-hover);color:var(--text-muted)}.star-rating{display:flex;gap:2px}.star{font-size:16px;cursor:pointer;color:var(--text-muted);transition:color .1s}.star.active,.star:hover{color:var(--yellow)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:10px;color:var(--text-muted);text-align:center}.empty-icon{font-size:36px;margin-bottom:4px}.empty-title{font-size:15px;color:var(--text-secondary);font-weight:500}.empty-subtitle{font-size:13px}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--red);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;display:flex;align-items:center;justify-content:space-between}.timeline-wrapper{overflow-x:auto}.timeline{display:flex;gap:10px;min-width:max-content;width:100%;justify-content:center;padding-bottom:4px}.timeline-block-group{display:flex;flex-direction:column;gap:4px}.timeline-block-label{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;padding-left:2px}.timeline-block-sections{display:flex;gap:2px}.section-cell{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:2px;cursor:pointer;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);transition:border-color .15s,background .15s;padding:8px 6px 6px;position:relative;height:72px;overflow:hidden}.section-cell.w32,.section-cell.w64{width:76px}.section-cell:hover{border-color:var(--accent);background:var(--bg-hover)}.section-cell.selected{border-color:var(--accent);background:var(--accent-dim)}.section-cell.has-pattern{border-color:var(--bass-dim)}.section-cell.has-pattern .section-dot{background:var(--bass-color)}.section-label-text{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--text-primary)}.section-role-text{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);white-space:nowrap}.section-beat-text{font-size:9px;color:var(--text-muted)}.section-dot{width:6px;height:6px;border-radius:50%;background:var(--border-light);margin-top:2px}.grid-wrapper{overflow-x:auto;overflow-y:hidden}.bass-grid{display:flex;flex-direction:column;gap:2px;min-width:max-content;font-family:var(--font-mono)}.grid-row{display:flex;align-items:center;gap:0}.grid-row-label{width:72px;flex-shrink:0;font-size:10px;color:var(--text-muted);text-align:right;padding-right:8px;-webkit-user-select:none;user-select:none}.grid-steps{display:flex;gap:1px}.grid-step{width:20px;height:28px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:8px;position:relative;flex-shrink:0;transition:opacity .1s}.grid-step.kick-active{background:var(--kick-color);box-shadow:0 0 6px #ef444480}.grid-step.kick-inactive{background:var(--kick-dim);opacity:.3}.grid-step.bass-active{background:var(--bass-color);box-shadow:0 0 6px #22d3ee66}.grid-step.bass-accent-active{background:var(--bass-accent);box-shadow:0 0 8px #f59e0b80}.grid-step.bass-rest{background:var(--rest-color)}.vel-bar{position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 2px 2px;background:#ffffff4d}.grid-beat-markers{display:flex;margin-left:72px;margin-bottom:2px}.beat-marker{width:20px;flex-shrink:0;font-size:8px;color:var(--text-muted);text-align:center}.beat-marker.bar{color:var(--text-secondary);font-weight:600}.step-note-label{font-size:7px;color:#000000b3;font-weight:700;line-height:1;letter-spacing:-.03em}.generate-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px}.generate-panel-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px}.preset-btn{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:7px 10px;font-size:11px;font-weight:500;text-align:left;transition:all .15s;cursor:pointer}.preset-btn:hover{border-color:var(--accent);color:var(--text-primary);background:var(--bg-card)}.preset-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.pattern-list{display:flex;flex-direction:column;gap:8px}.pattern-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;cursor:pointer;transition:border-color .15s;display:flex;align-items:center;gap:12px}.pattern-card:hover{border-color:var(--accent)}.pattern-card.selected{border-color:var(--accent);background:var(--accent-dim)}.pattern-card-info{flex:1;min-width:0}.pattern-card-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pattern-card-meta{font-size:11px;color:var(--text-muted);margin-top:2px;font-family:var(--font-mono)}.pattern-card-actions{display:flex;gap:6px;flex-shrink:0}.mixing-category{display:flex;flex-direction:column;gap:8px}.mixing-category-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding-bottom:6px;border-bottom:1px solid var(--border)}.mixing-note-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.mixing-note-title{font-size:14px;font-weight:600;margin-bottom:6px}.mixing-note-body{font-size:13px;color:var(--text-secondary);line-height:1.6}.mixing-note-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px}.mixing-tag{background:var(--bg-hover);color:var(--text-muted);border-radius:99px;padding:1px 8px;font-size:10px;font-family:var(--font-mono)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s,transform .1s;display:flex;flex-direction:column;gap:8px}.project-card:hover{border-color:var(--accent);transform:translateY(-1px)}.project-card-name{font-size:15px;font-weight:600}.project-card-meta{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.new-project-card{border:1px dashed var(--border);background:transparent;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;gap:6px}.new-project-card:hover{border-color:var(--accent);color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-panel);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:440px;display:flex;flex-direction:column;gap:16px}.modal-title{font-size:16px;font-weight:600}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modular-grid{display:flex;flex-direction:column;gap:0;font-family:var(--font-mono);min-width:max-content}.grid-scroll-viewport{overflow-x:auto;overflow-y:visible}.playhead-wrapper{position:relative;min-width:max-content;pointer-events:none}.modular-grid{pointer-events:auto}.playhead-line{position:absolute;top:0;bottom:0;left:0;width:2px;background:#ffffffe6;box-shadow:0 0 6px #7c3aede6;z-index:2;pointer-events:none;will-change:transform;opacity:0;transform:translate(160px)}.grid-ruler{display:flex;align-items:center;margin-bottom:4px}.grid-steps-area{display:flex;flex:1}.grid-bar-label{font-size:9px;color:var(--text-muted);text-align:left;padding-left:2px;font-family:var(--font-mono);-webkit-user-select:none;user-select:none}.grid-row-wrapper{margin-bottom:8px}.grid-row{display:flex;align-items:stretch;gap:0}.grid-row-label{width:160px;min-width:160px;flex-shrink:0;display:flex;align-items:center;gap:6px;padding-right:8px;position:sticky;left:0;z-index:3;background:var(--bg-card);box-shadow:3px 0 8px #0006}.grid-row-color{width:6px;height:6px;border-radius:50%;flex-shrink:0}.grid-row-name{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-step{width:18px;height:28px;border-radius:2px;background:var(--bg-hover);flex-shrink:0;position:relative;overflow:hidden;transition:opacity .1s}.grid-step.beat-start{border-left:1px solid var(--border-light)}.grid-step.bar-start{border-left:2px solid var(--border)}.grid-step-vel{position:absolute;bottom:0;left:0;right:0;border-radius:0 0 2px 2px;opacity:.5}.grid-density-row{display:flex;margin-top:2px;height:4px}.grid-bar-density{height:100%;background:transparent;border-radius:2px;overflow:hidden}.component-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.component-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border)}.component-add-list{display:flex;flex-direction:column;gap:2px;padding:6px 8px;background:var(--bg-hover);border-bottom:1px solid var(--border)}.component-add-btn{font-size:11px!important;padding:3px 8px!important;justify-content:flex-start!important;border:none!important}.component-group{padding:6px 0 4px;border-bottom:1px solid var(--border)}.component-group:last-child{border-bottom:none}.component-group-label{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:0 12px 4px}.component-row{display:flex;align-items:center;gap:8px;padding:5px 12px;transition:background .1s}.component-row:hover{background:var(--bg-hover)}.component-row.disabled{opacity:.4}.component-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.component-label{font-size:12px;color:var(--text-primary);flex:1}.comp-toggle{width:30px;height:16px;border-radius:99px;background:var(--border);border:none;position:relative;cursor:pointer;transition:background .18s;flex-shrink:0;padding:0}.comp-toggle.on{background:var(--dot-color, var(--accent))}.comp-toggle-knob{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:left .18s}.comp-toggle.on .comp-toggle-knob{left:16px}.comp-remove{font-size:9px!important;padding:1px 4px!important;opacity:0;border:none!important;color:var(--text-muted)!important}.component-row:hover .comp-remove{opacity:1}.btn-xs{padding:2px 6px;font-size:10px}.export-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px}.export-panel-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}.export-toggles{display:flex;flex-wrap:wrap;gap:10px}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.w-full{width:100%}.text-muted{color:var(--text-muted)}.text-mono{font-family:var(--font-mono)}.text-accent{color:var(--accent)}.text-sm{font-size:12px}.text-xs{font-size:11px}
