.app-container{min-height:100vh;background:linear-gradient(135deg,#1e3a8a,#7c3aed,#3730a3);color:#fff}.main-content{max-width:1600px;margin:0 auto;padding:7rem .75rem 8rem}.app-header{text-align:center;margin-bottom:2rem}.header-title-container{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem;position:relative;flex-wrap:wrap}.header-controls{position:relative;right:auto;top:auto;transform:none;display:flex;align-items:center;gap:.75rem;margin-top:.5rem;justify-content:center;width:100%}.header-icon{width:2rem;height:2rem;color:#fbbf24}.header-title{font-size:1.75rem;font-weight:700;background:linear-gradient(to right,#fbbf24,#f97316);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-subtitle{color:#bfdbfe;font-size:1.125rem}.key-interval-section{display:flex;justify-content:space-around;margin-bottom:2rem}.loading-container{text-align:center;margin-bottom:2rem}.loading-spinner{display:inline-block;animation:spin 1s linear infinite;border-radius:50%;width:2rem;height:2rem;border:2px solid transparent;border-bottom:2px solid #fbbf24}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:.5rem;color:#bfdbfe}.navigation-tabs{display:flex;justify-content:center;margin-bottom:2rem}.tabs-container{background:#0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:.375rem;display:flex;gap:.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.tabs-container::-webkit-scrollbar{display:none}.tab-button{display:flex;align-items:center;gap:.375rem;padding:.75rem 1rem;border-radius:8px;font-weight:500;transition:all .2s ease;cursor:pointer;border:none;background:transparent;color:#d1d5db;white-space:nowrap;min-width:-moz-max-content;min-width:max-content;touch-action:manipulation}.tab-button:hover{background:#ffffff1a;color:#fff}.tab-button.active{background:#fbbf24;color:#000}.tab-icon{width:1.25rem;height:1.25rem}.error-container{background:#ef444433;border:1px solid #ef4444;border-radius:8px;padding:1rem;margin-bottom:2rem;text-align:center}.error-title{color:#fca5a5;font-weight:600;margin-bottom:.5rem}.error-message{color:#fecaca}.retry-button{background:#fbbf24;color:#000;padding:.5rem 1rem;border-radius:6px;font-weight:500;border:none;cursor:pointer;margin-top:.5rem;transition:background .2s ease}.retry-button:hover{background:#f59e0b}.info-panels-container{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1000}@media (max-width: 768px){.info-panels-container{position:static;padding:.5rem;pointer-events:auto;z-index:auto;display:flex;flex-direction:column;gap:.5rem}}@media (max-width: 768px){.main-content{padding:5rem .75rem 8rem}.app-header{margin-bottom:1.5rem}.header-title-container{flex-direction:column;gap:.5rem}.header-title{font-size:1.5rem;text-align:center}.header-icon{width:1.75rem;height:1.75rem}.header-subtitle{font-size:.9rem;margin-top:.25rem}.key-interval-section{justify-content:center;margin-bottom:1.5rem}.navigation-tabs{margin-bottom:1.5rem}.tabs-container{padding:.25rem;gap:.125rem}.tab-button{padding:.625rem .75rem;font-size:.875rem;min-width:-moz-fit-content;min-width:fit-content}.tab-icon{width:1rem;height:1rem}}@media (max-width: 480px){.main-content{padding:5rem .75rem 8rem}.header-title{font-size:1.25rem}.header-icon{width:1.5rem;height:1.5rem}.tabs-container{flex-direction:column;width:100%;max-width:none}.tab-button{justify-content:center;width:100%;padding:.75rem}}.card{background:#0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:1.1rem}.card.compact{padding:1rem}.card.large{padding:2rem}.card-header{margin-bottom:1.5rem}.card-title{font-size:1.5rem;font-weight:600;text-align:center;color:#fbbf24;margin:0}.card-title.large{font-size:2rem}.card-title.small{font-size:1.25rem}.card-content{flex:1}.card-footer{margin-top:1.5rem}.card.primary{border:1px solid rgba(251,191,36,.3)}.card.secondary{border:1px solid rgba(147,197,253,.3)}.card.accent{background:#c2410c33}@media (max-width: 768px){.card{padding:1rem;width:100%}.card.large{padding:1.5rem}.card-title{font-size:1.4rem!important}}.button{padding:.75rem 1rem;border-radius:8px;font-weight:500;transition:all .3s ease;transform:scale(1);cursor:pointer;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;touch-action:manipulation;-webkit-user-select:none;-moz-user-select:none;user-select:none;min-height:44px;min-width:44px}.button:hover{transform:scale(1.05)}.button:active{transform:scale(.98)}.button:disabled{opacity:.5;cursor:not-allowed;transform:none}.button:disabled:hover{transform:none}.button.small{padding:.5rem .75rem;font-size:.875rem}.button.large{padding:1rem 1.5rem;font-size:1.125rem}.button.primary{background:#fbbf24;color:#000}.button.primary:hover{background:#f59e0b}.button.secondary{background:#ffffff1a;color:#fff}.button.secondary:hover{background:#fff3}.button.accent{background:#2563eb;color:#fff}.button.accent:hover{background:#1d4ed8}.button.danger{background:#dc2626;color:#fff}.button.danger:hover{background:#b91c1c}.button.selected{background:#fbbf24;color:#000;box-shadow:0 4px 12px #fbbf2466}.button.ghost{background:transparent;color:#d1d5db;border:1px solid rgba(255,255,255,.2)}.button.ghost:hover{background:#ffffff1a;color:#fff}.button-icon{width:1.25rem;height:1.25rem}.button.small .button-icon{width:1rem;height:1rem}.button.large .button-icon{width:1.5rem;height:1.5rem}@media (max-width: 768px){.button{padding:.625rem .875rem;font-size:.875rem;min-height:44px}.button.large{padding:.75rem 1rem;font-size:1rem;min-height:48px}.button.small{padding:.5rem .625rem;font-size:.8rem;min-height:40px;min-width:40px}}@media (max-width: 480px){.button{padding:.5rem .75rem;font-size:.8rem;min-height:44px}.button.large{padding:.625rem .875rem;font-size:.9rem}.button.small{padding:.375rem .5rem;font-size:.75rem;min-height:38px;min-width:38px}}.key-selector-container{display:flex;gap:1rem;align-items:center}.key-selector-section{flex:1}.interval-selector-section{flex-shrink:0;min-width:240px}.keys-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}.intervals-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.sharp-key{background:#374151!important;color:#fef3c7!important}.sharp-key.selected{background:#fbbf24!important;color:#000!important}@media (max-width: 768px){.key-selector-container{flex-direction:column;gap:1rem;padding:0 .5rem;width:100%}.interval-selector-section{min-width:unset}.keys-grid{grid-template-columns:repeat(4,1fr);gap:.375rem}.intervals-grid{gap:.5rem}}@media (max-width: 480px){.key-selector-container{padding:0 .25rem;gap:.75rem}.keys-grid{grid-template-columns:repeat(3,1fr);gap:.25rem}.intervals-grid{grid-template-columns:1fr;gap:.375rem}}.practice-tip{background:linear-gradient(135deg,#3b82f61a,#6366f10d);border:1px solid rgba(59,130,246,.2);border-radius:12px;margin-top:1.5rem;overflow:hidden;transition:all .3s ease}.practice-tip-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;cursor:pointer;transition:background-color .2s ease}.practice-tip-header:hover{background:#3b82f60d}.practice-tip-title{font-size:1.125rem;font-weight:600;color:#fa961c;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.1)}.practice-tip-toggle{background:none;border:none;color:#9ca3af;cursor:pointer;transition:color .2s ease;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.practice-tip-toggle:hover{color:#3b82f6;background:#3b82f61a}.practice-tip-content{padding:0 1rem 1rem;animation:slideDown .3s ease}.practice-tip-text{color:#d1d5db;line-height:1.6;margin:0 0 .75rem;font-size:.875rem}.practice-tip-text:last-child{margin-bottom:0}.chord-tooltip-trigger{position:relative;cursor:pointer;display:inline-block}.chord-tooltip{position:fixed;z-index:10000;background:#000000f2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(59,130,246,.3);border-radius:12px;padding:.75rem;box-shadow:0 8px 32px #0006;animation:tooltipFadeIn .2s ease;pointer-events:none;min-width:220px;max-width:300px;width:auto;margin:0}.chord-tooltip.persistent{pointer-events:auto;border-color:#3b82f680;box-shadow:0 12px 40px #0009}.chord-tooltip.dragging{-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:grabbing!important}.chord-tooltip.dragging *{cursor:grabbing!important}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;cursor:grab;padding-bottom:.25rem;border-bottom:1px solid rgba(59,130,246,.2)}.tooltip-header:active{cursor:grabbing}.tooltip-title{font-size:1.125rem;font-weight:600;color:#fbbf24;text-shadow:0 1px 2px rgba(0,0,0,.3)}.close-button{background:none;border:none;color:#9ca3af;font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-button:hover{color:#ef4444;background:#ef44441a}.piano-chord-diagram{display:flex;flex-direction:column;align-items:center;margin:0;padding:0}.mini-piano{position:relative;width:220px;height:120px;background:#1f2937;border-radius:6px;overflow:hidden;border:2px solid #374151}.white-keys{display:flex;height:100%}.white-key{flex:1;background:#f9fafb;border:1px solid #d1d5db;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;transition:background-color .2s ease}.white-key.active{background:#3b82f6;color:#fff}.key-label{font-size:.75rem;font-weight:600}.black-keys{position:absolute;top:0;left:0;right:0;height:60%;pointer-events:none}.black-key{position:absolute;width:8%;height:100%;background:#1f2937;border:1px solid #374151;transform:translate(-50%);transition:background-color .2s ease}.black-key.active{background:#1e40af}.guitar-chord-diagram{display:flex;flex-direction:column;align-items:center}.guitar-fretboard{background:#1f2937;border-radius:6px;padding:.75rem;min-width:180px;border:2px solid #374151}.fret-numbers{display:flex;margin-bottom:.25rem}.fret-numbers>div:first-child{width:28px}.fret-number{width:28px;text-align:center;font-size:.75rem;color:#9ca3af;font-weight:500}.guitar-string-row{display:flex;align-items:center;margin-bottom:4px;position:relative}.string-name{width:28px;text-align:center;font-size:.75rem;color:#60a5fa;font-weight:600}.fret-position{width:28px;height:16px;position:relative;display:flex;align-items:center;justify-content:center}.fret-line{position:absolute;left:0;width:2px;height:100%;background:#4b5563}.guitar-string-row:after{content:"";position:absolute;left:28px;right:0;top:50%;height:1px;background:#6b7280;z-index:1}.open-string{font-size:.625rem;color:#10b981;font-weight:700}.muted-string{font-size:.75rem;color:#ef4444;font-weight:700}.finger-position{width:12px;height:12px;background:#3b82f6;border-radius:50%;font-size:.625rem;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;position:relative;z-index:10;border:2px solid #1d4ed8}.strings{display:flex;flex-direction:column}.string{display:flex;align-items:center;margin-bottom:4px;position:relative}.string:after{content:"";position:absolute;left:28px;right:0;top:50%;height:1px;background:#6b7280;z-index:1}.frets{display:flex;align-items:center}.nut{width:28px;height:16px;display:flex;align-items:center;justify-content:center}.fret{width:28px;height:16px;position:relative;display:flex;align-items:center;justify-content:center}.fret:before{content:"";position:absolute;left:0;width:2px;height:100%;background:#4b5563}.piano-container{display:flex;justify-content:center}.piano-keyboard{position:relative}.black-keys-row{display:flex;margin-bottom:.5rem;position:relative;z-index:10}.black-key-container{position:relative;width:40px;top:7px}.black-key{width:30px;height:80px;background:#1f2937;border:1px solid #374151;border-radius:0 0 4px 4px;display:flex;align-items:flex-end;justify-content:center;color:#fff;font-size:.75rem;font-weight:600;padding-bottom:.5rem;cursor:pointer;transition:all .2s ease;position:absolute;left:90%;transform:translate(-50%)}.black-key:hover{background:#374151}.black-key.scale-note{background:#2563eb;color:#fff;border-color:#1d4ed8}.black-key.root-note{background:#dc2626;color:#fff;border-color:#b91c1c}.white-keys-row{display:flex}.white-key{width:40px;height:120px;background:#fff;border:1px solid #d1d5db;border-radius:0 0 4px 4px;display:flex;align-items:flex-end;justify-content:center;color:#1f2937;font-size:.875rem;font-weight:600;padding-bottom:.5rem;cursor:pointer;transition:all .2s ease}.white-key:hover{background:#f3f4f6}.white-key.scale-note{background:#3b82f6;color:#fff;border-color:#2563eb}.white-key.root-note{background:#ef4444;color:#fff;border-color:#dc2626}.piano-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1.5rem;font-size:.875rem}.legend-key{width:1.5rem;height:1rem;border-radius:2px;border:1px solid #d1d5db}.legend-key.white{background:#fff}.legend-key.root{background:#ef4444}.legend-key.scale{background:#3b82f6}@media (max-width: 768px){.piano-container{padding:0 .5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.piano-keyboard{min-width:-moz-max-content;min-width:max-content;margin:0 auto}.black-key-container{width:28px}.black-key{width:22px;height:60px;font-size:.625rem;padding-bottom:.375rem}.white-key{width:28px;height:90px;font-size:.7rem;padding-bottom:.375rem}.piano-legend{flex-direction:column;gap:.5rem;align-items:center;margin-top:1rem}.legend-item{font-size:.875rem}}@media (max-width: 480px){.piano-container{padding:0 .25rem}.black-key-container{width:24px}.black-key{width:18px;height:50px;font-size:.55rem;padding-bottom:.25rem}.white-key{width:24px;height:75px;font-size:.625rem;padding-bottom:.25rem}.legend-item{font-size:.8rem}}.chord-variation-picker-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;min-width:100vw;min-height:100vh;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s ease-out;box-sizing:border-box}.chord-variation-picker{background:linear-gradient(135deg,#1e3c72,#2a5298);border-radius:16px;box-shadow:0 20px 60px #00000080;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease-out;overflow:hidden;position:relative;box-sizing:border-box}.chord-variation-picker:hover{transform:none}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.picker-header{padding:20px 24px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);display:flex;justify-content:space-between;align-items:center}.picker-header h3{margin:0;font-size:1.5rem;color:#fff;font-weight:600}.close-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#fff;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;padding:0}.close-btn:hover{background:#fff3;transform:scale(1.1)}.picker-subtitle{padding:12px 24px;color:#fffc;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.1)}.variations-grid{padding:24px;display:grid;grid-template-columns:repeat(5,1fr);gap:16px;overflow-y:auto;flex:1;min-height:200px}.variation-item{background:#0000004d;border:2px solid rgba(255,255,255,.15);border-radius:12px;padding:12px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;box-sizing:border-box;min-height:160px}.variation-item:hover{background:#ffffff14;border-color:#ffffff4d;transform:translateY(-3px);box-shadow:0 8px 24px #0006}.variation-item.selected{background:linear-gradient(135deg,#26de81,#20bf6b);border-color:#fffc;box-shadow:0 0 0 3px #26de8166,0 8px 20px #0000004d;transform:scale(1.02)}.variation-item.selected:hover{transform:scale(1.02) translateY(-3px);box-shadow:0 0 0 3px #26de8180,0 12px 28px #0006}.variation-number{position:absolute;top:8px;right:8px;background:#00000080;color:#fff;font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:12px;z-index:1}.variation-item.selected .variation-number{background:#ffffff4d}.mini-chord-diagram{width:100%;height:120px;display:flex;align-items:center;justify-content:center}.mini-svg{width:100%;height:100%}.variation-position{color:#fff;font-size:.8rem;text-align:center;font-weight:500;margin-top:4px}.variation-item.selected .variation-position{font-weight:600}.picker-footer{padding:16px 24px;background:#0003;border-top:1px solid rgba(255,255,255,.1);text-align:center}.picker-footer p{margin:0;color:#ffffffb3;font-size:.9rem}.variations-grid::-webkit-scrollbar{width:8px}.variations-grid::-webkit-scrollbar-track{background:#0003;border-radius:4px}.variations-grid::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.variations-grid::-webkit-scrollbar-thumb:hover{background:#ffffff80}@media (max-width: 768px){.chord-variation-picker{width:95%;max-width:100%;max-height:90vh;border-radius:16px}.picker-header h3{font-size:1.2rem}.variations-grid{grid-template-columns:repeat(3,1fr);gap:12px;padding:16px}.variation-item{padding:10px}.mini-chord-diagram{height:100px}}@media (max-width: 480px){.chord-variation-picker{width:100%;border-radius:12px}.variations-grid{grid-template-columns:repeat(2,1fr);gap:10px}.picker-header{padding:16px}.picker-header h3{font-size:1rem}.variation-position{font-size:.7rem}}.chord-diagram-wrapper{display:inline-block;position:relative;vertical-align:top}.chord-diagram-container{display:inline-block;margin:2px;padding:2px 2px 0;background:#fffffff2;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:grab;position:relative}.chord-diagram-container:active{cursor:grabbing}.variation-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:24px;height:24px;background:#3498dbe6;color:#fff;border:none;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;padding:0;line-height:1;box-shadow:0 2px 4px #0003;transition:background .2s ease,transform .2s ease}.variation-nav-btn:hover{background:#3498db;transform:translateY(-50%) scale(1.1)}.variation-nav-btn:active{transform:translateY(-50%) scale(.95)}.variation-nav-btn.prev{left:-8px}.variation-nav-btn.next{right:-8px}.variation-indicator{position:absolute;top:-6px;right:-6px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;font-size:.65rem;font-weight:600;padding:3px 6px;border-radius:12px;box-shadow:0 2px 6px #0003;pointer-events:none;z-index:10;white-space:nowrap}.chord-diagram{margin-left:9px;display:block}.chord-diagram text{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.chord-diagram-container.dragging{transform:translateY(-3px) scale(1.1);box-shadow:0 6px 12px #0003;z-index:1000}.chord-diagram-container.piano-mode{background:linear-gradient(135deg,#fffffffa,#f8f8fff2);border:1px solid rgba(102,126,234,.2);padding:8px}.piano-chord-diagram{display:flex;flex-direction:column;align-items:center;gap:6px}.piano-keys-wrapper{position:relative;display:flex;height:auto;border-radius:4px 4px 0 0;box-shadow:0 2px 4px #0000001a}.piano-key-diagram{position:relative;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;transition:all .15s ease;box-sizing:border-box}.piano-key-diagram.white{position:relative;background:linear-gradient(180deg,#fff,#f8f8f8);border:1px solid #ccc;border-top:1px solid #999;border-radius:0 0 3px 3px;z-index:1}.piano-key-diagram.black{position:absolute;background:linear-gradient(180deg,#2a2a2a,#000);border:1px solid #000;border-radius:0 0 2px 2px;z-index:2;box-shadow:0 2px 3px #0006}.piano-key-diagram.active .note-indicator{display:block;width:10px;height:10px;background:radial-gradient(circle,#667eea,#4c5fd5);border-radius:50%;margin-bottom:2px;box-shadow:0 0 8px #667eeae6,0 0 12px #667eea80;animation:pulse 1.5s ease-in-out infinite}.piano-key-diagram.black.active .note-indicator{background:radial-gradient(circle,#4ecdc4,#38b2ac);box-shadow:0 0 8px #4ecdc4e6,0 0 12px #4ecdc480}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.85}}.note-indicator{display:none}.chord-label-piano{font-size:10px;font-weight:600;color:#333;text-align:center;padding:1px 6px 2px;background:#667eea14;border-radius:3px;letter-spacing:.3px}.scale-info-container{margin-bottom:2rem}.scale-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:1.5rem;background:linear-gradient(to right,#fbbf24,#f97316);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.scale-chords-main{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.scale-content{display:flex;grid-template-columns:1fr 1fr;gap:2rem;justify-content:center;margin:10px auto}.notes-container{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.note-badge{padding:.5rem 1rem;border-radius:50px;font-weight:600;font-size:1.125rem}.note-badge.root-note{background:#dc2626;color:#fff}.note-badge.regular-note{background:#3b82f6;color:#fff}.degrees-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.degree-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#ffffff0d;border-radius:6px;transition:background .2s ease}.degree-item:hover{background:#ffffff1a}.degree-left,.degree-right{display:flex;align-items:center;gap:.5rem}.degree-number{font-weight:700;color:#fbbf24;min-width:2rem}.degree-note{color:#fff;font-weight:600;min-width:2rem}.degree-chord{color:#a3e635;font-weight:500}.degree-function{color:#d1d5db;font-size:.875rem}.chords-display{margin:0 auto}.roman-numerals{display:flex;flex-wrap:wrap;gap:.5rem;width:100%;justify-content:center}.chord-column{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem .5rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease;min-height:180px;cursor:pointer;position:relative;flex:1 1 150px;min-width:150px;max-width:220px}.chord-column:hover{background:#ffffff14;transform:translateY(-2px)}.chord-column.selected{background:#10b98126;border-color:#10b98166;box-shadow:0 0 12px #10b98133}.has-variations-indicator{position:absolute;top:4px;right:4px;background:#fbbf24cc;color:#1f2937;font-size:.65rem;padding:2px 6px;border-radius:10px;font-weight:600}.roman-numeral{font-weight:700;font-size:1.25rem;color:#fbbf24;margin-bottom:.5rem;text-align:center}.chord-name{font-weight:600;font-size:1rem;color:#a3e635;background:#a3e63533;padding:.375rem .75rem;border-radius:8px;text-align:center;white-space:nowrap;border:1px solid rgba(163,230,53,.3)}.seventh-chords-section{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;margin-top:1rem}.seventh-chords-display{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.seventh-chord-button{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1f2937;border:1px solid rgba(251,191,36,.3);border-radius:8px;padding:.5rem 1rem;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.seventh-chord-button:hover{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#fbbf2480;transform:translateY(-1px);box-shadow:0 4px 12px #fbbf244d}.seventh-chord-button.selected{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b98180;box-shadow:0 2px 8px #10b98166}.seventh-chord-button.selected:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px #10b98180}.change-chord-block{margin-top:1.5rem;padding:1.5rem;background:#0000004d;border:2px solid rgba(16,185,129,.3);border-radius:12px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.change-chord-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.change-chord-header h3{color:#10b981;font-size:1.25rem;font-weight:600;margin:0}.close-variations-btn{background:transparent;border:none;color:#fff9;font-size:2rem;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-variations-btn:hover{background:#ffffff1a;color:#ffffffe6}.chord-variations-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.chord-variation-item{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:10px;padding:1rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem}.chord-variation-item:hover{background:#ffffff14;border-color:#10b9814d;transform:translateY(-2px)}.chord-variation-item.selected{background:#10b98126;border-color:#10b98180;box-shadow:0 4px 16px #10b98133}.chord-variation-item.selected:hover{border-color:#10b981b3;transform:translateY(-3px);box-shadow:0 6px 20px #10b9814d}.variation-label{color:#ffffffe6;font-weight:600;font-size:.9rem;text-align:center}.chord-variation-item.selected .variation-label{color:#10b981}.mini-chord-preview{width:100%;max-width:120px;height:auto;display:flex;justify-content:center;align-items:center}.mini-chord-svg{width:100%;height:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}@media (max-width: 768px){.scale-info-container{margin-bottom:1.5rem}.scale-chords-main{padding:1rem;margin:0 .5rem}.scale-title{font-size:1.5rem;margin-bottom:1rem}.roman-numerals{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:.375rem}.chord-column{padding:.5rem .25rem;min-height:100px}.roman-numeral{font-size:1rem;margin-bottom:.375rem}.chord-name{padding:.375rem .5rem;font-size:.8rem;min-width:50px}.change-chord-block{padding:1rem;margin-top:1rem}.change-chord-header h3{font-size:1rem}.chord-variations-list{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.chord-variation-item{padding:.75rem}.variation-label{font-size:.8rem}.mini-chord-preview{max-width:100px}}@media (max-width: 480px){.scale-chords-main{padding:.75rem .5rem;margin:0 .25rem}.scale-title{font-size:1.25rem}.roman-numerals{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:.25rem}.chord-column{padding:.375rem .125rem;min-height:90px}.roman-numeral{font-size:.875rem}.chord-name{padding:.25rem .375rem;font-size:.75rem;min-width:45px}}.fret-selector-container{margin-bottom:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea26,#764ba226);border-radius:10px;border:1px solid rgba(102,126,234,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;max-height:60px;display:flex;align-items:center;gap:1rem}.fret-selector-container:hover{border-color:#667eea99;box-shadow:0 8px 32px #667eea33}.fret-selector-header{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.selector-label{font-size:.85rem;font-weight:600;color:#ffffffe6;text-shadow:0 1px 4px rgba(102,126,234,.3);white-space:nowrap}.fret-count-display{display:flex;align-items:baseline;gap:.35rem;padding:.35rem .75rem;background:linear-gradient(135deg,#667eea4d,#764ba24d);border-radius:8px;border:1px solid rgba(102,126,234,.4);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 2px 8px #667eea4d,inset 0 1px #ffffff1a}.count-number{font-size:1.1rem;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(102,126,234,.5)}.count-label{font-size:.7rem;color:#ffffffb3;font-weight:500}.fret-neck-selector{position:relative;height:25px;flex:1;padding:0 .75rem;background:linear-gradient(180deg,#1e142899,#140a1ecc);border-radius:16px;border:1px solid rgba(102,126,234,.3);overflow:hidden;transition:all .3s ease;box-shadow:inset 0 1px #ffffff1a,inset 0 -1px #0000004d}.fret-neck-selector.hovering{border-color:#667eea80}.neck-strings{position:absolute;left:0;right:0;top:0;bottom:0;pointer-events:none;z-index:1}.neck-string{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 20%,rgba(255,255,255,.2) 80%,transparent 100%);box-shadow:0 0 4px #ffffff4d}.neck-visual{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:8px;pointer-events:none;z-index:2}.fret-dot{position:absolute;width:4px;height:4px;border-radius:50%;background:#667eea4d;border:1px solid rgba(102,126,234,.4);transform:translate(-50%,-50%);top:50%;transition:all .2s ease}.fret-dot.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#fff;box-shadow:0 0 6px #667eea99}.fret-dot.marker{width:6px;height:6px}.fret-dot.marker.active{background:linear-gradient(135deg,gold,#ffed4e);box-shadow:0 0 8px #ffd70099}.dot-number{display:none}.fret-range-input{position:absolute;width:100%;height:100%;left:0;top:0;opacity:0;cursor:pointer;z-index:10}.fret-presets{display:flex;gap:.4rem;flex-shrink:0}.preset-btn{position:relative;display:flex;align-items:center;justify-content:center;padding:.4rem .6rem;background:linear-gradient(135deg,#667eea33,#764ba233);border:1px solid rgba(102,126,234,.3);border-radius:6px;color:#fffc;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);overflow:hidden;font-size:.8rem;min-width:32px}.preset-btn:before{display:none}.preset-btn:hover{border-color:#667eea99;background:linear-gradient(135deg,#667eea4d,#764ba24d)}.preset-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#ffffff80;color:#fff;box-shadow:0 0 8px #667eea80}.preset-count{font-size:.8rem;font-weight:700}.preset-icon{display:none}.fretboard-scroll{overflow-x:auto;padding-bottom:1rem;display:flex;justify-content:flex-start;position:relative;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(102,126,234,.5) rgba(0,0,0,.1);isolation:isolate}.fretboard-scroll::-webkit-scrollbar{height:8px}.fretboard-scroll::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.fretboard-scroll::-webkit-scrollbar-thumb{background:#667eea80;border-radius:4px;-webkit-transition:background .3s ease;transition:background .3s ease}.fretboard-scroll::-webkit-scrollbar-thumb:hover{background:#667eeab3}.fretboard-wrapper{position:relative}.fretboard-fade-overlay{position:absolute;width:30px;right:0;top:22px;height:calc(100% - 2rem);background:linear-gradient(to left,rgba(102,126,234,.625) 0%,rgba(102,126,234,.329) 50%,transparent 100%);pointer-events:none;z-index:30;opacity:1;transition:opacity .2s ease}.fretboard-fade-overlay.hidden{opacity:0}.fretboard-content{min-width:-moz-max-content;min-width:max-content;margin:0;padding:0 .5rem;display:flex;flex-direction:column;position:relative}.fret-headers{display:flex;margin-bottom:.5rem;align-items:center}.string-label-header{width:3rem;min-width:3rem;font-size:.9rem;flex-shrink:0}.fret-number{width:3rem;text-align:center;font-size:.875rem;color:#ffffffb3;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.3)}.strings-container{display:flex;flex-direction:column;gap:.25rem}.guitar-string{display:flex;align-items:center}.string-name{width:3rem;min-width:3rem;text-align:center;font-weight:700;color:#fff;font-size:1.125rem;position:sticky;left:0;background:linear-gradient(90deg,rgba(102,126,234,.98) 0%,rgba(102,126,234,.9) 50%,transparent 100%);z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.25rem;text-shadow:0 2px 4px rgba(0,0,0,.3);border-radius:8px 0 0 8px;opacity:1;transition:opacity .3s ease}.fretboard-scroll.hide-string-names .string-name{opacity:0;pointer-events:none}.fretboard-scroll.show-string-names .string-name{opacity:1;pointer-events:auto}.frets-row{display:flex;flex-shrink:0}.fret-cell{width:3rem;height:2rem;display:flex;align-items:center;justify-content:center;position:relative}.fret-wire{position:absolute;left:0;top:0;bottom:0;width:2px;background:#ffffff4d;box-shadow:0 0 4px #fff3}.guitar-string-line{position:absolute;left:0;right:0;height:1px;background:#ffffff40;box-shadow:0 1px 2px #0003;top:50%}.note-dot{width:1.5rem;height:1.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;position:relative;z-index:10;transition:transform .2s ease;text-align:center;line-height:1}.note-dot.root-note{background:#dc2626;color:#fff;border:2px solid #fca5a5;box-shadow:0 0 0 2px #dc26264d}.note-dot.scale-note{background:#2563eb;color:#fff;border:2px solid #93c5fd}.fret-marker{width:.5rem;height:.5rem;background:#4b5563;border-radius:50%;opacity:.5}.fretboard-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:1.5rem;font-size:.875rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-dot{width:1rem;height:1rem;border-radius:50%}.legend-dot.root{background:#dc2626;border:2px solid #fca5a5}.legend-dot.scale{background:#2563eb;border:2px solid #93c5fd}.legend-dot.marker{width:.5rem;height:.5rem;background:#4b5563}.mobile-scroll-hint{display:none;text-align:center;padding:.5rem;font-size:.875rem;color:#667eea;animation:fadeInOut 3s ease-in-out}@keyframes fadeInOut{0%,to{opacity:0}20%,80%{opacity:1}}@media (max-width: 768px){.mobile-scroll-hint{display:block}}@media (max-width: 768px){.fretboard-container{padding:.75rem 0}.fretboard-title{font-size:1.25rem;margin-bottom:1rem;text-align:center;padding:0 .5rem}.fret-selector-container{max-height:110px;padding:.5rem .75rem;gap:.5rem;flex-wrap:wrap}.fret-selector-header{flex-shrink:0;gap:.5rem}.selector-label{font-size:.75rem}.fret-count-display{padding:.15rem .2rem}.count-number{font-size:.95rem}.count-label{font-size:.65rem}.fret-neck-selector{padding:0 .75rem;flex:1 1 100%;min-width:200px;order:3;height:20px}.fret-presets{flex-shrink:0;order:2;gap:.35rem}.preset-btn{padding:.35rem .4rem;font-size:.75rem;min-width:32px}.fret-dot{width:5px;height:5px}.fret-dot.marker{width:7px;height:7px}.neck-visual{height:12px}.fretboard-scroll{padding-bottom:.75rem;margin:0;padding-left:0;padding-right:0;width:100%;min-width:100%;scroll-snap-type:none;position:relative}.fretboard-scroll:after{width:30px;right:-10px;background:linear-gradient(to left,rgba(102,126,234,.6) 0%,rgba(102,126,234,.3) 50%,transparent 100%)}.fretboard-content{min-width:35.5rem;margin:0;padding:0 .5rem}.string-label-header,.string-name{width:3rem;min-width:3rem;font-size:.9rem;flex-shrink:0}.fret-number{width:2.5rem;font-size:.75rem;flex-shrink:0}.fret-cell{width:2.5rem;height:1.5rem;flex-shrink:0}.frets-row{display:flex;flex-shrink:0}.note-dot{width:1.125rem;height:1.125rem;font-size:.6rem;font-weight:600}.fretboard-legend{flex-direction:row;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1rem;padding:0 .5rem}.legend-item{font-size:.875rem}}@media (max-width: 480px){.fretboard-container{padding:.5rem 0}.fretboard-title{font-size:1.125rem;margin-bottom:.75rem;padding:0 .25rem}.fret-selector-container{padding:.625rem .75rem;gap:.625rem;max-height:none;flex-wrap:wrap}.fret-selector-header{flex-shrink:0}.fret-neck-selector{height:20px;padding:0 1.5rem;flex:1 1 100%;min-width:180px;order:3}.fret-presets{flex-shrink:0;order:2;gap:.5rem}.fret-dot{width:7px;height:7px}.fret-dot.marker{width:10px;height:10px}.neck-visual{height:14px}.selector-label{font-size:.8rem}.preset-btn{padding:.35rem .4rem;min-width:36px;font-size:.85rem}.fretboard-scroll{margin:0;padding-left:0;padding-right:0;scroll-snap-type:none}.fretboard-scroll:after{width:30px;right:-10px;background:linear-gradient(to left,rgba(102,126,234,.65) 0%,rgba(102,126,234,.3) 50%,transparent 100%)}.fretboard-content{min-width:28.5rem;padding:0 .25rem}.string-label-header,.string-name{width:2.5rem;min-width:2.5rem;font-size:.8rem;flex-shrink:0}.fret-position-spacer{width:2.5rem;min-width:2.5rem}.fret-number{width:2rem;font-size:.7rem;flex-shrink:0}.fret-cell{width:2rem;height:1.25rem;flex-shrink:0}.note-dot{width:1rem;height:1rem;font-size:.55rem;font-weight:600}.fretboard-legend{flex-direction:column;gap:.5rem;align-items:center;padding:0 .25rem}.legend-item{font-size:.8rem}}.info-container{position:fixed;z-index:1000;pointer-events:auto;transition:all .3s ease}.info-container:not(.mobile-layout).info-left{left:1rem;top:50%;transform:translateY(-50%)}.info-container:not(.mobile-layout).info-right{right:1rem;top:50%;transform:translateY(-50%)}.info-container:not(.mobile-layout).info-top{top:1rem;left:50%;transform:translate(-50%)}.info-container:not(.mobile-layout).info-bottom{bottom:1rem;left:50%;transform:translate(-50%)}.info-container.mobile-layout{position:fixed!important;bottom:1rem;left:1rem;right:1rem;top:auto!important;transform:none!important;width:auto!important}.info-toggle-button{display:flex;align-items:center;justify-content:center;gap:.5rem;background:#ffffff1a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);color:#fff;padding:.75rem 1rem;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;box-shadow:0 4px 20px #00000026;transition:all .2s ease;min-height:48px;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.info-container:not(.mobile-layout) .info-toggle-button{min-width:2.5rem;width:2.5rem;padding:.5rem .375rem;min-height:auto}.info-container:not(.mobile-layout) .toggle-content{display:flex;flex-direction:column;align-items:center;gap:.25rem}.info-container.mobile-layout .info-toggle-button{width:100%;justify-content:space-between;min-height:48px}.info-container.mobile-layout .toggle-content{display:flex;flex-direction:row;align-items:center;gap:.5rem;width:100%;justify-content:space-between}.info-toggle-button:hover{background:#ffffff26;border-color:#ffffff4d;transform:scale(1.02);box-shadow:0 6px 25px #0003}.info-toggle-button:active{transform:scale(1);box-shadow:0 2px 10px #0000001a}.toggle-content{display:flex;flex-direction:column;align-items:center;gap:.25rem}.info-icon{font-size:1rem;color:#fbbf24}.info-title-compact{display:none}.info-container.mobile-layout .info-title-compact{display:inline;color:#f3f4f6;font-weight:600}.expand-icon{color:#9ca3af;transition:transform .2s ease;font-size:.75rem}.info-container.expanded .expand-icon{transform:rotate(180deg)}.info-toggle-button:focus{outline:2px solid #8b5cf6;outline-offset:2px}.info-panel{background:#0003;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,.3);border-radius:16px;box-shadow:0 8px 40px #0000004d;overflow:hidden;transition:all .3s ease;animation:slideIn .3s ease}.info-container:not(.mobile-layout) .info-panel{position:absolute;min-width:300px;max-width:400px}.info-container:not(.mobile-layout).info-left .info-panel{left:calc(100% + .75rem);top:0}.info-container:not(.mobile-layout).info-right .info-panel{right:calc(100% + .75rem);top:0}.info-container:not(.mobile-layout).info-top .info-panel{top:calc(100% + .75rem);left:50%;transform:translate(-50%)}.info-container:not(.mobile-layout).info-bottom .info-panel{bottom:calc(100% + .75rem);left:50%;transform:translate(-50%)}.info-container.mobile-layout .info-panel{position:absolute;bottom:calc(100% + .5rem);left:0;right:0;max-height:60vh;overflow-y:auto}.info-container.collapsed .info-panel{opacity:0;visibility:hidden;transform:scale(.95);pointer-events:none}.info-container.mobile-layout.collapsed .info-panel{opacity:0;visibility:hidden;transform:translateY(20px);pointer-events:none}.info-container.expanded .info-panel{opacity:1;visibility:visible;transform:scale(1);pointer-events:auto}.info-container.mobile-layout.expanded .info-panel{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.info-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid rgba(99,102,241,.2);background:#0000004d}.info-title-with-icon{display:flex;align-items:center;gap:.5rem}.info-symbol{font-size:1.25rem;color:#fbbf24}.info-title{font-weight:600;font-size:1rem;color:#f3f4f6;margin:0}.info-controls{display:flex;align-items:center;gap:.5rem}.visibility-button,.close-button{background:none;border:none;padding:.375rem;border-radius:6px;cursor:pointer;color:#9ca3af;transition:all .2s ease;min-width:32px;min-height:32px}.visibility-button:hover,.close-button:hover{background-color:#ffffff1a;color:#d1d5db}.info-content{padding:1.25rem;animation:fadeIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.info-container{position:fixed!important;bottom:1rem!important;left:1rem!important;right:1rem!important;top:auto!important;transform:none!important;width:auto!important}.info-toggle-button{width:100%!important;min-height:48px!important;padding:.75rem 1rem!important;justify-content:space-between!important}.toggle-content{display:flex!important;flex-direction:row!important;align-items:center!important;gap:.5rem!important;width:100%!important;justify-content:space-between!important}.info-title-compact{display:inline!important;color:#f3f4f6!important;font-weight:600!important}.info-panel{position:absolute!important;bottom:calc(100% + .5rem)!important;left:0!important;right:0!important;max-height:60vh!important;overflow-y:auto!important;min-width:auto!important;max-width:none!important}.info-container.collapsed .info-panel{transform:translateY(20px)!important}.info-container.expanded .info-panel{transform:translateY(0)!important}}@media (max-width: 480px){.info-container{bottom:.5rem!important;left:.5rem!important;right:.5rem!important}.info-toggle-button{font-size:.8rem!important;padding:.625rem .75rem!important;min-height:44px!important}.info-header{padding:.75rem 1rem!important}.info-content{padding:1rem!important;font-size:.875rem!important}.info-panel{max-height:50vh!important}}.degrees-compact-floating{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;align-items:center;padding:.5rem}.degree-compact-floating{display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#3b82f626,#6366f11a);border:1px solid rgba(59,130,246,.3);border-radius:8px;padding:.75rem .5rem;min-width:3rem;box-shadow:0 2px 8px #3b82f61a;transition:all .2s ease}.degree-compact-floating:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633;background:linear-gradient(135deg,#3b82f633,#6366f126)}.degree-roman-floating{font-size:1rem;font-weight:700;color:#fbbf24;margin-bottom:.375rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}.degree-chord-floating{font-size:.75rem;font-weight:600;color:#a3e635;text-shadow:0 1px 2px rgba(0,0,0,.3)}.notes-compact-floating{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-items:center;padding:.5rem}.note-compact-floating{background:linear-gradient(135deg,#fbbf2433,#f59e0b1a);border:1px solid rgba(251,191,36,.4);border-radius:8px;padding:.5rem .75rem;font-size:.875rem;font-weight:700;color:#fbbf24;text-align:center;min-width:2.25rem;box-shadow:0 2px 8px #fbbf2426;transition:all .2s ease;text-shadow:0 1px 2px rgba(0,0,0,.3)}.note-compact-floating:hover{transform:translateY(-2px);box-shadow:0 4px 12px #fbbf2440;background:linear-gradient(135deg,#fbbf2440,#f59e0b26)}.note-compact-floating.root-note{background:linear-gradient(135deg,#ef444440,#dc262626);border-color:#ef444480;color:#fca5a5;box-shadow:0 2px 8px #ef444433}.note-compact-floating.root-note:hover{box-shadow:0 4px 12px #ef44444d;background:linear-gradient(135deg,#ef44444d,#dc262633)}.dominants-compact-floating{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;align-items:center;padding:.5rem}.dominant-item-floating{display:flex;width:100%;flex-direction:row;align-items:center;background:linear-gradient(135deg,#ef444426,#dc26261a);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:.75rem .5rem;min-width:4rem;box-shadow:0 2px 8px #ef44441a;transition:all .2s ease}.dominant-item-floating:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef444433;background:linear-gradient(135deg,#ef444433,#dc262626)}.dominant-source{flex:1;font-size:.875rem;font-weight:700;color:#ef4444;text-shadow:0 1px 2px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;text-align:center}.dominant-arrow{flex:1;font-size:.875rem;color:#9ca3af;display:flex;align-items:center;justify-content:center;text-align:center}.dominant-target{flex:1;font-size:.875rem;font-weight:700;color:#3b82f6;text-shadow:0 1px 2px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;text-align:center}.dominant-roman{font-size:.625rem;font-weight:500;color:#fbbf24;text-shadow:0 1px 2px rgba(0,0,0,.3)}.chord-display-switch{display:flex;align-items:center;justify-content:center}.switch-button{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:.75rem;border-radius:12px;transition:all .3s ease;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.switch-button:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.switch-track{width:50px;height:24px;background:#0000004d;border-radius:12px;position:relative;transition:background-color .3s ease;border:1px solid rgba(255,255,255,.2)}.switch-thumb{width:20px;height:20px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;position:absolute;top:2px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 8px #0003}.switch-thumb.guitar-mode{left:2px;background:linear-gradient(135deg,#f59e0b,#d97706)}.switch-thumb.piano-mode{left:26px;background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.switch-label{font-size:.75rem;font-weight:500;color:#d1d5db;transition:color .2s ease}.switch-button:hover .switch-label{color:#f9fafb}.switch-thumb svg{transition:all .2s ease}.switch-button:hover .switch-thumb{transform:scale(1.1)}.switch-thumb.chords-on{left:2px;background:linear-gradient(135deg,#10b981,#059669)}.switch-thumb.chords-off{left:26px;background:linear-gradient(135deg,#6b7280,#4b5563)}.progression-builder-panel{padding:1rem;margin:0 auto;min-height:-moz-fit-content;min-height:fit-content;pointer-events:auto;position:relative;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 8px 32px #0003;overflow:visible}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f0f0f0}.panel-title{font-size:1.5rem;font-weight:600;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.panel-actions{display:flex;gap:.5rem}.export-button{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.export-button:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.clear-button{padding:.5rem 1rem;background:#ff6b6b;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.clear-button:hover{background:#ff5252;transform:translateY(-1px);box-shadow:0 2px 8px #ff6b6b4d}.quick-chords-section,.progression-section{margin-bottom:2rem}.section-title{font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 1rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.quick-chords-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}.quick-chord-button{padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s ease;border:2px solid transparent}.quick-chord-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;border-color:#ffffff4d}.quick-chord-button.selected{background:linear-gradient(135deg,#4caf50,#45a049);border-color:#fff3}.quick-chord-button.selected:hover{box-shadow:0 4px 12px #4caf5066}.selected-chords-section{padding:1rem;background:#4caf501a;border-radius:12px;border:1px solid rgba(76,175,80,.2)}.seventh-notes-section{padding:1rem;background:#ffc1071a;border-radius:12px;border:1px solid rgba(255,193,7,.2)}.seventh-chord-button{padding:.75rem;background:linear-gradient(135deg,#ffc107,#ff8f00);color:#333;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s ease;border:2px solid transparent}.seventh-chord-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ffc10766;border-color:#ffffff4d}.progression-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.add-line-button{padding:.5rem 1rem;background:#2196f3;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.add-line-button:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px #2196f34d}.progression-lines{display:flex;flex-direction:column;gap:1rem}.progression-line{background:#f8f9fa;border-radius:12px;padding:1rem;border:2px solid transparent;transition:all .3s ease}.progression-line.active{background:#e3f2fd;border-color:#2196f3;box-shadow:0 2px 12px #2196f333}.line-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.line-number{font-weight:600;color:#555;min-width:60px}.line-select-button{width:24px;height:24px;border-radius:50%;border:2px solid #2196f3;background:#fff;color:#2196f3;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s ease}.line-select-button:hover,.progression-line.active .line-select-button{background:#2196f3;color:#fff}.remove-line-button{width:24px;height:24px;border-radius:50%;border:none;background:#ff6b6b;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;transition:all .2s ease;margin-left:auto}.remove-line-button:hover{background:#ff5252;transform:scale(1.1)}.line-chords{display:flex;flex-wrap:nowrap;gap:.75rem;min-height:3rem;align-items:center;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}.line-chords::-webkit-scrollbar{height:6px}.line-chords::-webkit-scrollbar-track{background:transparent}.line-chords::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.line-chords::-webkit-scrollbar-thumb:hover{background:#ffffff80}.empty-line{color:#999;font-style:italic;flex:1;text-align:center;padding:1rem;background:#ffffff80;border-radius:8px;border:2px dashed #ddd}.progression-chord-item{position:relative;display:flex;align-items:center;flex-shrink:0}.progression-chord-item .chord-display{padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid transparent;min-width:60px;text-align:center}.progression-chord-item .chord-display:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66;border-color:#ffffff4d}.progression-chord-item .remove-chord-button{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:#ff6b6b;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;line-height:1;transition:all .2s ease;box-shadow:0 2px 6px #0003}.progression-chord-item .remove-chord-button:hover{background:#ff5252;transform:scale(1.1)}.chord-with-diagram{display:flex;flex-direction:column;align-items:center;position:relative;padding:.1rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;min-width:60px;max-width:220px;min-height:60px;flex-shrink:0}.chord-diagram-inline{background:transparent;border-radius:0;padding:0;box-shadow:none}.chord-diagram-inline .inline-chord-container .inline-display{transform-origin:center}.chord-text-small{font-size:1.3rem;font-weight:600;color:#fff;text-align:center}.remove-chord-button.inline-mode{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;border:none;border-radius:50%;width:16px;height:16px;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.remove-chord-button.inline-mode:hover{background:#dc2626;transform:scale(1.1)}.progression-info{text-align:center;padding-top:1rem;border-top:1px solid #eee;margin-top:1rem}.progression-stats{color:#666;font-size:.9rem}.chord-selection-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.scale-chords-section,.seventh-notes-section{background:#ffffff1a;border-radius:8px;padding:.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2)}.scale-chords-section .section-title,.seventh-notes-section .section-title{font-size:.95rem;font-weight:600;color:#fff;margin:0 0 .5rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.compact-chords-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(20px,85px));gap:.5rem}.compact-chord-button,.compact-seventh-button{padding:1px;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.8rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.chord-text-display{font-weight:700;color:#1565c0;font-size:14px}.chord-text-large{background:#fffffff2;border-radius:8px;padding:12px 16px;font-size:18px;font-weight:700;border:2px solid #4CAF50;color:#333;text-align:center;min-width:60px;box-shadow:0 2px 8px #00000026}.compact-chord-button{color:#1565c0}.compact-chord-button:hover{background:#bbdefbfa;box-shadow:0 4px 12px #2196f34d}.compact-seventh-button{color:#e65100}.compact-seventh-button:hover{background:#ffcc02fa;transform:translateY(-1px);box-shadow:0 4px 12px #ff98004d}.inline-chord-container{width:100%;max-width:210px;height:225px;top:0;transform:scale(.8);position:relative}.inline-chord-container .inline-display{transform:scale(1);transform-origin:center;margin:0}@media (max-width: 768px){.progression-builder-panel{padding:.5rem;min-height:auto}.panel-header{flex-direction:column;gap:.5rem;align-items:flex-start;margin-bottom:.75rem}.chord-selection-grid{grid-template-columns:1fr;gap:.5rem}.scale-chords-section,.seventh-notes-section{padding:.25rem}.compact-chords-grid{grid-template-columns:repeat(3,1fr);gap:.25rem}.compact-chord-button,.compact-seventh-button{padding:0;font-size:.8rem;min-height:45px;border-radius:4px;overflow:hidden}.inline-chord-container{max-width:70px;height:auto;transform:scale(.45);margin:-15px 0 -12px}.compact-chord-button .chord-diagram-container,.compact-seventh-button .chord-diagram-container{margin:0;padding:0;border-radius:3px;box-shadow:none;max-height:140px}.progression-header{flex-direction:column;gap:.5rem;align-items:flex-start}.line-header{flex-wrap:wrap;gap:.5rem}.line-chords{gap:.5rem;padding-right:1rem;-webkit-overflow-scrolling:touch;touch-action:pan-x}.progression-chord-item .chord-display{padding:.6rem .8rem;font-size:.9rem;flex-shrink:0}}.music-production-panel{padding:2rem;margin:0 auto;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;position:relative}.music-production-panel:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff05;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none}.panel-header{margin-bottom:1.5rem}.header-content{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;z-index:10}.panel-title{font-size:1.5rem;font-weight:700;margin:0;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.panel-actions{display:flex;gap:.75rem}.draggable-chord-diagram{cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .2s ease,box-shadow .2s ease;pointer-events:auto}.draggable-chord-diagram:active{cursor:grabbing}.draggable-chord-diagram:hover{transform:translateY(-2px)}.draggable-chord-text{cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .2s ease,box-shadow .2s ease;pointer-events:auto}.draggable-chord-text:active{cursor:grabbing}.draggable-chord-text:hover{transform:translateY(-2px)}.chord-text-display{background:#fffffff2;border-radius:8px;padding:8px 12px;font-size:16px;font-weight:700;border:2px solid #4CAF50;color:#333;text-align:center;min-width:40px;box-shadow:0 2px 8px #00000026}.toggle-chord-display{background:linear-gradient(135deg,#4caf50,#45a049)!important;color:#fff!important;font-size:12px}.chords-layer.has-diagrams{min-height:120px}.chords-layer.has-text{min-height:50px}.chords-layer{position:relative;width:100%;min-height:50px;height:auto;border-bottom:1px dashed rgba(255,255,255,.2);margin-bottom:12px;background:#ffffff08;border-radius:4px;padding-bottom:8px;transition:min-height .3s ease}.action-button{padding:.5rem 1rem;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;transition:all .2s ease;margin-left:.5rem}.action-button:hover{background:#fff3}.action-button:disabled{opacity:.6;cursor:not-allowed}.action-button:disabled:hover{background:#ffffff1a}.action-button+.action-button{margin-left:0}.pdf-export-container{font-family:Arial,sans-serif!important}.pdf-export-container *{box-sizing:border-box}@media print{.music-production-panel{background:#fff!important;color:#000!important;margin:0;padding:20mm}.draggable-chord{background:#f0f0f0!important;color:#333!important;border:1px solid #ddd!important}.lyrics-input{background:transparent!important;border:none!important;color:#000!important;font-size:14px!important}.action-button{display:none!important}}.music-editor{position:relative;z-index:2}.editor-container{display:flex;flex-direction:column;gap:1rem}.music-line-card{background:#00000026;border-radius:8px;padding:.6rem;margin-bottom:.8rem;transition:background .2s ease}.music-line-card:hover{background:#00000040}.line-header{margin-bottom:.4rem}.line-number{color:#fff9;font-size:.85rem;font-weight:500}.chords-section{margin-bottom:.5rem}.chords-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.3rem}.chord-container{position:relative}.chord-input-wrapper{position:relative;display:inline-block}.chord-input{width:60px;padding:.3rem .5rem;border:none;border-radius:3px;text-align:center;font-weight:600;font-size:.9rem;color:#fff;background:#0006;transition:background .2s ease}.chord-input:focus{outline:none;background:#0009}.add-section-btn{width:24px;height:24px;border-radius:3px;border:none;background:#ffffff1a;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-left:.3rem}.add-section-btn:hover{background:#fff3}.add-icon{font-size:1.3rem}.lyrics-section{margin-bottom:.5rem}.lyrics-row{display:flex;gap:.5rem;align-items:flex-start;flex-wrap:wrap}.lyrics-container{flex:1;min-width:200px;position:relative}.lyrics-input-wrapper{position:relative;display:block}.lyrics-input{width:100%;min-height:60px;padding:.6rem .8rem;border:none;border-radius:3px;font-family:inherit;font-size:27px;line-height:1.6;resize:vertical;background:#0006;color:#fff;transition:background .2s ease;word-wrap:break-word;overflow-wrap:break-word}.lyrics-input:focus{outline:none;background:#0009}.chord-text-container{position:relative;width:100%;min-height:80px}.draggable-chord{position:absolute;top:8px;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:grab;z-index:5;transition:transform .1s ease,box-shadow .2s ease;border-radius:20px;padding:6px 12px;background:#ffffffe6;color:#333;font-weight:600;font-size:.9rem;min-width:40px;box-shadow:0 2px 6px #00000026;touch-action:none}.draggable-chord:hover{z-index:10;transform:translateY(-1px);box-shadow:0 4px 12px #0003;background:#fffffff2}.draggable-chord:active{cursor:grabbing!important;transform:translateY(-1px) scale(1.05);box-shadow:0 4px 12px #0000004d;background:#fffffff2;z-index:1000!important}.lyrics-line{margin-top:0}.lyrics-input:focus{outline:none;border-color:#fff6;background:#ffffff26;box-shadow:0 0 0 3px #ffffff1a}.lyrics-input::-moz-placeholder{color:#ffffff80;font-style:italic}.lyrics-input::placeholder{color:#ffffff80;font-style:italic}.lyrics-input:hover{border-color:#ffffff4d;background:#ffffff1f}.add-chord-btn{position:absolute;right:0;top:5px;width:30px;height:30px;border:2px dashed rgba(255,255,255,.3);background:transparent;color:#fff;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.add-chord-btn:hover{border-color:#ffffff80;background:#ffffff1a}.text-line{position:relative}.line-text-input{width:100%;min-height:60px;padding:.5rem;border:none;border-radius:4px;font-family:inherit;font-size:.9rem;line-height:1.5;resize:vertical;background:#0000004d;color:#fff;transition:background .2s ease}.line-text-input:focus{outline:none;background:#00000080}.line-text-input::-moz-placeholder{color:#fff6;font-style:italic}.line-text-input::placeholder{color:#fff6;font-style:italic}.lyrics-border{position:absolute;top:0;left:0;right:0;bottom:0;border:2px solid transparent;border-radius:16px;background:linear-gradient(45deg,#4ecdc4,#44a08d);background-clip:padding-box;opacity:0;transition:opacity .3s ease;pointer-events:none}.lyrics-input.modern:focus+.lyrics-border{opacity:.3}.remove-section-btn.modern{position:absolute;top:-10px;right:-10px;width:30px;height:30px;border-radius:50%;border:none;background:#ff6b6be6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10;box-shadow:0 4px 15px #ff6b6b4d}.remove-section-btn.modern:hover{background:#ff6b6b;transform:scale(1.15);box-shadow:0 6px 20px #ff6b6b80}.remove-icon-small{font-size:1rem;font-weight:700}.empty-state{text-align:center;padding:2rem;color:#ffffffb3;font-size:.9rem}@media (max-width: 768px){.music-production-panel{padding:.75rem .5rem;margin:0}.header-content{flex-direction:column;gap:1rem;text-align:center}.panel-title{font-size:1.5rem}.panel-actions{justify-content:center;gap:.5rem;flex-wrap:wrap}.action-button{padding:.5rem .75rem;font-size:.875rem;min-width:-moz-max-content;min-width:max-content}.music-line-card{margin:.5rem 0;padding:.75rem}.chords-layer.has-diagrams{min-height:120px}.chords-layer.has-text{min-height:40px}.lyrics-input{font-size:.875rem;padding:.5rem}.chord-text-display{padding:6px 10px;font-size:14px}}@media (max-width: 480px){.music-production-panel{padding:.5rem .25rem}.panel-title{font-size:1.25rem}.panel-actions{gap:.375rem}.action-button{padding:.375rem .5rem;font-size:.8rem;flex:1;max-width:calc(50% - .1875rem)}.music-line-card{margin:.375rem 0;padding:.5rem}.chords-layer.has-diagrams{min-height:120px}.chords-layer.has-text{min-height:35px}.lyrics-input{font-size:.8rem;padding:.375rem}.chord-text-display{padding:4px 8px;font-size:12px;min-width:35px}}.add-song-section{background:#9c27b00d;border-radius:12px;padding:1rem;margin-bottom:1.5rem;border:1px solid rgba(156,39,176,.1)}.section-title{font-size:1.5rem;font-weight:700;margin:0;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.song-form,.form-container{display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.form-row:has(.song-lyrics-textarea){align-items:flex-start}.song-lyrics-textarea{flex:1;min-width:100%;padding:.75rem;border:2px solid rgba(156,39,176,.2);border-radius:8px;font-size:.95rem;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .2s ease}.song-lyrics-textarea:focus{outline:none;border-color:#9c27b0}.song-title-input{flex:1;min-width:200px;padding:.75rem;border:2px solid rgba(156,39,176,.2);border-radius:8px;font-size:.95rem;transition:border-color .2s ease}.song-title-input:focus{outline:none;border-color:#9c27b0}.progression-select{flex:1;min-width:200px;padding:.75rem;border:2px solid rgba(156,39,176,.2);border-radius:8px;font-size:.95rem;background:#fff;cursor:pointer;transition:border-color .2s ease}.progression-select:focus{outline:none;border-color:#9c27b0}.add-song-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#9c27b0,#673ab7);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;white-space:nowrap}.add-song-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #9c27b04d}.add-song-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.songs-section{margin-top:2rem}.empty-songs{text-align:center;padding:2rem;background:#f9f9f9;border-radius:12px;color:#666;font-style:italic}.no-progressions-message{text-align:center;padding:2rem;background:#9c27b00d;border-radius:12px;color:#666;border:2px dashed rgba(156,39,176,.2)}.no-progressions-message p{margin:.5rem 0}.no-progressions-message p:first-child{font-size:1.2rem;font-weight:600;color:#9c27b0}.songs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-top:1rem}.song-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a;border:1px solid rgba(156,39,176,.1);transition:all .2s ease}.song-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026;border-color:#9c27b033}.song-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.song-title{font-size:1.2rem;font-weight:600;color:#333;margin:0}.remove-song-button{width:24px;height:24px;border-radius:50%;border:none;background:#ff6b6b;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;transition:all .2s ease}.remove-song-button:hover{background:#ff5252;transform:scale(1.1)}.song-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.song-info{display:flex;flex-direction:column;gap:.25rem}.song-key{font-weight:600;color:#9c27b0;font-size:.9rem}.song-date{font-size:.8rem;color:#666}.bpm-control{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:#555}.bpm-input{width:60px;padding:.25rem .5rem;border:1px solid #ddd;border-radius:4px;text-align:center}.song-progression{margin-bottom:1rem}.progression-title{font-weight:600;color:#555;margin-bottom:.5rem;font-size:.9rem}.progression-chords{display:flex;flex-wrap:wrap;gap:.5rem}.chord-badge{padding:.25rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:6px;font-size:.8rem;font-weight:600}.song-lyrics{margin-bottom:1rem}.lyrics-title{font-weight:600;color:#555;margin-bottom:.5rem;font-size:.9rem}.lyrics-content{background:#9c27b00d;padding:1rem;border-radius:8px;font-size:.9rem;line-height:1.6;white-space:pre-wrap;color:#555;border:1px solid rgba(156,39,176,.1)}.song-actions{display:flex;gap:.5rem;flex-wrap:wrap}.song-actions button{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease;flex:1;min-width:80px}.play-button{background:#4caf50;color:#fff}.play-button:hover{background:#45a049}.edit-button{background:#ff9800;color:#fff}.edit-button:hover{background:#f57c00}.export-button{background:#2196f3;color:#fff}.export-button:hover{background:#1976d2}@media (max-width: 768px){.form-row{flex-direction:column;align-items:stretch}.song-title-input,.progression-select{min-width:unset}.songs-grid{grid-template-columns:1fr}.song-details{flex-direction:column;align-items:flex-start}}.bottom-panel{position:fixed;bottom:0;left:0;right:0;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-top:1px solid rgba(255,255,255,.3);z-index:2000;box-shadow:0 -8px 32px #00000026;min-height:60px;transition:none;will-change:height;transform:translateZ(0);border-radius:12px 12px 0 0}.panel-drag-handle{position:absolute;top:-5px;left:0;right:0;height:10px;cursor:ns-resize;display:flex;justify-content:center;align-items:center;background:transparent;z-index:2002}.bottom-controls{display:flex;justify-content:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;z-index:2001;border-radius:12px 12px 0 0}.bottom-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bottom-button:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.bottom-button.active{background:#ffffff4d;border-color:#ffffff80;box-shadow:0 4px 16px #0000004d}.chord-count{background:#ffffff4d;padding:.2rem .5rem;border-radius:8px;font-size:.8rem;font-weight:600}.bottom-panel-content{height:calc(100% - 60px);min-height:200px;max-height:calc(85vh - 80px);overflow-y:auto;overflow-x:hidden;background:linear-gradient(135deg,#667eea,#764ba2);scrollbar-width:thin;scrollbar-color:rgba(102,126,234,.3) transparent;scroll-behavior:smooth;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;position:relative;z-index:2001;touch-action:pan-y;transition:transform .2s cubic-bezier(.25,.46,.45,.94)}.bottom-panel-content::-webkit-scrollbar{width:8px}.bottom-panel-content::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.bottom-panel-content::-webkit-scrollbar-thumb{background:#667eea4d;border-radius:4px;-webkit-transition:background .2s ease;transition:background .2s ease}.bottom-panel-content::-webkit-scrollbar-thumb:hover{background:#667eea80}@media (max-width: 768px){.bottom-panel{min-height:60px;border-radius:8px 8px 0 0;z-index:2100}.panel-drag-handle{pointer-events:auto;opacity:1;height:20px;top:-10px;z-index:2003}.bottom-controls{pointer-events:auto;touch-action:none;cursor:ns-resize}.bottom-button{pointer-events:auto}.bottom-controls{padding:.75rem .5rem;gap:.5rem;flex-wrap:wrap;justify-content:space-around}.bottom-button{padding:.75rem 1rem;font-size:.85rem;min-width:-moz-max-content;min-width:max-content;flex:1;max-width:calc(50% - .25rem);min-height:48px;display:flex;align-items:center;justify-content:center}.button-text{font-size:.8rem;white-space:nowrap}.button-icon{width:1rem;height:1rem;flex-shrink:0;position:relative;top:-6px;left:-7px}.bottom-panel-content{height:65vh;max-height:65vh;min-height:300px;touch-action:pan-y;overscroll-behavior:contain;overflow-y:scroll;-webkit-overflow-scrolling:touch;overflow-x:hidden;pointer-events:auto}.drag-indicator{width:60px;height:5px;background:#fffc}.panel-drag-handle:hover .drag-indicator,.drag-indicator.dragging{width:60px;height:6px}}@media (max-width: 480px){.bottom-panel{min-height:55px}.bottom-controls{padding:.5rem .375rem;gap:.375rem;justify-content:space-between}.bottom-button{padding:.625rem .75rem;font-size:.8rem;flex:1;max-width:calc(50% - .1875rem);min-height:44px}.button-text{font-size:.75rem;text-align:center}.button-icon{flex-shrink:0;position:relative;top:-6px;left:-6px}.bottom-panel-content{max-height:100%;min-height:100%}}.top-header{position:fixed;top:0;left:0;right:0;z-index:3000;box-shadow:0 8px 32px #00000026;min-height:60px;transition:height .1s ease-out;border-radius:0 0 12px 12px}.top-header.block{position:relative;top:auto;left:auto;right:auto;margin-bottom:1rem;border-radius:12px}.top-header.floating{position:fixed}.panel-drag-handle.bottom{position:absolute;bottom:-5px;left:0;right:0;height:10px;cursor:ns-resize;display:flex;justify-content:center;align-items:center;background:transparent;z-index:3002}.drag-indicator{width:40px;height:4px;background:#667eea99;border-radius:2px;transition:all .2s ease}.panel-drag-handle:hover .drag-indicator,.drag-indicator.dragging{background:#667eeae6;width:60px;height:6px}.top-controls{display:flex;justify-content:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;z-index:3001;border-radius:0 0 12px 12px}.top-header.block .top-controls{border-radius:12px 12px 0 0}.top-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.top-button:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.top-button.active{background:#ffffff4d;border-color:#ffffff80;box-shadow:0 4px 16px #0000004d}.button-icon{font-size:1.2rem}.button-text{font-size:.95rem;display:flex;align-items:center;gap:.3rem}.top-panel-content{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;overflow-y:auto;border-top:1px solid rgba(255,255,255,.3)}.top-panel-content.floating{height:calc(100% - 60px);max-height:calc(50vh - 60px)}.top-panel-content.block{height:auto;max-height:none;border-bottom-left-radius:12px;border-bottom-right-radius:12px}.shortcuts-content h3,.favorites-content h3,.controls-content h3{margin:0 0 1rem;color:#4a5568;font-size:1.1rem;font-weight:600}.shortcuts-grid,.favorites-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.shortcut-item{padding:.75rem 1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:8px;color:#4a5568;cursor:pointer;transition:all .2s ease}.shortcut-item:hover{background:#667eea33;transform:translateY(-1px)}.favorite-item{padding:.75rem 1rem;background:#ffc1071a;border:1px solid rgba(255,193,7,.2);border-radius:8px;color:#4a5568}.controls-grid{display:flex;flex-direction:column;gap:1rem}.control-group{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.2);border-radius:8px}.control-group label{color:#4a5568;font-weight:500}@media (max-width: 768px){.top-controls{gap:.5rem;padding:.75rem}.top-button{padding:.5rem 1rem;font-size:.9rem}.button-text{display:none}.shortcuts-grid,.favorites-grid{grid-template-columns:1fr;gap:.75rem}.control-group{flex-direction:column;gap:.5rem;align-items:flex-start}}.top-header.block+*{margin-top:0}.top-header{animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app-container:has(.top-header.floating) .main-content{padding-top:7rem}.app-container:has(.top-header.floating .top-panel-content) .main-content{padding-top:7rem}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-4{height:1rem}.h-5{height:1.25rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-8{width:2rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.bg-black\/20{background-color:#0003}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-900\/20{background-color:#1e3a8a33}.bg-green-900\/20{background-color:#14532d33}.bg-purple-900\/20{background-color:#581c8733}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-white\/5{background-color:#ffffff0d}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-600{--tw-gradient-from: #2563eb var(--tw-gradient-from-position);--tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-red-600{--tw-gradient-from: #dc2626 var(--tw-gradient-from-position);--tw-gradient-to: rgb(220 38 38 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-pink-600{--tw-gradient-to: #db2777 var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-blue-300{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-300{--tw-text-opacity: 1;color:rgb(253 224 71 / var(--tw-text-opacity, 1))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.piano-key{transition:all .2s ease}.piano-key:hover{transform:translateY(-2px)}.fret-dot{transition:all .3s ease}.fret-dot:hover{transform:scale(1.2)}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.group:hover .group-hover\:text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
