@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 600;font-display:swap;src:url(/fonts/jetbrains-mono.woff2) format("woff2")}@font-face{font-family:"Instrument Serif";font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/instrument-serif-regular.woff2) format("woff2")}@font-face{font-family:"Instrument Serif";font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/instrument-serif-italic.woff2) format("woff2")}:root{--ink: #0a0a0a;--ink-2: #111;--ink-3: #161616;--ink-4: #1c1c1c;--line: rgba(255,255,255,.06);--line-2: rgba(255,255,255,.1);--line-3: rgba(255,255,255,.18);--fg: #e9e9e9;--fg-2: #bdbdbd;--fg-3: #7c7c7c;--fg-4: #4a4a4a;--fg-5: #2c2c2c;--accent: #07c160;--accent-dim: rgba(7,193,96,.1);--accent-line: rgba(7,193,96,.3);--accent-glow: rgba(7,193,96,.06);--danger: #e5484d;--danger-dim: rgba(229,72,77,.1);--warn: #ff9e3d;--mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--serif: "Instrument Serif", "PT Serif", Georgia, serif;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", "Hiragino Sans GB", "Source Han Sans CN", "Noto Sans SC", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{height:100%;margin:0}body{background:var(--ink);color:var(--fg);font-family:var(--sans);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;color-scheme:dark}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}::selection{background:var(--accent);color:var(--ink)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--line-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--fg-4)}::-webkit-scrollbar-track{background:transparent}@keyframes mp-pulse{0%,to{box-shadow:0 0 0 1.5px #07c16040}50%{box-shadow:0 0 0 3.5px #07c1601a}}.brand-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 1.5px #07c16040;transform:translateY(-1px);animation:mp-pulse 2.4s ease-in-out infinite}.mono{font-family:var(--mono)}.serif{font-family:var(--serif);font-style:italic}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 600px at 20% -10%,rgba(7,193,96,.05),transparent 70%),var(--ink)}.login-card{width:360px;background:var(--ink);border:1px solid var(--line);border-radius:4px;padding:28px 28px 20px;box-shadow:0 1px #ffffff05 inset,0 30px 80px -30px #000c}.login-brand{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}.login-brand .name{font-family:var(--serif);font-style:italic;font-size:22px}.login-sub{font-family:var(--mono);font-size:11px;color:var(--fg-3);letter-spacing:.04em;margin-bottom:22px}.login-form{display:grid;gap:12px}.login-form label{display:block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);margin-bottom:4px}.login-form input{width:100%;height:36px;padding:0 10px;background:var(--ink-3);border:1px solid var(--line);color:var(--fg);font-family:var(--mono);font-size:13px;border-radius:3px;outline:none;transition:border-color .15s}.login-form input:focus{border-color:var(--accent-line)}.login-form input::placeholder{color:var(--fg-4)}.btn-primary{width:100%;height:36px;background:var(--accent);color:var(--ink);border:0;border-radius:3px;font-family:var(--mono);font-weight:600;font-size:12px;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:.15s}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{background:var(--fg-4);color:var(--ink);cursor:not-allowed}.login-error{padding:8px 10px;border:1px solid rgba(229,72,77,.35);background:#e5484d0f;color:#ff9a9d;font-family:var(--mono);font-size:11px;border-radius:3px;display:none}.login-error.show{display:block}.login-footer{margin-top:18px;padding-top:14px;border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;color:var(--fg-4);display:flex;justify-content:space-between}.login-footer .ok{color:var(--accent)}.shell-player{display:grid;grid-template-rows:44px 1fr 28px;grid-template-columns:280px 1fr;grid-template-areas:"topbar topbar" "sidebar main" "footer footer";height:100vh}.topbar{grid-area:topbar;display:flex;align-items:center;padding:0 14px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px}.topbar .brand{display:flex;align-items:baseline;gap:6px;font-family:var(--serif);font-style:italic;font-size:16px}.topbar .brand .sub{color:var(--fg-3);font-family:var(--mono);font-style:normal;font-size:11px;margin-left:6px}.topbar-meta{margin-left:auto;display:flex;gap:14px;color:var(--fg-3);font-size:11px;align-items:center}.topbar-meta b{color:var(--fg);font-weight:500}.topbar-meta .sep{color:var(--fg-4)}.topbar-meta button{background:none;border:1px solid var(--line-2);color:var(--fg-2);padding:3px 8px;border-radius:3px;font-family:var(--mono);font-size:11px;cursor:pointer;transition:.15s}.topbar-meta button:hover{border-color:var(--line-3);color:var(--fg)}.sidebar{grid-area:sidebar;border-right:1px solid var(--line);overflow-y:auto;padding:8px 0 16px}.sb-search{margin:8px 12px 12px;position:relative}.sb-search input{width:100%;height:30px;padding:0 10px 0 26px;background:var(--ink-3);border:1px solid var(--line);color:var(--fg);font-family:var(--mono);font-size:12px;border-radius:3px;outline:none}.sb-search input:focus{border-color:var(--accent-line)}.sb-search .icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--fg-4);font-size:11px;font-family:var(--mono)}.sb-group{margin:4px 0}.sb-group-h{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;color:var(--fg-3);font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;user-select:none}.sb-group-h:hover{color:var(--fg-2)}.sb-group-h .count{color:var(--fg-4)}.sb-list{list-style:none;padding:0;margin:0}.sb-list li{display:flex;align-items:center;gap:8px;padding:5px 14px 5px 24px;color:var(--fg-2);font-size:13px;cursor:pointer;line-height:1.2;border-left:2px solid transparent}.sb-list li:hover{background:var(--ink-2);color:var(--fg)}.sb-list li.active{background:var(--ink-3);color:var(--fg);border-left-color:var(--accent)}.sb-list li .num{font-family:var(--mono);font-size:11px;color:var(--fg-4);min-width:24px}.sb-list li.active .num{color:var(--accent)}.sb-list li .name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-list li .q{font-family:var(--mono);font-size:10px;color:var(--fg-4);padding:1px 4px;border:1px solid var(--line);border-radius:2px}.main{grid-area:main;display:grid;grid-template-rows:1fr auto;overflow:hidden}.player-wrap{position:relative;background:#000;overflow:hidden}.player-wrap video,.player-wrap .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}.player-wrap .ph{display:flex;align-items:center;justify-content:center;color:var(--fg-4);font-family:var(--mono);font-size:12px;background:repeating-linear-gradient(45deg,transparent 0 12px,rgba(255,255,255,.02) 12px 13px),#000}.now-playing{position:absolute;left:16px;top:16px;padding:8px 12px;background:#0a0a0abf;backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:3px;font-family:var(--mono);font-size:11px;color:var(--fg-2);display:flex;align-items:center;gap:10px}.now-playing .live{display:inline-flex;align-items:center;gap:5px;color:var(--accent)}.now-playing .live .d{width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 1.5px #07c16040;animation:mp-pulse 1.6s ease-in-out infinite}.now-playing .ch-name{color:var(--fg)}.now-playing .ch-meta{color:var(--fg-3)}.panel-bottom{border-top:1px solid var(--line);padding:12px 16px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:16px;font-family:var(--mono);font-size:11px}.panel-bottom .card{background:var(--ink-2);border:1px solid var(--line);border-radius:3px;padding:10px 12px}.panel-bottom .card .lbl{color:var(--fg-3);font-size:10px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.panel-bottom .card .val{font-size:14px;color:var(--fg)}.panel-bottom .card .val .unit{color:var(--fg-3);font-size:11px;margin-left:2px}.panel-bottom .card .bar{margin-top:6px;height:3px;background:var(--ink-4);border-radius:2px;overflow:hidden}.panel-bottom .card .bar .fill{height:100%;background:var(--accent);width:0%;transition:width .4s}.panel-bottom .card.warn .bar .fill{background:var(--warn)}.panel-bottom .card .sub{margin-top:4px;color:var(--fg-3);font-size:10px}.footer{grid-area:footer;display:flex;align-items:center;padding:0 14px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--fg-3);gap:18px}.footer .item b{color:var(--fg);font-weight:500}.footer .item.ok b{color:var(--accent)}.footer .item.warn b{color:var(--warn)}.footer .right{margin-left:auto;display:flex;gap:16px;color:var(--fg-4)}.shell-admin{display:grid;grid-template-rows:44px 1fr 28px;grid-template-columns:200px 1fr;grid-template-areas:"topbar topbar" "side main" "footer footer";height:100vh}.shell-admin .tag{font-family:var(--mono);font-size:10px;color:var(--accent);padding:2px 6px;border:1px solid var(--accent-line);border-radius:2px;margin-left:6px;text-transform:uppercase;letter-spacing:.08em}.side{grid-area:side;border-right:1px solid var(--line);padding:14px 0}.side-section{font-family:var(--mono);font-size:10px;color:var(--fg-4);text-transform:uppercase;letter-spacing:.08em;padding:6px 16px;margin-top:10px}.side-section:first-child{margin-top:0}.side-item{display:flex;align-items:center;gap:8px;padding:7px 16px;color:var(--fg-2);font-size:13px;cursor:pointer;border-left:2px solid transparent}.side-item:hover{background:var(--ink-2);color:var(--fg)}.side-item.active{background:var(--ink-3);color:var(--fg);border-left-color:var(--accent)}.side-item .ico{font-family:var(--mono);font-size:11px;color:var(--fg-4);min-width:18px}.side-item.active .ico{color:var(--accent)}.admin-main{grid-area:main;overflow-y:auto;padding:22px 26px}.page-h{display:flex;align-items:baseline;gap:12px;margin-bottom:4px}.page-h h1{font-family:var(--serif);font-style:italic;font-weight:400;font-size:28px;margin:0}.page-h .meta{font-family:var(--mono);font-size:11px;color:var(--fg-3)}.page-sub{color:var(--fg-3);font-size:12px;margin-bottom:18px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.stat{background:var(--ink-2);border:1px solid var(--line);border-radius:3px;padding:12px 14px}.stat .lbl{color:var(--fg-3);font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.stat .val{font-family:var(--mono);font-size:22px;color:var(--fg)}.stat .val .unit{color:var(--fg-3);font-size:12px;margin-left:3px}.stat .delta{margin-top:4px;font-family:var(--mono);font-size:11px;color:var(--fg-3)}.stat .delta.up{color:var(--accent)}.stat .bar{margin-top:6px;height:2px;background:var(--ink-4);border-radius:1px;overflow:hidden}.stat .bar .fill{height:100%;background:var(--accent)}.panel{background:var(--ink-2);border:1px solid var(--line);border-radius:3px;overflow:hidden}.panel-h{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em}.panel-h .ttl{color:var(--fg)}.panel-h .right{margin-left:auto;display:flex;gap:8px}.panel-h button{background:none;border:1px solid var(--line-2);color:var(--fg-2);padding:3px 10px;border-radius:3px;font-family:var(--mono);font-size:11px;cursor:pointer}.panel-h button.primary{background:var(--accent);border-color:var(--accent);color:var(--ink);font-weight:500}.panel-h button:hover{border-color:var(--line-3);color:var(--fg)}.panel-h button.primary:hover{filter:brightness(1.1)}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;font-family:var(--mono);font-weight:500;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);padding:8px 14px;border-bottom:1px solid var(--line);background:var(--ink-3)}tbody td{padding:9px 14px;border-bottom:1px solid var(--line);color:var(--fg-2)}tbody tr:hover td{background:var(--ink-3);color:var(--fg)}tbody td.mono,td.num{font-family:var(--mono);font-size:12px}tbody td.user-c{color:var(--fg)}tbody td .badge{display:inline-block;font-family:var(--mono);font-size:10px;padding:1px 6px;border-radius:2px;border:1px solid var(--line-2);color:var(--fg-3)}tbody td .badge.admin,tbody td .badge.enabled{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}tbody td .badge.disabled{color:var(--danger);border-color:#e5484d59;background:#e5484d0f}.quota-bar{display:inline-block;vertical-align:middle;width:80px;height:4px;background:var(--ink-4);border-radius:2px;overflow:hidden;margin-right:6px}.actions a{color:var(--fg-3);cursor:pointer;font-family:var(--mono);font-size:11px;margin-right:10px}.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:18px;background:#000000ad}.modal{width:min(440px,100%);background:var(--ink);border:1px solid var(--accent-line);border-radius:4px;box-shadow:0 28px 90px -36px #000000f2;font-family:var(--mono)}.modal-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);color:var(--fg);font-size:12px;text-transform:uppercase;letter-spacing:.06em}.modal-h button,.modal-actions button{background:none;border:1px solid var(--line-2);color:var(--fg-2);border-radius:3px;font-family:var(--mono);font-size:11px;cursor:pointer}.modal-h button{width:26px;height:24px;padding:0}.modal-h button:hover,.modal-actions button:hover{border-color:var(--accent-line);color:var(--fg)}.modal-body{display:grid;gap:12px;padding:14px}.modal-field{display:grid;gap:5px;color:var(--fg-3);font-size:10px;text-transform:uppercase;letter-spacing:.06em}.modal-field input,.modal-field select{width:100%;height:34px;padding:0 9px;background:var(--ink-3);border:1px solid var(--line);border-radius:3px;color:var(--fg);font-family:var(--mono);font-size:12px;outline:none}.modal-field input:focus,.modal-field select:focus{border-color:var(--accent-line)}.modal-field.check{grid-template-columns:1fr auto;align-items:center}.modal-field.check input{width:16px;height:16px;accent-color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}.modal-actions button{min-width:70px;height:30px;padding:0 12px}.modal-actions button[type=submit]{background:var(--accent);border-color:var(--accent);color:var(--ink);font-weight:600}.player-wrap{position:relative}.hud{display:flex;align-items:center;gap:16px;padding:8px 14px;margin-top:8px;border-radius:6px;background:var(--ink-2);border:1px solid var(--line);font-family:var(--mono);font-size:11.5px;line-height:1.2;color:var(--fg-2);user-select:none;white-space:nowrap;overflow-x:auto;scrollbar-width:none}.hud::-webkit-scrollbar{display:none}.hud-status{display:inline-flex;align-items:center;gap:6px;padding-right:14px;border-right:1px solid var(--line)}.hud-dot{width:6px;height:6px;border-radius:50%;background:var(--fg-4);flex-shrink:0;box-shadow:0 0 0 1.5px #ffffff0a;transition:background .2s ease}.hud-dot--ready{background:var(--fg-4)}.hud-status-t{font-size:11px;color:var(--fg-2);letter-spacing:.02em}.hud-cell{display:inline-flex;align-items:baseline;gap:5px}.hud-k{color:var(--fg-3);font-size:10.5px;letter-spacing:.04em}.hud-v{color:var(--fg);font-variant-numeric:tabular-nums;min-width:1ch}.hud-u{color:var(--fg-4);font-size:10px}.mobile-toggle,.mobile-backdrop{display:none}body{font-size:13.5px}.shell-player,.shell-admin{background:radial-gradient(1200px 600px at 80% -10%,var(--accent-glow),transparent 60%),var(--ink)}.topbar{height:48px;background:#0a0a0ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:sticky;top:0;z-index:5}.shell-player,.shell-admin{grid-template-rows:48px 1fr 28px}.topbar .brand{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-style:normal;font-size:13px}.topbar .brand .brand-mark{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--accent);letter-spacing:-.01em}.topbar .brand .brand-host{color:var(--fg);font-weight:500}.topbar .brand .sub{color:var(--fg-3);font-size:11px}.topbar-meta{gap:14px}.top-pill{display:inline-flex;align-items:baseline;gap:5px;padding:4px 10px;border:1px solid var(--line);border-radius:3px;color:var(--fg-2);font-size:11.5px;white-space:nowrap}.top-pill b{color:var(--fg);font-weight:500}.top-pill .u{color:var(--fg-4);font-size:10.5px}.top-pill.accent{border-color:var(--accent-line)}.top-pill.accent b{color:var(--accent)}.top-user{display:inline-flex;align-items:center;gap:7px}.top-user .role{font-size:10px;color:var(--fg-3);padding:1px 6px;border:1px solid var(--line-2);border-radius:2px;text-transform:uppercase;letter-spacing:.06em}.top-user .role.admin{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}.top-user .name{color:var(--fg);font-weight:500}.sb-list li{position:relative;padding:5px 14px 5px 12px;display:grid;grid-template-columns:32px 1fr auto;align-items:baseline;gap:8px;border-left:none;font-size:12.5px}.sb-list li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:22px;background:transparent;border-radius:2px;transition:background .15s ease}.sb-list li.active{background:linear-gradient(90deg,var(--accent-dim),transparent 70%)}.sb-list li.active:before{background:var(--accent)}.sb-list li .name{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.sb-list li .num{text-align:right;min-width:0;font-size:10.5px}.sb-list li .q{border:none;padding:0;font-size:9.5px;color:var(--fg-4);background:transparent}.shell-player .main{display:flex;flex-direction:column;gap:14px;padding:18px 22px 22px;overflow-y:auto;overflow-x:hidden}.shell-player .player-wrap{position:relative;aspect-ratio:16 / 9;background:#000;border:1px solid var(--line);border-radius:4px;overflow:hidden;height:auto;flex-shrink:0}.shell-player .player-wrap video,.shell-player .player-wrap .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}.now-playing{left:12px;top:12px;padding:6px 12px;background:#00000073;border:1px solid rgba(255,255,255,.08);border-radius:4px}.hud{display:flex;align-items:center;gap:16px;padding:10px 16px;background:var(--ink-2);border:1px solid var(--line);border-radius:4px;font-family:var(--mono);font-size:12px;color:var(--fg-2);user-select:none;white-space:nowrap;overflow-x:auto;scrollbar-width:none;margin-top:0}.hud-status{display:inline-flex;align-items:center;gap:7px;padding-right:14px;border-right:1px solid var(--line)}.hud-dot,.hud-dot--ready{background:var(--fg-5)}.hud-dot--live{background:var(--accent);animation:mp-pulse 2.4s ease-in-out infinite}.hud-dot--loading{background:var(--warn);animation:mp-pulse 1.2s ease-in-out infinite}.hud-dot--err{background:var(--danger)}.hud-status-t{color:var(--fg);font-size:11.5px}.hud-k{color:var(--fg-3);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em}.hud-v{color:var(--fg);font-weight:500;font-variant-numeric:tabular-nums;min-width:1ch}.hud-v--accent{color:var(--accent)}.hud-u{color:var(--fg-4);font-size:10.5px}.hud-meta{margin-left:auto;color:var(--fg-3);font-size:10.5px;padding-left:14px}.panel-bottom{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:10px}.card{padding:14px 16px;background:var(--ink-2);border:1px solid var(--line);border-radius:4px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s ease}.card:hover{border-color:var(--line-2)}.card .lbl{font-family:var(--mono);font-size:10.5px;color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.card .val{font-family:var(--serif);font-style:italic;font-size:32px;line-height:1.05;color:var(--fg);font-weight:400}.card .val .unit{font-family:var(--mono);font-style:normal;font-size:13px;color:var(--fg-3);margin-left:6px;letter-spacing:.02em}.card .bar{height:3px;background:var(--ink-4);border-radius:2px;margin-top:2px}.card .bar .fill{height:100%;background:var(--accent);transition:width .4s ease}.card.warn .bar .fill{background:var(--warn)}.card .sub{font-family:var(--mono);font-size:10.5px;color:var(--fg-3);display:flex;justify-content:space-between;align-items:baseline}.footer{height:28px;font-family:var(--mono);font-size:10.5px;color:var(--fg-3);padding:0 18px}.footer .item{display:inline-flex;align-items:center;gap:6px;margin-right:18px}.footer .item b{color:var(--fg-2);font-weight:500}.footer .right{margin-left:auto}.footer .right span{color:var(--fg-4);margin-left:18px}.shell-admin{display:grid;grid-template-columns:220px 1fr;grid-template-rows:48px 1fr 28px;grid-template-areas:"topbar topbar" "side main" "footer footer";height:100vh}.shell-admin .side{grid-area:side;border-right:1px solid var(--line);padding:14px 0;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.shell-admin .side-section{padding:10px 16px 4px;font-family:var(--mono);font-size:9.5px;color:var(--fg-4);letter-spacing:.1em;text-transform:uppercase}.shell-admin .side-item{display:flex;align-items:center;padding:7px 16px;margin:1px 8px;border-radius:3px;color:var(--fg-2);font-size:13px;cursor:pointer;transition:background .12s ease,color .12s ease;position:relative}.shell-admin .side-item .side-badge{margin-left:auto}.shell-admin .side-item:hover{background:var(--ink-3);color:var(--fg)}.shell-admin .side-item.active{background:var(--accent-dim);color:var(--fg)}.shell-admin .side-item.active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:2px;height:18px;background:var(--accent);border-radius:2px}.shell-admin .side-item .ico{color:var(--fg-4);font-family:var(--mono);font-size:11px;width:14px;text-align:center;margin-right:8px}.shell-admin .side-item.active .ico{color:var(--accent)}.shell-admin .side-item .side-badge{font-family:var(--mono);font-size:9.5px;color:var(--fg-4);padding:1px 5px;border:1px solid var(--line-2);border-radius:2px}.shell-admin .side-item.active .side-badge{color:var(--accent);border-color:var(--accent-line)}.shell-admin .admin-main{padding:22px 28px 28px;overflow-y:auto}.admin-main .page-h{display:flex;align-items:baseline;gap:12px;margin-bottom:4px}.admin-main .page-h h1{font-family:var(--serif);font-style:italic;font-weight:400;margin:0;font-size:28px;color:var(--fg);letter-spacing:-.005em}.admin-main .page-h .meta{font-family:var(--mono);font-size:11px;color:var(--fg-4)}.admin-main .page-sub{color:var(--fg-3);font-size:12.5px;margin-bottom:18px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}.stat{padding:14px 16px;background:var(--ink-2);border:1px solid var(--line);border-radius:4px;display:flex;flex-direction:column;gap:4px;transition:border-color .15s ease}.stat:hover{border-color:var(--line-2)}.stat .lbl{font-family:var(--mono);font-size:10px;color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em}.stat .val{font-family:var(--serif);font-style:italic;font-size:30px;line-height:1.1;color:var(--fg);font-weight:400}.stat .val .unit{font-family:var(--mono);font-style:normal;font-size:12px;color:var(--fg-3);margin-left:4px}.stat .bar{height:2px;background:var(--ink-4);border-radius:1px;margin-top:4px}.stat .bar .fill{height:100%;background:var(--accent);transition:width .4s ease}.stat.warn{border-color:#ff9e3d52}.stat.warn .bar .fill{background:var(--warn)}.stat .delta{font-family:var(--mono);font-size:10px;color:var(--fg-3)}.stat .delta.warn{color:var(--warn)}.panel{background:var(--ink-2);border:1px solid var(--line);border-radius:4px;margin-bottom:18px;overflow:hidden}.panel-h{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11.5px;color:var(--fg-3)}.panel-h .ttl{color:var(--fg);font-family:var(--sans);font-size:13px;font-weight:500}.panel-h .right{margin-left:auto;display:flex;gap:8px;align-items:center}table{width:100%;border-collapse:collapse;font-size:12px}table thead th{text-align:left;padding:9px 14px;font-family:var(--mono);font-size:10px;color:var(--fg-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);background:#00000026}table tbody td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--fg-2)}table tbody tr:hover{background:var(--ink-3)}table tbody td.user-c{color:var(--fg);font-weight:500;font-family:var(--mono)}table tbody td.num{font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--fg-2)}.badge{display:inline-block;padding:1px 7px;border-radius:2px;font-family:var(--mono);font-size:10px;border:1px solid var(--line-2);color:var(--fg-3);letter-spacing:.02em}.badge.admin{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}.badge.user{color:var(--fg-3)}.badge.enabled{color:var(--accent);border-color:var(--accent-line)}.badge.disabled{color:var(--fg-4)}.quota-bar{display:inline-block;width:100px;height:3px;background:var(--ink-4);border-radius:2px;overflow:hidden;vertical-align:middle;margin-right:8px}.quota-bar .fill{height:100%;background:var(--accent)}.quota-bar.warn .fill{background:var(--warn)}.actions a{color:var(--fg-3);cursor:pointer;font-family:var(--mono);font-size:11px;margin-right:12px}.actions a:hover{color:var(--accent)}.actions a.danger:hover{color:var(--danger)}.btn-sm{background:none;border:1px solid var(--line-2);color:var(--fg-2);padding:3px 9px;font-family:var(--mono);font-size:10.5px;border-radius:3px;cursor:pointer;transition:all .15s}.btn-sm:hover{border-color:var(--accent-line);color:var(--fg)}.btn-sm.primary{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}.btn-sm.primary:hover{background:#07c1602e}.table-scroll{width:100%;overflow-x:auto}.detail-cell{max-width:420px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state{padding:18px 16px;color:var(--fg-3);font-family:var(--mono);font-size:12px}.filter-bar{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap;margin-bottom:12px;padding:10px;background:var(--ink-2);border:1px solid var(--line);border-radius:4px}.filter-field{display:grid;gap:4px;min-width:120px;color:var(--fg-3);font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em}.filter-field input,.filter-field select,.settings-form input,.settings-form textarea,.modal-field textarea{width:100%;background:var(--ink-3);border:1px solid var(--line);border-radius:3px;color:var(--fg);font-family:var(--mono);font-size:12px;outline:none}.filter-field input,.filter-field select,.settings-form input{height:32px;padding:0 8px}.settings-form textarea,.modal-field textarea{min-height:70px;padding:8px;resize:vertical}.filter-field input:focus,.filter-field select:focus,.settings-form input:focus,.settings-form textarea:focus,.modal-field textarea:focus{border-color:var(--accent-line)}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:10px 14px;border-top:1px solid var(--line);color:var(--fg-3);font-family:var(--mono);font-size:11px}.pagination button:disabled{opacity:.4;cursor:not-allowed}.settings-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:14px}.settings-form .modal-field{text-transform:none;letter-spacing:0}.settings-form .modal-field:has(textarea),.settings-actions{grid-column:1 / -1}.settings-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding-top:10px;border-top:1px solid var(--line)}.save-ok{min-width:64px;color:var(--accent);font-family:var(--mono);font-size:11px}.channel-form{grid-template-columns:repeat(2,minmax(0,1fr))}.channel-form .modal-field:nth-child(7),.channel-form .modal-actions{grid-column:1 / -1}.wide-input{min-width:0}@media (max-width: 768px){.filter-bar{align-items:stretch}.filter-field{min-width:min(100%,180px);flex:1 1 160px}.settings-form,.channel-form{grid-template-columns:1fr}.channel-form .modal-field:nth-child(7),.channel-form .modal-actions,.settings-form .modal-field:has(textarea),.settings-actions{grid-column:auto}body{font-size:13px}.topbar{height:auto;min-height:44px;padding:6px 12px;flex-wrap:wrap;gap:8px}.topbar .brand{gap:6px;font-size:12px}.topbar .brand .brand-mark{font-size:16px}.topbar .brand .brand-host,.topbar .brand .sub{display:none}.topbar-meta{gap:8px;flex-wrap:wrap}.top-pill{padding:3px 8px;font-size:10.5px}.top-user .name{max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-meta button{padding:3px 7px;font-size:10.5px}.shell-player{grid-template-columns:1fr;grid-template-rows:auto 1fr 24px;grid-template-areas:"topbar" "main" "footer"}.shell-player .sidebar{position:fixed;top:0;left:0;width:80vw;max-width:320px;height:100vh;background:var(--ink);border-right:1px solid var(--line);transform:translate(-100%);transition:transform .25s ease;z-index:20;overflow-y:auto;box-shadow:0 0 40px #0009}.shell-player .sidebar.open{transform:translate(0)}.shell-player .main{padding:12px;gap:10px;overflow-y:visible;min-height:0}.shell-player{height:auto;min-height:100vh}.shell-player .player-wrap{aspect-ratio:16 / 9;max-height:50vh}.mobile-toggle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:30px;background:none;border:1px solid var(--line-2);color:var(--fg-2);border-radius:3px;font-family:var(--mono);font-size:14px;cursor:pointer;line-height:1}.mobile-toggle:active{background:var(--ink-3)}.mobile-backdrop{position:fixed;inset:0;background:#00000080;z-index:15;display:none}.mobile-backdrop.show{display:block}.hud{gap:10px;padding:7px 10px;font-size:11px}.hud-status{padding-right:10px}.hud-meta{display:none}.panel-bottom{grid-template-columns:1fr;gap:8px}.card{padding:12px}.card .val{font-size:26px}.footer{padding:0 12px;height:24px;font-size:9.5px}.footer .item{margin-right:10px}.footer .item:nth-child(n+3){display:none}.shell-admin{grid-template-columns:1fr;grid-template-rows:auto 1fr 24px;grid-template-areas:"topbar" "main" "footer"}.shell-admin .side{position:fixed;top:0;left:0;width:75vw;max-width:280px;height:100vh;background:var(--ink);border-right:1px solid var(--line);transform:translate(-100%);transition:transform .25s ease;z-index:20;box-shadow:0 0 40px #0009}.shell-admin .side.open{transform:translate(0)}.shell-admin .admin-main{padding:14px 12px 18px;overflow-y:visible}.shell-admin{height:auto;min-height:100vh}.admin-main .page-h h1{font-size:22px}.stats{grid-template-columns:1fr 1fr;gap:8px}.stat{padding:10px 12px}.stat .val{font-size:24px}.panel table{font-size:11.5px}.panel table thead th,.panel table tbody td{padding:8px 10px}.panel{overflow-x:auto}.panel-h{padding:10px 12px}.panel-h .right .btn-sm{padding:3px 7px;font-size:10px}.actions a{margin-right:8px;font-size:10.5px}.modal{width:100%;max-width:none;border-radius:4px 4px 0 0;align-self:end}.modal-backdrop{padding:0;place-items:end center}.modal-body{padding:12px;gap:10px}.modal-field input,.modal-field select{height:38px;font-size:13px}@media (min-width: 769px){.mobile-toggle,.mobile-backdrop{display:none}}}
