.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)}.agent-fab{position:fixed;bottom:24px;right:24px;z-index:1000;width:48px;height:48px;border-radius:50%;border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:background var(--transition-fast),transform var(--transition-fast)}.agent-fab:hover{background:var(--bg-tertiary);transform:scale(1.08)}.agent-fab__icon{font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:700;letter-spacing:-.5px}.agent-panel{position:fixed;bottom:24px;right:24px;z-index:1000;width:400px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.agent-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);flex-shrink:0}.agent-panel__title{display:flex;align-items:center;gap:var(--space-sm)}.agent-panel__title-text{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary)}.agent-panel__context-badge{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--accent);color:var(--bg-primary);font-weight:600;text-transform:capitalize}.agent-panel__header-actions{display:flex;gap:var(--space-xs)}.agent-panel__btn-icon{width:28px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:700;transition:background var(--transition-fast),color var(--transition-fast)}.agent-panel__btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.agent-panel__actions{display:flex;flex-wrap:wrap;gap:6px;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-primary);flex-shrink:0}.agent-panel__action-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--border-primary);border-radius:14px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-size:11px;font-family:var(--font-sans);transition:border-color var(--transition-fast),color var(--transition-fast),background var(--transition-fast);white-space:nowrap}.agent-panel__action-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--bg-tertiary)}.agent-panel__action-btn:disabled{opacity:.4;cursor:not-allowed}.agent-panel__action-icon{font-family:var(--font-mono);font-size:10px;font-weight:700;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-tertiary);color:var(--accent)}.agent-panel__action-label{font-weight:500}.agent-panel__messages{flex:1;overflow-y:auto;padding:var(--space-sm) var(--space-md);min-height:200px;max-height:400px;display:flex;flex-direction:column;gap:var(--space-sm)}.agent-panel__empty{color:var(--text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:var(--space-xl) 0}.agent-panel__msg{display:flex;flex-direction:column;gap:2px}.agent-panel__msg-label{font-size:11px;font-weight:600;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--space-xs)}.agent-panel__msg-label--error{color:var(--severity-critical)}.agent-panel__msg-body{font-family:var(--font-mono);font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word;margin:0;padding:var(--space-sm);border-radius:var(--radius-sm);max-height:300px;overflow-y:auto}.agent-panel__msg--user .agent-panel__msg-body{background:var(--bg-tertiary);color:var(--text-primary)}.agent-panel__msg--assistant .agent-panel__msg-body{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-primary)}.agent-panel__msg--system .agent-panel__msg-body{background:#f851491a;color:var(--severity-critical);border:1px solid rgba(248,81,73,.3)}.agent-panel__tool-tag{font-size:10px;font-weight:500;padding:1px 6px;border-radius:8px;background:var(--bg-tertiary);color:var(--text-secondary);font-family:var(--font-mono)}.agent-panel__loading-dots{display:flex;gap:4px;padding:var(--space-sm)}.agent-panel__loading-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);animation:agent-dot-pulse 1.2s ease-in-out infinite}.agent-panel__loading-dots span:nth-child(2){animation-delay:.2s}.agent-panel__loading-dots span:nth-child(3){animation-delay:.4s}@keyframes agent-dot-pulse{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.agent-panel__input-area{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border-primary);background:var(--bg-tertiary);flex-shrink:0}.agent-panel__input{flex:1;padding:6px 12px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--font-size-sm);outline:none;transition:border-color var(--transition-fast)}.agent-panel__input::placeholder{color:var(--text-tertiary)}.agent-panel__input:focus{border-color:var(--accent)}.agent-panel__input:disabled{opacity:.5}.agent-panel__send-btn{padding:6px 14px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:var(--bg-primary);font-family:var(--font-sans);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.agent-panel__send-btn:hover:not(:disabled){background:var(--accent-hover)}.agent-panel__send-btn:disabled{opacity:.4;cursor:not-allowed}.agent-panel__messages::-webkit-scrollbar,.agent-panel__msg-body::-webkit-scrollbar{width:6px}.agent-panel__messages::-webkit-scrollbar-track,.agent-panel__msg-body::-webkit-scrollbar-track{background:transparent}.agent-panel__messages::-webkit-scrollbar-thumb,.agent-panel__msg-body::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:3px}@media(max-width:480px){.agent-panel{width:calc(100vw - 16px);right:8px;bottom:8px;max-height:calc(100vh - 60px)}.agent-fab{right:12px;bottom:12px}}.agent-panel__msg-body{white-space:normal;word-wrap:break-word;line-height:1.5}.agent-panel__msg-body p{margin:0 0 .5em}.agent-panel__msg-body ol,.agent-panel__msg-body ul{margin:.3em 0;padding-left:1.5em}.agent-panel__msg-body li{margin:.2em 0}.agent-panel__msg-body strong{color:var(--text-primary)}.agent-code{background:var(--bg-tertiary);padding:.5em;border-radius:4px;overflow-x:auto;font-size:.85em}.agent-inline-code{background:var(--bg-tertiary);padding:1px 4px;border-radius:3px;font-size:.9em;color:var(--accent)}.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}
