.admin{--bg: #f8faf7;--panel: #ffffff;--line: #dce3d8;--ink: #1d231f;--muted: #59635c;--muted-2: #88918a;--brand: #122416;--accent: #4a7c19;--accent-ink: #ffffff;--danger: #d64545;--ok: #4caf50;--panel-alt: #f6f8f4;--surface-2: #f1f5ef;--hover: #f1f5ef;--hover-soft: #f4f7f1;--active-tint: #dff2c6;--hover-accent: #eaf5d9;--chip-bg: #edf1ea;--chip-bg-hover: #dfe6da;--input-bg: #ffffff;--btn-border-hover: #c2ccbd;--focus-ring: rgba(139, 197, 63, .35);--accent-strong: #33691e;--brand-green: #8bc53f;--brand-green-hover: #7cb433;--brand-green-ink: #10181f;--rail-bg: var(--brand);--rail-ink: #eef3ea;--rail-muted: #a7b5a2;--rail-line: rgba(255, 255, 255, .09);--nav-active-bg: #46561e;--rail-section: #93a48e;--danger-tint: #fdecea;--danger-line: #ecc7c3;--warn-ink: #b26a00;--warn-tint: #fff3e0;--warn-line: #ecc78f;--ok-tint: #e3f5eb;--info-tint: #eaf1fb;--info-line: #c6dbf2;--dot-off: #c6cec2;--trim-track: #e4eae0;--backdrop: rgba(8, 14, 10, .45);--pane-tree: 250px;--pane-tree-narrow: 210px;--shadow-menu: 0 10px 30px rgba(12, 28, 16, .18);--shadow-card: 0 8px 22px rgba(12, 28, 16, .14);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .3);color-scheme:light;position:fixed;top:0;right:0;bottom:0;left:0;display:flex;background:var(--bg);color:var(--ink);font-family:Inter Variable,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;overflow:hidden}.admin.dark{--bg: #0c0f11;--panel: #131617;--line: #1d2725;--ink: #f2f4f0;--muted: #a6adaa;--muted-2: #7b837f;--accent: #82b32c;--accent-ink: #ffffff;--danger: #e06557;--ok: #82b32c;--panel-alt: #181b1d;--surface-2: #0f1214;--hover: #191c1b;--hover-soft: #151817;--active-tint: #152119;--hover-accent: #1d2b16;--chip-bg: #1b1e1d;--chip-bg-hover: #232726;--input-bg: #121c1b;--btn-border-hover: #2c302f;--focus-ring: rgba(130, 179, 44, .4);--accent-strong: #8bc53f;--brand-green: #8bc53f;--brand-green-hover: #7cb433;--brand-green-ink: #10181f;--rail-bg: #0d1110;--rail-ink: #eaece9;--rail-muted: #d2d6d3;--rail-section: #a3aaa6;--rail-line: rgba(255, 255, 255, .06);--nav-active-bg: #243811;--danger-tint: #3a2320;--danger-line: #5f3730;--warn-ink: #e2a457;--warn-tint: #382c17;--warn-line: #5c4826;--ok-tint: #1a3018;--info-tint: #14202e;--info-line: #2a4a6e;--dot-off: #4c5451;--trim-track: #1a2422;color-scheme:dark}.admin.dark select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%2393a3b5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}.admin.dark .search-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2393a3b5' stroke-width='2.4'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.3-4.3'/%3E%3C/svg%3E")}.admin:not(.dark) .admin-nav{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E"),linear-gradient(180deg,#17301d,#122416 55%,#0d1a10)}.admin.dark .admin-nav{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E"),linear-gradient(180deg,#111716,#0b0e0d 62%,#090c0b)}.admin-nav{width:248px;flex:0 0 248px;background:var(--rail-bg);color:var(--rail-ink);display:flex;flex-direction:column;align-items:stretch;padding:calc(18px + env(safe-area-inset-top)) 16px calc(14px + env(safe-area-inset-bottom)) calc(20px + env(safe-area-inset-left));border-right:1px solid var(--rail-line);min-height:0}.admin-nav .brand{display:flex;align-items:center;gap:12px;padding:6px 12px 16px}.admin-nav .brand .wordmark{font-size:15px;font-weight:700;letter-spacing:.3em;color:#fff;transform:translateY(1px)}.nav-scroll{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.nav-section{display:block;margin:16px 0 6px;text-decoration:none;padding:0 12px;font-size:11px;font-weight:700;letter-spacing:.14em;color:var(--rail-section)}.nav-more{display:none;position:relative}.nav-scroll .nav-section+.nav-section,.nav-scroll a+.nav-section,.nav-scroll .nav-add+.nav-section{border-top:1px solid var(--rail-line);padding-top:20px;margin-top:20px}.admin-nav a,.admin-nav .nav-add{display:flex;flex-direction:row;align-items:center;gap:12px;padding:11px 12px;margin:2px 0;border:none;border-radius:12px;background:none;color:var(--rail-muted);text-decoration:none;font-weight:600;font-size:14px;letter-spacing:.01em;text-align:left;cursor:pointer}.nav-bottom-row{margin-top:auto;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding-top:12px}.nav-bottom-row .nav-add{margin:0;min-width:0;height:40px;align-items:center;justify-content:center;gap:6px;padding:0 2px;font-size:12.5px;letter-spacing:0;border-radius:10px}.nav-bottom-row .nav-add span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-bottom-row .nav-add svg{width:16px;height:16px;flex:0 0 auto}.admin-nav a:hover,.admin-nav .nav-add:hover{background:#ffffff0f;color:#fff}.admin-nav a.active{background:var(--nav-active-bg);color:#fff}.admin-nav a span,.admin-nav .nav-add span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-nav a svg{flex:0 0 auto}.admin.dark .admin-nav a.nav-screen.active{background:#17261f}.nav-dot{margin-left:auto;width:7px;height:7px;border-radius:999px;background:var(--brand-green);flex:0 0 auto}a.nav-screen.offline{opacity:.55}.admin-nav .nav-foot{border-top:1px solid var(--rail-line);margin-top:10px;padding-top:10px}.admin-nav .who{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;padding:0 4px}.who-avatar{width:30px;height:30px;border-radius:50%;background:#ffffff29;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.rail-btn{border:none;background:none;color:var(--rail-muted);padding:6px;border-radius:8px;display:flex}.rail-btn:hover{background:#ffffff1a;color:#fff;border:none}a.rail-btn.active{background:var(--nav-active-bg);color:#fff}.admin-nav a.nav-only-phone{display:none}.admin-nav .nav-add{background:#ffffff0d}.admin.dark .admin-nav .nav-add{background:var(--chip-bg);box-shadow:inset 0 1px #ffffff0a}.admin.dark .admin-nav .nav-add:hover{background:var(--chip-bg-hover);color:#fff}.admin-nav .user-card,.admin.dark .admin-nav .user-card{display:flex;align-items:center;gap:11px;width:100%;padding:12px;border:none;border-radius:14px;background:none;box-shadow:none;color:var(--rail-ink);text-align:left;cursor:pointer}.admin-nav .user-card:hover,.admin.dark .admin-nav .user-card:hover{background:#ffffff0d;border:none}.user-card-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.admin-nav .user-card .who-avatar{width:38px;height:38px;font-size:13px}.user-card-meta b{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-meta>span{font-size:11.5px;color:var(--rail-muted)}.user-card-chev{flex:0 0 auto;color:var(--rail-muted);transition:transform .15s ease}.user-card-chev.open{transform:rotate(180deg)}.admin-main{flex:1;overflow:auto;padding:28px 34px 60px}.admin-main h1{margin:0 0 4px;font-size:24px}.admin-main .sub{color:var(--muted);margin:0 0 22px}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px 16px;margin-bottom:18px;flex-wrap:wrap}.page-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.page-actions button,.np-head-actions button{height:36px;padding-top:0;padding-bottom:0;display:inline-flex;align-items:center}.page-actions .view-toggle{height:36px}.page-actions .view-toggle button{height:34px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:12px 16px;border-bottom:1px solid var(--line);background:var(--panel-alt)}td{padding:12px 16px;border-bottom:1px solid var(--line);vertical-align:middle}tr:last-child td{border-bottom:none}tr.clickable:hover td{background:var(--hover-soft);cursor:pointer}button{font:inherit;cursor:pointer;border:1px solid var(--line);background:var(--input-bg);color:var(--ink);padding:8px 14px;border-radius:8px;font-weight:600}button:hover{border-color:var(--btn-border-hover)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{background:color-mix(in srgb,var(--accent) 85%,#000);border-color:transparent}button.danger{color:var(--danger);border-color:var(--danger-line)}button.small{padding:5px 10px;font-size:13px}.admin.dark button{background:var(--chip-bg);border-color:transparent}.admin.dark button:hover{background:var(--chip-bg-hover);border-color:transparent}.admin.dark button.primary{background:var(--accent);border-color:transparent;color:#fff}.admin.dark button.danger{border-color:var(--danger-line)}.admin.dark input,.admin.dark select,.admin.dark textarea,.admin.dark .panel,.admin.dark .screen-card,.admin.dark .chip,.admin.dark .filter-btn{border-color:transparent}.admin.dark .panel,.admin.dark .screen-card{box-shadow:inset 0 1px #ffffff0a,0 12px 32px #00000052}.admin.dark button{background:linear-gradient(180deg,var(--chip-bg-hover),var(--chip-bg));box-shadow:inset 0 1px #ffffff0d}.admin.dark button:hover{background:linear-gradient(180deg,#262b28,var(--chip-bg-hover))}.admin.dark button.primary{background:var(--accent);box-shadow:none}.admin.dark button.primary:hover{background:color-mix(in srgb,var(--accent) 85%,#000)}.admin.dark .np-icon-btn{background:transparent;box-shadow:none}input,select{font:inherit;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--input-bg);color:var(--ink)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:32px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%236b7787' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center}input:focus,select:focus{outline:2px solid var(--focus-ring);border-color:var(--accent)}.chip-picker{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:var(--input-bg);color:var(--muted);font-weight:600;font-size:13px}.chip.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.chip.removable{display:inline-flex;align-items:center;gap:5px}.chip.removable button{border:none;background:none;color:inherit;padding:0 1px;font-size:14px;line-height:1;opacity:.75}.chip.removable button:hover{opacity:1;border:none}.chip.add{display:inline-flex;align-items:center;gap:4px;border-style:dashed;color:var(--muted)}.chip.add:hover{color:var(--accent);border-color:var(--accent)}.tag-picker{position:relative;display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.tag-bar{position:relative;display:inline-flex;align-items:center;gap:7px;flex-wrap:wrap;background:var(--input-bg);border:1px solid var(--line);border-radius:20px;padding:5px 6px 5px 12px;min-height:40px}.tag-bar-label{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--muted);padding-right:8px;border-right:1px solid var(--line)}.tag-bar-none{font-size:13px;color:var(--muted);font-style:italic}.tag-bar .chip.all-screens{background:var(--ink);border-color:var(--ink);color:var(--panel)}.tag-bar-add{border:none;background:none;font-size:13px;font-weight:700;color:var(--accent);padding:4px 10px 4px 12px;border-left:1px solid var(--line);border-radius:0;margin-left:auto}.tag-bar-add:hover{border:none;border-left:1px solid var(--line);text-decoration:underline;text-underline-offset:3px}.scope-bar{display:inline-flex;align-items:center;gap:7px;background:var(--input-bg);border:1px solid var(--line);border-radius:20px;padding:5px 8px 5px 12px;min-height:40px}.scope-bar .tag-bar-label{border-right:none;padding-right:0}.scope-bar select{border:none;background:none;font-size:13px;font-weight:600;color:var(--ink);padding:4px 2px}.tag-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:30;min-width:180px;max-height:240px;overflow:auto;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-menu);padding:6px;gap:2px}.tag-menu input{padding:6px 8px;font-size:13px;margin-bottom:4px}.tag-menu>button{border:none;background:none;text-align:left;padding:7px 9px;border-radius:7px;font-size:13px;font-weight:500}.tag-menu>button:hover{background:var(--hover-accent);border:none}.tag-menu .muted{padding:6px 9px;font-size:12px}.tag-menu-section{padding:7px 9px 2px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:5px}.field{margin-bottom:14px}.inline-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.badge{display:inline-block;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;background:var(--chip-bg);color:var(--muted)}.badge.active{background:var(--ok-tint);color:var(--ok)}.badge.inactive,.badge.unprovisioned{background:var(--danger-tint);color:var(--danger)}.badge.hold,.badge.pending{background:var(--warn-tint);color:var(--warn-ink)}.muted{color:var(--muted)}.empty{padding:40px;text-align:center;color:var(--muted)}.error-banner{background:var(--danger-tint);color:var(--danger);border:1px solid var(--danger-line);padding:10px 14px;border-radius:8px;margin-bottom:16px}.login-wrap{--ink: #1d231f;--muted: #59635c;--line: #dce3d8;--accent: #4a7c19;--accent-ink: #ffffff;--danger: #c0392b;--danger-tint: #fdecea;--danger-line: #ecc7c3;--input-bg: #ffffff;--btn-border-hover: #c2ccbd;--focus-ring: rgba(139, 197, 63, .35);--accent-strong: #33691e;color-scheme:light;color:var(--ink);position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#122416,#0b110d)}.login-card{background:#fff;width:360px;padding:34px 30px;border-radius:16px;box-shadow:0 20px 60px #00000059}.login-card h1{font-family:Georgia,serif;margin:0 0 4px;font-size:22px}.login-card h1.login-brand{font-family:inherit;display:flex;align-items:center;justify-content:center;gap:10px;font-size:20px;font-weight:700;letter-spacing:.09em;color:#1c2733;margin-bottom:14px}.login-card p{color:var(--muted);margin:0 0 22px;font-size:14px}.login-card input{width:100%}.login-card button{width:100%;margin-top:6px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--panel);border-radius:14px;width:440px;max-width:calc(100vw - 40px);max-height:calc(100vh - 32px);max-height:calc(100dvh - 32px);display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px 12px;flex:0 0 auto}.modal h3{margin:0}.modal-x{border:none;background:none;color:var(--muted);font-size:24px;line-height:1;padding:2px 8px;border-radius:8px}.modal-x:hover{border:none;background:var(--hover);color:var(--ink)}.modal-body{overflow-y:auto;padding:0 24px 24px;min-height:0}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal.wide{width:880px}.info-banner{background:var(--info-tint);color:var(--accent-strong);border:1px solid var(--info-line);padding:10px 14px;border-radius:8px;margin-bottom:16px}.panel.drop-target{outline:2px dashed var(--accent);outline-offset:-2px}.media-lightbox{background:#131c15;border-radius:14px;padding:14px;max-width:min(880px,calc(100vw - 60px));max-height:calc(100vh - 80px);display:flex;flex-direction:column;gap:10px;box-shadow:0 20px 60px #00000080}.media-lightbox img,.media-lightbox video{max-width:100%;max-height:calc(100vh - 180px);border-radius:8px}.media-lightbox-title{color:#eaf2f8;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:10px 16px}.media-lightbox-title button{white-space:nowrap}.media-lightbox .modal-x{color:#93a3b5}.media-lightbox .modal-x:hover{background:#ffffff14;color:#eaf2f8}@media(max-width:560px){.media-lightbox{max-width:calc(100vw - 24px);padding:12px}.media-lightbox-title{flex-wrap:wrap}.media-lightbox-title>span{width:100%;justify-content:flex-end;flex-wrap:wrap}.media-lightbox-title button{font-size:12px;padding:6px 10px}}.media-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.toolbar-sep{width:1px;height:20px;background:var(--line);margin:0 2px}.search-input{width:280px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b7787' stroke-width='2.4'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.3-4.3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:10px center;padding-left:32px}.media-layout{display:grid;grid-template-columns:var(--pane-tree) 1fr;gap:14px;align-items:start}@media(max-width:1280px){.media-layout{grid-template-columns:var(--pane-tree-narrow) 1fr}}@media(max-width:860px){.media-layout{grid-template-columns:1fr}}@media(max-width:1100px){.hide-narrow{display:none}}@media(max-width:560px){.hide-phone{display:none}}.tag-checklist{border:1px solid var(--line);border-radius:8px;background:var(--input-bg);padding:8px 10px;max-height:220px;overflow-y:auto}.tag-checklist .filter-group+.filter-group{margin-top:10px}.media-browser-head .search-input{flex:1;min-width:0;width:auto}.tree-caret{border:none;background:none;padding:0;width:14px;flex:0 0 14px;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;transition:transform .12s ease}.tree-caret.open{transform:rotate(90deg)}.tree-caret.hidden{visibility:hidden}.tree-icon{display:inline-flex;align-items:center;color:var(--muted);flex:0 0 auto}.media-main-plain{min-width:0}.filter-btn{display:inline-flex;align-items:center;gap:6px;font-weight:600}.filter-btn.on{border-color:var(--accent);color:var(--accent);background:var(--hover-accent)}.filter-badge{background:var(--accent);color:var(--accent-ink);font-size:11px;font-weight:700;border-radius:999px;padding:0 6px;line-height:17px}.filter-panel{padding:12px;max-height:calc(100vh - 220px);overflow:auto}.filter-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.filter-group{margin-top:12px}.filter-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:4px}.filter-row{display:flex;align-items:center;gap:8px;padding:5px 4px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;margin:0;color:var(--ink);text-transform:none;letter-spacing:0}.filter-row:hover{background:var(--hover)}.filter-row input[type=checkbox]{margin:0;accent-color:var(--accent)}.filter-row-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-manage{width:100%;margin-top:16px}.tag-swatch{flex:0 0 4px;width:4px;height:16px;border-radius:999px}.tree-count{margin-left:auto;font-size:11px;color:var(--muted);background:var(--chip-bg);border-radius:999px;padding:1px 7px}.tagmgr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;max-height:55vh;overflow:auto;align-items:start}.tagmgr-card{padding:12px;overflow:visible}.tagmgr-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.tagmgr-row{display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:7px;font-size:13px;font-weight:500}.tagmgr-row:hover{background:var(--hover)}.tagmgr-row .tree-actions{margin-left:auto;opacity:0}.tagmgr-row:hover .tree-actions{opacity:1}.tagmgr-create{width:100%;margin-top:8px;padding:7px 10px;font-size:13px;border-style:dashed}.crumbs{display:flex;align-items:center;gap:2px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--panel-alt);flex-wrap:wrap}.crumb{border:none;background:none;padding:3px 6px;border-radius:6px;font-size:13px;font-weight:600;color:var(--accent);cursor:pointer}.crumb:hover{background:var(--active-tint);border:none}.crumb.current{color:var(--ink);cursor:default}.crumb.current:hover{background:none}.crumb-filters{display:inline-flex;gap:6px;margin-left:12px;flex:0 0 auto}.crumb-sep{color:var(--muted);font-size:13px;padding:0 2px}.crumbs.crumbs-bar{border-radius:12px;border-bottom:none;margin:0 0 14px}.admin.dark .crumbs.crumbs-bar{box-shadow:inset 0 1px #ffffff0a}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--ink)}.folder-row{cursor:pointer}.folder-row:hover td{background:var(--hover-soft)}.folder-row.drop td{background:var(--active-tint);box-shadow:inset 0 0 0 1.5px var(--accent)}tr[draggable=true]{cursor:grab}.panel.library-pane{overflow:visible;container-type:inline-size}.library-pane>.crumbs{border-radius:12px 12px 0 0}.crumb-tools{display:inline-flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}.crumb-tools .crumb-filters{margin-left:0}.view-toggle .icon-btn{height:28px;padding:0 9px}.kind-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--muted);flex:0 0 auto}tr.media-row[draggable=true]{cursor:pointer}.media-row:hover td{background:var(--hover-soft)}.media-table .np-pl-more,.lib-tile .np-pl-more,.folder-chip .np-pl-more{opacity:0}.media-table tr:hover .np-pl-more,.lib-tile:hover .np-pl-more,.folder-chip:hover .np-pl-more,.np-pl-more:focus-within,.np-pl-more:has([aria-expanded=true]){opacity:1}@media(hover:none){.media-table .np-pl-more,.lib-tile .np-pl-more,.folder-chip .np-pl-more{opacity:1}}.row-actions-cell{white-space:nowrap;text-align:right}.row-actions-cell .np-pl-more{display:inline-flex}.row-check,.tile-check{width:15px;height:15px;margin:0;accent-color:var(--accent);cursor:pointer}.row-check{display:none;vertical-align:middle}.media-row:hover .row-check,.media-table.has-sel .row-check,.row-check:checked,.row-check:focus-visible{display:inline-block}.media-row:hover .sel-cell .kind-icon,.media-table.has-sel .sel-cell .kind-icon,.sel-cell:has(.row-check:checked) .kind-icon,.sel-cell:has(.row-check:focus-visible) .kind-icon{display:none}.media-row.selected td,.media-row.selected:hover td{background:var(--active-tint)}.tile-check{position:absolute;top:6px;left:6px;z-index:2;display:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}.lib-tile:hover .tile-check,.lib-board.has-sel .tile-check,.tile-check:checked,.tile-check:focus-visible{display:block}.lib-tile.selected{background:var(--active-tint);outline:2px solid var(--accent);outline-offset:-2px}@media(hover:none){.media-row .row-check,.lib-tile .tile-check{display:inline-block}.media-row .sel-cell .kind-icon{display:none}}.sel-bar{gap:10px}.sel-bar .sel-count{font-size:13px;font-weight:600}.sel-bar button.small{display:inline-flex;align-items:center;gap:6px}.sel-bar .icon-btn.sel-clear{height:28px;padding:0 7px}.kind-icon.folder-tint,.folder-chip>svg.folder-tint{color:var(--accent);opacity:.85}.lib-grid-body{padding-bottom:2px}.lib-grid-body>.empty{padding:28px 16px}.folder-chips{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;padding:14px 16px 0}.folder-chip{display:flex;align-items:center;gap:8px;min-width:0;padding:7px 7px 7px 12px;border:1px solid var(--line);border-radius:10px;background:var(--panel-alt);color:var(--ink);font-size:13px;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none}.folder-chip:hover{background:var(--hover)}.folder-chip:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.folder-chip.drop{background:var(--active-tint);border-color:var(--accent)}.folder-chip>svg{flex:0 0 auto;color:var(--muted)}.folder-chip-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin.dark .folder-chip{border-color:transparent;background:var(--chip-bg);box-shadow:inset 0 1px #ffffff0a}.admin.dark .folder-chip:hover{background:var(--chip-bg-hover)}.admin.dark .folder-chip.drop{background:var(--active-tint);box-shadow:inset 0 0 0 1.5px var(--accent)}.tile-board.lib-board{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.lib-tile:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.lib-tile .tile-badge{top:auto;bottom:6px}.lib-tile .tile-foot{gap:6px;padding-right:5px}.lib-tile .np-pl-more-btn.small{width:26px;height:26px;border-radius:7px}.upl-tile-foot{flex-direction:column;align-items:stretch;gap:4px}.upl-tile-foot .upl-track{margin-top:2px;max-width:none}.upl-tile.failed .tile-name{color:var(--danger)}@container (max-width: 480px){.tile-board.lib-board{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.folder-chips{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:12px 12px 0}}.hover-preview{position:fixed;z-index:90;width:320px;max-width:calc(100vw - 24px);pointer-events:none;display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:12px;background:var(--panel);border:1px solid var(--line);box-shadow:0 18px 44px #00000059;animation:hover-preview-in .14s ease-out}@keyframes hover-preview-in{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.admin.dark .hover-preview{border-color:transparent;box-shadow:inset 0 1px #ffffff0d,0 18px 44px #0000008c}.hover-preview-art{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:8px;background:#0e1510}.hover-preview-art.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);background:var(--panel-alt)}.hover-preview-name{font-size:13px;font-weight:600;overflow-wrap:anywhere}.hover-preview-fact{font-size:12px;color:var(--muted)}.move-list{display:flex;flex-direction:column;gap:2px;max-height:50vh;overflow:auto}.admin .move-list button,.admin.dark .move-list button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:none;background:none;box-shadow:none;padding:8px 12px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--ink)}.admin .move-list button:hover,.admin.dark .move-list button:hover{background:var(--hover)}.admin .move-list button.on,.admin.dark .move-list button.on{background:var(--active-tint);font-weight:600}.move-list button svg{flex:0 0 auto;color:var(--muted)}.move-list button svg:last-child:not(:first-child){margin-left:auto;color:var(--accent)}.detail-status{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:16px}.detail-status label{margin-bottom:3px;font-size:11px}.detail-status span{font-size:14px}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:26px}@media(max-width:900px){.week-grid{grid-template-columns:repeat(4,1fr)}}.week-col{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;min-height:180px}.week-col.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.week-col-head{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--panel-alt);border-bottom:1px solid var(--line)}.today-pill{font-size:10px;color:var(--accent-ink);background:var(--accent);border-radius:999px;padding:1px 7px;text-transform:none;letter-spacing:0;flex:0 0 auto}.week-col-body{display:flex;flex-direction:column;gap:6px;padding:8px;flex:1;max-height:46vh;overflow-y:auto}.sched-card{display:flex;flex-direction:column;align-items:flex-start;gap:1px;text-align:left;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);padding:7px 9px;font-weight:500;min-width:0;max-width:100%;overflow-wrap:anywhere}.sched-card:hover{border-color:var(--accent);background:var(--hover-accent)}.sched-time{font-size:11px;font-weight:700;color:var(--accent)}.sched-card.all .sched-time{color:var(--ok)}.sched-card.screen .sched-time{color:var(--warn-ink)}.sched-name{font-size:13px;font-weight:600;line-height:1.25}.sched-target{font-size:11px;color:var(--muted)}.sched-note{font-size:11px;color:var(--muted);font-style:italic}.sched-add{border:1px dashed var(--line);background:none;color:var(--muted);border-radius:8px;padding:4px;font-size:15px;opacity:0;transition:opacity .12s ease;margin-top:auto}.week-col:hover .sched-add{opacity:1}.sched-add:hover{color:var(--accent);border-color:var(--accent)}.section-title{font-size:16px;margin:0 0 10px}.occurrences-title{margin:18px 0 10px;font-size:15px}.occ-add{width:38px;height:38px;align-self:flex-end;border-radius:10px;font-size:18px;font-weight:700;color:var(--accent);padding:0}.occ-add:disabled{opacity:.5}.occ-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:12px;padding:12px;background:var(--surface-2);border-radius:10px;min-height:56px}.occ-list.empty{justify-content:center;color:var(--muted);font-size:13px}.month-nav{display:flex;align-items:center;gap:10px;margin-bottom:10px}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.month-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:2px 4px}.month-cell{background:var(--panel);border:1px solid var(--line);border-radius:10px;min-height:92px;padding:6px;display:flex;flex-direction:column;gap:3px;cursor:pointer}.month-cell:hover{border-color:var(--accent)}.month-cell.dim{background:var(--surface-2);opacity:.55}.month-cell.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.month-daynum{font-size:12px;font-weight:700;color:var(--muted)}.month-cell.today .month-daynum{color:var(--accent)}.m-chip{border:none;background:var(--chip-bg);color:var(--ink);border-radius:6px;padding:2px 6px;font-size:11px;font-weight:600;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.m-chip:hover{background:var(--chip-bg-hover);border:none}.m-chip.single{background:var(--accent);color:var(--accent-ink)}.m-chip.single:hover{background:var(--accent-strong)}.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.view-toggle button{border:none;border-radius:0;padding:7px 14px;font-size:13px;background:var(--input-bg);color:var(--muted)}.view-toggle button.on{background:var(--accent);color:var(--accent-ink)}.screen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.screen-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;transition:box-shadow .12s ease,transform .12s ease}.screen-card:hover{box-shadow:var(--shadow-card);transform:translateY(-1px)}.screen-card-stage{position:relative;aspect-ratio:16 / 9;background:#0e1510;display:flex;align-items:center;justify-content:center;overflow:hidden}.screen-card-stage img{width:100%;height:100%;object-fit:cover}.screen-card-title{color:#eaf2f8;font-weight:700;font-size:15px;text-align:center;padding:0 18px}.screen-card-idle{display:flex;flex-direction:column;align-items:center;gap:8px;color:#5c6c82;font-size:13px;font-weight:600}.screen-card-idle.online{color:#e6eef6}.screen-card-idle.online svg{color:#43b97c}.screen-card.offline .screen-card-stage{background:#0a141f}.screen-card.offline .screen-card-bar b{color:var(--muted);font-weight:600}.screen-card.offline .mini-tag{opacity:.6}.now-playing-pill{position:absolute;top:8px;left:8px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:#1d8a4eeb;padding:3px 8px;border-radius:999px}.screen-card-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;font-size:14px}.screen-card-bar b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.screen-card-meta{margin-left:auto;flex:0 0 auto;color:var(--muted);font-size:12px}.dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%}.dot.on{background:var(--ok);box-shadow:0 0 0 3px #1d8a4e26}.dot.off{background:var(--dot-off)}.screen-card-tags{display:flex;flex-wrap:wrap;gap:5px;padding:0 12px 10px}.mini-tag{font-size:11px;font-weight:600;color:var(--accent-strong);background:var(--active-tint);border-radius:999px;padding:3px 9px}.avatar{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;letter-spacing:.02em}.mini-schedule-list{display:flex;flex-direction:column;gap:6px;max-height:160px;overflow:auto}.mini-schedule{display:flex;align-items:baseline;gap:8px;font-size:13px;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:6px 10px}.detail-hero{display:grid;grid-template-columns:300px 1fr;gap:18px;align-items:stretch}@media(max-width:900px){.detail-hero{grid-template-columns:1fr}}.detail-stage{position:relative;aspect-ratio:16 / 9;background:#0e1510;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center}.detail-stage img{width:100%;height:100%;object-fit:cover}.detail-stage-title{color:#eaf2f8;font-weight:700;text-align:center;padding:0 16px}.detail-stage-idle{display:flex;flex-direction:column;align-items:center;gap:8px;color:#5c6c82;font-size:13px;font-weight:600}.detail-stage-idle.online{color:#e6eef6}.detail-stage-idle.online svg{color:#43b97c}.detail-facts{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;align-content:start;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px}.detail-facts label{margin-bottom:2px;font-size:11px}.detail-facts span{font-size:13px}.detail-tabs{margin:14px 0 0}.detail-body{border:1px solid var(--line);border-radius:0 12px 12px;height:300px;overflow:auto}.detail-body table th{position:sticky;top:0}.cache-ok{color:var(--ok);font-weight:700}.cache-pending{color:var(--warn-ink);font-weight:700}.theme-editor{display:grid;grid-template-columns:1fr 300px;gap:26px}@media(max-width:900px){.theme-editor{grid-template-columns:1fr}.theme-editor-preview{position:static}}.theme-editor-form{min-width:0}.theme-editor-preview{display:flex;flex-direction:column;gap:14px;position:sticky;top:0;align-self:start}.color-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px}.color-cell{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--ink);margin:0;cursor:pointer}.color-cell input[type=color]{width:40px;height:30px;padding:2px;border:1px solid var(--line);border-radius:6px;background:var(--input-bg);cursor:pointer;flex:0 0 auto}.image-slot{display:flex;align-items:center;gap:14px}.image-slot img.logo{height:40px;max-width:160px;object-fit:contain;background:repeating-conic-gradient(var(--chip-bg) 0% 25%,var(--panel) 0% 50%) 0 0 / 16px 16px;border:1px solid var(--line);border-radius:6px;padding:4px}.image-slot img.bg{width:88px;height:50px;object-fit:cover;border:1px solid var(--line);border-radius:6px}.file-button{display:inline-block;font-size:13px;font-weight:600;color:var(--ink);background:var(--input-bg);border:1px solid var(--line);border-radius:8px;padding:5px 10px;cursor:pointer;margin:0}.file-button:hover{border-color:var(--btn-border-hover)}.tv-preview-wrap{width:100%}.tv-preview{aspect-ratio:16 / 9;border-radius:10px;border:1px solid var(--line);box-shadow:0 6px 18px #0a1e322e;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;overflow:hidden;padding:12px}.tv-logo{max-height:26px;max-width:60%;object-fit:contain}.tv-logo-text{font-family:Georgia,serif;font-weight:700;font-size:15px}.tv-clock{font-size:30px;font-weight:700;line-height:1}.tv-sub{font-size:11px}.tv-home{width:100%;height:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px}.tv-home-left{display:flex;flex-direction:column;justify-content:space-between;align-self:stretch;padding:4px 0}.tv-home-right{display:flex;flex-direction:column;gap:6px;width:44%;flex:0 0 auto}.tv-home-right span{font-size:10px;font-weight:700;padding:7px 10px;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tv-strip{display:flex;gap:8px;margin-top:8px}.tv-strip span{width:52px;height:30px;border-radius:5px}.theme-swatch{width:92px;height:52px;border-radius:8px;border:1px solid var(--line);display:flex;align-items:flex-end;justify-content:center;gap:5px;padding-bottom:7px}.theme-swatch span{width:26px;height:9px;border-radius:999px}.plb-list{display:flex;flex-direction:column;gap:8px;border:1.5px solid transparent;border-radius:12px}.plb-list.drop{border-color:var(--accent)}.plb-row{display:flex;align-items:center;gap:16px;padding:10px 14px;border-radius:14px;background:var(--panel);box-shadow:var(--shadow-card);cursor:pointer;user-select:none;-webkit-user-select:none}.admin.dark .plb-row{box-shadow:inset 0 1px #ffffff0a}.plb-row:hover{background:var(--panel-alt)}.plb-row:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.plb-thumb{width:128px;aspect-ratio:16 / 9;flex:0 0 auto;border-radius:9px;object-fit:cover;background:var(--chip-bg)}.plb-thumb-empty{display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.plb-main{flex:1;min-width:0}.plb-name{display:flex;align-items:center;gap:8px;min-width:0;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plb-name .sched-dot{margin-left:0}.plb-fact{margin-top:3px;font-size:12.5px;color:var(--muted)}.plb-folder .plb-folder-tile{color:var(--accent);opacity:.85;background:var(--active-tint)}.plb-folder.drop{box-shadow:inset 0 0 0 1.5px var(--accent);background:var(--active-tint)}.plb-loc{flex:0 0 auto;max-width:40%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plb-list .empty{padding:28px 12px}.page-actions .search-input{height:36px;width:200px}@media(max-width:640px){.plb-row{gap:12px;padding:8px 10px}.plb-thumb{width:96px}.page-actions .search-input{flex:1 1 100%;width:auto}}.tree-actions{display:none;margin-left:auto;gap:2px}.tree-actions button{border:none;background:none;padding:1px 4px;font-size:12px;color:var(--muted);border-radius:5px}.tree-actions button:hover{background:var(--active-tint);color:var(--accent);border:none}.sched-dot{margin-left:auto;display:inline-flex;align-items:center;color:var(--ok)}.builder-title{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.title-input{font-size:22px;font-weight:700;border:1px solid transparent;background:none;padding:4px 8px;margin-left:-8px;border-radius:8px;min-width:160px;flex:1 1 220px;width:auto}.title-input:hover{border-color:var(--line);background:var(--input-bg)}.title-input:focus{border-color:var(--accent);background:var(--input-bg)}.target-warn{font-size:12px;color:var(--warn-ink);background:var(--warn-tint);border-radius:999px;padding:3px 10px}.link-btn{border:none;background:none;padding:0;font-size:12px;color:var(--accent);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.link-btn:hover{border:none}.trim-modal video{width:100%;max-height:46vh;border-radius:10px;background:#000}.trim-timeline{position:relative;height:26px;margin:16px 10px 6px;background:var(--trim-track);border-radius:6px;cursor:pointer;touch-action:none}.trim-range{position:absolute;top:0;bottom:0;background:color-mix(in srgb,var(--accent) 28%,transparent);border-top:2px solid var(--accent);border-bottom:2px solid var(--accent)}.trim-playhead{position:absolute;top:-4px;bottom:-4px;width:2px;margin-left:-1px;background:var(--ink);pointer-events:none}.trim-handle{position:absolute;top:-5px;bottom:-5px;width:12px;margin-left:-6px;background:var(--accent);border-radius:4px;cursor:ew-resize;box-shadow:0 1px 4px #0a1e3259;touch-action:none}.trim-handle:after{content:"";position:absolute;top:7px;right:4.5px;bottom:7px;left:4.5px;background:#ffffffd9;border-radius:2px}.trim-bar{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}.trim-field{display:flex;align-items:center;gap:6px;font-size:12px}.trim-field .small{font-variant-numeric:tabular-nums}.trim-play{width:36px;height:36px}.trim-modal video{cursor:pointer}.tile-board{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));justify-content:start;gap:14px;padding:16px;border-radius:0 0 12px 12px}@container (max-width: 640px){.tile-board{grid-template-columns:1fr 1fr;gap:10px;padding:12px}}.tile{display:flex;flex-direction:column;min-width:0;border-radius:10px;overflow:hidden;background:var(--chip-bg);cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:pan-y}.tile:hover{background:var(--chip-bg-hover)}.tile:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.tile.drag-float{box-shadow:var(--shadow-pop, var(--shadow-card));cursor:grabbing}.tile-thumb{position:relative;aspect-ratio:16 / 9;background:var(--panel-alt)}.tile-thumb img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.tile-thumb-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:10px 14px;text-align:center;font-size:12.5px;font-weight:600;color:var(--muted);overflow:hidden}.tile-badge{position:absolute;top:6px;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:#080c0a9e;color:#e8ede9;font-size:10.5px;font-weight:600;line-height:16px;white-space:nowrap;pointer-events:none}.tile-badge svg{color:#b7c0ba}.tile-badge-left{left:6px}.tile-badge-right{right:6px;max-width:calc(100% - 12px);overflow:hidden}.tile-badge-left+.tile-badge-right{max-width:calc(100% - 74px)}.tile-foot{display:flex;align-items:center;gap:7px;padding:7px 9px;font-size:12px}.tile-pos{flex:0 0 auto;min-width:18px;text-align:center;border-radius:999px;background:var(--panel-alt);font-weight:700;font-size:11px;color:var(--muted);padding:1px 4px}.tile-name{flex:1;min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tile-dur{flex:0 0 auto;color:var(--muted)}.admin .tile-add,.admin.dark .tile-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:120px;border:none;border-radius:10px;background:var(--panel-alt);color:var(--muted);font-size:13px;font-weight:600;box-shadow:none}.admin .tile-add:hover,.admin.dark .tile-add:hover{border:none;background:var(--chip-bg);color:var(--accent-strong)}.picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--backdrop);z-index:50}.picker-panel{position:absolute;top:0;right:0;bottom:0;width:380px;max-width:94vw;display:flex;flex-direction:column;background:var(--panel);box-shadow:-12px 0 32px #00000040;animation:picker-in .18s ease-out}@keyframes picker-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.picker-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px 10px;font-size:15px}@media(max-width:640px){.picker-panel{width:100vw;max-width:none;animation:none}.picker-head{padding-top:calc(14px + env(safe-area-inset-top))}.picker-panel .media-browser-body{padding-bottom:calc(10px + env(safe-area-inset-bottom))}}.picker-panel .media-browser{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.media-browser-head{padding:10px;border-bottom:1px solid var(--line);background:var(--panel-alt)}.media-browser-body{overflow:auto;padding:6px 4px 10px;-webkit-user-select:none;user-select:none}.browser-folder{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600}.browser-folder:hover{background:var(--hover)}.browser-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:8px;cursor:pointer;font-size:13px}.browser-item:hover{background:var(--hover)}.browser-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.browser-add{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:var(--chip-bg);color:var(--muted);opacity:0}.browser-item:hover .browser-add{opacity:1}.browser-add.added{opacity:1;background:var(--active-tint);color:var(--accent-strong)}.browser-add-all{flex:0 0 auto;opacity:0}.browser-folder:hover .browser-add-all{opacity:1}.ghost-edit{border:none;background:none;padding:2px 6px;color:var(--muted);font-size:13px;cursor:pointer}.ghost-edit:hover{color:var(--accent);border:none}.hold-seconds{display:flex;align-items:center;gap:4px;margin:0;font-size:12px;color:var(--muted);font-weight:600}.hold-seconds input{width:58px;padding:5px 8px;font-size:13px;text-align:right}.insp-preview{position:relative;aspect-ratio:16 / 9;border-radius:10px;overflow:hidden;background:var(--panel-alt)}.insp-preview.clickable{cursor:pointer}.insp-preview img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.insp-preview:focus-visible{outline:2px solid var(--accent)}.insp-preview-hint{position:absolute;right:8px;bottom:8px;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#080c0a9e;color:#e8ede9;pointer-events:none}.insp-meta{display:flex;align-items:center;flex-wrap:wrap;gap:4px 10px;margin-top:8px;font-size:12.5px}.insp-group{margin-top:14px}.insp-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.insp-row{display:flex;align-items:center;flex-wrap:wrap;gap:12px}.insp-actions{margin-top:18px;display:flex}.admin .insp-remove,.admin.dark .insp-remove{display:inline-flex;align-items:center;gap:7px;border:none;background:none;box-shadow:none;padding:7px 10px;margin-left:-10px;border-radius:8px;font-size:13px;font-weight:600;color:var(--danger)}.admin .insp-remove:hover,.admin.dark .insp-remove:hover{border:none;background:var(--danger-tint)}body.row-dragging{user-select:none;-webkit-user-select:none;cursor:grabbing}.tree-actions button,.ghost-edit{display:inline-flex;align-items:center}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:1px solid var(--line);border-radius:8px;background:var(--input-bg);color:var(--muted)}.icon-btn.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.admin.dark .icon-btn.on{background:var(--accent);color:var(--accent-ink);box-shadow:none}.icon-btn.danger{color:var(--danger);border-color:var(--danger-line)}.icon-btn.danger:hover{background:var(--danger-tint)}@media(max-width:900px){.admin-main{padding:18px 16px 48px}}@media(max-width:640px){.admin{flex-direction:column}.admin-main{order:1}.admin-nav{order:2;width:100%;flex:0 0 auto;flex-direction:row;align-items:stretch;justify-content:space-around;padding:6px calc(6px + env(safe-area-inset-right)) calc(6px + env(safe-area-inset-bottom)) calc(6px + env(safe-area-inset-left));border-right:none;border-top:1px solid var(--rail-line)}.admin-nav .brand,.admin-nav .nav-section,.admin-nav a.nav-screen,.admin-nav a.nav-hide-phone,.admin-nav .who,.admin-nav .nav-bottom-row{display:none}.admin-nav a.nav-only-phone{display:flex}.nav-more{display:flex;align-items:stretch;flex:0 0 auto}.nav-more-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:7px 10px 4px;border:none;background:none;box-shadow:none;color:var(--rail-muted);font-size:12px;font-weight:600;border-radius:8px}.nav-more-btn svg,.admin-nav .nav-scroll a svg{width:22px;height:22px}.admin.dark .admin-nav{background:var(--bg)}.admin.dark .nav-more-btn{background:none;box-shadow:none}.nav-more .more-menu{left:auto;right:0;bottom:calc(100% + 10px)}.admin-nav a.active{background:none;color:var(--brand-green)}.nav-scroll{flex:1;flex-direction:row;align-items:stretch;justify-content:space-around;overflow-y:visible}.admin-nav a{flex:1 1 0;flex-direction:column;margin:0 1px;padding:7px 1px 4px;gap:5px;min-width:0;font-size:12px;letter-spacing:0;border-radius:8px}.admin-nav a span{max-width:100%}.admin-nav .nav-foot{border-top:none;margin:0;padding:0;display:flex;align-items:center}.admin-nav .nav-foot a.rail-btn{display:none}.admin-nav .who{padding:0 4px;margin:0}}@media(max-width:860px){.filter-panel{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:0 20px;max-height:none;align-items:start}.filter-panel-head,.filter-manage{grid-column:1 / -1}}@media(max-width:560px){.week-grid{grid-template-columns:1fr;gap:8px}.week-col{min-height:0}.week-col-body{max-height:none;padding:6px 8px}.sched-add{padding:2px 4px}.month-grid{gap:3px}.m-chip{font-size:0;height:8px;padding:0;border-radius:3px}.row-between>div{flex-wrap:wrap}}@media(max-width:560px){.modal{max-width:calc(100vw - 20px);max-height:calc(100vh - 16px);max-height:calc(100dvh - 16px)}.modal-head{padding:14px 16px 10px}.modal-body{padding:0 16px 16px}.modal-actions{flex-wrap:wrap}.detail-status{grid-template-columns:1fr 1fr}.detail-facts{grid-template-columns:1fr}.inline-form{flex-wrap:wrap}}@media(hover:none){.browser-add,.browser-add-all,.sched-add,.tagmgr-row .tree-actions{opacity:1}.tree-actions{display:inline-flex}}.admin-main{padding-top:calc(28px + env(safe-area-inset-top));padding-bottom:calc(60px + env(safe-area-inset-bottom))}@media(max-width:900px){.admin-main{padding-top:calc(18px + env(safe-area-inset-top));padding-bottom:calc(48px + env(safe-area-inset-bottom))}}.panel.scroll-x{overflow-x:auto}@container (max-width: 480px){.builder-title .title-input{flex-basis:100%}}.upl-row td{opacity:.9}.upl-row.failed b{color:var(--danger)}.upl-track{margin-top:6px;height:4px;max-width:340px;border-radius:2px;background:var(--line);overflow:hidden}.upl-bar{height:100%;width:0;border-radius:2px;background:var(--accent);transition:width .25s ease}.upl-bar.indeterminate{width:40%;animation:upl-slide 1.2s ease-in-out infinite}@keyframes upl-slide{0%{margin-left:-40%}to{margin-left:100%}}.upl-error{color:var(--danger);font-size:12px;margin-top:3px}.badge.upl-failed{background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--danger)}.who-avatar-btn{border:none;background:none;padding:0;cursor:pointer;display:flex;border-radius:50%}.who-avatar-btn:hover .who-avatar{box-shadow:0 0 0 2px #ffffff59}img.who-avatar-img{object-fit:cover;display:block}img.avatar-img{object-fit:cover}.settings-avatar-row{display:flex;align-items:center;gap:14px;margin-bottom:18px;border-radius:12px}.settings-avatar-row.drop-hot{outline:2px dashed var(--accent);outline-offset:4px}.settings-avatar.clickable{cursor:pointer}.avatar-crop{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:18px}.avatar-crop-stage{position:relative;overflow:hidden;border-radius:50%;border:1px solid var(--line);background:#0e1510;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.avatar-crop-stage:active{cursor:grabbing}.avatar-crop-stage img{pointer-events:none}.avatar-crop-zoom{display:flex;align-items:center;gap:10px;width:240px;color:var(--muted);font-size:15px;font-weight:700}.avatar-crop-zoom input[type=range]{flex:1;padding:0}.avatar-crop-actions{display:flex;gap:8px}.settings-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;flex:0 0 auto}.settings-avatar-initials{display:inline-flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;font-size:22px;font-weight:700}.settings-section-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:18px 0 8px;padding-top:14px;border-top:1px solid var(--line)}.settings-inline-err{color:var(--danger);font-size:13px;margin-top:6px}.settings-inline-ok{color:var(--ok);font-size:13px;margin-top:6px}.mode-group{display:inline-flex;flex:0 0 auto}.mode-group .icon-btn{border-radius:0;width:auto;gap:6px;padding:0 12px;font-size:12.5px;font-weight:600;height:34px}.mode-group .icon-btn+.icon-btn{margin-left:-1px}.mode-group .icon-btn:first-child{border-top-left-radius:8px;border-bottom-left-radius:8px}.mode-group .icon-btn:last-child{border-top-right-radius:8px;border-bottom-right-radius:8px}.mode-group .icon-btn.on{position:relative;z-index:1}.builder-facts{row-gap:6px}.admin .fact-chip,.admin.dark .fact-chip{display:inline-flex;align-items:center;gap:7px;min-width:0;max-width:100%;padding:5px 11px;border:none;border-radius:999px;background:var(--chip-bg);color:var(--ink);font-size:12.5px;font-weight:600;box-shadow:none;text-align:left}.admin .fact-chip:hover,.admin.dark .fact-chip:hover{background:var(--chip-bg-hover);border:none}.fact-chip svg{color:var(--muted);flex:0 0 auto}.fact-chip .fact-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin .facts-edit,.admin.dark .facts-edit{border:none;background:none;box-shadow:none;margin-left:auto;padding:4px 8px;font-size:13px;font-weight:700;color:var(--accent)}.admin .facts-edit:hover,.admin.dark .facts-edit:hover{border:none;background:none;text-decoration:underline;text-underline-offset:3px}.builder-edit-panel{padding:12px 16px 14px;border-bottom:1px solid var(--line)}.edit-dests{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:0 24px;align-items:start}.edit-dests .filter-group:first-child{margin-top:0}.builder-edit-panel .filter-group-title{display:flex;align-items:center;gap:5px}.builder-edit-panel .filter-row.disabled{opacity:.45;cursor:default}.builder-edit-panel .filter-row.disabled:hover{background:none}.avail-edit{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.avail-edit .chip{padding:4px 10px}.dest-none{font-size:13px;font-style:italic;font-weight:600;color:var(--danger)}.admin-nav .who{position:relative}.who-menu{position:absolute;left:0;bottom:calc(100% + 10px);z-index:40;min-width:170px;display:flex;flex-direction:column;gap:2px;padding:6px;background:var(--panel);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-menu)}.who-menu button{display:flex;align-items:center;gap:9px;border:none;background:none;text-align:left;padding:8px 10px;border-radius:7px;font-size:13px;color:var(--ink)}.who-menu button:hover{background:var(--hover);border:none}.admin .who-menu button.danger,.admin.dark .who-menu button.danger{color:var(--danger)}.admin .who-menu button.danger:hover,.admin.dark .who-menu button.danger:hover{background:var(--danger-tint)}.admin.dark .who-menu button,.admin.dark .tag-menu>button{background:none;box-shadow:none}.admin.dark .who-menu button:hover,.admin.dark .tag-menu>button:hover{background:var(--hover)}.who-menu-sep{height:1px;margin:4px 6px;background:var(--line)}.scrsw{position:relative;display:inline-flex;min-width:0}.admin .scrsw-btn,.admin.dark .scrsw-btn{display:inline-flex;align-items:center;gap:10px;min-width:0;padding:3px 8px;margin-left:-8px;border:none;border-radius:10px;background:none;box-shadow:none;color:var(--ink);text-align:left}.admin .scrsw-btn:hover,.admin.dark .scrsw-btn:hover{background:var(--hover);border:none}.scrsw-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scrsw-title .scrsw-name{font-size:24px;font-weight:700;letter-spacing:-.01em}.scrsw-small .scrsw-btn{gap:7px;padding:3px 7px;margin-left:0;border-radius:8px}.scrsw-small .scrsw-name{font-size:12.5px;font-weight:600;color:var(--muted)}.scrsw-small .scrsw-btn:hover .scrsw-name{color:var(--ink)}.scrsw-chev{flex:0 0 auto;color:var(--muted);transition:transform .15s ease}.scrsw-chev.open{transform:rotate(180deg)}.scrsw-dot{flex:0 0 auto;width:9px;height:9px;border-radius:999px;background:var(--brand-green)}.scrsw-dot.off{background:var(--dot-off)}.scrsw-small .scrsw-dot{width:8px;height:8px}.scrsw-menu{top:calc(100% + 8px);bottom:auto;left:0;min-width:220px;max-width:min(320px,calc(100vw - 32px));max-height:50vh;overflow-y:auto}.scrsw-small .scrsw-menu{left:auto;right:0}.scrsw-menu .scrsw-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scrsw-check{flex:0 0 auto;color:var(--accent)}@media(max-width:640px){.who-menu{left:auto;right:0;bottom:calc(100% + 10px)}}.avail-window{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}.avail-edit input{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:4px 8px;font-size:13px;color:var(--ink)}.builder-panel{overflow:visible;container-type:inline-size}.builder-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 14px;margin:0;border-bottom:1px solid var(--line)}.builder-strip-head{background:var(--panel-alt);border-radius:12px 12px 0 0}.builder-strip .title-input{font-size:18px}@media(max-width:560px){.avail-edit .avail-window>.muted{display:none}}.detail-hero .detail-stage{width:100%;min-width:0}@media(max-width:640px){.media-toolbar .search-input{margin-left:0!important;flex:1 1 100%;width:auto}}.theme-editor-form input[type=color]{width:40px;height:30px;padding:2px;border:1px solid var(--line);border-radius:6px;background:var(--input-bg);cursor:pointer}.stale-note{grid-column:1 / -1;font-size:12px;color:var(--warn-ink);background:var(--warn-tint);border:1px solid var(--warn-line);border-radius:7px;padding:5px 9px}.settings-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 16px}.settings-tabs button.on{background:var(--active-tint);color:var(--accent-strong);border-color:transparent}.tagmgr-embed{max-width:1100px}.np-back-row,.np-status-dot{display:none}.np-head-actions{display:flex;align-items:center;gap:10px}.np-head-actions button{display:inline-flex;align-items:center;gap:8px}.np-panel{padding:22px;border-radius:16px;container-type:inline-size;container-name:cockpit}.np-cols{display:grid;grid-template-columns:minmax(0,1fr);grid-template-areas:"llab" "art" "meta" "trans" "nlab" "tiles";column-gap:28px}.np-live,.np-next{display:contents}.np-artwrap{max-width:860px}@container cockpit (min-width: 668px){.np-cols:not(.no-next){grid-template-columns:minmax(0,1fr) clamp(200px,calc((100cqw - 28px)/3.2),280px);grid-template-areas:"llab nlab" "art  tiles" "meta tiles" "trans tiles"}.np-cols:not(.no-next) .np-artwrap{max-width:none}.np-cols:not(.no-next) .np-next>.np-label{margin-top:0}.np-cols:not(.no-next) .np-next-tiles{position:relative;height:0;min-height:100%}.np-cols:not(.no-next) .np-next-scroll{position:absolute;top:0;right:0;bottom:0;left:0;flex-direction:column;overflow-x:hidden;overflow-y:auto;padding-bottom:0;padding-right:2px}.np-cols:not(.no-next) .np-next-scroll>.np-next-tile{flex:0 0 auto;width:100%}.np-cols:not(.no-next) .np-next-scroll.fade-start{mask-image:linear-gradient(to bottom,transparent 0,#000 36px);-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 36px)}.np-cols:not(.no-next) .np-next-scroll.fade-end{mask-image:linear-gradient(to bottom,#000 0,#000 calc(100% - 36px),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,#000 0,#000 calc(100% - 36px),transparent 100%)}.np-cols:not(.no-next) .np-next-scroll.fade-start.fade-end{mask-image:linear-gradient(to bottom,transparent 0,#000 36px,#000 calc(100% - 36px),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 36px,#000 calc(100% - 36px),transparent 100%)}}.np-cols.no-next{grid-template-columns:minmax(0,1fr);grid-template-areas:"llab" "art" "meta" "trans"}.np-live>.np-label{grid-area:llab}.np-artwrap{grid-area:art}.np-meta{grid-area:meta;align-self:start}.np-transport{grid-area:trans}.np-next>.np-label{grid-area:nlab;margin-top:22px}.np-next-tiles{grid-area:tiles;align-self:start;min-width:0}.np-next-scroll{display:flex;flex-direction:row;gap:12px;overflow-x:auto;padding-bottom:6px}.np-next-scroll>.np-next-tile{flex:0 0 200px}.np-next-go{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;background:#00000073;opacity:0;transition:opacity .12s ease}.np-next-tile:hover .np-next-go,.np-next-tile:focus-visible .np-next-go{opacity:1}@media(hover:none){.np-next-go{opacity:1;inset:auto 8px 8px auto;background:#0000008c;border-radius:8px;padding:4px 6px}}.np-next-tile{flex:0 0 200px;width:200px}.np-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}.np-label.green{color:var(--accent)}.np-artwrap{position:relative}.np-art{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:12px;background:#000}.np-empty{display:flex;align-items:center;justify-content:center;color:var(--muted);background:var(--surface-2)}.np-empty.off{opacity:.55}.np-dur-badge{position:absolute;right:10px;bottom:10px;padding:3px 9px;border-radius:7px;background:#000000b8;color:#fff;font-size:12px;font-weight:600}.np-meta{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:16px 2px 4px;min-height:48px}.np-name{font-size:19px;font-weight:600}.np-sub{color:var(--muted);font-size:13.5px;margin-top:3px}.np-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:10px;background:var(--chip-bg);font-size:13.5px;font-weight:600;white-space:nowrap}.np-transport{display:flex;align-items:center;flex-wrap:wrap;gap:16px clamp(14px,4cqw,44px);margin-top:22px;min-height:76px}.np-t-btn{display:flex;flex-direction:column;align-items:center}.np-t-btn>button{width:64px;height:64px;padding:0;border-radius:16px;display:flex;align-items:center;justify-content:center}.admin .np-t-btn>button.np-play{width:76px;height:76px;background:var(--accent);border-color:var(--accent);color:var(--accent-ink);border-radius:999px}.admin .np-t-btn>button.np-play:hover{background:color-mix(in srgb,var(--accent) 85%,#000)}.np-audio{display:flex;align-items:center;gap:10px;height:62px;flex:1 1 190px;min-width:0;max-width:300px}.np-vol{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;margin:0;flex:1;min-width:110px;max-width:220px;height:6px;border-radius:999px;border:none;outline:none;cursor:pointer;background:linear-gradient(var(--accent),var(--accent)) 0 / calc(9px + (100% - 18px) * var(--vol, .5)) 100% no-repeat,var(--trim-track)}.np-vol::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;border:none;background:#fff;box-shadow:0 1px 5px #00000073}.np-vol::-moz-range-thumb{width:18px;height:18px;border-radius:50%;border:none;background:#fff;box-shadow:0 1px 5px #00000073}.np-vol:focus-visible{box-shadow:0 0 0 3px var(--focus-ring)}.np-icon-btn,.admin.dark .np-icon-btn{background:transparent;border-color:transparent;color:var(--muted);padding:6px;display:flex}.np-icon-btn:hover{color:var(--ink)}.admin.dark .np-next-tile{background:var(--surface-2);box-shadow:none}.np-next-tile{position:relative;padding:0;border-radius:12px;overflow:hidden;aspect-ratio:16 / 9;background:var(--surface-2)}.np-next-tile img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.np-next-name{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:8px;font-size:13.5px;color:var(--muted)}.np-playlist{margin-top:28px}.np-upnext{display:none}.np-upnext-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.np-upnext-head .np-label{margin-bottom:0}.np-os-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.np-os-head .np-label{margin-bottom:0}.np-os-rows{display:flex;flex-direction:column;gap:8px}.np-os-pl{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}.admin.dark .np-os-pl{border-color:transparent;background:var(--hover-soft);box-shadow:inset 0 1px #ffffff08}.np-os-headrow{display:flex;align-items:center;gap:4px;padding-right:12px}.np-os-pl.active .np-os-headrow{background:var(--active-tint)}.admin .np-os-row,.admin.dark .np-os-row{flex:1;min-width:0;display:flex;align-items:center;gap:12px;padding:10px 12px;border:none;border-radius:0;background:none;box-shadow:none;text-align:left}.admin .np-os-row:hover,.admin.dark .np-os-row:hover{background:var(--hover);border:none}.np-os-pl.active .np-os-row:hover{background:transparent}.np-os-tile{flex:0 0 auto;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.np-os-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.np-os-name{font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.np-os-meta{font-size:12.5px;font-weight:500;color:var(--muted)}.np-os-chip{flex:0 0 auto;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--chip-bg);color:var(--muted);white-space:nowrap}.np-os-chev{flex:0 0 auto;color:var(--muted);transition:transform .15s ease}.np-os-chev.open{transform:rotate(180deg)}.admin .np-os-play,.admin.dark .np-os-play{flex:0 0 auto;width:34px;height:34px;padding:0;border:none;border-radius:999px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);box-shadow:none}.admin .np-os-play:hover,.admin.dark .np-os-play:hover{background:var(--accent);color:var(--accent-ink);border:none}.np-os-items{padding:4px 10px 10px}.admin .np-os-items .np-row,.admin.dark .np-os-items .np-row{background:transparent}.admin .np-os-items button.np-row:hover{background:var(--hover-soft)}.admin.dark .np-os-items button.np-row:hover{background:var(--hover)}.admin .np-os-items .np-row.playing,.admin.dark .np-os-items .np-row.playing{background:var(--active-tint)}.np-row-static{cursor:default}.np-os-editrow{display:flex;justify-content:flex-end;padding:4px 6px 2px}.np-os-phone{margin-top:24px}.np-os-phone .np-label{margin-bottom:12px}.np-os-compact .np-os-row{padding:8px 10px;gap:10px}.np-os-compact .np-os-tile{width:32px;height:32px;border-radius:9px}.np-os-compact .np-os-name{font-size:14.5px}.np-pl-more{position:relative;display:flex;flex:0 0 auto;margin-left:auto}.np-pl-more-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border-radius:12px;color:var(--muted)}.np-pl-more-btn.small{width:32px;height:32px;border-radius:9px}.admin.dark .np-pl-more-btn{background:var(--chip-bg);border:none;box-shadow:inset 0 1px #ffffff0a}.admin.dark .np-pl-more-btn:hover{background:var(--chip-bg-hover);color:var(--ink)}.np-pl-menu{top:calc(100% + 8px);bottom:auto;left:auto;right:0}.np-rows{display:flex;flex-direction:column;gap:4px}.admin .np-row{display:flex;align-items:center;gap:14px;width:100%;padding:9px 14px;border-radius:12px;background:transparent;border-color:transparent;text-align:left;font-weight:600}.admin .np-row:hover{background:var(--hover-soft)}.admin .np-row.playing{background:var(--active-tint)}.admin.dark .np-row{background:#141917;box-shadow:none}.admin.dark .np-row:hover{background:var(--hover)}.admin.dark .np-row.playing{background:var(--active-tint)}.np-row-n{width:30px;display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:13.5px}.np-row.playing .np-row-n{color:var(--accent)}.np-row-thumb{width:64px;height:38px;border-radius:8px;object-fit:cover;flex:0 0 auto}.np-row-thumb-empty{background:var(--surface-2);display:inline-block}.np-row-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px}.np-row-dur{color:var(--muted-2);font-size:13.5px}@media(min-width:641px)and (max-width:1024px){.admin-nav{width:220px;flex-basis:220px}.nav-bottom-row{flex-direction:column;gap:6px}}@media(max-width:640px){.admin-main{padding:16px 24px 40px}.np-back-row{display:flex;align-items:center;justify-content:flex-end;margin-bottom:18px}.admin.dark .np-back-gear{background:none;box-shadow:none}.np-back-gear{display:flex;padding:6px;border:none;background:none;color:color-mix(in srgb,var(--ink) 78%,var(--muted))}.np-back-gear svg{width:23px;height:23px}.np-headrow{justify-content:center;text-align:center;margin-bottom:0}.np-head-main .scrsw .scrsw-name{font-size:22px;font-weight:600}.np-head-main .scrsw .scrsw-dot{display:none}.admin .np-head-main .scrsw-btn,.admin.dark .np-head-main .scrsw-btn{margin-left:0}.np-status-dot{display:inline-block;width:9px;height:9px;border-radius:999px;background:var(--brand-green);margin-right:8px}.np-status-dot.off{background:var(--dot-off)}.admin-main .np-head-main .sub{margin:7px 0 0;font-size:15px}.np-head-actions{display:none}.admin .np-panel,.admin.dark .np-panel{margin-top:30px;background:none;border:none;box-shadow:none;padding:0;border-radius:0;overflow:visible}.np-label{font-size:12.5px;letter-spacing:.11em}.np-art{aspect-ratio:2 / 1}.np-meta{margin:22px 0 4px}.np-name{font-size:20px}.np-t-stop{display:none}.np-transport{justify-content:center;margin-top:28px;gap:16px min(44px,calc((100vw - 300px)/2))}.np-t-btn>button{width:82px;height:82px;border-radius:22px}.np-t-btn>button svg{width:24px;height:24px}.admin.dark .np-t-btn>button{background:#151a1a}.admin.dark .np-t-btn>button:hover{background:var(--chip-bg)}.admin .np-t-btn>button.np-play,.admin.dark .np-t-btn>button.np-play{width:88px;height:88px;border-radius:999px;background:var(--accent)}.np-t-btn>button.np-play svg{width:28px;height:28px}.np-audio{height:auto;flex-basis:100%;justify-content:stretch;margin-top:4px;gap:12px}.np-vol-min svg{width:21px;height:21px}.np-audio .np-icon-btn svg{width:21px;height:21px}.np-vol{max-width:none}.np-next,.np-playlist{display:none}.np-upnext{display:block;margin-top:28px;border-top:1px solid var(--line);padding-top:18px}.np-upnext-head{margin-bottom:12px}.np-rows{gap:2px;margin:0 -8px}.admin .np-row,.admin.dark .np-row{background:transparent;padding:6px 8px;gap:12px}.admin .np-row:hover,.admin.dark .np-row:hover{background:var(--hover-soft)}.admin .np-row.playing,.admin.dark .np-row.playing{background:var(--active-tint)}.np-row-n{font-size:15px}.np-row-thumb{width:70px;height:40px}.np-row-name{font-size:16px}.np-row-dur{font-size:14px;color:var(--muted)}}.dash{container-type:inline-size;container-name:dash}.dash-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px 18px;flex-wrap:wrap;margin-bottom:18px}.admin-main .dash-greet{font-size:24px;font-weight:700;letter-spacing:-.01em;margin:0 0 4px}.dash-head .sub{margin:0;font-size:15px}.dash-wave{margin-left:2px}.dash-new{position:relative}.admin .dash-new-btn,.admin.dark .dash-new-btn{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 14px 0 16px;border:none;border-radius:12px;font-size:14.5px;font-weight:600;color:#fff;background:var(--accent);box-shadow:none}.admin .dash-new-btn:hover,.admin.dark .dash-new-btn:hover{background:color-mix(in srgb,var(--accent) 85%,#000);border:none}.dash-new-sep{width:1px;height:16px;align-self:center;margin:0 3px;background:#ffffff47}.dash-new-menu{left:auto;right:0;top:calc(100% + 8px);bottom:auto;min-width:190px}.dash-stats{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}@container dash (min-width: 928px){.dash-stats{grid-template-columns:repeat(3,minmax(300px,1fr))}}.dash-stat{border-radius:16px;padding:16px 18px 15px;display:flex;flex-direction:column;gap:9px}.dash-stat-top{display:flex;align-items:center;gap:12px;min-width:0}.dash-stat-tile{flex:0 0 auto;width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 13%,transparent);color:var(--accent)}.dash-stat-label{font-size:13.5px;font-weight:600;color:var(--muted);min-width:0}.dash-stat-num{font-size:30px;font-weight:700;letter-spacing:-.01em;line-height:1;margin-top:2px}.dash-stat-foot{font-size:13px;font-weight:600;min-height:18px}.dash-up{display:inline-flex;align-items:center;gap:5px;color:var(--accent)}.dash-flat{color:var(--muted-2)}.dash-dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--brand-green)}.dash-dot.off{background:var(--dot-off)}.dash-body{display:flex;flex-direction:column;gap:14px;margin-top:14px}.dash-row2,.dash-row3{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;align-items:stretch}@container dash (min-width: 720px){.dash-row2{grid-template-columns:minmax(300px,1.34fr) minmax(300px,1fr)}.dash-row3{grid-template-columns:minmax(300px,1fr) minmax(300px,1.02fr)}}.dash-panel{border-radius:16px;padding:17px 18px 16px}.dash-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:13px;min-height:24px}.dash-label{font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--ink)}.dash-label.green{color:var(--accent)}.dash-title{display:inline-flex;align-items:center;gap:9px;font-size:15.5px;font-weight:700;min-width:0}.dash-title-ic{display:inline-flex;color:var(--muted)}.dash-viewall{flex:0 0 auto;font-size:13px;font-weight:600;color:var(--muted);text-decoration:none}.dash-viewall:hover{color:var(--ink);text-decoration:underline;text-underline-offset:3px}.dash-foot-link{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:13.5px;font-weight:600;color:var(--ink);text-decoration:none}.dash-foot-link:hover{color:var(--accent)}.dash-empty{padding:14px 2px 8px;display:flex;flex-direction:column;align-items:flex-start;gap:12px}.dash-empty p{margin:0}.dash-loop-chip{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;background:#080c09a8;color:#fff;font-size:12px;font-weight:600;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.dash-np-meta{margin:13px 2px 0}.dash-np-name{display:inline-block;font-size:17px;font-weight:600;color:var(--ink);text-decoration:none}.dash-np-name:hover{text-decoration:underline;text-underline-offset:3px}.dash-np{container-type:inline-size;container-name:dash-np;overflow:visible}.dash-transport{margin-top:16px;gap:12px clamp(14px,4cqw,24px);min-height:66px}.dash-transport .np-t-btn>button{width:56px;height:56px;border-radius:14px}.dash-transport .np-t-btn>button.np-play{width:66px;height:66px;border-radius:999px}.dash-transport .np-audio{height:52px;flex:0 1 280px;min-width:211px}.dash-transport .np-vol{min-width:170px;max-width:280px}.dash-transport .dash-pl{display:flex;flex-direction:column}.dash-pl-rows{display:flex;flex-direction:column;gap:5px;overflow-y:auto;max-height:330px;margin:0 -6px;padding:0 6px}.admin .dash-pl-row,.admin.dark .dash-pl-row{display:flex;align-items:center;gap:10px;padding:7px 9px;border:none;border-radius:10px;background:none;box-shadow:none;text-align:left;font-weight:500}.admin .dash-pl-row:hover,.admin.dark .dash-pl-row:hover{background:var(--hover);border:none}.admin .dash-pl-row.playing,.admin.dark .dash-pl-row.playing{background:var(--active-tint)}.dash-pl-row.playing .dash-pl-n{color:var(--accent)}.dash-pl-n{flex:0 0 auto;width:16px;display:inline-flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:600;color:var(--muted-2)}.dash-pl-thumb{flex:0 0 auto;width:42px;height:28px;border-radius:6px;object-fit:cover;background:var(--surface-2)}.dash-thumb-empty{display:inline-flex;align-items:center;justify-content:center;color:var(--muted-2);background:var(--surface-2)}.dash-pl-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600}.dash-pl-dur{flex:0 0 auto;font-size:12.5px;font-weight:600;color:var(--muted-2)}.dash-pl-foot{margin-top:12px;font-size:13px}.dash-pl-actions{margin-top:auto;padding-top:12px;display:flex;justify-content:flex-end}.dash-pl-actions button{display:inline-flex;align-items:center;gap:8px;font-size:13.5px}.dash-rows{display:flex;flex-direction:column;gap:6px}.dash-row{display:flex;align-items:center;gap:11px;padding:6px 2px;min-width:0}.dash-row-tile{flex:0 0 auto;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.dash-row-main{flex:1;min-width:0}.dash-row-title{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-row-sub{font-size:12.5px;color:var(--muted-2);margin-top:2px}.dash-row-time{flex:0 0 auto;font-size:13px;font-weight:600;color:var(--muted)}.dash-badge{flex:0 0 auto;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--info-tint);color:#2b64c8}.admin.dark .dash-badge{background:#3a74e429;color:#7fb0f6}.dash-act-ic{flex:0 0 auto;width:36px;height:36px;border-radius:999px;display:flex;align-items:center;justify-content:center}.dash-act-ic.playlist{background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}.dash-act-ic.media{background:var(--info-tint);color:#2b64c8}.admin.dark .dash-act-ic.media{background:#3a74e429;color:#7fb0f6}.dash-act-ic.screen{background:var(--chip-bg);color:var(--muted)}.dash-act-when{flex:0 0 auto;font-size:11.5px;color:var(--muted-2);white-space:nowrap}.admin .screen-card-gear,.admin.dark .screen-card-gear{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:8px;background:none;box-shadow:none;color:var(--muted)}.admin .screen-card-gear:hover,.admin.dark .screen-card-gear:hover{background:var(--hover);color:var(--ink);border:none}.modal.screen-detail-modal{width:min(760px,calc(100vw - 40px))}.screen-detail-modal .detail-hero{grid-template-columns:minmax(220px,340px) minmax(0,1fr);gap:16px;align-items:start}.screen-detail-modal .detail-facts{font-size:13px;min-width:0}@media(max-width:700px){.screen-detail-modal .detail-hero{grid-template-columns:1fr}}.np-next-scroll.fade-start{mask-image:linear-gradient(to right,transparent 0,#000 36px);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 36px)}.np-next-scroll.fade-end{mask-image:linear-gradient(to right,#000 calc(100% - 36px),transparent 100%),linear-gradient(#000,#000);mask-image:linear-gradient(to right,#000 0,#000 calc(100% - 36px),transparent 100%);-webkit-mask-image:linear-gradient(to right,#000 0,#000 calc(100% - 36px),transparent 100%)}.np-next-scroll.fade-start.fade-end{mask-image:linear-gradient(to right,transparent 0,#000 36px,#000 calc(100% - 36px),transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 36px,#000 calc(100% - 36px),transparent 100%)}.detail-ops{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.detail-ops .detail-remove{margin-left:auto;border:none;background:none;box-shadow:none;padding:6px 4px;color:var(--danger);font-weight:600}.admin.dark .detail-ops .detail-remove{background:none;box-shadow:none}.detail-name{flex:1;font-size:15px;font-weight:600}.admin.remote-standalone{position:fixed;top:0;right:0;bottom:0;left:0;display:block;overflow-y:auto;-webkit-overflow-scrolling:touch}.remote-body{max-width:560px;margin:0 auto;padding:calc(22px + env(safe-area-inset-top)) 20px calc(48px + env(safe-area-inset-bottom))}.remote-head{display:flex;align-items:center;gap:14px;margin-bottom:34px}.remote-head-main .np-title{margin:0;font-size:21px;font-weight:600}.remote-head-main .sub{margin:2px 0 0;color:var(--muted)}.remote-controls{width:fit-content;margin:0 auto}.remote-transport{justify-content:center;gap:16px clamp(14px,5vw,30px);margin-top:8px}.remote-standalone .np-t-btn>button{width:66px;height:66px}.remote-standalone .np-t-btn>button.np-play{width:84px;height:84px}.remote-audio{height:auto;width:100%;max-width:none;margin-top:22px}.remote-audio .np-vol{max-width:none}.remote-list{margin-top:40px}.remote-home{margin-top:52px}.remote-list .np-os-rows,.remote-list .np-rows{gap:8px}.remote-pl-tile{display:inline-flex;align-items:center;justify-content:center;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.remote-msg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0b110d;color:#e8ece8;font-family:Inter Variable,Helvetica Neue,Helvetica,Arial,sans-serif;padding:30px;text-align:center}.remote-msg.error{color:#ffb4ab}.remote-headbtns{margin-left:auto;display:flex;align-items:center;gap:8px}.remote-headbtns button{width:42px;height:42px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:12px}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2) format("woff2-variations");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-normal-CkhJZR-_.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-normal-Dx4kXJAl.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--text: #ffffff;--bg: #0b110d;--accent: #8bc53f;--muted: rgba(255, 255, 255, .62);--card: rgba(255, 255, 255, .06);--card-border: rgba(255, 255, 255, .12)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:#0b110d;overflow:hidden;font-family:Inter Variable,Helvetica Neue,Helvetica,Arial,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased}.player{position:fixed;top:0;right:0;bottom:0;left:0;height:100vh;width:100vw;touch-action:none;overscroll-behavior:none;-webkit-tap-highlight-color:transparent}.topbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:2.2vh 3vw;z-index:5}.topbar .logo{height:4.4vh}.clock{font-variant-numeric:tabular-nums;font-size:2.4vh;color:var(--muted);letter-spacing:.02em}.clock .time{color:var(--text);font-weight:600}.hint{position:absolute;bottom:2.4vh;left:0;right:0;text-align:center;color:var(--muted);font-size:1.8vh;z-index:5}.hint kbd{background:var(--card);border:1px solid var(--card-border);border-radius:6px;padding:.2em .55em;margin:0 .15em;font-family:inherit;font-size:.9em}.home{height:100%;display:flex;align-items:center;justify-content:space-between;gap:4vw;padding:7vh 6vw}.home-left{display:flex;flex-direction:column;gap:5vh}.home-logo{height:7vh;align-self:flex-start;object-fit:contain}.home-clock .t{font-size:15vh;line-height:.9;font-weight:800;letter-spacing:-.02em;color:var(--primary-text);font-variant-numeric:tabular-nums}.home-clock .d{font-size:4vh;font-weight:600;margin-top:1vh;color:var(--primary-text);opacity:.85}.home-right{display:flex;flex-direction:column;gap:1.8vh;width:36vw;flex:0 0 auto}.home-btn{display:flex;align-items:center;justify-content:space-between;gap:1vw;padding:2.6vh 2vw;border-radius:12px;font-size:3vh;font-weight:600;background:var(--secondary-btn);color:var(--secondary-btn-text);transition:transform .12s ease,box-shadow .12s ease}.home-btn .on{font-size:1.5vh;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.home-btn.focused{background:var(--primary-btn);color:var(--primary-btn-text);transform:scale(1.03);box-shadow:0 8px 30px #00000059}.home-empty{color:var(--primary-text);opacity:.6;font-size:2.4vh;text-align:center;padding:3vh 0}.playlist{height:100%;display:flex;flex-direction:column}.playlist-top{display:flex;align-items:flex-start;justify-content:space-between;padding:5vh 5vw 0}.pl-logo{height:6vh;object-fit:contain}.pl-title{text-align:right;color:var(--primary-text)}.pl-title .nm{font-size:4.5vh;font-weight:700}.pl-title .tm{font-size:2.4vh;opacity:.8;font-variant-numeric:tabular-nums}.pl-strip{flex:1;display:flex;align-items:center;gap:2vw;padding:0 5vw;overflow-x:auto;scroll-behavior:smooth}.pl-strip::-webkit-scrollbar{display:none}.pl-card{flex:0 0 auto;width:22vw;border-radius:12px;overflow:hidden;background:#00000040;border:3px solid transparent;transition:transform .12s ease,border-color .12s ease}.pl-card.focused{border-color:var(--primary-btn);transform:translateY(-1.5vh) scale(1.04);box-shadow:0 14px 44px #00000080}.pl-card .frame{position:relative;aspect-ratio:16 / 9;background:#0c130e}.pl-card .frame img{width:100%;height:100%;object-fit:cover;display:block}.pl-card .kind{position:absolute;top:8px;left:8px;font-size:1.3vh;padding:.25em .6em;border-radius:6px;background:#0009;color:#fff;text-transform:uppercase;letter-spacing:.06em}.pl-card .label{padding:1.4vh 1vw;color:var(--primary-text)}.pl-card .label .nm{display:block;font-size:2vh;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-card .label .flags{display:block;margin-top:.3em;font-size:1.5vh;color:var(--primary-text);opacity:.6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(orientation:portrait){.home{flex-direction:column;justify-content:center;align-items:stretch;gap:7vmin;padding:8vmin 7vmin calc(8vmin + env(safe-area-inset-bottom))}.home-left{gap:4vmin}.home-logo{height:9vmin}.home-clock .t{font-size:20vmin}.home-clock .d{font-size:5.5vmin}.home-right{width:auto}.home-btn{padding:4.5vmin 5vmin;font-size:4.5vmin}.home-btn .on{font-size:2.4vmin}.playlist-top{padding:7vmin 6vmin 0}.pl-title .nm{font-size:5.5vmin}.pl-card{width:62vmin}}.playback{height:100%;background:#000;display:flex;align-items:center;justify-content:center}.playback img,.playback video{max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain;background:#000}.playback .status{position:absolute;top:3vh;right:3vw;display:flex;gap:.6vw;align-items:center;z-index:6}.pill{background:#0000008c;border:1px solid var(--card-border);border-radius:999px;padding:.5vh 1vw;font-size:1.7vh;color:var(--text)}.pill.hold{background:var(--accent);color:#0b110d;font-weight:700}.playback .poster{text-align:center;color:var(--muted)}.playback .poster .big{font-size:4vh;color:var(--text);margin-bottom:1vh}.player:focus,.player:focus-visible{outline:none}.playback img.ghost{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none}.playback video.ghost-live{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.playback video.live-top,.playback img.live-top{position:relative;z-index:2}.playback video.standby{position:absolute;width:2px;height:2px;opacity:0;pointer-events:none}.video-starting{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.4vh;background:#000;color:#fff;opacity:0;animation:beacon-fade-in .2s ease .2s forwards;pointer-events:none}.video-starting .nm{font-size:3.2vh;font-weight:700}.video-starting .spin{width:5vh;height:5vh;border-radius:50%;border:.6vh solid rgba(255,255,255,.2);border-top-color:var(--primary-btn, #8bc53f);animation:beacon-spin .9s linear infinite}@keyframes beacon-fade-in{to{opacity:1}}@keyframes beacon-spin{to{transform:rotate(360deg)}}.cmd-debug{position:fixed;top:8px;left:8px;z-index:40;font:12px/1.4 monospace;color:#0f0;background:#000000b8;padding:5px 9px;border-radius:6px;pointer-events:none}.controls{position:absolute;left:0;right:0;bottom:0;z-index:8;display:flex;align-items:center;gap:1.6vw;padding:2vh 4vw calc(2vh + env(safe-area-inset-bottom,0px));background:linear-gradient(to top,#000000b8,#0000);touch-action:auto}.ctl-play{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:6vh;height:6vh;min-width:44px;min-height:44px;padding:1.3vh;border:none;border-radius:50%;background:var(--primary-btn, var(--accent));color:var(--primary-btn-text, #0b110d);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s ease}.ctl-play:active{transform:scale(.92)}.ctl-skip{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:5vh;height:5vh;min-width:40px;min-height:40px;padding:1.2vh;border:none;border-radius:50%;background:var(--secondary-btn, rgba(255, 255, 255, .14));color:var(--secondary-btn-text, #fff);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s ease}.ctl-skip:active{transform:scale(.92)}.ctl-mute{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:4.6vh;height:4.6vh;min-width:38px;min-height:38px;padding:1vh;border:none;border-radius:50%;background:var(--secondary-btn, rgba(255, 255, 255, .14));color:var(--secondary-btn-text, #fff);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s ease}.ctl-mute:active{transform:scale(.92)}.tap-for-sound{position:absolute;left:50%;bottom:calc(5vh + env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:9;display:flex;align-items:center;gap:.8vw;padding:1.3vh 2.6vw;border-radius:999px;background:#0000009e;color:#fff;font-size:2.1vh;font-weight:600;pointer-events:none;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.controls .t{font-variant-numeric:tabular-nums;font-size:1.8vh;color:#fff;min-width:6vw;text-align:center}.ctl-range{flex:1;height:.9vh;min-height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(to right,var(--primary-btn, var(--accent)) var(--pct, 0%),rgba(255,255,255,.28) var(--pct, 0%));border-radius:999px;outline:none;cursor:pointer}.ctl-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:2.4vh;height:2.4vh;min-width:18px;min-height:18px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #00000080}.ctl-range::-moz-range-thumb{width:2.4vh;height:2.4vh;border:none;border-radius:50%;background:#fff;box-shadow:0 2px 8px #00000080}.loading{height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:2.4vh}.status-overlay{position:fixed;left:2.2vh;bottom:2.2vh;z-index:20;display:flex;align-items:center;gap:1.2vh;max-width:46vw;padding:1vh 1.8vh 1vh 1.4vh;border-radius:999px;color:#fff;background:#00000080;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-family:Inter Variable,Helvetica Neue,Helvetica,Arial,sans-serif}.status-overlay .dot{flex:0 0 auto;width:1.3vh;height:1.3vh;border-radius:50%;background:#33c56e;box-shadow:0 0 0 .5vh #33c56e33}.status-overlay.syncing .dot{background:#f4a300;box-shadow:0 0 0 .5vh #f4a30033;animation:statuspulse 1.2s infinite}.status-overlay.offline .dot{background:#e5533c;box-shadow:0 0 0 .5vh #e5533c33}@keyframes statuspulse{0%,to{opacity:1}50%{opacity:.35}}.status-overlay .txt{line-height:1.25;min-width:0}.status-overlay .p{font-size:1.8vh;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-overlay .s{font-size:1.5vh;opacity:.7}.status-overlay .pbar{flex:0 0 auto;width:10vh;height:.7vh;border-radius:999px;background:#fff3;overflow:hidden}.status-overlay .pbar span{display:block;height:100%;background:#8bc53f;transition:width .2s ease}.status-overlay .err{flex:0 0 auto;color:#ffb4ab;font-weight:800}.pair{position:fixed;top:0;right:0;bottom:0;left:0;padding:0 6vmin env(safe-area-inset-bottom);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:radial-gradient(120vmin 80vmin at 50% 30%,#17331c,#0b110d 70%);color:#fff;font-family:Inter Variable,Helvetica Neue,Helvetica,Arial,sans-serif}.pair-lockup{display:flex;align-items:center;justify-content:center;gap:3vmin;margin-bottom:.8vmin}.pair-lockup svg{width:9.5vmin;height:auto;flex:0 0 auto}.pair-title{font-size:7.2vmin;font-weight:700;letter-spacing:.07em;line-height:1}.pair-sub{color:#b7c9b9;font-size:2.4vmin;margin-top:.5vmin}.pair-code{margin:5vmin 0 4vmin;font-size:14vmin;font-weight:700;letter-spacing:1.2vmin;padding-left:1.2vmin;color:#fff;font-variant-numeric:tabular-nums}.pair-steps{font-size:2.6vmin;line-height:1.6;color:#c3d2c6}.pair-steps b{color:#fff}.pair-wait{margin-top:6vmin;color:#93a698;font-size:2vmin;display:flex;align-items:center;justify-content:center}.pair-wait .dots{display:inline-flex;gap:.5vmin;margin-left:.8vmin}.pair-wait .dots i{width:.55vmin;height:.55vmin;border-radius:50%;background:currentColor;animation:pairdot 1.4s ease-in-out infinite}.pair-wait .dots i:nth-child(2){animation-delay:.2s}.pair-wait .dots i:nth-child(3){animation-delay:.4s}@keyframes pairdot{0%,60%,to{opacity:.25}30%{opacity:1}}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0b110d;opacity:1;transition:opacity .42s ease}.splash-fading{opacity:0}.splash-mark{width:15vh;height:auto}.splash-mark circle{transform-box:fill-box;transform-origin:center}.splash-play{transform-box:fill-box;transform-origin:center}.splash-loading .splash-mark circle{opacity:.2;animation:splash-wave 1.15s ease-in-out infinite alternate}.splash-loading .splash-play{opacity:.5}@keyframes splash-wave{0%{opacity:.2;transform:scale(.82)}to{opacity:1;transform:scale(1.12)}}.splash-done .splash-mark circle,.splash-fading .splash-mark circle{opacity:1;transform:scale(1.06);transition:opacity .22s ease,transform .22s ease}.splash-done .splash-play,.splash-fading .splash-play{opacity:1;transform:scale(1.08);filter:drop-shadow(0 0 6px rgba(139,197,63,.85)) drop-shadow(0 0 14px rgba(139,197,63,.45));transition:opacity .22s ease,transform .22s ease,filter .22s ease}@media(prefers-reduced-motion:reduce){.splash-mark circle{animation:none;opacity:.92;transform:none}.splash-loading .splash-play{opacity:.7}}
