@import"./src/modules/canvas/suggestions/components/SuggestionPalette.css?v=9";.modern-keyboard .black-key{height:58%;margin:0;background:linear-gradient(180deg,#1a1a1a,#0a0a0a);border:1px solid rgba(255,255,255,.1);border-top:2px solid rgba(50,50,50,.8);border-bottom:1px solid #000;border-radius:0 0 6px 6px;box-shadow:inset 0 -3px 6px #00000080,inset 0 1px #ffffff1a,0 4px 8px #0006,0 2px 4px #0000004d}.modern-keyboard .black-key:hover:not(.active-scale):not(.active-progression):not(.active-builder):not(.active-builder-playback):not(.active-scale-explorer):not(.active-scale-playback):not(.active-melody-playback){background:linear-gradient(180deg,#2a2a2a,#1a1a1a);box-shadow:inset 0 -3px 6px #00000080,inset 0 1px #ffffff26,0 6px 12px #00000080,0 3px 6px #0006;transform:translateY(-1px)}.modern-keyboard .black-key:active:not(.active-scale):not(.active-progression):not(.active-builder):not(.active-builder-playback):not(.active-scale-explorer):not(.active-scale-playback):not(.active-melody-playback){background:linear-gradient(180deg,#0a0a0a,#000);box-shadow:inset 0 2px 4px #000c,0 2px 4px #0000004d;transform:none}@keyframes key-press-scale{0%{transform:scale(1.02)}50%{transform:scale(1.03)}to{transform:scale(1.01)}}.white-key.active-builder{background:linear-gradient(180deg,#fef3c7,#fde68a)!important;box-shadow:inset 0 -4px #fbbf2499,0 0 20px #fbbf2466,0 4px 8px #fbbf2433,inset 0 1px #ffffff4d;border-color:#fbbf2466;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.black-key.active-builder{background:linear-gradient(180deg,#fde68a,#fbbf24)!important;box-shadow:inset 0 -4px #f59e0bcc,0 0 20px #fbbf2480,0 4px 8px #fbbf244d,inset 0 1px #fff3;border-color:#f59e0b99;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.white-key.active-builder-playback{background:linear-gradient(180deg,#f59e0b,#d97706);box-shadow:0 0 20px #f59e0b99,0 4px 12px #f59e0b66,inset 0 1px #fff6,inset 0 -2px #d9770699;border-color:#f59e0b80;transform:translateY(-1px);animation:glow-pulse-amber 1.5s infinite,key-press-scale .3s ease-out}#header-expand-collapse-group .group .absolute{display:none}#header-expand-collapse-group .group:hover .absolute{display:block}.tab-content>div{background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}#progression-visualization,#melody-progression-visualization,#builder-progression-visualization{gap:.25rem!important;overflow:visible!important}.scroll-view-container{scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.scroll-view-container::-webkit-scrollbar{height:6px}.scroll-view-container::-webkit-scrollbar-track{background:transparent}.scroll-view-container::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:3px}.scroll-view-container::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}.scroll-view-container .chord-card-wrapper,.scroll-view-container .section-unified-container{scroll-snap-align:start;flex-shrink:0}.chord-card-wrapper{position:relative;overflow:visible;padding-top:8px;margin-top:-8px;flex-shrink:0}.chord-card-wrapper .simplified-card,.chord-card-wrapper .detailed-card{overflow:visible}.ungrouped-cards-area{overflow:visible;padding-top:8px}[id$=-cards-grid]:not(.scroll-view-container){padding-top:8px}.section-cards-wrapper{padding-top:8px}#progression-visualization,#melody-progression-visualization,#builder-progression-visualization,[id$=-cards-grid]{overflow-x:auto;overflow-y:visible;padding-top:8px}#progression-visualization-panel,.progression-scroll-container{overflow-x:auto;overflow-y:visible}.section-filtered-cards{overflow-x:auto;overflow-y:visible;padding-top:8px}.section-cards-area{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;padding-top:8px}.section-unified-container{overflow:visible;flex-shrink:0}.chord-tooltip{z-index:999999!important}.section-picker-bar{border-bottom:1px solid #e5e7eb}.section-chip{transition:all .2s ease-out}.section-chip:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.section-nav-btn{transition:all .15s ease-out}.section-nav-btn:hover:not(:disabled){background-color:#f3f4f6;transform:scale(1.05)}.section-nav-btn:active:not(:disabled){transform:scale(.95)}.section-filtered-cards{transition:opacity .2s ease-out,transform .3s ease-out}.section-view-card{animation:slideInFromRight .3s ease-out forwards}@keyframes slideInFromRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.section-view-card:nth-child(1){animation-delay:0ms}.section-view-card:nth-child(2){animation-delay:30ms}.section-view-card:nth-child(3){animation-delay:60ms}.section-view-card:nth-child(4){animation-delay:90ms}.section-view-card:nth-child(5){animation-delay:.12s}.section-view-card:nth-child(6){animation-delay:.15s}.section-view-card:nth-child(7){animation-delay:.18s}.section-view-card:nth-child(8){animation-delay:.21s}.section-view-card:nth-child(9){animation-delay:.24s}.section-view-card:nth-child(10){animation-delay:.27s}.view-mode-toggle{transition:all .2s ease-out}.view-mode-btn{transition:all .15s ease-out}.view-mode-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a}:root{--rm-primary: #8b5cf6;--rm-primary-hover: #7c3aed;--rm-primary-light: #f5f3ff;--rm-primary-dark: #6d28d9;--rm-secondary: #667eea;--rm-secondary-light: #eef2ff;--rm-bg: #ffffff;--rm-bg-subtle: #f9fafb;--rm-bg-hover: #f3f4f6;--rm-bg-active: #e5e7eb;--rm-text: #111827;--rm-text-secondary: #4b5563;--rm-text-muted: #6b7280;--rm-text-light: #9ca3af;--rm-border: #e5e7eb;--rm-border-dark: #d1d5db;--rm-border-focus: var(--rm-primary);--rm-score-excellent: #059669;--rm-score-good: #2563eb;--rm-score-fair: #d97706;--rm-score-poor: #dc2626;--rm-action: #dbeafe;--rm-action-hover: #bfdbfe;--rm-action-text: #1d4ed8;--rm-action-light: #eff6ff;--rm-success: #cffafe;--rm-success-hover: #a5f3fc;--rm-success-text: #0e7490;--rm-add: #e0e7ff;--rm-add-hover: #c7d2fe;--rm-add-text: #4338ca;--rm-chord-accent: #f59e0b;--rm-melody-accent: #8b5cf6;--rm-section-accent: #3b82f6;--rm-harmonize-accent: #14b8a6;--rm-texture-accent: #ec4899;--rm-space-xs: 4px;--rm-space-sm: 6px;--rm-space-md: 10px;--rm-space-lg: 14px;--rm-space-xl: 18px;--rm-font-xs: 10px;--rm-font-sm: 11px;--rm-font-base: 12px;--rm-font-md: 13px;--rm-font-lg: 14px;--rm-font-xl: 16px;--rm-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--rm-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--rm-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--rm-shadow-modal: 0 25px 50px -12px rgba(0, 0, 0, .25);--rm-radius-sm: 4px;--rm-radius-md: 6px;--rm-radius-lg: 8px;--rm-radius-xl: 10px;--rm-radius-full: 9999px;--rm-transition: .15s ease}.rm-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:99999}.rm-modal{background:var(--rm-bg);border-radius:var(--rm-radius-xl);width:95%;max-width:850px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--rm-shadow-modal);overflow:hidden}.rm-header{display:flex;justify-content:space-between;align-items:center;padding:var(--rm-space-md) var(--rm-space-lg);border-bottom:1px solid var(--rm-border);background:linear-gradient(135deg,var(--rm-primary) 0%,var(--rm-primary-dark) 100%);color:#fff}.rm-header-title{margin:0;font-size:var(--rm-font-xl);font-weight:600}.rm-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#fff;opacity:.8;line-height:1;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--rm-radius-sm);transition:opacity var(--rm-transition),background var(--rm-transition)}.rm-close-btn:hover{opacity:1;background:#ffffff1a}.rm-progression-bar{padding:6px 12px;background:linear-gradient(135deg,#f0f4ff,#faf5ff);border-bottom:1px solid var(--rm-border);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.rm-progression-label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--rm-text-secondary);white-space:nowrap}.rm-progression-label-icon{font-size:12px}.rm-progression-label-key{color:var(--rm-text-muted);font-weight:400}.rm-separator{width:1px;height:16px;background:var(--rm-border-dark);margin:0 2px}.rm-chips-container{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.rm-chord-chip{padding:2px 6px;border-radius:var(--rm-radius-sm);font-size:var(--rm-font-sm);cursor:pointer;transition:all var(--rm-transition);border:1px solid transparent;background:#fff;color:var(--rm-text-secondary)}.rm-chord-chip:hover{background:var(--rm-bg-hover);border-color:var(--rm-border-dark)}.rm-chord-chip.selected{background:var(--rm-secondary-light);border-color:var(--rm-secondary);color:var(--rm-secondary);font-weight:600}.rm-chord-chip.section-start{border-left:2px solid;padding-left:4px}.rm-add-chip{padding:2px 6px;border:1px dashed var(--rm-border-dark);border-radius:var(--rm-radius-sm);background:transparent;color:var(--rm-text-muted);font-size:var(--rm-font-xs);font-weight:400;cursor:pointer;transition:all var(--rm-transition)}.rm-add-chip:hover{border-color:#10b981;color:#10b981}.rm-add-chip.selected{border-color:#10b981;background:#ecfdf5;color:#10b981;font-weight:600}.rm-selection-indicator{font-size:var(--rm-font-xs);color:var(--rm-text-muted);white-space:nowrap;padding:2px 6px;background:#fff;border-radius:var(--rm-radius-sm);border:1px solid var(--rm-border)}.rm-tabs{display:flex;gap:4px;padding:6px 8px;background:#e5e7eb;border-bottom:none;border-radius:8px;margin:0 12px;justify-content:stretch}.rm-tabs>div{flex:1;display:flex;align-items:center;justify-content:center}.rm-tab{flex:1;padding:8px 12px;background:transparent;border:1px solid transparent;border-radius:6px;font-size:var(--rm-font-md);font-weight:500;cursor:pointer;transition:all .15s ease;color:#6b7280;text-align:center}.rm-tab:hover:not(:disabled):not(.active){background:#ffffff80;color:#374151}.rm-tab.active{background:#fff;color:var(--rm-primary);border-color:var(--rm-primary);box-shadow:0 1px 3px #0000001a;font-weight:600}.rm-tab:disabled{cursor:not-allowed;color:#9ca3af;opacity:.6}.rm-context-bar{padding:6px 12px;background:var(--rm-bg-subtle);border-bottom:1px solid var(--rm-border);display:flex;flex-wrap:wrap;gap:8px;align-items:center}.rm-content{flex:1;overflow-y:auto;padding:var(--rm-space-md);min-height:350px}.rm-view-toggle{display:flex;gap:var(--rm-space-sm);margin-bottom:var(--rm-space-md)}.rm-view-btn{padding:4px 10px;border:1px solid var(--rm-border-dark);border-radius:var(--rm-radius-full);background:#fff;color:var(--rm-text-muted);font-size:var(--rm-font-sm);cursor:pointer;font-weight:400;transition:all var(--rm-transition)}.rm-view-btn:hover{background:var(--rm-bg-hover)}.rm-view-btn.active{border-color:var(--rm-primary);background:var(--rm-primary-light);color:var(--rm-primary);font-weight:600}.rm-intent-nav{display:flex;gap:var(--rm-space-xs);margin-bottom:var(--rm-space-md);flex-wrap:wrap}.rm-intent-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--rm-border);border-radius:var(--rm-radius-md);background:#fff;color:var(--rm-text-muted);font-size:var(--rm-font-sm);cursor:pointer;transition:all var(--rm-transition)}.rm-intent-btn:hover{background:var(--rm-bg-hover);border-color:var(--rm-border-dark)}.rm-intent-btn.active{background:var(--rm-primary-light);border-color:var(--rm-primary);color:var(--rm-primary);font-weight:600}.rm-card{padding:var(--rm-space-sm) var(--rm-space-md);background:#fff;border:1px solid var(--rm-border);border-left-width:3px;border-radius:var(--rm-radius-md);display:flex;align-items:center;gap:var(--rm-space-sm);cursor:pointer;transition:all var(--rm-transition);margin-bottom:var(--rm-space-sm)}.rm-card:hover{background:var(--rm-bg-subtle);border-color:var(--rm-border-dark)}.rm-card:last-child{margin-bottom:0}.rm-card-shortcut{width:20px;height:20px;border-radius:var(--rm-radius-sm);background:var(--rm-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--rm-font-xs);font-weight:600;flex-shrink:0}.rm-card-info{flex:1;min-width:0}.rm-card-title{font-weight:600;color:var(--rm-text);font-size:var(--rm-font-md)}.rm-card-subtitle{color:var(--rm-text-muted);font-weight:400;font-size:var(--rm-font-sm);margin-left:4px}.rm-card-reason{font-size:var(--rm-font-xs);color:var(--rm-text-muted);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rm-badge{padding:2px 6px;border-radius:var(--rm-radius-sm);font-size:var(--rm-font-xs);font-weight:600;flex-shrink:0}.rm-badge-duration{background:var(--rm-primary-light);color:#6366f1}.rm-badge-score{color:#fff;cursor:help;transition:transform var(--rm-transition),box-shadow var(--rm-transition)}.rm-badge-score:hover{transform:scale(1.05)}.rm-badge-score.excellent{background:var(--rm-score-excellent)}.rm-badge-score.good{background:var(--rm-score-good)}.rm-badge-score.fair{background:var(--rm-score-fair)}.rm-badge-score.poor{background:var(--rm-score-poor)}.rm-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 10px;border-radius:var(--rm-radius-md);font-size:var(--rm-font-sm);font-weight:500;cursor:pointer;transition:all var(--rm-transition);border:1px solid transparent}.rm-btn-primary{background:var(--rm-primary);color:#fff;border-color:var(--rm-primary)}.rm-btn-primary:hover{background:var(--rm-primary-hover);border-color:var(--rm-primary-hover)}.rm-btn-secondary{background:#fff;color:var(--rm-text-secondary);border-color:var(--rm-border-dark)}.rm-btn-secondary:hover{background:var(--rm-bg-hover)}.rm-btn-ghost{background:transparent;color:var(--rm-text-muted);border-color:transparent}.rm-btn-ghost:hover{background:var(--rm-bg-hover);color:var(--rm-text-secondary)}.rm-btn-icon{width:24px;height:24px;padding:0;border-radius:50%}.rm-btn-why{width:22px;height:22px;border-radius:50%;background:var(--rm-primary);color:#fff;border:none;cursor:pointer;font-size:var(--rm-font-sm);font-weight:700;flex-shrink:0;transition:background var(--rm-transition)}.rm-btn-why:hover{background:var(--rm-primary-hover)}.rm-btn-action{background:var(--rm-action);color:var(--rm-action-text);border-color:var(--rm-action-hover);font-weight:600}.rm-btn-action:hover{background:var(--rm-action-hover);border-color:var(--rm-action-text)}.rm-btn-apply{background:var(--rm-success);color:var(--rm-success-text);border-color:var(--rm-success-hover);font-weight:600}.rm-btn-apply:hover{background:var(--rm-success-hover);border-color:var(--rm-success-text)}.rm-btn-add{background:var(--rm-add);color:var(--rm-add-text);border-color:var(--rm-add-hover);font-weight:600}.rm-btn-add:hover{background:var(--rm-add-hover);border-color:var(--rm-add-text)}.rm-select{padding:4px 8px;border:1px solid var(--rm-border-dark);border-radius:var(--rm-radius-md);font-size:var(--rm-font-sm);background:#fff;cursor:pointer;color:var(--rm-text-secondary)}.rm-select:focus{outline:none;border-color:var(--rm-primary);box-shadow:0 0 0 2px #8b5cf633}.rm-empty{text-align:center;padding:var(--rm-space-xl) var(--rm-space-lg);color:var(--rm-text-muted)}.rm-empty-icon{font-size:36px;margin-bottom:var(--rm-space-md)}.rm-empty-title{margin:0 0 var(--rm-space-sm) 0;font-size:var(--rm-font-lg);color:var(--rm-text-secondary)}.rm-empty-text{margin:0;font-size:var(--rm-font-md)}.rm-banner{border-radius:var(--rm-radius-md);padding:var(--rm-space-sm) var(--rm-space-md);margin-bottom:var(--rm-space-md);font-size:var(--rm-font-sm)}.rm-banner-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.rm-banner-success{background:#f0fdf4;border:1px solid #86efac;color:#166534}.rm-banner-warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}.rm-current-chord{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);padding:var(--rm-space-md);border-radius:var(--rm-radius-md);margin-bottom:var(--rm-space-md);border:2px solid #86efac;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--rm-space-sm)}.rm-current-chord-icon{width:48px;height:48px;border-radius:var(--rm-radius-lg);background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--rm-font-xl);font-weight:700}.rm-current-chord-title{font-size:var(--rm-font-xl);font-weight:700;color:#166534}.rm-current-chord-subtitle{font-size:var(--rm-font-sm);color:#15803d}.rm-chord-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--rm-space-sm)}.rm-chord-grid-item{padding:var(--rm-space-sm);background:#fff;border:1px solid var(--rm-border);border-radius:var(--rm-radius-md);cursor:pointer;transition:all var(--rm-transition);text-align:center}.rm-chord-grid-item:hover{background:var(--rm-bg-subtle);border-color:var(--rm-border-dark);transform:translateY(-1px)}.rm-chord-grid-item.selected{border-color:var(--rm-primary);background:var(--rm-primary-light)}.rm-section{margin-bottom:var(--rm-space-md)}.rm-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--rm-space-sm);background:var(--rm-bg-subtle);border-radius:var(--rm-radius-md);cursor:pointer;font-size:var(--rm-font-md);font-weight:600;color:var(--rm-text-secondary);transition:background var(--rm-transition)}.rm-section-header:hover{background:var(--rm-bg-hover)}.rm-section-content{padding:var(--rm-space-sm) 0}.rm-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--rm-space-xl);color:var(--rm-text-muted)}.rm-spinner{width:32px;height:32px;border:3px solid var(--rm-border);border-top-color:var(--rm-primary);border-radius:50%;animation:rm-spin .8s linear infinite;margin-bottom:var(--rm-space-md)}@keyframes rm-spin{to{transform:rotate(360deg)}}.rm-content::-webkit-scrollbar{width:6px}.rm-content::-webkit-scrollbar-track{background:#0000000d}.rm-content::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:3px}.rm-content::-webkit-scrollbar-thumb:hover{background:#8b5cf680}@media (max-width: 640px){.rm-modal{width:100%;max-width:none;max-height:100vh;border-radius:0}.rm-tabs{overflow-x:auto}.rm-tab{padding:var(--rm-space-xs) var(--rm-space-sm);font-size:var(--rm-font-sm);white-space:nowrap}.rm-progression-bar{padding:var(--rm-space-xs) var(--rm-space-sm)}.rm-chord-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}:root{--color-builder: #f59e0b;--color-melody: #8b5cf6;--color-scales: #84cc16;--color-learn: #3b82f6;--color-primary: #8b5cf6;--builder-color: #f59e0b;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);--gradient-teal: linear-gradient(135deg, #14b8a6 0%, #0d9488 100%);--gradient-lime: linear-gradient(135deg, #84cc16 0%, #65a30d 100%);--gradient-purple: linear-gradient(135deg, #8b5cf6 0%, #a855f7 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-info: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--shadow-soft: 0 10px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-glow: 0 0 20px rgba(102, 126, 234, .3);--header-height: 60px;--keyboard-height: 120px;--card-bg: #ffffff;--card-border: #e5e7eb;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--card-shadow-hover: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--card-radius: 16px;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--text-muted: #9ca3af}#action-bar{transition:border-color .3s ease,box-shadow .3s ease}body[data-active-tab=builder] #action-bar{border-color:#f59e0b4d;box-shadow:0 2px 8px #f59e0b1a}body[data-active-tab=trainer] #action-bar{border-color:#a855f74d;box-shadow:0 2px 8px #a855f71a}body[data-active-tab=melody] #action-bar{border-color:#8b5cf64d;box-shadow:0 2px 8px #8b5cf61a}body[data-active-tab=scales] #action-bar{border-color:#14b8a64d;box-shadow:0 2px 8px #14b8a61a}body[data-active-tab=learn] #action-bar{border-color:#22c55e4d;box-shadow:0 2px 8px #22c55e1a}body[data-active-tab=builder] .melody-only,body[data-active-tab=trainer] .melody-only,body[data-active-tab=scales] .melody-only,body[data-active-tab=learn] .melody-only,body[data-active-tab=builder] .trainer-melody-only,body[data-active-tab=scales] .trainer-melody-only,body[data-active-tab=learn] .trainer-melody-only,body[data-active-tab=trainer] .builder-only,body[data-active-tab=melody] .builder-only,body[data-active-tab=scales] .builder-only,body[data-active-tab=learn] .builder-only{display:none!important}.section-header-connected{border-bottom-left-radius:0!important;border-bottom-right-radius:0!important}.section-panel-connected{margin-top:0!important;border-top-left-radius:0!important;border-top-right-radius:0!important;border-left:3px solid currentColor}#chord-setup-panel,#chord-library-panel,#chord-intervals-panel,#progression-controls-panel,#progression-visualization-panel,#suggestions-panel,#melody-controls-panel,#scale-info-panel,#style-mood-insights-panel,#chord-progression-card-panel,#staff-notation-card-panel,#builder-progression-panel{border-left:3px solid}#chord-setup-panel{border-left-color:#f59e0b}#chord-library-panel{border-left-color:#0ea5e9}#chord-intervals-panel{border-left-color:#84cc16}#progression-controls-panel{border-left-color:#0d9488}#progression-visualization-panel{border-left-color:#a855f7}#suggestions-panel{border-left-color:#6366f1}#scale-info-panel{border-left-color:#84cc16}#melody-controls-panel{border-left-color:#8b5cf6}#style-mood-insights-panel{border-left-color:#f59e0b}#chord-progression-card-panel{border-left-color:#a855f7}#staff-notation-card-panel{border-left-color:#0ea5e9}#builder-progression-panel{border-left-color:#a855f7}body{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}#sidebar{background:linear-gradient(135deg,#1e293bf2,#0f172afa);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-soft)}.custom-scrollbar{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb, rgba(0, 0, 0, .2)) var(--scrollbar-track, rgba(0, 0, 0, .05))}.custom-scrollbar::-webkit-scrollbar{width:6px;height:6px}.custom-scrollbar::-webkit-scrollbar-track{background:var(--scrollbar-track, rgba(0, 0, 0, .05));border-radius:3px}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb, rgba(0, 0, 0, .2));border-radius:3px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover, rgba(0, 0, 0, .3))}.custom-scrollbar-dark{scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.5) rgba(0,0,0,.2)}.custom-scrollbar-dark::-webkit-scrollbar{width:6px;height:6px}.custom-scrollbar-dark::-webkit-scrollbar-track{background:#0003;border-radius:3px}.custom-scrollbar-dark::-webkit-scrollbar-thumb{background:#8b5cf680;border-radius:3px}.custom-scrollbar-dark::-webkit-scrollbar-thumb:hover{background:#8b5cf6b3}#sidebar{scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.5) rgba(0,0,0,.2)}#sidebar::-webkit-scrollbar{width:6px}#sidebar::-webkit-scrollbar-track{background:#0003;border-radius:3px}#sidebar::-webkit-scrollbar-thumb{background:#8b5cf680;border-radius:3px}#sidebar::-webkit-scrollbar-thumb:hover{background:#8b5cf6b3}#header-expand-collapse-group .group:hover .absolute{pointer-events:auto!important}#header-expand-collapse-group .group .absolute{transition-delay:0s}#header-expand-collapse-group .group:hover .absolute{transition-delay:.1s}.panel-base{border-radius:var(--card-radius, 16px);box-shadow:var(--card-shadow, 0 4px 6px -1px rgba(0, 0, 0, .1));transition:box-shadow .2s ease,transform .2s ease}.panel-base:hover{box-shadow:var(--card-shadow-hover, 0 10px 15px -3px rgba(0, 0, 0, .1))}.panel-light{background:#fff;border:1px solid var(--card-border, #e5e7eb)}.panel-glass{background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.panel-dark{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(100,200,255,.2);color:#eaeaea}.panel-floating{box-shadow:0 8px 32px #00000026,0 4px 12px #0000001a;border-radius:12px}.panel-floating.panel-dark{box-shadow:0 8px 32px #00000080,0 0 20px #64c8ff26}.panel-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.panel-card{background:#fff;padding:1rem;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.panel-card-amber{border:1px solid rgba(245,158,11,.2)}.panel-card-purple{border:1px solid rgba(139,92,246,.2)}.panel-card-teal{border:1px solid rgba(13,148,136,.2)}.panel-card-lime{border:1px solid rgba(132,204,22,.2)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(0,0,0,.1)}.panel-header-dark{background:#ffffff0d;border-bottom:1px solid rgba(100,200,255,.2)}.panel-body{padding:1rem;overflow-y:auto}.panel-footer{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem;border-top:1px solid rgba(0,0,0,.1)}#sidebar h2{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:-.5px}.sidebar-btn{transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.sidebar-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.sidebar-btn:hover:before{left:100%}.sidebar-btn:hover{transform:translate(4px);box-shadow:0 4px 12px #667eea4d}#sidebar .border-t{border-color:#ffffff1a}#sidebar .flex.flex-col.gap-2>div{min-height:2rem;display:flex;align-items:center}.toggle-bg{position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #0003}input:checked+.toggle-bg{background:var(--gradient-primary);box-shadow:0 0 15px #667eea80}.toggle-bg:after{box-shadow:0 2px 4px #0000004d}.settings-group{margin-bottom:.5rem}.settings-group-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.5rem}.settings-group-header:hover{background:#ffffff0d;border-radius:.375rem;margin:0 -.5rem;padding:.5rem}.settings-group-title{display:flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.settings-group-title svg{opacity:.7}.settings-group-chevron{width:1rem;height:1rem;color:#6b7280;transition:transform .2s ease}.settings-group.collapsed .settings-group-chevron{transform:rotate(-90deg)}.settings-group-content{display:flex;flex-direction:column;gap:.5rem;padding-left:.25rem;overflow:hidden;transition:max-height .3s ease,opacity .2s ease}.settings-group.collapsed .settings-group-content{max-height:0;opacity:0;margin-bottom:0}.settings-group:not(.collapsed) .settings-group-content{max-height:500px;opacity:1}:focus-visible{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:2px}:focus:not(:focus-visible){outline:none}button:focus-visible,[role=button]:focus-visible{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:2px;box-shadow:0 0 0 4px #8b5cf633}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:0;box-shadow:0 0 0 3px #8b5cf626}.toggle-bg:focus-visible,label:has(input[type=checkbox]):focus-within .toggle-bg{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:2px;box-shadow:0 0 0 4px #8b5cf633}#header-tab-btn-builder:focus-visible,#header-tab-btn-trainer:focus-visible,#header-tab-btn-melody:focus-visible,#header-tab-btn-scales:focus-visible,#header-tab-btn-learn:focus-visible,.sidebar-btn:focus-visible{outline:2px solid white;outline-offset:2px;box-shadow:0 0 0 4px #ffffff4d}a:focus-visible{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:2px;text-decoration:underline}[tabindex]:focus-visible{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:2px}.chord-card:focus-visible,.progression-chord-card:focus-visible{outline:3px solid var(--color-primary, #8b5cf6);outline-offset:2px;box-shadow:0 0 0 6px #8b5cf640}.piano-key:focus-visible{outline:3px solid var(--color-primary, #8b5cf6);z-index:5}.section-panel-header:focus-visible{outline:2px solid var(--color-primary, #8b5cf6);outline-offset:-2px;background-color:#8b5cf61a}.settings-group-header:focus-visible{outline:2px solid white;outline-offset:2px;border-radius:.375rem}@media (prefers-contrast: high){:focus-visible{outline:3px solid currentColor;outline-offset:3px}button:focus-visible,a:focus-visible,input:focus-visible{outline-width:3px}}@media (prefers-reduced-motion: reduce){*{transition-duration:0ms!important;animation-duration:0ms!important}}.bg-primary{background-color:var(--color-primary)!important}.bg-success{background-color:var(--color-success)!important}.text-primary{color:var(--color-primary)!important}.text-muted{color:var(--text-muted)!important}.border-primary{border-color:var(--color-primary)!important}.bg-gradient-primary{background:var(--gradient-primary)!important}.chord-tonic{background-color:#10b981!important}.chord-subdominant{background-color:#3b82f6!important}.chord-dominant{background-color:#f59e0b!important}.chord-secondary{background-color:#8b5cf6!important}.chord-borrowed{background-color:#ec4899!important}.score-excellent{background-color:#10b981!important;color:#fff!important}.score-good{background-color:#3b82f6!important;color:#fff!important}.score-fair{background-color:#f59e0b!important;color:#fff!important}.score-poor{background-color:#ef4444!important;color:#fff!important}.grid.items-center.bg-white\/80{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);box-shadow:var(--shadow-soft)}#main-title{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:-.5px}.header-tab-pill{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.375rem;font-size:.6875rem;color:#6b7280;background:transparent;border:1px solid transparent;transition:all .2s ease;white-space:nowrap;height:40px;flex-shrink:0}.header-tab-pill:hover{background:#f3f4f6;color:#374151}.header-tab-pill[data-tab=builder].active{background:var(--gradient-amber);color:#fff;border-color:transparent;box-shadow:0 2px 8px #f59e0b59}.header-tab-pill[data-tab=melody].active{background:var(--gradient-purple);color:#fff;border-color:transparent;box-shadow:0 2px 8px #8b5cf659}.header-tab-pill[data-tab=scales].active{background:var(--gradient-lime);color:#fff;border-color:transparent;box-shadow:0 2px 8px #84cc1659}.header-tab-pill[data-tab=learn].active{background:var(--gradient-info);color:#fff;border-color:transparent;box-shadow:0 2px 8px #3b82f659}.header-tab-pill[data-tab=builder]:not(.active):hover{background:#f59e0b1a;color:#d97706;border-color:#f59e0b33}.header-tab-pill[data-tab=melody]:not(.active):hover{background:#8b5cf61a;color:#7c3aed;border-color:#8b5cf633}.header-tab-pill[data-tab=scales]:not(.active):hover{background:#84cc161a;color:#65a30d;border-color:#84cc1633}.header-tab-pill[data-tab=learn]:not(.active):hover{background:#3b82f61a;color:#2563eb;border-color:#3b82f633}.header-displays-container{max-width:400px;opacity:1}.header-displays-container.collapsed{max-width:0;opacity:0;margin:0;padding:0}#header-displays-chevron{transform:rotate(0)}.header-displays-collapsed #header-displays-chevron{transform:rotate(180deg)}#sidebar-btn-builder.bg-orange-500{background:var(--gradient-amber);box-shadow:0 4px 15px #f59e0b66}#sidebar-btn-trainer.bg-teal-600{background:var(--gradient-teal);box-shadow:0 4px 15px #0d948866}.tab-content>div{background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);box-shadow:var(--shadow-soft);transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-content>div:hover{box-shadow:0 20px 40px -10px #00000026}h3.text-lg{background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:-.3px}button,.key-button{transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}button:hover:not(:disabled),.key-button:hover:not(.bg-amber-500){transform:translateY(-2px);box-shadow:0 8px 16px -4px #0003}button:active:not(:disabled),.key-button:active{transform:translateY(0)}.selected-key{box-shadow:0 0 0 4px var(--builder-color),0 15px 25px -5px #00000026;animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 0 4px var(--builder-color),0 15px 25px -5px #00000026}50%{box-shadow:0 0 0 4px var(--builder-color),0 15px 25px -5px #f59e0b66}}.keyboard{display:flex;position:relative;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;height:150px;border:1px solid #aaa;box-shadow:inset 0 0 10px #0000001a;background-color:#f3f4f6;width:100%;overflow-x:auto}.key{position:relative;border:1px solid #000;border-radius:0 0 4px 4px;transition:background-color .1s;box-sizing:border-box;cursor:pointer;flex-shrink:0}.white-key{height:100%;background:#fff;z-index:1;border-color:#ccc;display:flex;align-items:flex-end;justify-content:center;font-size:.6rem;padding-bottom:5px}.black-key{height:60%;background:#000;z-index:2;border-color:#000;position:absolute}.modern-keyboard.keyboard{border:2px solid rgba(0,0,0,.15);border-radius:12px;box-shadow:inset 0 2px 8px #0000001a,0 8px 32px #00000026,0 0 0 1px #ffffff1a inset;background:linear-gradient(180deg,#f8f9fa,#e9ecef);padding:0;height:180px!important}.modern-keyboard .key{border-radius:0 0 8px 8px;transition:all .15s cubic-bezier(.4,0,.2,1);transform-origin:bottom}.modern-keyboard .white-key{height:100%;margin:0;border-right:none;background:linear-gradient(180deg,#fff,#f8f9fa,#f1f3f5);border:1px solid rgba(0,0,0,.1);border-top:2px solid rgba(255,255,255,.8);border-bottom:1px solid rgba(0,0,0,.2);box-shadow:inset 0 1px #ffffffe6,inset 0 -1px #0000000d,0 2px 4px #0000001a,0 1px 2px #0000000d}.modern-keyboard .white-key:last-child{border-right:1px solid rgba(0,0,0,.1)}.modern-keyboard .white-key:hover:not(.active-scale):not(.active-progression):not(.active-builder):not(.active-builder-playback):not(.active-scale-explorer):not(.active-scale-playback):not(.active-melody-playback){background:linear-gradient(180deg,#fff,#f8f9fa,#e9ecef);box-shadow:inset 0 1px #ffffffe6,inset 0 -1px #0000000d,0 4px 8px #00000026,0 2px 4px #0000001a;transform:translateY(-1px)}.modern-keyboard .white-key:active:not(.active-scale):not(.active-progression):not(.active-builder):not(.active-builder-playback):not(.active-scale-explorer):not(.active-scale-playback):not(.active-melody-playback){background:linear-gradient(180deg,#f1f3f5,#e9ecef,#dee2e6);box-shadow:inset 0 2px 4px #0000001a,inset 0 -1px #0000000d,0 1px 2px #0000001a;transform:none}.modern-keyboard .white-key.active-builder-playback,.modern-keyboard .white-key.active-scale-playback,.modern-keyboard .white-key.active-melody-playback,.modern-keyboard .white-key.active-progression,.modern-keyboard .white-key.active-builder,.modern-keyboard .white-key.active-scale,.modern-keyboard .white-key.active-scale-explorer,.modern-keyboard .black-key.active-builder-playback,.modern-keyboard .black-key.active-scale-playback,.modern-keyboard .black-key.active-melody-playback,.modern-keyboard .black-key.active-progression,.modern-keyboard .black-key.active-builder,.modern-keyboard .black-key.active-scale,.modern-keyboard .black-key.active-scale-explorer{animation:none!important;transform:none!important}.modern-keyboard .white-key.active-progression{background:linear-gradient(180deg,#14b8a6,#0d9488)!important;box-shadow:0 0 20px #14b8a680,0 4px 12px #14b8a64d,inset 0 1px #ffffff4d,inset 0 -2px #0d948899!important;border-color:#0d948866!important;border-top:2px solid rgba(13,148,136,.4)!important;border-bottom:1px solid rgba(13,148,136,.6)!important}.modern-keyboard .black-key.active-progression{background:linear-gradient(180deg,#0f766e,#115e59)!important;box-shadow:0 0 20px #14b8a699,0 4px 12px #14b8a666,inset 0 1px #fff3,inset 0 -2px #115e59cc!important;border-color:#115e5999!important;border-top:1px solid rgba(17,94,89,.6)!important}.white-key.active-scale-explorer.active-scale-playback,.black-key.active-scale-explorer.active-scale-playback{background:linear-gradient(180deg,#84cc16,#65a30d)!important;box-shadow:0 0 20px #84cc1699,0 4px 12px #84cc1666,inset 0 1px #ffffff4d,inset 0 -2px #65a30d99!important;border-color:#84cc1680!important;animation:glow-pulse-lime 1.5s infinite,key-press-scale .3s ease-out!important}.black-key.active-scale-explorer.active-scale-playback{background:linear-gradient(180deg,#4d7c0f,#365314)!important;box-shadow:0 0 20px #84cc16b3,0 4px 12px #84cc1680,inset 0 1px #fff3,inset 0 -2px #365314cc!important;border-color:#4d7c0fb3!important;animation:glow-pulse-lime 1.5s infinite,key-press-scale .3s ease-out!important}.modern-keyboard .white-key.active-scale-explorer.active-scale-playback,.modern-keyboard .black-key.active-scale-explorer.active-scale-playback{background:linear-gradient(180deg,#84cc16,#65a30d)!important;box-shadow:0 0 20px #84cc1699,0 4px 12px #84cc1666,inset 0 1px #ffffff4d,inset 0 -2px #65a30d99!important;border-color:#84cc1680!important;animation:none!important;transform:none!important}.modern-keyboard .black-key.active-scale-explorer.active-scale-playback{background:linear-gradient(180deg,#4d7c0f,#365314)!important;box-shadow:0 0 20px #84cc16b3,0 4px 12px #84cc1680,inset 0 1px #fff3,inset 0 -2px #365314cc!important;border-color:#4d7c0fb3!important;animation:none!important;transform:none!important}.modern-keyboard .black-key{background:linear-gradient(180deg,#1a1a1a,#000,#0a0a0a);border:1px solid rgba(0,0,0,.8);border-top:1px solid rgba(100,100,100,.3);box-shadow:inset 0 1px #ffffff1a,inset 0 -2px 4px #000c,0 4px 8px #0006,0 2px 4px #0000004d;border-radius:0 0 6px 6px}.modern-keyboard .black-key:hover:not(.active-scale):not(.active-progression):not(.active-builder):not(.active-builder-playback):not(.active-scale-explorer):not(.active-scale-playback):not(.active-melody-playback){background:linear-gradient(180deg,#2a2a2a,#1a1a1a,#0f0f0f);box-shadow:inset 0 1px #ffffff26,inset 0 -2px 4px #000c,0 6px 12px #00000080,0 3px 6px #0006;transform:translateY(-1px)}.modern-keyboard .black-key:active:not(.active-scale):not(.active-progression):not(.active-builder):not(.active-builder-playback):not(.active-scale-explorer):not(.active-scale-playback):not(.active-melody-playback){background:linear-gradient(180deg,#0a0a0a,#000,#050505);box-shadow:inset 0 2px 4px #000000e6,inset 0 -1px #00000080,0 2px 4px #0000004d;transform:none}.white-key.active-scale{background:linear-gradient(180deg,#67e8f9,#22d3ee);box-shadow:inset 0 -4px #06b6d499,0 0 20px #06b6d466,0 4px 8px #06b6d433,inset 0 1px #ffffff4d;border-color:#06b6d466;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.black-key.active-scale{background:linear-gradient(180deg,#06b6d4,#0891b2);box-shadow:inset 0 -4px #0891b2cc,0 0 20px #06b6d480,0 4px 8px #06b6d44d,inset 0 1px #fff3;border-color:#0891b299;transform:translateY(-1px);animation:key-press-scale .3s ease-out}@keyframes key-press-scale{0%{transform:translateY(0) scaleY(1)}50%{transform:translateY(2px) scaleY(.96)}to{transform:translateY(-1px) scaleY(1)}}.white-key.active-progression{background:linear-gradient(180deg,#14b8a6,#0d9488);box-shadow:0 0 20px #14b8a680,0 4px 12px #14b8a64d,inset 0 1px #ffffff4d,inset 0 -2px #0d948899;border-color:#0d948866;transform:translateY(-1px);animation:glow-pulse 2s infinite,key-press-scale .3s ease-out}.black-key.active-progression{background:linear-gradient(180deg,#0f766e,#115e59);box-shadow:0 0 20px #14b8a699,0 4px 12px #14b8a666,inset 0 1px #fff3,inset 0 -2px #115e59cc;border-color:#115e5999;transform:translateY(-1px);animation:glow-pulse 2s infinite,key-press-scale .3s ease-out}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #14b8a680,0 4px 12px #14b8a64d,inset 0 1px #ffffff4d,inset 0 -2px #0d948899}50%{box-shadow:0 0 30px #14b8a6cc,0 6px 16px #14b8a680,inset 0 1px #ffffff4d,inset 0 -2px #0d948899}}.white-key.active-builder{background:linear-gradient(180deg,#fde68a,#fcd34d);box-shadow:inset 0 -4px #fcd34d99,0 0 20px #fbbf2466,0 4px 8px #fbbf2433,inset 0 1px #fff6;border-color:#fcd34d66;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.black-key.active-builder{background:linear-gradient(180deg,#fcd34d,#fbbf24);box-shadow:inset 0 -4px #f59e0bcc,0 0 20px #fbbf2480,0 4px 8px #fbbf244d,inset 0 1px #ffffff40;border-color:#f59e0b99;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.white-key.active-builder-playback{background:var(--gradient-amber);box-shadow:0 0 20px #f59e0b99,0 4px 12px #f59e0b66,inset 0 1px #fff6,inset 0 -2px #d9770699;border-color:#f59e0b80;transform:translateY(-1px);animation:glow-pulse-amber 1.5s infinite,key-press-scale .3s ease-out}.black-key.active-builder-playback{background:linear-gradient(180deg,#d97706,#b45309);box-shadow:0 0 20px #f59e0bb3,0 4px 12px #f59e0b80,inset 0 1px #ffffff40,inset 0 -2px #b45309cc;border-color:#d97706b3;transform:translateY(-1px);animation:glow-pulse-amber 1.5s infinite,key-press-scale .3s ease-out}@keyframes glow-pulse-amber{0%,to{box-shadow:0 0 20px #f59e0b99,0 4px 12px #f59e0b66,inset 0 1px #fff6,inset 0 -2px #d9770699}50%{box-shadow:0 0 30px #f59e0be6,0 6px 16px #f59e0b99,inset 0 1px #fff6,inset 0 -2px #d9770699}}.white-key.active-scale-explorer{background:linear-gradient(180deg,#d9f99d,#bef264)!important;box-shadow:inset 0 -4px #bef26499,0 0 20px #bef26466,0 4px 8px #bef26433,inset 0 1px #ffffff4d;border-color:#bef26466;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.black-key.active-scale-explorer{background:linear-gradient(180deg,#bef264,#a3e635)!important;box-shadow:inset 0 -4px #a3e635cc,0 0 20px #bef26480,0 4px 8px #bef2644d,inset 0 1px #fff3;border-color:#a3e63599;transform:translateY(-1px);animation:key-press-scale .3s ease-out}.white-key.active-scale-playback{background:linear-gradient(180deg,#84cc16,#65a30d);box-shadow:0 0 20px #84cc1699,0 4px 12px #84cc1666,inset 0 1px #ffffff4d,inset 0 -2px #65a30d99;border-color:#84cc1680;transform:translateY(-1px);animation:glow-pulse-lime 1.5s infinite,key-press-scale .3s ease-out}.black-key.active-scale-playback{background:linear-gradient(180deg,#4d7c0f,#365314);box-shadow:0 0 20px #84cc16b3,0 4px 12px #84cc1680,inset 0 1px #fff3,inset 0 -2px #365314cc;border-color:#4d7c0fb3;transform:translateY(-1px);animation:glow-pulse-lime 1.5s infinite,key-press-scale .3s ease-out}@keyframes glow-pulse-lime{0%,to{box-shadow:0 0 20px #84cc1699,0 4px 12px #84cc1666,inset 0 1px #ffffff4d,inset 0 -2px #65a30d99}50%{box-shadow:0 0 30px #84cc16e6,0 6px 16px #84cc1699,inset 0 1px #ffffff4d,inset 0 -2px #65a30d99}}.white-key.active-melody-playback{background:linear-gradient(180deg,#8b5cf6,#7c3aed);box-shadow:0 0 20px #8b5cf699,0 4px 12px #8b5cf666,inset 0 1px #ffffff4d,inset 0 -2px #7c3aed99;border-color:#8b5cf680;transform:translateY(-1px);animation:glow-pulse-violet 1.5s infinite,key-press-scale .3s ease-out}.black-key.active-melody-playback{background:linear-gradient(180deg,#6d28d9,#5b21b6);box-shadow:0 0 20px #8b5cf6b3,0 4px 12px #8b5cf680,inset 0 1px #fff3,inset 0 -2px #5b21b6cc;border-color:#6d28d9b3;transform:translateY(-1px);animation:glow-pulse-violet 1.5s infinite,key-press-scale .3s ease-out}@keyframes glow-pulse-violet{0%,to{box-shadow:0 0 20px #8b5cf699,0 4px 12px #8b5cf666,inset 0 1px #ffffff4d,inset 0 -2px #7c3aed99}50%{box-shadow:0 0 30px #8b5cf6e6,0 6px 16px #8b5cf699,inset 0 1px #ffffff4d,inset 0 -2px #7c3aed99}}#floating-builder-controls,#floating-trainer-controls,#floating-melody-controls,#floating-scale-controls{background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);box-shadow:var(--shadow-soft),0 0 30px #667eea1a;transition:all .3s cubic-bezier(.4,0,.2,1)}#floating-builder-controls:hover,#floating-trainer-controls:hover,#floating-melody-controls:hover,#floating-scale-controls:hover{box-shadow:0 20px 40px -10px #0003,0 0 40px #667eea26;transform:translateY(-2px)}#floating-builder-controls button,#floating-trainer-controls button,#floating-melody-controls button,#floating-scale-controls button{transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer!important;pointer-events:auto!important}#floating-builder-controls button:before,#floating-trainer-controls button:before,#floating-melody-controls button:before,#floating-scale-controls button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}#floating-builder-controls button:active:before,#floating-trainer-controls button:active:before,#floating-melody-controls button:active:before,#floating-scale-controls button:active:before{width:300px;height:300px}#floating-builder-controls button.bg-amber-500{background:var(--gradient-amber);box-shadow:0 4px 15px #f59e0b66}#floating-builder-controls button.bg-amber-500:hover{box-shadow:0 6px 20px #f59e0b80}#floating-trainer-controls button.bg-teal-600{background:var(--gradient-teal);box-shadow:0 4px 15px #0d948866}#floating-trainer-controls button.bg-teal-600:hover{box-shadow:0 6px 20px #0d948880}#floating-scale-controls button.bg-lime-600,#floating-scale-controls button.bg-lime-500{background:var(--gradient-lime);box-shadow:0 4px 15px #84cc1666}#floating-scale-controls button.bg-lime-600:hover,#floating-scale-controls button.bg-lime-500:hover{box-shadow:0 6px 20px #84cc1680}#progression-visualization>div{transition:all .3s cubic-bezier(.4,0,.2,1)}#progression-visualization,#melody-progression-visualization,#builder-progression-visualization{gap:.25rem!important}#progression-visualization .chord-card-wrapper,#melody-progression-visualization .chord-card-wrapper,#builder-progression-visualization .chord-card-wrapper,[id$=-cards-grid]>.chord-card-wrapper,.scroll-view-container .chord-card-wrapper,.section-filtered-cards .chord-card-wrapper{margin:0!important;box-sizing:border-box!important;flex-shrink:0;padding:4px!important;overflow:visible}[id$=-cards-grid].grid>.chord-card-wrapper:not(.expanded-card-wrapper):not(.has-notation){width:100%!important}[id$=-cards-grid].flex>.chord-card-wrapper:not(.expanded-card-wrapper):not(.has-notation){width:auto!important;min-width:90px}#progression-visualization .chord-card-wrapper:not(.expanded-card-wrapper)>div,#melody-progression-visualization .chord-card-wrapper:not(.expanded-card-wrapper)>div,#builder-progression-visualization .chord-card-wrapper:not(.expanded-card-wrapper)>div,[id$=-cards-grid]>.chord-card-wrapper:not(.expanded-card-wrapper)>div{box-sizing:border-box!important;width:100%!important;max-width:100%!important;overflow:visible!important}.sortable-ghost{opacity:.5;background:#c7d2fe80!important}.sortable-ghost .progression-chord-item{background:#c7d2fe4d!important;border:2px dashed rgba(99,102,241,.6)!important}.sortable-chosen{opacity:.8;cursor:grabbing!important}.sortable-chosen .progression-chord-item{transform:rotate(2deg);box-shadow:0 10px 25px #0000004d!important}.sortable-drag{opacity:.9}#progression-visualization .chord-card-wrapper:not(.shift-right):hover,#melody-progression-visualization .chord-card-wrapper:not(.shift-right):hover,#builder-progression-visualization .chord-card-wrapper:not(.shift-right):hover,[id$=-cards-grid] .chord-card-wrapper:not(.shift-right):hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}#progression-visualization .chord-card-wrapper.shift-right:hover,#melody-progression-visualization .chord-card-wrapper.shift-right:hover,#builder-progression-visualization .chord-card-wrapper.shift-right:hover,[id$=-cards-grid] .chord-card-wrapper.shift-right:hover{transform:translate(var(--card-shift, 0px)) translateY(-4px);box-shadow:0 8px 20px #00000026}.active-progression-card{box-shadow:0 0 20px #6366f180,0 8px 20px #00000026;transform:scale(1.05);animation:card-pulse 2s infinite;z-index:1}.progression-chord-item.ring-4,.active-progression-card.ring-4{box-shadow:0 0 0 4px #a855f780,0 0 20px #6366f180,0 8px 20px #00000026!important}.progression-chord-item .flex.items-center{overflow:visible}.progression-chord-item button{flex-shrink:0}.progression-chord-item{user-select:none;-webkit-user-select:none;-ms-user-select:none}.expanded-card-wrapper{width:fit-content!important;min-width:auto!important;z-index:10;position:relative;box-sizing:border-box;flex-shrink:0}.expanded-card-wrapper .detailed-card{width:fit-content;min-width:auto;box-sizing:border-box}.chord-card-wrapper:not(.expanded-card-wrapper):not(.has-notation){box-sizing:border-box}.chord-card-wrapper.shift-right{position:relative;transform:translate(var(--card-shift, 0px));will-change:transform;transition:transform .3s ease-out}@keyframes card-pulse{0%,to{box-shadow:0 0 20px #6366f180,0 8px 20px #00000026}50%{box-shadow:0 0 30px #6366f1b3,0 12px 30px #0003}}select{transition:all .2s cubic-bezier(.4,0,.2,1);background:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}select:hover{box-shadow:0 4px 12px #0000001a}select:focus{box-shadow:0 0 0 3px #667eea33,0 4px 12px #0000001a}input[type=checkbox]{transition:all .2s cubic-bezier(.4,0,.2,1)}#shared-key-signature-display{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}#builder-info-display{background:linear-gradient(135deg,#fbbf2433,#f59e0b33);border:1px solid rgba(245,158,11,.3)}#progression-chord-display{background:linear-gradient(135deg,#14b8a633,#0d948833);border:1px solid rgba(13,148,136,.3)}#scale-info-display{background:linear-gradient(135deg,#84cc1633,#65a30d33);border:1px solid rgba(101,163,13,.3)}#scale-info-display #scale-name{font-size:.875rem}#scale-info-display #scale-notes-display{font-size:.65rem;letter-spacing:.02em}.suggestion-highlight{box-shadow:0 0 15px #60a5fa99;border-color:#3b82f6;animation:suggestion-pulse 2s infinite}@keyframes suggestion-pulse{0%,to{box-shadow:0 0 15px #60a5fa99}50%{box-shadow:0 0 25px #60a5fae6}}.sortable-ghost{opacity:.4;background:linear-gradient(135deg,#dbeafecc,#bfdbfecc)}#expand-controls-btn{background:var(--gradient-primary);box-shadow:0 4px 15px #667eea66;transition:all .3s cubic-bezier(.4,0,.2,1)}#expand-controls-btn:hover{box-shadow:0 6px 20px #667eea99;transform:scale(1.1)}#message-modal>div{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);box-shadow:var(--shadow-soft)}body.compact-mode #floating-builder-controls,body.compact-mode #floating-trainer-controls,body.compact-mode #floating-melody-controls,body.compact-mode #floating-scale-controls{width:auto!important;max-width:none!important;min-width:fit-content!important;padding:.5rem!important}body.compact-mode #floating-builder-controls>div,body.compact-mode #floating-trainer-controls>div,body.compact-mode #floating-melody-controls>div,body.compact-mode #floating-scale-controls>div{align-items:center!important}body.compact-mode #floating-builder-controls button,body.compact-mode #floating-trainer-controls button,body.compact-mode #floating-melody-controls button,body.compact-mode #floating-scale-controls button{padding:.25rem .5rem!important;font-size:.75rem!important;border-radius:8px!important;flex-shrink:0!important}body.compact-mode #floating-builder-controls button,body.compact-mode #floating-trainer-controls button{width:100%!important;min-width:0!important}body.compact-mode #floating-builder-controls button svg,body.compact-mode #floating-trainer-controls button svg,body.compact-mode #floating-melody-controls button svg,body.compact-mode #floating-scale-controls button svg{width:1rem!important;height:1rem!important;flex-shrink:0}.compact-show{display:none!important}.compact-hide{display:block!important}.compact-hide.inline{display:inline!important}body.compact-mode .compact-hide{display:none!important}body.compact-mode .compact-show{display:inline!important}body.compact-mode .compact-show.block{display:block!important}.bg-gray-50\/50{background:#f9fafbb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);transition:all .3s cubic-bezier(.4,0,.2,1)}.bg-gray-50\/50:hover{background:#f9fafbe6;box-shadow:0 4px 12px #00000014}.key-label-roman{text-shadow:0 1px 2px rgba(0,0,0,.1);font-weight:800;letter-spacing:-.5px}*{scroll-behavior:smooth}body.dark-mode{background:#1a1a2e;color:#e0e0e0}body.dark-mode .bg-gray-50{background:#16213e!important}body.dark-mode .bg-gray-100{background:#1e2a47!important}body.dark-mode .bg-white,body.dark-mode .bg-white\/80{background:#1e2a47f2!important}body.dark-mode .bg-gray-50\/50{background:#16213ecc!important}body.dark-mode .text-gray-800{color:#e8e8e8!important}body.dark-mode .text-gray-700{color:#d8d8d8!important}body.dark-mode .text-gray-600{color:silver!important}body.dark-mode .text-gray-500{color:#a8a8a8!important}body.dark-mode .text-gray-900{color:#f5f5f5!important}body.dark-mode .text-gray-400{color:#909090!important}body.dark-mode .text-gray-300{color:#d0d0d0!important}body.dark-mode .text-gray-200{color:#e0e0e0!important}body.dark-mode .border-gray-200,body.dark-mode .border-gray-300{border-color:#2a3f5f!important}body.dark-mode input[type=text],body.dark-mode input[type=number],body.dark-mode select,body.dark-mode textarea{background:#1e2a47!important;color:#e0e0e0!important;border-color:#2a3f5f!important}body.dark-mode input::placeholder{color:#707070!important}body.dark-mode .circle-of-fifths-content,body.dark-mode .guitar-fretboard-content,body.dark-mode .preset-panel-content{background:#1e2a47fa!important}body.dark-mode .circle-of-fifths-info,body.dark-mode .guitar-fretboard-info,body.dark-mode .preset-panel-toolbar{background:#16213ee6!important}body.dark-mode .preset-card{background:#1e2a47!important;border-color:#2a3f5f!important}body.dark-mode .preset-card:hover{border-color:#667eea!important}body.dark-mode button:not([class*=bg-gradient]):not([class*=bg-blue]):not([class*=bg-green]):not([class*=bg-red]):not([class*=bg-indigo]):not([class*=bg-teal]):not([class*=bg-orange]):not([class*=bg-amber]):not([class*=bg-lime]){background:#2a3f5f!important;color:#e0e0e0!important}body.dark-mode .modern-keyboard.keyboard{background:linear-gradient(180deg,#1e2a47,#16213e)!important;border-color:#2a3f5f80!important}body.dark-mode .modern-keyboard .white-key{background:linear-gradient(180deg,#e5e5e5,#d0d0d0,silver)!important;border-color:#64646466!important;border-top:2px solid rgba(255,255,255,.6)!important}body.dark-mode .modern-keyboard .black-key{background:linear-gradient(180deg,#0a0a0a,#000,#000)!important}body.dark-mode #floating-builder-controls,body.dark-mode #floating-trainer-controls,body.dark-mode #floating-melody-controls,body.dark-mode #floating-scale-controls{background:#1e2a47f2!important;border-color:#2a3f5f80!important}body.dark-mode #builder-info-display,body.dark-mode #progression-chord-display,body.dark-mode #scale-info-display{background:#16213ee6!important}body.dark-mode #progression-visualization{background:#16213e!important;border-color:#2a3f5f!important}body.dark-mode #theory-tools-toggle{background:linear-gradient(135deg,#6b21a8,#4338ca)!important}body.dark-mode #theory-tools-toggle:hover{background:linear-gradient(135deg,#7e22ce,#4f46e5)!important}body.dark-mode #theory-tools-panel{background:linear-gradient(135deg,#581c8726,#3730a326)!important;border-color:#8b5cf64d!important}body.dark-mode #theory-tools-panel .bg-white{background:#1e2a47cc!important;border-color:#8b5cf633!important}body.dark-mode #theory-tools-panel .bg-purple-100{background:#6d28d94d!important}body.dark-mode #theory-tools-panel .bg-purple-100:hover{background:#6d28d966!important}body.dark-mode #theory-tools-panel .bg-indigo-100{background:#4f46e54d!important}body.dark-mode #theory-tools-panel .bg-indigo-100:hover{background:#4f46e566!important}body.dark-mode #theory-tools-panel .bg-pink-600{background:#db2777!important}body.dark-mode #theory-tools-panel .bg-pink-600:hover{background:#be185d!important}body.dark-mode #theory-tools-panel .text-purple-800{color:#e9d5ff!important}body.dark-mode #theory-tools-panel .text-indigo-800{color:#c7d2fe!important}body.dark-mode #theory-tools-panel select{background:#1e2a47e6!important;color:#e0e0e0!important;border-color:#8b5cf64d!important}body.dark-mode .progression-chord-item.ring-4{box-shadow:0 0 0 4px #a855f780!important}body.dark-mode .guitar-fretboard-container{background-color:#1e2a47!important}body.dark-mode .string-label{background:#1e2a47e6!important;color:#d97706!important}body.dark-mode .fret-position{border-color:#5a4020!important}body.dark-mode h1,body.dark-mode h2,body.dark-mode h3,body.dark-mode h4,body.dark-mode h5,body.dark-mode h6{color:#f5f5f5!important}body.dark-mode strong{color:#f0f0f0!important}body.dark-mode p,body.dark-mode li{color:#d0d0d0!important}body.dark-mode .fret-number{color:silver!important}body.dark-mode .guitar-fretboard-info p,body.dark-mode .guitar-fretboard-info li,body.dark-mode .circle-of-fifths-info p,body.dark-mode .circle-of-fifths-info li{color:#d8d8d8!important}#guitar-fretboard-container{width:100%;background-color:#f3f4f6;border-radius:12px;padding:1.5rem;overflow:hidden;box-shadow:inset 0 0 10px #0000001a;display:flex;align-items:center;justify-content:center}body.dark-mode #guitar-fretboard-container{background-color:#1e2a47!important}.guitar-fretboard-panel{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998;display:flex;align-items:center;justify-content:center}.guitar-fretboard-panel.hidden{display:none}.guitar-fretboard-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.guitar-fretboard-content{position:relative;width:95%;max-width:1200px;max-height:90vh;background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;box-shadow:var(--shadow-soft),0 0 60px #f59e0b4d;display:flex;flex-direction:column;overflow:hidden}.guitar-fretboard-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1);background:linear-gradient(135deg,#f59e0b1a,#d977061a)}.guitar-fretboard-header h2{margin:0;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.guitar-fretboard-body{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.guitar-fretboard-container{width:100%;background-color:#f3f4f6;border-radius:12px;padding:.5rem;overflow:hidden;height:150px;display:flex;align-items:center;justify-content:center}.modern-keyboard~#guitar-fretboard-container,#piano-keyboard.modern-keyboard~#guitar-fretboard-container,body:has(#piano-keyboard.modern-keyboard) #guitar-fretboard-container{height:180px!important}#guitar-fretboard-container{min-height:250px!important;height:auto!important;max-height:280px!important;align-items:flex-start!important;padding-top:.75rem!important;padding-bottom:.75rem!important}.modern-keyboard~#guitar-fretboard-container,#piano-keyboard.modern-keyboard~#guitar-fretboard-container,body:has(#piano-keyboard.modern-keyboard) #guitar-fretboard-container{min-height:250px!important;height:auto!important;max-height:280px!important}.fretboard-grid{display:flex;flex-direction:column;gap:.25rem;width:100%;max-width:100%;flex:0 0 auto;overflow:visible}.fretboard-fingering-selector{margin-bottom:.5rem;width:100%;display:flex;align-items:center;gap:.5rem;padding:0 .25rem}.fret-numbers{display:grid;grid-template-columns:40px repeat(13,minmax(0,1fr));gap:2px;margin-bottom:.25rem;padding-left:0;height:20px;width:100%}.string-label-spacer{width:40px}.fret-number{text-align:center;font-size:.625rem;font-weight:600;color:#6b7280}.guitar-string{display:grid;grid-template-columns:40px repeat(13,minmax(0,1fr));gap:2px;align-items:center;position:relative;height:20px;width:100%}.guitar-string:after{content:"";position:absolute;left:40px;right:0;top:50%;height:3px;background:linear-gradient(90deg,#6b4513,#8b4513,#654321);z-index:0;pointer-events:none;box-shadow:0 0 2px #8b451380;transition:transform .1s ease}.guitar-string.playing:after{animation:stringWiggle .3s ease-in-out}@keyframes stringWiggle{0%,to{transform:translateY(0) scaleY(1)}25%{transform:translateY(-1px) scaleY(1.2)}50%{transform:translateY(1px) scaleY(.8)}75%{transform:translateY(-.5px) scaleY(1.1)}}.string-label{font-weight:700;color:#8b4513;font-size:.625rem;text-align:center;padding:.125rem;background:#ffffffe6;border-radius:3px;border:1px solid #d97706}.fret-position{height:20px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;border-right:2px solid #a0522d;cursor:pointer;transition:background-color .1s ease}.fret-position:hover{background-color:#8b45131a}.barre-bar{position:absolute;left:50%;transform:translate(-50%);width:70%;min-height:24px;background:linear-gradient(135deg,#8b4513d9,#654321f2);border:2px solid rgba(139,69,19,1);border-radius:6px;z-index:2;box-shadow:0 2px 8px #0006,inset 0 1px 2px #ffffff1a;pointer-events:none}.fret-position.barre-fret{position:relative;overflow:visible}.fret-position.open-string{border-right:3px solid #654321}.fret-position:nth-child(4),.fret-position:nth-child(6),.fret-position:nth-child(8),.fret-position:nth-child(10),.fret-position:nth-child(13){background:#8b45130d}.fret-dot{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.5rem;font-weight:700;color:#fff;box-shadow:0 1px 4px #0000004d;transition:all .2s ease;cursor:pointer}.fret-dot:hover{transform:scale(1.15);box-shadow:0 4px 12px #0006}.fret-dot-builder{background:linear-gradient(135deg,#fbbf24,#f59e0b);border:2px solid #d97706}.fret-dot-trainer{background:linear-gradient(135deg,#14b8a6,#0d9488);border:2px solid #0f766e}.fret-dot-scale{background:linear-gradient(135deg,#a3e635,#84cc16);border:2px solid #65a30d}.fret-note-label{text-shadow:0 1px 2px rgba(0,0,0,.3);letter-spacing:-.5px}.guitar-fretboard-info{text-align:center;padding:1rem;background:#f9fafbcc;border-radius:8px;width:100%;max-width:1000px}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.loading{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:1000px 100%;animation:shimmer 2s infinite}.preset-panel{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:center;justify-content:center}.preset-panel.hidden{display:none}.preset-panel-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.preset-panel-content{position:relative;width:90%;max-width:1000px;height:80vh;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;box-shadow:var(--shadow-soft),0 0 60px #667eea33;display:flex;flex-direction:column;overflow:hidden}.preset-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1);background:linear-gradient(135deg,#667eea1a,#764ba21a)}.preset-panel-header h2{margin:0;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.preset-panel-toolbar{display:flex;gap:.75rem;padding:1rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.1);background:#f9fafbcc}.preset-panel-toolbar input,.preset-panel-toolbar select{border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s}.preset-panel-toolbar input:focus,.preset-panel-toolbar select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.preset-list{flex:1;overflow-y:auto;padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;align-content:start}.preset-empty{grid-column:1 / -1;text-align:center;padding:3rem;color:#6b7280;font-size:1.125rem}.preset-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000001a}.preset-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026;border-color:#667eea}.preset-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.preset-card-title{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.preset-category-emoji{font-size:1.25rem;flex-shrink:0}.preset-name{font-weight:600;font-size:1rem;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-card-actions{display:flex;gap:.25rem;flex-wrap:wrap}.preset-btn{padding:.25rem .5rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.preset-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.preset-btn-primary{background:var(--gradient-primary);border-color:#667eea;color:#fff}.preset-btn-primary:hover{box-shadow:0 4px 12px #667eea66}.preset-btn-danger{background:linear-gradient(135deg,#f87171,#dc2626);border-color:#dc2626;color:#fff}.preset-btn-danger:hover{box-shadow:0 4px 12px #dc262666}.preset-description{font-size:.875rem;color:#6b7280;margin-bottom:.75rem;line-height:1.4}.preset-metadata{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.75rem;color:#9ca3af;padding-top:.75rem;border-top:1px solid #f3f4f6}.preset-panel-footer{padding:1rem 1.5rem;border-top:1px solid rgba(0,0,0,.1);background:#f9fafbcc}.quick-save-btn,.quick-load-btn{margin-bottom:0;height:auto;line-height:1.2;min-height:0;pointer-events:auto!important}.circle-of-fifths-panel{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998;display:flex;align-items:center;justify-content:center}.circle-of-fifths-panel.hidden{display:none}.circle-of-fifths-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.circle-of-fifths-content{position:relative;width:95%;max-width:1400px;max-height:90vh;background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;box-shadow:var(--shadow-soft),0 0 60px #3b82f64d;display:flex;flex-direction:column;overflow:hidden}.circle-of-fifths-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.1);background:linear-gradient(135deg,#3b82f61a,#06b6d41a)}.circle-of-fifths-header h2{margin:0;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.circle-of-fifths-body{flex:1;overflow-y:auto;padding:2rem}.circle-of-fifths-layout{display:grid;grid-template-columns:550px 1fr;gap:2rem;align-items:start}.circle-of-fifths-visual{display:flex;flex-direction:column;align-items:center}#circle-of-fifths-svg{width:500px;height:500px}.circle-of-fifths-info{text-align:left;padding:1.5rem;background:#f9fafbcc;border-radius:8px;max-height:none;overflow-y:visible}@media (max-width: 1024px){.circle-of-fifths-layout{grid-template-columns:1fr;gap:1rem}#circle-of-fifths-svg{width:100%;max-width:500px;height:auto}.circle-of-fifths-info{max-height:none}}.circle-segment{transition:all .2s cubic-bezier(.4,0,.2,1)}.circle-segment:hover:not(.selected-key){filter:brightness(1.1)}.circle-segment:active{filter:brightness(.9)}.circle-segment.selected-key{animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.85}}#voicing-editor-container{min-height:auto}#tab-builder .bg-gray-50\/50:nth-child(2){min-height:fit-content}#tab-builder .bg-gray-50\/50:nth-child(2) section>div.grid{align-items:start}#progression-visualization .relative{position:relative}#progression-visualization .absolute{pointer-events:auto}#progression-visualization .hidden{display:none}#progression-visualization .z-50{z-index:50}.sortable-ghost{opacity:.4;background:#e5e7eb;border:2px dashed #9ca3af}.sortable-chosen{cursor:grabbing;opacity:.8}.sortable-drag{opacity:.8}.builder-section-item,.trainer-section-item,.melody-section-item{position:relative}.drag-handle{cursor:grab;pointer-events:auto!important;user-select:none;-webkit-user-select:none}.drag-handle:active{cursor:grabbing}.drag-handle svg{pointer-events:auto!important}.builder-section-item,.trainer-section-item,.melody-section-item{cursor:default}.builder-section-item.sortable-chosen,.trainer-section-item.sortable-chosen,.melody-section-item.sortable-chosen{cursor:grabbing}#interactive-melody-notation-canvas{min-width:800px;scroll-margin:0;overflow-anchor:none}canvas{scroll-margin:0;overflow-anchor:none}.overflow-x-auto{scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.5) rgba(0,0,0,.1)}.overflow-x-auto::-webkit-scrollbar{height:6px}.overflow-x-auto::-webkit-scrollbar-track{background:#0000001a;border-radius:3px}.overflow-x-auto::-webkit-scrollbar-thumb{background:#8b5cf680;border-radius:3px}.overflow-x-auto::-webkit-scrollbar-thumb:hover{background:#8b5cf6b3}#main-header{outline:1px solid rgba(107,114,128,.2);outline-offset:-1px}@keyframes pattern-pulse{0%{box-shadow:0 0 #a855f7b3;transform:scale(1)}50%{box-shadow:0 0 0 10px #a855f700;transform:scale(1.05)}to{box-shadow:0 0 #a855f700;transform:scale(1)}}.pattern-highlight-active{animation:pattern-pulse .6s ease-out 3;border:2px solid rgba(168,85,247,.8)!important;background:linear-gradient(135deg,#a855f71a,#ec48991a)!important}.chord-card-wrapper{transition:all .3s ease-out;scroll-margin:0;overflow-anchor:none}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.chord-card-wrapper>div{animation:fadeIn .2s ease-out}.chord-card-wrapper.no-animation,.chord-card-wrapper.no-animation>*,.chord-card-wrapper.no-animation *{transition:none!important;animation:none!important}.simplified-card{transition:all .2s ease;scroll-margin:0;overflow-anchor:none;width:100%!important;box-sizing:border-box!important}.chord-tooltip{pointer-events:auto!important;z-index:1000;white-space:normal;overflow:visible;contain:layout;scroll-margin:0!important;overflow-anchor:none!important}.chord-card-wrapper:has(.chord-tooltip:not(.hidden)){z-index:20;position:relative}#progression-visualization,#melody-progression-visualization,#builder-progression-visualization{position:relative;z-index:11}.chord-tooltip,.chord-tooltip *{scroll-margin:0!important}.info-tooltip-btn{pointer-events:auto;z-index:10}.info-tooltip-btn:active{pointer-events:auto}.tooltip-inversion-btn{cursor:pointer;-webkit-user-select:none;user-select:none;scroll-margin:0}.tooltip-inversion-btn:focus{outline:none;scroll-behavior:auto}.tooltip-inversion-btn:hover{will-change:background-color}.detailed-card{transition:all .2s ease}.chord-card-wrapper.sortable-ghost{opacity:.4}.chord-card-wrapper.sortable-chosen .simplified-card{background-color:#374151;border-color:#60a5fa!important}.chord-card-wrapper.sortable-drag{opacity:.9;box-shadow:0 8px 16px #00000080}.simplified-chord-card{transition:all .2s ease}.simplified-chord-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.simplified-chord-card.sortable-ghost{opacity:.4;background-color:#1f2937}.simplified-chord-card.sortable-chosen{background-color:#374151;border-color:#60a5fa!important}.simplified-chord-card.sortable-drag{opacity:.9;box-shadow:0 8px 16px #00000080}#sidebar>.flex-1.overflow-y-auto{overflow-x:visible!important}#sidebar .group>div.absolute.left-full{z-index:9999}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.animate-fade-in-up{animation:fade-in-up .3s ease-out}.animate-fade-out{animation:fade-out .3s ease-out forwards}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes bounce-once{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.animate-fade-in{animation:fade-in .3s ease-out}.animate-bounce-once{animation:bounce-once .5s ease-out}#ear-training-modal .ear-training-container{max-height:90vh}.hover\:scale-102:hover{transform:scale(1.02)}.active\:scale-98:active{transform:scale(.98)}.sections-container{display:flex;flex-direction:column;gap:.5rem;width:100%}.section-toolbar{position:sticky;top:0;z-index:10;background:#f9fafbf2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.section-wrapper{transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:.5rem;overflow:visible}.section-wrapper.collapsed .section-cards-container{max-height:0;padding:0;overflow:hidden;border:none}.section-wrapper:hover{box-shadow:0 4px 12px #00000014}.section-header{transition:all .2s ease;-webkit-user-select:none;user-select:none}.section-header:hover{filter:brightness(.97)}.section-drag-handle{cursor:grab}.section-drag-handle:active{cursor:grabbing}.section-collapse-btn svg{transition:transform .2s ease}.section-wrapper.collapsed .section-collapse-btn svg{transform:rotate(-90deg)}.section-cards-container{transition:all .3s cubic-bezier(.4,0,.2,1);max-height:2000px;min-height:60px}.section-empty-indicator{grid-column:1 / -1;transition:all .2s ease}.section-empty-indicator:hover{border-color:#6366f1;background:#6366f10d}.ungrouped-section{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #e5e7eb}.ungrouped-header{opacity:.7}.ungrouped-cards-container{min-height:60px;transition:all .2s ease}.ungrouped-cards-container:hover{border-color:#9ca3af}.section-type-menu{animation:fadeInScale .15s ease-out;transform-origin:top left}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.section-type-menu button{transition:background-color .15s ease}.section-context-menu{animation:fadeInScale .15s ease-out;transform-origin:top left}.section-context-menu button{transition:background-color .15s ease}.section-context-menu button:hover{background-color:#f3f4f6}.section-context-menu button.text-red-600:hover{background-color:#fef2f2}.section-ghost{opacity:.4;background:#f3f4f6;border-radius:.5rem}.chord-card-wrapper.multi-selected{outline:2px solid #3B82F6;outline-offset:2px;border-radius:.75rem}.chord-card-wrapper.multi-selected:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:.875rem;background:#3b82f61a;pointer-events:none;z-index:-1}.chord-card-wrapper[data-dragging-count]:before{content:attr(data-dragging-count);position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:#3b82f6;color:#fff;font-size:11px;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:100;box-shadow:0 2px 4px #0003}.section-wrapper.collapsed.drag-over .section-cards-container{max-height:100px;padding:.5rem;border-width:1px;opacity:.6}.section-label-input{transition:all .15s ease}.section-label-input:focus{box-shadow:0 0 0 2px #6366f14d}.empty-progression-state{background:linear-gradient(135deg,#f9fafbcc,#f3f4f6e6);border:2px dashed #d1d5db;border-radius:1rem;min-height:150px}.section-inline-grid{position:relative}.inline-section-group{margin:4px 0}.section-group-wrapper{transition:all .2s ease;box-shadow:0 1px 3px #00000014}.section-group-wrapper:hover{box-shadow:0 4px 12px #0000001f}.section-banner{transition:all .15s ease;z-index:5}.section-banner:hover{filter:brightness(1.05)}.section-group-drag-handle{cursor:grab}.section-group-drag-handle:active{cursor:grabbing}.section-banner-label{text-shadow:0 1px 2px rgba(0,0,0,.2)}.section-banner-menu{opacity:0;transition:opacity .15s ease}.section-banner:hover .section-banner-menu{opacity:1}.section-cards-area{min-height:50px;transition:all .2s ease}.section-cards-area .chord-card-wrapper{position:relative}.inline-section-group.sortable-ghost{opacity:.5}.inline-section-group.sortable-chosen{transform:scale(1.02);box-shadow:0 8px 25px #00000026}.section-cards-area.drag-over{background-color:#6366f11a;outline:2px dashed rgba(99,102,241,.5);outline-offset:-2px}.section-unified-container{min-width:fit-content;display:inline-flex;flex-direction:column;flex-shrink:0}.section-banner{min-height:28px;-webkit-user-select:none;user-select:none;box-shadow:0 1px 2px #0000001a}.section-banner:hover{filter:brightness(1.1)}.section-cards-area{min-height:60px;display:flex!important;flex-direction:row!important;flex-wrap:wrap!important}.section-cards-area .chord-card-wrapper{flex-shrink:0;width:auto!important;min-width:90px;max-width:300px}.section-cards-area .chord-card-wrapper.expanded-card-wrapper,.section-cards-area .chord-card-wrapper.has-notation{width:fit-content!important;min-width:auto!important;max-width:none!important}.expanded-card-wrapper{min-width:auto!important;width:fit-content!important;flex-shrink:0}.chord-card-wrapper.has-notation{width:fit-content!important;flex-shrink:0}.section-cards-area.drag-over{background-color:#6366f126!important;outline:2px dashed rgba(99,102,241,.5);outline-offset:-2px}.section-menu-btn:hover{background-color:#ffffff40}[id$=-cards-grid]{overflow:visible}.chord-card-wrapper.in-section{position:relative}:root{--card-bg: #ffffff;--card-border: #e5e7eb;--card-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--card-shadow-hover: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--card-radius: 16px;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--primary-gradient: linear-gradient(135deg, #8b5cf6 0%, #a855f7 100%);--success-gradient: linear-gradient(135deg, #10b981 0%, #059669 100%);--danger-gradient: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--info-gradient: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%)}.melody-dashboard{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:1400px;margin:0 auto;padding:var(--spacing-md)}.dashboard-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);overflow:hidden;transition:box-shadow .2s ease,transform .2s ease}.dashboard-card:hover{box-shadow:var(--card-shadow-hover)}.dashboard-card.card-highlighted{border-color:#a855f7;box-shadow:0 0 0 2px #a855f733,var(--card-shadow)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(to bottom,#fafafa,#f5f5f5);border-bottom:1px solid var(--card-border);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease}.card-header:hover{background:linear-gradient(to bottom,#f5f5f5,#efefef)}.card-header-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(to bottom,#fafafa,#f5f5f5);border:none;border-radius:var(--card-radius) var(--card-radius) 0 0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;font-family:inherit;font-size:inherit}.card-header-btn:hover{background:linear-gradient(to bottom,#f5f5f5,#efefef)}.card-header-btn.header-progression{background:linear-gradient(to bottom,#faf5ff,#f3e8ff)}.card-header-btn.header-progression:hover{background:linear-gradient(to bottom,#f3e8ff,#ede9fe)}.card-header-btn.header-notation{background:linear-gradient(to bottom,#f5f3ff,#ede9fe)}.card-header-btn.header-notation:hover{background:linear-gradient(to bottom,#ede9fe,#ddd6fe)}.card-header-btn.header-bass{background:linear-gradient(to bottom,#ecfdf5,#d1fae5)}.card-header-btn.header-bass:hover{background:linear-gradient(to bottom,#d1fae5,#a7f3d0)}.header-progression{background:linear-gradient(to bottom,#faf5ff,#f3e8ff);border-bottom-color:#e9d5ff}.header-progression:hover{background:linear-gradient(to bottom,#f3e8ff,#ede9fe)}.header-notation{background:linear-gradient(to bottom,#f5f3ff,#ede9fe);border-bottom-color:#c4b5fd}.header-notation:hover{background:linear-gradient(to bottom,#ede9fe,#ddd6fe)}.header-bass{background:linear-gradient(to bottom,#ecfdf5,#d1fae5);border-bottom-color:#a7f3d0}.header-bass:hover{background:linear-gradient(to bottom,#d1fae5,#a7f3d0)}.card-header-left{display:flex;align-items:center;gap:var(--spacing-sm)}.card-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:#fff}.card-icon.icon-progression{background:linear-gradient(135deg,#a855f7,#ec4899)}.card-icon.icon-actions{background:linear-gradient(135deg,#10b981,#3b82f6)}.card-icon.icon-notation{background:linear-gradient(135deg,#8b5cf6,#6366f1)}.card-icon.icon-suggestions{background:linear-gradient(135deg,#f59e0b,#ef4444)}.card-icon.icon-parameters{background:linear-gradient(135deg,#06b6d4,#3b82f6)}.card-icon.icon-bass{background:linear-gradient(135deg,#14b8a6,#0891b2)}.card-title{font-weight:600;font-size:.9rem;color:#374151}.shortcuts-btn-styled{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:.75rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #6366f14d}.shortcuts-btn-styled:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 2px 6px #6366f166;transform:translateY(-1px)}.shortcuts-btn-styled svg{width:14px;height:14px}.add-section-header-btn{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-size:.7rem;font-weight:500;border:none;border-radius:5px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #4f46e54d}.add-section-header-btn:hover{background:linear-gradient(135deg,#4f46e5,#4338ca);box-shadow:0 2px 4px #4f46e566;transform:translateY(-1px)}.add-section-header-btn svg{width:12px;height:12px}.card-header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.card-chevron{width:20px;height:20px;color:#9ca3af;transition:transform .2s ease}.card-collapsed .card-chevron{transform:rotate(-90deg)}.card-body{padding:var(--spacing-md);border-top:1px solid var(--card-border)}.card-body.hidden,.card-collapsed .card-body{display:none}.quick-actions-card{background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border:none;box-shadow:var(--card-shadow)}.quick-actions-card .card-body{padding:var(--spacing-sm) var(--spacing-md)}.quick-actions-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center}.action-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-weight:600;font-size:.875rem;border-radius:10px;border:none;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 4px #0000001a}.action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.action-btn:active{transform:translateY(0)}.action-btn.btn-play{background:var(--success-gradient);color:#fff}.action-btn.btn-stop{background:var(--danger-gradient);color:#fff}.action-btn.btn-generate{background:var(--primary-gradient);color:#fff}.action-btn.btn-save{background:var(--info-gradient);color:#fff}.action-btn svg{width:16px;height:16px}.action-divider{width:1px;height:32px;background:#d1d5db;margin:0 var(--spacing-xs)}.mode-toggle-container{display:flex;align-items:center;gap:8px;padding:4px 12px;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.mode-label{font-size:.75rem;font-weight:600;color:#6b7280}.mode-label.active{color:#8b5cf6}.progression-card .card-body{padding:var(--spacing-sm)}.progression-scroll-container{display:flex;gap:var(--spacing-xs);overflow-x:auto;padding:var(--spacing-xs);-webkit-overflow-scrolling:touch;scrollbar-width:thin}.progression-scroll-container::-webkit-scrollbar{height:6px}.progression-scroll-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.progression-chord-chip{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:8px 12px;background:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .15s ease;min-width:60px}.progression-chord-chip:hover{border-color:#a855f7;background:#faf5ff}.progression-chord-chip.selected{border-color:#8b5cf6;background:linear-gradient(135deg,#f5f3ff,#ede9fe);box-shadow:0 0 0 2px #8b5cf633}.chord-chip-name{font-weight:700;font-size:.9rem;color:#1f2937}.chord-chip-type{font-size:.65rem;color:#6b7280;text-transform:uppercase}.progression-empty{padding:var(--spacing-md);text-align:center;color:#9ca3af;font-style:italic}.key-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border-radius:6px;font-size:.75rem;font-weight:600;color:#5b21b6}.notation-card{border:2px solid #c4b5fd}.notation-card .card-header{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-bottom-color:#c4b5fd}.notation-card .card-body{padding:var(--spacing-sm);background:#fafafa}.notation-toolbar{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding:var(--spacing-xs);background:#fff;border-radius:8px;margin-bottom:var(--spacing-sm);border:1px solid #e5e7eb}.notation-canvas-wrapper{background:#fff;border-radius:8px;border:1px solid #e5e7eb;padding:var(--spacing-xs);min-height:200px}.bpm-control{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#f3f4f6;border-radius:6px}.bpm-control label{font-size:.7rem;font-weight:600;color:#6b7280}.bpm-control input[type=range]{width:80px;height:4px}.bpm-control .bpm-value{font-size:.75rem;font-weight:700;color:#374151;min-width:30px}.notation-header-btn{display:inline-flex;align-items:center;gap:3px;padding:4px 8px;font-size:.65rem;font-weight:600;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.notation-header-btn:hover{transform:translateY(-1px);filter:brightness(1.1)}.notation-header-btn:active{transform:translateY(0)}.notation-header-btn.btn-green{background:linear-gradient(135deg,#10b981,#059669)}.notation-header-btn.btn-teal{background:linear-gradient(135deg,#14b8a6,#0d9488)}.notation-header-btn.btn-red{background:linear-gradient(135deg,#ef4444,#dc2626)}.notation-header-btn.btn-orange{background:linear-gradient(135deg,#f97316,#ea580c)}.notation-header-btn.btn-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.notation-header-btn.btn-pink{background:linear-gradient(135deg,#ec4899,#db2777)}.notation-header-btn.btn-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.notation-controls-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:8px 12px;background:linear-gradient(to bottom,#f8f9fa,#f1f3f4);border-bottom:1px solid var(--card-border)}.controls-group{display:flex;align-items:center;gap:6px}.controls-group-label{font-size:.7rem;font-weight:600;color:#6b7280;margin-right:2px}.controls-divider{width:1px;height:24px;background:#d1d5db}.shortcuts-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:500;color:#6b7280;background:transparent;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .15s ease}.shortcuts-btn:hover{color:#374151;background:#f3f4f6;border-color:#9ca3af}.shortcuts-btn svg{color:#9ca3af}@media (max-width: 768px){.notation-controls-bar{padding:6px 10px}.controls-divider{display:none}.controls-group{flex-wrap:wrap}.controls-group-label{width:100%;margin-bottom:4px}}@media (max-width: 640px){.notation-header-btn span{display:none}.notation-header-btn{padding:6px}.shortcuts-btn span{display:none}.shortcuts-btn{padding:6px}}.cards-row{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.cards-row:has(>:nth-child(2)){grid-template-columns:1fr 1fr}@media (max-width: 768px){.cards-row,.cards-row:has(>:nth-child(2)){grid-template-columns:1fr}}.suggestions-card .card-body{max-height:300px;overflow-y:auto}.suggestion-tabs{display:flex;gap:4px;margin-bottom:var(--spacing-sm);padding:4px;background:#f3f4f6;border-radius:8px}.suggestion-tab{flex:1;padding:6px 12px;font-size:.75rem;font-weight:600;color:#6b7280;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.suggestion-tab:hover{color:#374151;background:#e5e7eb}.suggestion-tab.active{color:#fff;background:var(--primary-gradient)}.suggestion-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.suggestion-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .15s ease}.suggestion-item:hover{background:#f3f4f6;border-color:#d1d5db}.suggestion-name{font-weight:600;font-size:.875rem;color:#1f2937}.suggestion-reason{font-size:.7rem;color:#6b7280}.suggestion-score{padding:2px 8px;background:#ddd6fe;border-radius:4px;font-size:.7rem;font-weight:700;color:#5b21b6}.parameters-card .card-body{padding:var(--spacing-sm)}.param-group{margin-bottom:var(--spacing-sm)}.param-group:last-child{margin-bottom:0}.param-group-title{font-size:.7rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.param-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.param-item{display:flex;flex-direction:column;gap:4px}.param-item label{font-size:.75rem;font-weight:500;color:#374151}.param-item select,.param-item input{padding:6px 10px;font-size:.8rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.param-item select:focus,.param-item input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf633}.bass-card .card-body{padding:var(--spacing-sm)}.bass-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm);background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:8px;margin-bottom:var(--spacing-sm)}.bass-toggle-info{display:flex;flex-direction:column}.bass-toggle-title{font-weight:600;font-size:.875rem;color:#065f46}.bass-toggle-desc{font-size:.7rem;color:#059669}.intent-selector{display:flex;gap:4px;padding:4px;background:#f3f4f6;border-radius:8px}.intent-pill{padding:6px 12px;font-size:.7rem;font-weight:600;color:#6b7280;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.intent-pill:hover{color:#374151;background:#e5e7eb}.intent-pill.active{color:#fff;background:var(--primary-gradient)}.helper-buttons-row{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.helper-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;font-size:.8rem;font-weight:600;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease}.helper-btn:hover{transform:translateY(-1px);filter:brightness(1.1)}.helper-btn.btn-chord-suggestions{background:linear-gradient(135deg,#3b82f6,#06b6d4)}.helper-btn.btn-melody-suggestions{background:linear-gradient(135deg,#ec4899,#f43f5e)}.helper-btn.btn-shortcuts{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.helper-btn svg{width:14px;height:14px}.recording-indicator{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;font-size:.75rem;font-weight:600;color:#dc2626}.recording-dot{width:8px;height:8px;background:#dc2626;border-radius:50%;animation:pulse-recording 1s infinite}@keyframes pulse-recording{0%,to{opacity:1}50%{opacity:.5}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;color:#9ca3af}.empty-state-icon{width:48px;height:48px;margin-bottom:var(--spacing-sm);opacity:.5}.empty-state-text{font-size:.875rem}.empty-state-hint{font-size:.75rem;margin-top:4px}@media (max-width: 768px){.melody-dashboard{padding:var(--spacing-sm);gap:var(--spacing-md)}.quick-actions-grid{justify-content:center}.action-btn{padding:8px 12px;font-size:.8rem}.action-btn span,.action-divider{display:none}.mode-toggle-container{width:100%;justify-content:center;margin-top:var(--spacing-xs)}.param-row{grid-template-columns:1fr}.helper-buttons-row{justify-content:center}}@media (max-width: 480px){.card-header{padding:var(--spacing-xs) var(--spacing-sm)}.card-body{padding:var(--spacing-sm)}.card-title{font-size:.8rem}.progression-chord-chip{padding:6px 10px;min-width:50px}.chord-chip-name{font-size:.8rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dashboard-card{animation:fadeIn .3s ease-out}.dashboard-card:nth-child(2){animation-delay:.05s}.dashboard-card:nth-child(3){animation-delay:.1s}.dashboard-card:nth-child(4){animation-delay:.15s}.dashboard-card:nth-child(5){animation-delay:.2s}.dashboard-card .card-body::-webkit-scrollbar{width:6px}.dashboard-card .card-body::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.dashboard-card .card-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.dashboard-card .card-body::-webkit-scrollbar-thumb:hover{background:#9ca3af}.toggle-switch{position:relative;display:inline-flex;align-items:center;cursor:pointer}.toggle-switch input{position:absolute;opacity:0;width:0;height:0}.toggle-slider{width:40px;height:22px;background:#d1d5db;border-radius:11px;transition:background .2s ease;position:relative}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 2px #0003}.toggle-switch input:checked+.toggle-slider{background:#8b5cf6}.toggle-switch input:checked+.toggle-slider:after{transform:translate(18px)}.dashboard-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);overflow:hidden}.auto-bass-accordion{margin-top:8px;margin-bottom:12px;border:1px solid #d1fae5;border-radius:8px;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);overflow:hidden}.auto-bass-accordion-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;background:transparent;border:none;cursor:pointer;transition:background .15s ease;font-family:inherit}.auto-bass-accordion-header:hover{background:#10b98114}.auto-bass-accordion-content{max-height:0;overflow:hidden;padding:0 12px;transition:max-height .25s ease,padding .25s ease}.auto-bass-accordion.expanded .auto-bass-accordion-content{max-height:100px;padding:0 12px 10px}.auto-bass-accordion.expanded .accordion-chevron{transform:rotate(180deg)}.accordion-chevron{transition:transform .25s ease}.sidebar-icon-pill{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;transition:all .2s ease;flex-shrink:0}.sidebar-icon-pill:hover{transform:scale(1.1)}.sidebar-icon-purple{background:linear-gradient(135deg,#a855f7,#9333ea);color:#fff;box-shadow:0 2px 4px #a855f74d}.sidebar-icon-purple:hover{background:linear-gradient(135deg,#9333ea,#7c3aed);box-shadow:0 3px 6px #a855f766}.sidebar-icon-indigo{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 2px 4px #6366f14d}.sidebar-icon-indigo:hover{background:linear-gradient(135deg,#4f46e5,#4338ca);box-shadow:0 3px 6px #6366f166}.sidebar-chevron-pill{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;transition:all .2s ease;flex-shrink:0}.sidebar-chevron-pill:hover{transform:scale(1.05)}.sidebar-chevron-purple{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#9333ea;border:1px solid #d8b4fe}.sidebar-chevron-purple:hover{background:linear-gradient(135deg,#e9d5ff,#d8b4fe);color:#7c3aed}.sidebar-chevron-indigo{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5;border:1px solid #a5b4fc}.sidebar-chevron-indigo:hover{background:linear-gradient(135deg,#c7d2fe,#a5b4fc);color:#4338ca}
