h4[data-v-a3dc0979]{margin-top:20px;margin-bottom:15px;font-size:1.1em;color:#444;border-bottom:1px solid #eee;padding-bottom:5px}h4[data-v-a3dc0979]:first-child{margin-top:0}.setting-group label[data-v-a3dc0979]{display:flex;justify-content:space-between;align-items:center}.color-alpha-group[data-v-a3dc0979]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.color-alpha-group span[data-v-a3dc0979]{font-weight:400;color:#666}.player-panel h4[data-v-1a699c66]{margin-bottom:10px}.player-buttons[data-v-1a699c66]{display:flex;justify-content:center;margin-bottom:10px}.player-btn[data-v-1a699c66]{background:linear-gradient(45deg,#ff9a56,#ff6b6b);color:#fff;border:none;padding:8px 15px;border-radius:15px;margin:0 5px;cursor:pointer;font-size:12px}.progress-bar[data-v-1a699c66]{width:100%;height:8px;background:#ddd;border-radius:4px;cursor:pointer}.progress-fill[data-v-1a699c66]{height:100%;background:linear-gradient(45deg,#ff9a56,#ff6b6b);border-radius:4px;width:0%;transition:width .1s linear}.speed-display[data-v-1a699c66]{text-align:center;font-size:12px;color:#666;margin-top:5px}.sidebar-container[data-v-504e88f7]{position:relative;z-index:1000}.collapse-btn[data-v-504e88f7]{position:fixed;left:0;top:50%;transform:translateY(-50%);width:30px;height:60px;background:#fffffff2;border:1px solid #ddd;border-left:none;border-radius:0 15px 15px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:#ff9a56;box-shadow:2px 0 10px #0000001a;transition:all .3s cubic-bezier(.25,.8,.25,1);z-index:1001}.collapse-btn[data-v-504e88f7]:hover{background:#ff9a561a;transform:translateY(-50%) translate(2px)}.collapse-btn.collapsed[data-v-504e88f7]{left:0}.collapse-btn .arrow[data-v-504e88f7]{transition:transform .3s ease}.sidebar[data-v-504e88f7]{width:300px;background:#fffffff2;box-shadow:2px 0 10px #0000001a;overflow:hidden;position:fixed;height:100vh;left:0;top:0;transition:transform .3s cubic-bezier(.25,.8,.25,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000}.sidebar.collapsed[data-v-504e88f7]{transform:translate(-100%)}.sidebar-content[data-v-504e88f7]{padding:20px;height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#ff9a56 #f0f0f0;position:relative}.sidebar-content[data-v-504e88f7]::-webkit-scrollbar{width:6px}.sidebar-content[data-v-504e88f7]::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.sidebar-content[data-v-504e88f7]::-webkit-scrollbar-thumb{background:#ff9a56;border-radius:3px}.sidebar h2[data-v-504e88f7]{color:#333;margin-bottom:20px;text-align:center;font-size:1.4em;font-weight:700}.sidebar h4[data-v-504e88f7]{font-size:1em;margin-bottom:10px;text-align:center;color:#ff9a56}.upload-section[data-v-504e88f7]{margin-bottom:25px}.upload-area[data-v-504e88f7]{border:2px dashed #ff9a56;border-radius:10px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#ffffff80}.upload-area[data-v-504e88f7]:hover{border-color:#ff6b6b;background:#ff9a561a;transform:translateY(-2px)}.upload-area h4[data-v-504e88f7]{margin:0 0 10px;color:#333;font-size:1.1em}.upload-area p[data-v-504e88f7]{margin:0;color:#666;font-size:.9em}.file-input[data-v-504e88f7]{display:none}.sidebar-footer[data-v-504e88f7]{text-align:center;font-size:12px;color:#999;margin-top:auto;padding-top:20px;border-top:1px solid #eee}.keyboard-section[data-v-504e88f7]{margin-bottom:25px}.keyboard-toggle-btn[data-v-504e88f7]{width:100%;padding:12px;border:none;border-radius:10px;background:linear-gradient(135deg,#ff9a56,#ff6b6b);color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease}.keyboard-toggle-btn[data-v-504e88f7]:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}@media (max-width: 768px){.sidebar[data-v-504e88f7]{width:280px;position:fixed}.sidebar-content[data-v-504e88f7]{padding:15px}.collapse-btn[data-v-504e88f7]{width:25px;height:50px;font-size:14px;z-index:1003}.upload-area[data-v-504e88f7]{padding:15px}.upload-area h4[data-v-504e88f7]{font-size:1em}}@media (max-width: 480px){.sidebar[data-v-504e88f7]{width:260px}.sidebar h2[data-v-504e88f7]{font-size:1.2em}.sidebar h4[data-v-504e88f7]{font-size:.9em}}.note[data-v-e3214b92]{display:flex;justify-content:center;align-items:center;font-weight:700;border-radius:50%;box-shadow:0 2px 4px #0003;position:relative;margin:2px 0;width:2.4em;height:2.4em;transition:all .2s;color:var(--note-text-color);background-color:var(--note-bg-color-type1)}.note.multiple[data-v-e3214b92]{background-color:var(--note-bg-color-multiple, #ff6b6b)}.note.type-2.highlight[data-v-e3214b92]{background-color:var(--note-bg-color-type2)}.note.type-2.highlight.multiple[data-v-e3214b92]{background-color:var(--note-bg-color-type2-multiple, #e47566)}.note.hidden[data-v-e3214b92]{display:none}.sharp-dot[data-v-e3214b92]{position:absolute;top:.3em;left:50%;transform:translate(-50%);width:.3em;height:.3em;background:var(--note-text-color);border-radius:50%;z-index:2}.sharp-dot.double[data-v-e3214b92]{top:.2em}.sharp-dot.second[data-v-e3214b92]{top:.6em}.sheet-container[data-v-8111ad7f]{width:100%;transition:margin-left .3s cubic-bezier(.25,.8,.25,1)}.song-info[data-v-8111ad7f]{background:#fffffff2;border-radius:15px;padding:20px 25px;margin-bottom:20px;box-shadow:0 4px 15px #0000000d}.song-info h3[data-v-8111ad7f]{font-size:1.4em}.seek-feedback[data-v-8111ad7f]{position:fixed;pointer-events:none;z-index:9999;font-size:24px;color:#ff9a56;transform:translate(-50%,-50%);animation:seekPulse-8111ad7f 1s ease-out forwards}@keyframes seekPulse-8111ad7f{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.5)}to{opacity:0;transform:translate(-50%,-50%) scale(2)}}.sheet-music[data-v-8111ad7f]{border:1px solid #e0e0e0;border-radius:15px;padding:25px;margin:10px 0;font-family:Courier New,monospace;position:relative;background:var(--sheet-bg-color);box-shadow:0 8px 30px #0000001a;transition:all .3s ease;width:100%;cursor:pointer;-webkit-user-select:none;user-select:none}.sheet-music.scroll-mode-page[data-v-8111ad7f]{max-height:none;overflow:visible}.sheet-music.scroll-mode-sheet[data-v-8111ad7f]{max-height:70vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--primary-color-2, #ff6b6b) #e0e0e0}.sheet-music:hover .note-group[data-v-8111ad7f]{transition:transform .2s ease}.music-line[data-v-8111ad7f]{display:flex;margin-bottom:25px;min-height:50px;align-items:flex-start}.music-line[data-v-8111ad7f]:last-child{justify-content:flex-start}.music-line.standard-mode[data-v-8111ad7f]{display:flex;align-items:flex-start;overflow-x:auto;overflow-y:visible}.music-line.standard-mode.no-wrap[data-v-8111ad7f]{flex-wrap:nowrap!important}.line-content[data-v-8111ad7f]{display:flex;flex-grow:1;align-items:flex-start}.line-content.standard-mode[data-v-8111ad7f]{display:flex;flex-grow:1;align-items:flex-start;flex-wrap:nowrap!important;overflow:visible}.line-content.standard-mode.no-break[data-v-8111ad7f]{white-space:nowrap;flex-shrink:0;min-width:max-content}.line-content.standard-mode.no-break[data-v-8111ad7f]>*{flex-shrink:0;display:inline-flex;vertical-align:top}.line-number[data-v-8111ad7f]{font-size:.8em;color:#6770d6;font-weight:700;margin-right:15px;display:flex;align-items:flex-start;padding-top:.5em;line-height:1;width:30px;flex-shrink:0}.line-start-bar[data-v-8111ad7f]{width:2px;height:40px;background-color:#999;margin-right:8px;margin-top:5px;flex-shrink:0}.line-start-bar-wrapper[data-v-8111ad7f]{display:flex;align-items:center;align-self:stretch;margin-right:8px}.line-start-bar.standard[data-v-8111ad7f]{width:2px;background-color:#999}.note-group-wrapper[data-v-8111ad7f]{display:flex;align-items:flex-start;justify-content:center;flex-shrink:0;box-sizing:border-box}.note-group[data-v-8111ad7f]{display:inline-flex;flex-direction:column;align-items:center;width:100%;box-sizing:border-box}.note-group-wrapper[data-v-8111ad7f]{flex-shrink:0!important;display:inline-flex}.filler-group[data-v-8111ad7f]{position:relative;min-height:40px;width:100%;display:flex;align-items:center;justify-content:center}.filler-group[data-v-8111ad7f]:after{content:"·";color:#ccc;font-size:1.5em;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.play-indicator[data-v-8111ad7f]{position:absolute;width:3px;background:var(--danger-color, #ff6b6b);border-radius:2px;transform:translate(-50%);opacity:0;transition:all .1s ease-out;z-index:10;pointer-events:none}.controls[data-v-8111ad7f]{text-align:center;margin-top:20px}.control-btn[data-v-8111ad7f]{background:var(--primary-gradient, linear-gradient(45deg, #ff9a56, #ff6b6b));color:#fff;border:none;padding:12px 25px;border-radius:50px;font-size:1em;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);box-shadow:0 2px 5px #0000001a}.control-btn[data-v-8111ad7f]:hover{transform:translateY(-3px);box-shadow:0 4px 10px #764ba24d}.empty-state[data-v-8111ad7f]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff1a;border:3px dashed rgba(255,255,255,.3);border-radius:20px;min-height:400px;color:#fff;transition:all .3s ease}.empty-state.dragover[data-v-8111ad7f]{background:#fff3;border-color:#fff9;transform:scale(1.02)}.empty-text[data-v-8111ad7f]{text-align:center}.empty-text h3[data-v-8111ad7f]{font-size:2.2em;margin-bottom:15px}.bar-line-wrapper[data-v-8111ad7f]{flex-shrink:0!important;display:inline-flex;align-items:center;padding:5px}.bar-line[data-v-8111ad7f]{width:1.5px;background-color:#bbb}@media (max-width: 768px){.sheet-container[data-v-8111ad7f]{margin-left:0!important;cursor:default}.sheet-music[data-v-8111ad7f]{padding:15px;margin:10px 0}.song-info[data-v-8111ad7f]{padding:15px 20px;margin-bottom:15px}.music-line[data-v-8111ad7f]{margin-bottom:20px}.line-number[data-v-8111ad7f]{width:25px;margin-right:10px;font-size:.7em}.line-start-bar[data-v-8111ad7f]{margin-right:6px}.note-group[data-v-8111ad7f]{padding:8px;margin:-8px}.music-line.standard-mode[data-v-8111ad7f]{overflow-x:auto;-webkit-overflow-scrolling:touch}.line-content.standard-mode.no-break[data-v-8111ad7f]{padding-right:10px}}@media (max-width: 480px){.sheet-music[data-v-8111ad7f]{padding:10px;border-radius:10px}.song-info h3[data-v-8111ad7f]{font-size:1.2em}.music-line[data-v-8111ad7f]{margin-bottom:15px}.line-number[data-v-8111ad7f]{width:20px;margin-right:8px;font-size:.6em}.line-start-bar[data-v-8111ad7f]{margin-right:1px}}.notification[data-v-e862cfec]{position:fixed;top:20px;right:20px;padding:15px 25px;border-radius:10px;color:#fff;font-weight:700;z-index:9999;box-shadow:0 4px 12px #00000026;transition:all .3s ease-in-out}.notification.success[data-v-e862cfec]{background:#51cf66}.notification.error[data-v-e862cfec]{background:#ff6b6b}.fade-enter-active[data-v-e862cfec],.fade-leave-active[data-v-e862cfec]{transition:opacity .3s,transform .3s}.fade-enter-from[data-v-e862cfec],.fade-leave-to[data-v-e862cfec]{opacity:0;transform:translateY(-20px)}.search-container[data-v-f00ae854]{position:fixed;top:25px;right:25px;z-index:2000}.search-icon[data-v-f00ae854]{width:50px;height:50px;background:#fffffff2;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 4px 15px #0000001a;transition:all .2s ease-in-out;color:#555}.search-icon[data-v-f00ae854]:hover{transform:scale(1.1);box-shadow:0 6px 20px #00000026}.search-box[data-v-f00ae854]{position:absolute;top:-5px;right:-5px;width:380px;padding:15px;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:15px;box-shadow:0 8px 30px #0000001f;display:flex;flex-direction:column}.search-input-wrapper[data-v-f00ae854]{display:flex;gap:10px;margin-bottom:15px}.search-box input[data-v-f00ae854]{flex-grow:1;padding:10px 15px;border:1px solid #ddd;border-radius:50px;font-size:16px;outline:none;transition:border-color .2s}.search-box input[data-v-f00ae854]:focus{border-color:var(--primary-color-1)}.search-button[data-v-f00ae854]{padding:0 20px;border-radius:50px;background:var(--primary-gradient);color:#fff;border:none;font-size:16px;cursor:pointer;transition:transform .2s}.search-button[data-v-f00ae854]:hover{transform:scale(1.05)}.results-wrapper[data-v-f00ae854]{max-height:350px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--primary-color-2) #e0e0e0}.search-results ul[data-v-f00ae854]{list-style:none}.search-results li[data-v-f00ae854]{display:flex;justify-content:space-between;align-items:center;padding:12px 5px;border-bottom:1px solid #eee;gap:10px}.sheet-info[data-v-f00ae854]{display:flex;flex-direction:column;gap:2px;flex-grow:1;min-width:0}.sheet-name[data-v-f00ae854]{font-weight:700;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sheet-author[data-v-f00ae854]{font-size:13px;color:#777}.sheet-meta[data-v-f00ae854]{display:flex;align-items:center;gap:10px;flex-shrink:0}.sheet-size[data-v-f00ae854]{font-size:12px;color:#999;background:#f0f0f0;padding:2px 6px;border-radius:10px}.open-btn[data-v-f00ae854]{padding:6px 14px;border-radius:50px;background:var(--primary-color-2);color:#fff;border:none;font-size:12px;cursor:pointer;transition:background-color .2s}.open-btn[data-v-f00ae854]:hover{background-color:#5a3a7b}.feedback-message[data-v-f00ae854]{text-align:center;padding:40px 0;color:#888}.results-title[data-v-f00ae854]{font-size:14px;font-weight:700;color:#555;margin-top:10px;margin-bottom:10px;padding-left:5px}.search-history[data-v-f00ae854]{margin-bottom:15px}.history-title[data-v-f00ae854]{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:700;color:#555;margin-bottom:5px;padding:0 5px}.clear-btn[data-v-f00ae854]{background:none;border:none;cursor:pointer;font-size:16px;opacity:.5;transition:opacity .2s}.clear-btn[data-v-f00ae854]:hover{opacity:1}.search-history ul[data-v-f00ae854]{list-style:none}.search-history li[data-v-f00ae854]{padding:8px 5px;cursor:pointer;border-radius:5px;transition:background-color .2s;color:#333}.search-history li[data-v-f00ae854]:hover{background:#f0f0f0}.sheet-rank[data-v-f00ae854]{flex-shrink:0}.rank-badge[data-v-f00ae854]{display:inline-block;width:22px;height:22px;line-height:22px;text-align:center;border-radius:5px;font-weight:700;color:#fff;background-color:#ccc}.rank-badge.rank-1[data-v-f00ae854]{background-color:#ff4d4f}.rank-badge.rank-2[data-v-f00ae854]{background-color:#fa8c16}.rank-badge.rank-3[data-v-f00ae854]{background-color:#fadb14;color:#555}.slide-fade-enter-active[data-v-f00ae854],.slide-fade-leave-active[data-v-f00ae854]{transition:all .3s cubic-bezier(.4,0,.2,1)}.slide-fade-enter-from[data-v-f00ae854],.slide-fade-leave-to[data-v-f00ae854]{transform:translate(20px,-20px) scale(.95);opacity:0}.settings-panel[data-v-27d0ea2a]{position:absolute;right:0;top:0;width:300px;height:100%;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:0 15px 15px 0;overflow-y:auto;box-shadow:-5px 0 20px #0003;animation:slideIn-27d0ea2a .3s ease}@keyframes slideIn-27d0ea2a{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.settings-header[data-v-27d0ea2a]{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(0,0,0,.1)}.settings-header h4[data-v-27d0ea2a]{margin:0;color:#333;font-size:1.2em;font-weight:600}.close-btn[data-v-27d0ea2a]{width:30px;height:30px;border:none;border-radius:50%;background:#0000001a;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn[data-v-27d0ea2a]:hover{background:#0003;transform:scale(1.1)}.settings-content[data-v-27d0ea2a]{padding:20px}.setting-group[data-v-27d0ea2a]{margin-bottom:25px}.setting-group label[data-v-27d0ea2a]{display:block;margin-bottom:10px;color:#333;font-weight:500;font-size:.95em}.instrument-grid[data-v-27d0ea2a]{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.instrument-option[data-v-27d0ea2a]{display:flex;flex-direction:column;align-items:center;padding:12px 8px;border:2px solid rgba(0,0,0,.1);border-radius:10px;cursor:pointer;transition:all .2s ease;background:#ffffff80}.instrument-option[data-v-27d0ea2a]:hover{border-color:#667eea80;transform:translateY(-2px)}.instrument-option.active[data-v-27d0ea2a]{border-color:#ff9a56;background:#667eea1a}.instrument-icon[data-v-27d0ea2a]{font-size:1.5em;margin-bottom:5px}.instrument-name[data-v-27d0ea2a]{font-size:.8em;text-align:center;color:#555;font-weight:500}.pitch-control[data-v-27d0ea2a]{background:#ffffff80;border-radius:10px;padding:15px}.pitch-display[data-v-27d0ea2a]{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.current-pitch[data-v-27d0ea2a]{font-size:1.5em;font-weight:700;color:#ff9a56}.pitch-offset[data-v-27d0ea2a]{font-size:1em;color:#666;font-weight:500}.pitch-slider-container[data-v-27d0ea2a]{position:relative;margin-bottom:10px}.pitch-slider[data-v-27d0ea2a]{width:100%;height:8px;border-radius:4px;background:linear-gradient(to right,#ff6b6b,#ffd93d,#6bcf7f);outline:none;cursor:pointer}.pitch-slider[data-v-27d0ea2a]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #ff9a56;cursor:pointer;box-shadow:0 2px 8px #0003}.pitch-markers[data-v-27d0ea2a]{position:absolute;top:-15px;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none}.pitch-marker[data-v-27d0ea2a]{color:#ccc;font-size:.8em}.pitch-labels[data-v-27d0ea2a]{display:flex;justify-content:space-between;font-size:.8em;color:#666}.size-control[data-v-27d0ea2a]{display:flex;align-items:center;gap:15px}.size-slider[data-v-27d0ea2a]{flex:1;height:6px;border-radius:3px;background:#ddd;outline:none;cursor:pointer}.size-slider[data-v-27d0ea2a]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:#ff9a56;cursor:pointer;box-shadow:0 2px 6px #0003}.size-preview[data-v-27d0ea2a]{display:flex;align-items:center;justify-content:center;width:60px;height:50px}.preview-key[data-v-27d0ea2a]{background:linear-gradient(135deg,#ff9a56,#ff6b6b);border-radius:8px;transition:all .2s ease}.background-options[data-v-27d0ea2a]{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.bg-option[data-v-27d0ea2a]{display:flex;flex-direction:column;align-items:center;padding:10px;border:2px solid rgba(0,0,0,.1);border-radius:10px;cursor:pointer;transition:all .2s ease}.bg-option[data-v-27d0ea2a]:hover{border-color:#667eea80;transform:translateY(-2px)}.bg-option.active[data-v-27d0ea2a]{border-color:#ff9a56;background:#667eea1a}.bg-preview[data-v-27d0ea2a]{width:40px;height:30px;border-radius:5px;margin-bottom:5px;border:1px solid rgba(0,0,0,.1)}.default-bg[data-v-27d0ea2a]{background:linear-gradient(135deg,#ff9a56,#ff6b6b)}.galaxy-bg[data-v-27d0ea2a]{background:linear-gradient(135deg,#191970,#483d8b,#191970)}.ocean-bg[data-v-27d0ea2a]{background:linear-gradient(135deg,#0077be,#00b4d8)}.custom-preview[data-v-27d0ea2a]{display:flex;align-items:center;justify-content:center;background:#f0f0f0;color:#999;font-size:1.2em;font-weight:700}.bg-option span[data-v-27d0ea2a]{font-size:.8em;color:#555;font-weight:500}.reset-btn[data-v-27d0ea2a]{width:100%;padding:12px;border:none;border-radius:10px;background:linear-gradient(135deg,#ff6b6b,orange);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-btn[data-v-27d0ea2a]:hover{transform:translateY(-2px);box-shadow:0 5px 15px #ff6b6b4d}.sync-control[data-v-27d0ea2a]{display:flex;flex-direction:column;gap:8px}.checkbox-label[data-v-27d0ea2a]{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500}.checkbox-label input[type=checkbox][data-v-27d0ea2a]{width:16px;height:16px;accent-color:#ff9a56}.sync-description[data-v-27d0ea2a]{font-size:12px;color:#666;margin:0;padding-left:24px;line-height:1.4}@media (max-width: 768px){.settings-panel[data-v-27d0ea2a]{width:280px}.instrument-grid[data-v-27d0ea2a],.background-options[data-v-27d0ea2a]{grid-template-columns:1fr}}.keyboard-overlay[data-v-b9ae488f]{position:fixed;top:0;left:0;width:100vw;height:100vh;background:transparent;z-index:2000;display:flex;justify-content:center;align-items:center;pointer-events:none}.keyboard-window[data-v-b9ae488f]{position:absolute;min-width:400px;min-height:300px;border-radius:15px;box-shadow:0 20px 60px #0000004d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden;resize:none;-webkit-user-select:none;user-select:none}.keyboard-window[data-v-b9ae488f],.keyboard-mobile[data-v-b9ae488f]{pointer-events:auto}.keyboard-header[data-v-b9ae488f]{height:50px;background:#ffffff1a;border-bottom:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:space-between;padding:0 20px;cursor:move}.keyboard-header h3[data-v-b9ae488f]{margin:0;color:#fff;font-size:1.1em;font-weight:600}.header-controls[data-v-b9ae488f]{display:flex;gap:10px}.practice-btn[data-v-b9ae488f],.settings-btn[data-v-b9ae488f],.close-btn[data-v-b9ae488f]{width:30px;height:30px;border:none;border-radius:50%;background:#fff3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.practice-btn[data-v-b9ae488f]:hover,.settings-btn[data-v-b9ae488f]:hover,.close-btn[data-v-b9ae488f]:hover{background:#ffffff4d;transform:scale(1.1)}.practice-btn.active[data-v-b9ae488f]{background:#ffd700cc;color:#333}.keyboard-area[data-v-b9ae488f]{flex:1;display:flex;justify-content:center;align-items:center;padding:20px}.keys-grid[data-v-b9ae488f]{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(3,1fr);gap:8px;max-width:100%;max-height:100%}.key-button[data-v-b9ae488f]{position:relative;border:none;border-radius:12px;background:#0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .15s ease;display:flex;align-items:center;justify-content:center;perspective:1000px;transform-style:preserve-3d}.key-button[data-v-b9ae488f]:hover{background:#0000004d;transform:translateY(-2px)}.key-button.pressed[data-v-b9ae488f]{background:#ffffff4d}.key-inner[data-v-b9ae488f]{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.key-glow[data-v-b9ae488f]{position:absolute;width:60%;height:60%;border-radius:inherit;background:transparent;border:2px solid #ffd700;box-shadow:0 0 10px #ffd7004d;opacity:1;transition:all .2s ease}.key-button.pressed .key-glow[data-v-b9ae488f],.key-button.animating .key-glow[data-v-b9ae488f]{border-color:#ffed4e;box-shadow:0 0 20px #ffd70099}.key-button.highlighted[data-v-b9ae488f]{background:#ffffff4d;border:2px solid #ffffff;box-shadow:0 0 15px #fffc;animation:highlight-pulse-b9ae488f 1.5s ease-in-out infinite}@keyframes highlight-pulse-b9ae488f{0%,to{box-shadow:0 0 15px #fffc}50%{box-shadow:0 0 25px #fff}}.key-circle .key-glow[data-v-b9ae488f]{border-radius:50%}.key-square .key-glow[data-v-b9ae488f]{border-radius:8px}.key-diamond .key-glow[data-v-b9ae488f],.key-diamond-circle .key-glow[data-v-b9ae488f]{border-radius:8px;transform:rotate(45deg)}.key-diamond-circle .key-glow[data-v-b9ae488f]:after{content:"";position:absolute;top:50%;left:50%;width:90%;height:90%;background:transparent;border:2px solid #ffd700;border-radius:50%;transform:translate(-50%,-50%)}.key-number[data-v-b9ae488f]{position:relative;z-index:2;color:#fff;font-weight:600;font-size:.9em;text-shadow:0 1px 3px rgba(0,0,0,.5)}.keyboard-mobile[data-v-b9ae488f]{width:100vw;height:100vh;background:linear-gradient(135deg,#667eeaf2,#764ba2f2);display:flex;flex-direction:column;transform:rotate(90deg);transform-origin:center}.mobile-header[data-v-b9ae488f]{height:60px;background:#ffffff1a;display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.2)}.mobile-keyboard[data-v-b9ae488f]{flex:1;padding:20px}.mobile-key[data-v-b9ae488f]{min-width:80px;min-height:80px}.resize-handles[data-v-b9ae488f]{position:absolute;bottom:0;right:0;width:20px;height:20px}.resize-handle[data-v-b9ae488f]{position:absolute;background:#ffffff4d;cursor:se-resize}.resize-se[data-v-b9ae488f]{bottom:0;right:0;width:20px;height:20px;border-radius:15px 0}.resize-se[data-v-b9ae488f]:after{content:"";position:absolute;bottom:3px;right:3px;width:0;height:0;border-left:8px solid transparent;border-bottom:8px solid rgba(255,255,255,.6)}@media (max-width: 768px){.keyboard-overlay[data-v-b9ae488f]{background:#000c}.mobile-header h3[data-v-b9ae488f]{font-size:1em}.keys-grid[data-v-b9ae488f]{gap:6px}}@media (orientation: landscape) and (max-width: 768px){.keyboard-mobile[data-v-b9ae488f]{transform:none}.mobile-key[data-v-b9ae488f]{min-width:60px;min-height:60px}}.root-container{min-height:100vh}.main-container{position:relative;min-height:100vh}.content-area{min-height:100vh;padding:20px 40px;background:linear-gradient(135deg,#ff9a56,#ff6b6b);transition:all .3s cubic-bezier(.25,.8,.25,1);margin-left:var(--sidebar-width);width:calc(100vw - var(--sidebar-width));box-sizing:border-box;position:relative;z-index:1}.header{text-align:center;margin-bottom:30px;color:#fff}.header h1{font-size:2.5em;margin-bottom:10px;text-shadow:0 2px 4px rgba(0,0,0,.3);font-weight:700}.header p{font-size:1.2em;opacity:.9;font-weight:300}.drop-overlay{position:absolute;inset:0;background:#764ba2b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1500;display:flex;justify-content:center;align-items:center;border:3px dashed rgba(255,255,255,.8);border-radius:20px;margin:20px 40px}.drop-overlay-text{color:#fff;text-align:center;font-size:1.5em;text-shadow:0 2px 4px rgba(0,0,0,.5)}.drop-overlay-text h3{margin:0;font-weight:600}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}@media (min-width: 769px){.sidebar{position:fixed;z-index:1000}.content-area{margin-left:var(--sidebar-width);width:calc(100vw - var(--sidebar-width))}}@media (max-width: 768px){.sidebar{position:fixed;z-index:1000;width:280px}.content-area{margin-left:0!important;width:100%!important;padding:15px 20px}.header h1{font-size:2em}.header p{font-size:1em}.drop-overlay{margin:15px 20px}.drop-overlay-text{font-size:1.2em}.sidebar:not(.collapsed){z-index:1001}}@media (max-width: 480px){.content-area{padding:10px 15px}.header h1{font-size:1.8em}.header{margin-bottom:20px}.drop-overlay{margin:10px 15px}.drop-overlay-text{font-size:1.1em}}.content-area{width:100%;box-sizing:border-box}*{box-sizing:border-box}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}:root{--bg-blur: 0px;--custom-bg-image: linear-gradient(135deg, #ff9a56 0%, #ff6b6b 100%);--primary-gradient: linear-gradient(45deg, #ff9a56, #ff6b6b);--primary-color-1: #ff9a56;--primary-color-2: #ff6b6b;--danger-color: #ff6b6b;--success-color: #51cf66;--note-text-color: #ffffff;--sheet-bg-color: rgba(255, 255, 255, 1);--sidebar-width: 300px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Microsoft YaHei,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;min-height:100vh;background-color:#f0f2f5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh}.main-container{display:flex;min-height:100vh}.content-area{flex:1;margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width));padding:25px 40px;display:flex;flex-direction:column;position:relative;overflow-x:hidden;transition:margin-left .3s cubic-bezier(.25,.8,.25,1),width .3s cubic-bezier(.25,.8,.25,1)}.content-area:before{content:"";position:absolute;inset:0;z-index:-1;background-image:var(--custom-bg-image);background-size:cover;background-position:center center;background-attachment:fixed;transition:backdrop-filter .3s ease,background-position .1s linear;-webkit-backdrop-filter:var(--bg-blur);backdrop-filter:var(--bg-blur)}.header{text-align:center;color:#fff;margin-bottom:25px;text-shadow:0 2px 5px rgba(0,0,0,.3)}.header h1{font-size:2.5em;margin-bottom:10px}.header p{font-size:1.2em;opacity:.9}.sidebar{width:var(--sidebar-width);background:#fffffff7;padding:20px;box-shadow:3px 0 15px #0000001a;overflow-y:auto;position:fixed;height:100vh;z-index:1000;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.25,.8,.25,1)}.sidebar.collapsed{transform:translate(-100%)}.sidebar.collapsed~.content-area,.content-area[data-sidebar-collapsed=true]{--sidebar-width: 0px;margin-left:0;width:100vw}.sidebar h2{color:#333;margin-bottom:20px;text-align:center;font-size:1.5em}.upload-section,.settings-panel,.player-panel{margin-bottom:25px;border-bottom:1px solid #e0e0e0;padding-bottom:25px}.sidebar>*:last-child{border-bottom:none}.upload-area{border:2px dashed var(--primary-color-1);border-radius:12px;padding:25px 20px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1)}.upload-area:hover,.upload-area.dragover{border-color:var(--primary-color-2);background:#667eea0d;transform:translateY(-2px)}.upload-area h4{color:#333;margin-bottom:8px}.upload-area p{color:#777;font-size:12px}.file-input{display:none}.sidebar-footer{text-align:center;font-size:12px;color:#aaa;margin-top:auto;padding-top:20px}.sheet-container{width:100%}.song-info{background:#fffffff2;border-radius:15px;padding:20px 25px;margin-bottom:20px;box-shadow:0 4px 15px #0000000d}.song-info h3{font-size:1.4em}.sheet-music{border:1px solid #e0e0e0;border-radius:15px;padding:25px;margin:20px 0;font-family:Courier New,monospace;position:relative;overflow-y:auto;max-height:65vh;background-color:rgba(var(--sheet-bg-color-rgb),var(--sheet-bg-alpha));box-shadow:0 8px 30px #0000001a}.sheet-music .music-line{display:flex;flex-wrap:nowrap;align-items:flex-end;margin-bottom:20px;min-height:50px;justify-content:space-between}.sheet-music .music-line:last-child{justify-content:flex-start}.sheet-music.scroll-mode-page{max-height:none;overflow-y:visible}.sheet-music.scroll-mode-sheet{max-height:70vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--primary-color-2) #e0e0e0}.line-number{font-size:.8em;color:#ccc;font-weight:700;align-self:flex-start;padding-top:.5em;margin-right:15px}.note-group-wrapper{display:flex;align-items:center}.note-group{display:inline-flex;flex-direction:column;align-items:flex-start}.rhythm-marker{color:var(--rhythm-marker-color);font-size:1.5em;font-weight:700;align-self:center;-webkit-user-select:none;user-select:none;margin:0 5px}.play-indicator{position:absolute;width:3px;background:var(--danger-color);border-radius:2px;transform:translate(-50%);opacity:0;transition:all .1s ease-out;z-index:10;pointer-events:none}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff1a;border:3px dashed rgba(255,255,255,.3);border-radius:20px;min-height:400px;color:#fff}.setting-group{margin-bottom:15px;font-size:14px}.setting-group h4{margin-bottom:15px;font-size:1.1em;color:#444}.setting-group label{display:block;margin-bottom:8px;font-weight:600;color:#555}.setting-group select,.setting-group input[type=range]{width:100%}.toggle-group label{display:inline-flex;align-items:center;margin-right:15px;font-weight:400;cursor:pointer}.toggle-group input[type=checkbox]{margin-right:5px}input[type=color]{vertical-align:middle;margin-left:8px;border:1px solid #ddd;border-radius:5px;width:30px;height:30px;cursor:pointer}select{padding:8px;border-radius:8px;border:1px solid #ccc;background-color:#f9f9f9;transition:border-color .2s}select:focus{outline:none;border-color:var(--primary-color-1)}.control-btn,.upload-btn-style{background:var(--primary-gradient);color:#fff;border:none;padding:12px 25px;border-radius:50px;font-size:1em;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);box-shadow:0 2px 5px #0000001a}.control-btn:hover,.upload-btn-style:hover{transform:translateY(-3px);box-shadow:0 4px 10px #764ba24d}.upload-area .upload-btn-style{padding:8px 20px;font-size:14px}button.reset-btn{width:100%;padding:10px;background:#f67280;color:#fff;border:none;border-radius:8px;cursor:pointer;margin-top:10px;transition:background .2s}button.reset-btn:hover{background:#d64555}.player-btn{background:var(--primary-gradient);color:#fff;border:none;padding:8px 15px;border-radius:50px;margin:0 5px;cursor:pointer;font-size:12px;transition:all .2s}.player-btn:hover{transform:scale(1.05)}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;cursor:pointer;margin:15px 0}.progress-fill{height:100%;background:var(--primary-gradient);border-radius:4px;width:0%;transition:width .1s linear}@media (max-width: 768px){.main-container{flex-direction:column}.content-area{margin-left:0;width:100%;padding:15px}.sidebar{position:relative;width:100%;height:auto;box-shadow:none}}
