:root{--color-primary:#0d9488;--color-primary-light:#14b8a6;--color-primary-dark:#0f766e;--color-primary-bg:#ccfbf1;--color-primary-border:#5eead4;--color-secondary:#6366f1;--color-secondary-light:#818cf8;--color-secondary-bg:#e0e7ff;--color-secondary-border:#a5b4fc;--color-accent:#65a30d;--color-accent-light:#84cc16;--color-accent-bg:#ecfccb;--color-accent-border:#a3e635;--color-chord-highlight:#f59e0b;--color-chord-active:#f97316;--color-bg:#f8fafc;--color-surface:#fff;--color-border:#e2e8f0;--color-text:#334155;--color-text-muted:#94a3b8;--color-text-strong:#0f172a;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 10px 30px #0000001a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--font-sans:"Inter", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:var(--radius-full)}.surface-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none;transition:all .15s}button:active{transform:scale(.97)}select{font-family:var(--font-sans)}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));color:#fff;padding:var(--space-lg) var(--space-xl);box-shadow:var(--shadow-md)}.header-content{max-width:1400px;margin:0 auto}.header-title{align-items:center;gap:var(--space-sm);letter-spacing:-.02em;font-size:1.75rem;font-weight:700;display:flex}.header-icon{font-size:2rem}.header-subtitle{margin-top:var(--space-xs);opacity:.85;font-size:.95rem;font-weight:400}.app-main{gap:var(--space-lg);padding:var(--space-lg);flex:1;grid-template-columns:280px 1fr;align-items:start;width:100%;max-width:1400px;margin:0 auto;display:grid}.control-panel{top:var(--space-lg);max-height:calc(100vh - 2 * var(--space-lg) - 100px);flex-direction:column;height:fit-content;display:flex;position:sticky;overflow:hidden}.control-params{flex:auto;min-height:0;overflow-y:auto}.control-params-inner{padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;display:flex}.control-actions{padding:var(--space-md) var(--space-lg);padding-bottom:var(--space-lg);gap:var(--space-md);border-top:1px solid var(--color-border);background:var(--color-surface);flex-direction:column;flex:none;display:flex}.control-group{gap:var(--space-sm);flex-direction:column;display:flex}.control-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.control-select{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;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='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.control-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg);outline:none}.control-select:hover{border-color:var(--color-primary-light)}.mode-select,.rhythm-select{padding:6px 32px 6px 12px;font-size:.85rem}.chip-group{gap:var(--space-xs);flex-wrap:wrap;display:flex}.chip{border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);padding:6px 14px;font-size:.85rem;font-weight:500;transition:all .15s}.chip:hover{border-color:var(--color-primary);background:var(--color-primary-bg)}.chip-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.chip-active:hover{background:var(--color-primary-dark)}.root-chip{min-width:0;padding:5px 8px;font-size:.8rem;font-weight:600}.root-accidental{opacity:.85;font-size:.72rem}.current-key-display{color:var(--color-primary);margin-top:var(--space-sm);text-align:center;font-size:1.05rem;font-weight:700}.transpose-buttons{align-items:center;gap:var(--space-sm);display:flex}.transpose-btn{border-radius:var(--radius-sm);background:var(--color-bg);border:1px solid var(--color-border);width:40px;height:40px;color:var(--color-text);justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;display:flex}.transpose-btn:hover{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.transpose-current{text-align:center;color:var(--color-text-strong);flex:1;font-size:.9rem;font-weight:600}.action-buttons{gap:var(--space-sm);flex-direction:column;display:flex}.btn{border-radius:var(--radius-sm);text-align:center;padding:10px 20px;font-size:.95rem;font-weight:600;transition:all .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{box-shadow:var(--shadow-md);background:#4d7c0f}.btn-danger{color:#fff;background:#ef4444}.btn-danger:hover{background:#dc2626}.btn-outline{color:var(--color-primary);border:1px solid var(--color-primary);background:0 0}.btn-outline:hover{background:var(--color-primary-bg)}.btn-sm{min-width:auto;padding:4px 10px;font-size:.85rem}.btn-active{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary)}.btn-active:hover{background:var(--color-primary-dark)}.midi-io-buttons{gap:var(--space-sm);display:flex}.midi-io-buttons .btn{padding:var(--space-xs) var(--space-sm);flex:1;font-size:.8rem}.btn:disabled{opacity:.5;cursor:not-allowed}.control-slider{appearance:none;background:linear-gradient(to right, var(--color-accent-bg), var(--color-accent));border-radius:var(--radius-full);cursor:pointer;outline:none;width:100%;height:6px}.control-slider::-webkit-slider-thumb{appearance:none;background:var(--color-primary);width:20px;height:20px;box-shadow:var(--shadow-sm);cursor:pointer;border:2px solid #fff;border-radius:50%;transition:transform .15s}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-labels{color:var(--color-text-muted);justify-content:space-between;margin-top:2px;font-size:.7rem;display:flex}.center-panel{gap:var(--space-lg);flex-direction:column;min-width:0;display:flex}.progression-row{gap:var(--space-md);align-items:flex-start;display:flex}.progression-main{flex:1 1 0;min-width:0}.progression-view{padding:var(--space-lg)}.progression-empty{text-align:center;padding:var(--space-xl);color:var(--color-text-muted)}.progression-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.progression-title{color:var(--color-text-strong);font-size:1.1rem;font-weight:600}.progression-score{font-size:.9rem;font-weight:600}.score-exotic-note{opacity:.6;font-size:.7rem;font-style:italic;font-weight:400}.progression-chords{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.chord-card{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);background:var(--color-bg);border:2px solid var(--color-border);cursor:pointer;flex-direction:column;align-items:center;min-width:80px;transition:all .15s;display:flex;position:relative}.chord-card:hover{border-color:var(--color-primary);background:var(--color-primary-bg);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.chord-card-wrapper{align-items:center;gap:2px;display:flex}.chord-add-btn{border:1px dashed var(--color-border);background:var(--color-bg);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;transition:all .15s;display:flex}.chord-add-btn:hover{border-color:var(--color-accent);background:var(--color-accent-bg);color:var(--color-accent);border-style:solid}.chord-remove-btn{color:#dc2626;cursor:pointer;background:#fecaca;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:.6rem;line-height:1;display:none;position:absolute;top:-6px;left:-6px}.chord-card:hover .chord-remove-btn{display:flex}.chord-remove-btn:hover{color:#fff;background:#dc2626}.chord-active{box-shadow:var(--shadow-md);transform:scale(1.05);border-color:var(--color-chord-highlight)!important;background:#fef3c7!important}.chord-roman{color:var(--color-text-muted);text-transform:uppercase;font-size:.75rem;font-weight:500}.chord-name{color:var(--color-text-strong);margin-top:2px;font-size:1.1rem;font-weight:700}.chord-spicy{border-color:var(--color-chord-highlight)!important;background:#fffbeb!important}.chord-derived{border-color:var(--color-chord-highlight)!important;background:#fefce8!important}.chord-editing{box-shadow:0 0 0 2px var(--color-primary-bg);border-color:var(--color-primary)!important}.chord-derived-badge{color:var(--color-chord-active);background:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;display:flex;position:absolute;top:-6px;right:-6px;box-shadow:0 1px 3px #0000001f}.derivation-status{color:var(--color-primary);background:var(--color-primary-bg);border-radius:var(--radius-sm);border:1px solid var(--color-primary);margin-bottom:8px;padding:6px 12px;font-size:.75rem}.chord-spice-label{color:var(--color-chord-active);text-transform:none;white-space:nowrap;margin-top:2px;font-size:.6rem;font-weight:600}.chord-filter-tag{color:var(--color-primary);opacity:.6;margin-top:1px;font-size:.65rem}.chord-mod-pivot{box-shadow:0 0 0 2px #a855f755;border-color:#a855f7!important}.chord-mod-label{color:#a855f7;white-space:nowrap;margin-top:2px;font-size:.55rem;font-weight:600}.modulation-banner{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);color:#7c3aed;background:linear-gradient(135deg,#f5f3ff,#faf5ff);border-left:3px solid #a855f7;border-radius:8px;font-size:.85rem;font-weight:600}.chord-arrow{color:var(--color-text-muted);z-index:1;font-size:1.2rem;position:absolute;right:-14px}.chord-edit-btn{background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.65rem;line-height:1;transition:all .15s;display:flex;position:absolute;top:-6px;right:-6px}.chord-edit-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:scale(1.2)}.derivation-panel{max-height:520px;padding:var(--space-md);gap:var(--space-md);flex-direction:column;flex:0 0 260px;display:flex;overflow-y:auto}.derivation-header{align-items:center;gap:var(--space-sm);display:flex;position:relative}.derivation-title{color:var(--color-text-strong);margin:0;font-size:1rem;font-weight:600}.derivation-chord-name{color:var(--color-primary);background:var(--color-primary-bg);border-radius:var(--radius-sm);padding:2px 8px;font-size:.85rem;font-weight:700}.derivation-close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:1rem;transition:all .15s}.derivation-close:hover{background:var(--color-bg);color:var(--color-text-strong)}.derivation-section{gap:var(--space-xs);flex-direction:column;display:flex}.derivation-section .chip-group{margin-top:2px}.derivation-score-preview{background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:6px 10px;font-size:.8rem;font-weight:600}.derivation-hint{color:var(--color-text-muted);text-align:center;border-top:1px solid var(--color-border);margin-top:2px;padding:4px 0;font-size:.68rem}.derivation-actions{gap:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border);flex-direction:column;display:flex}.derivation-actions .btn{padding:8px 16px;font-size:.85rem}.progression-playing-indicator{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);color:var(--color-primary);font-size:.9rem;font-weight:500;display:flex}.playing-dot{background:var(--color-chord-highlight);border-radius:50%;width:8px;height:8px;animation:.6s ease-in-out infinite alternate pulse}@keyframes pulse{0%{opacity:.3;transform:scale(.8)}to{opacity:1;transform:scale(1.2)}}.suggestions-inline{border-radius:var(--radius-md);padding:0;overflow:hidden}.suggestions-bar{width:100%;padding:var(--space-sm) var(--space-md);color:var(--color-text);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600;transition:background .15s;display:flex}.suggestions-bar:hover{background:var(--color-primary-bg)}.suggestions-arrow{color:var(--color-text-muted);font-size:.8rem;transition:transform .15s}.suggestion-refresh-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;padding:2px 6px;font-size:.8rem;line-height:1;transition:all .12s}.suggestion-refresh-btn:hover{background:var(--color-primary-bg);border-color:var(--color-primary-border)}.suggestion-refresh-btn:active{transform:rotate(90deg)}.suggestions-inline.suggestions-collapsed{opacity:.7}.suggestions-inline.suggestions-collapsed:hover{opacity:1}.suggestions-list{background:var(--color-border);flex-direction:column;gap:1px;margin:0;display:flex}.suggestion-card{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-surface);cursor:pointer;text-align:left;border:none;width:100%;transition:background .12s;display:flex;position:relative}.suggestion-card:hover{background:var(--color-primary-bg)}.suggestion-score-badge{border-radius:var(--radius-md);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:.9rem;font-weight:700;line-height:1;display:flex}.suggestion-score-badge.score-excellent{background:var(--color-accent-bg);color:var(--color-accent)}.suggestion-score-badge.score-good{background:var(--color-primary-bg);color:var(--color-primary)}.suggestion-score-badge.score-ok{color:#a16207;background:#fef9c3}.suggestion-score-badge.score-weak{color:#dc2626;background:#fee2e2}.suggestion-score-label{opacity:.8;margin-top:-2px;font-size:.55rem;font-weight:500}.suggestion-body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.suggestion-chords{color:var(--color-text);flex-wrap:wrap;align-items:center;gap:6px;font-size:.95rem;font-weight:600;display:flex}.suggestion-chord-name{white-space:nowrap}.suggestion-arrow-icon{color:var(--color-text-muted);flex-shrink:0;font-size:.75rem}.suggestion-key-tag{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border);white-space:nowrap;border-radius:10px;flex-shrink:0;margin-left:auto;padding:1px 8px;font-size:.7rem;font-weight:500}.suggestion-key-tag.key-different{color:#92400e;background:#fef3c7;border-color:#fcd34d;font-weight:600}.suggestion-roman{color:var(--color-text-muted);flex-wrap:wrap;gap:4px;font-size:.75rem;display:flex}.suggestion-roman-name{white-space:nowrap}.suggestion-roman-arrow{color:var(--color-border)}.suggestion-actions{gap:var(--space-xs);flex-shrink:0;display:flex}.suggestion-preview-btn,.suggestion-select-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;padding:6px 10px;font-size:.85rem;transition:all .12s}.suggestion-preview-btn:hover{background:var(--color-primary-bg);color:var(--color-primary);border-color:var(--color-primary-border)}.suggestion-select-btn:hover{background:var(--color-accent-bg);color:var(--color-accent);border-color:var(--color-accent-border)}.suggestion-preview-btn:active,.suggestion-select-btn:active{transform:scale(.95)}@media (width<=640px){.suggestion-card{gap:var(--space-sm);padding:var(--space-sm);flex-wrap:wrap}.suggestion-body{flex:100%;order:2}.suggestion-actions{order:3}.suggestion-chords{font-size:.85rem}}.instrument-section{padding:var(--space-lg)}.instrument-title{color:var(--color-text);margin-bottom:var(--space-md);font-size:.95rem;font-weight:600}.instrument-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.instrument-header .instrument-title{margin-bottom:0}.instrument-toggles{gap:var(--space-xs);display:flex}.instrument-toggle{cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:.85rem;transition:all .2s;display:inline-flex}.instrument-toggle input[type=checkbox]{display:none}.instrument-toggle.toggle-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.instrument-subtitle{color:var(--color-text-muted);margin-bottom:var(--space-sm);margin-top:var(--space-md);font-size:.85rem;font-weight:600}.piano-keyboard{width:100%;padding-bottom:var(--space-sm);overflow-x:auto}.piano-keys{min-width:560px;height:140px;position:relative}.piano-key{cursor:default;border-radius:0 0 4px 4px;transition:background .12s;position:absolute}.white-key{z-index:1;background:#fafafa;border:1px solid #d4d4d8;border-top:none;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;padding-bottom:12px;display:flex}.white-key:hover{background:#f0fdf4}.black-key{z-index:2;background:#27272a;border:1px solid #18181b;flex-direction:column;justify-content:flex-end;align-items:center;height:60%;padding-bottom:8px;display:flex;box-shadow:1px 2px 6px #0000004d}.black-key:hover{background:#3f3f46}.key-highlighted{background:var(--color-primary)!important;border-color:var(--color-primary-dark)!important}.white-key.key-highlighted{background:var(--color-primary-light)!important;border-color:var(--color-primary)!important}.key-root{background:var(--color-primary-dark)!important;border-color:var(--color-primary-dark)!important;box-shadow:0 0 6px #0f766e59!important}.white-key.key-root{background:var(--color-primary-dark)!important;border-color:var(--color-primary-dark)!important;box-shadow:0 0 6px #0f766e73!important}.key-label-root{color:#ffffff8c;pointer-events:none;font-size:.5rem;font-weight:700;line-height:1;position:absolute;top:2px;right:4px}.key-in-chord{box-shadow:inset 0 0 0 3px var(--color-chord-highlight)}.key-label-note{color:#71717a;font-size:.75rem;font-weight:700}.key-label-solfege{color:#a1a1aa;margin-top:1px;font-size:.65rem;font-weight:400}.black-key .key-label-note{color:#a1a1aa;font-size:.65rem}.key-highlighted .key-label-note,.key-highlighted .key-label-solfege{color:#fff!important}.fretboard-container{gap:var(--space-sm);display:flex;overflow-x:auto}.fretboard-labels{padding-right:var(--space-sm);flex-direction:column;justify-content:space-between;display:flex;position:relative}.fretboard-label{color:var(--color-text-muted);text-align:right;min-width:28px;right:var(--space-sm);font-size:.72rem;font-weight:600;position:absolute;transform:translateY(-50%)}.fretboard-neck{border-radius:var(--radius-sm);background:wheat;border:2px solid #d4a574;width:100%;max-width:500px;position:relative;overflow:hidden}.fretboard-string{background:#c4a882;height:1px;position:absolute;left:0;right:0;transform:translateY(-50%)}.fretboard-fret{background:#c4a882;width:2px;position:absolute;top:0;bottom:0}.fretboard-nut{background:#fafafa;border-right:1px solid #d4d4d8;width:5px}.fret-marker{color:#a08060;font-size:.6rem;font-weight:600;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chord-dot{color:var(--color-primary-dark);z-index:3;text-shadow:0 0 4px #fffc;pointer-events:none;font-size:1.1rem;position:absolute;transform:translate(-50%,-50%)}.chord-dot-root{z-index:4;color:#0f766e!important;text-shadow:0 0 6px #0f766e80!important;font-size:1.4rem!important}.chord-note-label{color:var(--color-primary);z-index:4;pointer-events:none;background:#fffc;border-radius:2px;padding:1px 3px;font-size:.55rem;font-weight:700;position:absolute;transform:translate(-50%,-140%)}@media (width<=768px){.app-main{padding:var(--space-md);grid-template-columns:1fr}.control-panel{max-height:none;position:static;overflow:visible}.control-params{flex:auto}.control-params-inner{gap:var(--space-md)}.control-actions{flex-direction:column}.control-group{flex:1;min-width:140px}.action-buttons{flex-direction:row}.progression-chords{flex-direction:column;align-items:stretch}.chord-arrow{display:none}.fretboard-neck{max-width:100%}}.rhythm-preview{background:var(--color-bg);border-radius:4px;height:20px;margin-top:8px;position:relative;overflow:hidden}.rhythm-dot{background:var(--color-primary);opacity:.6;border-radius:2px;min-width:3px;position:absolute;bottom:0}
