:root{--bg: #f4f4f5;--surface: #ffffff;--surface-2: #fafafa;--text: #18181b;--text-muted: #71717a;--text-faint: #a1a1aa;--border: #e4e4e7;--border-strong: #d4d4d8;--hover: rgba(24, 24, 27, .045);--primary: #18181b;--primary-text: #ffffff;--live: #16a34a;--warn: #d97706;--shadow-sm: 0 1px 2px rgba(24, 24, 27, .06);--shadow-card: 0 1px 2px rgba(24, 24, 27, .05), 0 4px 12px rgba(24, 24, 27, .04);--r: 10px;--r-lg: 14px;--sidebar-w: 264px;--font: -apple-system, system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: "SF Mono", "Menlo", "Consolas", monospace;color-scheme:light}[data-theme=dark]{--bg: #09090b;--surface: #18181b;--surface-2: #1f1f23;--text: #fafafa;--text-muted: #a1a1aa;--text-faint: #71717a;--border: #27272a;--border-strong: #3f3f46;--hover: rgba(255, 255, 255, .06);--primary: #fafafa;--primary-text: #18181b;--live: #22c55e;--warn: #f59e0b;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-card: 0 1px 2px rgba(0, 0, 0, .35), 0 4px 14px rgba(0, 0, 0, .3);color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}::selection{background:var(--text);color:var(--surface)}button,input,select{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--bg);border-right:1px solid var(--border);padding:12px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.main{flex:1;min-width:0;display:flex;flex-direction:column}.content{padding:24px 32px 64px;width:100%}.profile{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r)}.avatar{width:36px;height:36px;flex:0 0 36px;border-radius:9px;background:var(--primary);color:var(--primary-text);display:grid;place-items:center;font-weight:600;font-size:13px;letter-spacing:.02em}.profile .who{flex:1;min-width:0}.profile .who .nm{font-weight:600;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile .who .em{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;background:transparent;border:none;color:var(--text-muted);cursor:pointer}.icon-btn:hover{background:var(--hover);color:var(--text)}.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:8px 10px;margin:8px 0 10px;box-shadow:var(--shadow-sm)}.search svg{color:var(--text-faint);flex:0 0 auto}.search input{flex:1;min-width:0;border:none;background:transparent;outline:none;font-size:13.5px}.search input::placeholder{color:var(--text-faint)}.kbd{font-family:var(--mono);font-size:11px;color:var(--text-faint);border:1px solid var(--border);border-radius:5px;padding:1px 6px;background:var(--bg)}.lang-switch{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:3px;margin:8px 0 10px;box-shadow:var(--shadow-sm)}.lang-switch button{flex:1;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.04em;padding:6px 0;border-radius:7px;cursor:pointer}.lang-switch button:hover{color:var(--text)}.lang-switch button.on{background:var(--primary);color:var(--primary-text)}.nav{display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 11px;border-radius:var(--r);border:1px solid transparent;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;text-align:left}.nav-item svg{color:var(--text-faint);flex:0 0 auto}.nav-item:hover{background:var(--hover);color:var(--text)}.nav-item:hover svg{color:var(--text-muted)}.nav-item[aria-current=true]{background:var(--surface);border-color:var(--border);box-shadow:var(--shadow-card);color:var(--text);font-weight:600}.nav-item[aria-current=true] svg{color:var(--text)}.nav-item:disabled{opacity:.5;cursor:not-allowed}.nav-item .soon{margin-left:auto;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);border:1px solid var(--border);border-radius:5px;padding:1px 5px}.nav-sep{height:1px;background:var(--border);margin:8px 6px}.sidebar .spacer{flex:1}.sidebar .foot{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);padding:8px 10px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 32px;border-bottom:1px solid var(--border);position:sticky;top:0;background:color-mix(in srgb,var(--bg) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5}.topbar .ttl h1{margin:0;font-size:18px;font-weight:600}.topbar .ttl p{margin:1px 0 0;font-size:13px;color:var(--text-muted)}.status{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted)}.status .dot{width:8px;height:8px;border-radius:50%;background:var(--text-faint)}.status.live{color:var(--live);border-color:color-mix(in srgb,var(--live) 35%,var(--border))}.status.live .dot{background:var(--live);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--live) 60%,transparent)}70%{box-shadow:0 0 0 7px transparent}to{box-shadow:0 0 0 0 transparent}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;margin-bottom:18px;box-shadow:var(--shadow-card)}.card h2{margin:0 0 4px;font-size:16px;font-weight:600}.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);margin:0 0 12px}.hint{color:var(--text-muted);font-size:13px;margin:4px 0 0}.empty{color:var(--text-muted);font-size:13.5px;padding:6px 0}.btn{display:inline-flex;align-items:center;gap:8px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--r);padding:9px 15px;font-weight:500;cursor:pointer}.btn:hover{border-color:var(--border-strong);background:var(--hover)}.btn-primary{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}.btn-primary:hover{filter:brightness(1.08);background:var(--primary)}.btn:disabled{opacity:.45;cursor:not-allowed}.iconbtn{background:transparent;border:none;color:var(--text-faint);cursor:pointer;display:grid;place-items:center;padding:4px;border-radius:6px}.iconbtn:hover{color:var(--warn);background:var(--hover)}button:focus-visible,input:focus-visible,select:focus-visible,.nav-item:focus-visible{outline:2px solid var(--text);outline-offset:1px}.field{display:block;margin-bottom:18px}.field .lbl{display:block;font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:7px}input[type=text],input[type=number],select{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:9px 12px;outline:none}input[type=text]:focus,input[type=number]:focus,select:focus{border-color:var(--border-strong)}input[type=range]{width:100%;accent-color:var(--primary)}.list{display:flex;flex-direction:column;gap:6px;margin-top:14px}.row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r)}.row .name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.row .meta{font-family:var(--mono);font-size:12px;color:var(--text-muted);white-space:nowrap}.badge{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 7px;border-radius:5px;border:1px solid var(--border);color:var(--text-muted)}.badge.ad{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,var(--border))}.steps{margin:14px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--text)}.steps li{line-height:1.5;padding-left:4px}.steps .code{word-break:break-all}.pchips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.pchip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:13.5px;font-weight:500;cursor:pointer}.pchip:hover{border-color:var(--border-strong);color:var(--text)}.pchip[aria-current=true]{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}.pchip .ct{font-family:var(--mono);font-size:11px;opacity:.75}.songs-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.songs-head h2{margin:2px 0 0}.songs-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.playbtn{display:grid;place-items:center;width:34px;height:34px;flex:0 0 34px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}.playbtn:hover{border-color:var(--border-strong);background:var(--hover)}.playbtn.on{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}.row.song .move{width:auto;flex:0 0 auto;max-width:170px;padding:6px 10px;font-size:12.5px;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:34px 0 20px;color:var(--text-faint);text-align:center}.empty-state p{margin:0;font-size:14px}.drop.disabled{opacity:.55;cursor:not-allowed}.targets{position:relative}.targets>summary{cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.targets>summary::-webkit-details-marker,.targets>summary::marker{display:none;content:""}.targets>summary:hover{border-color:var(--border-strong)}.targets-panel{position:absolute;right:0;top:calc(100% + 6px);z-index:20;min-width:210px;max-height:280px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-card);padding:6px}.targets-row{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:7px;font-size:13.5px;font-weight:500;cursor:pointer;white-space:nowrap}.targets-row:hover{background:var(--hover)}.targets-row input{accent-color:var(--primary)}.drop{border:1.5px dashed var(--border-strong);border-radius:var(--r);padding:26px;text-align:center;color:var(--text-muted);cursor:pointer;font-size:13.5px}.drop:hover,.drop.hot{border-color:var(--text);color:var(--text);background:var(--hover)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-card)}.stat .n{font-size:26px;font-weight:650;letter-spacing:-.01em}.stat .k{font-size:12px;color:var(--text-muted);margin-top:2px}.now{text-align:center;padding:12px 0 4px}.now .kindline{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);margin-bottom:10px}.now .title{font-size:26px;font-weight:650;letter-spacing:-.01em;word-break:break-word}.now .title.ad{color:var(--warn)}.progress{height:6px;background:var(--bg);border:1px solid var(--border);border-radius:999px;overflow:hidden;margin:20px 0 6px}.progress>i{display:block;height:100%;background:var(--primary);width:0}.times{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--text-muted)}.transport{display:flex;align-items:center;justify-content:center;gap:12px;margin:22px 0 4px}.transport .big{width:56px;height:56px;border-radius:50%;padding:0;justify-content:center}.upnext{text-align:center;font-size:13px;color:var(--text-muted);margin-top:16px}.upnext b{color:var(--text)}.vu{display:flex;align-items:flex-end;justify-content:center;gap:4px;height:28px;margin-top:16px}.vu i{width:4px;border-radius:2px;background:var(--live);height:25%}.vu.live i{animation:bounce .9s ease-in-out infinite}.vu i:nth-child(2){animation-delay:.1s}.vu i:nth-child(3){animation-delay:.25s}.vu i:nth-child(4){animation-delay:.05s}.vu i:nth-child(5){animation-delay:.3s}.vu i:nth-child(6){animation-delay:.15s}.vu i:nth-child(7){animation-delay:.22s}@keyframes bounce{0%,to{height:25%}50%{height:100%}}@media (max-width: 720px){.sidebar{display:none}.stats{grid-template-columns:repeat(2,1fr)}.content,.topbar{padding-left:20px;padding-right:20px}}@media (prefers-reduced-motion: reduce){.status.live .dot,.vu.live i{animation:none}}.boot{display:grid;place-items:center;height:100vh;color:var(--text-muted);font-family:var(--mono);letter-spacing:.1em}.auth-error{color:var(--accent-2, #d9483b);font-size:13px;margin:12px 0}.auth-split{display:flex;min-height:100vh}.auth-aside{flex:0 0 46%;max-width:620px;position:relative;overflow:hidden;display:flex;flex-direction:column;padding:56px 52px;color:#fafafa;background:radial-gradient(130% 90% at 0% 0%,rgba(245,158,11,.22),transparent 55%),radial-gradient(120% 80% at 100% 100%,rgba(245,158,11,.08),transparent 50%),linear-gradient(160deg,#18181b,#09090b)}.auth-aside .wordmark{display:flex;align-items:center;gap:11px;font-size:14px;font-weight:700;letter-spacing:.18em}.auth-aside .wordmark .dot{width:11px;height:11px;border-radius:50%;background:#f59e0b;box-shadow:0 0 16px #f59e0bcc}.auth-aside .pitch{margin-top:auto}.auth-aside h2{font-size:34px;line-height:1.18;font-weight:650;letter-spacing:-.02em;margin:0 0 14px;max-width:13ch}.auth-aside .pitch p{margin:0;font-size:15px;line-height:1.6;color:#a1a1aa;max-width:34ch}.auth-features{list-style:none;margin:30px 0 0;padding:0;display:flex;flex-direction:column;gap:13px}.auth-features li{display:flex;align-items:center;gap:12px;font-size:14px;color:#e4e4e7}.auth-features li svg{color:#f59e0b;flex:0 0 auto}.auth-aside .foot{margin-top:40px;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#52525b}.auth-main{flex:1;position:relative;display:grid;place-items:center;padding:32px 24px}.auth-lang{position:absolute;top:22px;right:24px;width:104px;margin:0}.auth-card{width:100%;max-width:380px}.auth-brand-sm{display:none;align-items:center;gap:10px;font-weight:700;letter-spacing:.14em;font-size:13px;color:var(--text);margin-bottom:26px}.auth-brand-sm .dot{width:10px;height:10px;border-radius:50%;background:var(--warn)}.auth-card h1{font-size:25px;letter-spacing:-.01em;margin:0 0 5px}.auth-card .field{margin-bottom:16px}.pw{position:relative}.pw input{padding-right:40px}.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:grid;place-items:center;width:30px;height:30px;border:none;background:none;color:var(--text-faint);cursor:pointer;border-radius:7px}.pw-toggle:hover{color:var(--text);background:var(--hover)}.btn-block{width:100%;justify-content:center;margin-top:4px;padding-top:11px;padding-bottom:11px}.auth-switch{display:block;width:100%;margin-top:16px;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer}.auth-switch:hover,.auth-switch b{color:var(--text)}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 860px){.auth-aside{display:none}.auth-brand-sm{display:flex}}.inline{display:flex;gap:8px;align-items:center}.inline>select,.inline>input[type=text]{flex:1;min-width:0}.rowbtn{cursor:pointer;text-align:left;font:inherit;color:inherit}.rowbtn:hover{border-color:var(--border-strong)}.rowbtn[aria-current=true]{border-color:var(--text)}.code{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:3px 8px}.kiosk{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:24px}.kiosk-top{width:100%;max-width:560px;display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.kiosk-store{font-size:18px;font-weight:650}.kiosk-meta{display:flex;align-items:center;gap:8px}.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-family:var(--mono);letter-spacing:.04em;color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:4px 10px}.chip.ok{color:var(--live);border-color:color-mix(in srgb,var(--live) 35%,var(--border))}.chip.warn{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,var(--border))}.chip .dot2{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block}.kiosk-card{width:100%;max-width:560px;margin-top:auto;margin-bottom:auto;padding:36px 28px}.kiosk-card .title{font-size:30px}.kiosk-card .transport .big{width:64px;height:64px}
