@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600&display=swap";:root{--cf-primary: #2e5cbf;--cf-primary-dark: #1a3a8f;--cf-blue: #008AEF;--cf-teal: #56C5D0;--cf-yellow: #EEA616;--cf-red: #C4161C;--cf-green: #1db85a;--cf-header-gradient: linear-gradient(90deg, #2e5cbf 0%, #008AEF 100%)}:root{--bg: #0a0e14;--surface: #111720;--surface2: #1a2336;--border: #1e2d42;--accent: var(--cf-blue);--accent2: var(--cf-green);--warn: var(--cf-yellow);--danger: var(--cf-red);--text: #c8d8ee;--text-dim: #4e6a8e;--text-bright: #e8f0fc;--mono: "IBM Plex Mono", "Cascadia Code", "Consolas", monospace;--sans: "IBM Plex Sans", "Segoe UI", system-ui, sans-serif}:root.light{--bg: #f0f4fa;--surface: #ffffff;--surface2: #e4ecf6;--border: #c0cedf;--accent: var(--cf-primary);--accent2: #1a7a40;--warn: #b87800;--danger: var(--cf-red);--text: #1a2840;--text-dim: #5070a0;--text-bright: #0a1828}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;opacity:.2}:root.light body:before{opacity:.06}.cf-title{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--text-bright);letter-spacing:.05em}.cf-subtitle{font-size:12px;color:var(--text-dim);margin-top:2px}.cf-label{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text)}.cf-meta{font-family:var(--mono);font-size:10px;color:var(--text-dim)}header{background:var(--cf-header-gradient);grid-column:1 / -1;display:flex;align-items:center;padding:0 24px;gap:16px;height:56px;flex-shrink:0;position:sticky;top:0;z-index:100}header,header *{color:#ffffffe6!important}header .logo-module{color:#ffffffa6!important}.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}.logo-img{height:28px;width:auto}.logo-img-dark{display:block}.logo-img-light{display:none}header .logo-img-dark{display:block!important}header .logo-img-light{display:none!important}.logo-divider{width:1px;height:24px;background:#ffffff4d}.logo-module{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase}.header-sep{flex:1}.broker-status{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px}.broker-status span{color:#ffffffe6!important}.conn-dot{width:7px;height:7px;border-radius:50%;background:var(--danger);flex-shrink:0}.conn-dot.connected{background:var(--cf-green)!important;box-shadow:0 0 6px #1db85acc;animation:pulse 2s infinite;color:transparent!important}.conn-dot:not(.connected){background:var(--cf-red)!important;color:transparent!important}.conn-label{transition:color .3s}.header-toggle{display:flex;align-items:center;gap:6px}.toggle-btn{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.08em;padding:4px 10px;border:1.5px solid rgba(255,255,255,.45);border-radius:4px;background:#ffffff1f;color:#fff!important;cursor:pointer;transition:all .15s;white-space:nowrap}.toggle-btn:hover{background:#ffffff47!important;border-color:#fff!important}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.btn{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;padding:7px 16px;border-radius:5px;cursor:pointer;transition:all .15s;text-transform:uppercase;border:1.5px solid var(--cf-primary);background:var(--cf-primary);color:#fff}.btn:hover{background:#1a3a8f;border-color:#1a3a8f}.btn-primary{background:var(--cf-header-gradient);border-color:var(--cf-primary);color:#fff;font-weight:700;box-shadow:0 2px 8px #2e5cbf59}.btn-primary:hover{background:linear-gradient(135deg,#1a3a8f,#007acc);border-color:#1a3a8f;box-shadow:0 4px 14px #2e5cbf73;transform:translateY(-1px)}.btn-success{background:var(--cf-header-gradient);border-color:var(--cf-primary);color:#fff;font-weight:700;box-shadow:0 2px 8px #2e5cbf59}.btn-success:hover{background:linear-gradient(135deg,#1a3a8f,#007acc);border-color:#1a3a8f}.btn-danger{background:#c4161c1a;border-color:var(--cf-red);color:var(--cf-red)}.btn-danger:hover{background:var(--cf-red);color:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:28px;width:420px;display:flex;flex-direction:column;gap:16px}:root.light .modal{box-shadow:0 8px 40px #0000002e}.modal-title{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:.05em}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text)}.form-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:4px;padding:8px 12px;font-family:var(--mono);font-size:12px;color:var(--text);outline:none;transition:border-color .15s;width:100%}.form-input:focus{border-color:var(--cf-primary)}:root.light .form-input{background:#fff;border-color:#b0c4de;color:#1a2840}:root.light .form-input:focus{border-color:var(--cf-primary)}.status-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.08em;padding:3px 10px;border-radius:20px;text-transform:uppercase}.status-badge.online{background:#1db85a1f;border:1px solid rgba(29,184,90,.3);color:var(--cf-green)}.status-badge.offline{background:#c4161c14;border:1px solid rgba(196,22,28,.2);color:var(--cf-red)}.status-dot-sm{width:5px;height:5px;border-radius:50%;background:currentColor}.status-badge.online .status-dot-sm{box-shadow:0 0 4px currentColor;animation:pulse 2s infinite}:root{--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-pill: 20px;--shadow-sm: 0 1px 4px rgba(0,0,0,.12);--shadow-md: 0 4px 16px rgba(0,0,0,.2);--shadow-lg: 0 8px 32px rgba(0,0,0,.28);--shadow-inset: inset 0 1px 3px rgba(0,0,0,.15);--z-base: 1;--z-nav: 10;--z-header: 100;--z-panel: 999;--z-modal: 1000;--z-toast: 1100;--transition-fast: .12s ease;--transition: .18s ease;--transition-slow: .3s cubic-bezier(.4,0,.2,1)}.cf-tabs{display:flex;border-bottom:1.5px solid var(--border);gap:0;overflow-x:auto;scrollbar-width:none}.cf-tabs::-webkit-scrollbar{display:none}.cf-tab{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:10px 18px;color:var(--text-dim);background:none;border:none;border-bottom:2.5px solid transparent;margin-bottom:-1.5px;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;flex-shrink:0}.cf-tab:hover{color:var(--text)}.cf-tab.active{color:var(--cf-blue);border-bottom-color:var(--cf-blue);font-weight:700}:root.light .cf-tab.active{color:var(--cf-primary);border-bottom-color:var(--cf-primary)}.cf-tab-panel{display:none}.cf-tab-panel.active{display:block}.cf-tabs.pill{border-bottom:none;gap:4px;padding:4px;background:var(--surface2);border-radius:var(--radius-lg);width:fit-content}.cf-tabs.pill .cf-tab{border-bottom:none;border-radius:var(--radius-md);margin-bottom:0;padding:6px 14px}.cf-tabs.pill .cf-tab.active{background:var(--surface);color:var(--text-bright);border-color:transparent;box-shadow:var(--shadow-sm)}:root.light .cf-tabs.pill .cf-tab.active{color:var(--cf-primary)}.cf-alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid;font-size:13px;line-height:1.5;animation:fadeIn .2s ease}.cf-alert .alert-icon{font-size:14px;flex-shrink:0;margin-top:1px}.cf-alert .alert-body{flex:1}.cf-alert .alert-title{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}.cf-alert .alert-close{background:none;border:none;cursor:pointer;color:inherit;opacity:.5;font-size:16px;line-height:1;padding:0;flex-shrink:0}.cf-alert .alert-close:hover{opacity:1}.cf-alert.info{background:#008aef14;border-color:#008aef40;color:var(--cf-blue)}.cf-alert.success{background:#1db85a14;border-color:#1db85a40;color:var(--cf-green)}.cf-alert.warn{background:#eea61614;border-color:#eea61640;color:var(--cf-yellow)}.cf-alert.danger{background:#c4161c14;border-color:#c4161c40;color:var(--cf-red)}:root.light .cf-alert.info{background:#e8f4fe;border-color:#90c4f4;color:#0060b8}:root.light .cf-alert.success{background:#e8f8ee;border-color:#80d8a0;color:#1a7a40}:root.light .cf-alert.warn{background:#fef8e8;border-color:#f0c860;color:#8a6000}:root.light .cf-alert.danger{background:#fee8e8;border-color:#f08080;color:#a00000}.cf-toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.cf-toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-md);font-family:var(--mono);font-size:11px;font-weight:500;color:var(--text);min-width:240px;max-width:360px;pointer-events:all;transform:translate(110%);transition:transform var(--transition-slow),opacity var(--transition);opacity:0}.cf-toast.show{transform:translate(0);opacity:1}.cf-toast .toast-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cf-toast.info .toast-dot{background:var(--cf-blue)}.cf-toast.success .toast-dot{background:var(--cf-green);box-shadow:0 0 5px #1db85ab3}.cf-toast.warn .toast-dot{background:var(--cf-yellow)}.cf-toast.danger .toast-dot{background:var(--cf-red)}.cf-toast .toast-msg{flex:1}.cf-toast .toast-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:14px;padding:0;line-height:1}.cf-toast .toast-close:hover{color:var(--text)}.cf-tag{display:inline-flex;align-items:center;gap:var(--space-1);font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--surface2);color:var(--text);white-space:nowrap;line-height:1.4}.cf-tag .tag-remove{background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:12px;padding:0;line-height:1;margin-left:2px}.cf-tag .tag-remove:hover{opacity:1}.cf-tag.blue{background:#008aef1a;border-color:#008aef40;color:var(--cf-blue)}.cf-tag.green{background:#1db85a1a;border-color:#1db85a40;color:var(--cf-green)}.cf-tag.yellow{background:#eea6161a;border-color:#eea61640;color:var(--cf-yellow)}.cf-tag.red{background:#c4161c1a;border-color:#c4161c40;color:var(--cf-red)}.cf-tag.teal{background:#56c5d01a;border-color:#56c5d040;color:var(--cf-teal)}.cf-tag.primary{background:#2e5cbf1f;border-color:#2e5cbf4d;color:#6090d0}:root.light .cf-tag.primary{color:var(--cf-primary)}.cf-switch{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none}.cf-switch input[type=checkbox]{display:none}.cf-switch-track{width:36px;height:20px;background:var(--border);border-radius:10px;position:relative;transition:background var(--transition);flex-shrink:0}.cf-switch-track:after{content:"";position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform var(--transition);box-shadow:var(--shadow-sm)}.cf-switch input:checked+.cf-switch-track{background:var(--cf-green)}.cf-switch input:checked+.cf-switch-track:after{transform:translate(16px)}.cf-switch-label{font-family:var(--mono);font-size:11px;color:var(--text)}.cf-switch:has(input:disabled){opacity:.4;cursor:not-allowed}.cf-switch.sm .cf-switch-track{width:28px;height:16px}.cf-switch.sm .cf-switch-track:after{width:10px;height:10px;top:3px;left:3px}.cf-switch.sm input:checked+.cf-switch-track:after{transform:translate(12px)}.cf-tooltip{position:relative;display:inline-flex}.cf-tooltip:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%) scale(.9);background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.04em;padding:5px 10px;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast),transform var(--transition-fast);z-index:var(--z-modal);box-shadow:var(--shadow-md)}.cf-tooltip:before{content:"";position:absolute;bottom:calc(100% + 1px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--border);pointer-events:none;opacity:0;transition:opacity var(--transition-fast)}.cf-tooltip:hover:after,.cf-tooltip:hover:before{opacity:1;transform:translate(-50%) scale(1)}.cf-tooltip.bottom:after{bottom:auto;top:calc(100% + 6px);transform:translate(-50%) scale(.9)}.cf-tooltip.bottom:before{bottom:auto;top:calc(100% + 1px);border-top-color:transparent;border-bottom-color:var(--border)}.cf-tooltip.bottom:hover:after{transform:translate(-50%) scale(1)}.cf-progress{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;position:relative}.cf-progress-bar{height:100%;width:var(--pct, 0%);background:var(--pct-color, var(--cf-blue));border-radius:3px;transition:width .5s ease}.cf-progress.sm{height:3px}.cf-progress.lg{height:10px;border-radius:5px}.cf-progress.lg .cf-progress-bar{border-radius:5px}.cf-progress-wrap{display:flex;flex-direction:column;gap:var(--space-1)}.cf-progress-meta{display:flex;justify-content:space-between;align-items:baseline}.cf-progress-label{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.cf-progress-value{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--text)}.cf-progress.loading .cf-progress-bar{width:40%;animation:progress-indeterminate 1.4s ease-in-out infinite}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(350%)}}.cf-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10) var(--space-8);text-align:center}.cf-empty .empty-icon{font-size:32px;opacity:.35;line-height:1}.cf-empty .empty-title{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.06em;color:var(--text)}.cf-empty .empty-desc{font-size:12px;color:var(--text-dim);max-width:260px;line-height:1.6}.cf-skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--border) 50%,var(--surface2) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-shimmer 1.6s ease-in-out infinite}.cf-skeleton.circle{border-radius:50%}.cf-skeleton.text{height:12px}.cf-skeleton.title{height:18px;width:60%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cf-breadcrumb{display:flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.cf-breadcrumb .bc-item{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--text-dim);text-decoration:none;letter-spacing:.04em;transition:color var(--transition-fast)}.cf-breadcrumb .bc-item:hover{color:var(--cf-blue)}.cf-breadcrumb .bc-item.current{color:var(--text);font-weight:700;cursor:default}:root.light .cf-breadcrumb .bc-item:hover{color:var(--cf-primary)}.cf-breadcrumb .bc-sep{font-size:10px;color:var(--text-dim);opacity:.5;-webkit-user-select:none;user-select:none}.cf-select-wrap{position:relative;display:inline-block}.cf-select-wrap:after{content:"▾";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--text-dim);pointer-events:none}.cf-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:7px 28px 7px 12px;font-family:var(--mono);font-size:11px;font-weight:500;color:var(--text);cursor:pointer;outline:none;transition:border-color var(--transition-fast);min-width:120px}.cf-select:focus{border-color:var(--cf-blue)}.cf-select:hover{border-color:#008aef66}:root.light .cf-select{background:#fff;border-color:#b0c4de;color:#1a2840}:root.light .cf-select:focus{border-color:var(--cf-primary)}.cf-check,.cf-radio{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--mono);font-size:11px;color:var(--text);-webkit-user-select:none;user-select:none}.cf-check input[type=checkbox],.cf-radio input[type=radio]{display:none}.cf-check span:first-of-type,.cf-radio span:first-of-type{width:16px;height:16px;border:1.5px solid var(--border);background:var(--surface2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.cf-check span:first-of-type{border-radius:var(--radius-sm)}.cf-radio span:first-of-type{border-radius:50%}.cf-check input:checked+span:first-of-type{background:var(--cf-blue);border-color:var(--cf-blue)}.cf-check input:checked+span:first-of-type:after{content:"";display:block;width:4px;height:8px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg) translateY(-1px)}.cf-radio input:checked+span:first-of-type{border-color:var(--cf-blue)}.cf-radio input:checked+span:first-of-type:after{content:"";display:block;width:8px;height:8px;background:var(--cf-blue);border-radius:50%}:root.light .cf-check input:checked+span:first-of-type{background:var(--cf-primary);border-color:var(--cf-primary)}:root.light .cf-radio input:checked+span:first-of-type{border-color:var(--cf-primary)}:root.light .cf-radio input:checked+span:first-of-type:after{background:var(--cf-primary)}.cf-divider{border:none;border-top:1px solid var(--border);margin:var(--space-4) 0}.cf-divider.vertical{border-top:none;border-left:1px solid var(--border);margin:0 var(--space-4);align-self:stretch}.cf-pagination{display:flex;align-items:center;gap:var(--space-1)}.cf-pagination .pg-btn{font-family:var(--mono);font-size:11px;font-weight:600;min-width:30px;height:30px;padding:0 var(--space-2);border-radius:var(--radius-sm);border:1.5px solid var(--border);background:none;color:var(--text-dim);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.cf-pagination .pg-btn:hover:not(:disabled){border-color:var(--cf-blue);color:var(--cf-blue)}.cf-pagination .pg-btn.active{background:var(--cf-blue);border-color:var(--cf-blue);color:#fff}:root.light .cf-pagination .pg-btn:hover:not(:disabled){border-color:var(--cf-primary);color:var(--cf-primary)}:root.light .cf-pagination .pg-btn.active{background:var(--cf-primary);border-color:var(--cf-primary)}.cf-pagination .pg-btn:disabled{opacity:.3;cursor:not-allowed}.cf-pagination .pg-ellipsis{font-family:var(--mono);font-size:11px;color:var(--text-dim);padding:0 var(--space-1)}@media (max-width: 900px){.layout{grid-template-columns:52px 1fr}.nav-item span:not(.nav-icon){display:none}.nav-section{display:none}.nav-item{justify-content:center;padding:10px}.nav-badge{display:none}}@media (max-width: 600px){.layout{grid-template-columns:1fr;grid-template-rows:56px 1fr 56px}nav{grid-row:3;grid-column:1;flex-direction:row;padding:0;overflow-x:auto;border-right:none;border-top:1px solid var(--border)}.nav-item{flex-direction:column;gap:2px;padding:8px 12px;font-size:9px}.nav-item span:not(.nav-icon){display:block;font-size:9px}.nav-section{display:none}main{padding:var(--space-4)}.stats-row{grid-template-columns:repeat(2,1fr)}}:focus-visible{outline:2px solid var(--cf-blue);outline-offset:2px}:root.light :focus-visible{outline-color:var(--cf-primary)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.layout{display:grid;grid-template-columns:220px 1fr;grid-template-rows:56px 1fr;height:100vh;overflow:hidden;position:relative;z-index:1}nav{background:var(--surface);border-right:2px solid var(--border);padding:16px 0;display:flex;flex-direction:column;gap:2px;overflow-y:auto}:root:not(.light) nav{background:var(--bg);border-right-color:var(--border)}.nav-section{font-family:var(--mono);font-size:9px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--cf-primary);padding:20px 20px 5px;opacity:.9}:root:not(.light) .nav-section{color:#4e6a8ee6}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:500;color:var(--text);cursor:pointer;transition:all .15s;border-left:3px solid transparent}:root:not(.light) .nav-item{color:var(--text-dim)}.nav-item:hover{background:var(--surface2);color:var(--text-bright);border-left-color:var(--border)}:root:not(.light) .nav-item:hover{background:var(--surface2);color:var(--text);border-left-color:var(--text-dim)}.nav-item.active{background:#2e5cbf1a;color:var(--cf-primary);border-left-color:var(--cf-primary);font-weight:700}:root:not(.light) .nav-item.active{background:#2e5cbf26;color:var(--cf-blue);border-left-color:var(--cf-primary)}.nav-icon{font-size:14px;width:18px;text-align:center;flex-shrink:0}.nav-badge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:2px 7px;border-radius:10px}:root:not(.light) .nav-badge{background:#2e5cbf1f;border-color:#2e5cbf;color:var(--cf-blue)}.nav-item.active .nav-badge{background:var(--cf-primary);border-color:var(--cf-primary);color:#fff}main{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.view{display:none;flex-direction:column;gap:20px}.view.active{display:flex}.topbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.page-title{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--text-bright);letter-spacing:.05em}.page-subtitle{font-size:12px;color:var(--text-dim);margin-top:2px}.topbar-actions{margin-left:auto;display:flex;gap:8px}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:16px 20px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card.s-online:before{background:var(--cf-green)}.stat-card.s-total:before{background:var(--cf-teal)}.stat-card.s-warn:before{background:var(--cf-yellow)}.stat-card.s-msg:before{background:var(--cf-teal)}.stat-label{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text);margin-bottom:8px}.stat-value{font-family:var(--mono);font-size:36px;font-weight:600;line-height:1}.stat-card.s-online .stat-value{color:var(--cf-green)}.stat-card.s-warn .stat-value{color:var(--cf-yellow)}.stat-card.s-msg .stat-value{color:var(--cf-teal)}:root.light .stat-card.s-total .stat-value{color:var(--text-bright)}:root:not(.light) .stat-card.s-total .stat-value{color:var(--text-bright)}.stat-sub{font-size:11px;color:var(--text);margin-top:6px}.card{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}.card-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface2);gap:10px}.table-title{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text)}.table-time{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--text-dim)}table{width:100%;border-collapse:collapse}th{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text);padding:10px 16px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface2)}td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:12px;color:var(--text)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.gw-name{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--text-bright)}.gw-mac{font-family:var(--mono);font-size:10px;color:var(--text-dim);margin-top:2px}.topic-cell{font-family:var(--mono);font-size:10px;color:var(--text-dim);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.beacon-num{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--cf-primary)}.last-seen{font-family:var(--mono);font-size:11px;color:var(--text-dim)}.action-btn{font-family:var(--mono);font-size:11px;font-weight:600;padding:6px 14px;border-radius:5px;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.05em;min-height:32px;border:1.5px solid var(--cf-primary);background:var(--cf-primary);color:#fff}.action-btn:hover{background:color-mix(in srgb,var(--cf-primary) 80%,black);border-color:var(--cf-primary);box-shadow:0 2px 8px #1a3a8f4d}.action-btn.secondary{background:transparent;color:var(--cf-primary)}.action-btn.secondary:hover{background:var(--cf-primary);color:#fff}.action-btn.danger{background:transparent;border-color:var(--cf-red);color:var(--cf-red)}.action-btn.danger:hover{background:var(--cf-red);color:#fff}.bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}.panel-header{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--surface2);gap:10px;flex-shrink:0}.panel-title{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text);flex:1}.panel-body{padding:10px 14px;flex:1;overflow:hidden}.feed{height:200px;overflow-y:auto;font-family:var(--mono);font-size:10px;display:flex;flex-direction:column;gap:0}.mqtt-msg{display:grid;grid-template-columns:55px 70px 1fr;gap:10px;padding:4px 0;border-bottom:1px solid rgba(30,45,66,.4);animation:fadeIn .2s ease}:root.light .mqtt-msg{border-bottom-color:#c0cedf80}.m-time{color:var(--text-dim)}.m-gw{color:var(--cf-primary);font-weight:600}.m-data{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-line{display:flex;gap:10px;padding:4px 0;border-bottom:1px solid rgba(30,45,66,.3);font-family:var(--mono);font-size:10px;animation:fadeIn .2s ease}:root.light .log-line{border-bottom-color:#c0cedf66}.l-time{color:var(--text-dim);min-width:55px}.l-src{font-weight:600;min-width:35px}.l-src.mqtt{color:var(--cf-blue)}.l-src.sys{color:var(--cf-teal)}.l-src.prov{color:var(--cf-yellow)}.l-src.err{color:var(--cf-red)}.l-level{min-width:35px}.l-level.info{color:var(--text-dim)}.l-level.warn{color:var(--cf-yellow)}.l-level.error{color:var(--cf-red)}.l-msg{color:var(--text);flex:1}.prov-table{width:100%}.prov-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border)}.prov-check{width:18px;height:18px;cursor:pointer;accent-color:var(--cf-primary)}.prov-name{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--text-bright)}.prov-mac{font-family:var(--mono);font-size:10px;color:var(--text-dim)}.prov-steps{font-family:var(--mono);font-size:10px;color:var(--text-dim);max-height:80px;overflow-y:auto}.ps-icon.done{color:var(--cf-green)}.ps-icon.err{color:var(--cf-red)}.ps-icon.wait{color:var(--text-dim)}.ps-icon.sent{color:var(--cf-yellow)}.ps-label{color:var(--text)}.conn-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:20px 24px;max-width:520px;display:flex;flex-direction:column;gap:14px}.conn-title{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text-bright);letter-spacing:.06em}.eye-btn{background:none;border:none;cursor:pointer;color:var(--text-dim);padding:0 4px}.eye-btn:hover{color:var(--text)}#gwDetailPanel{position:fixed;top:0;right:0;width:500px;height:100vh;background:var(--surface);border-left:2px solid var(--cf-primary);box-shadow:-8px 0 32px #00000040;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:1000;display:flex;flex-direction:column;font-family:var(--mono);font-size:12px;color:var(--text-bright)}:root:not(.light) #gwDetailPanel{background:var(--surface);color:var(--text);border-left-color:var(--cf-primary)}#gwDetailPanel.open{transform:translate(0)}#gwDetailBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:999;display:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}#gwDetailBackdrop.open{display:block}.detail-header{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}:root:not(.light) .detail-header{border-bottom-color:var(--border)}.detail-header-info{flex:1}#detailTitle{font-size:14px;font-weight:700;color:var(--cf-blue);letter-spacing:.04em}.detail-meta{color:var(--text-dim);font-size:10px;margin-top:4px;letter-spacing:.06em;font-weight:500}.detail-close{background:none;border:1px solid var(--border);color:var(--text-dim);width:28px;height:28px;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.detail-close:hover{color:var(--cf-blue);border-color:var(--cf-blue)}.detail-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;padding:0 12px}:root:not(.light) .detail-tabs{border-bottom-color:var(--border)}.detail-tab{padding:9px 14px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--mono);transition:all .15s}.detail-tab:hover{color:var(--text-bright)}.detail-tab.active{color:var(--cf-blue);border-bottom-color:var(--cf-blue);font-weight:700}:root:not(.light) .detail-tab{color:var(--text-dim)}:root:not(.light) .detail-tab:hover{color:var(--text)}:root:not(.light) .detail-tab.active{color:var(--cf-blue);border-bottom-color:var(--cf-primary)}.detail-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:14px}.detail-pane{display:none;flex-direction:column;gap:14px}.detail-pane.active{display:flex}.detail-section{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:12px 14px}:root:not(.light) .detail-section{background:var(--surface2);border-color:var(--border)}.detail-section-title{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--cf-blue);margin-bottom:10px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);gap:10px}:root:not(.light) .detail-row{border-bottom-color:var(--border)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-dim);font-size:11px;font-weight:500;letter-spacing:.05em;flex-shrink:0}.detail-value{color:var(--text-bright);font-size:12px;font-weight:500;text-align:right;word-break:break-all}:root:not(.light) .detail-value{color:var(--text)}.detail-input{background:var(--surface);border:1.5px solid var(--border);color:var(--text-bright);font-family:var(--mono);font-size:11px;padding:5px 8px;border-radius:4px;width:100px;text-align:right}:root:not(.light) .detail-input{background:var(--surface2);border-color:var(--border);color:var(--text)}.detail-input:focus{outline:none;border-color:var(--cf-primary)}.detail-btn{font-family:var(--mono);font-size:10px;font-weight:600;padding:5px 12px;border-radius:4px;cursor:pointer;letter-spacing:.06em;text-transform:uppercase;transition:all .15s;flex-shrink:0;border:1.5px solid var(--cf-primary);background:var(--cf-primary);color:#fff}.detail-btn:hover{background:color-mix(in srgb,var(--cf-primary) 80%,black);border-color:var(--cf-primary)}.detail-btn.danger{background:var(--cf-yellow);border-color:var(--cf-yellow);color:#fff}.detail-btn.danger:hover{background:color-mix(in srgb,var(--cf-yellow) 70%,black);border-color:color-mix(in srgb,var(--cf-yellow) 70%,black)}.detail-log{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:8px 10px;font-size:10px;color:var(--text-dim);max-height:80px;overflow-y:auto;white-space:pre-wrap;line-height:1.6;display:none}:root:not(.light) .detail-log{background:var(--bg);border-color:var(--border);color:var(--text-dim)}.full-row{flex-direction:column;align-items:flex-start;gap:6px}.full-row .detail-input{width:100%;box-sizing:border-box}.rssi-bar-wrap{flex:1;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.rssi-bar{height:100%;border-radius:3px;transition:width .4s}
