.loading-spinner{display:inline-flex;align-items:center;justify-content:center}.loading-spinner--sm .loading-spinner__svg{width:16px;height:16px}.loading-spinner--md .loading-spinner__svg{width:24px;height:24px}.loading-spinner--lg .loading-spinner__svg{width:40px;height:40px}.loading-spinner__track{stroke:var(--bg-tertiary)}.loading-spinner__arc{stroke:var(--accent);stroke-dasharray:50 14;animation:spinner-rotate .8s linear infinite;transform-origin:center}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg);background-color:var(--bg-primary)}.login-card{width:100%;max-width:380px;background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-xl)}.login-header{text-align:center;margin-bottom:var(--space-lg)}.login-logo{width:48px;height:48px;color:var(--accent);margin-bottom:var(--space-md)}.login-title{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.login-subtitle{font-size:var(--font-size-base);color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-error{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:#f851491a;border:1px solid rgba(248,81,73,.3);border-radius:var(--radius-md);color:var(--severity-critical);font-size:var(--font-size-sm)}.login-submit{width:100%;padding:10px var(--space-md);font-size:var(--font-size-base);margin-top:var(--space-sm)}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;top:0;left:0;z-index:20;display:flex;flex-direction:column;background-color:var(--bg-secondary);border-right:1px solid var(--border-primary);padding-top:var(--topbar-height);transition:width var(--transition-normal);overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed)}.sidebar__nav{flex:1;display:flex;flex-direction:column;padding:var(--space-sm);overflow-y:auto}.sidebar__list{list-style:none;display:flex;flex-direction:column;gap:2px}.sidebar__link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:var(--font-size-base);font-weight:500;transition:background-color var(--transition-fast),color var(--transition-fast);white-space:nowrap;min-height:36px}.sidebar__link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.sidebar__link--active{background-color:#58a6ff1f;color:var(--accent)}.sidebar__link--active:hover{background-color:#58a6ff2e}.sidebar__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px}.sidebar__label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background-color:var(--severity-critical);color:#fff;font-size:11px;font-weight:600}.sidebar__separator{height:1px;background-color:var(--border-primary);margin:var(--space-sm) var(--space-sm);flex-shrink:0}.sidebar__toggle{display:flex;align-items:center;justify-content:center;padding:var(--space-sm);margin:var(--space-sm);border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--text-tertiary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar__toggle:hover{background-color:var(--bg-hover);color:var(--text-primary)}.sidebar--collapsed .sidebar__link{justify-content:center;padding:var(--space-sm)}.sidebar--collapsed .sidebar__nav{padding:var(--space-sm) var(--space-xs)}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);z-index:30;display:flex;align-items:center;gap:var(--space-md);padding:0 var(--space-md);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.topbar__left{display:flex;align-items:center;gap:var(--space-sm);width:var(--sidebar-width);padding-left:var(--space-sm);flex-shrink:0}.topbar__logo-icon{width:24px;height:24px;color:var(--accent);flex-shrink:0}.topbar__title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);white-space:nowrap}.topbar__center{flex:1;display:flex;justify-content:center;max-width:480px}.topbar__search{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:6px var(--space-sm);background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-tertiary);transition:border-color var(--transition-fast)}.topbar__search:focus-within{border-color:var(--accent)}.topbar__search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:var(--font-size-sm)}.topbar__search-input::placeholder{color:var(--text-tertiary)}.topbar__right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.topbar__icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.topbar__icon-btn:hover{background-color:var(--bg-hover);color:var(--text-primary)}.topbar__user-menu{position:relative}.topbar__user-btn{display:flex;align-items:center;gap:var(--space-sm);padding:4px var(--space-sm);border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color var(--transition-fast)}.topbar__user-btn:hover{background-color:var(--bg-hover)}.topbar__avatar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:var(--accent);color:#fff;font-size:var(--font-size-sm);font-weight:600;flex-shrink:0}.topbar__user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar__dropdown{position:absolute;top:calc(100% + var(--space-xs));right:0;width:220px;background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-sm);box-shadow:var(--shadow-lg);z-index:50}.topbar__dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) var(--space-sm)}.topbar__dropdown-name{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary)}.topbar__dropdown-role{font-size:11px;padding:1px 6px;background-color:var(--bg-hover);color:var(--text-secondary)}.topbar__dropdown-email{font-size:var(--font-size-sm);color:var(--text-tertiary);padding:0 var(--space-sm) var(--space-sm)}.topbar__dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm);border:none;border-radius:var(--radius-sm);background:none;color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.topbar__dropdown-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.topbar__dropdown-item--danger:hover{background-color:#f851491f;color:var(--severity-critical)}.app-layout{min-height:100vh}.app-layout__content{margin-left:var(--sidebar-width);margin-top:var(--topbar-height);padding:var(--space-lg);min-height:calc(100vh - var(--topbar-height));transition:margin-left var(--transition-normal)}.sidebar--collapsed~.app-layout__content,:has(.sidebar--collapsed) .app-layout__content{margin-left:var(--sidebar-collapsed)}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-hover: #30363d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-tertiary: #6e7681;--status-healthy: #3fb950;--status-warning: #d29922;--status-critical: #f85149;--status-offline: #6e7681;--severity-critical: #f85149;--severity-high: #db6d28;--severity-medium: #d29922;--severity-low: #8b949e;--accent: #58a6ff;--accent-hover: #79c0ff;--sidebar-width: 240px;--sidebar-collapsed: 64px;--topbar-height: 48px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-sm: 12px;--font-size-base: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--border-primary: #30363d;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit}code,pre{font-family:var(--font-mono)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:500;line-height:1.4;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-hover)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.btn-danger{background-color:var(--severity-critical);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.input{width:100%;padding:var(--space-sm) var(--space-md);background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.input:focus{border-color:var(--accent);outline:none}.input::placeholder{color:var(--text-tertiary)}.input-error{border-color:var(--severity-critical)}.card{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-lg)}.card-hover:hover{border-color:var(--accent);cursor:pointer}.label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.error-text{font-size:var(--font-size-sm);color:var(--severity-critical)}.page-title{font-size:var(--font-size-2xl);font-weight:600;margin-bottom:var(--space-lg)}.section-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-md)}.badge{display:inline-flex;align-items:center;padding:2px var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;line-height:1.4}.divider{height:1px;background-color:var(--border-primary);margin:var(--space-md) 0}.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}
