:root,[data-theme=dark]{--bg-primary: #060d1e;--bg-secondary: #0d1b2e;--bg-card: #0f2040;--border: #1a3a5c;--accent-purple: #7c3aed;--accent-cyan: #0891b2;--accent-green: #059669;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--online: #10b981;--offline: #ef4444;--warning: #f59e0b;--surface: #102449;--surface-2: #0c1c3a;--surface-3: #16305a;--hairline: #1a3a5c;--text: #f1f5f9;--text-muted: #aebbd0;--text-dim: #7e8aa3;--shadow: 0 14px 40px -16px rgba(0,0,0,.65);--shadow-sm: 0 4px 14px -8px rgba(0,0,0,.6);--page-glow-a: rgba(124,58,237,.1);--page-glow-b: rgba(8,145,178,.08)}[data-theme=light]{--bg-primary: #eef2f8;--bg-secondary: #ffffff;--bg-card: #ffffff;--border: #e2e8f0;--accent-purple: #7c3aed;--accent-cyan: #0891b2;--accent-green: #059669;--text-primary: #1e293b;--text-secondary: #64748b;--online: #10b981;--offline: #ef4444;--warning: #f59e0b;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #eef2f7;--hairline: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-dim: #94a3b8;--shadow: 0 14px 40px -18px rgba(15,23,42,.22);--shadow-sm: 0 4px 14px -8px rgba(15,23,42,.14);--page-glow-a: rgba(124,58,237,.06);--page-glow-b: rgba(8,145,178,.05)}html{color-scheme:dark light}*{box-sizing:border-box;margin:0;padding:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes growBar{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes drawLine{0%{stroke-dashoffset:var(--dash, 1000)}to{stroke-dashoffset:0}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes floatPulse{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes ringPulse{0%{transform:scale(.8);opacity:.7}to{transform:scale(2.2);opacity:0}}body{background:var(--bg-primary);color:var(--text-primary);font-family:Inter,system-ui,sans-serif;min-height:100vh;transition:background .3s ease,color .3s ease}.sidebar,.main-content,.card,.nav-link,.rt-stat,.data-table td,.data-table th,.endpoint-banner,.modal,.drawer,.login-card{transition:background .3s ease,color .3s ease,border-color .3s ease}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;min-width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;overflow:hidden;transition:width .2s ease}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:6px;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.sidebar-collapse-btn:hover{background:#7c3aed14;color:var(--text-primary)}.sidebar-collapse-btn svg{transition:transform .2s ease}.logout-btn{display:flex;align-items:center;justify-content:center;gap:8px}.logout-icon{flex-shrink:0}.sidebar.collapsed{width:66px;min-width:66px}.sidebar.collapsed .logo-sub,.sidebar.collapsed .cmdk-launcher span,.sidebar.collapsed .cmdk-launcher kbd,.sidebar.collapsed .connection-status span:not(.status-dot),.sidebar.collapsed .nav-section-header span,.sidebar.collapsed .nav-section-header .chev,.sidebar.collapsed .nav-link span,.sidebar.collapsed .sidebar-user .user-info,.sidebar.collapsed .theme-toggle.pill .tt-label,.sidebar.collapsed .logout-btn span{display:none}.sidebar.collapsed .logo-pad{padding:5px}.sidebar.collapsed .logo-pad img{max-width:44px}.sidebar.collapsed .connection-status{justify-content:center}.sidebar.collapsed .cmdk-launcher{justify-content:center;padding-left:0;padding-right:0}.sidebar.collapsed .nav-section-header{justify-content:center;padding:12px 0 4px}.sidebar.collapsed .nav-group-items{max-height:none!important;opacity:1!important}.sidebar.collapsed .nav-link{justify-content:center;padding:10px 0}.sidebar.collapsed .theme-toggle.pill{justify-content:center;padding-left:0;padding-right:0}.sidebar-logo{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 16px 14px;border-bottom:1px solid var(--border)}.logo-pad{background:#fff;border-radius:10px;padding:9px 12px;width:100%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 6px #00000040}.logo-pad img{width:100%;max-width:168px;height:auto;display:block}.logo-title{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:.03em}.logo-sub{font-size:10px;color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase}.nav-group{display:flex;flex-direction:column}.nav-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;cursor:pointer;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);padding:14px 12px 6px;transition:color .15s}.nav-section-header:hover{color:var(--text-primary)}.nav-section-header .chev{transition:transform .2s ease;opacity:.7;flex-shrink:0}.nav-section-header .chev.open{transform:rotate(90deg)}.nav-group-items{display:flex;flex-direction:column;gap:4px;overflow:hidden;max-height:0;opacity:0;transition:max-height .26s ease,opacity .2s ease}.nav-group-items.open{max-height:520px;opacity:1}.connection-status{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:12px;color:var(--text-secondary);background:#ffffff05;border-bottom:1px solid var(--border)}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s;white-space:nowrap}.nav-link:hover{background:#7c3aed1a;color:var(--text-primary)}.nav-link.active{background:#7c3aed33;color:#a78bfa;border-left:3px solid var(--accent-purple)}.sidebar-user{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.user-info{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;background:var(--accent-purple);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:var(--text-primary)}.user-role{font-size:11px;color:var(--text-secondary);text-transform:capitalize}.logout-btn{width:100%;font-size:13px}.main-content{flex:1;overflow-y:auto;background:var(--bg-primary)}.page{padding:24px 28px;max-width:1400px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-desc{font-size:13px;color:var(--text-secondary);margin-top:4px}.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:#ffffff08;border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;align-items:center;gap:14px;transition:border-color .2s}.stat-card:hover{border-color:#7c3aed4d}.stat-card--cyan{border-left:3px solid var(--accent-cyan)}.stat-card--purple{border-left:3px solid var(--accent-purple)}.stat-card--green{border-left:3px solid var(--accent-green)}.stat-card--orange{border-left:3px solid var(--warning)}.stat-card--red{border-left:3px solid var(--offline)}.stat-icon{color:var(--text-secondary);flex-shrink:0}.stat-body{flex:1}.stat-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-title{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-subtitle{font-size:11px;color:var(--text-secondary);margin-top:2px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.card-title{font-size:15px;font-weight:600;color:var(--text-primary)}.tracking-main{display:grid;grid-template-columns:460px 1fr;gap:20px;margin-bottom:0}.radar-card{overflow:hidden}.feed-card{display:flex;flex-direction:column;overflow:hidden}.radar-container{display:flex;justify-content:center;align-items:center}.radar-legend{display:flex;justify-content:center;gap:16px;margin-top:10px}.antenna-label{font-size:11px;color:var(--text-secondary);background:#ffffff0d;padding:2px 8px;border-radius:4px}.compact-select{padding:4px 8px!important;font-size:12px!important;height:auto!important}.search-input{margin-bottom:10px}.search-input-sm{padding:4px 10px!important;font-size:12px!important;width:160px!important}.tag-list{flex:1;overflow-y:auto;max-height:420px;display:flex;flex-direction:column;gap:6px}.tag-item{padding:10px 12px;border-radius:8px;background:#ffffff08;border:1px solid var(--border);border-left:3px solid var(--border);transition:background .15s;animation:fadeIn .2s ease}.tag-item:hover{background:#ffffff0f}.tag-item.entry{border-left-color:var(--accent-green)}.tag-item.alarm{border-left-color:var(--offline);background:#ef44440d}.tag-item.staying{border-left-color:var(--accent-cyan)}.tag-item-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.tag-item-mid{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.tag-item-bot{display:flex;align-items:center;gap:8px}.tag-id{font-size:13px;font-weight:600;color:var(--text-primary)}.tag-time{font-size:11px;color:var(--text-secondary)}.signal-bar{flex:1;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.signal-fill{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-purple));border-radius:2px;transition:width .3s ease}.floor-plan-container{width:100%;border-radius:8px;overflow:hidden}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent-purple);color:#fff;border-color:var(--accent-purple)}.btn-primary:hover:not(:disabled){background:#6d28d9;border-color:#6d28d9}.btn-danger{background:#ef444426;color:#f87171;border-color:#ef44444d}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-secondary{background:#ffffff12;color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:#ffffff1f;color:var(--text-primary)}.btn-sm{padding:4px 10px;font-size:12px;border-radius:6px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.form-input,.form-select,.form-textarea{width:100%;background:#ffffff0d;border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:14px;color:var(--text-primary);font-family:inherit;transition:border-color .15s,background .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-purple);background:#7c3aed0d}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b880}.form-hint{display:block;font-size:11px;color:var(--text-secondary);margin-top:4px}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:72px}.reg-form{display:flex;flex-direction:column}.table-container{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:13px}th{background:#ffffff0a;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:11px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}td{padding:10px 14px;border-bottom:1px solid rgba(26,58,92,.4);color:var(--text-primary);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:#ffffff0a;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:11px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:10px 14px;border-bottom:1px solid rgba(26,58,92,.4);color:var(--text-primary);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#ffffff05}.empty-cell{text-align:center;color:var(--text-secondary);padding:24px!important;font-size:13px}.tag-code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;background:#ffffff0f;padding:2px 6px;border-radius:4px;color:#a78bfa}.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-entry{background:#05966933;color:#34d399;border:1px solid rgba(5,150,105,.3)}.badge-staying{background:#0891b233;color:#38bdf8;border:1px solid rgba(8,145,178,.3)}.badge-alarm{background:#ef444433;color:#f87171;border:1px solid rgba(239,68,68,.3)}.badge-type{background:#7c3aed26;color:#a78bfa;border:1px solid rgba(124,58,237,.2)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online,.status-dot.connected{background:var(--online);box-shadow:0 0 6px var(--online);animation:pulse 2s infinite}.status-dot.offline,.status-dot.disconnected{background:var(--offline)}.login-page{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:24px;background-image:radial-gradient(ellipse at 20% 50%,rgba(124,58,237,.07) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(8,145,178,.07) 0%,transparent 60%)}.login-card{width:100%;max-width:380px;background:#ffffff08;border:1px solid var(--border);border-radius:16px;padding:36px 32px;display:flex;flex-direction:column;align-items:center}.login-logo{margin-bottom:18px;background:#fff;border-radius:14px;padding:16px 22px;box-shadow:0 2px 16px #00000040}.login-logo img{width:240px;max-width:60vw;height:auto;display:block}.login-title{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px}.login-subtitle{font-size:13px;color:var(--text-secondary);margin-bottom:28px;text-align:center}.login-form{width:100%;display:flex;flex-direction:column;gap:0}.login-btn{width:100%;padding:11px;font-size:14px;margin-top:4px}.login-footer{margin-top:24px;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px}.alert-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#f87171}.alert-success{background:#0596691f;border:1px solid rgba(5,150,105,.3);color:#34d399}.two-col-layout{display:grid;grid-template-columns:380px 1fr;gap:20px}.stats-mini{display:flex;gap:10px;align-items:center}.stat-mini-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:#7c3aed26;color:#a78bfa;border:1px solid rgba(124,58,237,.2)}.stat-mini-badge.warn{background:#f59e0b26;color:#fbbf24;border-color:#f59e0b33}.unreg-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#ffffff08;border:1px solid var(--border);border-radius:8px;margin-bottom:6px;flex-wrap:wrap}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.spinner{width:36px;height:36px;border:3px solid rgba(124,58,237,.2);border-top-color:var(--accent-purple);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;color:var(--text-secondary);font-size:13px;padding:32px 16px}.text-secondary{color:var(--text-secondary)}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px 18px;font-size:13px;color:var(--text-primary);box-shadow:0 8px 24px #0006;animation:fadeIn .3s ease;z-index:1000}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes sweep{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1100px){.tracking-main{grid-template-columns:1fr}.stats-bar{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{width:56px;min-width:56px}.sidebar-logo .logo-title,.sidebar-logo .logo-sub,.connection-status span:last-child,.nav-link span,.nav-section-header span,.sidebar-user .user-info>div,.logout-btn{display:none}.nav-section-header{display:none}.nav-group-items{max-height:none!important;opacity:1!important}.nav-link{justify-content:center;padding:10px}.sidebar-logo{justify-content:center;padding:16px 6px}.logo-pad{padding:6px}.logo-pad img{max-width:40px}.connection-status{justify-content:center;padding:10px 8px}.user-avatar{margin:0 auto}.sidebar-user{padding:12px 8px;align-items:center}.two-col-layout{grid-template-columns:1fr}.page{padding:16px}.stats-bar{grid-template-columns:repeat(2,1fr)}}.card:fullscreen,.card:-webkit-full-screen{background:var(--bg-primary)!important;border-radius:0!important;border:none!important;margin:0!important;padding:0!important;width:100vw!important;height:100vh!important;display:flex!important;flex-direction:column!important;align-items:stretch!important;overflow:hidden!important}.card:fullscreen .card-header,.card:-webkit-full-screen .card-header{flex-shrink:0;padding:14px 20px;border-bottom:1px solid var(--border)}.card:fullscreen canvas,.card:-webkit-full-screen canvas{flex:1;display:block!important;margin:auto!important;width:min(calc(100vh - 90px),calc(100vw - 40px))!important;height:min(calc(100vh - 90px),calc(100vw - 40px))!important;max-width:none!important;max-height:none!important;border-radius:12px}.card:fullscreen .radar-legend,.card:-webkit-full-screen .radar-legend{flex-shrink:0;padding-bottom:10px}.card:fullscreen .floor-plan-container,.card:-webkit-full-screen .floor-plan-container{flex:1;display:flex!important;align-items:center;justify-content:center;overflow:hidden;padding:12px}.card:fullscreen .floor-plan-container svg,.card:-webkit-full-screen .floor-plan-container svg{width:auto!important;height:auto!important;max-width:calc(100vw - 24px)!important;max-height:calc(100vh - 80px)!important}.nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-secondary);padding:14px 16px 6px;margin-top:4px;opacity:.7}.nav-section-label:first-of-type{margin-top:0;padding-top:8px}.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.page-sub{font-size:13px;color:var(--text-secondary);margin-top:2px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid label{display:block;font-size:11px;font-weight:700;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 720px){.form-grid{grid-template-columns:1fr}}.input,.select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;background:#ffffff0a;color:var(--text-primary)}.input:focus,.select:focus{outline:none;border-color:var(--accent-purple);box-shadow:0 0 0 3px #7c3aed2e}.select option{background:var(--bg-secondary);color:var(--text-primary)}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;border-bottom:1px solid var(--border)}.data-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04)}.data-table tr:hover{background:#ffffff08}.status-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.status-badge.online{background:#10b9812e;color:#34d399}.status-badge.offline{background:#ef44442e;color:#fca5a5}.card.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary)}.card.empty-state h3{color:var(--text-primary);margin-bottom:8px}.btn.btn-danger{background:var(--offline);color:#fff}.btn.btn-danger:hover{background:#dc2626}.ble-map-page{position:relative;width:100%;height:100vh;background:var(--bg-primary);overflow:hidden}.ble-map-canvas{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 20%,rgba(124,58,237,.08),transparent 50%),radial-gradient(circle at 75% 80%,rgba(8,145,178,.06),transparent 50%),var(--bg-primary)}.indoor-map-wrap{width:100%;height:100%;position:relative}.indoor-map-svg{display:block}.map-overlay{position:absolute;z-index:10;pointer-events:none}.map-overlay.top-left{top:16px;left:16px;max-width:460px}.map-overlay.top-right{top:16px;right:16px;max-width:580px}.map-overlay.bottom-left{bottom:16px;left:16px}.map-overlay.right-panel{top:96px;right:16px;bottom:16px;width:360px;max-width:40vw}.overlay-card{pointer-events:auto;background:#0f2040eb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(124,58,237,.18);box-shadow:0 8px 24px #00000059,0 2px 4px #0003;margin-bottom:12px;color:var(--text-primary)}.overlay-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.overlay-title{font-size:15px;font-weight:800;color:var(--text-primary);letter-spacing:-.01em}.overlay-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}.stat-chips{display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px 12px}.chip{display:inline-flex;flex-direction:column;align-items:flex-start;padding:4px 10px;background:#ffffff0d;border:1px solid var(--border);border-radius:8px;min-width:62px}.chip-num{font-size:14px;font-weight:800;color:var(--text-primary)}.chip-label{font-size:9px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;font-weight:700}.floor-cards{display:flex;gap:4px;flex-wrap:wrap;max-width:240px;justify-content:flex-end}.floor-card-btn{padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:#ffffff08;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s}.floor-card-btn:hover{border-color:#7c3aed66;color:var(--text-primary)}.floor-card-btn.active{background:#7c3aed33;border-color:var(--accent-purple);color:#c4b5fd}.overlay-tools{display:flex;flex-wrap:wrap;gap:6px;padding:8px;align-items:center}.search-box{display:flex;align-items:center;gap:6px;padding:0 10px;height:32px;background:#ffffff0d;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary)}.search-box input{border:none;outline:none;background:transparent;font-size:13px;width:150px;color:var(--text-primary)}.tool-btn{display:inline-flex;align-items:center;gap:5px;padding:0 10px;height:32px;background:#ffffff0d;border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s}.tool-btn:hover{background:#ffffff14;color:var(--text-primary)}.tool-btn.active{background:#7c3aed38;border-color:var(--accent-purple);color:#c4b5fd}.tool-btn.tool-btn-primary{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.tool-btn.tool-btn-primary:hover{background:#6d28d9}.tool-btn.tool-btn-danger{background:var(--offline);border-color:var(--offline);color:#fff}.tool-btn:disabled{opacity:.5;cursor:not-allowed}.tool-sep{width:1px;height:20px;background:var(--border);margin:0 4px}.select.select-compact{height:32px;padding:0 8px;font-size:13px;width:auto}.badge-mini{display:inline-block;padding:1px 5px;border-radius:999px;font-size:10px;font-weight:800;background:#7c3aed4d;color:#c4b5fd;margin-left:4px;line-height:1.4}.tool-btn.active .badge-mini{background:var(--accent-purple);color:#fff}.overlay-warning{padding:10px 14px;font-size:13px;color:#fcd34d;background:#f59e0b26!important;border-color:#f59e0b59!important}.overlay-warning a{color:#fde68a;font-weight:700}.panel-card{height:100%;display:flex;flex-direction:column;margin-bottom:0;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-header h3{margin:0;font-size:13px;font-weight:800;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.panel-body{flex:1;overflow-y:auto;padding:8px}.panel-empty{padding:32px 16px;text-align:center;color:var(--text-secondary);font-size:13px}.btn-icon{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:#ffffff08;color:var(--text-secondary);cursor:pointer;font-size:12px}.btn-icon:hover{background:#ffffff14;color:var(--text-primary)}.beacon-row{display:flex;align-items:center;gap:10px;padding:8px 10px;width:100%;background:#ffffff05;border:1px solid transparent;border-radius:8px;cursor:pointer;text-align:left;margin-bottom:4px;transition:all .15s;color:var(--text-primary)}.beacon-row:hover{background:#ffffff0f;border-color:var(--border)}.beacon-row.alarm{background:#ef44441f;border-color:#ef444466}.beacon-row.alarm:hover{background:#ef44442e}.beacon-row-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;flex-shrink:0}.beacon-row-main{flex:1;min-width:0}.beacon-row-name{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.beacon-row-sub{margin-top:2px}.beacon-row-sub>span{color:var(--text-secondary)!important}.beacon-row-stat{text-align:right;flex-shrink:0}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;padding:8px 10px 12px}.detail-cell{padding:6px 0}.detail-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:700;margin-bottom:2px}.detail-val{font-size:13px;color:var(--text-primary);font-weight:600}.detail-val.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.detail-section{margin:12px 12px 6px;font-size:11px;font-weight:800;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.rssi-list{padding:0 10px 10px}.rssi-row{display:grid;grid-template-columns:1fr 90px 70px;gap:8px;align-items:center;padding:6px 0;font-size:12px}.rssi-name strong{color:var(--text-primary);font-weight:700}.rssi-name .rssi-coords{color:var(--text-secondary);font-size:10px;margin-left:4px}.rssi-bar-wrap{height:10px;background:#ffffff0f;border-radius:5px;overflow:hidden}.rssi-bar{height:100%;transition:width .3s}.rssi-val{font-size:11px;font-weight:700;text-align:right}.legend-card{padding:10px 12px;font-size:11px;margin-bottom:0}.legend-row{display:flex;align-items:center;gap:8px;padding:3px 0;color:var(--text-secondary)}.legend-icon{width:16px;height:12px;flex-shrink:0;display:inline-block;border-radius:3px}.legend-icon.legend-gw{background:var(--accent-cyan);border-radius:3px}.legend-icon.legend-online{width:10px;height:10px;background:var(--online);border-radius:50%}.legend-icon.legend-coverage{background:#0891b21a;border:1px dashed rgba(8,145,178,.55);border-radius:50%;width:14px;height:14px}.legend-icon.legend-beacon{background:var(--accent-purple);border-radius:50%;width:12px;height:12px}.legend-icon.legend-trail{background:linear-gradient(90deg,transparent,var(--accent-purple))}.legend-icon.legend-alarm{background:var(--offline);border-radius:50%;width:12px;height:12px}.map-zoom-controls{position:absolute;bottom:16px;right:16px;z-index:5;display:flex;flex-direction:column;gap:0;background:var(--bg-card);border-radius:8px;box-shadow:0 4px 12px #0000004d;border:1px solid var(--border);overflow:hidden}.map-zoom-controls button{width:32px;height:32px;border:none;background:transparent;cursor:pointer;font-size:16px;font-weight:700;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.05)}.map-zoom-controls button:hover{background:#ffffff0f;color:var(--text-primary)}.map-zoom-controls button:last-of-type{border-bottom:none}.map-zoom-label{font-size:9px;text-align:center;padding:4px;color:var(--text-secondary);font-weight:600;background:#ffffff08;border-top:1px solid var(--border)}.sos-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:30;display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--offline);color:#fff;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 8px 24px #ef444480;cursor:pointer;pointer-events:auto}.sos-banner-pulse{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:14px;border:2px solid var(--offline);animation:sos-pulse 1.4s ease-out infinite;pointer-events:none}@keyframes sos-pulse{0%{transform:scale(1);opacity:.85}to{transform:scale(1.15);opacity:0}}.sos-icon{font-size:22px}.sos-banner-dismiss{margin-left:8px;width:26px;height:26px;border-radius:50%;border:none;background:#ffffff40;color:#fff;cursor:pointer;font-size:11px}.sos-banner-dismiss:hover{background:#fff6}.toast-stack{position:absolute;top:80px;left:50%;transform:translate(-50%);z-index:25;display:flex;flex-direction:column;gap:6px;align-items:center;pointer-events:none}.toast{background:#0f2040f2;color:var(--text-primary);padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #0006;border:1px solid var(--border);animation:toast-in .25s ease-out,toast-out .4s ease-in 4.6s forwards}.toast.alert,.toast.restricted{background:var(--offline);border-color:var(--offline);color:#fff}.toast.safe{background:var(--accent-green);border-color:var(--accent-green);color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1}to{opacity:0;transform:translateY(-6px)}}.map-overlay.bottom-right{position:absolute;bottom:16px;right:64px;width:320px;max-height:50vh;z-index:8}.feed-row{display:flex;gap:10px;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.04)}.feed-row.alert{background:#ef44441f}.feed-row:last-of-type{border-bottom:none}.feed-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.feed-dot.enter{background:var(--online)}.feed-dot.leave{background:var(--text-secondary)}.feed-dot.restricted{background:var(--offline)}.feed-dot.alert{background:var(--warning)}.feed-text{font-size:12px;line-height:1.4;flex:1;min-width:0;color:var(--text-primary)}.feed-time{font-size:10px;color:var(--text-secondary);margin-top:2px}.ble-map-page.fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;height:100vh}.ble-map-page.fullscreen .map-overlay{z-index:1001}@media (max-width: 900px){.map-overlay.right-panel{left:16px;right:16px;width:auto;bottom:80px;top:auto;max-width:none;max-height:40vh}.map-overlay.bottom-left{display:none}.map-overlay.top-left{max-width:calc(100% - 32px)}.map-overlay.bottom-right{left:16px;right:16px;width:auto;bottom:16px}}.replay-slider{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:12;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#0f2040f0;border:1px solid rgba(124,58,237,.25);border-radius:12px;box-shadow:0 8px 24px #00000059;width:min(640px,70vw);pointer-events:auto;color:var(--text-primary)}.replay-slider input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none}.replay-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-purple);cursor:pointer;border:2px solid white}.replay-slider input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-purple);cursor:pointer;border:2px solid white}.replay-time{font-size:11px;color:var(--text-secondary);white-space:nowrap;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.rtest .page-sub{font-size:13px;color:var(--text-muted);margin-top:2px;max-width:720px}.status-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-3);color:var(--text-muted);border:1px solid var(--hairline)}.status-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--text-dim)}.status-pill.connected{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.status-pill.connected .dot{background:#10b981;box-shadow:0 0 8px #10b981}.status-pill.silent{background:#fffbeb;color:#92400e;border-color:#fde68a}.status-pill.silent .dot{background:#f59e0b}.status-pill.error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.status-pill.error .dot{background:#ef4444}.status-pill.saved{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.status-pill.saved .dot{background:#3b82f6}.endpoint-banner{display:flex;gap:24px;padding:18px 20px;margin-bottom:14px;flex-wrap:wrap;align-items:flex-start;background:linear-gradient(135deg,#faf5ff,#eff6ff);border:1px solid #e9d5ff}.endpoint-banner .eb-left{flex:1 1 380px}.eb-label{font-size:12px;font-weight:600;color:#6d28d9;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.eb-url{display:flex;align-items:center;gap:10px}.eb-url code{font-family:ui-monospace,SF Mono,monospace;font-size:20px;font-weight:700;color:var(--text);background:var(--surface);padding:6px 14px;border-radius:8px;border:1px solid var(--hairline)}.eb-hint{font-size:12px;color:var(--text-muted);margin-top:8px;max-width:480px}.eb-right{display:flex;flex-direction:column;gap:8px;min-width:220px}.eb-noreader{font-size:13px;color:var(--text-dim);font-style:italic;padding:8px 0}.reader-chip{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--hairline);border-radius:8px;padding:8px 12px}.reader-chip .rc-dot{width:9px;height:9px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981}.rc-name{font-family:ui-monospace,monospace;font-size:13px;font-weight:600;color:var(--text)}.rc-meta{font-size:11px;color:var(--text-dim)}.saved-banner{display:flex;align-items:center;gap:12px;padding:10px 16px;margin-bottom:14px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;font-size:13px;color:#1e40af}.saved-banner button{margin-left:auto}.rtest-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.rtest-pause{font-size:13px;color:var(--text-muted);display:inline-flex;align-items:center;gap:5px;cursor:pointer}.rtest-stats{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:16px}.rt-stat{background:var(--surface);border:1px solid var(--hairline);border-radius:10px;padding:12px 14px}.rt-stat .k{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.rt-stat .v{font-size:24px;font-weight:800;color:var(--text);margin-top:2px}.rt-stat .v.vsmall{font-size:14px;font-weight:600}.rt-stat.accent{border-color:#ddd6fe}.rt-stat.accent .v{color:#7c3aed}.rt-stat.success{border-color:#a7f3d0}.rt-stat.success .v{color:#059669}.rt-stat.warning{border-color:#fde68a}.rt-stat.warning .v{color:#d97706}.rt-stat.error{border-color:#fecaca}.rt-stat.error .v{color:#dc2626}.rt-stat.spark{grid-column:span 1}.sparkline{display:flex;align-items:flex-end;gap:2px;height:30px;margin-top:4px}.sparkline span{flex:1;background:linear-gradient(180deg,#a78bfa,#7c3aed);border-radius:1px;min-height:2px}@media (max-width: 1100px){.rtest-stats{grid-template-columns:repeat(4,1fr)}.rt-stat.spark{grid-column:span 4}}.rtest-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:16px}@media (max-width: 980px){.rtest-grid{grid-template-columns:1fr}}.rtest .panel{padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:620px}.rtest .panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--surface-3)}.rtest .panel-head h3{margin:0;font-size:14px}.rtest .filter{margin:10px 16px;width:calc(100% - 32px)}.input-sm,.select-sm{padding:6px 10px;font-size:13px}.tag-list,.event-list{overflow-y:auto;flex:1;padding:0 8px 8px}.tag-row{display:grid;grid-template-columns:1fr auto 44px;gap:10px;align-items:center;padding:9px 10px;border-radius:8px}.tag-row:hover{background:var(--surface-2)}.tr-hex{font-family:ui-monospace,monospace;font-weight:700;color:var(--text);font-size:13px}.tr-dec{font-family:ui-monospace,monospace;font-size:11px;color:var(--text-dim)}.tr-meta{display:flex;gap:8px;align-items:center;font-size:11px}.tr-rssi{color:#059669;font-weight:600;font-family:ui-monospace,monospace}.tr-ant{color:var(--text-muted)}.tr-flag{padding:1px 6px;border-radius:4px;font-weight:700;font-size:10px;text-transform:uppercase}.tr-flag.alarm{background:#fee2e2;color:#b91c1c}.tr-flag.entry{background:#dbeafe;color:#1d4ed8}.tr-count{font-family:ui-monospace,monospace;font-weight:700;color:#7c3aed;text-align:right}.event-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:12px}.event-row:hover{background:var(--surface-2)}.event-row.active{background:#f5f3ff}.ev-check{flex-shrink:0}.ev-cmd{font-weight:700;min-width:96px}.ev-dev{font-family:ui-monospace,monospace;color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ev-tags{background:#ede9fe;color:#6d28d9;padding:1px 7px;border-radius:999px;font-weight:600;font-size:11px}.ev-crc.ok{color:#16a34a;font-weight:700}.ev-crc.bad{color:#dc2626;font-weight:700}.ev-len{color:var(--text-dim);font-family:ui-monospace,monospace}.ev-time{color:var(--text-dim);font-family:ui-monospace,monospace;white-space:nowrap}.rtest .empty{padding:48px 16px;text-align:center;color:var(--text-dim);font-size:13px}.hexdump{background:#0f172a;border-radius:8px;padding:12px 14px;overflow-x:auto;font-family:ui-monospace,SF Mono,monospace;font-size:12px;line-height:1.7}.hex-row{display:flex;gap:14px;white-space:nowrap}.hex-off{color:var(--text-muted);-webkit-user-select:none;user-select:none}.hex-bytes{color:#cbd5e1}.hex-b{padding:0 1px;cursor:default;border-radius:2px}.hex-b.hl{background:#a78bfa59}.hex-ascii{color:var(--text-muted)}.hex-hover{margin-top:10px;color:#cbd5e1;font-size:12px}.hex-hover strong{color:#a78bfa}.field-table{display:flex;flex-direction:column;gap:3px}.field-row{display:grid;grid-template-columns:56px 1fr 1.4fr;gap:10px;padding:7px 10px;background:var(--surface-2);border-radius:6px;font-size:12px}.fr-off{font-family:ui-monospace,monospace;font-weight:700}.fr-name{color:var(--text-muted);font-weight:600}.fr-val{font-family:ui-monospace,monospace;color:var(--text);word-break:break-all}.ptag-row{display:flex;gap:10px;align-items:center;padding:8px 10px;background:var(--surface-2);border-radius:6px;font-family:ui-monospace,monospace;font-size:12px;flex-wrap:wrap}.pt-hex{font-weight:700;color:var(--text)}.pt-dec{color:var(--text-dim)}.pt-rssi{color:#059669;font-weight:600}.pt-ant,.pt-st{color:var(--text-muted)}.diff-summary{display:flex;gap:18px;margin-bottom:12px;font-size:13px;flex-wrap:wrap}.diff-count{color:#dc2626;font-weight:700;margin-left:auto}.diff-cells{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:4px}.diff-cell{display:flex;flex-direction:column;align-items:center;background:var(--surface-2);border-radius:5px;padding:4px;font-family:ui-monospace,monospace;font-size:11px}.diff-cell.diff{background:#fef2f2;border:1px solid #fecaca}.dc-off{color:var(--text-dim);font-size:9px}.dc-a{color:var(--text)}.dc-b{color:#7c3aed}.diff-cell.diff .dc-a,.diff-cell.diff .dc-b{color:#b91c1c;font-weight:700}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;opacity:0;pointer-events:none;transition:opacity .18s}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{background:var(--surface);border-radius:12px;width:min(560px,100%);max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px -16px #0006}.modal-head{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--surface-3)}.modal-head h3{margin:0;font-size:15px}.modal-head .close,.drawer-head .close{margin-left:auto;border:1px solid var(--hairline);background:var(--surface);width:30px;height:30px;border-radius:6px;cursor:pointer;color:var(--text-muted)}.modal-body{padding:14px 20px;overflow-y:auto}.session-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--surface-3)}.sr-name{font-weight:600;color:var(--text)}.sr-meta{font-size:12px;color:var(--text-dim)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a5c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .18s;z-index:90}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(640px,94vw);background:var(--surface);box-shadow:-12px 0 48px -16px #0000004d;transform:translate(100%);transition:transform .24s cubic-bezier(.22,.61,.36,1);z-index:100;display:flex;flex-direction:column}.drawer.open{transform:translate(0)}.drawer.wide{width:min(820px,96vw)}.drawer-head{display:flex;align-items:center;gap:12px;padding:16px 22px;border-bottom:1px solid var(--surface-3)}.drawer-head h3{margin:0;font-size:15px}.drawer-head .sub{color:var(--text-dim);font-size:12px;font-family:ui-monospace,monospace}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px}.drawer-section{margin-bottom:22px}.drawer-section h4{margin:0 0 8px;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim)}.analytics .page-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.window-switch{display:inline-flex;border:1px solid var(--hairline);border-radius:8px;overflow:hidden}.ws-btn{padding:6px 12px;font-size:13px;font-weight:600;background:var(--surface);border:none;border-right:1px solid var(--hairline);cursor:pointer;color:var(--text-muted)}.ws-btn:last-child{border-right:none}.ws-btn.active{background:#7c3aed;color:#fff}.analytics-kpi{grid-template-columns:repeat(5,1fr)}@media (max-width: 1100px){.analytics-kpi{grid-template-columns:repeat(2,1fr)}}.chart-card{padding:16px;margin-bottom:16px}.chart-card .panel-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}.chart-card .panel-head h3{margin:0;font-size:14px}.chart-card .muted{color:var(--text-dim);font-size:12px}.mono{font-family:ui-monospace,SF Mono,monospace}.bar-chart{display:flex;align-items:flex-end;gap:2px;height:150px;padding-top:6px}.bar-chart.rssi{height:140px;align-items:flex-end}.bc-col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;min-width:3px}.bc-bar{width:100%;background:linear-gradient(180deg,#a78bfa,#7c3aed);border-radius:2px 2px 0 0;transition:height .3s}.bc-bar.rssi{background:linear-gradient(180deg,#34d399,#0891b2)}.bc-label{font-size:9px;color:var(--text-dim);margin-top:3px;font-family:ui-monospace,monospace}.analytics-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 900px){.analytics-2col{grid-template-columns:1fr}}.hbar-list{display:flex;flex-direction:column;gap:8px}.hbar-row{display:grid;grid-template-columns:90px 1fr auto;gap:10px;align-items:center;font-size:13px}.hbar-label{color:var(--text-muted);font-weight:600}.hbar-track{background:var(--surface-3);border-radius:999px;height:14px;overflow:hidden}.hbar-fill{height:100%;background:linear-gradient(90deg,#7c3aed,#0891b2);border-radius:999px}.hbar-val{font-family:ui-monospace,monospace;color:var(--text);font-weight:600;white-space:nowrap}.heatmap-wrap{overflow-x:auto}.heatmap{border-collapse:collapse;font-size:11px;width:100%}.heatmap th.hm-hr{width:3.6%;text-align:center;color:var(--text-dim);font-weight:600;font-size:10px;padding:2px}.heatmap th.hm-corner{text-align:left;color:var(--text-muted);font-size:11px;padding:4px 8px}.heatmap td.hm-reader{font-weight:600;color:var(--text);padding:4px 8px;white-space:nowrap;font-size:12px}.heatmap td.hm-cell{text-align:center;padding:0;height:26px;border:1px solid var(--surface);font-size:10px;color:var(--text);font-family:ui-monospace,monospace}.data-table tr.clickable{cursor:pointer}.data-table tr.clickable:hover{background:#f5f3ff}.data-table .muted{color:var(--text-dim);font-size:11px}.asset-pill{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:999px;background:#ede9fe;color:#6d28d9;font-size:10px;font-weight:700}.tag-summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.tag-summary-grid>div{background:var(--surface-2);border-radius:8px;padding:10px 12px}.ts-k{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.ts-v{font-size:18px;font-weight:700;color:var(--text)}.ts-v.sm{font-size:13px;font-weight:600}.timeline{display:flex;flex-direction:column;gap:2px;max-height:360px;overflow-y:auto;border-left:2px solid var(--hairline);padding-left:12px}.tl-ev{display:grid;grid-template-columns:72px 1fr;gap:8px;padding:6px 0;font-size:12px;position:relative}.tl-ev:before{content:"";position:absolute;left:-17px;top:10px;width:7px;height:7px;border-radius:50%;background:#7c3aed}.tl-time{color:var(--text-dim);font-family:ui-monospace,monospace}.tl-reader{color:var(--text);font-weight:600}.tl-meta{grid-column:2;color:var(--text-muted);font-size:11px;font-family:ui-monospace,monospace}.theme-toggle{display:inline-flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;color:var(--text-secondary);font:inherit}.theme-toggle .tt-track{position:relative;width:42px;height:24px;border-radius:999px;background:var(--surface-3);border:1px solid var(--hairline);transition:background .3s ease;flex-shrink:0}.theme-toggle .tt-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--accent-purple),var(--accent-cyan));color:#fff;display:flex;align-items:center;justify-content:center;transition:transform .32s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 6px #00000059}[data-theme=light] .theme-toggle .tt-thumb{transform:translate(18px)}.theme-toggle .tt-label{font-size:13px;font-weight:500}.theme-toggle.pill{width:100%;justify-content:flex-start;padding:9px 12px;border-radius:8px;background:var(--surface-2);border:1px solid var(--hairline);margin-bottom:10px}.theme-toggle.pill:hover{border-color:var(--accent-purple)}.theme-toggle.pill .tt-label{color:var(--text-primary)}.login-theme-toggle{position:absolute;top:22px;right:24px;z-index:5}.page{animation:fadeUp .42s cubic-bezier(.22,.61,.36,1) both}.main-content{position:relative}.card{transition:transform .22s ease,box-shadow .22s ease,background .3s ease,border-color .3s ease}.chart-card:hover,.rt-stat:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.rtest-stats .rt-stat{animation:popIn .4s ease both}.rtest-stats .rt-stat:nth-child(2){animation-delay:.05s}.rtest-stats .rt-stat:nth-child(3){animation-delay:.1s}.rtest-stats .rt-stat:nth-child(4){animation-delay:.15s}.rtest-stats .rt-stat:nth-child(5){animation-delay:.2s}.rtest-stats .rt-stat:nth-child(6){animation-delay:.25s}.rtest-stats .rt-stat:nth-child(7){animation-delay:.3s}.nav-link{transition:background .15s,color .15s,transform .15s}.nav-link:hover{transform:translate(3px)}.nav-link.active{box-shadow:inset 0 0 0 1px #7c3aed40,0 0 18px -6px #7c3aed80}.bc-bar{transform-origin:bottom;animation:growBar .6s cubic-bezier(.22,.61,.36,1) both}.hbar-fill{animation:fadeIn .6s ease both}.login-logo{animation:popIn .5s ease both}.sidebar-logo .logo-pad{transition:transform .3s ease}.sidebar-logo:hover .logo-pad{transform:translateY(-2px)}.btn{transition:transform .12s ease,box-shadow .2s ease,background .2s ease}.btn:active{transform:scale(.97)}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 37%,var(--surface-2) 63%);background-size:800px 100%;animation:shimmer 1.4s infinite linear;border-radius:8px}.status-pill.connected .dot,.status-dot.online{position:relative}.status-pill.connected .dot:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:1px solid var(--online);animation:ringPulse 1.8s ease-out infinite}.area-chart{position:relative}.area-tip{position:absolute;top:-6px;transform:translate(-50%);background:var(--surface);border:1px solid var(--hairline);border-radius:8px;padding:6px 10px;font-size:12px;color:var(--text);box-shadow:var(--shadow-sm);pointer-events:none;white-space:nowrap}.area-tip strong{color:var(--accent-purple);font-size:14px}.area-tip span{color:var(--text-dim);font-size:10px;font-family:ui-monospace,monospace}.donut-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center;padding:6px 0}.donut-legend{display:flex;flex-direction:column;gap:7px;min-width:160px}.dl-row{display:grid;grid-template-columns:12px 1fr auto;gap:9px;align-items:center;font-size:13px}.dl-dot{width:11px;height:11px;border-radius:3px}.dl-label{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dl-val{color:var(--text-dim);font-family:ui-monospace,monospace;font-weight:600}.cmdk-launcher{display:flex;align-items:center;gap:8px;margin:10px 12px 6px;padding:7px 10px;background:var(--surface-2);border:1px solid var(--hairline);border-radius:8px;color:var(--text-muted);font-size:13px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.cmdk-launcher:hover{color:var(--text);border-color:var(--accent-purple)}.cmdk-launcher span{flex:1;text-align:left}.cmdk-launcher kbd,.cmdk kbd,.cmdk-footer kbd{background:var(--surface-3);border:1px solid var(--hairline);border-radius:4px;padding:1px 6px;font-size:11px;font-family:ui-monospace,SF Mono,monospace;color:var(--text-muted)}.cmdk-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;z-index:300;animation:fadeIn .14s ease}.cmdk{width:min(620px,92vw);background:var(--surface);border:1px solid var(--hairline);border-radius:14px;box-shadow:0 30px 80px -16px #0000008c;display:flex;flex-direction:column;overflow:hidden;animation:popIn .18s cubic-bezier(.22,.61,.36,1)}.cmdk-input{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--hairline);color:var(--text-muted)}.cmdk-input input{flex:1;background:none;border:none;outline:none;font:inherit;color:var(--text);font-size:15px}.cmdk-list{max-height:50vh;overflow-y:auto;padding:6px 0}.cmdk-item{display:grid;grid-template-columns:28px 1fr auto;gap:10px;align-items:center;padding:9px 16px;cursor:pointer;border-left:2px solid transparent}.cmdk-item.active{background:var(--surface-2);border-left-color:var(--accent-purple)}.cmdk-icon{font-size:17px;text-align:center}.cmdk-text{min-width:0}.cmdk-label{color:var(--text);font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cmdk-sub{color:var(--text-dim);font-size:12px;font-family:ui-monospace,SF Mono,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cmdk-type{font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;opacity:.8}.cmdk-empty{padding:30px 16px;text-align:center;color:var(--text-dim);font-size:13px}.cmdk-footer{display:flex;gap:18px;justify-content:flex-end;padding:8px 14px;border-top:1px solid var(--hairline);font-size:11px;color:var(--text-dim)}.cmdk-footer span{display:inline-flex;gap:5px;align-items:center}.presence-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}@media (max-width: 800px){.presence-stats{grid-template-columns:repeat(2,1fr)}}.pstat{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:10px;background:var(--surface);border:1px solid var(--hairline);cursor:pointer;text-align:left;font:inherit;transition:border-color .15s,transform .15s}.pstat:not(.total):hover{transform:translateY(-2px)}.pstat.active{border-color:var(--accent-purple);box-shadow:0 0 0 1px var(--accent-purple) inset}.pstat.total{cursor:default;opacity:.85}.pstat-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 10px currentColor}.pstat.present .pstat-dot{background:#10b981;color:#10b981}.pstat.stale .pstat-dot{background:#f59e0b;color:#f59e0b}.pstat.missing .pstat-dot{background:#ef4444;color:#ef4444}.pstat-v{font-size:24px;font-weight:800;color:var(--text);line-height:1.1}.pstat-k{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim)}.presence-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.presence-card{background:var(--surface);border:1px solid var(--hairline);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;animation:popIn .35s ease both;position:relative;overflow:hidden}.presence-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--text-dim)}.presence-card.state-present:before{background:#10b981}.presence-card.state-stale:before{background:#f59e0b}.presence-card.state-missing:before{background:#ef4444;opacity:.7}.presence-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent-purple)}.presence-card.state-missing{opacity:.85}.pc-head{display:grid;grid-template-columns:32px 1fr auto;gap:10px;align-items:center}.pc-emoji{font-size:22px;line-height:1}.pc-id{min-width:0}.pc-name{font-weight:700;color:var(--text);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pc-hex{font-size:11px;color:var(--text-dim)}.pc-presence{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;display:inline-flex;align-items:center;gap:5px}.pc-presence .pc-dot{width:8px;height:8px;border-radius:50%}.presence-card.state-present .pc-presence .pc-dot{animation:ringPulse 1.6s ease-out infinite;box-shadow:0 0 0 0 currentColor}.pc-loc{padding:6px 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}.pc-zone{color:var(--text);font-weight:600;font-size:13px}.pc-reader{font-size:11px;margin-top:1px}.pc-meta{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}.pc-rssi{min-width:0}.pc-rssi-label{display:flex;justify-content:space-between;font-size:11px;margin-bottom:4px}.pc-rssi-bar{background:var(--surface-3);border-radius:999px;height:6px;overflow:hidden}.pc-rssi-fill{height:100%;background:linear-gradient(90deg,#ef4444,#f59e0b 45%,#10b981);border-radius:999px;transition:width .4s ease}.pc-ago{font-size:12px;font-family:ui-monospace,monospace;color:var(--text-muted);font-weight:600;white-space:nowrap}.pc-flags{display:flex;gap:6px;flex-wrap:wrap;align-items:center;font-size:11px}.pc-flag{padding:2px 7px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.pc-flag.alarm{background:#ef444426;color:#ef4444}.pc-flag.entry{background:#3b82f626;color:#3b82f6}.pc-owner{font-style:italic}.pc-reads{color:var(--accent-purple);font-weight:600}.presence-card .muted{color:var(--text-dim)}.guide-layout{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:start}@media (max-width: 900px){.guide-layout{grid-template-columns:1fr}}.guide-toc{position:sticky;top:16px;display:flex;flex-direction:column;gap:8px}.guide-toc input{margin-bottom:6px}.guide-toc nav{display:flex;flex-direction:column;gap:2px}.toc-link{text-align:left;padding:8px 12px;border-radius:8px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font:inherit;font-size:13px;border-left:2px solid transparent}.toc-link:hover{color:var(--text);background:var(--surface-2)}.toc-link.active{color:var(--accent-purple);border-left-color:var(--accent-purple);background:var(--surface-2);font-weight:600}.guide-body{display:flex;flex-direction:column;gap:16px}.guide-section{padding:24px 28px;scroll-margin-top:16px}.guide-section h2{font-size:20px;margin-bottom:14px;color:var(--text)}.guide-content{color:var(--text);line-height:1.7;font-size:14px}.guide-content h3{margin:18px 0 8px;font-size:15px;color:var(--text)}.guide-content h3:first-child{margin-top:0}.guide-content p,.guide-content ul{margin-bottom:10px;color:var(--text-muted)}.guide-content ul{padding-left:22px}.guide-content li{margin-bottom:4px}.guide-content strong{color:var(--text)}.guide-content code{background:var(--surface-3);padding:1px 6px;border-radius:4px;font-family:ui-monospace,SF Mono,monospace;font-size:12px;color:var(--accent-purple)}.guide-content kbd{background:var(--surface-3);border:1px solid var(--hairline);border-radius:4px;padding:1px 6px;font-size:11px;font-family:ui-monospace,SF Mono,monospace;color:var(--text-muted)}.user-mgmt-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-purple),var(--accent-cyan));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.you-tag{margin-left:6px;padding:1px 7px;border-radius:999px;background:var(--accent-purple);color:#fff;font-size:10px;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.role-badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.role-badge.role-admin{background:#ef444426;color:#ef4444}.role-badge.role-op{background:#7c3aed26;color:var(--accent-purple)}.role-badge.role-viewer{background:#64748b26;color:var(--text-muted)}.form-row{margin-bottom:14px}.form-row label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.role-picker{display:flex;flex-direction:column;gap:8px}.role-option{display:flex;gap:12px;align-items:flex-start;padding:10px 12px;border-radius:8px;border:1px solid var(--hairline);background:var(--surface-2);cursor:pointer;transition:border-color .15s,background .15s}.role-option:hover{border-color:var(--accent-purple)}.role-option.selected{border-color:var(--accent-purple);background:#7c3aed14}.role-option input{margin-top:4px}.ro-label{font-weight:600;color:var(--text);font-size:14px}.ro-desc{font-size:12px;color:var(--text-muted);margin-top:2px}.alert{padding:10px 14px;border-radius:8px;margin-bottom:14px;cursor:pointer;font-size:13px}.alert-success{background:#10b9811f;color:#10b981;border:1px solid rgba(16,185,129,.3)}.alert-error{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.activity-table td{vertical-align:middle}.log-action{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:13px}.la-icon{font-size:14px}.log-fail td{background:#ef44440a}.log-fail-tag{margin-left:8px;padding:1px 7px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;background:#ef444426;color:#ef4444}.pager{display:flex;justify-content:center;align-items:center;gap:16px;padding:14px;border-top:1px solid var(--hairline);font-size:13px;color:var(--text-muted)}.log-details{background:var(--surface-3);border:1px solid var(--hairline);border-radius:8px;padding:12px;margin:0;font-family:ui-monospace,SF Mono,monospace;font-size:12px;color:var(--text);white-space:pre-wrap;word-break:break-all;max-height:320px;overflow-y:auto}
