.draggable-tempo-container{display:flex;align-items:center;gap:8px;background:#ffffff08;padding:2px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.08);-webkit-user-select:none;user-select:none}.tempo-arrows{display:flex;flex-direction:column;gap:1px}.tempo-arrow-btn{background:transparent;border:none;color:#fff6;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:all .2s;height:12px}.tempo-arrow-btn:hover{color:#667eea}.tempo-arrow-btn:active{transform:scale(.9)}.tempo-value-display{display:flex;align-items:baseline;gap:3px;cursor:ns-resize;padding:2px 4px;border-radius:4px;transition:background .2s}.tempo-value-display:hover{background:#667eea1a}.tempo-value-display.dragging{background:#667eea40;color:#667eea}.tempo-number{font-size:.9rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.tempo-unit{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.playback-settings-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000}.playback-settings-modal{background:#1f2937;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;width:90%;max-width:360px;color:#fff;box-shadow:0 10px 25px #00000080;animation:modalPop .2s ease-out}@keyframes modalPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.playback-settings-modal .modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.4rem}.playback-settings-modal .modal-header h3{margin:0;font-size:1.1rem;font-weight:600}.playback-settings-modal .close-btn{background:none;border:none;color:var(--text-muted);font-size:1.35rem;cursor:pointer;line-height:1}.playback-settings-modal .modal-content{display:flex;flex-direction:column;gap:1rem}.playback-settings-modal .setting-row{display:flex;flex-direction:column;gap:.35rem}.playback-settings-modal .setting-row label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.playback-settings-modal input[type=range]{width:100%}.playback-settings-modal select{background:#374151;color:#fff;border:1px solid rgba(255,255,255,.2);padding:.3rem .45rem;border-radius:6px;font-size:.9rem;cursor:pointer;outline:none;transition:border-color .2s}.playback-settings-modal select:focus{border-color:#6366f1}.playback-settings-modal .octave-controls{display:flex;gap:.5rem}.playback-settings-modal button.octave-btn{background:#374151;color:#fff;border:1px solid rgba(255,255,255,.2);padding:.3rem .8rem;border-radius:6px;cursor:pointer;font-size:.95rem;transition:background .2s}.playback-settings-modal button.octave-btn:hover{background:#4b5563}.setting-divider{height:1px;background:#ffffff1a;margin:.5rem 0}.setting-label-with-toggle{display:flex;justify-content:space-between;align-items:center}.toggle-switch{width:44px;height:22px;background:#374151;border-radius:11px;position:relative;cursor:pointer;transition:background .2s;border:1px solid rgba(255,255,255,.1)}.toggle-switch.active{background:#6366f1}.toggle-handle{width:18px;height:18px;background:#fff;border-radius:50%;position:absolute;top:1px;left:1px;transition:transform .2s}.toggle-switch.active .toggle-handle{transform:translate(22px)}.piano-samples-row{padding-left:.5rem;border-left:3px solid #6366f1;margin-top:-.5rem;background:#6366f10d;padding:.5rem;border-radius:4px}.piano-samples-info{display:flex;flex-direction:column;gap:.25rem}.samples-status-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .4rem;border-radius:4px;display:inline-block;align-self:flex-start}.samples-status-badge.loading{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.samples-status-badge.ready{background:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.header{margin-bottom:3rem;animation:fadeInDown .6s ease-out}.header-left{display:flex;align-items:center;gap:1.5rem}.title{font-size:2.5rem;font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.02em}.header-loading-spinner{width:20px;height:20px;border:2.5px solid rgba(102,126,234,.15);border-top:2.5px solid #667eea;border-radius:50%;animation:spin .8s linear infinite;display:inline-block;margin-left:.5rem;vertical-align:middle}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.upgrade-pill-btn{display:flex;align-items:center;gap:.5rem;background:#667eea1a;border:1px solid rgba(102,126,234,.3);color:#667eea;padding:.5rem 1rem;border-radius:2rem;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s ease}.upgrade-pill-btn:hover{background:#667eea26;border-color:#667eea}.pill-icon{font-size:1rem}.mode-nav-header{display:flex;background:#ffffff0d;padding:.25rem;border-radius:.75rem;border:1px solid rgba(255,255,255,.1)}.nav-btn-small{background:none;border:none;color:var(--text-muted);padding:.375rem .875rem;border-radius:.5rem;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative}.notification-dot{position:absolute;top:2px;right:4px;width:7px;height:7px;background-color:#ef4444;border-radius:50%;border:1.5px solid #1a1b26;box-shadow:0 0 5px #ef444480}.notification-badge-mobile{background-color:#ef4444;color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:1rem;text-align:center;line-height:1}.nav-btn-small.active{background:#667eea;color:#fff;box-shadow:0 2px 8px #667eea66}.header-top{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 1rem}.header-actions{display:flex;align-items:center;gap:1.5rem}.auth-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:.5rem 1rem;border-radius:.75rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.auth-btn:hover{background:#ffffff1a;border-color:#fff3}.user-avatar{width:2.25rem;height:2.25rem;border:2px solid #667eea}.subtitle{font-size:1.125rem;color:var(--text-secondary);font-weight:400;margin-top:1rem}.stripe-checkout-btn{width:100%;padding:1rem;margin-bottom:1.5rem;background:#635bff;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 6px #32325d1c,0 1px 3px #00000014}.stripe-checkout-btn:hover{background:#7a73ff;box-shadow:0 7px 14px #32325d1a,0 3px 6px #00000014}.stripe-checkout-btn:disabled{background:#a0a0a0;cursor:not-allowed;transform:none;box-shadow:none}.divider-text{text-align:center;color:var(--text-muted);margin:1rem 0;font-size:.9rem;position:relative}.divider-text:before,.divider-text:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:#ffffff1a}.divider-text:before{left:0}.divider-text:after{right:0}.hamburger-btn{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem}.brand-container{display:flex;align-items:center;gap:1rem}.mobile-menu-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .2s ease-out}.mobile-menu{position:absolute;top:0;left:0;bottom:0;width:80%;max-width:300px;background:#1a1b26;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;padding:1.5rem;animation:slideRight .3s ease-out;box-shadow:10px 0 30px #00000080;z-index:1001;overflow-y:auto;max-height:100vh}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem}.mobile-menu-header h2{margin:0;font-size:1.5rem;background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.close-menu-btn{background:none;border:none;color:var(--text-muted);font-size:2rem;line-height:1;cursor:pointer;padding:0}.mobile-nav-links{display:flex;flex-direction:column;gap:1rem;flex:1}.mobile-nav-item{background:none;border:none;text-align:left;color:var(--text-secondary);font-size:1.1rem;font-weight:500;padding:.75rem;border-radius:.5rem;cursor:pointer;transition:all .2s}.mobile-nav-item.active{background:#667eea1a;color:#667eea}.mobile-menu-footer{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem}.upgrade-btn-mobile,.login-btn-mobile{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer}.signout-btn-mobile{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-muted);padding:.75rem;border-radius:.5rem;cursor:pointer}@keyframes slideRight{0%{transform:translate(-100%)}to{transform:translate(0)}}.test-mode-badge{font-size:.6rem;background:#ff9800;color:#000;padding:2px 6px;border-radius:4px;font-weight:700;margin-left:8px;vertical-align:middle;display:inline-block;text-shadow:none;letter-spacing:normal}@media(max-width:768px){.header{margin-bottom:2rem}.header-top{flex-direction:column;gap:1rem;align-items:stretch}.header-left{justify-content:center;width:100%;gap:1rem}.title{font-size:2rem}.header-actions{display:none}.desktop-only{display:none!important}.hamburger-btn{display:block}.brand-container{display:flex;align-items:center;gap:.5rem;width:100%;justify-content:center;position:relative}.brand-container .hamburger-btn{position:absolute;left:0}}@media(max-width:480px){.title{font-size:1.65rem}}.library-dropdown-container{position:relative;display:inline-block}.library-dropdown{position:absolute;top:120%;right:0;width:320px;max-height:400px;overflow-y:auto;background:#1f2937;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;box-shadow:0 10px 15px -3px #00000080,0 4px 6px -2px #0000004d;z-index:100;padding:.5rem;animation:fadeInDropdown .2s ease-out}.library-empty-state{padding:2rem 1rem;text-align:center;color:var(--text-muted);font-size:.9rem;font-style:italic}.library-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:.375rem;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.05)}.library-item:last-child{border-bottom:none}.library-item:hover{background:#ffffff1a}.library-item-content{display:flex;flex-direction:column;gap:.25rem;overflow:hidden;flex:1;margin-right:.5rem}.library-item-name{font-weight:600;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-item-chords{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-delete-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem;line-height:1;padding:.25rem .5rem;border-radius:.25rem;transition:all .2s;opacity:.6}.library-delete-btn:hover{opacity:1;color:#ef4444;background:#ef44441a}@keyframes fadeInDropdown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.admin-toggle-container{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:2rem;transition:all .2s ease;cursor:pointer;margin-right:10px;-webkit-user-select:none;user-select:none}.admin-toggle-container:hover{background:#ffffff0f;border-color:#ffffff26}.admin-toggle-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;transition:color .2s ease}.admin-toggle-container:hover .admin-toggle-label{color:var(--text-primary)}.switch{position:relative;display:inline-block;width:32px;height:18px}.switch input{opacity:0;width:0;height:0;position:absolute}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ffffff1a;transition:.25s ease;border:1px solid rgba(255,255,255,.15)}.slider:before{position:absolute;content:"";height:12px;width:12px;left:2px;bottom:2px;background-color:#fff;transition:.25s ease;box-shadow:0 1px 3px #0006}.switch input:checked+.slider{background-color:#667eea;border-color:#667eea}.switch input:checked+.slider:before{transform:translate(14px)}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.mobile-admin-toggle-container{display:flex;justify-content:space-between;align-items:center;cursor:pointer;background:#ffffff05;border:1px solid rgba(255,255,255,.08);color:var(--text-secondary);font-size:1.1rem;font-weight:500;padding:.75rem;border-radius:.5rem;transition:all .2s;-webkit-user-select:none;user-select:none;margin:.5rem .75rem}.mobile-admin-toggle-container:hover{background:#ffffff0d;color:var(--text-primary)}.intro-modal-overlay{position:fixed;inset:0;background:#0a0f1ebf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;z-index:99999;overflow-y:auto;padding:2.5rem 1rem 1.5rem;box-sizing:border-box;animation:introFadeIn .25s ease-out}.intro-modal{background:#111827;border:1px solid rgba(255,255,255,.1);border-radius:1.25rem;padding:2.25rem;width:100%;max-width:460px;box-shadow:0 25px 50px -12px #000000b3,0 0 40px #6366f126;text-align:center;position:relative;margin:0;animation:introScaleIn .3s cubic-bezier(.34,1.56,.64,1)}.intro-modal-overlay::-webkit-scrollbar{width:6px}.intro-modal-overlay::-webkit-scrollbar-track{background:#ffffff05}.intro-modal-overlay::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:1rem}.intro-modal-overlay::-webkit-scrollbar-thumb:hover{background:#ffffff40}.intro-close-x{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-muted, #9ca3af);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.intro-close-x:hover{background:#ffffff14;color:#fff}.intro-content-container{margin-bottom:2rem;min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center}.intro-screenshot-wrapper{width:100%;border-radius:.75rem;border:1px solid rgba(255,255,255,.1);overflow:hidden;margin-bottom:1.25rem;box-shadow:0 4px 6px -1px #0000004d,0 2px 4px -1px #0003;background:#0000004d}.intro-screenshot{width:100%;height:auto;max-height:180px;object-fit:cover;object-position:center top;display:block;transition:transform .3s ease}.intro-screenshot-wrapper:hover .intro-screenshot{transform:scale(1.02)}.intro-title{margin:0 0 .5rem;font-size:1.6rem;font-weight:700;background:var(--primary-gradient, linear-gradient(135deg, #818cf8 0%, #6366f1 100%));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.025em}.intro-subtitle{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:#a3bffa;letter-spacing:.02em}.intro-description{color:#d1d5db;margin:0 0 1.25rem;line-height:1.6;font-size:.975rem;font-weight:400}.intro-hint-box{background:#f59e0b0f;border:1px dashed rgba(245,158,11,.25);border-radius:.5rem;padding:.75rem 1rem;font-size:.85rem;color:#f59e0b;line-height:1.4;text-align:left;width:100%;box-sizing:border-box}.intro-footer{display:flex;flex-direction:column;align-items:center;gap:1.25rem;border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem}.intro-dots{display:flex;gap:.5rem}.intro-dot{width:.5rem;height:.5rem;border-radius:50%;background:#fff3;border:none;cursor:pointer;padding:0;transition:all .2s ease}.intro-dot.active{background:#6366f1;width:1.25rem;border-radius:1rem}.intro-dot:hover:not(.active){background:#fff6}.intro-actions{display:flex;justify-content:center;gap:.75rem;width:100%}.intro-btn{padding:.625rem 1.75rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.95rem;border:none;outline:none;display:inline-flex;align-items:center;justify-content:center}.intro-btn.primary{background:var(--primary-gradient, linear-gradient(135deg, #6366f1 0%, #4f46e5 100%));color:#fff;flex:1;max-width:160px;box-shadow:0 4px 12px #6366f14d}.intro-btn.primary:hover{box-shadow:0 6px 16px #6366f173;transform:translateY(-1px)}.intro-btn.secondary{background:#ffffff14;color:#f3f4f6;border:1px solid rgba(255,255,255,.1)}.intro-btn.secondary:hover{background:#ffffff26}.intro-skip-link{background:none;border:none;color:#9ca3af;font-size:.8rem;text-decoration:underline;cursor:pointer;transition:color .2s ease;padding:.25rem;margin-top:.25rem}.intro-skip-link:hover{color:#fff}@keyframes introFadeIn{0%{opacity:0}to{opacity:1}}@keyframes introScaleIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes introBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:480px),(max-height:740px){.intro-modal-overlay{padding-top:1rem}.intro-modal{padding:1.25rem 1rem;border-radius:1rem}.intro-screenshot-wrapper{margin-bottom:.75rem}.intro-screenshot{max-height:120px}.intro-content-container{min-height:auto;margin-bottom:1rem}.intro-title{font-size:1.3rem}.intro-subtitle{font-size:.85rem;margin-bottom:.5rem}.intro-description{font-size:.875rem;margin-bottom:.75rem;line-height:1.45}.intro-hint-box{padding:.5rem .75rem;font-size:.775rem}.intro-footer{padding-top:.75rem;gap:.75rem}.intro-btn{padding:.5rem 1rem;font-size:.85rem}.intro-dots{gap:.35rem}}.splash-screen{position:fixed;inset:0;background:var(--dark-bg);display:flex;align-items:center;justify-content:center;z-index:10000;overflow:hidden;background-image:radial-gradient(circle at 20% 30%,rgba(102,126,234,.15) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(245,87,108,.15) 0%,transparent 50%)}.splash-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;animation:fadeIn .8s ease-out}.logo-container{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.splash-logo{font-size:4rem;z-index:2;filter:drop-shadow(0 0 20px rgba(102,126,234,.5));animation:float 3s ease-in-out infinite}.pulse-ring{position:absolute;width:100%;height:100%;border:2px solid #667eea;border-radius:50%;animation:pulse 2s ease-out infinite;opacity:0}.pulse-ring-delayed{position:absolute;width:100%;height:100%;border:2px solid #f5576c;border-radius:50%;animation:pulse 2s ease-out 1s infinite;opacity:0}.splash-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em;margin:0}.splash-subtitle{color:var(--text-secondary);font-size:1.1rem;font-weight:500;letter-spacing:.05em;margin:0}.loading-bar-container{width:240px;height:4px;background:#ffffff0d;border-radius:2px;overflow:hidden;margin-top:1rem}.loading-bar-progress{width:40%;height:100%;background:var(--primary-gradient);border-radius:2px;animation:loadingBar 2s ease-in-out infinite}@keyframes pulse{0%{transform:scale(.6);opacity:.8}to{transform:scale(1.8);opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes loadingBar{0%{transform:translate(-100%)}50%{transform:translate(150%)}to{transform:translate(-100%)}}.app-footer{padding:1.5rem 1rem;background-color:var(--element-bg);border-top:1px solid var(--card-border);margin-top:2rem;display:flex;justify-content:center;align-items:center}.footer-content{display:flex;align-items:center;gap:1rem;color:var(--text-secondary);font-size:.9rem}.footer-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease,transform .2s ease;background:none;border:none;padding:0;font-size:inherit;font-family:inherit;cursor:pointer}.footer-link:hover{color:var(--accent)}.footer-link.instagram:hover{color:#e1306c}.footer-separator{color:var(--card-border)}@media(max-width:768px){.app-footer{display:none!important}}.bottom-nav{display:flex;position:fixed;top:0;bottom:0;left:0;width:80px;flex-direction:column;justify-content:flex-start;gap:1.5rem;background-color:var(--dark-bg);border-right:1px solid var(--card-border);z-index:1000;padding-top:2rem;padding-bottom:env(safe-area-inset-bottom)}body{padding-left:calc(80px + 1rem)!important}@media(max-width:768px){.bottom-nav{width:100%;height:60px;box-sizing:content-box;inset:auto 0 0;flex-direction:row;justify-content:space-around;align-items:center;border-right:none;border-top:1px solid var(--card-border);padding-top:0;padding-bottom:env(safe-area-inset-bottom);gap:0}body{padding-left:.5rem!important;padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.hide-on-bottom-nav{display:none!important}}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);padding:8px 4px;cursor:pointer;transition:color .2s;font-size:.75rem;gap:4px;width:100%}.bottom-nav-item-container{position:relative;display:flex;width:100%}@media(max-width:768px){.bottom-nav-item-container,.bottom-nav-item{flex:1}}.bottom-nav-item.active{color:var(--primary-color)}.bottom-nav-item:hover{color:var(--text-color)}.bottom-nav-library-drawer{position:fixed;left:80px;bottom:0;top:0;width:320px;background-color:var(--dark-bg);border-right:1px solid var(--card-border);box-shadow:4px 0 12px #0006;z-index:999;display:flex;flex-direction:column}@media(max-width:768px){.bottom-nav-library-drawer{left:0;right:0;top:auto;width:auto;max-height:50vh;border-right:none;border-top:1px solid var(--card-border);border-radius:16px 16px 0 0;box-shadow:0 -4px 12px #0006}}.bottom-nav-library-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--card-border)}.bottom-nav-library-header h3{margin:0;font-size:1rem}.bottom-nav-library-header button{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;line-height:1;cursor:pointer}.bottom-nav-library-content{overflow-y:auto;padding:8px 0}.instrument-dropdown-menu{position:absolute;left:100%;top:0;margin-left:8px;background-color:var(--dark-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column;min-width:120px;overflow:hidden;z-index:1001}@media(max-width:768px){.instrument-dropdown-menu{left:0;bottom:100%;top:auto;margin-left:0;margin-bottom:8px;box-shadow:0 -4px 12px #0000004d}}.instrument-dropdown-item{background:transparent;border:none;color:var(--text-secondary);padding:12px 16px;font-size:.9rem;font-weight:500;cursor:pointer;text-align:left;border-bottom:1px solid var(--card-border);transition:all .2s ease}.instrument-dropdown-item:last-child{border-bottom:none}.instrument-dropdown-item:hover,.instrument-dropdown-item.active{background-color:#ffffff0d;color:var(--primary-color, #ffffff)}.feedback-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.feedback-modal{background-color:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:2rem;max-width:500px;width:90%;color:var(--text-primary);position:relative;box-shadow:0 10px 30px #00000080;animation:modalScaleIn .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes modalScaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.close-button{position:absolute;top:1rem;right:1.5rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:color .2s ease}.close-button:hover{color:var(--text-primary)}.feedback-modal h3{margin-top:0;margin-bottom:.5rem;color:var(--text-primary);font-size:1.25rem}.feedback-intro{color:var(--text-secondary);font-size:.95rem;margin-bottom:1.5rem}.feedback-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;font-size:.9rem;color:var(--text-primary)}.form-group input,.form-group textarea{background-color:#0003;border:1px solid var(--card-border);border-radius:8px;padding:.75rem;color:var(--text-primary);font-family:inherit;transition:border-color .2s ease,outline .2s ease}.form-group textarea{resize:none;min-height:44px;overflow:hidden}.form-group input:focus,.form-group textarea:focus{outline:2px solid var(--accent);border-color:var(--accent)}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group small{color:var(--text-secondary);font-size:.8rem}.feedback-modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:.5rem}.feedback-btn{padding:.75rem 1.5rem;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:all .2s ease}.feedback-btn:disabled{opacity:.6;cursor:not-allowed}.feedback-btn.primary{background-color:var(--accent);color:#fff}.feedback-btn.primary:not(:disabled):hover{background-color:var(--accent-hover)}.feedback-btn.secondary{background-color:transparent;color:var(--text-secondary);border:1px solid var(--card-border)}.feedback-btn.secondary:not(:disabled):hover{background-color:#ffffff0d;color:var(--text-primary)}.feedback-error{background-color:#dc26261a;color:#ef4444;padding:.75rem;border-radius:8px;font-size:.9rem;border:1px solid rgba(220,38,38,.2)}.feedback-success{background-color:#10b9811a;border:1px solid rgba(16,185,129,.2);color:#10b981;padding:2rem;border-radius:8px;text-align:center;margin:2rem 0}.feedback-success p{margin:.5rem 0}.feedback-widget{position:fixed;bottom:2rem;right:2rem;z-index:1000;background:#667eead9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:9999px;padding:.6rem 1rem .6rem 1.25rem;display:flex;align-items:center;gap:.75rem;color:#fff;cursor:pointer;box-shadow:0 10px 25px -5px #0000004d,0 8px 10px -6px #0000004d;transition:all .4s cubic-bezier(.16,1,.3,1);transform:translateY(120%) scale(.9);opacity:0;-webkit-user-select:none;user-select:none}.feedback-widget.visible{transform:translateY(0) scale(1);opacity:1}.feedback-widget:hover{background:#667eea;box-shadow:0 15px 35px #667eea66}.feedback-widget:active{scale:.98}.feedback-widget-content{display:flex;align-items:center;gap:.5rem}.feedback-icon{font-size:1.2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.feedback-text{font-weight:600;font-size:.9rem;white-space:nowrap;letter-spacing:.01em}.feedback-widget-close{background:#ffffff1a;border:none;color:#fffc;font-size:1.2rem;cursor:pointer;padding:0;line-height:1;transition:all .2s;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%}.feedback-widget-close:hover{color:#fff;background:#fff3;transform:rotate(90deg)}@media(max-width:768px){.feedback-widget{display:none!important}}@media print{.feedback-widget{display:none!important}}.piano-diagram-container{width:100%;background:#0006;padding:10px;border-radius:8px;margin-bottom:10px;display:flex;justify-content:center}.piano-diagram{display:flex;flex-direction:row;height:60px;width:95%;margin:0 auto}.piano-white-key{flex:1 1 0%;height:100%;background-color:#fff;border:1px solid #ccc;border-radius:0 0 3px 3px;position:relative;box-sizing:border-box;z-index:1}.piano-white-key.active{background-color:#ef4444}.piano-black-key{position:absolute;top:0;right:-45%;width:90%;height:60%;background-color:#111;border-radius:0 0 2px 2px;z-index:2;box-shadow:inset 0 -1px 2px #00000080}.piano-black-key.active{background-color:#ef4444}.chord-diagram-svg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.2));width:100%;height:auto;display:block}.export-voicing-btn{background:#4a5568;border:1px solid rgba(255,255,255,.4);border-radius:6px;color:#fff;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px #0000004d;z-index:20;pointer-events:auto}.export-voicing-btn:hover{background:#2d3748;border-color:#fff9;transform:scale(1.1)}.export-voicing-btn svg{display:block}.clickable-chord-wrapper{position:relative;cursor:pointer;border-radius:.5rem;padding:.25rem .25rem 0;transition:all .2s ease;width:100%;box-sizing:border-box}.clickable-chord-wrapper:hover{background:#ffffff1a;box-shadow:0 4px 12px #0003}.clickable-chord-wrapper:active{background:#ffffff26}.clickable-chord-overlay{position:absolute;inset:0;background:#0006;opacity:0;display:flex;align-items:center;justify-content:center;transition:opacity .2s;border-radius:8px;pointer-events:none;z-index:10}.clickable-chord-wrapper:hover .clickable-chord-overlay{opacity:1;pointer-events:auto}.overlay-icons{display:flex;gap:12px;align-items:center}.edit-icon{font-size:24px;color:#fff;text-shadow:0 0 10px rgba(0,0,0,.5);cursor:pointer;transition:transform .2s}.edit-icon:hover{transform:scale(1.2)}.locked-indicator{position:absolute;top:-5px;right:-5px;background:gold;color:#000;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 2px 4px #0006;z-index:5;pointer-events:none;border:1px solid rgba(255,255,255,.2)}.voicing-selector-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.voicing-selector-modal{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;padding:1.5rem;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;animation:scaleIn .2s cubic-bezier(.175,.885,.32,1.275)}.voicing-selector-modal.piano-mode{max-width:900px}.voicing-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.voicing-selector-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-primary)}.voicing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;padding:.5rem;justify-items:center;justify-content:center}.voicing-grid.piano-mode{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.voicing-content{overflow-y:auto;flex:1;padding-right:.5rem;display:flex;flex-direction:column;gap:1.5rem}.voicing-section-header{display:flex;align-items:center;gap:1rem;margin-top:1rem;padding:0 .5rem}.voicing-section-header h4{margin:0;color:var(--text-muted);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;white-space:nowrap}.section-divider{flex:1;height:1px;background:linear-gradient(to right,rgba(255,255,255,.1),transparent)}.voicing-option{display:flex;flex-direction:column;align-items:center;width:clamp(90px,14vw,119px);background:#ffffff08;border:1px solid transparent;border-radius:.75rem;padding:.4rem;cursor:pointer;transition:all .2s ease}.voicing-option.piano-mode{width:clamp(280px,30vw,350px)}.voicing-option:hover{background:#ffffff14}.voicing-option.selected{border-color:#667eea;background:#667eea1a;box-shadow:0 0 15px #667eea33}.voicing-label{margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:768px){.voicing-selector-modal{padding:.85rem;width:95%;max-height:90vh}.voicing-selector-modal.piano-mode{max-width:98%}.voicing-grid.piano-mode{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.75rem}.voicing-option.piano-mode{width:100%;max-width:300px}}.all-paths-section{background:transparent;border:none;border-top:1px solid rgba(255,255,255,.08);border-radius:0;padding:1.5rem 0 0;margin-top:1.5rem;margin-bottom:0;animation:fadeInUp .4s ease-out}.all-paths-header{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;margin-bottom:1rem}.all-paths-title-row{display:flex;align-items:center;gap:.5rem}.paths-icon{font-size:1.25rem}.all-paths-header h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.paths-subtitle-container{padding-left:2rem;margin-top:.25rem;display:flex;flex-direction:column;gap:.5rem}.paths-subtitle{font-size:.85rem;color:var(--text-muted);margin:0;line-height:1.6;max-width:800px}.paths-subtitle.benefits{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-weight:500}.sparkle{font-size:1rem;filter:drop-shadow(0 0 4px rgba(255,215,0,.4))}.highlight-benefit{color:var(--text-primary);font-weight:700;position:relative;display:inline-block}.highlight-benefit:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background:var(--accent-gradient);opacity:.5}.paths-container{display:flex;flex-direction:column;gap:.75rem}.chord-path{background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;padding:.5rem;transition:all .2s ease}.chord-path:hover{border-color:#667eea66;background:#ffffff14}.path-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;padding-left:.25rem}.path-scroll-container{position:relative;width:100%;-webkit-mask-image:linear-gradient(to right,black 85%,transparent 100%);mask-image:linear-gradient(to right,black 85%,transparent 100%)}.path-scroll-container.expanded{-webkit-mask-image:none;mask-image:none;overflow:visible}.path-bars{display:flex;gap:0;overflow-x:auto;padding-bottom:.5rem;padding-right:2rem;flex-shrink:1;scrollbar-width:none}.path-bar{display:flex;align-items:flex-start}.bar-divider{font-size:4rem;font-weight:200;color:var(--text-muted);opacity:.3;padding:0 .5rem;display:flex;align-items:flex-end;justify-content:center;height:144px;flex-shrink:0}.bar-chords{display:flex;gap:.25rem;padding:.25rem 0}.path-chord{width:var(--chord-width);flex-shrink:0;display:flex;flex-direction:column;align-items:center;border-radius:.65rem;transition:all .2s ease;border:2px solid transparent;padding:.25rem}.path-chord.ukulele-mode{width:var(--ukulele-chord-width)}.path-chord.piano-mode{width:var(--piano-chord-width)}.path-chord.playing-glow{background:#f59e0b14;box-shadow:0 0 12px #f59e0b40;border-color:#f59e0b80}.path-chord svg{width:100%;height:auto}.beat-space{width:clamp(60px,10vw,80px);flex-shrink:0}.path-chord.unknown{background:#f5576c1a;border-radius:.5rem;padding:.5rem}.path-chord-info{display:flex;flex-direction:column;align-items:center;margin-bottom:.25rem;width:100%}.path-chord-name{font-size:1rem;font-weight:800;color:var(--text-primary);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.measure-badge{font-size:.6rem;font-weight:500;color:var(--text-muted);background:#ffffff0d;padding:1px 4px;border-radius:4px;border:1px solid rgba(255,255,255,.1);white-space:nowrap;margin-top:2px}.measure-badge.small{font-size:.55rem;opacity:.8}.path-chord .unknown-text{font-size:.7rem;color:var(--text-muted)}.path-bars::-webkit-scrollbar{display:none}@media(max-width:480px){.paths-subtitle-container{display:none}.path-header-row{flex-direction:column;align-items:flex-start;gap:.5rem}}.path-header-row{display:flex;align-items:center;margin-bottom:.5rem;gap:.75rem}.path-action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.path-blur{filter:blur(2px);opacity:.6;pointer-events:none;-webkit-user-select:none;user-select:none;transition:all .3s ease}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-5px)}}.upgrade-overlay-compact{margin:1rem 0;padding:1rem 1.5rem;background:#667eea14;border:1px solid rgba(102,126,234,.2);border-radius:1rem;display:flex;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn .4s ease-out}.upgrade-compact-content{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%}.upgrade-text-grp{display:flex;align-items:center;gap:.75rem}.upgrade-icon-small{font-size:1.25rem;animation:bounce 1s infinite alternate}.upgrade-overlay-compact h4{margin:0;font-size:1rem;font-weight:600;color:#fff}.upgrade-button-small{background:var(--accent-gradient);color:#fff;border:none;padding:.5rem 1.25rem;border-radius:.75rem;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d;white-space:nowrap}.upgrade-button-small:hover{box-shadow:0 6px 15px #667eea66}.path-bars.expanded{display:flex;flex-wrap:wrap;overflow-x:visible;padding-right:0;gap:.25rem;row-gap:1rem;align-items:flex-start}.path-bars.expanded.with-divisions{padding-left:2.5rem}.path-bars.expanded .path-bar,.path-bars.expanded .bar-chords{display:contents}.path-bars.expanded .bar-divider{display:flex;height:144px;font-size:4rem;opacity:.3;flex-shrink:0;margin-left:-2.5rem}.path-expand-btn{width:100%;background:transparent;border:none;border-top:1px solid rgba(255,255,255,.1);padding:.5rem;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .2s ease;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem;border-radius:0 0 .75rem .75rem}.path-expand-btn:hover{background:#ffffff0d;color:var(--text-primary)}.path-expand-btn.top{border-top:none;border-bottom:1px solid rgba(255,255,255,.1);margin-top:0;margin-bottom:.5rem;border-radius:.75rem .75rem 0 0}.arrow-triangle-down{width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:10px solid currentColor;display:inline-block;margin-left:0;transform:translateY(1px);opacity:.7}.arrow-triangle-up{width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-bottom:10px solid currentColor;display:inline-block;margin-left:0;transform:translateY(-1px);opacity:.7}.show-more-paths-btn{width:100%;background:#ffffff0d;border:1px solid var(--card-border);color:var(--text-secondary);padding:.75rem;border-radius:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.show-more-paths-btn:hover{background:#ffffff1a;color:var(--text-primary)}.lock-indicator-badge{background:#ffd70026;border:1px solid rgba(255,215,0,.4);color:gold;font-size:.65rem;font-weight:700;padding:.15rem .5rem;border-radius:100px;display:flex;align-items:center;gap:4px;text-transform:uppercase;letter-spacing:.05em;animation:lockBadgeFade 3s forwards ease-out;white-space:nowrap;pointer-events:none;box-shadow:0 0 10px #ffd7001a}.lock-indicator-badge span{font-size:.75rem}@keyframes lockBadgeFade{0%{opacity:0;transform:translate(-10px)}10%{opacity:1;transform:translate(0)}80%{opacity:1;transform:translate(0)}to{opacity:0;transform:translateY(-5px)}}.piano-keyboard-container{width:100%;overflow-x:auto;padding:.5rem 1rem;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.piano-keyboard{position:relative;height:160px;background:#0006;padding:10px;border-radius:12px;box-shadow:0 10px 30px #00000080;border:1px solid rgba(255,255,255,.05);margin:0 auto}.piano-key{position:absolute;top:10px;border-radius:0 0 5px 5px;transition:background .2s ease,box-shadow .2s ease;-webkit-user-select:none;user-select:none;cursor:default;box-sizing:border-box}.piano-key.white{width:28px;height:140px;background:linear-gradient(to bottom,#eee,#fff);border:1px solid #cccccc;z-index:1}.piano-key.black{width:18px;height:90px;background:linear-gradient(to bottom,#333,#000);border:1px solid #444444;z-index:10;border-radius:0 0 3px 3px;box-shadow:2px 2px 5px #0006}.piano-key.white.voicing-active,.piano-key.white.chord-active,.piano-key.white.scale-active,.piano-key.white.avoid-active{z-index:5}.piano-key.black.voicing-active,.piano-key.black.chord-active,.piano-key.black.scale-active,.piano-key.black.avoid-active{z-index:15}.piano-key.voicing-active.white{background:#ef4444;box-shadow:inset 0 0 10px #0003,inset 0 0 15px #fff3;border:1.5px solid white}.piano-key.voicing-active.black{background:#ef4444;box-shadow:inset 0 0 5px #ffffff4d;border:1px solid #ef4444}.piano-key.chord-active.white{background:linear-gradient(to bottom,#fee2e2e6,#fca5a5e6);box-shadow:inset 0 0 10px #ef444433,inset 0 0 15px #fff6;border-color:#ef4444}.piano-key.chord-active.black{background:linear-gradient(to bottom,#fecacaf2,#f87171f2);box-shadow:inset 0 0 5px #fff3;border:1px solid #ef4444}.piano-key.scale-active.white{background:linear-gradient(to bottom,#fee2e2b3,#fca5a5b3);box-shadow:inset 0 0 10px #ef444433,inset 0 0 15px #fff6;border-color:#ef4444}.piano-key.scale-active.black{background:linear-gradient(to bottom,#fecacacc,#f87171cc);box-shadow:inset 0 0 5px #ffffff1a;border:1px solid #ef4444}.piano-key.avoid-active.white{background:#7f1d1db3;border-color:#ef4444}.piano-key.avoid-active.black{background:#7f1d1d;border:1px solid rgba(239,68,68,.3)}.piano-key.next-active:after{content:"";position:absolute;inset:0;background:#a855f726;box-shadow:inset 0 0 8px #a855f766;pointer-events:none;z-index:5;border-radius:inherit;border:1.5px solid rgba(168,85,247,.3)}.piano-key.detected.white{background:linear-gradient(to bottom,#fbbf24,#f59e0b)!important;border-color:#d97706!important;box-shadow:inset 0 0 12px #fff6!important}.piano-key.detected.black{background:linear-gradient(to bottom,#f59e0b,#b45309)!important;border-color:#92400e!important;box-shadow:inset 0 0 8px #ffffff4d!important}.key-markers{position:absolute;bottom:10px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:4px;pointer-events:none;z-index:25}.black .key-markers{bottom:15px}.marker.detected-note{position:absolute;top:-90px;background:#f59e0b;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 0 15px #f59e0b99;animation:detected-bounce .4s infinite alternate}.black .marker.detected-note{top:-60px}.detected-label{color:#fff;font-weight:800;font-size:.7rem}@keyframes detected-bounce{0%{transform:translateY(0)}to{transform:translateY(-5px)}}.degree-label{font-size:.65rem;font-weight:800;text-align:center;width:100%;color:#fff;line-height:1}.degree-label.root{font-size:.65rem;font-weight:900;display:inline-block}@keyframes piano-beat{0%{filter:drop-shadow(0 0 0px rgba(102,126,234,0))}50%{filter:drop-shadow(0 0 20px rgba(102,126,234,.4))}to{filter:drop-shadow(0 0 0px rgba(102,126,234,0))}}.piano-keyboard-container.beat-flash .piano-keyboard{animation:piano-beat .2s ease-out}.piano-keyboard-container::-webkit-scrollbar{height:8px}.piano-keyboard-container::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.piano-keyboard-container::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.voicing-card{position:relative;padding:10px;background:#1e1e1e;border-radius:8px;border:1px solid #333;transition:all .2s ease;text-align:center;width:clamp(90px,14vw,119px)}.voicing-card:hover{border-color:#555;background:#252525}.voicing-card-overlay{position:absolute;top:8px;right:8px;opacity:0;transition:opacity .2s ease}.voicing-card:hover .voicing-card-overlay{opacity:1}.voicing-card.piano-mode{width:clamp(280px,30vw,350px)}.chord-diagram{margin:0 auto}.chord-typeahead{width:100%;margin-bottom:.25rem;overflow:hidden;min-height:34px}.typeahead-scroll{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.typeahead-scroll::-webkit-scrollbar{display:none}.typeahead-pill{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--text-primary);padding:4px 12px;border-radius:16px;font-size:.9rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;flex-shrink:0}.typeahead-pill:hover{background:var(--accent-color, #667eea);border-color:var(--accent-color, #667eea);color:#fff}.typeahead-pill:active{transform:scale(.96);background:var(--accent-color, #667eea)}.chord-chart-container{width:100%;margin:.5rem auto;padding:.75rem 0;background:transparent;color:var(--text-primary, #ffffff);font-family:Inter,-apple-system,sans-serif;position:relative;border:none;box-shadow:none}.chart-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.chart-title{margin:0;font-size:1.2rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.chart-key-context{font-size:.9rem;font-weight:600;color:var(--text-secondary, #9ca3af)}.chart-key-context .key-root{color:#ef4444;font-weight:800}.chart-transpose-controls{display:flex;align-items:center;background:#ffffff08;border:1px solid rgba(255,255,255,.08);padding:2px;border-radius:8px;height:32px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.chart-transpose-controls .transpose-label{font-size:.65rem;font-weight:700;color:#fff6;text-transform:uppercase;letter-spacing:.06em;padding:0 .5rem;-webkit-user-select:none;user-select:none}.chart-transpose-controls .transpose-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.06);border-radius:6px;color:var(--text-primary);width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-weight:800;font-size:.85rem;transition:all .2s cubic-bezier(.4,0,.2,1);line-height:1}.chart-transpose-controls .transpose-btn:hover{background:#667eea40;border-color:#667eea66;color:#818cf8;box-shadow:0 0 8px #667eea33}.chart-transpose-controls .transpose-btn:active{transform:scale(.95)}.chord-loading-spinner{width:20px;height:20px;border:2px solid rgba(129,140,248,.1);border-top:2px solid #818cf8;border-radius:50%;animation:chord-spin 1s linear infinite;box-shadow:0 0 8px #818cf84d}@keyframes chord-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chord-chart-grid{display:flex;flex-direction:column;gap:.75rem}.chart-system{display:flex;position:relative}.chart-measure{background:#ffffff08;display:flex;position:relative;padding:.4rem .2rem;align-items:stretch;justify-content:space-evenly;border-right:2px solid rgba(255,255,255,.15);flex:1;min-width:0;border-radius:4px;transition:background .3s ease}.chart-system>.chart-measure:last-child{border-right:3px solid rgba(255,255,255,.4)}.chart-system>.chart-measure:first-child{border-left:3px solid rgba(255,255,255,.4)}.chart-measure.first-in-system{border-left:3px solid rgba(255,255,255,.4)}.chart-chord{flex:1;display:flex;justify-content:center;align-items:stretch;position:relative;min-height:0;min-width:0;padding:.3rem .2rem .4rem;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;border-radius:8px;border:1px solid transparent}.chart-chord.playing{background:#38bdf81f;border-color:#38bdf866;box-shadow:0 0 16px #38bdf840}.chart-chord.playing:hover{background:#38bdf82e}.chart-chord-inner{display:flex;flex-direction:column;align-items:center;width:100%;height:100%;position:relative}.chord-symbol{display:flex;flex-direction:column;align-items:center;width:fit-content}.chart-chord-diagram{display:flex;justify-content:center;flex-shrink:0;overflow:visible;margin:0 auto .2rem}.chart-chord-diagram.piano{overflow:hidden;padding:0 5px}.chart-chord-diagram svg{max-width:500px!important;height:auto!important;transition:transform .2s ease}.chart-chord-diagram.piano svg{max-width:800px!important}.chord-name-main{font-size:1.6rem;font-weight:800;line-height:1.1;letter-spacing:-.04em;display:flex;align-items:baseline;margin-top:.1rem;text-shadow:0 2px 4px rgba(0,0,0,.25)}.chord-root{font-size:1.6rem}.chord-ext{font-size:.9rem;vertical-align:super;margin-left:1px;color:var(--text-secondary, rgba(255, 255, 255, .7))}.chart-measure .chart-chord:only-child{justify-content:flex-start;padding-left:.5rem}.chart-measure .chart-chord:not(:only-child) .chord-name-main,.chart-measure .chart-chord:not(:only-child) .chord-root{font-size:1.25rem}.chart-measure .chart-chord:not(:only-child) .chord-ext{font-size:.75rem}.chart-measure .chart-chord:not(:only-child) .analysis-mode{font-size:.55rem}.chord-analysis{display:flex;flex-direction:column;align-items:center;gap:2px;margin-top:.1rem;min-height:1.1rem}.analysis-roman{font-size:.85rem;font-weight:800;color:#f87171;font-family:Georgia,Times New Roman,serif;letter-spacing:.05em}.analysis-mode{font-size:.6rem;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.02em}.chart-close-btn{position:absolute;top:.5rem;right:.5rem;background:#0000000d;border:none;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;font-size:.75rem;transition:all .2s;z-index:100}.chart-close-btn:hover{background:#ef44441a;color:#ef4444}.chord-delete-btn{position:absolute;top:-6px;left:-6px;width:24px;height:24px;border-radius:50%;background:transparent;border:none;color:var(--text-muted, rgba(255, 255, 255, .5));display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:scale(.8);transition:all .2s ease;z-index:20;box-shadow:none}.chart-chord:hover .chord-delete-btn{opacity:1;transform:scale(1)}.chord-delete-btn:hover{background:transparent!important;color:#ef4444!important;transform:scale(1.1)!important;box-shadow:none!important}.chord-edit-icon-btn{position:absolute;top:-6px;right:-6px;width:24px;height:24px;border-radius:50%;background:transparent;border:none;color:var(--text-muted, rgba(255, 255, 255, .5));display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:scale(.8);transition:all .2s ease;z-index:20;box-shadow:none}.chart-chord:hover .chord-edit-icon-btn{opacity:1;transform:scale(1)}.chord-edit-icon-btn:hover{background:transparent!important;color:#38bdf8!important;transform:scale(1.1)!important;box-shadow:none!important}.duration-select-wrapper{margin:.2rem auto 0;display:flex;justify-content:center;z-index:10}.chord-duration-badge{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;color:var(--text-secondary, #9ca3af);font-size:.65rem;font-weight:700;padding:.1rem .4rem;cursor:pointer;outline:none;transition:all .2s ease;text-align:center;appearance:none;-webkit-appearance:none}.chord-duration-badge:hover{background:#ffffff26;color:#fff;border-color:#667eea66}.chart-chord.dragging{opacity:.3;border:1px dashed rgba(255,255,255,.5);transform:scale(.95)}.chart-chord.drag-over{border:2px dashed #4facfe;background:#4facfe14;transform:scale(1.02)}.chart-insertion-trigger{position:absolute;top:0;bottom:0;width:14px;display:flex;align-items:center;justify-content:center;z-index:30;cursor:pointer;opacity:0;transition:opacity .2s ease,transform .2s ease}.left-trigger{left:-7px}.right-trigger{right:-7px}.chart-insertion-trigger:after{content:"";position:absolute;top:5%;bottom:5%;width:2px;background:linear-gradient(to bottom,transparent,#4facfe,transparent);box-shadow:0 0 8px #4facfecc;transform:scaleX(.5);transition:transform .2s ease}.chart-insertion-trigger:hover:after{transform:scaleX(1.5)}.trigger-icon{width:16px;height:16px;border-radius:50%;background:#4facfe;color:#fff;font-size:.8rem;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 0 8px #4facfecc;transform:scale(.7);transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.chart-insertion-trigger:hover{opacity:1}.chart-insertion-trigger:hover .trigger-icon{transform:scale(1.1)}.inline-edit-container{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;z-index:50;padding:.2rem 0}.inline-edit-input{width:90px;background:#000000a6;border:2px solid #4facfe;border-radius:6px;color:#fff;font-size:1.1rem;font-weight:700;text-align:center;padding:.3rem .2rem;outline:none;box-shadow:0 0 10px #4facfe66;transition:all .2s ease}.inline-edit-input:focus{border-color:#00c6ff;box-shadow:0 0 14px #00c6ff99}.empty-builder{padding:1.5rem 1rem!important}.chart-builder-empty-placeholder{text-align:center;margin-bottom:2.5rem;position:relative}.empty-glow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:250px;height:120px;background:radial-gradient(circle,rgba(102,126,234,.15) 0%,transparent 70%);pointer-events:none}.empty-title{font-size:1.4rem;font-weight:800;margin:0 0 .5rem;background:linear-gradient(135deg,#00c6ff,#0072ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}.empty-description{font-size:.95rem;color:var(--text-secondary, #9ca3af);max-width:480px;margin:0 auto;line-height:1.5}.empty-grid{max-width:900px;margin:0 auto}.empty-builder-measure{height:160px;border:2px dashed rgba(255,255,255,.08)!important;background:#ffffff03!important;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center!important;gap:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.empty-builder-measure:hover{border-color:#667eea4d!important;background:#667eea08!important;box-shadow:inset 0 0 12px #667eea0d}.measure-number{font-size:.7rem;font-weight:700;color:#fff3;text-transform:uppercase;letter-spacing:.05em;position:absolute;top:8px;left:8px}.add-chord-btn{background:#ffffff08;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary, #9ca3af);border-radius:20px;padding:.7rem 1.4rem;font-size:.95rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s ease}.add-chord-btn:hover{background:#667eea26;border-color:#667eea66;color:#fff;box-shadow:0 0 12px #667eea40;transform:translateY(-1px)}.add-chord-btn .plus{font-size:.95rem;font-weight:800}.chart-chord.append-card{border:2px dashed rgba(255,255,255,.1)!important;background:#ffffff03;border-radius:8px;display:flex;align-items:center;justify-content:center}.chart-chord.append-card:hover{border-color:#667eea4d!important;background:#667eea0a}.append-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ffffff59;transition:color .2s ease;text-align:center}.chart-chord.append-card:hover .append-inner{color:#4facfe}.chart-chord.append-card.b-section-card:hover{border-color:#667eea99!important;background:#667eea14}.chart-chord.append-card.b-section-card:hover .append-inner{color:#a3b8ff}.append-inner .plus{font-size:1.8rem;font-weight:300;margin-bottom:.2rem;line-height:1}.append-inner .label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.append-card-stacked-container{flex:1;display:flex;flex-direction:column;gap:.35rem;min-width:0;align-self:stretch}.append-card-stacked-container .chart-chord.append-card{flex:1;padding:.2rem;margin:0}.append-card-stacked-container .append-inner .plus{font-size:1.1rem;margin-bottom:0;line-height:1.1}.append-card-stacked-container .append-inner .label{font-size:.62rem;letter-spacing:.02em;line-height:1.2}@media(max-width:768px){.chord-name-main,.chord-root{font-size:1.25rem}.chart-measure .chart-chord:not(:only-child) .chord-name-main,.chart-measure .chart-chord:not(:only-child) .chord-root{font-size:.9rem}.chart-insertion-trigger{width:10px}.empty-builder{padding:.25rem .5rem!important}.chart-builder-empty-placeholder{margin-bottom:1.25rem}.empty-title{font-size:1.15rem}.empty-description{font-size:.85rem;padding:0 .5rem}.empty-grid .chart-system{display:flex;flex-wrap:wrap;gap:.75rem}.empty-grid .chart-system>.empty-builder-measure{flex:1 1 calc(50% - .375rem);height:105px;border:2px dashed rgba(255,255,255,.12)!important;border-radius:12px;padding:.5rem;box-shadow:inset 0 2px 6px #0003}.empty-builder-measure .measure-number{top:8px;left:8px;font-size:.7rem}.add-chord-btn{padding:.45rem .85rem;font-size:.8rem;gap:5px;border-radius:18px}.add-chord-btn .plus{font-size:.95rem}.chord-chart-container{max-height:calc(100vh - 120px);overflow-y:auto;padding-bottom:80px}.chart-chord.edit-mode .chord-delete-btn,.chart-chord.edit-mode .chord-edit-icon-btn{opacity:1;transform:scale(1)}}.chart-modal-backdrop{position:fixed;inset:0;background:#0a0a0fb3;backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .25s cubic-bezier(.16,1,.3,1)}.chart-modal-content{background:#14141ed9;border:1px solid rgba(255,255,255,.08);border-radius:16px;width:90%;max-width:460px;padding:1.5rem;box-shadow:0 20px 40px #00000080,0 0 0 1px #ffffff0d,inset 0 1px #ffffff1a;transform:scale(.95) translateY(10px);animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1) forwards;color:#fff;display:flex;flex-direction:column;gap:1.25rem}@keyframes modalSlideUp{to{transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.06);padding-bottom:.75rem}.modal-title{margin:0;font-size:1.15rem;font-weight:800;letter-spacing:-.01em;color:#fff}.modal-close-x{background:transparent;border:none;color:#fff6;font-size:1.5rem;cursor:pointer;line-height:1;padding:0;transition:color .2s ease}.modal-close-x:hover{color:#f87171}.modal-form,.modal-body{display:flex;flex-direction:column;gap:1.25rem}.modal-field{display:flex;flex-direction:column;gap:.5rem}.modal-field-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80}.modal-input-wrapper{position:relative;width:100%}.modal-chord-input{width:100%;background:#0006;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;font-size:1.25rem;font-weight:700;padding:.75rem 1rem;outline:none;box-shadow:inset 0 2px 4px #0003;transition:all .2s cubic-bezier(.4,0,.2,1);box-sizing:border-box}.modal-chord-input:focus{border-color:#4facfe;box-shadow:inset 0 2px 4px #0003,0 0 12px #4facfe40;background:#0000008c}.chart-modal-content .chord-typeahead{position:absolute;top:100%;left:0;right:0;z-index:1100;margin-top:4px;background:#0f0f19f2!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:8px;box-shadow:0 10px 25px #00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-duration-selector{display:flex;gap:.5rem;width:100%}.duration-pill{flex:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff9;font-size:.9rem;font-weight:700;padding:.6rem 0;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:center}.duration-pill:hover{background:#ffffff14;color:#fff;border-color:#fff3}.duration-pill.active{background:linear-gradient(135deg,#00c6ff,#0072ff);border-color:#00c6ff;color:#fff;box-shadow:0 4px 12px #0072ff59;transform:translateY(-1px)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem;border-top:1px solid rgba(255,255,255,.06);padding-top:1rem}.modal-btn{padding:.65rem 1.25rem;font-size:.85rem;font-weight:700;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none}.modal-cancel-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:#ffffffb3}.modal-cancel-btn:hover{background:#ffffff1a;color:#fff}.modal-save-btn{background:linear-gradient(135deg,#00c6ff,#0072ff);color:#fff;box-shadow:0 4px 12px #0072ff33}.modal-save-btn:hover{filter:brightness(1.1);box-shadow:0 4px 16px #0072ff4d;transform:translateY(-1px)}.modal-save-btn:active{transform:translateY(0)}.chart-toolbar-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;width:100%;margin-bottom:1.25rem;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:.75rem}.voicing-arrow-btn{position:absolute;top:52%;transform:translateY(-50%);background:#14141eb3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.12);color:var(--text-secondary, #9ca3af);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;font-weight:700;line-height:1;z-index:25;opacity:.7;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.voicing-arrow-btn.prev{left:0;transform:translate(-50%,-50%);padding-bottom:2px;padding-right:2px}.voicing-arrow-btn.next{right:0;transform:translate(50%,-50%);padding-bottom:2px;padding-left:2px}.chart-chord:hover .voicing-arrow-btn{opacity:.8}.voicing-arrow-btn:hover{opacity:1!important;background:#667eeae6;color:#fff;border-color:#667eeab3;box-shadow:0 0 10px #667eea80}.voicing-arrow-btn.prev:hover{transform:translate(-50%,-50%) scale(1.15)}.voicing-arrow-btn.next:hover{transform:translate(50%,-50%) scale(1.15)}.voicing-arrow-btn.prev:active{transform:translate(-50%,-50%) scale(.92)}.voicing-arrow-btn.next:active{transform:translate(50%,-50%) scale(.92)}.melody-staff-container{width:100%;margin-top:.15rem;background:#0f172a4d;border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:.2rem 0;box-sizing:border-box;position:relative;-webkit-user-select:none;user-select:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.melody-staff-container:hover{background:#0f172a73;border-color:#ffffff14}.treble-staff-svg{display:block;width:100%;overflow:visible}.staff-line{stroke:#ffffff40;stroke-width:1.5;shape-rendering:crispEdges}.ledger-line{stroke:#fff6;stroke-width:1.5;shape-rendering:crispEdges}.beat-line{stroke:#ffffff0f;stroke-width:1;stroke-dasharray:2 2;shape-rendering:crispEdges}.measure-bar{stroke:#ffffff4d;stroke-width:2.5;shape-rendering:crispEdges}.clef-text{font-family:Apple Symbols,Noto Music,Bravura,sans-serif;-webkit-user-select:none;user-select:none;pointer-events:none}.note-group{cursor:pointer}.note-head{fill:#fff;stroke:#0f172a;stroke-width:1;transition:fill .2s,filter .2s,stroke-width .2s}.note-group:hover .note-head{fill:#38bdf8;filter:drop-shadow(0 0 4px rgba(56,189,248,.6))}.note-group.selected .note-head{fill:#38bdf8;stroke:#fff;stroke-width:1.5;filter:drop-shadow(0 0 6px rgba(56,189,248,.8))}.note-stem{stroke:#fff;stroke-width:1.5;shape-rendering:geometricPrecision;transition:stroke .2s}.note-group:hover .note-stem,.note-group.selected .note-stem{stroke:#38bdf8}.note-accidental{font-family:Apple Symbols,Noto Music,Bravura,sans-serif;font-weight:700;-webkit-user-select:none;user-select:none;pointer-events:none;transition:fill .2s}.note-group:hover .note-accidental,.note-group.selected .note-accidental{fill:#38bdf8}.beat-highlight{fill:#38bdf814;transition:fill .15s ease}.beat-highlight.flash{fill:#38bdf859;transition:none}.ghost-note-head{fill:#38bdf866;stroke:#fff3;stroke-width:1;pointer-events:none}.ghost-note-stem{stroke:#ffffff4d;stroke-width:1.5;pointer-events:none}.ghost-note-accidental{fill:#38bdf880;font-family:Apple Symbols,Noto Music,Bravura,sans-serif;pointer-events:none}@media(max-width:768px){.melody-staff-container{display:none!important}}.solo-view-container{width:100%;overflow-x:auto;padding:0;position:relative;background:transparent;border:none;margin-top:0}@keyframes shimmer-pulse{0%{filter:brightness(1) saturate(1)}50%{filter:brightness(1.25) saturate(1.2)}to{filter:brightness(1) saturate(1)}}.guitar-shimmer{animation:shimmer-pulse .4s infinite ease-in-out}@keyframes hazard-crawl{0%{background-position:0 0}to{background-position:30px 30px}}.piano-key.detected.white.shimmer-chord-active,.piano-key.detected.black.shimmer-chord-active{animation:shimmer-pulse .4s infinite ease-in-out;box-shadow:inset 0 0 20px #f59e0bcc,inset 0 0 40px #f59e0b66!important;z-index:20!important}.piano-key.detected.white.shimmer-scale-active,.piano-key.detected.black.shimmer-scale-active{box-shadow:inset 0 0 20px #ef4444cc,inset 0 0 40px #ef444466!important;z-index:20!important}.piano-key.detected.white.shimmer-avoid-active,.piano-key.detected.black.shimmer-avoid-active{background:repeating-linear-gradient(45deg,#000,#000 15px,#eab308 15px 17px)!important;background-size:30px 30px;animation:hazard-crawl .4s infinite linear;border:2px solid #000000!important;box-shadow:inset 0 0 20px #000000e6,inset 0 0 40px #0009!important;z-index:25!important;color:#fff!important}.detected-note-marker.shimmer-chord-active circle{fill:#f59e0b!important;filter:brightness(1.2) drop-shadow(0 0 12px rgba(245,158,11,.9))}.detected-note-marker.shimmer-scale-active circle{fill:#ef4444!important}.detected-note-marker.shimmer-avoid-active circle{fill:#000!important;stroke:#eab308!important;stroke-width:2px!important;filter:brightness(1.2) drop-shadow(0 0 15px rgba(0,0,0,1))}.solo-view-header{display:flex;flex-direction:column;align-items:center;gap:1.15rem;padding:0 0 .5rem}.solo-view-close-absolute-btn{position:absolute;top:.75rem;right:.75rem;background:#ffffff1a;border:none;border-radius:50%;width:28px;height:28px;color:var(--text-secondary, #9ca3af);font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.solo-view-close-absolute-btn:hover{background:#ef444433;color:#ef4444}.solo-view-close-absolute-btn:active{transform:scale(.95)}.solo-view-title-nav-row{display:flex;align-items:center;justify-content:center;width:100%}.solo-view-playback-row{display:flex;align-items:center;justify-content:center;gap:.5rem;width:fit-content;margin:.5rem auto;background:#ffffff0a;padding:.35rem .75rem;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.solo-view-volume-group{display:flex;align-items:center;gap:.2rem}.solo-view-volume-group .volume-icon{opacity:.6;display:flex;align-items:center}.mic-volume-slider{width:50px;margin:0}.chart-zoom-slider{-webkit-appearance:none;appearance:none;background:transparent;outline:none;margin:0}.chart-zoom-slider::-webkit-slider-runnable-track{height:2px;background:#ffffff2e;border-radius:2px}.chart-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:8px;height:8px;border-radius:50%;background:#ffffff73;margin-top:-3px;transition:background .15s ease,transform .15s ease}.chart-zoom-slider::-webkit-slider-thumb:hover{background:#ffffffbf;transform:scale(1.3)}.chart-zoom-slider::-moz-range-track{height:2px;background:#ffffff2e;border-radius:2px}.chart-zoom-slider::-moz-range-thumb{width:8px;height:8px;border-radius:50%;border:none;background:#ffffff73}.rhythm-group{display:flex;align-items:center;gap:.35rem;border:1px solid rgba(255,255,255,.25);border-radius:9999px;padding:.2rem .5rem;background:#ffffff0d;transition:all .2s ease;cursor:pointer}.rhythm-group:hover{border-color:#ffffff73;background:#ffffff1a}.rhythm-group .rhythm-icon{opacity:.65;display:flex;align-items:center;color:var(--text-primary)}.solo-view-rhythm-select{background:transparent;border:none;color:var(--text-primary);font-size:.72rem;font-weight:600;cursor:pointer;outline:none;padding:0 .85rem 0 .2rem;max-width:140px;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right center;background-size:10px}.toolbar-divider{width:1px;height:24px;background:#ffffff1a;margin:0 .25rem}.toolbar-group{display:flex;align-items:center;gap:.5rem;background:#ffffff0a;padding:.35rem .6rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.playback-group{background:transparent;border:none;padding:0}.settings-header-row{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;width:100%}.solo-view-options-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem 1.25rem;margin:.5rem auto 0;padding:1rem 1.25rem;background:#0f172a99;border:1px solid rgba(102,126,234,.25);border-radius:16px;width:fit-content;max-width:98%;box-shadow:inset 0 1px 1px #ffffff0d,0 10px 25px -5px #0006,0 8px 10px -6px #0006;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeInDown .2s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-collapse-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary, #9ca3af);border-radius:20px;padding:.4rem 1.2rem;font-size:.75rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;font-family:Inter,sans-serif;align-self:center;margin-bottom:.25rem}.settings-collapse-btn:hover{background:#ffffff1a;color:var(--text-primary)}.settings-chevron{font-size:.55rem;transition:transform .3s;display:inline-block}.option-group{display:flex;flex-direction:column;align-items:center;gap:.35rem}.option-group-label{font-size:.6rem;font-weight:700;color:var(--text-muted, #94a3b8);letter-spacing:.1em;text-transform:uppercase;opacity:.9}.option-group-content{display:flex;align-items:center;gap:.35rem;background:#1e293b66;padding:.2rem .4rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);min-height:32px}.settings-toggle-btn{background:#ffffff08;border:1px solid rgba(255,255,255,.06);color:#fff6;padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;display:flex;align-items:center;gap:.35rem}.settings-toggle-btn:hover{background:#ffffff14;border-color:#ffffff26;color:#ffffffe6;transform:translateY(-1px)}.settings-toggle-btn:active{transform:translateY(0) scale(.96)}.settings-toggle-btn.active{background:#667eea1f;border-color:#667eea4d;color:#60a5fa;font-weight:600}.settings-toggle-btn.active .dot{background:currentColor;box-shadow:0 0 8px currentColor}.settings-toggle-btn .dot{width:6px;height:6px;border-radius:50%;background:#fff3;flex-shrink:0}.solo-view-options-grid .string-btn{width:22px;height:22px;font-size:.65rem}.solo-view-options-grid .inversion-btn{min-width:24px;height:24px;font-size:.65rem;padding:0 4px}.fret-limit-input{background:#667eea14!important;border:1px solid rgba(102,126,234,.2)!important;border-radius:6px!important;color:#fff!important;text-align:center;font-family:inherit;font-weight:600;transition:all .2s ease}.fret-limit-input:hover{background:#667eea26!important;border-color:#667eea66!important}.fret-limit-input:focus{outline:none;background:#667eea33!important;border-color:#60a5fa!important;box-shadow:0 0 0 2px #60a5fa33}.solo-view-chord-name{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.solo-view-chord-column{display:flex;flex-direction:column;align-items:center;gap:1.15rem}.solo-view-voicing-nav{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary, #9ca3af);font-family:Inter,sans-serif;font-size:.85rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;opacity:.75}.voicing-nav-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary, #9ca3af);width:28px;height:28px;border-radius:50%;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center;padding:0}.voicing-nav-btn:hover{background:#667eea26;border-color:#667eea66;color:#4facfe;transform:scale(1.1);box-shadow:0 0 12px #667eea4d}.voicing-nav-btn.prev:hover svg{transform:translate(-2px) scale(1.1)}.voicing-nav-btn.next:hover svg{transform:translate(2px) scale(1.1)}.voicing-nav-btn:active{transform:scale(.9);background:#667eea40}.voicing-nav-label{transition:all .2s ease;display:inline-block;color:var(--text-primary);text-shadow:0 0 8px rgba(79,172,254,.4)}.voicing-nav-label.pop{animation:label-pop .3s ease-out}@keyframes label-pop{0%{transform:scale(1)}50%{transform:scale(1.05);color:#4facfe}to{transform:scale(1)}}.how-to-solo-container{width:100%;display:flex;flex-direction:column;align-items:center;padding:0 1rem;font-family:Inter,sans-serif}.how-to-solo-toggle{background:#667eea1a;border:1px solid rgba(102,126,234,.3);color:#4facfe;border-radius:20px;padding:.35rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.how-to-solo-toggle:hover{background:#667eea33}.how-to-solo-chevron{font-size:.6rem;margin-left:8px;transition:transform .3s;display:inline-block}.how-to-solo-content{margin-top:.75rem;font-size:.85rem;color:var(--text-secondary, #9ca3af);text-align:center;max-width:500px;line-height:1.4;background:#0003;padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.mode-selector-dropdown{background:#0000004d;border:1px solid rgba(102,126,234,.4);border-radius:4px;color:#667eea;font-size:.75rem;padding:2px 4px;cursor:pointer;outline:none;font-weight:700;transition:all .2s;font-family:Inter,sans-serif}.mode-info-btn{background:transparent;border:none;color:var(--text-muted, #6b7280);border-radius:50%;width:16px;height:16px;font-size:.75rem;display:inline-flex;align-items:center;justify-content:center;cursor:help;margin-left:4px;transition:color .2s;padding:0}.mode-info-btn:hover{color:#4facfe}.mode-selector-dropdown:hover{border-color:#667eea;background:#0006}.mode-selector-dropdown option{background:#1a202c;color:#fff}.solo-view-chord-duration{background:#667eea33;color:#4facfe;padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:700}.solo-view-nav-btn{background:transparent;border:none;color:var(--text-secondary, #9ca3af);border-radius:4px;padding:.3rem .6rem;cursor:pointer;font-size:.85rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.solo-view-nav-btn:hover:not(:disabled){background:#ffffff0d;color:var(--text-primary)}.solo-view-nav-btn:disabled{opacity:.5;cursor:not-allowed}.solo-view-chart-wrapper{padding:0 .5rem}.solo-view-svg-container{width:100%;display:flex;justify-content:center;padding:0 1rem;gap:2rem}.solo-view-svg-container.multi-view.horizontal{flex-direction:column;align-items:center}.solo-view-svg-container.multi-view.vertical{flex-direction:row;align-items:flex-start;flex-wrap:wrap}.view-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem}.view-label{font-size:.9rem;font-weight:600;color:#4facfe;background:transparent;padding:0;border-radius:0;border:none}.solo-view-play-btn{background:linear-gradient(135deg,#764ba2,#6366f1);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:28px;height:28px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:inset 0 2px 3px #ffffff4d,0 3px 6px #0006,0 0 10px #6366f14d;flex-shrink:0}.solo-view-play-btn:hover{filter:brightness(1.1);box-shadow:inset 0 2px 3px #fff6,0 4px 8px #00000080,0 0 15px #6366f180}.solo-view-play-btn:active{transform:scale(.96) translateY(1px);box-shadow:inset 0 1px 2px #00000080,0 1px 2px #0000004d}.solo-view-playback-row .draggable-tempo-container{background:transparent;padding:0;margin:0;border:none}.solo-view-playback-row .tempo-value-display{min-width:48px}.solo-view-playback-row .tempo-arrow-btn{height:10px}.solo-view-playback-row .tempo-arrow-btn svg{width:10px;height:10px}.solo-view-playback-row .tempo-number{font-size:.8rem}.solo-view-playback-row .tempo-unit{font-size:.55rem}.solo-view-mode-btn,.solo-view-rotate-btn{background:transparent;border:none;border-radius:4px;padding:.35rem .6rem;color:var(--text-secondary, #9ca3af);font-size:.8rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;height:30px}.solo-view-mode-btn.active{color:#667eea}.solo-view-mode-btn:hover,.solo-view-rotate-btn:hover{background:#ffffff0d;color:var(--text-primary)}.solo-view-mode-btn:active,.solo-view-rotate-btn:active{transform:scale(.95)}.solo-view-tempo{display:flex;align-items:center;margin-left:0}.solo-view-mode-btn.inactive{opacity:.5;background:transparent;border:1px dashed rgba(255,255,255,.2);filter:grayscale(100%);box-shadow:none}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.voicing-tone{background-color:#ef4444;border:2px solid white}.legend-dot.chord-tone{background-color:#ef444499;border:1.5px solid rgba(239,68,68,.8)}.legend-dot.scale-tone{background-color:#ef444499;border:1px solid rgba(239,68,68,.6)}.legend-dot.avoid-tone{width:10px;height:10px;background:repeating-linear-gradient(45deg,#ef444499,#ef444499 2px,#000000b3 2px 4px);border:1.5px solid rgba(239,68,68,.8)}.solo-view-mode-btn.mic-btn.active{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b4d}.solo-view-metronome-btn{background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:50%;width:22px;height:22px;color:var(--text-secondary, #9ca3af);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-left:0}.solo-view-metronome-btn:hover{background:#ffffff0d;color:var(--text-primary);border-color:#fff3}.solo-view-metronome-btn.active{color:#4facfe;background:#4facfe1a;border-color:#4facfe66;box-shadow:0 0 10px #4facfe33}.solo-view-metronome-btn:active{transform:scale(.95)}.neck-background{fill:#0000004d}.fret-line{stroke:#667eea66}.fret-beat-flash{animation:fret-beat .3s ease-in-out}@keyframes fret-beat{0%{stroke:#667eea66}30%{stroke:#788cf58c}to{stroke:#667eea66}}@keyframes beat-aura{0%{filter:drop-shadow(0 0 15px rgba(102,126,234,1))}to{filter:drop-shadow(0 0 0px rgba(102,126,234,0))}}.solo-view-chord-name.beat-flash{animation:beat-aura .2s ease-out}.full-neck-svg{max-width:100%;height:auto;filter:drop-shadow(0 4px 6px rgba(0,0,0,.3))}.mic-volume-container{display:flex;align-items:center;gap:.5rem;padding-left:.5rem;border-left:1px solid rgba(255,255,255,.1);animation:slide-in-left .3s ease-out}@keyframes slide-in-left{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.mic-volume-icon{font-size:.9rem;display:flex;align-items:center;justify-content:center;min-width:20px}.mic-volume-value{font-size:.65rem;font-weight:700;color:var(--text-muted, #9ca3af);min-width:32px}.mic-volume-slider{-webkit-appearance:none;appearance:none;width:50px;height:3px;background:#ffffff1a;border-radius:1.5px;outline:none;cursor:pointer;transition:all .2s}.mic-volume-slider:hover{background:#fff3;width:65px}.mic-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:10px;height:10px;background:#f59e0b;border-radius:50%;cursor:pointer;box-shadow:0 0 5px #f59e0b80;transition:all .2s}.mic-volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px #f59e0bcc}.mic-volume-slider::-moz-range-thumb{width:10px;height:10px;background:#f59e0b;border:none;border-radius:50%;cursor:pointer;box-shadow:0 0 5px #f59e0b80;transition:all .2s}.mic-volume-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 8px #f59e0bcc}.load-progression-container{display:flex;flex-direction:column;gap:.5rem;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:.75rem 1rem;box-shadow:inset 0 1px #ffffff0d}.load-progression-header{display:flex;align-items:center;width:100%;cursor:pointer;-webkit-user-select:none;user-select:none}.load-progression-header-left{display:flex;align-items:center;gap:.4rem}.load-progression-header:hover .load-progression-title{color:#fff9}.load-progression-header:hover .collapse-chevron{color:#ffffffb3}.load-progression-title{font-size:.7rem;font-weight:800;color:#fff6;text-transform:uppercase;letter-spacing:.08em;margin-bottom:0;transition:color .2s ease}.load-progression-toggle-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.collapse-chevron{color:#ffffff59;transition:transform .25s cubic-bezier(.4,0,.2,1),color .2s ease}.collapse-chevron.collapsed{transform:rotate(-90deg)}.load-progression-container.collapsed{padding-bottom:.75rem}.load-progression-buttons{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.toolbar-right-group{display:flex;align-items:center;gap:1rem}.load-progression-buttons .toolbar-btn,.load-progression-buttons .sleek-upload-container.mini{height:36px!important;min-height:36px!important;box-sizing:border-box!important;padding:0 1rem!important;background:#ffffff0d!important;border:1px solid rgba(255,255,255,.08)!important;border-radius:8px!important;color:var(--text-secondary, #9ca3af)!important;font-size:.78rem!important;font-weight:600!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:.5rem!important;cursor:pointer!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important;box-shadow:0 2px 4px #0000001a!important;text-decoration:none!important;-webkit-user-select:none!important;user-select:none!important}.load-progression-buttons .toolbar-btn:hover,.load-progression-buttons .sleek-upload-container.mini:hover{background:#ffffff17!important;border-color:#ffffff2e!important;color:var(--text-primary, #ffffff)!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px #00000026!important}.load-progression-buttons .toolbar-btn:active,.load-progression-buttons .sleek-upload-container.mini:active{transform:translateY(0)!important}.load-progression-buttons .toolbar-btn.active{background:#667eea2e!important;border-color:#667eea73!important;color:#818cf8!important;box-shadow:0 0 12px #667eea40!important}.load-progression-buttons .toolbar-btn.preset-active:not(.active){border-color:#10b98166!important;background:#10b98114!important;color:#34d399!important}.load-progression-buttons .sleek-upload-container.mini .upload-placeholder{gap:.5rem!important;display:flex!important;align-items:center!important;width:auto!important;height:auto!important}.load-progression-buttons .sleek-upload-container.mini .upload-icon-wrapper{width:auto!important;height:auto!important;background:transparent!important;padding:0!important;border-radius:0!important;color:currentColor!important;display:flex!important;align-items:center!important;justify-content:center!important}.load-progression-buttons .sleek-upload-container.mini .upload-icon-svg{width:14px!important;height:14px!important;stroke-width:2.5px!important}.load-progression-buttons .sleek-upload-container.mini .upload-text-content{display:flex!important;align-items:center!important}.load-progression-buttons .sleek-upload-container.mini .main-text{font-size:.78rem!important;font-weight:600!important;color:currentColor!important}.load-progression-buttons .btn-icon-svg{flex-shrink:0;color:currentColor}.syntax-examples{display:flex;flex-direction:column;gap:.5rem;max-width:480px;width:100%;margin:0 auto 1.5rem;box-sizing:border-box;background:#0d0d1773;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.06);max-height:45vh;overflow-y:auto;box-shadow:inset 0 1px #ffffff0d,0 8px 32px #0000004d}.category-section{background:transparent;border:none;border-radius:0;padding:0;margin-bottom:0;border-bottom:1px solid rgba(255,255,255,.08)}.category-summary{color:var(--text-secondary, #9ca3af);font-size:.9rem;padding:.6rem .25rem;cursor:pointer;font-weight:700;list-style-position:inside;outline:none;transition:color .2s ease;text-align:center}.category-summary:hover{color:var(--text-primary, #ffffff)}.examples-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:0 1.25rem;padding:.35rem .25rem .25rem}.example-item{cursor:pointer;padding:.4rem .25rem;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.08);transition:all .2s cubic-bezier(.4,0,.2,1)}.example-item:hover{background:#ffffff08;border-bottom-color:#ffffff26}.example-item.selected{background:#10b98114;border-bottom:1px solid #10b981}.example-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.example-label{font-size:.75rem;font-weight:700;color:var(--text-secondary, #9ca3af);text-transform:uppercase;letter-spacing:.02em}.example-value{font-size:.8rem;color:var(--text-primary, #ffffff);font-family:JetBrains Mono,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loaded-checkmark{font-size:.75rem;color:#10b981;font-weight:700}.add-icon{font-size:.9rem;color:#667eea}.btn-icon{font-size:.9rem}.full-instrument-settings-toolbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:flex-end;width:100%;padding:0 .5rem;margin-bottom:.25rem}.settings-left-column{display:flex;align-items:center;gap:.5rem;justify-content:flex-start}.settings-middle-column{display:flex;flex-direction:column;align-items:center;gap:.5rem}.views-toggle-container{padding:0 1rem;margin-bottom:.5rem;display:flex;justify-content:center;align-items:center;width:100%}.views-toggle-group{display:flex;background:#0000004d;border-radius:8px;padding:4px;border:1px solid rgba(255,255,255,.1)}.view-toggle-btn{border:none;border-radius:6px;padding:.4rem 1rem;font-size:.8rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.view-toggle-btn:disabled{cursor:not-allowed}@media(max-width:768px){.solo-view-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem .5rem;padding:.75rem .5rem;width:100%;max-width:100%;box-sizing:border-box;border-radius:12px}.solo-view-options-grid .option-group{width:100%;align-items:center}.solo-view-options-grid .option-group-content{width:100%;justify-content:center;flex-wrap:wrap}.solo-view-options-grid .option-group:last-child{grid-column:span 2}.solo-view-playback-row{flex-wrap:wrap;justify-content:center;gap:.5rem .75rem;padding:.4rem .6rem;width:95%;max-width:360px;margin:.5rem auto}.load-progression-buttons{display:flex!important;flex-wrap:wrap!important;width:100%!important;gap:.5rem!important}.load-progression-buttons .chord-settings-btn{display:none!important}.load-progression-buttons>button:not(.chord-settings-btn),.load-progression-buttons>.image-upload-section{flex:1 1 110px!important;min-width:0!important;box-sizing:border-box!important}.load-progression-buttons .image-upload-section{display:flex!important}.load-progression-buttons .image-upload-section .sleek-upload-container.mini{flex:1!important;width:100%!important;box-sizing:border-box!important}.load-progression-buttons .toolbar-btn,.load-progression-buttons .sleek-upload-container.mini{padding:0 .75rem!important;font-size:.76rem!important;white-space:normal!important;text-align:center;height:auto!important;min-height:36px!important}.full-instrument-settings-toolbar{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;padding:0 .5rem}.settings-left-column{justify-content:center;flex-wrap:wrap;gap:.5rem;width:100%;order:2}.settings-middle-column{width:100%;order:1;gap:.35rem}.settings-right-column{display:none}.views-toggle-container{padding:0 .5rem}.views-toggle-group{width:100%;justify-content:space-between}.view-toggle-btn{padding:.4rem .5rem!important;font-size:.75rem!important;flex:1;text-align:center}.solo-view-voicing-nav{flex-wrap:wrap;justify-content:center;gap:.5rem;width:100%;max-width:100%;padding:0 .5rem}.solo-view-chart-wrapper{padding:0!important}}.playback-toolbar-container{position:fixed;bottom:5.5rem;left:50%;transform:translate(-50%);z-index:5000;pointer-events:none;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%);opacity:1}}.playback-toolbar{pointer-events:auto;display:flex;align-items:center;background:#1f2937d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:9999px;padding:.25rem .5rem;box-shadow:0 10px 25px -5px #0006,0 8px 10px -6px #0006,inset 0 1px #ffffff1a;gap:.2rem}.toolbar-btn{background:transparent;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:50%;transition:all .2s;outline:none}.toolbar-btn:hover{background:#ffffff1a}.toolbar-btn:active{transform:scale(.95)}.toolbar-btn{flex-shrink:0}.play-pause-btn{width:36px;height:36px;background:transparent;border:none;box-shadow:none}.play-pause-btn:hover{background:#ffffff26}.play-pause-btn:active{transform:scale(.96)}.close-btn{opacity:.6;transition:all .2s}.close-btn:hover{opacity:1;color:#ef4444;background:#ef44441a}.metronome-btn.active{color:#4facfe}.toolbar-divider{width:1px;height:14px;background:#fff3;margin:0 .05rem}.expand-btn{border-radius:9999px;padding:.35rem .75rem;gap:.3rem;font-size:.75rem;font-weight:600}.expand-text{display:inline-block}.playback-toolbar .draggable-tempo-container{background:transparent;padding:0;margin:0;border:none}.playback-toolbar .tempo-value-display{min-width:48px}.playback-toolbar .tempo-arrow-btn{height:10px}.playback-toolbar .tempo-arrow-btn svg{width:10px;height:10px}.playback-toolbar .tempo-number{font-size:.8rem}.playback-toolbar .tempo-unit{font-size:.55rem}.toolbar-volume{display:flex;align-items:center;gap:.2rem;padding:0 .15rem}.volume-icon{color:var(--text-secondary, #9ca3af);display:flex;align-items:center}.toolbar-volume-slider{-webkit-appearance:none;width:50px;height:3px;background:#ffffff26;border-radius:1.5px;outline:none;cursor:pointer;transition:all .2s}.toolbar-volume-slider:hover{background:#ffffff40;width:65px}.toolbar-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000004d}.toolbar-volume-slider::-moz-range-thumb{width:10px;height:10px;background:#fff;border:none;border-radius:50%;cursor:pointer}.toolbar-rhythm{display:flex;align-items:center;gap:.35rem;border:1px solid rgba(255,255,255,.25);border-radius:9999px;padding:.2rem .5rem;background:#ffffff0d;transition:all .2s ease;cursor:pointer}.toolbar-rhythm:hover{border-color:#ffffff73;background:#ffffff1a}.toolbar-rhythm .rhythm-icon{opacity:.65;display:flex;align-items:center;color:#fff}.toolbar-rhythm-select{background:transparent;border:none;color:#fff;font-size:.72rem;font-weight:600;cursor:pointer;outline:none;padding:0 .85rem 0 .2rem;max-width:140px;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right center;background-size:10px}@media(max-width:640px){.playback-toolbar-container{bottom:5.5rem;width:max-content;max-width:95vw}.playback-toolbar{overflow-x:auto;justify-content:flex-start;padding-left:1rem;padding-right:1rem}.playback-toolbar::-webkit-scrollbar{display:none}.playback-toolbar{-ms-overflow-style:none;scrollbar-width:none}.expand-text{display:none}.expand-btn{padding:.5rem}}.global-tooltip{position:fixed;z-index:10000;background:#0f172afa;color:#f1f5f9;padding:6px 12px;border-radius:6px;font-size:11px;font-weight:600;white-space:nowrap;pointer-events:none;box-shadow:0 4px 12px #00000080,0 2px 4px #0000004d;border:1px solid rgba(255,255,255,.12);letter-spacing:.02em;opacity:0;transform:translateY(5px);transition:opacity .15s ease,transform .15s ease;font-family:Inter,sans-serif;top:0;left:0}.global-tooltip.visible{opacity:1;transform:translateY(0)}.global-tooltip-arrow{position:absolute;bottom:-5px;left:50%;transform:translate(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid rgba(15,23,42,.98)}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--secondary-gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--accent-gradient: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--dark-bg: #0f0f23;--card-bg: rgba(255, 255, 255, .05);--card-border: rgba(255, 255, 255, .1);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .5);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .2);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .3);--shadow-glow: 0 0 40px rgba(102, 126, 234, .3);--chord-width: clamp(220px, 30vw, 260px);--ukulele-chord-width: clamp(190px, 25.5vw, 220px);--piano-chord-width: clamp(320px, 35vw, 400px)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--dark-bg);color:var(--text-primary);min-height:100vh;padding:2rem 1rem;background-image:radial-gradient(circle at 20% 30%,rgba(102,126,234,.1) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(245,87,108,.1) 0%,transparent 50%)}.container{max-width:1440px;margin:0 auto}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.input-mode-toggle{display:flex;justify-content:center;gap:0;animation:fadeInUp .4s ease-out}.toggle-btn{padding:.75rem 1.5rem;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.toggle-btn:first-child{border-radius:.75rem 0 0 .75rem;border-right:none}.toggle-btn:last-child{border-radius:0 .75rem .75rem 0}.toggle-btn:hover{background:#ffffff1a;color:var(--text-primary)}.toggle-btn.active{background:var(--primary-gradient);color:#fff;border-color:transparent}.input-toggle-container{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:1.5rem}.workspace-card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--card-border);border-radius:1.5rem;box-shadow:var(--shadow-md);margin-bottom:2rem;overflow:hidden;padding:1.5rem}.results-settings-bar{display:none;justify-content:center;align-items:stretch;flex-wrap:wrap;gap:.75rem;margin:0;padding:.75rem 1rem 1rem;background:transparent;border:none}.results-settings-bar.open{display:flex}.filter-toggle{display:flex;width:auto;justify-content:center;align-items:center;gap:.5rem;margin:.75rem 1rem;padding:.6rem 1.25rem;background:#667eea1f;border:1px solid rgba(102,126,234,.35);border-radius:.6rem;color:#fffc;font-family:inherit;cursor:pointer;font-weight:600;font-size:.85rem;letter-spacing:.02em;transition:all .2s ease;box-shadow:0 1px 4px #00000026}.filter-toggle:hover{background:#667eea38;border-color:#667eea99;color:#fff;box-shadow:0 3px 10px #667eea40}.filter-toggle.active{background:var(--primary-gradient);border-color:transparent;color:#fff;box-shadow:0 3px 12px #667eea66}@media(max-width:768px){.workspace-card{padding:1rem;border-radius:1rem}.results-settings-bar.open{flex-direction:column;align-items:stretch;gap:1rem}.filter-toggle{margin:.5rem 0;padding:.5rem .9rem;font-size:.8rem}.toggle-btn{padding:.5rem .75rem;font-size:.8rem}}.settings-container input{width:50px}.string-selector-container{display:flex;align-items:center;gap:8px}.filter-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.string-toggles{display:flex;gap:4px}.string-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--card-border);background:#ffffff0d;color:var(--text-secondary);font-weight:700;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.string-btn:hover{border-color:#646cff;color:#fff}.string-btn.active{background:#646cff;border-color:#646cff;color:#fff;box-shadow:0 2px 8px #646cff4d}.string-btn.active:hover{box-shadow:0 4px 12px #646cff66}.settings-container{display:flex;align-items:center;gap:.5rem;background:var(--card-bg);padding:.4rem .75rem;border-radius:.5rem;border:1px solid var(--card-border)}input[type=checkbox]{appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1px solid rgba(255,255,255,.3);border-radius:4px;background:#ffffff0d;cursor:pointer;position:relative;transition:all .2s ease}input[type=checkbox]:checked{background:#667eea;border-color:#667eea}input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}input[type=checkbox]:hover{border-color:#ffffff80}.inversion-toggles{display:flex;gap:6px}.inversion-btn{min-width:32px;padding:0 .5rem;height:32px;border-radius:6px;border:1px solid var(--card-border);background:#ffffff0d;color:var(--text-secondary);font-weight:600;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.inversion-btn:hover{border-color:#646cff;color:#fff;background:#646cff1a}.inversion-btn.active{background:#646cff;border-color:#646cff;color:#fff;box-shadow:0 4px 12px #646cff4d}.settings-container label{font-size:.85rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center}.fret-limit-input{width:60px;background:#ffffff1a;border:1px solid var(--card-border);border-radius:.4rem;color:#fff;padding:.3rem .5rem;font-family:inherit;font-size:1rem;font-weight:600;text-align:center;transition:border-color .2s}.fret-limit-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.app-header{text-align:center;margin-bottom:2.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.05)}@media(max-width:768px){.app-header{margin-bottom:1.5rem}}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1000px;margin:0 auto}.mode-nav{display:flex;gap:.5rem;background:#ffffff0d;padding:.3rem;border-radius:.8rem}.nav-btn{padding:.5rem 1.2rem;border:none;background:transparent;color:var(--text-secondary);font-weight:600;cursor:pointer;border-radius:.6rem;transition:all .3s ease}.nav-btn.active{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#1a1a1a;box-shadow:0 2px 10px #0000001a}.voicing-controls{display:flex;justify-content:center;margin-bottom:1.5rem;animation:fadeInUp .5s ease-out}.voicing-btn-group{display:flex;gap:.75rem}.voicing-btn{padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.choose-btn{background:var(--primary-gradient);color:#fff;box-shadow:var(--shadow-md)}.choose-btn:hover{box-shadow:var(--shadow-glow)}.reshuffle-btn{background:var(--secondary-gradient);color:#fff}.reshuffle-btn:hover{filter:brightness(1.1)}.show-all-btn{background:#ffffff1a;color:var(--text-secondary);border:1px solid var(--card-border)}.show-all-btn:hover{background:#ffffff26;color:var(--text-primary)}@media(max-width:768px){body{padding:1rem .5rem}.container{padding:0}.voicing-btn-group{flex-direction:column;width:100%}.voicing-btn{justify-content:center}}.landing-experience{padding:3rem 2rem;background:radial-gradient(circle at top center,rgba(102,126,234,.08) 0%,transparent 70%);border-bottom:1px solid rgba(255,255,255,.05)}.landing-header{text-align:center;margin-bottom:3rem}.landing-title{font-size:2rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.landing-subtitle{color:var(--text-secondary);font-size:1.1rem}.landing-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:1000px;margin:0 auto}.landing-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:1.5rem;padding:2rem;display:flex;flex-direction:column;transition:all .3s ease}.landing-card:hover{background:#ffffff0d;border-color:#667eea4d;box-shadow:0 12px 40px #0000004d}.card-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem}.card-icon{display:flex;align-items:center;justify-content:center;color:#667eea;filter:drop-shadow(0 0 10px rgba(102,126,234,.3))}.card-titles h3{margin:0;font-size:1.25rem;font-weight:700;color:#fff}.card-titles p{margin:0;font-size:.9rem;color:var(--text-muted)}.syntax-examples-container{display:flex;flex-direction:column;gap:.75rem}.category-details{background:#0003;border-radius:.75rem;border:1px solid rgba(255,255,255,.05);overflow:hidden}.category-summary{padding:.75rem 1rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);cursor:pointer;list-style:none;transition:background .2s}.category-summary:hover{background:#ffffff0d}.examples-list{padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.progression-pill{padding:.75rem 1rem;background:#ffffff08;border-radius:.6rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem 1.5rem;cursor:pointer;transition:all .2s;border:1px solid transparent}.progression-pill:hover{background:#667eea1a;border-color:#667eea4d}.pill-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-align:left;flex:1 1 120px}.pill-value{font-size:.85rem;color:#667eea;font-weight:700;text-align:right;flex:2 1 180px}.landing-divider{display:flex;align-items:center;justify-content:center;margin:3rem 0 1rem;position:relative}.landing-divider:before,.landing-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);max-width:200px}.landing-divider span{padding:0 1.5rem;font-size:.8rem;font-weight:800;color:var(--text-muted);letter-spacing:.2em}.manual-entry-section{text-align:center}.manual-entry-section p{font-size:.9rem;color:var(--text-muted);font-style:italic}.compact-search-header{padding:.75rem;background:#ffffff05;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:center}@media(max-width:900px){.landing-grid{grid-template-columns:1fr}.landing-experience{padding:2rem 1rem}.landing-title{font-size:1.5rem}}@keyframes cheatHighlightPulse{0%{box-shadow:0 0 #10b981cc,0 0 10px #10b98166!important;border-color:#10b981!important}70%{box-shadow:0 0 0 12px #10b98100,0 0 20px #10b98100!important;border-color:#10b98199!important}to{box-shadow:0 0 #10b98100,0 0 #10b98100!important;border-color:#10b9814d!important}}.cheat-mode-active #browse-presets-btn,.cheat-mode-active [id=browse-presets-btn],.cheat-mode-active .browse-presets-btn{border:2.5px solid #10b981!important;animation:cheatHighlightPulse 2s infinite ease-in-out!important;position:relative}.cheat-mode-active .image-upload-section.mini{border:2.5px solid #10b981!important;box-shadow:0 0 15px #10b98166!important;position:relative;border-radius:.5rem}
