.top-bar{position:sticky;top:0;left:0;width:100%;z-index:1000;background-color:#fff;padding:.8rem 1.2rem;border-bottom:1px solid rgba(0,0,0,.08);box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 10px #0000000d;height:60px;transition:all .3s ease}.brand-section{display:flex;align-items:center;flex-shrink:0}.brand-button{background:none;border:none;color:#4338ca;font-weight:600;padding:.5rem;cursor:pointer;font-size:1.25rem;font-family:inherit;display:flex;align-items:center;border-radius:8px;transition:all .2s ease}.brand-button:hover{background-color:#4338ca14}.brand-icon{font-size:1.25rem;margin-right:.5rem;color:#4338ca}.brand-name{font-weight:700;letter-spacing:.05em}.center-controls{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:1rem}.piece-selector-button{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background-color:#fff;border:1px solid rgba(0,0,0,.12);border-radius:24px;min-width:200px;max-width:300px;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.piece-selector-button:hover{border-color:#4338ca;box-shadow:0 2px 8px #4338ca26}.piece-selector-button:focus{outline:none;border-color:#4338ca;box-shadow:0 0 0 2px #4338ca40}.button-icon{font-size:1rem;margin-right:.5rem;color:#4338ca}.piece-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:.5rem;flex:1}.dropdown-icon{font-size:.875rem;color:#6b7280;transition:transform .2s ease}.piece-selector-button:hover .dropdown-icon{transform:translateY(2px)}.search-container{position:relative;display:flex;align-items:center;transition:width .3s ease;width:40px;height:40px}.search-container.expanded{width:220px}.search-toggle{display:inline-block;text-align:center;width:40px;height:40px;border-radius:50%;background-color:transparent;border:none;cursor:pointer;color:#6b7280;transition:all .2s ease;position:absolute;right:0;z-index:2;line-height:40px}.search-toggle svg{color:#6b7280;font-size:1rem;vertical-align:middle;position:relative;top:-1px}.search-toggle:hover{background-color:#4338ca14}.search-toggle:hover svg{color:#4338ca}.search-input-wrapper{position:absolute;right:0;display:flex;align-items:center;width:220px;height:40px;background-color:#fff;border-radius:20px;border:1px solid rgba(0,0,0,.12);box-shadow:0 2px 8px #00000014;overflow:hidden;animation:slideIn .2s forwards}@keyframes slideIn{0%{width:40px;opacity:0}to{width:220px;opacity:1}}.search-input-wrapper input{width:100%;height:100%;border:none;outline:none;padding:0 45px 0 15px;font-size:.875rem;color:#1f2937;background-color:transparent}.search-input-wrapper input::placeholder{color:#9ca3af}.user-section{display:flex;align-items:center;margin-left:auto}.user-info-button{display:flex;align-items:center;background-color:#fff;border:1px solid rgba(0,0,0,.12);border-radius:24px;padding:.6rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.user-info-button:hover{border-color:#4338ca;box-shadow:0 2px 8px #4338ca26}.user-info-button:focus{outline:none;border-color:#4338ca;box-shadow:0 0 0 2px #4338ca40}.user-icon{margin-right:.5rem;color:#4338ca;font-size:1.125rem}.user-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}@media (max-width: 768px){.center-controls{position:relative;left:0;transform:none;margin-left:1rem}.piece-selector-button{min-width:150px}.user-name{display:none}.user-info-button{padding:.6rem}.user-icon{margin-right:0}}@media (max-width: 480px){.top-bar{padding:.8rem}.brand-name{display:none}.brand-icon{margin-right:0}.piece-selector-button{min-width:120px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background-color:#fff;border-radius:8px;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;position:relative;padding:20px;box-shadow:0 4px 8px #0003;margin:auto}.close-button{position:absolute;top:10px;right:15px;font-size:24px;border:none;background:transparent;cursor:pointer;color:#333;z-index:1}.modal-body{padding-top:10px;overflow-y:auto}.modal-body h1{font-size:24px;margin-bottom:16px;color:#333}.modal-body h2{font-size:18px;margin-top:20px;margin-bottom:10px;color:#444}.modal-body p{line-height:1.5;margin-bottom:16px;color:#555}.modal-body ul{padding-left:20px;margin-bottom:16px}.modal-body li{margin-bottom:8px;line-height:1.4;color:#555}@media (max-height: 600px){.modal-content{max-height:85vh;padding:15px}.modal-body h1{font-size:20px;margin-bottom:12px}.modal-body h2{font-size:16px;margin-top:15px;margin-bottom:8px}}@media (max-width: 480px){.modal-content{width:95%;padding:15px 12px}.modal-body{padding-top:5px}.modal-body ul{padding-left:15px}.modal-body li{margin-bottom:6px}.close-button{top:5px;right:10px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.piece-selection-modal{background-color:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:1.5rem;font-weight:500;color:#333}.close-button{background:none;border:none;color:#666;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:5px;border-radius:50%;transition:background-color .2s}.close-button:hover{background-color:#f0f0f0;color:#333}.search-bar{padding:12px 20px;position:relative;border-bottom:1px solid #eee;display:flex;align-items:center}.search-icon{color:#666;margin-right:10px}.search-bar input{flex:1;border:none;padding:8px;font-size:1rem;outline:none;background:transparent}.clear-search{background:none;border:none;color:#999;cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;border-radius:50%}.clear-search:hover{background-color:#f0f0f0;color:#666}.pieces-list{overflow-y:auto;padding:10px 0;flex:1}.piece-item{padding:12px 20px;display:flex;align-items:center;cursor:pointer;transition:background-color .15s;border-left:3px solid transparent}.piece-item:hover{background-color:#f8f8f8}.piece-item.selected{background-color:#f0f7ff;border-left-color:#3498db}.piece-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:#e9eef5;border-radius:8px;margin-right:15px;color:#3498db;flex-shrink:0}.piece-details{flex:1;min-width:0}.piece-title{font-weight:500;font-size:1rem;margin-bottom:5px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.piece-metadata{display:flex;flex-wrap:wrap;gap:10px;font-size:.85rem;color:#777}.piece-composer,.piece-key,.piece-year{display:inline-flex;align-items:center}.piece-composer:after,.piece-key:after{content:"•";margin-left:10px;opacity:.5}.no-results{padding:30px;text-align:center;color:#777;font-style:italic}@media (max-width: 576px){.piece-selection-modal{width:95%;max-height:90vh}.piece-metadata{flex-direction:column;gap:2px}.piece-composer:after,.piece-key:after{content:"";margin-left:0}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.user-info-modal{width:400px;max-width:90vw;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;display:flex;flex-direction:column;overflow:hidden;max-height:80vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #dee2e6}.modal-header h2{margin:0;font-size:1.25rem;color:#343a40}.close-button{background:none;border:none;font-size:1rem;color:#6c757d;cursor:pointer;padding:5px;border-radius:4px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#343a40;background-color:#f8f9fa}.user-details{padding:20px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.user-detail-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid #f0f0f0}.detail-label{font-weight:500;color:#6c757d}.detail-value{color:#212529}.balance{margin-top:10px;padding:15px 10px;background-color:#f8f9fa;border-radius:6px;border:none}.balance .detail-value{font-weight:700;color:#28a745}.modal-footer{padding:16px 20px;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end}.logout-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.logout-button:hover{background-color:#c82333}.sheet-music-container{margin-top:20px;padding:10px;background-color:#fff;position:relative}.osmd-render-area{width:100%;min-height:200px;overflow-x:auto;background-color:#fff}.osmd-render-area svg{display:block;margin:0 auto;max-width:100%;height:auto}.osmd-controls{display:flex;justify-content:center;align-items:center;gap:10px;margin-bottom:15px;padding:5px;background-color:#f0f0f0;border-radius:5px}.osmd-controls button{padding:5px 10px}.osmd-controls span{min-width:50px;text-align:center;font-weight:700;color:#333}.osmd-controls label{margin-left:15px;font-weight:700;color:#333}.osmd-controls input[type=number]{padding:4px 8px;border:1px solid #ccc;border-radius:4px;width:60px;margin-left:5px;text-align:right}.osmd-controls button.clear-highlight{margin-left:5px;padding:5px 8px}.error-message{padding:20px;margin:20px auto;max-width:80%;background-color:#fff8f8;border:1px solid #ffcdd2;border-radius:6px;color:#d32f2f;text-align:center}.error-message p{margin:8px 0}.loading-indicator{padding:20px;margin:20px auto;max-width:80%;text-align:center;color:#666;font-style:italic;background-color:#f9f9f9;border:1px solid #eee;border-radius:6px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.highlight-overlay{position:absolute;background-color:#ffd70033;border:1px solid rgba(255,215,0,.5);z-index:0;pointer-events:none;transition:all .1s ease-out}.no-sheet-message{padding:20px;margin:20px auto;max-width:80%;text-align:center;color:#666;font-style:italic}.bottom-bar{position:fixed;bottom:0;left:0;width:100%;background-color:#fff;border-top:1px solid rgba(0,0,0,.08);padding:.8rem 1.2rem;display:flex;justify-content:center;align-items:center;z-index:990;box-sizing:border-box;-webkit-user-select:none;user-select:none;box-shadow:0 -2px 10px #0000000d;height:64px;transition:all .3s ease}.bottom-bar-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;position:relative;transition:opacity .3s ease}.bottom-bar-content.is-loading{opacity:.7}.left-section{display:flex;align-items:center;flex-grow:1}.right-section{display:flex;align-items:center;margin-left:auto}.player-controls{display:flex;align-items:center;gap:1rem;flex:1}.bar-input-container{display:flex;align-items:center;background-color:#f5f5f5;border-radius:8px;padding:.3rem .8rem;border:1px solid rgba(0,0,0,.08)}#bar-select-bottom{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;padding:.2rem;width:3rem;color:#333;background:transparent;font-size:.875rem;text-align:center;border:none;outline:none}.bar-input-container label{margin-left:.5rem;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase}.mixer-toggle-button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background-color:#fff;border:1px solid rgba(0,0,0,.12);border-radius:24px;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.mixer-toggle-button:hover:not(:disabled){border-color:#4338ca;box-shadow:0 2px 8px #4338ca26}.mixer-toggle-button:focus{outline:none;border-color:#4338ca;box-shadow:0 0 0 2px #4338ca40}.mixer-toggle-button:disabled{opacity:.5;cursor:not-allowed}.mixer-toggle-button .button-icon{margin-right:.5rem;color:#4338ca}.zoom-controls{display:flex;align-items:center;background-color:#f5f5f5;border-radius:16px;padding:.2rem;box-shadow:0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.1);height:32px}.zoom-button{width:1.6rem;height:1.6rem;display:inline-block;text-align:center;line-height:1.6rem;border:none;background-color:transparent;color:#4338ca;cursor:pointer;border-radius:50%;transition:all .2s ease;margin:0;position:relative}.zoom-button svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px}.zoom-button:hover:not(:disabled){background-color:#4338ca1a;color:#4338ca}.zoom-button:disabled{opacity:.4;cursor:not-allowed}.zoom-percentage{margin:0 .25rem;font-size:.75rem;font-weight:500;min-width:2.5rem;text-align:center;color:#1f2937}.loading-container{display:flex;justify-content:center;align-items:center;width:100%}.loading-message{display:flex;align-items:center;padding:.6rem 1rem;background-color:#f0f7ff;border-radius:8px;border:1px solid rgba(67,56,202,.2);font-size:.875rem;color:#4338ca;box-shadow:0 2px 8px #0000000d}.loading-spinner{width:1rem;height:1rem;border:2px solid rgba(67,56,202,.2);border-top-color:#4338ca;border-radius:50%;margin-right:.8rem;animation:spinner 1s linear infinite}@keyframes spinner{to{transform:rotate(360deg)}}.loading-overlay{position:absolute;right:1rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center}.loading-dot{width:8px;height:8px;background-color:#4338ca;border-radius:50%;animation:pulse 1.2s infinite ease-in-out}@keyframes pulse{0%,to{transform:scale(.6);opacity:.6}50%{transform:scale(1);opacity:1}}.info-message{display:flex;align-items:center;padding:.6rem 1rem;font-size:.875rem;border-radius:8px;max-width:100%}.playback-disabled-message{color:#64748b;border:none;box-shadow:none}.playback-disabled-message .message-icon{margin-right:.8rem;color:#64748b;font-size:1.2rem}@media (max-width: 768px){.mixer-toggle-button span{display:none}.mixer-toggle-button .button-icon{margin-right:0}.mixer-toggle-button{padding:.5rem}.bar-input-container label{display:none}}@media (max-width: 480px){.bottom-bar{padding:.8rem}.player-controls{gap:.5rem}.zoom-percentage{min-width:2.5rem}}#audio-inline-controls{display:inline-flex;align-items:center;gap:0px;color:#213547}#audio-play-pause-btn,#audio-stop-btn{min-width:28px;padding:4px;font-size:1rem}#audio-play-pause-btn{border-radius:4px 0 0 4px;border-right:none}#audio-stop-btn{border-radius:0 4px 4px 0;border-left:none}#audio-progress-bar{flex:1;min-width:120px;margin:0 8px;cursor:pointer;background:#ddd;height:16px;border-radius:3px;position:relative}#audio-progress-fill{position:absolute;left:0;top:0;height:100%;background:#4e4e4e;border-radius:3px 0 0 3px}#audio-progress-indicator{position:absolute;top:0;width:2px;height:100%;background:#000}#audio-time-label{text-align:right;font-size:12px;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;padding:2px 8px;border-radius:6px;color:#213547;background:#eee}#audio-bars-label{text-align:right;font-size:12px;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;white-space:nowrap;overflow:hidden;display:inline-block;padding:2px 8px;border-radius:6px;color:#213547;background:#fff12e;min-width:unset}#audio-tracks-popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000004d;z-index:1000}#audio-tracks-popup{background:#fff;border-radius:8px;max-width:400px;margin:60px auto;padding:24px;position:relative;box-shadow:0 4px 24px #0003}#audio-tracks-popup-close{position:absolute;top:8px;right:8px;font-size:1.2rem;background:transparent;border:none;cursor:pointer}#audio-tracks-popup-title{margin-top:0}#audio-tracks-loading{text-align:center;padding:16px 0}#audio-tracks-list{display:flex;flex-direction:column;gap:12px}[id^=audio-track-row-]{display:flex;align-items:center;gap:8px}[id^=audio-track-label-]{width:80px}[id^=audio-track-volume-]{flex:1}[id^=audio-track-mute-],[id^=audio-track-solo-]{margin-left:4px}:root{color-scheme:light;background-color:#fff;color:#213547}body{background:#fff;color:#213547}@media (prefers-color-scheme: dark){:root{color-scheme:light;background-color:#fff;color:#213547}body{background:#fff;color:#213547}}.audio-player.disabled button{opacity:.5;cursor:not-allowed;background-color:#f5f5f5;color:#888}.bottom-bar-container{position:relative;width:100%;display:flex;justify-content:center}.no-indicator{opacity:0}.loading-message-invisible{display:none}.fallback-container{width:100%;display:flex;justify-content:center}.bottom-bar-container>*{transition:opacity .15s ease;width:100%}.bottom-bar-container .fallback-container,.bottom-bar-container .suspense-content{position:absolute;left:0;right:0;display:flex;justify-content:center}.bottom-bar-container .fallback-container{z-index:1}.sheets-page{width:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.App{display:flex;flex-direction:column;min-height:100vh}.content{padding:0 20px 60px;flex-grow:1;text-align:left}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;background-color:#fff;color:#213547;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#747bff}body{margin:0;min-width:320px;min-height:100vh;background:#fff;color:#213547}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}
