.admin{--bg: #f4f6f9;--panel: #ffffff;--line: #e3e8ef;--ink: #1a2433;--muted: #6b7787;--brand: #0b3d5c;--accent: #1769aa;--danger: #c0392b;--ok: #1d8a4e;position:fixed;top:0;right:0;bottom:0;left:0;display:flex;background:var(--bg);color:var(--ink);font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;overflow:hidden}.admin-nav{width:232px;flex:0 0 232px;background:var(--brand);color:#eaf2f8;display:flex;flex-direction:column;padding:20px 0}.admin-nav .brand{font-family:Georgia,serif;font-size:20px;font-weight:700;padding:4px 22px 20px;color:#fff}.admin-nav a{display:flex;align-items:center;gap:10px;padding:11px 22px;color:#cfe0ec;text-decoration:none;font-weight:500}.admin-nav a:hover{background:#ffffff0f;color:#fff}.admin-nav a.active{background:#ffffff1f;color:#fff;box-shadow:inset 3px 0 0 var(--accent)}.admin-nav .spacer{flex:1}.admin-nav .who{padding:14px 22px 0;border-top:1px solid rgba(255,255,255,.12);margin-top:10px;font-size:13px;color:#aec6d8}.admin-nav .who b{color:#fff;display:block;font-weight:600}.admin-nav .who button{margin-top:8px}.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:16px;margin-bottom:18px}.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:#fafbfc}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:#f6f9fc;cursor:pointer}button{font:inherit;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 14px;border-radius:8px;font-weight:600}button:hover{border-color:#cbd5e1}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{background:#12588f}button.danger{color:var(--danger);border-color:#ecc7c3}button.small{padding:5px 10px;font-size:13px}input,select{font:inherit;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:#fff;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 rgba(23,105,170,.25);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:#fff;color:var(--muted);font-weight:600;font-size:13px}.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}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:3px 9px;border-radius:999px;background:#eef2f6;color:var(--muted)}.badge.active{background:#e3f5eb;color:var(--ok)}.badge.inactive,.badge.unprovisioned{background:#fdecea;color:var(--danger)}.badge.hold,.badge.pending{background:#fff3e0;color:#b26a00}.muted{color:var(--muted)}.empty{padding:40px;text-align:center;color:var(--muted)}.error-banner{background:#fdecea;color:var(--danger);border:1px solid #f3c9c3;padding:10px 14px;border-radius:8px;margin-bottom:16px}.login-wrap{--ink: #1a2433;--muted: #6b7787;--line: #e3e8ef;--accent: #1769aa;--danger: #c0392b;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,#0b3d5c,#04121c)}.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 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:#0a141e73;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:14px;width:440px;max-width:calc(100vw - 40px);padding:24px;box-shadow:0 20px 60px #0000004d}.modal h3{margin:0 0 16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.builder-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line)}.builder-item .grab{color:var(--muted);font-size:18px;cursor:grab}.builder-item .pos{width:26px;height:26px;border-radius:50%;background:#eef2f6;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--muted)}.builder-item .grow{flex:1}.builder-item .flags{display:flex;gap:6px}.remote{min-height:100vh;background:linear-gradient(170deg,#0b3d5c,#04121c);color:#fff;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:24px 18px 40px;max-width:520px;margin:0 auto;box-sizing:border-box}.remote header{text-align:center;margin-bottom:26px}.remote .screen-name{font-family:Georgia,serif;font-size:26px;font-weight:700}.remote .now{color:#aecbe0;margin-top:6px;font-size:15px}.remote .transport{display:flex;gap:14px;justify-content:center;margin-bottom:16px}.remote .transport.flash{animation:flash .25s ease}@keyframes flash{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.remote .t-btn{flex:1;font-size:20px;letter-spacing:.12em;padding:20px 0 16px;border-radius:18px;border:none;background:#ffffff1a;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px}.remote .t-btn span{font-size:13px;letter-spacing:.02em;font-weight:600;opacity:.85}.remote .t-btn:active{background:#ffffff38}.remote .t-btn.play{background:#f4a300;color:#04121c;flex:1.3}.remote .dpad-row{display:flex;gap:14px;margin-bottom:30px}.remote .dpad-row button{flex:1;padding:16px 0;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:transparent;color:#fff;font-size:16px;font-weight:600}.remote .section-label{text-transform:uppercase;letter-spacing:.08em;font-size:12px;color:#8fb2ca;margin-bottom:12px}.remote .playlists{display:flex;flex-direction:column;gap:12px}.remote .pl{display:flex;align-items:center;justify-content:space-between;padding:20px;border-radius:14px;border:2px solid rgba(255,255,255,.14);background:#ffffff0f;color:#fff;font-size:18px;font-weight:600;text-align:left}.remote .pl:active{background:#ffffff29}.remote .pl.current{border-color:#f4a300}.remote .pl .dot{font-size:12px;color:#f4a300;font-weight:700}.remote-msg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#04121c;color:#cfe0ec;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:30px;text-align:center}.remote-msg.error{color:#ffb4ab}:root{--text: #ffffff;--bg: #0b1220;--accent: #f4a300;--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:#000;overflow:hidden;font-family: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}.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-family:Georgia,serif;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:#061019}.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}.pl-card .label .flags{display:block;margin-top:.3em;font-size:1.5vh;color:var(--primary-text);opacity:.6}.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:#04121c;font-weight:700}.playback .poster{text-align:center;color:var(--muted)}.playback .poster .big{font-family:Georgia,serif;font-size:4vh;color:var(--text);margin-bottom:1vh}.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)}.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, #04121c);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s ease}.ctl-play:active{transform:scale(.92)}.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: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:#f4a300;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;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:radial-gradient(120vh 80vh at 50% 30%,#0e4a6e,#04121c 70%);color:#fff;font-family:Helvetica Neue,Helvetica,Arial,sans-serif}.pair-mark{color:#f4a300;font-size:6vh;letter-spacing:-.05em;margin-bottom:1vh}.pair-title{font-family:Georgia,serif;font-size:4vh;font-weight:700}.pair-sub{color:#9fc0d6;font-size:2.4vh;margin-top:.5vh}.pair-code{margin:5vh 0 4vh;font-size:14vh;font-weight:700;letter-spacing:1.2vh;padding-left:1.2vh;color:#fff;font-variant-numeric:tabular-nums}.pair-steps{font-size:2.6vh;line-height:1.6;color:#cfe0ec}.pair-steps b{color:#fff}.pair-wait{margin-top:6vh;color:#7fa3bb;font-size:2vh}.pair-wait .dots:after{content:"";animation:pairdots 1.4s steps(4,end) infinite}@keyframes pairdots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}
