:root{--bg: #16130f;--bg-2: #1e1a15;--card: #221d17;--card-2: #2a241c;--line: #3a3127;--text: #f3ece1;--muted: #a89c89;--dim: #6f6553;--accent: #f2a541;--accent-2: #e8854a;--accent-3: #d96a5b;--on-accent: #2a1c08;--ok: #6cc08b;--err: #e5675f;--inset: #100d09;--code: #cdbfa6;--glow: rgba(242, 165, 65, .08);--radius: 14px;font-family:Inter,Segoe UI,system-ui,Avenir,Helvetica,Arial,sans-serif;color-scheme:dark}[data-theme=onyx]{--bg: #0e1116;--bg-2: #151a21;--card: #1a2029;--card-2: #232b36;--line: #333d4b;--text: #e8edf4;--muted: #94a1b2;--dim: #5c6979;--accent: #4aa3f0;--accent-2: #5b8def;--accent-3: #7a72e8;--on-accent: #08243f;--ok: #5ecf95;--err: #f0685f;--inset: #0a0d12;--code: #b6c2d1;--glow: rgba(74, 163, 240, .08);color-scheme:dark}[data-theme=daylight]{--bg: #f5eee2;--bg-2: #ece2d2;--card: #fffdf8;--card-2: #f2e9da;--line: #e1d5c1;--text: #2c2417;--muted: #71654f;--dim: #9c8f78;--accent: #c2410c;--accent-2: #b1480f;--accent-3: #a8533a;--on-accent: #fff7ee;--ok: #2f8d5b;--err: #c33b33;--inset: #efe5d3;--code: #5b5040;--glow: rgba(194, 65, 12, .07);color-scheme:light}[data-theme=frost]{--bg: #eef1f5;--bg-2: #e4e9f0;--card: #ffffff;--card-2: #eef2f8;--line: #d7dee8;--text: #1b2531;--muted: #5e6b7a;--dim: #94a1b1;--accent: #1d6fc4;--accent-2: #2b5fbf;--accent-3: #4a54c0;--on-accent: #f2f7ff;--ok: #2f8d5b;--err: #cf463d;--inset: #eaeef4;--code: #48535f;--glow: rgba(29, 111, 196, .06);color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;overflow:hidden;overscroll-behavior:none}body{position:fixed;inset:0;background:radial-gradient(1200px 600px at 80% -10%,var(--glow),transparent 60%),var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--bg-2),transparent)}.brand{display:flex;align-items:center;gap:12px}.brand-name{font-weight:700;font-size:16px;letter-spacing:.2px}.brand-sub{font-size:12px;color:var(--muted)}.status{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted)}.status-text b{color:var(--accent);font-weight:600}.status-text.err{color:var(--err)}.dot{width:9px;height:9px;border-radius:50%;background:var(--dim);box-shadow:0 0 #6cc08b99}.dot.on{background:var(--ok);animation:pulse 2.4s infinite}.dot.off{background:var(--err)}@keyframes pulse{0%{box-shadow:0 0 #6cc08b80}70%{box-shadow:0 0 0 7px #6cc08b00}to{box-shadow:0 0 #6cc08b00}}.grid{flex:1;display:grid;grid-template-columns:minmax(380px,1fr) minmax(420px,1.15fr);gap:18px;padding:18px 22px 22px;overflow:hidden}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;min-height:0}.card.right{overflow:hidden}.card-title{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin:0 0 10px;font-weight:600}.card-title:not(:first-child){margin-top:18px}.drop{border:1.5px dashed var(--line);border-radius:var(--radius);background:var(--bg-2);padding:26px 18px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s,transform .05s}.drop:hover{border-color:var(--accent-2)}.drop.over{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.drop.has-file{border-style:solid;border-color:var(--accent-2)}.drop-icon{display:inline-block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);border:1px solid var(--line);border-radius:8px;padding:5px 10px;margin-bottom:12px}.drop-main{font-size:17px;font-weight:600}.drop-file{font-size:15px;font-weight:600;color:var(--accent);word-break:break-all}.drop-sub{font-size:12.5px;color:var(--muted);margin-top:6px}.modes{display:flex;flex-direction:column;gap:8px}.mode{text-align:left;background:var(--card-2);border:1px solid var(--line);border-radius:10px;padding:11px 13px;color:var(--text);cursor:pointer;display:flex;flex-direction:column;gap:2px;transition:border-color .15s,background .15s}.mode:hover:not(:disabled){border-color:var(--accent-2)}.mode.sel{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.mode:disabled{opacity:.55;cursor:default}.mode-label{font-weight:650;font-size:14px}.mode-blurb{font-size:12px;color:var(--muted)}.prompts{margin-top:12px;display:flex;flex-direction:column;gap:6px}.prompts label{font-size:12px;color:var(--muted)}.prompts input{background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--text);font-size:13.5px;font-family:inherit}.prompts input:focus{outline:none;border-color:var(--accent)}.actions{margin-top:auto;padding-top:16px}.run,.cancel{width:100%;border:none;border-radius:11px;padding:13px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:filter .15s,transform .05s}.run{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent)}.run:hover:not(:disabled){filter:brightness(1.07)}.run:active:not(:disabled){transform:translateY(1px)}.run:disabled{background:var(--card-2);color:var(--dim);cursor:default}.cancel{background:transparent;border:1px solid var(--err);color:var(--err)}.cancel:hover{background:#e5675f1f}.empty{color:var(--dim);font-size:14px;padding:30px 6px}.progress-head{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:8px}.badge{font-size:11px;text-transform:uppercase;letter-spacing:.6px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--card-2);color:var(--muted);border:1px solid var(--line)}.badge.running{color:var(--accent);border-color:var(--accent-2)}.badge.done{color:var(--ok);border-color:var(--ok)}.badge.error{color:var(--err);border-color:var(--err)}.badge.canceled{color:var(--muted)}.badge.hd{color:var(--accent);border-color:var(--accent)}.queue-note{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:10px 0 2px;padding:10px 12px;background:var(--card-2);border:1px solid var(--accent-2);border-radius:10px;font-size:13.5px;color:var(--text)}.queue-note b{color:var(--accent);font-weight:700}.queue-note .queue-sub{color:var(--muted);font-size:12.5px;flex-basis:100%}.queue-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);flex:none;animation:pulse 1.6s infinite}.stage{font-size:13px;color:var(--muted);flex:1;min-width:0}.pct{font-weight:700;font-variant-numeric:tabular-nums}.bar{height:10px;background:var(--bg-2);border-radius:20px;overflow:hidden;border:1px solid var(--line)}.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-3),var(--accent));border-radius:20px;transition:width .3s ease}.bar-fill.done{background:var(--ok)}.bar-fill.error{background:var(--err)}.error-box{margin-top:12px;padding:10px 12px;border-radius:9px;background:#e5675f1a;border:1px solid var(--err);color:var(--err);font-size:13px}.results{margin-top:16px}.results-head{display:flex;align-items:center;justify-content:space-between}.results-head h3{margin:0;font-size:14px}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12.5px;font-family:inherit}.link-btn:hover{text-decoration:underline}.outpath{font-size:11.5px;color:var(--dim);margin:4px 0 10px;word-break:break-all;font-family:ui-monospace,Cascadia Code,Consolas,monospace}.stems{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}.stem{background:var(--card-2);border:1px solid var(--line);border-radius:10px;padding:9px 11px}.stem-row{display:flex;align-items:center;gap:10px;margin-bottom:7px}.stem-name{font-weight:600;font-size:13.5px;text-transform:capitalize;flex:1}.stem-size{font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums}.dl{font-size:12px;color:var(--accent)}.stem audio{width:100%;height:32px}.logs-title{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:18px 0 8px}.logs{flex:1;min-height:90px;overflow-y:auto;background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:12px;line-height:1.55}.logline{color:var(--code);white-space:pre-wrap;word-break:break-word}.logline.dim{color:var(--dim)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}::-webkit-scrollbar-track{background:transparent}.tabs{display:flex;gap:4px;background:var(--bg-2);border:1px solid var(--line);border-radius:11px;padding:4px}.tab{background:transparent;border:none;color:var(--muted);font-family:inherit;font-size:13.5px;font-weight:600;padding:7px 16px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.tab:hover{color:var(--text)}.tab.on{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent)}.tabbody{flex:1;display:flex;min-height:0;overflow:hidden}.tabbody>.grid{flex:1}.row2{display:flex;gap:12px}.field{display:flex;flex-direction:column;gap:5px;flex:1;font-size:12px;color:var(--muted)}.field>span{font-size:12px;color:var(--muted)}select,.text,.textarea{background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--text);font-size:13.5px;font-family:inherit}select:focus,.text:focus,.textarea:focus{outline:none;border-color:var(--accent)}.textarea{resize:vertical;line-height:1.5;min-height:232px;max-height:60vh;overflow-y:auto}input[type=range]{accent-color:var(--accent)}.hint{font-size:12px;color:var(--muted);margin-top:8px}.tagprev{margin-top:10px;background:var(--inset);border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-size:12px;color:var(--code);line-height:1.5;font-family:ui-monospace,Cascadia Code,Consolas,monospace}.tagprev-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);margin-bottom:4px;font-family:Inter,system-ui,sans-serif}.check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);margin-top:12px;cursor:pointer}.check input{accent-color:var(--accent);width:16px;height:16px}.ghost{background:var(--card-2);border:1px solid var(--line);color:var(--text);font-family:inherit;font-size:13px;font-weight:600;padding:9px 13px;border-radius:9px;cursor:pointer}.ghost:hover:not(:disabled){border-color:var(--accent-2)}.ghost:disabled{opacity:.5;cursor:default}.pick-btn{margin:10px 0 4px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);border:none;border-radius:10px;padding:11px 22px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer}.pick-btn:hover:not(:disabled){filter:brightness(1.07)}.pick-btn:disabled{opacity:.55;cursor:default}.consent{margin-top:10px;background:var(--card-2);border:1px solid var(--accent-2);border-radius:10px;padding:12px}.consent-script{font-size:14px;line-height:1.5;color:var(--text);font-style:italic}.rec-row{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}.rec-state{font-size:12px;color:var(--muted)}.disclaimer{font-size:11.5px;color:var(--dim);line-height:1.5;margin-top:8px}.engine-note{font-size:12px;color:var(--accent-2);background:#d96a5b14;border:1px solid var(--line);border-radius:8px;padding:7px 10px;margin-bottom:12px}.engine-note.ok{color:var(--ok)}.profiles{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}.profile{background:var(--card-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px}.profile-row{display:flex;align-items:center;gap:10px}.profile-name{font-weight:600;font-size:14px;flex:1}.profile-meta{font-size:11.5px;color:var(--muted);margin-top:5px}.song-card{padding:12px 13px}.lib-head{display:flex;align-items:center;gap:8px}.lib-title{font-weight:650;font-size:15px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lib-meta{font-size:12px;color:var(--muted);margin-top:3px}.act-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.act-btn{display:inline-flex;align-items:center;gap:6px;background:var(--card-2);border:1px solid var(--line);color:var(--text);font-family:inherit;font-size:13px;font-weight:600;padding:9px 13px;border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s,color .15s,filter .15s}.act-btn svg{width:16px;height:16px;flex:none}.act-btn:hover:not(:disabled){border-color:var(--accent-2)}.act-btn:disabled{opacity:.45;cursor:default}.act-btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);border:none}.act-btn.primary:hover:not(:disabled){filter:brightness(1.06)}.act-btn.on{border-color:var(--accent);color:var(--accent)}.act-btn.danger{color:var(--err)}.act-btn.danger:hover:not(:disabled){border-color:var(--err);background:#e5675f1f}.share-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:10px}.mode-hint{display:block;font-size:11px;color:var(--dim);margin-top:3px;font-variant-numeric:tabular-nums}.vr-queue{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.vr-q{display:flex;align-items:center;gap:10px;background:var(--card-2);border:1px solid var(--line);border-radius:9px;padding:7px 10px}.vr-q-name{flex:1;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vr-q-size{font-size:11.5px;color:var(--muted);font-variant-numeric:tabular-nums;flex:none}.vr-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;line-height:1;padding:2px 7px;border-radius:6px;flex:none}.vr-x:hover{color:var(--err);background:#e5675f1f}.vr-tip{margin-top:12px}.vr-results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.vr-result{background:var(--card-2);border:1px solid var(--line);border-radius:12px;padding:12px}.vr-result-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}.vr-result-head .vr-q-name{font-size:13.5px}.vr-stem{margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}.vr-stem:first-of-type{border-top:none;padding-top:0;margin-top:6px}.vr-stem .stem-name{text-transform:none}.update-gate{max-width:520px;margin:12vh auto 0;padding:32px 28px;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;gap:14px}.update-gate .logo{width:48px;height:48px}.update-gate h1{margin:4px 0 0;font-size:22px;color:var(--text)}.update-gate p{margin:0;color:var(--text);font-size:15px;line-height:1.5}.update-gate .update-sub{color:var(--muted);font-size:13.5px}.chan-tweak{margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}.tweak-in{width:100%;box-sizing:border-box;margin-top:6px;padding:8px 10px;background:var(--bg-2);border:1px solid var(--line);border-radius:8px;color:var(--text);font-family:inherit;font-size:13px}.tweak-in:focus{outline:none;border-color:var(--accent-2)}.tweak-in::placeholder{color:var(--dim)}.krender-toggle{display:inline-flex;gap:4px;margin-left:4px}.cdg-wrap{display:flex;flex-direction:column;align-items:center;padding:10px 0}.cdg-canvas{width:100%;max-width:760px;height:auto;aspect-ratio:300 / 216;background:#000;border-radius:10px;image-rendering:auto}.ksweep{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:38vh;text-align:center;padding:12px}.ksweep-line{font-size:clamp(28px,6vw,56px);font-weight:800;line-height:1.22;letter-spacing:.4px}.ksweep-next{font-size:clamp(16px,3.2vw,26px);font-weight:600;color:var(--muted);opacity:.5}.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(560px,100%),1fr));gap:10px;align-items:start}.lyrics-box{margin-top:10px;max-height:320px;overflow-y:auto;background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-size:13.5px;line-height:1.6;color:var(--code);white-space:pre-wrap}.lyr-tag{color:var(--accent-2);font-weight:700;margin-top:8px}.lyr-tag:first-child{margin-top:0}.link-btn.danger{color:var(--err)}.card.scroll{overflow-y:auto}.gen-tab{flex:1;display:flex;flex-direction:column;min-height:0}.gen-tab>.grid{flex:1;min-height:0}.gen-mode{display:flex;gap:4px;align-self:center;background:var(--bg-2);border:1px solid var(--line);border-radius:11px;padding:4px;margin:14px 0 0}.gen-mode-btn{background:transparent;border:none;color:var(--muted);font-family:inherit;font-size:13px;font-weight:600;padding:6px 22px;border-radius:8px;cursor:pointer}.gen-mode-btn.on{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent)}.wiz-steps{display:flex;flex-wrap:wrap;gap:6px;margin:2px 0 14px}.wiz-pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-2);border:1px solid var(--line);color:var(--muted);border-radius:999px;padding:4px 11px 4px 4px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer}.wiz-pill-n{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--line);color:var(--text);font-size:11px}.wiz-pill.on{border-color:var(--accent);color:var(--accent)}.wiz-pill.on .wiz-pill-n{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent)}.wiz-pill.done .wiz-pill-n{background:var(--accent-2);color:var(--on-accent)}.wiz-pill:hover:not(.on){border-color:var(--accent-2)}.wiz-title{font-size:16px;margin:0;color:var(--text)}.wiz-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:0 0 10px}.wiz-tip-toggle{width:22px;height:22px;flex:none;padding:0;border:1px solid var(--line);background:var(--card-2);color:var(--muted);border-radius:50%;font-size:13px;line-height:1;font-family:inherit;cursor:pointer}.wiz-tip-toggle:hover{border-color:var(--accent-2);color:var(--text)}.wiz-teach{background:var(--card-2);border:1px solid var(--line);border-left:3px solid var(--accent-2);border-radius:8px;padding:10px 12px;font-size:12.5px;line-height:1.55;color:var(--muted);margin-bottom:14px}.wiz-teach b{color:var(--text)}.wiz-teach ul{margin:6px 0 0;padding-left:18px}.wiz-teach li{margin:2px 0}.wiz-nav{display:flex;align-items:center;gap:10px;margin-top:auto;padding-top:16px}.wiz-nav .run,.wiz-nav .cancel{width:auto;min-width:160px;padding:11px 22px}.wiz-recipe{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:10px;overflow:hidden}.wiz-recipe-row{display:flex;gap:12px;padding:9px 12px;border-bottom:1px solid var(--line);cursor:pointer;font-size:13px}.wiz-recipe-row:last-child{border-bottom:none}.wiz-recipe-row:hover{background:var(--card-2)}.wiz-recipe-k{flex:0 0 92px;color:var(--muted);font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.5px;padding-top:1px}.wiz-recipe-v{flex:1;color:var(--text);word-break:break-word}.gen-progress{display:flex;align-items:center;gap:9px;margin-top:10px;font-size:12.5px;color:var(--muted)}.gen-progress b{color:var(--text);font-variant-numeric:tabular-nums}.gen-spinner{width:15px;height:15px;flex:none;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:gen-spin .7s linear infinite}@keyframes gen-spin{to{transform:rotate(360deg)}}@media(max-width:760px){.gen-tab{display:block}.gen-mode{margin:12px auto 0;width:fit-content}}.mic-btn{background:var(--card-2);border:1px solid var(--line);color:var(--muted);border-radius:9px;padding:8px 10px;cursor:pointer;display:inline-flex;align-items:center;flex-shrink:0}.mic-btn:hover{border-color:var(--accent-2);color:var(--text)}.mic-btn.on{color:var(--accent);border-color:var(--accent);animation:pulse 1.2s infinite}.input-mic{display:flex;gap:8px;align-items:center}.title-row{display:flex;align-items:center;gap:10px;margin-top:18px}.title-row .card-title{margin-top:0}.karaoke-stage{flex:1;display:flex;flex-direction:column;min-height:0;padding:16px 22px 20px;gap:12px}.karaoke-head{display:flex;align-items:center;gap:12px}.karaoke-intro{flex:1;font-size:15px;color:var(--accent);font-weight:650}.karaoke-audio{width:100%}.tabbody>.karaoke-stage{flex:1;min-height:0}.karaoke-lyrics{flex:1;min-height:240px;overflow:hidden;text-align:center;padding:16px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(14px,3vh,30px);--k-sung: #ff3b3b;--k-unsung: #ffffff;border-radius:16px;color:#fff;background:radial-gradient(130% 90% at 18% 0%,hsl(var(--khue, 250) 55% 15% / .9),transparent 60%),radial-gradient(120% 90% at 85% 100%,hsl(calc(var(--khue, 250) + 60) 55% 12% / .85),transparent 55%),linear-gradient(160deg,hsl(var(--khue, 250) 40% 8%),hsl(calc(var(--khue, 250) + 30) 45% 4%));background-size:200% 200%,200% 200%,100% 100%;animation:kdrift 24s ease-in-out infinite alternate}@keyframes kdrift{0%{background-position:0% 0%,100% 100%,0 0}to{background-position:40% 30%,60% 70%,0 0}}.kw2{background-image:linear-gradient(90deg,var(--k-sung) var(--p, 0%),var(--k-unsung) var(--p, 0%));-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}.ktitle-card{display:flex;flex-direction:column;align-items:center;gap:8px}.ktitle{font-size:clamp(30px,6vw,60px);font-weight:800;color:#fff;text-shadow:0 3px 22px rgba(0,0,0,.6)}.kfamous{font-size:clamp(13px,1.8vw,18px);color:#ffd23f;letter-spacing:.4px}.kartist{font-size:clamp(20px,3.6vw,34px);font-weight:700;color:#fff;opacity:.92}.kmode{display:flex;gap:4px;background:var(--bg-2);border:1px solid var(--line);border-radius:11px;padding:4px;margin-bottom:12px}.kmode .tab{flex:1;text-align:center}.karaoke-lyrics .klyric.active{color:#fff}.karaoke-lyrics .klyric.next{color:#fff;opacity:.45}.karaoke-lyrics .empty{color:#ffffffb3}.karaoke-lyrics .karaoke-bigintro.dim{color:#fff9;opacity:.8}.karaoke-bigintro{font-size:clamp(22px,4vw,38px);color:var(--accent-2);font-style:italic;font-weight:600}.karaoke-bigintro.dim{color:var(--muted);opacity:.5}.klyric{line-height:1.3;max-width:22ch;transition:color .2s,opacity .2s,transform .2s}.klyric.next{font-size:clamp(18px,2.6vw,26px);color:var(--muted);opacity:.5}.klyric.active{font-size:clamp(28px,5vw,46px);color:var(--text);font-weight:750}.kw{transition:color .1s,text-shadow .1s;color:var(--text)}.kw.done{color:var(--accent)}.kw.on{color:var(--accent);text-shadow:0 0 16px var(--accent)}.maint-banner{display:flex;align-items:center;gap:10px;padding:9px 16px;background:linear-gradient(90deg,#ffb2382e,#ffb23812);border-bottom:1px solid rgba(255,178,56,.45);color:var(--text);font-size:13px}.maint-banner b{color:var(--accent)}.maint-spinner{width:14px;height:14px;flex:none;border:2px solid rgba(255,178,56,.35);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dot.online{background:var(--ok);animation:pulse 2.4s infinite}.dot.starting,.dot.reconnecting{background:var(--accent);animation:pulse 1.2s infinite}.dot.failed{background:var(--err)}.mini-btn{background:var(--card-2);border:1px solid var(--line);color:var(--text);font-family:inherit;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:7px;cursor:pointer;white-space:nowrap}.mini-btn:hover{border-color:var(--accent-2)}.mini-btn.ghosty{color:var(--muted)}.console-drawer{position:fixed;left:0;right:0;bottom:0;height:240px;background:var(--inset);border-top:1px solid var(--line);box-shadow:0 -10px 30px #0006;display:flex;flex-direction:column;z-index:50}.console-head{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--line);font-size:12px}.console-reason{color:var(--muted)}.console-meta{color:var(--dim);font-size:11.5px;font-variant-numeric:tabular-nums}.console-log{flex:1;overflow-y:auto;padding:8px 14px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:11.5px;line-height:1.5}.console-log .logline{color:var(--code);white-space:pre-wrap;word-break:break-word}.dj-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:760px){.dj-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap;gap:8px 10px;padding:10px 12px;padding-top:calc(10px + env(safe-area-inset-top));padding-left:calc(12px + env(safe-area-inset-left));padding-right:calc(12px + env(safe-area-inset-right))}.brand{flex:1 1 auto;min-width:0}.status{font-size:11px;gap:7px;flex:0 1 auto;min-width:0}.status-text{display:none}.tabs{order:3;width:100%;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex:0 0 auto;white-space:nowrap;padding:8px 14px}.tabbody{overflow-y:auto;overflow-x:hidden}.grid{grid-template-columns:1fr;grid-auto-rows:min-content;overflow-y:visible;padding:12px;gap:12px}.card{min-height:0;min-width:0}.card.right{overflow:visible}.row2{flex-direction:column}.logs{max-height:240px}audio{width:100%}}.player{flex:1;min-height:0;display:flex;flex-direction:column;gap:14px;padding:16px 22px 20px;overflow-y:auto}.tabbody>.player{flex:1}.player-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.player-stage{display:flex;align-items:stretch;justify-content:center;gap:16px}.player-center{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;flex:1;max-width:600px}.player-art{width:220px;height:220px;border-radius:18px;background:linear-gradient(140deg,var(--accent),var(--accent-3) 70%,var(--accent-2));display:flex;align-items:center;justify-content:center;padding:16px;margin-bottom:12px;box-shadow:0 14px 40px #00000059}.player-art span{color:var(--on-accent);font-weight:800;font-size:19px;line-height:1.25;max-height:100%;overflow:hidden}.player-title{font-size:24px;font-weight:750}.player-meta{font-size:13px;color:var(--muted)}.side-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:124px;flex:none;border-radius:18px;border:2px solid;font-family:inherit;font-size:16px;font-weight:800;cursor:pointer;transition:transform .06s,background .15s}.side-btn:active:not(:disabled){transform:scale(.97)}.side-btn:disabled{opacity:.4;cursor:default}.side-btn.discard{background:#e5675f1f;border-color:var(--err);color:var(--err)}.side-btn.discard:hover:not(:disabled){background:#e5675f3d}.side-btn.keep{background:#6cc08b1f;border-color:var(--ok);color:var(--ok)}.side-btn.keep:hover:not(:disabled){background:#6cc08b3d}.transport{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:14px}.t-btn{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--card-2);border:1px solid var(--line);color:var(--text);cursor:pointer}.t-btn:hover:not(:disabled){border-color:var(--accent-2)}.t-btn:disabled{opacity:.4;cursor:default}.t-btn.play{width:62px;height:62px;border:none;color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2))}.seek-row{display:flex;align-items:center;gap:10px;width:100%;max-width:480px;margin-top:12px}.seek-row input[type=range]{flex:1}.t-time{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums;min-width:36px}.upnext{margin-top:8px}@media(max-width:760px){.player-stage{flex-wrap:wrap}.player-center{order:1;flex-basis:100%;max-width:none}.side-btn{order:2;flex:1;height:64px;flex-direction:row}}.auth-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px 16px}.auth-card{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px 26px;display:flex;flex-direction:column;gap:0}.auth-logo{display:flex;align-items:center;gap:14px;margin-bottom:28px}.auth-title{font-size:20px;font-weight:750;letter-spacing:.1px;color:var(--text);line-height:1.2}.auth-sub{font-size:12.5px;color:var(--muted);margin-top:2px}.auth-card .field{width:100%;margin-top:10px}.auth-card .field:first-child{margin-top:0}.auth-card .text{width:100%}.auth-links{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:18px}.auth-link{background:none;border:none;font-family:inherit;font-size:13px;color:var(--accent);cursor:pointer;padding:2px 4px;line-height:1.4;text-align:center}.auth-link:hover{text-decoration:underline}@media(max-width:440px){.auth-card{padding:24px 18px 20px}}.icon-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--card-2);border:1px solid var(--line);color:var(--muted);width:30px;height:28px;border-radius:8px;cursor:pointer;padding:0}.icon-btn:hover{border-color:var(--accent-2);color:var(--text)}.icon-btn svg{width:16px;height:16px}.modal-backdrop{position:fixed;inset:0;z-index:60;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px}.modal{width:100%;max-width:480px;max-height:86vh;overflow-y:auto;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px 22px;box-shadow:0 24px 70px #00000080}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:18px;font-weight:750}.modal-label{font-size:12px;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);font-weight:600;margin:18px 0 10px}.modal-hint{font-size:12.5px;color:var(--muted);margin-top:12px;line-height:1.5}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:10px}.theme-card{text-align:left;cursor:pointer;padding:0;overflow:hidden;background:var(--card-2);border:1px solid var(--line);border-radius:12px;font-family:inherit;transition:border-color .15s,transform .05s}.theme-card:hover{border-color:var(--accent-2)}.theme-card:active{transform:translateY(1px)}.theme-card.sel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.theme-preview{height:58px;display:flex;align-items:center;gap:9px;padding:0 14px;border-bottom:1px solid var(--line)}.theme-bars{display:flex;flex-direction:column;gap:3px}.theme-bars span{display:block;width:22px;height:3.5px;border-radius:2px}.theme-chip{width:16px;height:16px;border-radius:5px}.theme-card-foot{display:flex;align-items:center;justify-content:space-between;padding:8px 12px}.theme-card-name{font-size:13px;font-weight:650;color:var(--text)}.theme-card-mode{font-size:11px;color:var(--muted)}.theme-card-check{color:var(--accent);display:inline-flex}.settings-modal{max-width:680px}.settings-body{display:flex;gap:18px;margin-top:16px}.settings-nav{display:flex;flex-direction:column;gap:4px;flex:none;width:132px}.settings-nav-btn{text-align:left;background:transparent;border:1px solid transparent;color:var(--muted);font:600 14px/1 inherit;font-family:inherit;padding:10px 12px;border-radius:9px;cursor:pointer}.settings-nav-btn:hover{color:var(--text);background:var(--card-2)}.settings-nav-btn.on{color:var(--text);background:var(--card-2);border-color:var(--line)}.settings-pane{flex:1;min-width:0}.set-section{margin-bottom:22px}.set-section:last-child{margin-bottom:0}.set-h{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-weight:600;margin:0 0 10px}.set-note{font-size:12.5px;color:var(--muted);line-height:1.5;margin:10px 0 0}.set-row{display:flex;gap:8px;align-items:center;margin-top:10px;flex-wrap:wrap}.set-input{flex:1;min-width:0;background:var(--card-2);border:1px solid var(--line);color:var(--text);border-radius:9px;padding:10px 12px;font:inherit}.set-input:focus{outline:none;border-color:var(--accent)}.set-status{display:flex;flex-direction:column;gap:1px;border:1px solid var(--line);border-radius:10px;overflow:hidden}.set-statrow{display:flex;justify-content:space-between;gap:12px;padding:9px 12px;background:var(--card-2);font-size:13.5px}.set-statk{color:var(--muted)}.set-statv{font-weight:600;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.act-btn.danger{color:var(--err);border-color:color-mix(in srgb,var(--err) 45%,var(--line))}.act-btn.danger:hover{border-color:var(--err)}.faq{display:flex;flex-direction:column;gap:6px}.faq-item{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--card-2)}.faq-item.open{border-color:var(--accent-2)}.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:transparent;border:0;color:var(--text);font:600 14px inherit;font-family:inherit;padding:12px 14px;cursor:pointer;text-align:left}.faq-caret{color:var(--accent);font-size:18px;line-height:1;flex:none}.faq-a{padding:0 14px 13px;font-size:13.5px;color:var(--muted);line-height:1.55}.faq-a b{color:var(--text);font-weight:650}.tut{margin-bottom:14px}.tut-title{font-weight:700;font-size:14px;margin-bottom:6px}.tut-steps{margin:0;padding-left:20px;color:var(--muted);font-size:13.5px;line-height:1.7}@media(max-width:560px){.settings-body{flex-direction:column;gap:12px}.settings-nav{flex-direction:row;width:100%;overflow-x:auto}.settings-nav-btn{flex:1;text-align:center;white-space:nowrap}}
