.piano-container[data-v-b14182fd]{width:100%;overflow:hidden;background:linear-gradient(to bottom,#f5f5fa,#e8e8f2);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--border)}.piano-container.scrollable[data-v-b14182fd]{overflow-x:auto}.piano-keyboard[data-v-b14182fd]{position:relative;height:200px;background:linear-gradient(to bottom,#e0e0ea,#c8c8d8);border-radius:8px;box-shadow:inset 0 4px 16px #0000001a}.piano-key[data-v-b14182fd]{position:absolute;box-sizing:border-box;transition:all .08s ease;cursor:pointer;user-select:none;top:0;touch-action:none}.piano-key.white[data-v-b14182fd]{height:100%;background:linear-gradient(to bottom,#ffffff,#f0f0f5);border:1px solid #ccc;border-bottom:4px solid #999;border-radius:0 0 5px 5px;box-shadow:0 2px 6px #00000014}.piano-key.white[data-v-b14182fd]:hover{background:linear-gradient(to bottom,#fefefe,#ffeaa7)}.piano-key.white.active[data-v-b14182fd]{background:linear-gradient(to bottom,#fd79a8,#e84393);border-bottom-color:#d63031;transform:translateY(3px);box-shadow:0 1px 3px #0000001a,0 0 20px #fd79a84d}.piano-key.black[data-v-b14182fd]{height:60%;background:linear-gradient(to bottom,#555,#222);border:1px solid #111;border-bottom:3px solid #000;border-radius:0 0 4px 4px;box-shadow:0 4px 8px #0000004d}.piano-key.black[data-v-b14182fd]:hover{background:linear-gradient(to bottom,#666,#444)}.piano-key.black.active[data-v-b14182fd]{background:linear-gradient(to bottom,#e84393,#d63031);border-bottom-color:#c0392b;transform:translateY(2px);box-shadow:0 2px 6px #0003,0 0 20px #fd79a84d}.key-label-container[data-v-b14182fd]{position:absolute;bottom:6px;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.piano-key.white .key-name[data-v-b14182fd]{color:#555;font-size:10px;font-weight:700}.piano-key.white .key-midi[data-v-b14182fd]{color:#888;font-size:9px}.piano-key.black .key-name[data-v-b14182fd]{color:#ccc;font-size:9px;font-weight:700}.piano-key.black .key-midi[data-v-b14182fd]{color:#999;font-size:8px}.piano-key.white.active .key-name[data-v-b14182fd],.piano-key.white.active .key-midi[data-v-b14182fd],.piano-key.black.active .key-name[data-v-b14182fd],.piano-key.black.active .key-midi[data-v-b14182fd]{color:#fff}@media (max-width: 480px){.piano-container[data-v-b14182fd]{overflow-x:auto;-webkit-overflow-scrolling:touch}.piano-key.white[data-v-b14182fd]{height:100px}.piano-key.black[data-v-b14182fd]{height:60px}.key-name[data-v-b14182fd]{font-size:9px}}.sound-selector[data-v-bf327a56]{display:flex;align-items:center;gap:10px}.sound-selector label[data-v-bf327a56]{font-size:13px;font-weight:600;color:var(--text-secondary)}.sound-selector select[data-v-bf327a56]{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);font-size:13px;cursor:pointer;transition:all var(--transition)}.sound-selector select[data-v-bf327a56]:hover{border-color:var(--accent2)}.sound-selector select[data-v-bf327a56]:focus{border-color:var(--accent2);outline:none;box-shadow:0 0 0 3px #00cec926}.login-modal-overlay[data-v-bf327a56]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.login-modal[data-v-bf327a56]{background:white;border-radius:16px;padding:32px 28px;text-align:center;max-width:360px;width:90%;box-shadow:0 20px 60px #0003;animation:modalIn-bf327a56 .3s ease}@keyframes modalIn-bf327a56{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.login-modal-icon[data-v-bf327a56]{font-size:48px;margin-bottom:12px}.login-modal h3[data-v-bf327a56]{margin:0 0 8px;font-size:18px;color:#2d2d3a}.login-modal p[data-v-bf327a56]{margin:0 0 24px;font-size:14px;color:#6b6b80}.login-modal-btns[data-v-bf327a56]{display:flex;gap:12px;justify-content:center}.btn-cancel[data-v-bf327a56],.btn-login[data-v-bf327a56]{padding:10px 24px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel[data-v-bf327a56]{background:#f0f0f5;color:#6b6b80}.btn-cancel[data-v-bf327a56]:hover{background:#e2e2ec}.btn-login[data-v-bf327a56]{background:linear-gradient(135deg,#35b8e0,#2d9dc5);color:#fff}.btn-login[data-v-bf327a56]:hover{box-shadow:0 4px 16px #35b8e04d;transform:translateY(-1px)}.load-progress[data-v-bf327a56]{display:flex;align-items:center;gap:8px;margin-left:4px}.progress-bar[data-v-bf327a56]{width:80px;height:6px;background:#e8e8f0;border-radius:3px;overflow:hidden}.progress-fill[data-v-bf327a56]{height:100%;background:linear-gradient(90deg,#35b8e0,#2d9dc5);border-radius:3px;transition:width .4s ease}.progress-text[data-v-bf327a56]{font-size:11px;color:var(--text-muted);white-space:nowrap}@media (max-width: 480px){.sound-selector[data-v-bf327a56]{gap:6px}.sound-selector label[data-v-bf327a56]{font-size:11px}.sound-selector select[data-v-bf327a56]{font-size:12px;padding:6px 8px}}.control-panel{flex:1;display:flex;gap:15px}.control-section{background:var(--bg-surface);padding:16px;border-radius:var(--radius-sm);border:1px solid var(--border)}.control-section h3{margin-top:0;margin-bottom:15px;color:var(--text-primary);font-size:15px;font-weight:600}.velocity-control{display:flex;flex-direction:row;gap:15px;align-items:center}.velocity-count-control{display:flex;align-items:center;gap:10px}.count-btn{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);font-size:16px;font-weight:400;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition)}.count-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.count-btn:disabled{background:#e8e8f0;color:var(--text-muted);cursor:not-allowed}.velocity-options-grid{display:flex;gap:12px;flex-direction:row;align-items:center}.velocity-option{display:flex;flex-direction:column;align-items:center;gap:4px}.velocity-color{width:32px;height:32px;border-radius:6px;border:2px solid var(--border);cursor:pointer;transition:all var(--transition)}.velocity-color:hover{transform:scale(1.15);box-shadow:0 0 12px #35b8e04d;border-color:var(--accent)}.duration-control{display:flex;flex-direction:column;gap:10px}.duration-control label{color:var(--text-secondary);font-size:13px}.knob-container{display:flex;flex-direction:column;align-items:center;gap:8px}.knob{position:relative;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#ffffff,#f0f0f5);border:2px solid #d0d0e0;box-shadow:0 3px 10px #00000014,inset 0 1px 2px #ffffffe6;cursor:ns-resize;display:flex;align-items:center;justify-content:center;transition:transform .1s ease}.knob:before{content:"";position:absolute;top:3px;left:3px;right:3px;bottom:3px;border-radius:50%;background:linear-gradient(135deg,#ffffff,#f8f8fc);box-shadow:inset 0 2px 4px #0000000a}.knob:after{content:"";position:absolute;top:6px;left:6px;right:6px;bottom:6px;border-radius:50%;border:1px solid rgba(255,255,255,.6)}.knob-mark{position:absolute;top:5px;left:50%;width:6px;height:6px;margin-left:-3px;background:var(--accent);border-radius:50%;transform-origin:center 20px;box-shadow:0 0 6px var(--accent-glow),0 0 12px var(--accent-glow);z-index:2}.knob-value{font-size:12px;color:var(--accent);font-weight:700}.status-info{color:var(--text-primary);font-size:13px}.status-info p{margin:5px 0}.button-matrix{display:flex;flex-direction:column;gap:10px;align-items:center;padding:20px;background:#3a3a45;border-radius:var(--radius-md);border:1px solid var(--border)}.square-button{width:52px;height:52px;background-color:#f0f0f5;border-radius:6px;cursor:pointer;transition:all .15s ease;border:2px solid #d0d0e0;box-shadow:0 2px 6px #00000014}.square-button:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow);transform:translateY(-1px)}.square-button.active{box-shadow:0 0 20px #35b8e080;border-color:#ffffff80}.round-button{width:42px;height:42px;background-color:#f0f0f5;border-radius:50%;cursor:pointer;transition:all .15s ease;border:2px solid #d0d0e0;box-shadow:0 2px 6px #00000014}.round-button:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow);transform:translateY(-1px)}.round-button.active{box-shadow:0 0 20px #35b8e080;border-color:#ffffff80}.color-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.color-picker{background:var(--bg-surface);padding:24px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);max-width:800px;width:90%}.color-picker h3{margin-top:0;margin-bottom:16px;color:var(--text-primary);text-align:center;font-size:16px}.color-palette{display:grid;grid-template-columns:repeat(auto-fill,minmax(30px,1fr));gap:5px;margin-bottom:16px;max-height:400px;overflow-y:auto}.color-swatch{width:100%;height:30px;border-radius:5px;cursor:pointer;transition:all var(--transition);position:relative;border:2px solid transparent}.color-swatch:hover{transform:scale(1.15);z-index:1}.color-swatch.highlighted{box-shadow:0 0 12px 3px #35b8e080;border-color:var(--accent);transform:scale(1.2);z-index:2}.close-btn{display:block;margin:0 auto;padding:10px 20px;background:linear-gradient(135deg,var(--accent),#2d9dc5);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;transition:all var(--transition);font-size:14px;font-weight:600}.close-btn:hover{box-shadow:0 4px 18px var(--accent-glow);transform:translateY(-2px)}.export-controls{margin:20px 0;padding:15px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}.exported-textarea{width:100%;height:150px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-primary);font-family:monospace;resize:vertical}.copy-button{margin-top:10px;padding:8px 15px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;transition:all var(--transition)}.copy-button:hover{box-shadow:0 2px 12px var(--accent-glow)}@media (max-width: 768px){.launchpad-wrapper{flex-direction:column}.velocity-options-grid{display:flex;gap:12px;margin-top:10px;flex-wrap:wrap;flex-direction:row}.top-buttons,.bottom-buttons{gap:10px}.button-row{gap:8px}.square-button{width:40px;height:40px}.round-button{width:35px;height:35px}}.midi-connector{display:flex;flex-direction:column;gap:15px;padding:20px;background:var(--bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);font-family:Segoe UI,system-ui,-apple-system,sans-serif;transition:all var(--transition)}.midi-connector:hover{box-shadow:var(--shadow-md)}.toggle-label{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.toggle-switch{position:relative;width:80px;height:28px;background:#e8e8f0;border-radius:14px;border:1px solid #d0d0e0;box-shadow:inset 0 1px 3px #0000001a;cursor:pointer;transition:all var(--transition);overflow:hidden}.toggle-switch:hover{border-color:var(--accent)}.toggle-switch.active{background:linear-gradient(135deg,var(--accent),#2d9dc5);border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow)}.toggle-switch.active .toggle-knob{transform:translate(52px);box-shadow:0 2px 8px #0003}.toggle-status{position:absolute;width:100%;text-align:center;font-size:10px;font-weight:600;color:var(--text-secondary);transition:color var(--transition);z-index:1;line-height:28px}.connection-status-text{margin-left:10px;font-size:13px;color:var(--text-secondary)}.no-device-alert{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 14px;background:#fff8e6;border-radius:var(--radius-sm);border:1px solid #ffd700;font-size:13px;color:#e67e22}.alert-icon{font-size:16px}.device-control-area{display:flex;flex-direction:column;gap:12px;padding:14px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border)}.device-group label{margin-right:5px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.midi-device-selector{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);min-width:160px;flex:1;font-size:13px;transition:all var(--transition)}.midi-device-selector option:disabled{color:var(--text-muted)}.midi-channel-selector{padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);width:65px;font-size:13px;transition:all var(--transition)}.channel-label{font-size:11px;color:var(--text-muted);margin-right:6px;font-weight:600;text-transform:uppercase}.no-devices{font-size:13px;color:var(--text-muted);padding:0 8px}.error-message{color:var(--danger);font-size:13px;padding:10px 14px;background:#fff0f0;border-radius:var(--radius-sm);border:1px solid #ffd0d0}.last-note-info{margin-top:8px;padding:10px 14px;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:13px;border:1px solid var(--border)}.knob-container{display:flex;flex-direction:column;align-items:center;margin-left:12px}.knob-label{font-size:11px;color:var(--text-muted);margin-top:5px;font-weight:600;display:flex;align-items:center}.shift-value{margin-left:5px;font-weight:700;color:var(--accent);min-width:30px;text-align:center}.knob{position:relative;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#ffffff,#f0f0f5);border:2px solid #d0d0e0;box-shadow:0 3px 10px #00000014,inset 0 1px 2px #ffffffe6;cursor:ns-resize;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.knob-mark{position:absolute;top:4px;left:50%;width:5px;height:5px;margin-left:-2.5px;background:var(--accent);border-radius:50%;transform-origin:center 16px;box-shadow:0 0 5px var(--accent-glow),0 0 10px var(--accent-glow);z-index:2}.toggle-container .toggle-label{font-size:11px;color:var(--text-muted);margin-right:6px;font-weight:600}.device-status-indicator{margin-left:10px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;background-color:var(--success);color:#fff}.device-status-indicator.disconnected{background-color:var(--danger)}.shift-selector-container label{margin-right:5px;font-size:11px;color:var(--text-muted);font-weight:600}.semitone-shift-selector{padding:5px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);font-size:12px;min-width:60px;transition:all var(--transition)}.semitone-shift-selector:hover{border-color:var(--border-light)}.semitone-shift-selector:focus{border-color:var(--accent);outline:none}@media (max-width: 480px){.connection-toggle-container{flex-wrap:wrap;gap:8px}.toggle-switch{min-width:auto;padding:6px 12px}.toggle-label{font-size:12px}.device-control-area{flex-direction:column;gap:8px}.device-selection-row{flex-direction:column;gap:6px}.device-group{width:100%}.device-group label{font-size:11px;min-width:40px}.midi-device-selector{font-size:11px;padding:5px 6px;min-width:auto;flex:1;width:100%}.knob{width:32px;height:32px}.knob-control{gap:4px;margin-right:0}.knob-label,.knob-value{font-size:10px}.shift-selector-container{margin-left:0}}.device-status-indicator[data-v-512fd150]{margin-left:10px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;background-color:#00b894;color:#fff}.device-status-indicator.disconnected[data-v-512fd150]{background-color:#e17055}.midi-device-selector option[data-v-512fd150]:disabled{color:#999}.shift-selector-container[data-v-512fd150]{display:flex;align-items:center;margin-left:8px}.shift-selector-container label[data-v-512fd150]{margin-right:5px;font-size:11px;color:#9e9eb0;font-weight:600}.semitone-shift-selector[data-v-512fd150]{padding:5px 8px;border-radius:8px;border:1px solid #e2e2ec;background:#ffffff;color:#2d2d3a;font-size:12px;min-width:60px;transition:all .25s}.semitone-shift-selector[data-v-512fd150]:hover{border-color:#d0d0e0}.semitone-shift-selector[data-v-512fd150]:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #35b8e01a}.device-group[data-v-512fd150]{display:flex;align-items:center;margin-right:15px;gap:8px}.device-group label[data-v-512fd150]{margin-right:5px;font-size:11px;color:#9e9eb0;font-weight:600}.midi-device-selector[data-v-512fd150]{padding:8px 12px;border-radius:8px;border:1px solid #e2e2ec;background:#ffffff;color:#2d2d3a;font-size:12px;min-width:150px;margin-right:10px;transition:all .25s}.midi-device-selector[data-v-512fd150]:hover{border-color:#d0d0e0}.midi-channel-selector[data-v-512fd150]{padding:8px 10px;border-radius:8px;border:1px solid #e2e2ec;background:#ffffff;color:#2d2d3a;font-size:12px;min-width:50px;margin-right:10px;transition:all .25s}.midi-file-selector[data-v-17eaeaf9]{display:flex;align-items:center;gap:10px}.file-input-hidden[data-v-17eaeaf9]{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.file-upload-btn[data-v-17eaeaf9]{display:inline-flex;align-items:center;padding:8px 16px;background:linear-gradient(135deg,var(--accent),#2d9dc5);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:all var(--transition);box-shadow:0 2px 10px var(--accent-glow)}.file-upload-btn[data-v-17eaeaf9]:hover{box-shadow:0 4px 18px var(--accent-glow);transform:translateY(-1px)}.midi-device-selector[data-v-17eaeaf9]{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);font-size:13px;cursor:pointer;min-width:160px;transition:all var(--transition)}.midi-device-selector[data-v-17eaeaf9]:hover{border-color:var(--border-light)}.midi-device-selector[data-v-17eaeaf9]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #35b8e026}.midi-info-row[data-v-17eaeaf9]{display:flex;align-items:center;gap:2px;white-space:nowrap;margin-left:6px}.midi-info-row .info-label[data-v-17eaeaf9]{font-size:11px;font-weight:600;color:var(--accent)}.midi-info-row .info-value[data-v-17eaeaf9]{font-size:11px;font-weight:600;color:var(--text-primary);margin-left:2px}.midi-info-row .info-sep[data-v-17eaeaf9]{color:var(--border-light);margin:0 8px;font-size:11px}.loading-text[data-v-17eaeaf9]{margin-left:10px;font-size:12px;color:var(--text-secondary)}.jiaoxue-container{margin:0 auto;padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 15px #00000014;border:1px solid #e1e1e1;font-family:Segoe UI,Arial,sans-serif}.jiaoxue-wrapper{display:flex;justify-content:center}.jiaoxue-keyboard{flex:0 0 auto;background-color:#5d5d5d;padding:20px;border-radius:8px;box-shadow:0 2px 15px #00000014;border:1px solid #e1e1e1;height:610px}.top-buttons,.bottom-buttons{display:flex;justify-content:center;gap:20px;margin-bottom:10px;margin-top:10px}.button-matrix{display:flex;flex-direction:column;gap:10px;align-items:center}.button-row{display:flex;gap:10px}.square-button{width:50px;height:50px;background-color:#f8f8f8;border-radius:5px;cursor:pointer;transition:all .1s ease;border:1px solid #e0e0e0;box-shadow:0 1px 3px #0000001a}.square-button:hover{background-color:#f0f0f0}.square-button.active{box-shadow:0 0 15px #5aa0f080}.round-button{width:40px;height:40px;background-color:#f8f8f8;border-radius:50%;cursor:pointer;transition:all .1s ease;border:1px solid #e0e0e0;box-shadow:0 1px 3px #0000001a}.round-button:hover{background-color:#f0f0f0}.round-button.active{box-shadow:0 0 15px #5aa0f080}.jiaoxue-container[data-v-b2a14bed]{display:flex;flex-direction:column;align-items:center;padding:20px;gap:20px}.offset-controls[data-v-b2a14bed]{display:flex;align-items:center;gap:10px;margin-top:10px}.offset-select[data-v-b2a14bed]{padding:6px 12px;border-radius:6px;border:1px solid #ddd;background:white;font-size:14px}.export-controls[data-v-b2a14bed]{margin:20px 0;padding:15px;background-color:#f5f5f5;border-radius:8px;width:100%;max-width:800px}.exported-text-container[data-v-b2a14bed]{margin-top:15px}.exported-textarea[data-v-b2a14bed]{width:100%;height:150px;padding:10px;border:1px solid #ddd;border-radius:4px;font-family:monospace;resize:vertical;margin-bottom:10px;background:white;color:#333}.copy-button[data-v-b2a14bed]{padding:8px 15px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.copy-button[data-v-b2a14bed]:hover{background-color:#0b7dda}.empty-tip[data-v-b2a14bed]{color:#666;font-size:14px;padding:10px;text-align:center}.jiaoxue-keyboard[data-v-b2a14bed]{margin-top:20px;background:#2d2d2d;padding:20px;border-radius:12px;box-shadow:0 4px 12px #0003}.top-buttons[data-v-b2a14bed],.bottom-buttons[data-v-b2a14bed]{display:flex;justify-content:center;gap:20px;margin:10px 0}.button-matrix[data-v-b2a14bed]{display:flex;flex-direction:column;gap:10px}.button-row[data-v-b2a14bed]{display:flex;align-items:center;gap:10px}.round-button[data-v-b2a14bed],.square-button[data-v-b2a14bed]{cursor:pointer;border:none;transition:all .1s ease}.round-button[data-v-b2a14bed]{width:40px;height:40px;border-radius:50%;background:#444}.square-button[data-v-b2a14bed]{width:50px;height:50px;border-radius:8px;background:#444;position:relative}.active[data-v-b2a14bed]{transform:scale(.95)}.pagination-controls[data-v-b2a14bed]{display:flex;align-items:center;gap:20px;margin-top:10px}.page-btn[data-v-b2a14bed]{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer}.page-btn[data-v-b2a14bed]:disabled{background-color:#ccc;cursor:not-allowed}.page-info[data-v-b2a14bed]{color:#666;font-size:14px}.button-text[data-v-b2a14bed]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;color:#333;font-weight:700;pointer-events:none;word-wrap:break-word;max-width:90%;text-align:center}.container{margin:0 auto;padding:0;max-width:1440px;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.controls-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:16px;margin-top:16px}.file-upload-container{padding:12px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);transition:border-color var(--transition)}.file-upload-container:hover{border-color:var(--accent)}.file-upload-label{gap:10px;display:flex;align-items:center;justify-content:center;min-height:60px}.file-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.file-upload-button{padding:8px 18px;background:linear-gradient(135deg,var(--accent),#2d9dc5);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:all var(--transition);box-shadow:0 2px 10px var(--accent-glow)}.file-upload-button:hover{box-shadow:0 4px 18px var(--accent-glow);transform:translateY(-1px)}.midi-file-selector{padding:12px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);gap:10px;display:flex;align-items:center;justify-content:center;min-height:60px}.midi-style{padding:12px;background:var(--bg-elevated);border-radius:var(--radius-sm);gap:10px;display:flex;align-items:center;justify-content:center;min-height:60px;border:1px solid var(--border)}.file-name{font-size:13px;color:var(--text-secondary);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.last-note-info{padding:8px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:13px;border:1px solid var(--border)}.last-note-info .note-name{font-weight:700;color:var(--accent)}.last-note-info .note-details{color:var(--text-secondary);margin-left:8px}.duration-control{display:flex;gap:8px;flex-direction:row;margin-right:0}.duration-control label{font-size:13px;color:var(--text-secondary);white-space:nowrap;font-weight:500}.midi-device-selector{padding:7px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);min-width:100px;font-size:13px;transition:all var(--transition)}.midi-device-selector:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #35b8e01a}.midi-device-selector:hover{border-color:var(--border-light)}.audio-controls{display:flex;flex-wrap:wrap;align-items:flex-start;gap:25px;margin-bottom:12px;margin-top:12px;padding:20px;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.knob-control{display:flex;flex-direction:column;align-items:center;min-width:80px}.knob-label{font-size:12px;color:var(--text-secondary);margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.knob{position:relative;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#ffffff,#f0f0f5);border:2px solid #d0d0e0;box-shadow:0 4px 12px #00000014,inset 0 1px 2px #ffffffe6;cursor:ns-resize;display:flex;align-items:center;justify-content:center;transition:all var(--transition);user-select:none}.knob:hover{border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow),inset 0 1px 2px #ffffffe6}.knob:active{transform:scale(.95)}.knob:before{content:"";position:absolute;top:4px;left:4px;right:4px;bottom:4px;border-radius:50%;background:linear-gradient(135deg,#ffffff,#f8f8fc);box-shadow:inset 0 2px 4px #0000000a}.knob:after{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border-radius:50%;border:1px solid rgba(255,255,255,.6)}.knob-mark{position:absolute;top:6px;left:50%;width:6px;height:6px;margin-left:-3px;background:var(--accent);border-radius:50%;transform-origin:center 20px;box-shadow:0 0 6px var(--accent-glow),0 0 12px var(--accent-glow);z-index:2}.metro-fader{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px}.metro-btn{font-size:20px;color:var(--text-secondary);margin-bottom:2px;cursor:pointer}.metro-btn:before,.metro-btn:after{display:none}.metro-btn:hover{border-color:var(--accent);color:var(--accent)}.metro-btn.metro-active{background:linear-gradient(135deg,var(--accent),#2d9dc5);border-color:var(--accent);color:#fff}.fader-track{position:relative;width:8px;height:52px;background:#e2e2ec;border-radius:4px;cursor:pointer;overflow:hidden}.fader-fill{position:absolute;bottom:0;width:100%;background:var(--accent);border-radius:4px;transition:height .05s linear}.fader-thumb{position:absolute;left:50%;transform:translate(-50%,50%);width:18px;height:10px;background:#fff;border:2px solid var(--accent);border-radius:3px;box-shadow:0 1px 4px #00000026;pointer-events:none}.knob-divider{width:1px;background:var(--border);align-self:stretch;margin:4px 2px}.knob-value{margin-top:8px;font-size:12px;font-weight:700;color:var(--accent)}.mute-button{margin-top:5px;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:16px;transition:color var(--transition)}.mute-button:hover{color:var(--accent)}.playback-controls{display:flex;gap:10px;flex-direction:column;align-items:center;justify-content:center}.control-button{padding:10px 22px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all var(--transition);letter-spacing:.3px}.play-button{background:linear-gradient(135deg,var(--success),#00a381);color:#fff;box-shadow:0 2px 12px #00b89440}.play-button:hover:not(:disabled){background:linear-gradient(135deg,#00d2a8,var(--success));box-shadow:0 4px 20px #00b89466;transform:translateY(-2px)}.play-button:disabled{background:#d0d0e0;color:#999;cursor:not-allowed;box-shadow:none}.stop-button{background:linear-gradient(135deg,var(--danger),#d35400);color:#fff;box-shadow:0 2px 12px #e1705540}.stop-button:hover:not(:disabled){background:linear-gradient(135deg,#eb8168,var(--danger));box-shadow:0 4px 20px #e1705566;transform:translateY(-2px)}.stop-button:disabled{background:#d0d0e0;color:#999;cursor:not-allowed;box-shadow:none}.play-bar,.record-bar{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:12px;margin-top:12px;min-height:72px}.record-left{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:56px}.record-right{display:flex;flex-direction:column;align-items:center;gap:4px}.record-btn{width:42px;height:42px;border-radius:50%;border:2px solid #d0d0e0;background:linear-gradient(135deg,#ffffff,#f0f0f5);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);box-shadow:0 4px 12px #00000014,inset 0 1px 2px #ffffffe6;color:var(--accent);flex-shrink:0}.record-btn:hover:not(:disabled){border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow),inset 0 1px 2px #ffffffe6;transform:translateY(-1px)}.record-btn:active{transform:scale(.95)}.record-btn.metro-active{background:linear-gradient(135deg,var(--accent),#2d9dc5);border-color:var(--accent);color:#fff;animation:metroPulse .6s ease-in-out infinite}.record-btn.playing{background:linear-gradient(135deg,var(--success),#00a381);border-color:var(--success);color:#fff}.record-btn:disabled{background:#d0d0e0;color:#999;cursor:not-allowed;box-shadow:none}.record-btn.recording{background:linear-gradient(135deg,var(--danger),#d35400);border-color:var(--danger);color:#fff;animation:recordPulse 1.2s ease-in-out infinite}.record-bar .knob-value{font-size:10px;font-weight:700;color:var(--text-muted);text-align:center;white-space:nowrap}.record-bar .knob-value.recording{color:var(--danger)!important}.wave-canvas{flex:1;height:70px;background:#f5f5fa;border-radius:6px;border:1px solid var(--border);cursor:pointer}.recording-list{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:12px;margin-top:6px;padding:12px 16px}.recording-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.recording-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;transition:background var(--transition)}.recording-item:hover{background:var(--bg-elevated)}.recording-item.active{background:rgba(53,184,224,.08)}.rec-name{flex:1;font-size:13px;color:var(--text-primary);font-weight:500}.rec-duration{font-size:12px;color:var(--text-muted);font-family:JetBrains Mono,monospace}.rec-play-btn,.rec-dl-btn,.rec-del-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-input);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all var(--transition);color:var(--text-secondary)}.rec-play-btn:hover{border-color:var(--accent);color:var(--accent)}.rec-play-btn.playing{background:var(--accent);color:#fff;border-color:var(--accent)}.rec-dl-btn:hover{border-color:var(--accent);color:var(--accent)}.rec-del-btn:hover{border-color:var(--danger);color:var(--danger)}@keyframes recordPulse{0%,to{box-shadow:0 0 #e1705566}50%{box-shadow:0 0 0 10px #e1705500}}@keyframes metroPulse{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 10px #35b8e000}}.player-container{margin-top:12px;margin-bottom:12px}.preview-container{color:var(--text-primary);display:flex;min-width:160px;flex:1;flex-direction:column;flex-wrap:nowrap;justify-content:center}.preview-canvas{width:100%;height:78px;background-color:#f5f5fa;border-radius:var(--radius-sm);cursor:pointer;touch-action:none;border:1px solid var(--border)}.time-display{display:flex;justify-content:space-between;margin-top:6px;font-size:12px;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.load-container{display:flex;flex-direction:column;gap:12px;padding:20px;background:var(--bg-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:12px;margin-top:12px}.track-controls{margin:20px 0;padding:15px;background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.track-control-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.track-control-header h3{margin:0;font-size:16px;color:var(--text-primary)}.track-control-actions{display:flex;gap:10px}.track-control-button{padding:5px 10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;color:var(--text-secondary);transition:all var(--transition)}.track-control-button:hover{background:var(--bg-elevated);border-color:var(--accent)}.track-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.track-item{padding:8px;background:var(--bg-surface);border-radius:var(--radius-sm);border:1px solid var(--border)}.track-toggle{display:flex;align-items:center;cursor:pointer;font-size:14px}.track-toggle input{margin-right:8px}.track-name{font-weight:700;margin-right:8px;color:var(--text-primary)}.track-instrument{flex-grow:1;color:var(--text-secondary);font-size:12px}.track-note-count{color:var(--text-muted);font-size:11px}@media (max-width: 768px){.container{padding:0}.controls-row{flex-direction:column;align-items:stretch;gap:8px}.midi-file-selector{width:100%;flex-wrap:wrap}.midi-device-selector{min-width:auto;flex:1}.midi-info-row{flex-wrap:wrap}.audio-controls{flex-wrap:wrap;gap:12px;padding:12px}.knob-control{flex:1 1 auto;min-width:70px}.knob{width:42px;height:42px}.control-button{padding:6px 12px;font-size:12px}.record-bar{flex-direction:column;align-items:stretch;gap:8px;padding:10px 14px;min-height:auto}.record-left{flex-direction:row;gap:8px}.wave-canvas{height:64px}.preview-canvas{height:58px}.time-display{font-size:13px}}@media (max-width: 480px){.controls-row,.midi-file-selector{gap:6px}.midi-device-selector{font-size:12px;padding:6px 8px}.file-upload-button{font-size:12px;padding:6px 14px}.audio-controls{gap:8px;padding:10px}.knob{width:36px;height:36px}.knob-label,.knob-value{font-size:10px}.playback-controls{gap:6px}.control-button{padding:5px 10px;font-size:11px;border-radius:6px}.record-btn{width:38px;height:38px}.wave-canvas{height:48px}.recording-list{padding:8px 12px}.rec-name{font-size:12px}.rec-play-btn,.rec-dl-btn,.rec-del-btn{width:24px;height:24px;font-size:10px}.duration-control{flex-wrap:wrap;gap:4px}.duration-control label{font-size:11px}.duration-control .midi-device-selector{min-width:auto}.hold-toggle-label{font-size:10px!important}.toggle-switch.small{width:30px;height:16px}.toggle-switch.small .toggle-knob{width:12px;height:12px}.toggle-switch.small.active .toggle-knob{transform:translate(14px)}}#app{font-family:Segoe UI,system-ui,-apple-system,sans-serif;max-width:1440px;margin:0 auto;padding:24px 12px;position:relative;z-index:1}@media (max-width: 768px){#app{padding:12px 8px}}@media (max-width: 480px){#app{padding:8px 4px;font-size:13px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f0f0f5;border-radius:3px}::-webkit-scrollbar-thumb{background:#c0c0d0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::selection{background:var(--accent);color:#fff}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239e9eb0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px!important}.midi-connector{display:flex;flex-direction:column;gap:15px;padding:20px;background:#ffffff;border-radius:14px;box-shadow:0 2px 10px #0000000f;border:1px solid #e2e2ec}.connection-toggle-container{display:flex;align-items:center;gap:10px}.toggle-label{font-size:13px;font-weight:600;color:#2d2d3a;text-transform:uppercase;letter-spacing:.5px}.toggle-switch{position:relative;width:80px;height:28px;background:#e8e8f0;border-radius:14px;border:1px solid #d0d0e0;box-shadow:inset 0 1px 3px #0000001a;cursor:pointer;transition:all .25s;overflow:hidden}.toggle-switch.active{background:linear-gradient(135deg,#35b8e0,#2d9dc5);border-color:#35b8e0;box-shadow:0 0 14px #35b8e040}.toggle-knob{position:absolute;left:3px;top:3px;width:20px;height:20px;background:linear-gradient(135deg,#fff,#f0f0f5);border-radius:50%;box-shadow:0 2px 6px #00000026;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:2}.toggle-switch.active .toggle-knob{transform:translate(52px)}.toggle-status{position:absolute;width:100%;text-align:center;font-size:10px;font-weight:600;color:#6b6b80;transition:color .25s;z-index:1;line-height:28px}.toggle-switch.active .toggle-status{color:#fff}.connection-status-text{margin-left:10px;font-size:13px;color:#6b6b80}.no-device-alert{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 14px;background:#fff8e6;border-radius:8px;border:1px solid #ffd700;font-size:13px;color:#e67e22}.device-control-area{display:flex;flex-direction:column;gap:12px;padding:14px;background:#f8f9fb;border-radius:8px;border:1px solid #e2e2ec}.device-selection-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.device-group{display:flex;align-items:center;gap:8px;flex:1;min-width:200px}.midi-device-selector{padding:8px 12px;border-radius:8px;border:1px solid #e2e2ec;background:#ffffff;color:#2d2d3a;min-width:160px;flex:1;font-size:13px}.midi-channel-selector{padding:8px 10px;border-radius:8px;border:1px solid #e2e2ec;background:#ffffff;color:#2d2d3a;width:65px;font-size:13px}.channel-label{font-size:11px;color:#9e9eb0;margin-right:6px;font-weight:600}.no-devices{font-size:13px;color:#9e9eb0;padding:0 8px}.error-message{color:#e17055;font-size:13px;padding:10px 14px;background:#fff0f0;border-radius:8px;border:1px solid #ffd0d0}.last-note-info{margin-top:8px;padding:10px 14px;background:#f8f9fb;border-radius:8px;font-size:13px;border:1px solid #e2e2ec}.toggle-container{display:flex;align-items:center;margin-left:12px}.toggle-container .toggle-label{font-size:11px;color:#9e9eb0;margin-right:6px;font-weight:600}.toggle-container .toggle-switch.small{width:36px;height:18px;border-radius:9px}.toggle-container .toggle-switch.small .toggle-knob{width:14px;height:14px;top:1px;left:1px}.toggle-container .toggle-switch.small.active .toggle-knob{transform:translate(18px)}.mapping-status{margin-left:6px;font-size:11px;color:var(--accent);font-weight:600}.shift-selector-container{display:flex;align-items:center;margin-left:8px}.shift-selector-container label{margin-right:5px;font-size:11px;color:#9e9eb0;font-weight:600}.semitone-shift-selector{padding:5px 8px;border-radius:8px;border:1px solid #e2e2ec;background:#ffffff;color:#2d2d3a;font-size:12px;min-width:60px}.device-status-indicator{margin-left:10px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;background-color:#00b894;color:#fff}.device-status-indicator.disconnected{background-color:#e17055}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}
