.log-viewer-overlay[data-v-d69189ee]{position:fixed;inset:0;width:100vw;height:100vh;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:9999;padding:40px 20px;box-sizing:border-box;overflow-y:auto}.log-viewer[data-v-d69189ee]{width:100%;max-width:1200px;height:80vh;max-height:80vh;background:#141414;border:1px solid rgba(255,255,255,.1);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #00000080}.header[data-v-d69189ee]{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.header .title-section[data-v-d69189ee]{display:flex;align-items:center;gap:12px;color:#fff}.header .title-section svg[data-v-d69189ee]{color:#42b883}.header .title-section h2[data-v-d69189ee]{margin:0;font-size:1.25rem;font-weight:500;letter-spacing:.5px}.header .title-section .log-count[data-v-d69189ee]{font-size:.85rem;color:#fff6;background:#ffffff0d;padding:4px 10px;border-radius:12px;font-family:monospace}.header .header-actions[data-v-d69189ee]{display:flex;align-items:center;gap:12px}.action-btn[data-v-d69189ee]{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#ffffffb3;padding:8px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.action-btn[data-v-d69189ee]:hover{background:#ffffff1a;color:#fff;border-color:#fff3}.auto-scroll-toggle[data-v-d69189ee]{display:flex;align-items:center;gap:8px;color:#ffffffb3;font-size:.9rem;cursor:pointer;-webkit-user-select:none;user-select:none}.auto-scroll-toggle input[type=checkbox][data-v-d69189ee]{cursor:pointer;width:16px;height:16px;accent-color:#42b883}.auto-scroll-toggle[data-v-d69189ee]:hover{color:#fff}.close-btn[data-v-d69189ee]{background:transparent;border:none;color:#fff9;cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn[data-v-d69189ee]:hover{background:#ffffff1a;color:#fff}.logs-container[data-v-d69189ee]{flex:1;overflow-y:auto;padding:16px;background:#0a0a0a;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9rem}.logs-container[data-v-d69189ee]::-webkit-scrollbar{width:8px}.logs-container[data-v-d69189ee]::-webkit-scrollbar-track{background:#ffffff05}.logs-container[data-v-d69189ee]::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.logs-container[data-v-d69189ee]::-webkit-scrollbar-thumb:hover{background:#fff3}.empty-state[data-v-d69189ee]{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#ffffff4d;gap:12px}.empty-state svg[data-v-d69189ee]{opacity:.3}.empty-state p[data-v-d69189ee]{margin:0;font-size:1.1rem;font-weight:500}.empty-state span[data-v-d69189ee]{font-size:.9rem;opacity:.7}.log-entry[data-v-d69189ee]{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;margin-bottom:4px;border-radius:6px;border-left:3px solid transparent;transition:background .15s}.log-entry[data-v-d69189ee]:hover{background:#ffffff08}.log-entry.log[data-v-d69189ee]{border-left-color:#42b883}.log-entry.log .log-type-badge[data-v-d69189ee]{background:#42b88326;color:#42b883}.log-entry.warn[data-v-d69189ee]{border-left-color:#f39c12}.log-entry.warn .log-type-badge[data-v-d69189ee]{background:#f39c1226;color:#f39c12}.log-entry.error[data-v-d69189ee]{border-left-color:#e74c3c}.log-entry.error .log-type-badge[data-v-d69189ee]{background:#e74c3c26;color:#e74c3c}.log-entry.latency[data-v-d69189ee]{border-left-color:#3498db}.log-entry.latency .log-type-badge[data-v-d69189ee]{background:#3498db26;color:#3498db}.log-entry .timestamp[data-v-d69189ee]{color:#fff6;font-size:.8rem;min-width:90px;flex-shrink:0}.log-entry .log-type-badge[data-v-d69189ee]{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:4px;min-width:60px;text-align:center;flex-shrink:0}.log-entry .log-message[data-v-d69189ee]{color:#ffffffd9;white-space:pre-wrap;word-break:break-word;flex:1;line-height:1.5}@media(max-width:768px){.log-viewer-overlay[data-v-d69189ee]{padding:20px 10px}.log-viewer[data-v-d69189ee]{height:85vh;max-height:85vh;border-radius:12px}.header[data-v-d69189ee]{padding:16px;flex-wrap:wrap;gap:12px}.header .title-section h2[data-v-d69189ee]{font-size:1.1rem}.log-entry[data-v-d69189ee]{flex-direction:column;gap:6px}.log-entry .timestamp[data-v-d69189ee]{min-width:auto}}.modal-fade-enter-active[data-v-a102ec80],.modal-fade-leave-active[data-v-a102ec80]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-a102ec80],.modal-fade-leave-to[data-v-a102ec80]{opacity:0}.modal-overlay[data-v-a102ec80]{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content[data-v-a102ec80]{background:#14141ef2;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:40px 60px;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:0 20px 60px #00000080}.spinner[data-v-a102ec80]{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#fff;border-radius:50%;animation:spin-a102ec80 1s linear infinite}@keyframes spin-a102ec80{to{transform:rotate(360deg)}}.loading-text[data-v-a102ec80]{color:#fff;font-size:1.1rem;font-weight:500;letter-spacing:.5px}.show-ui-btn-wrapper[data-v-335ebe2f]{position:fixed;z-index:90;transform:translate(0) rotate(0);transition:transform .5s cubic-bezier(.2,.8,.2,1),opacity .3s ease}.show-ui-btn-wrapper.idle[data-v-335ebe2f]{opacity:.5}.show-ui-btn-wrapper.idle.left[data-v-335ebe2f]{transform:translate(-100%) rotate(-90deg)}.show-ui-btn-wrapper.idle.right[data-v-335ebe2f]{transform:translate(100%) rotate(90deg)}@media(hover:hover){.show-ui-btn-wrapper.idle[data-v-335ebe2f]:hover{transform:translate(0) rotate(0);opacity:1}}.show-ui-btn-wrapper.dragging[data-v-335ebe2f]{transition:opacity .3s ease;transform:scale(1.1);cursor:grabbing}.show-ui-btn-inner[data-v-335ebe2f]{width:44px;height:44px;border-radius:50%;background:#323232e6;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:grab;display:flex;justify-content:center;align-items:center;transition:all .3s;box-shadow:0 4px 15px #0000004d;-webkit-tap-highlight-color:transparent}.show-ui-btn-inner[data-v-335ebe2f]:active{cursor:grabbing;background:#ffffff4d;transform:scale(.95)}@media(hover:hover){.show-ui-btn-inner[data-v-335ebe2f]:hover{background:#ffffff40;transform:scale(1.05)}}.fullscreen-btn[data-v-335ebe2f]{margin-right:10px}.top-bar[data-v-335ebe2f]{position:absolute;top:0;left:0;width:100%;height:80px;display:flex;justify-content:space-between;align-items:center;padding:0 30px;background:#141414f2;border-bottom:1px solid rgba(255,255,255,.05);transition:transform .4s cubic-bezier(.16,1,.3,1);z-index:100;box-sizing:border-box}.top-bar.hidden[data-v-335ebe2f]{transform:translateY(-100%)}.group[data-v-335ebe2f]{display:flex;align-items:center;gap:20px;flex:1}.group.left[data-v-335ebe2f]{justify-content:flex-start}.group.center[data-v-335ebe2f]{justify-content:center}.group.right[data-v-335ebe2f]{justify-content:flex-end}.control-group[data-v-335ebe2f]{display:flex;gap:10px;background:#0000004d;padding:5px;border-radius:12px}.text-btn[data-v-335ebe2f]{background:transparent;border:none;color:#ffffffb3;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s;-webkit-tap-highlight-color:transparent}.text-btn[data-v-335ebe2f]:active{background:#ffffff26;color:#fff;transform:scale(.95)}@media(hover:hover){.text-btn[data-v-335ebe2f]:hover{background:#ffffff1a;color:#fff}}.pitch-control[data-v-335ebe2f]{display:flex;align-items:center;background:#0000004d;border-radius:12px;padding:5px}.pitch-control button[data-v-335ebe2f]{width:32px;height:32px;border:none;background:#ffffff1a;color:#fff;border-radius:8px;cursor:pointer;display:flex;justify-content:center;align-items:center;font-size:1.2rem;transition:all .2s;-webkit-tap-highlight-color:transparent}.pitch-control button[data-v-335ebe2f]:disabled{opacity:.3;cursor:not-allowed}.pitch-control button[data-v-335ebe2f]:not(:disabled):active{background:#ffffff40;transform:scale(.9)}@media(hover:hover){.pitch-control button[data-v-335ebe2f]:not(:disabled):hover{background:#fff3}}.pitch-control .octave-label[data-v-335ebe2f]{color:#fff;margin:0 15px;font-family:monospace;font-weight:700;letter-spacing:1px;min-width:50px;text-align:center}.volume-slider[data-v-335ebe2f]{display:flex;align-items:center;gap:10px;color:#fff9;background:#0000004d;padding:8px 15px;border-radius:20px}.volume-slider input[type=range][data-v-335ebe2f]{width:100px;height:4px;background:#fff3;border-radius:2px;outline:none;appearance:none;-webkit-appearance:none}.volume-slider input[type=range][data-v-335ebe2f]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer;transition:transform .2s}.volume-slider input[type=range][data-v-335ebe2f]::-webkit-slider-thumb:hover{transform:scale(1.2)}.icon-btn[data-v-335ebe2f]{background:transparent;border:none;color:#fffc;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;-webkit-tap-highlight-color:transparent}.icon-btn[data-v-335ebe2f]:active{background:#ffffff26;color:#fff;transform:scale(.9)}@media(hover:hover){.icon-btn[data-v-335ebe2f]:hover{background:#ffffff1a;color:#fff}}@media(max-width:768px){.top-bar[data-v-335ebe2f]{padding:0 15px;height:70px}.text-btn span[data-v-335ebe2f]{display:none}.text-btn[data-v-335ebe2f]:after{content:"Load";font-size:.8rem}.text-btn[data-v-335ebe2f]:nth-child(2):after{content:"Tut"}.pitch-control .octave-label[data-v-335ebe2f]{margin:0 5px;min-width:40px}.volume-slider[data-v-335ebe2f]{display:none}}.loading-screen[data-v-22df8f2c]{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-background, #1a1a1a);display:flex;justify-content:center;align-items:center;z-index:100;color:#fff}.content[data-v-22df8f2c]{text-align:center;width:300px}.progress-bar[data-v-22df8f2c]{height:6px;background:#333;border-radius:3px;margin-top:20px;width:100%;overflow:hidden}.progress-fill[data-v-22df8f2c]{height:100%;background:#42b883;transition:width .3s ease}.error-msg[data-v-22df8f2c]{color:#ff4d4f;margin:10px 0}.hint[data-v-22df8f2c]{opacity:.5;font-size:12px;margin-top:20px}.buttons[data-v-22df8f2c]{display:flex;gap:10px;justify-content:center;margin-top:15px}.buttons button[data-v-22df8f2c]{padding:8px 16px;background:#42b883;color:#fff;border:none;border-radius:4px;cursor:pointer}.buttons button[data-v-22df8f2c]:hover{opacity:.9}.buttons button.warning[data-v-22df8f2c]{background:#ff4d4f}.start-overlay[data-v-19ab93d0]{position:fixed;inset:0;background:#000000f2;z-index:9999;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:opacity .5s ease;-webkit-user-select:none;user-select:none}.start-overlay.fading-out[data-v-19ab93d0]{opacity:0;pointer-events:none}.start-overlay .content[data-v-19ab93d0]{text-align:center;color:#fff;animation:pulse-19ab93d0 2s infinite ease-in-out}.start-overlay .content .icon[data-v-19ab93d0]{font-size:4rem;margin-bottom:20px}.start-overlay .content h1[data-v-19ab93d0]{font-size:2rem;margin:0 0 10px;font-weight:300;letter-spacing:2px}.start-overlay .content p[data-v-19ab93d0]{opacity:.7;margin:0}@keyframes pulse-19ab93d0{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}html,body,#app{width:100%;height:100%;margin:0;padding:0;overflow:hidden;background:var(--color-background, #1a1a1a);color:var(--color-text, #ffffff);font-family:Inter,sans-serif;user-select:none;-webkit-user-select:none}.app-container{width:100%;height:100%;display:flex;flex-direction:column}@media screen and (orientation:portrait){.app-container:after{content:"Please rotate your device for the best experience";position:fixed;inset:0;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:9999;padding:20px;text-align:center;color:#fff}}.piano-key[data-v-d0252455]{flex:1 1 0;min-width:0;min-height:0;border:none;background:#ffffff14;border-radius:16px;cursor:pointer;position:relative;overflow:hidden;transition:all .1s cubic-bezier(.4,0,.2,1);color:#ffffffe6;box-shadow:0 4px 6px #0003,inset 0 1px #ffffff1a;-webkit-tap-highlight-color:transparent}.piano-key[data-v-d0252455]:active,.piano-key.active-touch[data-v-d0252455]{transform:scale(.96);background:#ffffff26}.piano-key.highlight[data-v-d0252455]{background:#42b8834d;border:2px solid rgba(66,184,131,.8)}.piano-key.highlight .jianpu-icon[data-v-d0252455]{color:#42b883}.key-inner[data-v-d0252455]{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:2}.jianpu-icon[data-v-d0252455]{width:60%;height:60%;display:block;color:inherit;transition:color .2s}.piano-grid[data-v-ab4fc0dc]{flex:1;display:flex;flex-direction:column;padding:20px;gap:12px;margin:0 auto;width:100%;max-height:100%;box-sizing:border-box;transition:padding-top .4s cubic-bezier(.16,1,.3,1)}body.topbar-visible{max-height:calc(100% - 80px);padding-top:80px}.grid-row[data-v-ab4fc0dc]{flex:1;display:flex;gap:12px;align-items:center;justify-content:center}.layout-fill .grid-row[data-v-ab4fc0dc]{align-items:stretch}.layout-square-gap .grid-row[data-v-ab4fc0dc]{align-items:center;justify-content:center}.layout-square-gap[data-v-ab4fc0dc] .piano-key{aspect-ratio:1 / 1}.layout-square-center[data-v-ab4fc0dc]{justify-content:center}.layout-square-center .grid-row[data-v-ab4fc0dc]{flex:0;align-items:center;justify-content:center}.layout-square-center[data-v-ab4fc0dc] .piano-key{aspect-ratio:1 / 1}.piano-view[data-v-647c13a1]{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden}.settings-page[data-v-134d0c4f]{position:absolute;inset:0;background:radial-gradient(circle at center,#2a2a2a,#111);color:#fff;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:40px;box-sizing:border-box;z-index:1000}.settings-container[data-v-134d0c4f]{max-width:800px;margin:0 auto}.header[data-v-134d0c4f]{display:flex;align-items:center;gap:20px;margin-bottom:50px}.header h1[data-v-134d0c4f]{font-size:2rem;font-weight:300;margin:0;letter-spacing:2px}.back-btn[data-v-134d0c4f]{background:#ffffff1a;border:none;color:#fff;padding:10px 20px;border-radius:30px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.back-btn[data-v-134d0c4f]:hover{background:#fff3;transform:translate(-5px)}.setting-section[data-v-134d0c4f]{margin-bottom:40px}.setting-section h2[data-v-134d0c4f]{font-size:1rem;text-transform:uppercase;letter-spacing:1.5px;color:#fff6;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px;margin-bottom:20px}.setting-row[data-v-134d0c4f]{display:flex;justify-content:space-between;align-items:center;background:#ffffff08;padding:20px;border-radius:12px;margin-bottom:15px;transition:background .2s}.setting-row[data-v-134d0c4f]:hover{background:#ffffff0d}.setting-label h3[data-v-134d0c4f]{margin:0 0 5px;font-size:1.1rem;font-weight:500}.setting-label p[data-v-134d0c4f]{margin:0;font-size:.9rem;color:#ffffff80}.toggle-switch[data-v-134d0c4f]{display:inline-block;width:56px;height:32px;position:relative}.toggle-switch input[data-v-134d0c4f]{opacity:0;width:0;height:0}.toggle-switch .slider[data-v-134d0c4f]{position:absolute;cursor:pointer;inset:0;background-color:#ffffff1a;transition:.4s cubic-bezier(.2,.8,.2,1);border-radius:34px;border:1px solid rgba(255,255,255,.1)}.toggle-switch .slider[data-v-134d0c4f]:before{position:absolute;content:"";height:24px;width:24px;left:3px;bottom:3px;background-color:#fffc;transition:.4s cubic-bezier(.2,.8,.2,1);border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.slider[data-v-134d0c4f]{background-color:#42b883;border-color:#42b883}.toggle-switch input:checked+.slider[data-v-134d0c4f]:before{transform:translate(24px);background-color:#fff}.toggle-switch.disabled[data-v-134d0c4f]{opacity:.5;cursor:not-allowed}.toggle-switch.disabled .slider[data-v-134d0c4f]{cursor:not-allowed}.select-input[data-v-134d0c4f]{background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:8px 16px;border-radius:8px;font-size:1rem;cursor:pointer;outline:none}.select-input option[data-v-134d0c4f]{background:#222;color:#fff}.setting-controls-group[data-v-134d0c4f]{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.custom-buffer-row[data-v-134d0c4f]{display:flex;gap:10px;align-items:center}.text-input[data-v-134d0c4f]{background:#0000004d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:8px 12px;border-radius:6px;width:80px;outline:none}.text-input[data-v-134d0c4f]:focus{border-color:#42b883}.action-btn[data-v-134d0c4f]{border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.action-btn.small[data-v-134d0c4f]{padding:6px 12px;font-size:.9rem;background:#42b883;color:#fff}.action-btn.small[data-v-134d0c4f]:hover{background:#3aa876;transform:translateY(-1px)}.action-btn.primary[data-v-134d0c4f]{background:#42b883;color:#fff;padding:10px 20px;font-size:1rem}.action-btn.primary[data-v-134d0c4f]:hover{background:#3aa876}.action-btn.secondary[data-v-134d0c4f]{background:#ffffff1a;color:#ddd;padding:10px 20px;font-size:1rem}.action-btn.secondary[data-v-134d0c4f]:hover{background:#fff3;color:#fff}.error-text[data-v-134d0c4f]{color:#ff4757;font-size:.8rem;margin:0;max-width:200px;text-align:right}.warning-text[data-v-134d0c4f]{color:#ffa502;font-size:.9rem}.about-card[data-v-134d0c4f]{text-align:center;padding:20px;background:#ffffff0d;border-radius:8px;color:#888}.about-card p[data-v-134d0c4f]{margin:5px 0}.about-card .sub[data-v-134d0c4f]{font-size:.85rem}.modal-overlay[data-v-134d0c4f]{position:fixed;inset:0;background:#000000e6;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.modal-card[data-v-134d0c4f]{background:#2a2a2a;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;width:100%;max-width:400px;box-shadow:0 10px 25px #00000080;text-align:center}.modal-card h3[data-v-134d0c4f]{margin:0 0 12px;color:#fff;font-size:1.25rem}.modal-card p[data-v-134d0c4f]{color:#aaa;margin:0 0 24px;line-height:1.5}.modal-actions[data-v-134d0c4f]{display:flex;gap:12px;justify-content:flex-end}.backend-tag[data-v-134d0c4f]{background:#ffffff1a;color:#42b883;padding:6px 12px;border-radius:6px;font-family:monospace;font-size:.9rem;font-weight:700}
