*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg);color:var(--text);transition:opacity .2s ease}body{display:flex;flex-direction:column;min-height:100vh}#app{max-width:900px;width:100%;margin:5px auto;padding:0 20px;flex:1;display:flex;flex-direction:column;min-height:calc(100vh - 10px)}.hero{background:var(--surface-hero);border:1px solid var(--border-hero);padding:16px;border-radius:12px;margin-bottom:16px;position:relative}.hero-actions{display:flex;justify-content:flex-end}.offline-banner{position:absolute;top:4px;left:16px;display:inline-flex;align-items:center;justify-content:center;gap:4px;min-width:110px;height:24px;padding:0 12px;border:1px solid color-mix(in srgb,var(--accent) 55%,black);border-radius:999px;background:var(--accent);box-shadow:2px 3px color-mix(in srgb,var(--accent),black 30%);color:rgb(from var(--text) calc(255 - r) calc(255 - g) calc(255 - b));font-family:Tilt Neon,sans-serif;font-size:.6rem;font-weight:500;letter-spacing:.04em;line-height:1;text-align:center;text-decoration:none;text-transform:uppercase;white-space:nowrap}.offline-banner-icon{font-size:13px;line-height:1}.offline-banner:hover,.offline-banner:focus-visible{background:color-mix(in srgb,var(--accent) 86%,white);color:rgb(from var(--text) calc(255 - r) calc(255 - g) calc(255 - b));outline:none}.hero-main{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.hero-title{display:flex;flex-wrap:wrap;align-items:baseline;gap:12px}.hero-title h1{margin:0}.hero-title-neon{font-family:Tilt Neon,sans-serif;font-optical-sizing:auto;font-weight:400;font-style:normal;font-variation-settings:"XROT" 0,"YROT" 0;text-transform:uppercase;letter-spacing:.08em;font-size:clamp(1.6rem,2.5vw,2.4rem);color:var(--title-accent);text-shadow:0 0 12px var(--title-glow),0 0 28px var(--title-glow);animation:neon-flicker 6s infinite}@keyframes neon-flicker{0%,to{opacity:1;text-shadow:0 0 12px var(--title-glow),0 0 28px var(--title-glow)}2%{opacity:.95;text-shadow:0 0 8px var(--title-glow),0 0 22px var(--title-glow)}3%{opacity:.75;text-shadow:0 0 6px var(--title-glow),0 0 14px var(--title-glow)}4%{opacity:1}6%{opacity:.85}7%{opacity:1}12%{opacity:.92}13%{opacity:1}28%{opacity:.88}29%{opacity:1}44%{opacity:.7;text-shadow:0 0 5px var(--title-glow),0 0 12px var(--title-glow)}46%{opacity:1}58%{opacity:.9}59%{opacity:1}76%{opacity:.8;text-shadow:0 0 7px var(--title-glow),0 0 18px var(--title-glow)}77%{opacity:1}89%{opacity:.86}90%{opacity:1}}.theme-toggle{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);position:absolute;top:14px;right:16px}.theme-link.active{color:var(--text);font-weight:700}.theme-sep{color:var(--muted)}.panel{background:var(--surface-panel);border:1px solid var(--border-panel);padding:16px;border-radius:10px;margin-bottom:16px}.site-footer{max-width:900px;width:100%;margin:auto auto 0;text-align:center;color:var(--muted);font-size:.95rem}.site-footer a{color:var(--accent);text-decoration:none;font-weight:600}.site-footer a:hover{text-decoration:underline}.panel-title{font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}.panel-title-row{display:flex;align-items:center;justify-content:flex-start;gap:12px}.favorites-sync{position:relative;display:inline-flex;align-items:center}.favorites-sync-button{background:transparent;border:none;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.favorites-sync-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 28;color:var(--text);font-size:24px;line-height:1}.favorites-sync-menu{position:absolute;top:28px;right:0;min-width:170px;padding:6px;border-radius:12px;border:1px solid var(--border-control);background:var(--surface-panel);box-shadow:0 12px 24px rgba(0,0,0,.24);z-index:10}.favorites-sync-item{width:100%;text-align:left;padding:8px 10px;border-radius:10px;border:none;background:transparent;color:var(--text);font-size:13px;letter-spacing:.01em;cursor:pointer}.favorites-sync-item:hover{background:var(--surface-control)}.subtabs{display:flex;align-items:center;gap:8px;margin-bottom:10px}.subtab-spacer{flex:1}.subtab-btn{padding:6px 12px;border-radius:999px;border:1px solid var(--border-control);background:var(--surface-panel);color:var(--text);font-size:12px;letter-spacing:.02em;cursor:pointer}.subtab-btn.active{background:var(--surface-control)}.faq h3{margin:0 0 6px;font-size:20px}.faq h4{margin:18px 0 6px;font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.faq p{margin:0 0 12px;line-height:1.5}.faq ul{margin:0 0 12px 18px;padding:0}.faq li{margin-bottom:6px}.faq a{color:var(--accent);text-decoration:none;font-weight:600}.faq a:hover{text-decoration:underline}.menu-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 0}.menu-left,.menu-right{display:inline-flex;align-items:center;gap:8px}.hidden{display:none}.tabs{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;margin-bottom:0}.tab-btn{padding:8px 14px;border-radius:999px;border:1px solid var(--border-control);background:var(--surface-panel);color:var(--text);font-size:13px;letter-spacing:.02em}.tab-btn.active{background:var(--surface-control);border-color:var(--border-control);color:var(--text)}.controls .row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:12px}label{display:flex;flex-direction:column;gap:6px;padding-bottom:10px;font-size:14px}.label-line{display:flex;align-items:center;gap:6px}button{padding:8px 14px;border-radius:999px;border:1px solid var(--border-control);background:var(--surface-panel);color:var(--text);font-size:13px;letter-spacing:.02em;cursor:pointer}button:hover{background:var(--surface-control)}.theme-link{background:transparent;border:none;padding:0;font-size:11px;letter-spacing:0;color:var(--muted);cursor:pointer}.modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;background:rgba(10,12,16,.75);z-index:20}.modal.open{display:flex}.modal-panel{width:min(520px,90vw);background:var(--surface-panel);border:1px solid var(--border-panel);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-body{display:flex;flex-direction:column;gap:12px}.modal-hint{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.modal-status{margin:0;font-size:12px;letter-spacing:.01em;color:var(--muted)}.modal-status.error{color:#e35a5a}.info-body{gap:10px}.info-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px}.info-label{color:var(--muted)}.modal-footer{display:flex;justify-content:flex-end}.tuning-footer{justify-content:space-between}.favorites-sync-code{padding:10px 12px;border-radius:10px;border:1px solid var(--border-control);background:var(--surface-control);color:var(--text);font-size:16px;letter-spacing:.06em;text-transform:lowercase}.checkbox-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:13px}.checkbox-row label{display:inline-flex;flex-direction:row;align-items:center;gap:8px}.checkbox-row input[type=checkbox]{margin:0}.top-list{margin:0;padding-left:20px;display:grid;gap:6px;font-size:14px;color:var(--text)}.top-list.hidden{display:none}.favorites-list{padding-left:0;list-style:none}.favorite-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.favorite-row a{color:var(--accent);text-decoration:none;font-weight:600;flex:1}.favorite-row a:hover{text-decoration:underline}.favorite-row .favorite-tune-icon{font-size:14px;line-height:1;vertical-align:middle;color:var(--muted)}.favorite-remove{width:22px;height:22px;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center}.favorite-toggle{background:transparent;border:none;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.favorite-toggle .favorite-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 30;color:var(--beat-fill);font-size:30px;line-height:1}.favorite-toggle.active .favorite-icon{font-variation-settings:"FILL" 1,"wght" 300,"GRAD" 0,"opsz" 30}.copy-toggle,.delete-toggle{background:transparent;border:none;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.delete-toggle.hidden{display:none}.delete-toggle .delete-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 30;color:#e35a5a;font-size:30px;line-height:1}.copy-toggle .copy-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 30;color:var(--text);font-size:30px;line-height:1}.info-toggle{background:transparent;border:none;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.info-toggle .info-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 30;color:var(--text);font-size:30px;line-height:1}.tune-toggle,.play-toggle{background:transparent;border:none;padding:0 6px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.is-hidden{display:none!important}.play-toggle{border:1px solid var(--border-control);border-radius:8px;padding-right:15px}.tab-btn.is-playing{animation:play-tab-pulse 2.4s ease-in-out infinite}@keyframes play-tab-pulse{0%,to{background:var(--surface-panel)}50%{background:rgba(var(--text-rgb),.12)}}.tune-toggle .tune-icon,.play-toggle .play-icon{font-variation-settings:"FILL" 1,"wght" 300,"GRAD" 0,"opsz" 30;color:var(--text);font-size:30px;line-height:1}.play-toggle .play-text{font-size:13px;letter-spacing:.02em}.fullscreen-toggle{background:transparent;border:none;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.fullscreen-toggle .fullscreen-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 30;color:var(--text);font-size:30px;line-height:1}.modal-close{background:transparent;border:none;padding:0;display:inline-flex;align-items:center;justify-content:center}.modal-close .modal-close-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 30;color:var(--text);font-size:30px;line-height:1}.favorite-remove{background:transparent;border:none}.favorite-remove .favorite-remove-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20;color:var(--text);font-size:20px;line-height:1}.top-list a{color:var(--accent);text-decoration:none;font-weight:600}.top-list a:hover{text-decoration:underline}.search-panel{display:grid;gap:12px}.search-panel.hidden{display:none}.search-hint{font-size:13px;color:var(--muted)}.search-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.search-bar .search-input,.controls .search-input{flex:1;min-width:280px}.search-bar button{white-space:nowrap;border-radius:8px;padding:10px 12px;font-size:14px}.toast{position:fixed;right:20px;bottom:20px;padding:10px 14px;border-radius:10px;border:1px solid var(--border-panel);background:var(--surface-panel);color:var(--text);font-size:13px;box-shadow:0 8px 20px rgba(0,0,0,.35);z-index:30}.toast.has-icon{display:flex;align-items:center;gap:6px}.toast.hidden{display:none}.toast-icon{font-variation-settings:"FILL" 1,"wght" 300,"GRAD" 0,"opsz" 20;color:var(--text);font-size:16px;line-height:1}.search-input{background:var(--surface-panel);border:1px solid var(--border-panel);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px}.search-results{min-height:140px;border:1px dashed var(--border-panel);border-radius:10px;padding:12px;color:var(--muted);font-size:13px}.upload-panel{display:grid;gap:32px}.upload-panel.hidden{display:none}.upload-section{display:grid;gap:8px}.upload-section.hidden{display:none}.upload-title{font-size:14px;font-weight:600;color:var(--text)}.upload-hint{font-size:12px;color:var(--muted)}.search-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.search-item{display:flex;justify-content:space-between;gap:12px;align-items:baseline;color:var(--text);cursor:pointer}.search-item span{color:var(--muted);font-size:12px;white-space:nowrap}.search-meta{display:inline-flex;align-items:center;gap:8px}.search-open{display:inline-flex;align-items:center;justify-content:center;color:var(--muted);text-decoration:none}.search-open:hover{color:var(--text)}.search-open-icon{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 20;font-size:18px;line-height:1}.play-title{font-size:16px;font-weight:600;color:var(--text);margin:0 0 10px}.viz{width:100%;height:clamp(360px,65vh,700px);background:var(--viz-bg);border:1px solid var(--border-panel);border-radius:12px;position:relative;overflow:hidden;cursor:pointer}#jukebox-viz.is-canonizer{cursor:default}#viz-panel:fullscreen{padding:0;margin:0;width:100%;height:100%}#viz-panel:fullscreen .viz{height:100%;border-radius:0}#viz-panel:-webkit-full-screen{padding:0;margin:0;width:100%;height:100%}#viz-panel:-webkit-full-screen .viz{height:100%;border-radius:0}.viz canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.viz-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.canonizer-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:none}.canonizer-layer canvas{position:absolute;top:0;right:0;bottom:0;left:0}#jukebox-viz.is-canonizer .canonizer-layer{display:block}#jukebox-viz.is-canonizer .viz-layer{display:none}.viz-top{position:absolute;top:12px;left:12px;right:12px;z-index:3;display:flex;justify-content:space-between;align-items:center}.viz-actions{display:inline-flex;align-items:center;gap:8px}.viz-bottom{position:absolute;bottom:12px;left:12px;right:12px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:14px;z-index:3;color:var(--text);padding:10px 12px;border-radius:12px;background:var(--viz-overlay);backdrop-filter:blur(8px)}.viz-bottom-left{display:flex;align-items:center;gap:16px;min-width:0;flex:1}.viz-play-toggle{display:none}#viz-panel:fullscreen .play-toggle.viz-play-toggle,#viz-panel:-webkit-full-screen .play-toggle.viz-play-toggle{display:inline-flex;padding:0;width:36px;height:36px;border-radius:999px;justify-content:center}.viz-info{display:flex;flex-direction:column;gap:4px;min-width:0}.viz-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:none}#viz-panel:fullscreen .viz-title,#viz-panel:-webkit-full-screen .viz-title{display:block}.viz-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--muted)}.viz-divider{color:var(--muted)}.viz-controls{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.viz-actions{font-size:12px;color:var(--muted)}#jukebox-viz.is-canonizer .viz-controls .viz-select-group{display:none}#jukebox-viz:not(.is-canonizer) .canonizer-finish{display:none}.canonizer-finish{display:inline-flex;align-items:center;gap:6px;color:var(--text);font-size:12px}.canonizer-finish input{accent-color:var(--accent)}.viz-select-group{display:inline-flex;align-items:center;gap:8px;padding-bottom:0;font-size:12px}.viz-select-wrap{position:relative;display:inline-flex;align-items:center}.viz-select{-webkit-appearance:none;appearance:none;border:1px solid var(--border-control);background:var(--surface-panel);color:var(--text);font-size:12px;border-radius:999px;padding:4px 30px 4px 10px;min-width:116px}.viz-select:disabled{opacity:.55}.viz-select-arrow{position:absolute;right:8px;font-size:17px;color:var(--muted);pointer-events:none}.hint{font-size:12px;color:var(--muted)}.pulse{animation:pulse-highlight .35s ease}@keyframes pulse-highlight{0%{transform:scale(1);box-shadow:0 0 rgb(from var(--beat-highlight) r g b / 0)}50%{transform:scale(1.02);box-shadow:0 0 18px rgb(from var(--beat-highlight) r g b / .35)}to{transform:scale(1);box-shadow:0 0 rgb(from var(--beat-highlight) r g b / 0)}}.status-row{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted)}.status-progress{min-width:48px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.status-text{flex:1;color:var(--muted)}.spinner{width:16px;height:16px;border-radius:50%;border:2px solid rgba(var(--text-rgb),.2);border-top-color:var(--text);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 720px){.hero{padding-top:42px}.offline-banner{left:12px}.theme-toggle{top:10px;right:12px}.hero-main{margin-top:0}.viz{height:min(70vh,520px)}.viz-top{flex-wrap:wrap;gap:8px}}
