@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";.sidebar[data-v-b55e5d5a]{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-logo[data-v-b55e5d5a]{height:var(--header-height);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:0 16px;display:flex}.logo-mark[data-v-b55e5d5a]{background:var(--accent);border-radius:var(--radius-sm);color:#fff;letter-spacing:.5px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:800;display:flex}.logo-text[data-v-b55e5d5a]{color:var(--text-primary);font-size:14px;font-weight:600}.sidebar-nav[data-v-b55e5d5a]{flex-direction:column;flex:1;gap:2px;padding:10px 8px;display:flex;overflow-y:auto}.nav-item[data-v-b55e5d5a]{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-family:var(--font);text-align:left;transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 10px;font-size:13.5px;font-weight:500;display:flex}.nav-item[data-v-b55e5d5a]:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-item.active[data-v-b55e5d5a]{background:var(--accent-dim);color:var(--accent)}.nav-icon[data-v-b55e5d5a]{text-align:center;flex-shrink:0;width:20px;font-size:16px;line-height:1}.nav-label[data-v-b55e5d5a]{flex:1}.sidebar-footer[data-v-b55e5d5a]{border-top:1px solid var(--border);padding:12px 16px}.sidebar-version[data-v-b55e5d5a]{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.hq-header[data-v-8ebbc284]{height:var(--header-height);border-bottom:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:0 20px;display:flex}.header-left[data-v-8ebbc284]{align-items:center;gap:16px;display:flex}.header-right[data-v-8ebbc284]{align-items:center;gap:12px;display:flex}.ws-indicator[data-v-8ebbc284]{align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.ws-indicator.connected[data-v-8ebbc284]{color:var(--green)}.ws-indicator.disconnected[data-v-8ebbc284]{color:var(--text-muted)}.ws-dot[data-v-8ebbc284]{background:currentColor;border-radius:50%;width:7px;height:7px}.ws-indicator.connected .ws-dot[data-v-8ebbc284]{animation:2s infinite pulse-8ebbc284}@keyframes pulse-8ebbc284{0%,to{opacity:1}50%{opacity:.4}}.ws-label[data-v-8ebbc284]{text-transform:uppercase;letter-spacing:.5px;font-size:11px}.admin-info[data-v-8ebbc284]{align-items:center;gap:10px;display:flex}.admin-avatar[data-v-8ebbc284]{background:var(--bg-elevated);border:1px solid var(--border);width:30px;height:30px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex;overflow:hidden}.admin-avatar img[data-v-8ebbc284]{object-fit:cover;width:100%;height:100%}.admin-details[data-v-8ebbc284]{flex-direction:column;gap:1px;display:flex}.admin-name[data-v-8ebbc284]{color:var(--text-primary);font-size:13px;font-weight:500;line-height:1}.admin-role[data-v-8ebbc284]{color:var(--accent);font-size:11px;line-height:1}.debug-build-badge{color:var(--text-muted);font-size:10px;font-family:var(--font-mono);z-index:9999;pointer-events:none;border:1px solid var(--border);background:#0f172acc;border-radius:4px;padding:3px 8px;position:fixed;bottom:8px;right:8px}:root{--bg-base:#0a0e1a;--bg-surface:#111827;--bg-elevated:#1e293b;--bg-hover:#263347;--bg-active:#2d3f58;--border:#1f2d42;--border-light:#2a3a52;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#4b6280;--accent:#3b82f6;--accent-hover:#2563eb;--accent-dim:#3b82f626;--green:#22c55e;--green-dim:#22c55e26;--red:#ef4444;--red-dim:#ef444426;--yellow:#f59e0b;--yellow-dim:#f59e0b26;--purple:#a855f7;--purple-dim:#a855f726;--cyan:#06b6d4;--cyan-dim:#06b6d426;--sidebar-width:240px;--header-height:56px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 10px 30px #0009;--font:"DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%;overflow:hidden}body{font-family:var(--font);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.3}h1{font-size:24px}h2{font-size:20px}h3{font-size:16px}p{color:var(--text-secondary)}.app-layout{height:100%;display:flex;overflow:hidden}.app-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-content{flex:1;padding:24px;overflow-y:auto}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:15px;font-weight:600}.btn{border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;transition:background var(--transition), opacity var(--transition);white-space:nowrap;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-ghost{color:var(--text-secondary);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border:none;padding:6px}.btn-icon:hover{background:var(--bg-elevated);color:var(--text-primary)}.input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:8px 12px;font-size:14px}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input::placeholder{color:var(--text-muted)}.input-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.input-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.input-error{color:var(--red);font-size:12px}.badge{text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-radius:100px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-blue{background:var(--accent-dim);color:var(--accent)}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-yellow{background:var(--yellow-dim);color:var(--yellow)}.badge-purple{background:var(--purple-dim);color:var(--purple)}.badge-cyan{background:var(--cyan-dim);color:var(--cyan)}.badge-gray{background:var(--bg-elevated);color:var(--text-secondary)}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:10px 14px;font-size:11px;font-weight:600}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{color:var(--text-primary)}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:11px 14px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{cursor:pointer;transition:background var(--transition)}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:hover td{color:var(--text-primary)}.avatar{background:var(--bg-elevated);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-lg{width:48px;height:48px;font-size:18px}.toggle{flex-shrink:0;width:36px;height:20px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:var(--bg-elevated);border:1px solid var(--border);transition:background var(--transition), border-color var(--transition);border-radius:20px;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-muted);width:14px;height:14px;transition:transform var(--transition), background var(--transition);border-radius:50%;position:absolute;bottom:2px;left:2px}.toggle input:checked+.toggle-slider{background:var(--accent-dim);border-color:var(--accent)}.toggle input:checked+.toggle-slider:before{background:var(--accent);transform:translate(16px)}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-dot.up{background:var(--green);box-shadow:0 0 6px #22c55e80}.status-dot.down{background:var(--red);box-shadow:0 0 6px #ef444480}.tabs{background:var(--bg-elevated);border-radius:var(--radius-sm);gap:2px;width:fit-content;padding:3px;display:flex}.tab-btn{border-radius:calc(var(--radius-sm) - 2px);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);transition:background var(--transition), color var(--transition);white-space:nowrap;background:0 0;border:none;padding:6px 14px}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{background:var(--bg-surface);color:var(--text-primary)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);padding:24px}.modal-title{margin-bottom:8px;font-size:17px;font-weight:600}.modal-body{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.6}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-row{color:var(--text-muted);justify-content:center;align-items:center;gap:12px;padding:40px;font-size:13px;display:flex}.empty-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:60px 20px;font-size:14px;display:flex}.empty-state .empty-icon{opacity:.5;margin-bottom:4px;font-size:36px}.error-message{background:var(--red-dim);border-radius:var(--radius-sm);color:var(--red);border:1px solid #ef44444d;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.pagination{border-top:1px solid var(--border);align-items:center;gap:12px;padding:12px 16px;display:flex}.pagination-info{color:var(--text-muted);flex:1;font-size:12px}.pagination-btns{gap:6px;display:flex}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.section-title{font-size:18px;font-weight:600}.search-bar{flex:1;max-width:320px;position:relative}.search-bar .search-icon{color:var(--text-muted);pointer-events:none;font-size:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-bar .input{padding-left:32px}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.two-col{grid-template-columns:1fr 1fr;gap:16px;display:grid}.divider{background:var(--border);height:1px;margin:16px 0}.mono{font-family:var(--font-mono);font-size:12px}.user-cell{align-items:center;gap:10px;display:flex}.user-cell-info{flex-direction:column;gap:1px;min-width:0;display:flex}.user-cell-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.user-cell-sub{color:var(--text-muted);font-size:11px}.page-enter-active,.page-leave-active{transition:opacity .12s}.page-enter-from,.page-leave-to{opacity:0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.text-sm{font-size:12px}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-mono{font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}
