*,:after,:before{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--bg:#0b0d12;--panel:#151821;--panel-2:#1e2230;--border:#2a2f3d;--text:#e6e9f0;--text-dim:#8b91a4;--accent:#4f8cff;--green:#2dd4bf;--red:#ff4757;--yellow:#f7c948}body,html{background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;min-height:100vh}.container{max-width:720px;margin:0 auto;padding:24px 16px 64px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.topbar h1{font-size:22px;letter-spacing:.5px}.topbar-right{gap:12px}.status,.topbar-right{display:flex;align-items:center}.status{gap:8px;font-size:13px;color:var(--text-dim)}.status .dot{width:8px;height:8px;border-radius:50%;background:var(--text-dim)}.status .dot.green{background:var(--green);box-shadow:0 0 10px var(--green)}.status .dot.red{background:var(--red)}.user-chip{display:flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:4px 4px 4px 12px;font-size:13px;color:var(--text-dim)}.logout-btn{background:transparent;border:none;color:var(--text-dim);cursor:pointer;padding:2px 8px;font-size:14px;border-left:1px solid var(--border);margin-left:2px}.logout-btn:hover{color:var(--red)}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top,#1a1f2e 0,var(--bg) 60%)}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:28px 28px 24px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:10px}.login-card h1{font-size:22px;letter-spacing:.5px;margin-bottom:4px}.login-sub{color:var(--text-dim);font-size:13px;margin-bottom:12px}.login-card label{color:var(--text-dim);font-size:12px;margin-top:4px}.login-card input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:10px 12px;font:inherit;font-size:14px}.login-card input:focus{outline:none;border-color:var(--accent)}.login-error{color:var(--red);background:rgba(255,71,87,.08);border:1px solid rgba(255,71,87,.3);border-radius:8px;padding:8px 12px;font-size:13px}.login-card button{margin-top:8px;padding:12px}.empty{background:var(--panel);border:1px dashed var(--border);border-radius:12px;padding:36px;text-align:center;color:var(--text-dim)}.dev-list{display:flex;flex-direction:column;gap:10px}.dev-list-item{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;color:var(--text);font:inherit;text-align:left}.dev-list-item:hover{background:var(--panel-2)}.dev-list-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600;font-size:15px;flex-shrink:0}.dev-list-meta{display:flex;gap:12px;flex-wrap:wrap;flex-grow:1;align-items:center;font-size:13px}.dev-list-item .chev,.dev-list-meta .muted{color:var(--text-dim)}.dev-list-item .chev{font-size:22px}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.3px}.pill.online{background:rgba(45,212,191,.15);color:var(--green)}.pill.offline{background:rgba(255,71,87,.15);color:var(--red)}.page-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.page-header .back{background:var(--panel);border:1px solid var(--border);color:var(--text);width:36px;height:36px;border-radius:50%;font-size:16px;cursor:pointer}.page-header h2{font-size:16px;letter-spacing:1px;color:var(--text-dim);text-transform:uppercase}.status-pill{display:inline-block;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;margin-bottom:16px}.status-pill.online{background:rgba(45,212,191,.15);color:var(--green)}.status-pill.offline{background:rgba(255,71,87,.15);color:var(--red)}.menu{flex-direction:column}.menu,.menu-item{display:flex;gap:8px}.menu-item{align-items:center;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;color:var(--text);font:inherit;text-align:left;font-size:15px}.menu-item:hover{background:var(--panel-2)}.menu-item>span:first-child{flex:1 1}.menu-item .val{color:var(--text-dim);font-size:13px}.menu-item .chev{color:var(--text-dim);font-size:20px}.menu-item.danger{color:var(--red);border-color:rgba(255,71,87,.4)}.menu-item.danger:hover{background:rgba(255,71,87,.08)}.menu-item.center{justify-content:center}.menu-item.center>span:first-child{flex:none}.hint-text{color:var(--text-dim);font-size:13px;text-align:center}.hint-text,.info-card{padding:16px;line-height:1.5}.info-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;font-size:14px;margin-bottom:16px}.info-card.danger{border-color:rgba(255,71,87,.4);color:#ffd9de}.scrub{padding:12px 0;text-align:center;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.scrub .hint{color:var(--text-dim);font-size:12px;margin-bottom:8px}.scrub .pad{height:200px;overflow:hidden;position:relative;background:linear-gradient(to bottom,var(--panel) 0,var(--bg) 50%,var(--panel) 100%);border:1px solid var(--border);border-radius:14px;cursor:ns-resize;-webkit-mask:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent);mask:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent)}.scrub .reel{position:absolute;top:50%;left:0;right:0;display:flex;flex-direction:column;align-items:center;transform:translateY(-50%);will-change:transform}.scrub .reel.snap{transition:transform .18s cubic-bezier(.2,.7,.3,1)}.scrub .nv{height:50px;line-height:50px;font-size:30px;color:#555;font-weight:700;width:100%;text-align:center;opacity:.55}.scrub .nv.near{color:#999;opacity:.85;font-size:34px}.scrub .nv.current{color:var(--red);opacity:1;font-size:48px}.relays-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.relay-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:8px}.relay-card.on{border-color:var(--green)}.relay-label{font-size:13px;color:var(--text-dim)}.relay-state{font-size:24px;font-weight:700;color:var(--text-dim)}.relay-card.on .relay-state{color:var(--green)}.relay-actions{display:flex;gap:8px;margin-top:6px}.btn{flex:1 1;font:inherit;padding:8px 0;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:13px;font-weight:600}.btn:hover{background:var(--panel-2)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:white}.btn.primary:hover{background:#3a78f0}.events-feed{display:flex;flex-direction:column;gap:6px}.ev-row{display:grid;grid-template-columns:180px 140px 1fr;grid-gap:12px;gap:12px;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;align-items:center}.ev-t{font-family:ui-monospace,Menlo,monospace;font-size:11px;color:var(--text-dim)}.ev-topic{font-weight:600}.ev-payload{color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:560px){.ev-row{grid-template-columns:1fr}.dev-list-meta{font-size:12px;gap:8px}}