*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,sans-serif;font-size:15px}body{color:#e5e7eb;background:#111827;min-height:100vh}#root{min-height:100vh}.app{flex-direction:column;gap:16px;max-width:900px;margin:0 auto;padding:20px 16px 40px;display:flex}.header{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.logo{background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-text-fill-color:transparent;white-space:nowrap;-webkit-background-clip:text;font-size:1.4rem;font-weight:700}.header-controls{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.instrument-select{color:#e5e7eb;cursor:pointer;appearance:none;background:#1f2937 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='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 8px center no-repeat;border:1px solid #374151;border-radius:8px;outline:none;padding:7px 28px 7px 10px;font-size:.88rem;font-weight:600}.instrument-select:focus{border-color:#3b82f6}.bpm-wrap{color:#9ca3af;align-items:center;gap:10px;font-size:.88rem;display:flex}.bpm-wrap strong{color:#e5e7eb}.bpm-wrap input[type=range]{accent-color:#3b82f6;cursor:pointer;width:110px}.bpm-step{color:#e5e7eb;cursor:pointer;background:#1f2937;border:1px solid #374151;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:1rem;line-height:1;transition:background .1s;display:flex}.bpm-step:hover{background:#374151}.palette-section{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:16px}.section-label{text-transform:uppercase;letter-spacing:.08em;color:#6b7280;margin-bottom:12px;font-size:.75rem;font-weight:700}.tip{text-transform:none;letter-spacing:0;color:#4b5563;margin-left:10px;font-size:.72rem;font-weight:400}.palette-grid{flex-direction:column;gap:6px;display:flex}.chord-row{flex-wrap:wrap;gap:6px;display:flex}.chord-btn,.field-strip,.prog-name,.chord-add{touch-action:manipulation}.chord-btn{color:#e5e7eb;cursor:pointer;-webkit-user-select:none;user-select:none;background:#111827;border:1px solid #374151;border-radius:8px;min-width:62px;padding:8px 12px;font-size:.85rem;font-weight:700;transition:transform 80ms,background .1s,box-shadow .1s}.chord-btn:hover{background:#374151}.chord-btn:active{transform:scale(.93)}.chord-btn.type-major{color:#93c5fd;border-color:#1d4ed8}.chord-btn.type-minor{color:#c4b5fd;border-color:#5b21b6}.chord-btn.type-dom7{color:#6ee7b7;border-color:#065f46}.chord-btn.type-maj7{color:#7dd3fc;border-color:#1e3a5f}.chord-btn.type-min7{color:#ddd6fe;border-color:#4c1d95}.chord-btn.type-dim{color:#fca5a5;border-color:#7f1d1d}.chord-btn.type-add9{color:#5eead4;border-color:#134e4a}.chord-btn.flash{background:#3b82f6;border-color:#60a5fa;transform:scale(1.04);box-shadow:0 0 12px #3b82f680}.chord-wrap{display:inline-flex;position:relative}.chord-add{color:#fff;cursor:pointer;opacity:0;z-index:1;background:#2563eb;border:none;border-radius:50%;justify-content:center;align-items:center;width:17px;height:17px;font-size:.75rem;line-height:1;transition:opacity .15s,transform .1s;display:flex;position:absolute;top:-6px;right:-6px}.chord-wrap:hover .chord-add{opacity:1}.chord-add:hover{background:#1d4ed8;transform:scale(1.15)}.metro-section{background:#1f2937;border:1px solid #374151;border-radius:12px;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;display:flex}.metro-btn{color:#e5e7eb;cursor:pointer;background:#374151;border:none;border-radius:8px;min-width:90px;padding:7px 18px;font-size:.88rem;font-weight:700;transition:background .15s}.metro-btn.on{background:#dc2626}.metro-btn:hover:not(.on){background:#4b5563}.metro-beats-toggle{gap:4px;display:flex}.metro-sig{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:6px;padding:5px 10px;font-size:.8rem;transition:all .1s}.metro-sig.active{color:#fff;background:#2563eb;border-color:#2563eb}.metro-sig:hover:not(.active){color:#e5e7eb;border-color:#6b7280}.metro-dots{align-items:center;gap:8px;display:flex}.metro-dot{background:#374151;border-radius:50%;width:14px;height:14px;transition:background 50ms,transform 50ms,box-shadow 50ms}.metro-dot.accent{background:#4b5563}.metro-dot.active{background:#facc15;transform:scale(1.3);box-shadow:0 0 8px #facc1580}.metro-dot.accent.active{background:#f97316;box-shadow:0 0 10px #f9731680}.field-section{background:#1f2937;border:1px solid #374151;border-radius:12px;min-height:100px;padding:16px}.field-list{flex-wrap:wrap;gap:10px;display:flex}.field-item{-webkit-user-select:none;user-select:none;background:#111827;border:2px solid #374151;border-radius:10px;flex-direction:column;width:76px;height:156px;transition:opacity .15s,border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:visible}.field-item.dragging{opacity:.3}.field-item.drag-over{border-color:#3b82f6;box-shadow:-3px 0 #3b82f6}.field-item.type-major{border-color:#1d4ed8}.field-item.type-minor{border-color:#5b21b6}.field-item.type-dom7{border-color:#065f46}.field-item.type-maj7{border-color:#1e3a5f}.field-item.type-min7{border-color:#4c1d95}.field-item.type-dim{border-color:#7f1d1d}.field-item.type-add9{border-color:#134e4a}.field-item.drag-over{border-color:#3b82f6!important}.field-remove{color:#111827;cursor:pointer;opacity:0;background:#6b7280;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6rem;transition:opacity .15s;display:flex;position:absolute;top:-7px;right:-7px}.field-item:hover .field-remove{opacity:1}.field-name{color:#e5e7eb;text-align:center;pointer-events:none;background:#1f2937e6;border-bottom:1px solid #374151;border-radius:8px 8px 0 0;flex-shrink:0;padding:6px 4px 5px;font-size:.95rem;font-weight:800}.field-strip{cursor:pointer;border-radius:0 0 8px 8px;flex-direction:column;flex:1;display:flex;overflow:hidden}.strip-section{background:#0d1520;flex:1;transition:background 80ms;position:relative}.strip-section+.strip-section{border-top:1px solid #1e293b}.strip-section:hover{background:#172033}.strip-section.active{background:#1a3455}.strip-section.active:after{content:"";background:#3b82f6;border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.drag-hint{color:#2d3748;cursor:grab;z-index:2;font-size:.72rem;line-height:1;transition:color .1s;position:absolute;bottom:3px;right:4px}.field-item:hover .drag-hint{color:#6b7280}.drag-hint:active{cursor:grabbing}.rhythm-section{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:16px}.rhythm-header{align-items:center;gap:12px;margin-bottom:14px;display:flex}.rhythm-play-btn{color:#e5e7eb;cursor:pointer;background:#374151;border:1px solid #4b5563;border-radius:6px;padding:5px 14px;font-size:.82rem;transition:background .1s}.rhythm-play-btn:hover{background:#4b5563}.rhythm-grid{flex-direction:column;gap:6px;display:flex}.rhythm-row{align-items:center;gap:8px;display:flex}.rhythm-label{color:#9ca3af;text-align:right;flex-shrink:0;width:38px;font-size:.72rem}.rhythm-steps{scrollbar-width:none;gap:3px;display:flex;overflow-x:auto}.rhythm-steps::-webkit-scrollbar{display:none}.rhythm-step{cursor:pointer;touch-action:manipulation;background:#0f172a;border:1px solid #2d3748;border-radius:4px;flex-shrink:0;width:30px;height:30px;transition:background 70ms}.rhythm-step:hover{background:#1e293b}.rhythm-step.beat-first{margin-left:6px}.rhythm-step.active{background:#1d4ed8;border-color:#3b82f6}.rhythm-step.active:hover{background:#2563eb}.rhythm-step.current{outline-offset:1px;outline:2px solid #fbbf24}@media (width<=600px){.chord-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;padding-bottom:2px;overflow-x:auto}.chord-row::-webkit-scrollbar{display:none}.chord-btn{flex-shrink:0;min-width:54px;padding:7px 9px;font-size:.78rem}}.prog-section{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:16px}.prog-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.prog-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.presets{flex-wrap:wrap;gap:6px;display:flex}.preset-btn{color:#9ca3af;cursor:pointer;background:#111827;border:1px solid #374151;border-radius:6px;padding:4px 10px;font-size:.75rem;transition:all .15s}.preset-btn:hover{color:#e5e7eb;background:#374151}.loop-label{color:#9ca3af;cursor:pointer;align-items:center;gap:5px;font-size:.82rem;display:flex}.ctrl-btn{cursor:pointer;border:none;border-radius:8px;padding:6px 16px;font-size:.85rem;font-weight:700;transition:opacity .15s,transform .1s}.ctrl-btn:active{transform:scale(.95)}.ctrl-btn.play{color:#fff;background:#2563eb}.ctrl-btn.stop{color:#fff;background:#dc2626}.ctrl-btn.clear{color:#9ca3af;background:#374151}.ctrl-btn:disabled{opacity:.35;cursor:not-allowed}.empty{text-align:center;color:#4b5563;border:2px dashed #374151;border-radius:10px;padding:36px;font-size:.9rem}.prog-list{flex-wrap:wrap;gap:10px;display:flex}.prog-item{background:#111827;border:2px solid #374151;border-radius:10px;flex-direction:column;align-items:center;gap:7px;min-width:82px;padding:12px 12px 10px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.prog-item.active{border-color:#3b82f6;box-shadow:0 0 14px #3b82f660}.prog-item.dragging{opacity:.3}.prog-item.drag-over{border-color:#3b82f6!important}.prog-item .drag-hint{opacity:0}.prog-item:hover .drag-hint{color:#6b7280;opacity:1}.prog-item .field-strip{border-radius:4px;flex:none;width:100%;height:52px}.prog-remove{color:#111827;cursor:pointer;opacity:0;background:#6b7280;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6rem;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:-7px;right:-7px}.prog-item:hover .prog-remove{opacity:1}.prog-name{color:#e5e7eb;cursor:pointer;border-radius:4px;padding:2px 4px;font-size:1.05rem;font-weight:800;transition:background .1s}.prog-name:hover{background:#374151}.beats-row{gap:3px;display:flex}.beat-btn{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:4px;justify-content:center;align-items:center;width:21px;height:21px;font-size:.7rem;transition:all .1s;display:flex}.beat-btn:hover{color:#e5e7eb;border-color:#6b7280}.beat-btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.beats-unit{color:#6b7280;font-size:.7rem}.pattern-row{gap:3px;display:flex}.pattern-btn{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:4px;justify-content:center;align-items:center;width:21px;height:21px;font-size:.8rem;transition:all .1s;display:flex}.pattern-btn:hover{color:#e5e7eb;border-color:#6b7280}.pattern-btn.active{color:#fff;background:#7c3aed;border-color:#7c3aed}
