.log-viewer-overlay[data-v-bf431b92]{position:fixed;inset:0;width:100vw;height:100vh;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);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-bf431b92]{width:100%;max-width:1200px;height:80vh;max-height:80vh;background:#141414f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);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-bf431b92]{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-bf431b92]{display:flex;align-items:center;gap:12px;color:#fff}.header .title-section svg[data-v-bf431b92]{color:#42b883}.header .title-section h2[data-v-bf431b92]{margin:0;font-size:1.25rem;font-weight:500;letter-spacing:.5px}.header .title-section .log-count[data-v-bf431b92]{font-size:.85rem;color:#fff6;background:#ffffff0d;padding:4px 10px;border-radius:12px;font-family:monospace}.header .header-actions[data-v-bf431b92]{display:flex;align-items:center;gap:12px}.action-btn[data-v-bf431b92]{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-bf431b92]:hover{background:#ffffff1a;color:#fff;border-color:#fff3}.auto-scroll-toggle[data-v-bf431b92]{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-bf431b92]{cursor:pointer;width:16px;height:16px;accent-color:#42b883}.auto-scroll-toggle[data-v-bf431b92]:hover{color:#fff}.close-btn[data-v-bf431b92]{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-bf431b92]:hover{background:#ffffff1a;color:#fff}.logs-container[data-v-bf431b92]{flex:1;overflow-y:auto;padding:16px;background:#0a0a0a;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9rem}.logs-container[data-v-bf431b92]::-webkit-scrollbar{width:8px}.logs-container[data-v-bf431b92]::-webkit-scrollbar-track{background:#ffffff05}.logs-container[data-v-bf431b92]::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.logs-container[data-v-bf431b92]::-webkit-scrollbar-thumb:hover{background:#fff3}.empty-state[data-v-bf431b92]{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#ffffff4d;gap:12px}.empty-state svg[data-v-bf431b92]{opacity:.3}.empty-state p[data-v-bf431b92]{margin:0;font-size:1.1rem;font-weight:500}.empty-state span[data-v-bf431b92]{font-size:.9rem;opacity:.7}.log-entry[data-v-bf431b92]{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-bf431b92]:hover{background:#ffffff08}.log-entry.log[data-v-bf431b92]{border-left-color:#42b883}.log-entry.log .log-type-badge[data-v-bf431b92]{background:#42b88326;color:#42b883}.log-entry.warn[data-v-bf431b92]{border-left-color:#f39c12}.log-entry.warn .log-type-badge[data-v-bf431b92]{background:#f39c1226;color:#f39c12}.log-entry.error[data-v-bf431b92]{border-left-color:#e74c3c}.log-entry.error .log-type-badge[data-v-bf431b92]{background:#e74c3c26;color:#e74c3c}.log-entry.latency[data-v-bf431b92]{border-left-color:#3498db}.log-entry.latency .log-type-badge[data-v-bf431b92]{background:#3498db26;color:#3498db}.log-entry .timestamp[data-v-bf431b92]{color:#fff6;font-size:.8rem;min-width:90px;flex-shrink:0}.log-entry .log-type-badge[data-v-bf431b92]{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-bf431b92]{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-bf431b92]{padding:20px 10px}.log-viewer[data-v-bf431b92]{height:85vh;max-height:85vh;border-radius:12px}.header[data-v-bf431b92]{padding:16px;flex-wrap:wrap;gap:12px}.header .title-section h2[data-v-bf431b92]{font-size:1.1rem}.log-entry[data-v-bf431b92]{flex-direction:column;gap:6px}.log-entry .timestamp[data-v-bf431b92]{min-width:auto}}.modal-fade-enter-active[data-v-55f4d0bc],.modal-fade-leave-active[data-v-55f4d0bc]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-55f4d0bc],.modal-fade-leave-to[data-v-55f4d0bc]{opacity:0}.modal-overlay[data-v-55f4d0bc]{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content[data-v-55f4d0bc]{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-55f4d0bc]{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#fff;border-radius:50%;animation:spin-55f4d0bc 1s linear infinite}@keyframes spin-55f4d0bc{to{transform:rotate(360deg)}}.loading-text[data-v-55f4d0bc]{color:#fff;font-size:1.1rem;font-weight:500;letter-spacing:.5px}.show-ui-btn-wrapper[data-v-35b9ca7a]{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-35b9ca7a]{opacity:.5}.show-ui-btn-wrapper.idle.left[data-v-35b9ca7a]{transform:translate(-100%) rotate(-90deg)}.show-ui-btn-wrapper.idle.right[data-v-35b9ca7a]{transform:translate(100%) rotate(90deg)}@media(hover:hover){.show-ui-btn-wrapper.idle[data-v-35b9ca7a]:hover{transform:translate(0) rotate(0);opacity:1}}.show-ui-btn-wrapper.dragging[data-v-35b9ca7a]{transition:opacity .3s ease;transform:scale(1.1);cursor:grabbing}.show-ui-btn-inner[data-v-35b9ca7a]{width:44px;height:44px;border-radius:50%;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);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-35b9ca7a]:active{cursor:grabbing;background:#ffffff4d;transform:scale(.95)}@media(hover:hover){.show-ui-btn-inner[data-v-35b9ca7a]:hover{background:#ffffff40;transform:scale(1.05)}}.fullscreen-btn[data-v-35b9ca7a]{margin-right:10px}.top-bar[data-v-35b9ca7a]{position:absolute;top:0;left:0;width:100%;height:80px;display:flex;justify-content:space-between;align-items:center;padding:0 30px;background:#0006;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);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-35b9ca7a]{transform:translateY(-100%)}.group[data-v-35b9ca7a]{display:flex;align-items:center;gap:20px;flex:1}.group.left[data-v-35b9ca7a]{justify-content:flex-start}.group.center[data-v-35b9ca7a]{justify-content:center}.group.right[data-v-35b9ca7a]{justify-content:flex-end}.control-group[data-v-35b9ca7a]{display:flex;gap:10px;background:#0000004d;padding:5px;border-radius:12px}.text-btn[data-v-35b9ca7a]{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-35b9ca7a]:active{background:#ffffff26;color:#fff;transform:scale(.95)}@media(hover:hover){.text-btn[data-v-35b9ca7a]:hover{background:#ffffff1a;color:#fff}}.pitch-control[data-v-35b9ca7a]{display:flex;align-items:center;background:#0000004d;border-radius:12px;padding:5px}.pitch-control button[data-v-35b9ca7a]{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-35b9ca7a]:disabled{opacity:.3;cursor:not-allowed}.pitch-control button[data-v-35b9ca7a]:not(:disabled):active{background:#ffffff40;transform:scale(.9)}@media(hover:hover){.pitch-control button[data-v-35b9ca7a]:not(:disabled):hover{background:#fff3}}.pitch-control .octave-label[data-v-35b9ca7a]{color:#fff;margin:0 15px;font-family:monospace;font-weight:700;letter-spacing:1px;min-width:50px;text-align:center}.volume-slider[data-v-35b9ca7a]{display:flex;align-items:center;gap:10px;color:#fff9;background:#0000004d;padding:8px 15px;border-radius:20px}.volume-slider input[type=range][data-v-35b9ca7a]{width:100px;height:4px;background:#fff3;border-radius:2px;outline:none;appearance:none;-webkit-appearance:none}.volume-slider input[type=range][data-v-35b9ca7a]::-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-35b9ca7a]::-webkit-slider-thumb:hover{transform:scale(1.2)}.icon-btn[data-v-35b9ca7a]{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-35b9ca7a]:active{background:#ffffff26;color:#fff;transform:scale(.9)}@media(hover:hover){.icon-btn[data-v-35b9ca7a]:hover{background:#ffffff1a;color:#fff}}@media(max-width:768px){.top-bar[data-v-35b9ca7a]{padding:0 15px;height:70px}.text-btn span[data-v-35b9ca7a]{display:none}.text-btn[data-v-35b9ca7a]:after{content:"Load";font-size:.8rem}.text-btn[data-v-35b9ca7a]:nth-child(2):after{content:"Tut"}.pitch-control .octave-label[data-v-35b9ca7a]{margin:0 5px;min-width:40px}.volume-slider[data-v-35b9ca7a]{display:none}}.loading-screen[data-v-cf44c42c]{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-cf44c42c]{text-align:center;width:300px}.progress-bar[data-v-cf44c42c]{height:6px;background:#333;border-radius:3px;margin-top:20px;width:100%;overflow:hidden}.progress-fill[data-v-cf44c42c]{height:100%;background:#42b883;transition:width .3s ease}.error-msg[data-v-cf44c42c]{color:#ff4d4f;margin:10px 0}.hint[data-v-cf44c42c]{opacity:.5;font-size:12px;margin-top:20px}.buttons[data-v-cf44c42c]{display:flex;gap:10px;justify-content:center;margin-top:15px}.buttons button[data-v-cf44c42c]{padding:8px 16px;background:#42b883;color:#fff;border:none;border-radius:4px;cursor:pointer}.buttons button[data-v-cf44c42c]:hover{opacity:.9}.buttons button.warning[data-v-cf44c42c]{background:#ff4d4f}.start-overlay[data-v-1cbb423b]{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);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-1cbb423b]{opacity:0;pointer-events:none}.start-overlay .content[data-v-1cbb423b]{text-align:center;color:#fff;animation:pulse-1cbb423b 2s infinite ease-in-out}.start-overlay .content .icon[data-v-1cbb423b]{font-size:4rem;margin-bottom:20px}.start-overlay .content h1[data-v-1cbb423b]{font-size:2rem;margin:0 0 10px;font-weight:300;letter-spacing:2px}.start-overlay .content p[data-v-1cbb423b]{opacity:.7;margin:0}@keyframes pulse-1cbb423b{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-e7d513e2]{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;touch-action:none;box-shadow:0 4px 6px #0003,inset 0 1px #ffffff1a;-webkit-tap-highlight-color:transparent}.piano-key[data-v-e7d513e2]:active,.piano-key.active-touch[data-v-e7d513e2]{transform:scale(.96);background:#ffffff26;box-shadow:0 2px 4px #0003,inset 0 1px #ffffff0d}.piano-key:active .jianpu-icon[data-v-e7d513e2],.piano-key.active-touch .jianpu-icon[data-v-e7d513e2]{filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}.piano-key.highlight[data-v-e7d513e2]{background:#42b88333;border:2px solid rgba(66,184,131,.8);box-shadow:0 0 20px #42b88366}.piano-key.highlight .jianpu-icon[data-v-e7d513e2]{color:#42b883}.key-inner[data-v-e7d513e2]{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:2;pointer-events:none}.jianpu-icon[data-v-e7d513e2]{width:60%;height:60%;display:block;color:inherit;transition:color .2s}.piano-grid[data-v-967db02c]{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-967db02c]{flex:1;display:flex;gap:12px;align-items:center;justify-content:center}.layout-fill .grid-row[data-v-967db02c]{align-items:stretch}.layout-square-gap .grid-row[data-v-967db02c]{align-items:center;justify-content:center}.layout-square-gap[data-v-967db02c] .piano-key{aspect-ratio:1 / 1}.layout-square-center[data-v-967db02c]{justify-content:center}.layout-square-center .grid-row[data-v-967db02c]{flex:0;align-items:center;justify-content:center}.layout-square-center[data-v-967db02c] .piano-key{aspect-ratio:1 / 1}.piano-view[data-v-647c13a1]{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden}
