:root,:root.dark{--color-bg-primary: #0a0f1a;--color-bg-secondary: #111827;--color-bg-tertiary: #1f2937;--color-bg-elevated: #374151;--color-bg-hover: #1f2937;--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-text-muted: #6b7280;--color-border: #374151;--color-border-light: #4b5563;--color-border-focus: #3b82f6;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #60a5fa;--color-primary-dark: #1d4ed8;--color-success: #10b981;--color-success-light: #34d399;--color-success-dark: #059669;--color-warning: #f59e0b;--color-warning-light: #fbbf24;--color-warning-dark: #d97706;--color-danger: #ef4444;--color-danger-light: #f87171;--color-danger-dark: #dc2626;--color-info: #8b5cf6;--color-info-light: #a78bfa;--color-info-dark: #7c3aed;--gradient-primary: linear-gradient(135deg, #3b82f6, #8b5cf6);--gradient-success: linear-gradient(135deg, #10b981, #34d399);--gradient-warning: linear-gradient(135deg, #f59e0b, #fbbf24);--gradient-danger: linear-gradient(135deg, #ef4444, #f87171);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3), 0 1px 3px 0 rgba(0, 0, 0, .15);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .15);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .3), 0 10px 10px -5px rgba(0, 0, 0, .15);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .4);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .15);--shadow-glow: 0 0 15px rgba(59, 130, 246, .3);--sidebar-bg: var(--color-bg-secondary);--sidebar-active: var(--color-bg-tertiary);--sidebar-width: 280px;--sidebar-width-collapsed: 70px;--table-header-bg: var(--color-bg-tertiary);--table-row-hover: var(--color-bg-hover);--table-border: var(--color-border);--radius-sm: .375rem;--radius: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}:root,:root.dark,:root.light{--bg-primary: var(--color-bg-primary);--bg-secondary: var(--color-bg-secondary);--bg-tertiary: var(--color-bg-tertiary);--bg-card: var(--color-bg-card);--bg-elevated: var(--color-bg-elevated);--bg-hover: var(--color-bg-hover);--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-muted: var(--color-text-muted);--border-color: var(--color-border);--accent: var(--color-primary);--accent-bg: var(--color-primary-light);--accent-hover: var(--color-primary-hover);--success: var(--color-success);--success-bg: var(--color-success-light);--warning: var(--color-warning);--warning-bg: var(--color-warning-light);--danger: var(--color-danger);--danger-bg: var(--color-danger-light);--info: var(--color-info);--info-bg: var(--color-info-light)}:root.light{--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-bg-elevated: #e5e7eb;--color-bg-hover: #f3f4f6;--color-text-primary: #111827;--color-text-secondary: #4b5563;--color-text-tertiary: #6b7280;--color-text-muted: #9ca3af;--color-border: #e5e7eb;--color-border-light: #d1d5db;--color-border-focus: #3b82f6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05), 0 1px 3px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .05);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--shadow-glow: 0 0 15px rgba(59, 130, 246, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{width:100%;max-width:100vw;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;font-size:16px;overflow-x:hidden;min-height:100vh}#root{width:100%;max-width:100%;min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full);border:2px solid var(--color-bg-secondary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:#3b82f633;color:var(--color-text-primary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.login-box{background:var(--bg-card);border-radius:16px;padding:40px;width:100%;max-width:420px;border:1px solid var(--color-border);box-shadow:var(--shadow-lg);transition:all .3s ease}.login-header{text-align:center;margin-bottom:32px}.login-icon{margin-bottom:16px}.login-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-header p{color:var(--text-muted);font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{background:#ef44441a;color:var(--color-danger);padding:12px;border-radius:8px;font-size:14px;border:1px solid rgba(239,68,68,.2);animation:fadeIn .3s ease-out}.form-label{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--text-secondary)}.login-btn{width:100%;justify-content:center;padding:12px;font-size:16px;margin-top:8px}.login-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:12px}.login-footer .theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%}.login-footer p{color:var(--text-muted);font-size:12px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.login-box{padding:24px;max-width:100%;box-shadow:var(--shadow-md)}.login-header h1{font-size:1.5rem}.login-icon svg{width:40px;height:40px}}:root,:root.dark{--color-bg-primary: #0a0f1a;--color-bg-secondary: #111827;--color-bg-tertiary: #1f2937;--color-bg-card: #1e293b;--color-bg-hover: #1f2937;--color-bg-input: #1e293b;--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-text-muted: #6b7280;--color-border: #374151;--color-border-light: #4b5563;--color-border-focus: #3b82f6;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #60a5fa;--color-success: #10b981;--color-success-light: #34d399;--color-success-dark: #059669;--color-warning: #f59e0b;--color-warning-light: #fbbf24;--color-warning-dark: #d97706;--color-danger: #ef4444;--color-danger-light: #f87171;--color-danger-dark: #dc2626;--color-info: #8b5cf6;--color-info-light: #a78bfa;--color-info-dark: #7c3aed;--color-sidebar-bg: #111827;--color-sidebar-active: #1f2937;--color-table-header-bg: #1f2937;--color-table-row-hover: #1f2937;--color-table-border: #374151;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .3);--radius-sm: .375rem;--radius: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 280px;--sidebar-width-collapsed: 70px;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}:root.light{--color-bg-primary: #f9fafb;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f3f4f6;--color-bg-card: #ffffff;--color-bg-hover: #f3f4f6;--color-bg-input: #ffffff;--color-text-primary: #111827;--color-text-secondary: #4b5563;--color-text-tertiary: #6b7280;--color-text-muted: #9ca3af;--color-border: #e5e7eb;--color-border-light: #d1d5db;--color-border-focus: #3b82f6;--color-sidebar-bg: #ffffff;--color-sidebar-active: #f3f4f6;--color-table-header-bg: #f9fafb;--color-table-row-hover: #f3f4f6;--color-table-border: #e5e7eb;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1)}.layout{display:flex;min-height:100vh;background:var(--color-bg-primary);transition:background-color var(--transition-base);overflow:hidden;width:100%;max-width:100vw}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:all var(--transition-slow) cubic-bezier(.4,0,.2,1);z-index:var(--z-modal);flex-shrink:0;position:relative}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}.sidebar.closed{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;min-height:64px}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--color-primary);white-space:nowrap;overflow:hidden}.logo-icon{font-size:1.5rem;color:var(--color-primary);flex-shrink:0}.logo-text{transition:opacity var(--transition-fast)}.sidebar.collapsed .logo-text{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .logo{justify-content:center}.sidebar-toggle{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.sidebar-section{padding:.75rem 1rem}.settings-row{display:flex;gap:.5rem}.settings-row .theme-toggle,.settings-row .lang-dropdown{flex:1}.theme-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem}.theme-toggle:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.lang-dropdown{position:relative}.lang-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;width:100%}.lang-toggle:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.lang-menu{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);overflow:hidden}.lang-option{display:block;width:100%;padding:.5rem .75rem;background:none;border:none;color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast);font-size:.875rem}.lang-option:hover{background:var(--color-bg-hover)}.lang-option.active{background:var(--color-primary);color:#fff}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap;position:relative}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background:var(--color-sidebar-active);color:var(--color-text-primary);font-weight:500}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:1.25rem;background:var(--color-primary);border-radius:0 2px 2px 0}.sidebar.collapsed .nav-item{justify-content:center;padding:.75rem}.sidebar.collapsed .nav-item span{display:none}.sidebar-footer{padding:1rem .75rem;border-top:1px solid var(--color-border)}.sidebar-settings{padding:.75rem;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.5rem}.sidebar-settings .settings-row{display:flex;gap:.5rem}.sidebar-settings .settings-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);font-size:.8125rem}.sidebar-settings .settings-btn:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.sidebar-settings .settings-label{display:inline;font-size:.75rem;font-weight:500}.sidebar.collapsed .sidebar-settings .settings-label{display:none}.sidebar-settings .lang-dropdown{flex:1;position:relative}.sidebar-settings .lang-btn{width:100%}.sidebar-settings .lang-menu{position:absolute;bottom:100%;left:0;right:0;margin-bottom:.25rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);overflow:hidden}.sidebar-settings .logout-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);background:none;border:none;color:var(--color-danger);cursor:pointer;transition:all var(--transition-fast);font-size:.875rem}.sidebar-settings .logout-btn:hover{background:#ef44441a}.sidebar.collapsed .sidebar-settings{padding:.5rem}.sidebar.collapsed .settings-row{flex-direction:column}.sidebar.collapsed .settings-btn{padding:.625rem;justify-content:center}.sidebar.collapsed .settings-btn .settings-label,.sidebar.collapsed .logout-btn span{display:none}.sidebar.collapsed .logout-btn{justify-content:center;padding:.625rem}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--color-bg-primary);position:relative;min-width:0}.content-wrapper{padding:1.5rem;max-width:1400px;margin:0 auto;box-sizing:border-box;width:100%;animation:fadeIn var(--transition-slow) ease-out}@media (max-width: 768px){.content-wrapper{padding:.5rem;max-width:100%}}.mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-modal) - 1);display:none;pointer-events:none;opacity:0;transition:opacity var(--transition-base)}.mobile-overlay.visible{display:block;pointer-events:auto;opacity:1}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--color-sidebar-bg);border-bottom:1px solid var(--color-border);padding:0 1rem;z-index:var(--z-fixed);flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box}.mobile-logo{font-weight:700;color:var(--color-primary);font-size:1rem}.desktop-only{display:block}@media (max-width: 768px){.mobile-overlay.visible{display:block;pointer-events:auto;opacity:1}.mobile-header{display:flex}.mobile-settings{display:flex;gap:.25rem}.mobile-settings .theme-toggle,.mobile-settings .lang-toggle{width:auto;min-width:unset;padding:.5rem;flex-shrink:0}.mobile-settings .theme-toggle span{display:none}.lang-dropdown-mobile{position:relative}.lang-toggle{display:flex;align-items:center;gap:.25rem;padding:.5rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.lang-toggle:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.lang-code{font-size:.75rem;font-weight:600;color:var(--color-primary);min-width:20px;text-align:center}.lang-menu-mobile{position:fixed;top:60px;right:10px;min-width:160px;background:#fff;border:3px solid #3b82f6;border-radius:8px;box-shadow:0 10px 30px #0009;z-index:99999;overflow:visible;padding:8px 0}.lang-menu-mobile:before{content:"";position:absolute;top:-10px;right:20px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #3b82f6}.lang-menu-mobile .lang-option{display:block;width:100%;padding:12px 20px;background:#fff!important;border:none;border-bottom:1px solid #e5e7eb;color:#111827!important;text-align:left;cursor:pointer;font-size:16px;font-weight:500;line-height:1.5;white-space:nowrap;min-height:44px;box-sizing:border-box}.lang-menu-mobile .lang-option:last-child{border-bottom:none}.lang-menu-mobile .lang-option:hover,.lang-menu-mobile .lang-option:active{background:#3b82f6!important;color:#fff!important}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:var(--z-modal);transform:translate(-100%);max-height:100vh;height:100vh}.sidebar.open{transform:translate(0);z-index:calc(var(--z-modal) + 1)}.sidebar.collapsed{transform:translate(-100%)}.sidebar-nav{max-height:calc(100vh - 200px)}.main-content{padding-top:56px}.content-wrapper{padding:1rem}.desktop-only{display:none!important}}@media (min-width: 769px) and (max-width: 1024px){.sidebar{width:220px}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}}@media (min-width: 1025px){.mobile-overlay,.mobile-header{display:none!important}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}button:focus-visible,input:focus-visible,a:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.animate-fade-in{animation:fadeIn var(--transition-slow) ease-out}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius);font-weight:500;font-size:.875rem;transition:all var(--transition-fast);border:none;cursor:pointer;text-decoration:none;white-space:nowrap}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg-hover)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover{background-color:var(--color-danger-dark)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover{background-color:var(--color-success-dark)}.btn-warning{background-color:var(--color-warning);color:#fff}.btn-warning:hover{background-color:var(--color-warning-dark)}.input{width:100%;padding:.625rem .875rem;background-color:var(--color-bg-input);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;transition:all var(--transition-fast);box-sizing:border-box}.input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #3b82f61a;outline:none}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.badge-success{background-color:#10b98126;color:var(--color-success)}.badge-warning{background-color:#f59e0b26;color:var(--color-warning)}.badge-danger{background-color:#ef444426;color:var(--color-danger)}.badge-info{background-color:#3b82f626;color:var(--color-primary)}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.card-title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.table{width:100%;border-collapse:collapse;min-width:600px}.table th,.table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--color-table-border);white-space:nowrap}.table th{background:var(--color-table-header-bg);font-weight:600;color:var(--color-text-secondary);font-size:.688rem;text-transform:uppercase;letter-spacing:.05em}.table tbody tr:hover{background-color:var(--color-table-row-hover)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.modal-large{max-width:700px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-title{font-size:1.875rem;font-weight:700;color:var(--color-text-primary)}.page-description{color:var(--color-text-secondary);font-size:.875rem;margin-top:.25rem}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:var(--color-primary)}.pagination{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-top:1rem}.pagination-info{font-size:.875rem;color:var(--color-text-secondary);min-width:100px;text-align:center}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--color-text-muted)}.empty-state svg{opacity:.3;margin-bottom:1rem}.loading-container{display:flex;align-items:center;justify-content:center;padding:3rem}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.dashboard-header h1{font-size:1.875rem;font-weight:700;color:var(--color-text-primary);margin:0}.page-description{color:var(--color-text-secondary);margin:.25rem 0 0;font-size:.875rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card .stat-card-content{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}@media (max-width: 768px){.stat-card .stat-card-content{flex-direction:column;align-items:flex-start}.stat-card .stat-icon{margin-bottom:.5rem}}.stat-card .stat-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card .stat-info h3{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .25rem;line-height:1}.stat-card .stat-info p{font-size:.875rem;color:var(--color-text-secondary);margin:0}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.provider-cell{display:flex;align-items:center;gap:.5rem}.provider-name{font-weight:500;color:var(--color-text-primary)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--radius);font-size:.75rem;font-weight:500}.status-badge.active{background:#10b98126;color:var(--color-success)}.status-badge.blocked{background:#ef444426;color:var(--color-danger)}.status-badge.pending{background:#f59e0b26;color:var(--color-warning)}.table-footer{padding:.75rem 1rem;background:var(--color-bg-tertiary);border-top:1px solid var(--color-border);text-align:center}.view-all-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--color-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:gap var(--transition-fast)}.view-all-link:hover{gap:.5rem}.usage-summary{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.usage-stat{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--color-bg-tertiary);border-radius:var(--radius)}.usage-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:#3b82f626;color:var(--color-primary)}.usage-icon.tokens{background:#8b5cf626;color:var(--color-info)}.usage-icon.success{background:#10b98126;color:var(--color-success)}.usage-info{flex:1}.usage-value{display:block;font-size:1.5rem;font-weight:700;color:var(--color-text-primary);line-height:1.2}.usage-label{display:block;font-size:.875rem;color:var(--color-text-secondary);margin-top:.125rem}.top-models-section{padding:1rem;border-top:1px solid var(--color-border)}.top-models-section h4{font-size:.875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.top-models-list{display:flex;flex-direction:column;gap:.5rem}.top-model-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--color-bg-tertiary);border-radius:var(--radius)}.top-model-rank{font-size:.75rem;font-weight:600;color:var(--color-primary);min-width:1.5rem}.top-model-info{flex:1;min-width:0}.top-model-name{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-model-provider{display:block;font-size:.75rem;color:var(--color-text-muted)}.top-model-requests{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;color:var(--color-text-secondary)}.spinner-large{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.card-title{font-size:1rem;font-weight:600;color:var(--color-text-primary)}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card .stat-card-content{padding:1rem;gap:.75rem}.stat-card .stat-icon{width:48px;height:48px}.stat-card .stat-info h3{font-size:1.5rem}.dashboard-grid{grid-template-columns:1fr;gap:1.25rem}.dashboard-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;display:flex;justify-content:flex-start}}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:0 4px 20px #0000001a}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-card-header)}.card-title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.card-content{padding:20px}.card-footer{padding:12px 20px;border-top:1px solid var(--border-color);background:var(--bg-card-header)}.card-loading{display:flex;flex-direction:column;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;font-family:inherit}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-warning{background:var(--warning);color:#fff}.btn-small{padding:6px 12px;font-size:12px}.btn-medium{padding:10px 16px;font-size:14px}.btn-large{padding:14px 20px;font-size:16px}.btn-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.btn-icon{display:flex;align-items:center;justify-content:center}.btn-text{display:flex;align-items:center}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge-default{background:#e5e7eb;color:#374151}.badge-primary{background:#3b82f6;color:#fff}.badge-success{background:#10b981;color:#fff}.badge-warning{background:#f59e0b;color:#fff}.badge-danger{background:#ef4444;color:#fff}.badge-small{padding:1px 6px;font-size:10px}.badge-medium{padding:2px 8px;font-size:12px}.badge-large{padding:4px 12px;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease}.modal-small{width:400px}.modal-medium{width:600px}.modal-large{width:800px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:var(--text-secondary);transition:all .2s ease}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-color)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.providers-page{padding-bottom:2.5rem}.page-header h1{font-size:1.875rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.25rem}.page-description{color:var(--color-text-secondary);font-size:.875rem}.provider-types-hint{display:block;margin-top:.5rem;font-size:.75rem;color:var(--color-text-muted)}.hint-standard{color:var(--color-success);font-weight:500}.hint-custom{color:var(--color-info);font-weight:500}.custom-providers-info{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;margin-bottom:1.5rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem}.custom-providers-info svg{flex-shrink:0;margin-top:2px;color:var(--color-info)}.custom-providers-info strong{color:var(--color-info-light)}.providers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.provider-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;transition:all var(--transition-base);position:relative;overflow:hidden}.provider-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.provider-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.provider-card:hover:before{opacity:1}.provider-card.disabled{opacity:.6}.provider-card.custom-provider{border-color:#8b5cf64d}.provider-card.custom-provider:hover{border-color:var(--color-info)}.provider-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.custom-badge{display:inline-flex;align-items:center;margin-left:.5rem;padding:2px 8px;background:var(--gradient-primary);color:#fff;font-size:10px;font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.provider-info{display:flex;align-items:center;gap:.75rem}.provider-icon{color:var(--color-primary);background:#3b82f61a;padding:.5rem;border-radius:var(--radius)}.provider-info h3{font-size:1rem;font-weight:600;color:var(--color-text-primary);display:flex;align-items:center}.provider-id{font-size:.75rem;color:var(--color-text-muted);text-transform:lowercase;margin-top:2px}.provider-details{margin-bottom:1rem;padding:.75rem;background:var(--color-bg-tertiary);border-radius:var(--radius)}.detail-row{display:flex;margin-bottom:.5rem;font-size:.813rem}.detail-row:last-child{margin-bottom:0}.detail-label{color:var(--color-text-muted);min-width:90px;flex-shrink:0}.detail-value{color:var(--color-text-primary);word-break:break-all}.features-tags{display:flex;gap:.5rem;flex-wrap:wrap}.feature-tag{background:#3b82f61a;color:var(--color-primary);padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem}.provider-actions{display:flex;gap:.5rem;flex-wrap:wrap}.provider-actions .btn{padding:.375rem .75rem;font-size:.813rem}.provider-status{display:flex;align-items:center}.test-result{margin-top:1rem;padding:.75rem;border-radius:var(--radius);font-size:.875rem}.test-result.success{background:#10b9811a;border:1px solid rgba(16,185,129,.2)}.test-result.error{background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.test-result-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:600}.test-result.success .test-result-header{color:var(--color-success)}.test-result.error .test-result-header{color:var(--color-danger)}.success-icon{color:var(--color-success)}.error-icon{color:var(--color-danger)}.models-found{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.checkbox-group{display:flex;gap:1.25rem;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--color-text-primary)}.checkbox-label input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:var(--color-primary)}.modal-large{max-width:700px;width:95%}.loading-models,.empty-models{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.25rem;color:var(--color-text-muted);gap:1rem}.models-count{color:var(--color-text-muted);margin-bottom:1rem;font-size:.875rem}.models-list{max-height:400px;overflow-y:auto;padding-right:.5rem}.model-item{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:.75rem;overflow:hidden;transition:border-color var(--transition-fast)}.model-item:hover{border-color:var(--color-primary)}.model-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background var(--transition-fast)}.model-header:hover{background:var(--color-bg-hover)}.model-title{display:flex;align-items:center;gap:.75rem}.model-name{font-weight:600;color:var(--color-text-primary);font-size:.875rem}.model-provider{font-size:.75rem;color:var(--color-text-muted);background:var(--color-bg-secondary);padding:2px 8px;border-radius:var(--radius-sm)}.model-meta{display:flex;align-items:center;gap:.75rem}.model-context{font-size:.75rem;color:var(--color-success);background:#10b9811a;padding:2px 8px;border-radius:var(--radius-sm)}.model-details-expanded{padding:1rem;border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.detail-section{margin-bottom:1rem}.detail-section:last-child{margin-bottom:0}.detail-section h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:.5rem}.detail-section p{color:var(--color-text-primary);line-height:1.6;margin:0;font-size:.875rem}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item .detail-label{font-size:.75rem;color:var(--color-text-muted);min-width:auto}.detail-item code{background:var(--color-bg-primary);padding:4px 8px;border-radius:var(--radius-sm);font-size:.75rem;color:var(--color-primary);word-break:break-all}.detail-item .healthy{color:var(--color-success)}.detail-item .unhealthy{color:var(--color-danger)}.test-response{margin-top:1.25rem;padding:1rem;border-radius:var(--radius);border:1px solid}.test-response.success{background:#10b9810d;border-color:#10b98133}.test-response.error{background:#ef44440d;border-color:#ef444433}.test-response h4{margin-bottom:.75rem;color:var(--color-text-primary)}.response-content{background:var(--color-bg-primary);padding:.75rem;border-radius:var(--radius);margin-bottom:1rem}.response-text{color:var(--color-text-primary);margin:0;line-height:1.6;white-space:pre-wrap}.tool-calls{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.tool-calls h5{display:flex;align-items:center;gap:.5rem;color:var(--color-warning);margin-bottom:.75rem;font-size:.875rem}.tool-call{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius);padding:.75rem;margin-bottom:.75rem}.tool-name{color:var(--color-text-primary);margin-bottom:.5rem}.tool-name code{color:var(--color-primary);background:#3b82f61a;padding:2px 6px;border-radius:var(--radius-sm)}.tool-arguments{margin-top:.5rem}.tool-arguments span{font-size:.75rem;color:var(--color-text-muted)}.tool-arguments pre{background:var(--color-bg-secondary);padding:.5rem;border-radius:var(--radius-sm);margin-top:.25rem;overflow-x:auto;font-size:.75rem;color:var(--color-text-primary)}.response-meta{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border);font-size:.75rem;color:var(--color-text-muted)}.error-message{color:var(--color-danger);margin:0}.form-hint{display:block;margin-top:.25rem;font-size:.75rem;color:var(--color-text-muted)}.checkbox-label svg{margin-right:.25rem;vertical-align:middle}@media (max-width: 768px){.page-header{flex-direction:column;align-items:stretch}.providers-grid,.form-row,.details-grid{grid-template-columns:1fr}.modal-large{width:95%;margin:.625rem;max-height:90vh}.model-header{flex-direction:column;align-items:flex-start;gap:.5rem}.model-meta{flex-wrap:wrap}}.models-page{padding-bottom:2.5rem}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.page-description{color:var(--text-secondary);font-size:.875rem;margin-top:.25rem}.header-actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.header-stats{display:flex;gap:.5rem;flex-wrap:wrap}.stat-badge{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--color-border);border-radius:8px;font-size:.813rem;color:var(--text-secondary);transition:all .2s}.stat-badge:hover{border-color:var(--accent-primary)}.stat-badge.success{background:#22c55e1a;border-color:#22c55e4d;color:var(--accent-success)}.stat-badge.warning{background:#f59e0b1a;border-color:#f59e0b4d;color:var(--accent-warning)}.filters-bar{display:flex;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:200px;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:.875rem;color:var(--text-muted);z-index:1}.search-box input{padding-left:2.75rem;width:100%}.filter-select{min-width:140px}.items-per-page-select{min-width:120px}.view-toggle{display:flex;gap:.25rem;background:var(--bg-tertiary);padding:.25rem;border-radius:8px}.view-toggle .btn{padding:.5rem .875rem;font-size:.813rem}.toggle-switch-container{display:flex;align-items:center;gap:.5rem;background:var(--bg-tertiary);padding:.4rem .75rem;border-radius:8px;border:1px solid var(--color-border)}.toggle-label{font-size:.75rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em;transition:all .2s;-webkit-user-select:none;user-select:none;min-width:50px}.toggle-label.active{color:var(--text-primary)}.toggle-switch{position:relative;width:50px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#d1d5db;border-radius:26px;transition:all .3s ease}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 6px #0000004d}.toggle-switch input:checked+.toggle-slider{background-color:#fca5a5;border:2px solid #ef4444}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch:hover .toggle-slider{background-color:#e5e7eb}.toggle-switch input:checked:hover+.toggle-slider{background-color:#f87171;border-color:#dc2626}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.toggle-switch input:disabled+.toggle-slider:before{cursor:not-allowed}.models-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:.75rem}.section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.model-count{color:var(--text-muted);font-weight:400;margin-left:.5rem}.table-container{overflow-x:auto;width:100%;border-radius:8px;border:1px solid var(--color-border);box-shadow:0 1px 3px #0000000d}.models-table{width:100%;border-collapse:collapse;min-width:700px}.models-table th,.models-table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.models-table th{background:var(--table-header-bg, var(--bg-tertiary));font-weight:600;color:var(--text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0;z-index:1}.models-table tbody tr{transition:background-color .15s}.models-table tbody tr:hover{background:var(--table-row-hover, var(--bg-hover))}.models-table tbody tr:last-child td{border-bottom:none}.model-info{display:flex;align-items:flex-start;gap:.75rem}.model-icon{color:var(--accent-primary);margin-top:2px;flex-shrink:0}.model-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem;font-size:.875rem}.model-id{font-size:.75rem;color:var(--text-muted);font-family:monospace;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manual-badge{display:inline-block;background:#8b5cf626;color:#8b5cf6;padding:2px 6px;border-radius:4px;font-size:.625rem;margin-top:4px;font-weight:500}.provider-badge{display:inline-flex;align-items:center;background:#3b82f626;color:var(--accent-primary);padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500}.context-window{display:flex;align-items:center;gap:4px;color:var(--accent-success);font-size:.813rem}.no-data{color:var(--text-muted);font-style:italic;font-size:.813rem}.status-cell{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.status-badges{display:flex;flex-wrap:wrap;gap:4px}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500}.status-badge.active{background:#22c55e26;color:var(--accent-success);border:1px solid rgba(34,197,94,.3)}.status-badge.pending,.status-badge.rate-limited{background:#f59e0b26;color:var(--accent-warning);border:1px solid rgba(245,158,11,.3)}.status-badge.blocked,.status-badge.disabled{background:#ef444426;color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.user-disabled-badge{display:block;font-size:.688rem;color:var(--text-muted);font-style:italic;margin-top:2px;cursor:help}.user-disabled-badge .disabled-reason{color:var(--accent-danger);font-weight:500}.alert{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-radius:8px;font-size:.875rem}.alert-warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:var(--accent-warning)}.alert svg{flex-shrink:0;margin-top:2px}.action-buttons{display:flex;gap:.375rem}.btn-sm{padding:.375rem .625rem;font-size:.75rem}.disabled-row{opacity:.6}.disabled-row:hover{background:var(--table-row-hover, var(--bg-hover))}.empty-cell{padding:3rem 1.25rem}.empty-models{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-muted)}.empty-models svg{opacity:.3}.pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;padding:.75rem}.pagination-info{font-size:.875rem;color:var(--text-secondary);min-width:100px;text-align:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-card);border-radius:12px;border:1px solid var(--color-border);width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:1.25rem;overflow-y:auto;flex:1}.form-label{display:block;margin-bottom:.375rem;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:var(--accent-primary)}.test-result{display:flex;flex-direction:column;gap:1rem}.test-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.test-model-id{font-family:monospace;font-size:.75rem;color:var(--text-primary);background:var(--bg-tertiary);padding:.375rem .75rem;border-radius:6px}.test-sections{display:flex;flex-direction:column;gap:.75rem}.test-section-card{background:var(--bg-tertiary);border-radius:8px;padding:.875rem;border:1px solid var(--color-border)}.test-section-card h4{display:flex;align-items:center;gap:.5rem;font-size:.813rem;font-weight:600;color:var(--text-secondary);margin:0 0 .625rem}.test-success{display:flex;align-items:center;gap:.5rem;color:var(--accent-success);font-size:.813rem}.test-warning{display:flex;align-items:center;gap:.5rem;color:var(--accent-warning);font-size:.813rem}.test-fail{display:flex;align-items:center;gap:.5rem;color:var(--accent-danger);font-size:.813rem}.test-meta{display:flex;gap:1rem;font-size:.75rem;color:var(--text-muted);padding-top:.75rem;border-top:1px solid var(--color-border)}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-muted);gap:1rem}@media (max-width: 768px){.page-header{flex-direction:column;align-items:stretch}.header-actions,.header-stats{justify-content:flex-start}.filters-bar{flex-direction:column;align-items:stretch}.search-box{min-width:100%}.filter-select,.items-per-page-select,.view-toggle{width:100%}.view-toggle .btn{flex:1;justify-content:center}.section-header{flex-direction:column;align-items:stretch}.action-buttons{flex-wrap:wrap}.stat-badge{font-size:.75rem;padding:.375rem .5rem}.toggle-switch-container{width:100%;justify-content:center}}@media (max-width: 640px){.page-header h1{font-size:1.5rem}.models-table th,.models-table td{padding:.625rem .75rem;font-size:.813rem}.model-id{max-width:150px}}.test-progress{display:flex;flex-direction:column;gap:1.5rem}.test-model-info{font-size:.875rem;color:var(--text-secondary);margin:0;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.test-model-info strong{color:var(--text-primary);font-family:monospace;font-size:.813rem}.test-phases{display:flex;flex-direction:column;gap:.75rem}.test-phase{display:flex;align-items:center;gap:.875rem;padding:.875rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--color-border);transition:all .2s ease}.test-phase.running{background:#3b82f61a;border-color:#3b82f64d}.test-phase.success{background:#22c55e1a;border-color:#22c55e4d}.test-phase.failed{background:#ef44441a;border-color:#ef44444d}.test-phase.skipped{background:#6b72801a;border-color:#6b72804d}.test-phase-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.test-phase-icon .spin{color:var(--accent-primary)}.test-phase-icon .text-success{color:var(--accent-success)}.test-phase-icon .text-error{color:var(--accent-danger)}.test-phase-icon .text-muted{color:var(--text-muted)}.phase-dot{width:10px;height:10px;background:var(--text-muted);border-radius:50%;opacity:.4}.test-phase-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.test-phase-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.test-phase-status{font-size:.75rem;color:var(--text-muted)}.test-phase-status.text-success{color:var(--accent-success)}.test-phase-status.text-error{color:var(--accent-danger)}.test-phase-status.text-muted{color:var(--text-muted)}.test-progress-bar{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden;margin-top:.5rem}.test-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:3px;transition:width .3s ease}@media (max-width: 480px){.filters-bar{gap:.5rem}.view-toggle .btn{padding:.5rem;font-size:.75rem}.header-stats{flex-direction:column;align-items:flex-start}.stat-badge{width:100%;justify-content:center}}.toast-notification{position:fixed;top:80px;right:24px;background:var(--bg-card)!important;color:var(--text-primary)!important;padding:14px 20px!important;border-radius:10px!important;box-shadow:0 8px 25px #00000026!important;border:1px solid var(--color-border)!important;z-index:9999!important;animation:toast-slide-in .3s ease-out!important;font-weight:600!important;max-width:350px!important;min-width:200px!important;width:auto!important;height:auto!important;text-align:left!important;font-size:14px!important;line-height:1.5!important;display:flex!important;align-items:center!important;gap:10px!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;opacity:1!important;visibility:visible!important;transform:translate(0)!important}.toast-notification:before{content:"✓"!important;color:var(--color-success)!important;font-weight:700!important;font-size:16px!important}@keyframes toast-slide-in{0%{transform:translate(120%)!important;opacity:0!important}to{transform:translate(0)!important;opacity:1!important}}.rate-limits-page{padding-bottom:40px}.stat-badge.danger{background:#ef44441a;border-color:#ef44444d;color:var(--color-danger)}.rate-limits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.empty-state{grid-column:1 / -1;text-align:center;padding:60px 20px;background:var(--color-bg-secondary);border-radius:12px;border:2px dashed var(--color-border)}.empty-icon{color:var(--text-muted);margin-bottom:16px}.empty-state h3{color:var(--text-primary);margin-bottom:8px}.empty-state p{color:var(--text-secondary)}.rate-limit-card{background:var(--color-bg-secondary);border-radius:12px;padding:20px;border:1px solid var(--color-border);transition:all .2s}.rate-limit-card:hover{border-color:var(--color-border-hover)}.rate-limit-card.limited{border-color:#ef444480;background:#ef44440d}.rate-limit-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border)}.model-info h3{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px;word-break:break-all}.limited-badge{display:inline-flex;align-items:center;gap:4px;background:#ef444433;color:var(--color-danger);padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.usage-indicator{display:flex;align-items:center;gap:6px;color:var(--color-primary);font-size:13px;font-weight:500}.rate-limit-stats{margin-bottom:16px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--color-border-light)}.stat-row:last-child{border-bottom:none}.stat-label{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:13px}.stat-value{color:var(--text-primary);font-weight:500;font-size:13px}.limitation-info{display:flex;gap:12px;padding:12px;background:#ef44441a;border-radius:8px;margin-bottom:16px}.limitation-info svg{color:var(--color-danger);flex-shrink:0}.limitation-info p{font-size:13px;color:var(--color-danger)}.time-left{color:var(--color-warning);margin-top:4px}.rate-limit-actions{display:flex;gap:8px}.rate-limit-actions .btn{flex:1}@media (max-width: 768px){.rate-limits-grid{grid-template-columns:1fr}}.errors-page{padding-bottom:40px}.header-actions{display:flex;gap:12px}.errors-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.summary-card{background:var(--bg-card);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid var(--color-border)}.summary-card svg{color:var(--color-danger)}.summary-card.warning svg{color:var(--color-warning)}.summary-card h3{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.summary-card p{color:var(--text-secondary);font-size:14px}.filter-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-group .input{min-width:200px}.filter-group .select{min-width:150px}.filter-group .btn{padding:8px 14px}.table-container{overflow-x:auto;border-radius:8px;border:1px solid var(--color-border);margin-top:16px}.errors-table{width:100%;border-collapse:collapse;min-width:800px}.errors-table th,.errors-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.errors-table th{background:var(--table-header-bg);font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0;z-index:1}.errors-table tbody tr:hover{background:var(--table-row-hover)}.error-level{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500}.error-level.error{background:#ef444426;color:var(--color-danger)}.error-level.warning{background:#f59e0b26;color:var(--color-warning)}.error-message-cell{max-width:300px}.provider-name{font-weight:600;color:var(--text-primary)}.error-time{font-size:13px;color:var(--text-secondary)}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.pagination-info{font-size:14px;color:var(--text-secondary);min-width:100px;text-align:center}.pagination .btn:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state svg{opacity:.3;margin-bottom:16px}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-muted);gap:16px}@media (max-width: 768px){.filter-group{flex-direction:column;align-items:stretch}.filter-group .input,.filter-group .select,.filter-group .btn{width:100%;justify-content:center}.errors-summary{grid-template-columns:1fr}.error-message-cell{max-width:200px}}.toast-notification{position:fixed;bottom:24px;right:24px;background:var(--bg-card);color:var(--text-primary);padding:16px 24px;border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);z-index:9999;animation:toast-slide-in .3s ease-out;font-weight:500;max-width:400px}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.text-muted{color:var(--text-secondary);font-size:.875rem;margin-top:8px}.error-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:6px}.error-card-header{display:flex;justify-content:space-between;align-items:center}.expand-icon{transition:transform .2s ease;display:inline-block;transform:rotate(0)}.expand-icon.expanded{transform:rotate(180deg)}.error-type{display:inline-flex;align-items:center;gap:6px}.error-type-badge{font-size:12px;text-transform:uppercase;padding:2px 6px;border-radius:6px}.error-time{font-size:12px;color:var(--color-text-secondary)}.error-model{display:flex;align-items:center;gap:6px;font-family:monospace;font-size:12px}.error-message{font-family:monospace;font-size:12px;color:var(--text-primary);background:var(--bg-tertiary);padding:8px 12px;border-radius:6px;word-break:break-word;line-height:1.4}.error-actions{display:flex;justify-content:flex-end}.fallback-page{padding-bottom:2.5rem}.save-notification{display:flex;align-items:center;gap:.625rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--color-success);padding:.75rem 1.25rem;border-radius:var(--radius);margin-bottom:1.5rem;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem}.setting-item{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--color-border)}.setting-item:last-child{border-bottom:none}.setting-info{flex:1;margin-right:1.25rem}.setting-label{display:block;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.setting-description{color:var(--color-text-secondary);font-size:.813rem;margin:0}.setting-input{width:150px}.toggle{position:relative;display:inline-block;width:48px;height:24px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-border);transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(24px)}.providers-priority{margin-bottom:1rem}.priority-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.priority-item:last-child{border-bottom:none}.priority-item.draggable{cursor:grab;transition:all .2s ease;background:var(--color-bg-secondary);margin-bottom:.5rem;padding:.75rem;border-radius:var(--radius);border:1px solid var(--color-border)}.priority-item.draggable:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a}.priority-item.draggable:active{cursor:grabbing}.drag-handle{display:flex;align-items:center;color:var(--color-text-secondary);margin-right:.5rem;cursor:grab}.priority-number{font-weight:600;color:var(--color-primary);min-width:30px;text-align:right}.drag-container{padding:.5rem 0}.priority-info{display:flex;align-items:center;gap:.75rem}.priority-name{font-weight:500;color:var(--color-text-primary)}.priority-status{font-size:.688rem;padding:2px 8px;border-radius:var(--radius-sm);font-weight:500}.priority-status.enabled{background:#10b9811a;color:var(--color-success)}.priority-status.disabled{background:#ef44441a;color:var(--color-danger)}.priority-input{width:80px;text-align:center}.priority-help{color:var(--color-text-secondary);font-size:.75rem;margin:0;padding-top:.75rem;border-top:1px solid var(--color-border)}.empty-priority{text-align:center;padding:2.5rem;color:var(--color-text-muted)}.info-card{background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border:1px solid var(--color-border)}.info-content{color:var(--color-text-secondary);font-size:.875rem;line-height:1.7}.info-content p{margin-bottom:1rem}.info-content h4{color:var(--color-text-primary);margin-bottom:.75rem;font-size:.875rem}.info-content ul{margin-bottom:1rem;padding-left:1.25rem}.info-content li{margin-bottom:.5rem}.info-content strong{color:var(--color-primary)}@media (max-width: 768px){.settings-grid{grid-template-columns:1fr}.setting-item{flex-direction:column;gap:.75rem}.setting-input{width:100%}.header-actions{flex-direction:column;width:100%}}.monitoring-page{max-width:1600px;margin:0 auto;padding:0}@media (max-width: 768px){.monitoring-page{padding:0 12px;overflow-x:hidden}}.monitoring-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.monitoring-page .page-header h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#3b82f6,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.monitoring-page .page-description{color:var(--text-secondary);margin-top:4px;font-size:14px}.monitoring-page .header-actions{display:flex;gap:10px;flex-wrap:wrap}.tabs-container{margin-bottom:24px}.tabs{display:flex;gap:4px;padding:6px;background:var(--bg-tertiary);border-radius:14px;overflow-x:auto;width:fit-content;min-width:100%}.tab{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.tab.active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 4px 15px #3b82f666;transform:translateY(-1px)}.tab-content{animation:tabFadeIn .4s ease-out}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px}min-width: 0; } .stat-info h3{font-size:1.75rem;word-break:break-all;line-height:1.1}.stat-info p{font-size:12px}} .stat-card{position:relative;background:var(--bg-card);border:1px solid var(--color-border);border-radius:16px;padding:24px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026;border-color:#3b82f64d}.stat-glow{display:none}@keyframes glowPulse{0%,to{transform:scale(1);opacity:.08}50%{transform:scale(1.1);opacity:.12}}.stat-card-content{display:flex;align-items:center;gap:16px;position:relative;z-index:1}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-info{flex:1}.stat-info h3{font-size:2rem;font-weight:800;color:var(--text-primary);margin:0;line-height:1.2;font-variant-numeric:tabular-nums}.stat-info p{font-size:.875rem;color:var(--text-secondary);margin:4px 0 0;font-weight:500}.counter-animate{animation:counterPop .5s cubic-bezier(.4,0,.2,1)}@keyframes counterPop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:1fr}}.lg-col-span-2{grid-column:span 2}@media (max-width: 1200px){.lg-col-span-2{grid-column:span 1}}.chart-card{padding:0;overflow:visible}.chart-card .card-header{padding:16px 20px;border-bottom:1px solid var(--color-border)}.chart-card .card-title{font-size:14px}.chart-wrapper{padding:16px 12px;min-height:240px;overflow:hidden}@media (max-width: 500px){.chart-wrapper{min-height:180px;padding:8px 4px}}.pie-wrapper{display:flex;align-items:center;justify-content:center;width:100%;min-height:240px}@media (max-width: 500px){.pie-wrapper{min-height:200px;padding:8px 0}}.chart-tooltip{background:var(--bg-card);border:1px solid var(--color-border);border-radius:10px;padding:12px 16px;box-shadow:0 8px 30px #0003}.tooltip-label{font-weight:600;color:var(--text-primary);margin-bottom:6px;font-size:13px}.tooltip-value{font-size:12px;margin:2px 0;font-weight:500}.empty-chart{display:flex;align-items:center;justify-content:center;height:280px;color:var(--text-muted);font-size:14px;background:var(--bg-tertiary);border-radius:12px;margin:16px}.table-container{padding:0;overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:14px 16px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-tertiary);border-bottom:1px solid var(--color-border)}.table td{padding:16px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--color-border);vertical-align:middle}.table tbody tr{transition:all .2s ease}.table tbody tr:hover{background:var(--bg-hover)}.fade-in-row{animation:rowFadeIn .4s ease-out forwards;opacity:0}@keyframes rowFadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.provider-cell{display:flex;align-items:center;gap:10px;font-weight:500}.provider-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 10px currentColor}.success-bar-container{display:flex;align-items:center;gap:10px;min-width:120px}.success-bar{height:8px;border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1);flex:1;max-width:80px}.success-text{font-size:13px;font-weight:600;min-width:40px}.model-info{display:flex;align-items:center;gap:10px}.model-info svg{color:var(--text-muted);flex-shrink:0}.model-name{font-weight:500;font-size:14px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-cell{font-weight:700;font-size:16px;color:var(--text-muted);width:50px}.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:20px;border-top:1px solid var(--color-border)}.pagination .btn{min-width:36px;height:36px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.5}.monitoring-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.spinner-large{width:48px;height:48px;border:4px solid var(--bg-tertiary);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.toast-notification{position:fixed;bottom:24px;right:24px;background:var(--bg-card);color:var(--text-primary);padding:16px 24px;border-radius:12px;box-shadow:0 8px 30px #0003;border:1px solid var(--color-border);z-index:9999;animation:toastSlideIn .3s ease-out;font-weight:500}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:overlayFadeIn .2s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border-radius:16px;width:90%;max-width:480px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:scale(.95) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-sm{max-width:380px}.modal-header{padding:20px 24px;border-bottom:1px solid var(--color-border)}.modal-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.modal-body{padding:24px}.modal-body p{margin:0;color:var(--text-secondary)}.modal-footer{padding:16px 24px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:10px}@media (max-width: 768px){.monitoring-page{padding:0 12px;width:100%;max-width:100%;overflow-x:hidden}.monitoring-page .page-header{flex-direction:column;gap:12px;margin-bottom:16px}.monitoring-page .page-header h1{font-size:1.5rem}.monitoring-page .page-description{font-size:13px}.header-actions{width:100%;display:flex;flex-wrap:wrap;gap:8px}.header-actions .btn{flex:1 1 calc(50% - 4px);min-width:unset;justify-content:center;padding:10px 8px;font-size:12px}.header-actions .btn svg{display:none}.header-actions .btn.btn-danger{flex:1 1 100%;order:-1}.tabs-container{margin:0 -12px 16px;padding:0 12px;overflow:visible}.tabs{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:4px;gap:4px;border-radius:10px}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 14px;font-size:12px;gap:6px;flex-shrink:0;border-radius:8px}.tab svg{width:14px;height:14px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:0 -12px 16px;padding:0 12px;width:calc(100% + 24px);box-sizing:border-box}.stat-card{min-height:80px;padding:12px;border-radius:12px;overflow:visible}.stat-card-content{display:flex;flex-direction:row;align-items:center;gap:10px;width:100%}.stat-icon{width:36px;height:36px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.stat-icon svg{width:18px;height:18px}.stat-info{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;gap:2px}.stat-info h3{font-size:1.1rem;font-weight:700;line-height:1.1;word-break:break-word}.stat-info p{font-size:10px;margin-top:0}.dashboard-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.lg-col-span-2{grid-column:span 1}.card{border-radius:12px;overflow:visible}.card-header{flex-direction:row;justify-content:space-between;padding:12px}.card-title{font-size:14px;display:flex;align-items:center;gap:6px}.card-title svg{width:16px;height:16px}.chart-wrapper{padding:8px;min-height:180px;overflow:visible;width:100%;max-width:100%;box-sizing:border-box}.pie-wrapper{width:100%;min-height:160px;display:flex;align-items:center;justify-content:center;overflow:hidden}.pie-wrapper>div{width:100%!important;max-width:280px}.table-container{margin:0 -12px;padding:0 12px;width:calc(100% + 24px);overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.table-container::-webkit-scrollbar{height:6px}.table-container::-webkit-scrollbar-track{background:transparent}.table-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.table{width:100%;min-width:500px;font-size:11px}.table th,.table td{padding:8px 6px}.success-bar-container{min-width:50px;gap:4px}.success-bar{max-width:30px;height:5px}.success-text{font-size:10px;min-width:25px}.pagination{padding:12px;gap:4px;flex-wrap:wrap}.pagination .btn{min-width:28px;height:28px;padding:4px 6px;font-size:11px}.modal{width:95%;margin:8px}.modal-header,.modal-body{padding:12px}.modal-footer{padding:10px 12px;flex-direction:column}.modal-footer .btn{width:100%;justify-content:center}.toast-notification{left:8px;right:8px;bottom:8px}}@media (max-width: 400px){.stats-grid{grid-template-columns:1fr}.tab{padding:8px 10px;font-size:11px}.header-actions .btn{min-width:80px;font-size:11px}.header-actions .btn svg{display:none}}.card{background:var(--bg-card);border:1px solid var(--color-border);border-radius:16px;box-shadow:0 2px 8px #0000000d;overflow:visible}.card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border)}.card-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--text-muted)}.btn-danger{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444433}.btn-primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;border:none}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px #3b82f666}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--color-border)}.btn-outline:hover{background:var(--bg-hover)}.btn-sm{padding:6px 12px;font-size:13px}.select{padding:8px 14px;border-radius:8px;border:1px solid var(--color-border);background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;cursor:pointer}.select:focus{outline:none;border-color:#3b82f6}@keyframes cardEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.recharts-default-tooltip{background:var(--bg-card)!important;border:1px solid var(--color-border)!important;border-radius:10px!important;box-shadow:0 8px 30px #0003!important}.recharts-legend-item-text{color:var(--text-secondary)!important}.blacklist-page{padding:1rem;max-width:1800px;margin:0 auto}@media (max-width: 768px){.blacklist-page{padding:.5rem;max-width:100%}}.blacklist-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-text-secondary)}.blacklist-loading .spin{animation:spin 1s linear infinite;margin-bottom:1rem;color:var(--color-primary)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h1{display:flex;align-items:center;gap:.75rem;font-size:1.875rem;font-weight:700;color:var(--color-text-primary);margin:0}.page-description{color:var(--color-text-secondary);margin:.5rem 0 0}.header-actions{display:flex;gap:.75rem}.blacklist-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;margin-top:1rem}.blacklist-stats .stat-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem}.blacklist-stats .stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center}.blacklist-stats .stat-icon.blacklisted{background:linear-gradient(135deg,var(--color-danger),#dc2626);color:#fff}.blacklist-stats .stat-icon.providers{background:linear-gradient(135deg,var(--color-info),#7c3aed);color:#fff}.blacklist-stats .stat-icon.recheck{background:linear-gradient(135deg,var(--color-warning),#d97706);color:#fff}.blacklist-stats .stat-info h3{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0}.blacklist-stats .stat-info p{font-size:.875rem;color:var(--color-text-secondary);margin:.25rem 0 0}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:var(--radius);margin-bottom:1.5rem}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:var(--color-danger)}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:1rem}.card-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0}.blacklist-table{width:100%}.blacklist-table th{text-align:left;padding:.875rem 1.5rem;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary);word-break:break-word}.blacklist-table td{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border-light);font-size:.875rem;color:var(--color-text-primary)}.blacklist-table tr:last-child td{border-bottom:none}.blacklist-table tr:hover td{background:var(--color-bg-tertiary)}.model-cell{display:flex;align-items:center;gap:.5rem}.model-cell .model-name{font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.model-id{font-family:Monaco,Menlo,monospace;font-size:.75rem;background:var(--color-bg-tertiary);padding:.25rem .5rem;border-radius:var(--radius-sm);color:var(--color-text-secondary)}.provider-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;background:var(--color-bg-tertiary);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-transform:capitalize}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.badge-danger{background:#ef44441a;color:var(--color-danger)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--color-text-secondary)}.empty-state svg{color:var(--color-success);margin-bottom:1rem}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin:0 0 .5rem}.empty-state p{margin:0}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius);font-weight:500;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast);border:none}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-light)}.btn-danger:hover{background:var(--color-danger-dark)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:1rem}.modal{background:var(--color-bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);border:1px solid var(--color-border)}.modal-sm{max-width:400px}.modal-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0;display:flex;align-items:center;gap:.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border)}.warning-text{color:var(--color-text-secondary);line-height:1.6;margin:0}.info-card{margin-bottom:1rem;background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-tertiary) 100%);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-top:0}.info-content{padding:1.5rem}.recovery-steps{display:flex;align-items:stretch;gap:1rem;flex-wrap:wrap}.step{flex:1;min-width:200px;display:flex;gap:.75rem;padding:1rem;background:var(--color-bg-secondary);border-radius:var(--radius);border:1px solid var(--color-border)}.step-number{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.step-content strong{display:block;color:var(--color-text-primary);margin-bottom:.25rem;font-size:.875rem}.step-content p{margin:0;font-size:.75rem;color:var(--color-text-secondary);line-height:1.4}.step-arrow{display:flex;align-items:center;color:var(--color-text-muted);font-size:1.5rem;font-weight:300}.stat-subtitle{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.stat-icon.recheck{background:linear-gradient(135deg,var(--color-warning),#d97706);color:#fff}.badge-warning{background:#f59e0b1a;color:var(--color-warning);display:inline-flex;align-items:center;gap:.25rem}.time-info{display:inline-flex;align-items:center;gap:.375rem;color:var(--color-text-secondary);font-size:.875rem}.recovery-progress{display:flex;flex-direction:column;gap:.375rem;min-width:150px}.progress-bar{width:100%;height:6px;background:var(--color-bg-tertiary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-success),#34d399);border-radius:3px;transition:width .3s ease}.progress-text{font-size:.75rem;color:var(--color-text-secondary);font-weight:500}.reason-text{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;color:var(--color-text-secondary);font-size:.875rem}.recheck-row{background:#f59e0b0d}.recheck-row:hover{background:#f59e0b1a!important}.table-toolbar{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.search-results{font-size:.875rem;color:var(--color-text-secondary)}.search-box{position:relative;display:flex;align-items:center;flex:1;max-width:400px}.search-icon{position:absolute;left:.75rem;color:var(--color-text-muted);pointer-events:none}.search-input{width:100%;padding:.625rem 2rem .625rem 2.5rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:.875rem;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.search-input::placeholder{color:var(--color-text-muted)}.search-clear{position:absolute;right:.5rem;background:none;border:none;color:var(--color-text-muted);font-size:1.25rem;cursor:pointer;padding:.25rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.search-clear:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.pagination{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border);flex-wrap:wrap}.pagination-info{font-size:.875rem;color:var(--color-text-secondary);white-space:nowrap}.pagination-controls{display:flex;align-items:center;gap:.25rem}.pagination-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-secondary);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-page{font-size:.875rem;font-weight:500;color:var(--color-text-primary);padding:0 .75rem;min-width:100px;text-align:center}.pagination-size{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.pagination-size select{padding:.375rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:.875rem;cursor:pointer}.pagination-size select:focus{outline:none;border-color:var(--color-primary)}.recheck-progress-card{margin-bottom:2rem;border:2px solid var(--color-primary);margin-top:1rem}.card-section{margin-top:1rem}.recheck-progress-card .card-title .pulse{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.recheck-progress-content{padding:1.5rem}.recheck-main-progress{margin-bottom:1.5rem}.recheck-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.recheck-progress-label{font-size:.875rem;color:var(--color-text-primary);font-weight:500}.recheck-progress-label code{background:var(--color-bg-tertiary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-family:Monaco,Menlo,monospace;font-size:.8rem}.recheck-progress-percentage{font-size:.875rem;font-weight:600;color:var(--color-primary)}.recheck-progress-bar-container{width:100%;height:12px;background:var(--color-bg-tertiary);border-radius:6px;overflow:hidden;position:relative}.recheck-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:6px;transition:width .3s ease;position:relative}.recheck-progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.recheck-results-section{border-top:1px solid var(--color-border);padding-top:1.5rem}.recheck-results-title{font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}.recheck-results-list{display:flex;flex-direction:column;gap:.75rem}.recheck-result-item{display:flex;flex-direction:column;gap:.5rem;padding:.875rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-bg-secondary);transition:all var(--transition-fast)}.recheck-result-item:hover{background:var(--color-bg-hover)}.recheck-result-item.success{border-left:3px solid var(--color-success)}.recheck-result-item.failed{border-left:3px solid var(--color-danger)}.recheck-result-main{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.recheck-result-status{flex-shrink:0}.icon-success{color:var(--color-success)}.icon-failed{color:var(--color-danger)}.recheck-result-model{font-weight:500;color:var(--color-text-primary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recheck-result-provider{font-size:.75rem;color:var(--color-text-muted);background:var(--color-bg-tertiary);padding:.25rem .5rem;border-radius:var(--radius-sm)}.recheck-result-details{display:flex;gap:.5rem;margin-left:1.625rem}.test-badge{font-size:.7rem;padding:.125rem .375rem;border-radius:var(--radius-sm);font-weight:500;text-transform:uppercase}.test-badge.pass{background:#10b9811a;color:var(--color-success)}.test-badge.fail{background:#ef44441a;color:var(--color-danger)}.recheck-result-error{margin-left:1.625rem;font-size:.8rem;color:var(--color-danger);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recheck-results-more{text-align:center;padding:.75rem;color:var(--color-text-muted);font-size:.875rem;font-style:italic}.badge-info{background:#3b82f61a;color:var(--color-primary)}.recheck-header-badges{display:flex;align-items:center;gap:.5rem}.countdown-badge{display:inline-flex;align-items:center;gap:.25rem;animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 768px){.blacklist-page{padding:.25rem}.page-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;justify-content:flex-end}.blacklist-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.blacklist-table th,.blacklist-table td{padding:.5rem}.model-cell .model-name{max-width:80px}}.proxies-page{padding:1.5rem;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-title{display:flex;align-items:center;gap:.75rem}.header-title h1{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;gap:1rem;border:1px solid var(--color-border)}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-icon.total{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover))}.stat-icon.enabled{background:linear-gradient(135deg,var(--color-success),#059669)}.stat-icon.working{background:linear-gradient(135deg,var(--color-info),#7c3aed)}.stat-icon.not-tested{background:linear-gradient(135deg,var(--color-warning),#d97706)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);line-height:1}.stat-label{font-size:.875rem;color:var(--color-text-secondary);margin-top:.25rem}.proxies-list{background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.table-container{overflow-x:auto}.proxies-table{width:100%;border-collapse:collapse}.proxies-table th,.proxies-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--color-border)}.proxies-table th{font-weight:600;color:var(--color-text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg-tertiary)}.proxies-table tbody tr:hover{background:var(--color-bg-tertiary)}.proxies-table tbody tr.disabled{opacity:.6}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.badge-success{background:#10b9811a;color:var(--color-success)}.badge-error{background:#ef44441a;color:var(--color-danger)}.badge-warning{background:#f59e0b1a;color:var(--color-warning)}.badge-disabled{background:#6b72801a;color:var(--color-text-muted)}.protocol-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:uppercase}.protocol-badge.http,.protocol-badge.https{background:#3b82f61a;color:var(--color-primary)}.protocol-badge.socks5{background:#8b5cf61a;color:var(--color-info)}.mono{font-family:JetBrains Mono,monospace;font-size:.813rem}.action-buttons{display:flex;gap:.5rem}.btn-icon{width:32px;height:32px;border-radius:var(--radius);border:none;background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.btn-icon.active{background:#10b9811a;color:var(--color-success)}.btn-icon.btn-danger:hover{background:#ef44441a;color:var(--color-danger)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;padding:4rem 1.5rem}.empty-icon{color:var(--color-text-muted);margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:var(--color-text-primary)}.empty-state p{margin:0 0 1.5rem;color:var(--color-text-secondary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:1.5rem}.modal{background:var(--color-bg-secondary);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-xl);border:1px solid var(--color-border)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.btn-close{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.modal-body{padding:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.375rem}.form-group input,.form-group select{width:100%;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.875rem;transition:border-color var(--transition-fast)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid var(--color-border)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary:hover{background:var(--color-bg-hover)}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--color-text-secondary)}.loading-spinner p{margin-top:1rem}.alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.alert-error{background:#ef44441a;color:var(--color-danger);border:1px solid rgba(239,68,68,.2)}.text-success{color:var(--color-success)}.text-muted{color:var(--color-text-secondary)}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.proxies-page{padding:1rem}.page-header{flex-direction:column;gap:1rem;align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}.proxies-table{font-size:.813rem}.proxies-table th,.proxies-table td{padding:.75rem .5rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}}.toast-notice{position:fixed;top:16px;right:16px;background:#141414f2;color:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000040;z-index:9999;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:14px;animation:toast-slide-in .25s ease-out}@keyframes toast-slide-in{0%{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}.system-page{max-width:1200px;margin:0 auto}.page-header{margin-bottom:24px}.page-header h1{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin:0 0 4px}.page-description{color:var(--text-secondary);font-size:.875rem;margin:0}.tabs{display:flex;gap:8px;margin-bottom:24px;padding:4px;background:var(--bg-tertiary);border-radius:10px;overflow-x:auto}.tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm);border:2px solid var(--color-primary)}.tab-content{background:var(--bg-card);border-radius:12px;border:1px solid var(--color-border);overflow:hidden}.card{margin:0}.card-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-tertiary);border-bottom:1px solid var(--color-border)}.card-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.card-body{padding:24px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-large{padding:12px 24px;font-size:16px}.btn-sm{padding:6px 12px;font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}.cleanup-tab{padding:0}.cleanup-content{display:flex;flex-direction:column;gap:24px;padding:24px}.cleanup-section{background:var(--bg-tertiary);border-radius:8px;padding:20px;border:1px solid var(--color-danger)}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.section-header.warning{color:var(--color-danger)}.section-header h2{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.cleanup-warning-text{color:var(--text-secondary);line-height:1.6;margin:0}.cleanup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.cleanup-card{background:var(--bg-tertiary);border-radius:8px;padding:20px;border:1px solid var(--color-border)}.cleanup-card.preserved{border:2px solid var(--color-success)}.cleanup-card h3{display:flex;align-items:center;gap:10px;font-size:1.125rem;font-weight:600;margin:0 0 16px;color:var(--text-primary)}.cleanup-card.preserved h3{color:var(--color-success)}.cleanup-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.cleanup-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-card);border-radius:8px}.cleanup-item-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--danger);color:#fff;border-radius:8px;flex-shrink:0}.cleanup-item-icon.preserved{background:var(--success)}.cleanup-item-content{display:flex;flex-direction:column;gap:4px}.cleanup-item-title{font-weight:600;color:var(--text-primary)}.cleanup-item-desc{font-size:13px;color:var(--text-secondary)}.cleanup-actions{display:flex;justify-content:center;padding:24px 0}.cleanup-result,.backup-result{background:var(--bg-tertiary);border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center;border:1px solid var(--color-border)}.cleanup-result.success,.backup-result.success{border:2px solid var(--color-success)}.cleanup-result.error,.backup-result.error{border:2px solid var(--color-danger)}.cleanup-result.success .result-header,.backup-result.success .result-header{color:var(--color-success)}.cleanup-result.error .result-header,.backup-result.error .result-header{color:var(--color-danger)}.result-header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:16px}.result-details{font-size:14px;color:var(--text-secondary)}.error-count{color:var(--color-danger);font-weight:600}.create-backup-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.create-backup-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.section-description{color:var(--text-secondary);font-size:14px;margin-bottom:16px}.backups-list-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text-muted);text-align:center}.empty-state p{margin-top:16px;font-size:14px}.backups-list{display:flex;flex-direction:column;gap:12px}.backup-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid var(--color-border);border-radius:8px;background:var(--bg-tertiary)}.backup-info{flex:1;min-width:0}.backup-name{font-weight:500;color:var(--text-primary);margin-bottom:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;word-break:break-all}.backup-meta{display:flex;gap:16px;font-size:12px;color:var(--text-secondary);flex-wrap:wrap}.backup-date{color:var(--text-secondary)}.backup-size{color:var(--text-primary);font-weight:500}.backup-actions{display:flex;gap:8px;flex-shrink:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--bg-card);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow:auto;border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.modal-confirm{max-width:500px}.modal-header{padding:16px 20px;border-bottom:1px solid var(--color-border)}.modal-footer{padding:16px 20px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:12px}.modal-title{display:flex;align-items:center;gap:12px;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.confirm-text{font-size:14px;color:var(--text-primary);margin-bottom:16px}.confirm-list{list-style:disc;padding-left:20px;margin-bottom:16px;color:var(--text-secondary)}.confirm-list li{margin-bottom:8px;line-height:1.5;font-size:14px}.confirm-list li strong{color:var(--success)}.confirm-warning{background:#ef444426;color:var(--color-danger);padding:12px 16px;border-radius:8px;font-weight:600;text-align:center;margin:0;border:1px solid var(--color-danger)}.backup-info-box{background:var(--bg-tertiary);border:1px solid var(--color-border);border-radius:8px;padding:16px;margin:16px 0}.backup-info-box p{margin:8px 0;font-size:14px;color:var(--text-secondary)}.backup-info-box p:first-child{margin-top:0}.backup-info-box p:last-child{margin-bottom:0}.backup-info-box strong{color:var(--text-primary)}@media (max-width: 768px){.tabs{gap:4px;padding:4px}.tab{padding:8px 12px;font-size:13px}.cleanup-grid{grid-template-columns:1fr;gap:16px}.backup-item{flex-direction:column;align-items:flex-start;gap:12px}.backup-actions{width:100%;justify-content:flex-end}.modal{width:95%;margin:8px}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}@media (max-width: 480px){.page-header h1{font-size:1.5rem}.card-body,.cleanup-content{padding:16px}.cleanup-item{padding:10px}.backup-meta{flex-direction:column;gap:4px}}.auto-disable-form{display:flex;flex-direction:column;gap:24px}.toggle-group{display:flex;flex-direction:column;gap:12px}.toggle-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s;font-size:1rem;color:var(--color-text-secondary)}.toggle-btn:hover{border-color:var(--color-primary)}.toggle-btn.active{background:#10b9811a;border-color:var(--color-success);color:var(--color-success)}.toggle-btn svg{color:var(--color-text-muted)}.toggle-btn.active svg{color:var(--color-success)}.form-hint{font-size:.875rem;color:var(--color-text-muted);margin-top:6px}.auto-disable-preview{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;padding:16px}.auto-disable-preview h4{margin:0 0 12px;color:var(--color-text-primary);font-size:1rem}.preview-box{background:var(--color-bg-secondary);border-radius:6px;padding:12px}.preview-box p{margin:8px 0;font-size:.875rem;color:var(--color-text-secondary)}.preview-box strong{color:var(--color-text-primary)}.form-actions{display:flex;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--color-border)}.alert{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;margin-bottom:16px}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--color-success)}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--color-danger)}.alert .btn-close{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;opacity:.6}.alert .btn-close:hover{opacity:1}.loading-state{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px;color:var(--color-text-muted)}.about-section{display:flex;gap:32px;margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border-color)}.about-logo{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-radius:16px;border:1px solid rgba(99,102,241,.2);min-width:200px}.about-logo svg{color:var(--color-primary)}.about-logo h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;text-align:center}.version-badge{background:linear-gradient(135deg,var(--color-primary),#8b5cf6);color:#fff;padding:6px 16px;border-radius:20px;font-size:.875rem;font-weight:600;margin:0}.about-info{flex:1;display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color)}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-secondary);font-weight:500}.info-value{color:var(--text-primary);font-weight:600;text-align:right}.tech-stack{margin-bottom:32px}.tech-stack h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 16px}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.tech-item{display:flex;flex-direction:column;gap:4px;padding:12px 16px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.tech-name{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.tech-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.about-footer{text-align:center;padding-top:24px;border-top:1px solid var(--border-color)}.about-footer p{margin:0 0 4px;color:var(--text-secondary);font-size:.875rem}.about-footer .copyright{color:var(--text-muted);font-size:.75rem}.update-tab{padding:0}.upload-update-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.upload-update-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.file-upload-area{margin-top:16px}.file-input{display:none}.file-upload-label{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--color-primary);color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.file-upload-label:hover{background:var(--color-primary-hover)}.update-result{margin-top:16px;padding:12px 16px;border-radius:6px;background:var(--bg-tertiary)}.update-result.success{border-left:4px solid var(--color-success)}.update-result.error{border-left:4px solid var(--color-danger)}.update-result.success .result-header{color:var(--color-success)}.update-result.error .result-header{color:var(--color-danger)}.updates-list-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:16px}.updates-list{display:flex;flex-direction:column;gap:12px}.update-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid var(--color-border);border-radius:8px;background:var(--bg-tertiary)}.update-info{flex:1;min-width:0}.update-name{font-weight:500;color:var(--text-primary);margin-bottom:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;word-break:break-all}.update-meta{display:flex;gap:16px;font-size:12px;color:var(--text-secondary);flex-wrap:wrap}.update-date{color:var(--text-secondary)}.update-size{color:var(--text-primary);font-weight:500}.update-actions{display:flex;gap:8px;flex-shrink:0}@media (max-width: 768px){.update-item{flex-direction:column;align-items:flex-start;gap:12px}.update-actions{width:100%;justify-content:flex-end}}.restart-tab{padding:0}.restart-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.restart-section h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.restart-result{margin-top:16px;padding:12px 16px;border-radius:6px;background:var(--bg-tertiary)}.restart-result.success{border-left:4px solid var(--color-success)}.restart-result.error{border-left:4px solid var(--color-danger)}.restart-result.success .result-header{color:var(--color-success)}.restart-result.error .result-header{color:var(--color-danger)}.restart-info{margin-top:8px;font-size:.875rem;color:var(--text-secondary)}.btn-warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn-warning:hover:not(:disabled){background:#d97706}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 60px);background:var(--bg-primary);margin:0;border-radius:0;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:10px}.chat-header-left h1{font-size:1rem;font-weight:600;margin:0;color:var(--text-primary)}.chat-subtitle{font-size:.7rem;color:var(--text-muted);display:block}.chat-header-actions{display:flex;gap:6px}.header-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.header-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.header-btn.active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent)}.header-btn.danger:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.chat-status-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted)}.status-item{display:flex;align-items:center;gap:6px}.retry-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;transition:all .2s}.retry-btn:hover{background:var(--bg-hover);color:var(--accent)}.status-message-success{color:var(--success)}.status-message-error{color:var(--danger)}.status-message-warning{color:var(--warning)}.status-message-info{color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success)}.status-dot.pulse{animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.chat-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);text-align:center;padding:20px}.chat-welcome svg{margin-bottom:12px;opacity:.5}.chat-welcome h2{font-size:1.1rem;margin:0 0 6px;color:var(--text-primary)}.chat-welcome p{font-size:.85rem;margin:0 0 16px}.welcome-features{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.feature{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-tertiary);border-radius:12px;font-size:.75rem}.message{max-width:92%;animation:fadeIn .2s ease}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message.error .message-content{background:var(--danger-bg)!important;color:var(--danger)!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.message-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.message-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-secondary)}.message.user .message-avatar{background:var(--accent-bg);color:var(--accent)}.message-meta{display:flex;flex-direction:column}.message-role{font-size:.75rem;font-weight:600;color:var(--text-primary)}.message-time{font-size:.65rem;color:var(--text-muted)}.copy-btn{margin-left:auto;padding:4px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;opacity:0;transition:all .2s}.message:hover .copy-btn{opacity:1}.copy-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.message-content{padding:10px 12px;border-radius:14px;line-height:1.5;font-size:.9rem;word-break:break-word}.message.user .message-content{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-content{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px}.message-content pre{margin:8px 0;border-radius:6px;overflow:hidden}.reasoning-content{padding:8px 12px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:8px;font-size:.85rem;color:var(--text-muted);font-style:italic}.reasoning-toggle{background:none;border:none;color:var(--warning);font-size:.75rem;cursor:pointer;padding:0;margin-right:6px}.reasoning-toggle:hover{text-decoration:underline}.reasoning-hint{padding:4px 8px;font-size:.75rem;color:var(--text-muted);font-style:italic;margin-bottom:4px;opacity:.7}.reasoning-label{font-weight:600;color:var(--warning);margin-right:6px}.text-content{word-break:break-word}.message-content code{font-family:Fira Code,monospace;font-size:.85em}.cursor{animation:blink .8s infinite;color:var(--accent)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.system-message{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 10px;border-radius:6px;font-size:.75rem;max-width:95%;align-self:center}.system-message span:first-child{flex:1}.sys-time{font-size:.65rem;color:var(--text-muted);white-space:nowrap}.system-message.info{background:var(--info-bg);color:var(--info)}.system-message.success{background:var(--success-bg);color:var(--success)}.system-message.warning{background:var(--warning-bg);color:var(--warning)}.system-message.error{background:var(--danger-bg);color:var(--danger)}.routing-log{margin-top:6px;padding:6px 8px;background:var(--bg-tertiary);border-radius:6px;border:1px dashed var(--border-color)}.routing-header{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}.routing-attempt{display:flex;align-items:center;gap:6px;padding:4px 6px;border-radius:4px;font-size:.75rem;margin-bottom:2px}.routing-attempt.success{background:var(--success-bg);color:var(--success)}.routing-attempt.failed{background:var(--danger-bg);color:var(--danger)}.attempt-num{font-weight:600;min-width:20px}.attempt-provider{flex:1}.attempt-status svg{width:12px;height:12px}.chat-input-area{padding:12px;background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.input-wrapper{display:flex;align-items:flex-end;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:6px 10px;transition:border-color .2s}.input-wrapper:focus-within{border-color:var(--accent)}.input-wrapper textarea{flex:1;border:none;background:transparent;resize:none;padding:4px 0;font-size:.9rem;color:var(--text-primary);line-height:1.4;max-height:100px;font-family:inherit}.input-wrapper textarea::placeholder{color:var(--text-muted)}.input-wrapper textarea:focus{outline:none}.send-btn{padding:6px 10px;background:var(--accent);border:none;color:#fff;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}.send-btn:hover:not(:disabled){filter:brightness(1.1)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.stop-btn{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:8px;width:100%;padding:8px;background:var(--danger-bg);border:none;color:var(--danger);border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.stop-btn:hover{background:var(--danger);color:#fff}@media (min-width: 768px){.chat-container{margin:16px;border-radius:16px;height:calc(100vh - 100px)}.message{max-width:75%}}:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--container-padding: 1.5rem;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}@media (min-width: 640px){:root{--container-padding: 2rem}}@media (min-width: 768px){:root{--container-padding: 2.5rem}}@media (min-width: 1024px){:root{--container-padding: 3rem}}@media (min-width: 1280px){:root{--container-padding: 4rem}}.container{width:100%;max-width:var(--container-xl);margin:0 auto;padding:var(--container-padding)}.container-sm{max-width:var(--container-sm)}.container-md{max-width:var(--container-md)}.container-lg{max-width:var(--container-lg)}.container-xl{max-width:var(--container-xl)}.grid{display:grid;gap:var(--space-6)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-5{grid-template-columns:repeat(5,1fr)}.grid-cols-6{grid-template-columns:repeat(6,1fr)}@media (min-width: 768px){.grid-cols-md-1{grid-template-columns:repeat(1,1fr)}.grid-cols-md-2{grid-template-columns:repeat(2,1fr)}.grid-cols-md-3{grid-template-columns:repeat(3,1fr)}.grid-cols-md-4{grid-template-columns:repeat(4,1fr)}.grid-cols-md-5{grid-template-columns:repeat(5,1fr)}.grid-cols-md-6{grid-template-columns:repeat(6,1fr)}}@media (min-width: 1024px){.grid-cols-lg-1{grid-template-columns:repeat(1,1fr)}.grid-cols-lg-2{grid-template-columns:repeat(2,1fr)}.grid-cols-lg-3{grid-template-columns:repeat(3,1fr)}.grid-cols-lg-4{grid-template-columns:repeat(4,1fr)}.grid-cols-lg-5{grid-template-columns:repeat(5,1fr)}.grid-cols-lg-6{grid-template-columns:repeat(6,1fr)}}.flex{display:flex}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.flex-1{flex:1}.flex-grow{flex-grow:1}.flex-shrink{flex-shrink:1}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-1{padding-left:var(--space-1);padding-right:var(--space-1)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-5{padding-left:var(--space-5);padding-right:var(--space-5)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-5{padding-top:var(--space-5);padding-bottom:var(--space-5)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-5{margin:var(--space-5)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.mx-1{margin-left:var(--space-1);margin-right:var(--space-1)}.mx-2{margin-left:var(--space-2);margin-right:var(--space-2)}.mx-3{margin-left:var(--space-3);margin-right:var(--space-3)}.mx-4{margin-left:var(--space-4);margin-right:var(--space-4)}.mx-5{margin-left:var(--space-5);margin-right:var(--space-5)}.mx-6{margin-left:var(--space-6);margin-right:var(--space-6)}.mx-8{margin-left:var(--space-8);margin-right:var(--space-8)}.my-1{margin-top:var(--space-1);margin-bottom:var(--space-1)}.my-2{margin-top:var(--space-2);margin-bottom:var(--space-2)}.my-3{margin-top:var(--space-3);margin-bottom:var(--space-3)}.my-4{margin-top:var(--space-4);margin-bottom:var(--space-4)}.my-5{margin-top:var(--space-5);margin-bottom:var(--space-5)}.my-6{margin-top:var(--space-6);margin-bottom:var(--space-6)}.my-8{margin-top:var(--space-8);margin-bottom:var(--space-8)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.font-thin{font-weight:100}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-black{font-weight:900}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-primary-50{color:rgba(var(--primary-rgb),.05)}.text-primary-100{color:rgba(var(--primary-rgb),.1)}.text-primary-200{color:rgba(var(--primary-rgb),.2)}.text-primary-300{color:rgba(var(--primary-rgb),.3)}.text-primary-400{color:rgba(var(--primary-rgb),.4)}.text-primary-500{color:rgba(var(--primary-rgb),.5)}.text-primary-600{color:rgba(var(--primary-rgb),.6)}.text-primary-700{color:rgba(var(--primary-rgb),.7)}.text-primary-800{color:rgba(var(--primary-rgb),.8)}.text-primary-900{color:rgba(var(--primary-rgb),.9)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.bg-card{background-color:var(--bg-card)}.bg-hover{background-color:var(--bg-hover)}.bg-input{background-color:var(--bg-input)}.bg-surface{background-color:var(--surface)}.bg-surface-hover{background-color:var(--surface-hover)}.bg-success{background-color:var(--success)}.bg-warning{background-color:var(--warning)}.bg-danger{background-color:var(--danger)}.bg-transparent{background-color:transparent}.border-primary{border-color:var(--primary)}.border-secondary{border-color:var(--bg-secondary)}.border-tertiary{border-color:var(--bg-tertiary)}.border-card{border-color:var(--bg-card)}.border-hover{border-color:var(--bg-hover)}.border-input{border-color:var(--bg-input)}.border-surface{border-color:var(--surface)}.border-surface-hover{border-color:var(--surface-hover)}.border-success{border-color:var(--success)}.border-warning{border-color:var(--warning)}.border-danger{border-color:var(--danger)}.border-transparent{border-color:transparent}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-none{box-shadow:none}.rounded-none{border-radius:0}.rounded-sm{border-radius:.125rem}.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.border{border-width:1px;border-style:solid}.border-0{border:none}.border-2{border-width:2px;border-style:solid}.border-4{border-width:4px;border-style:solid}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.visible{visibility:visible}.invisible{visibility:hidden}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.w-full{width:100%}.w-auto{width:auto}.w-screen{width:100vw}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.max-w-full{max-width:100%}.max-w-screen-sm{max-width:640px}.max-w-screen-md{max-width:768px}.max-w-screen-lg{max-width:1024px}.max-w-screen-xl{max-width:1280px}.min-h-screen{min-height:100vh}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.cursor-wait{cursor:wait}.cursor-text{cursor:text}.cursor-move{cursor:move}.cursor-not-allowed{cursor:not-allowed}.select-none{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.select-text{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.resize-none{resize:none}.resize-y{resize:vertical}.resize-x{resize:horizontal}.resize{resize:both}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.card-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.btn{padding:.5rem 1rem;border-radius:var(--radius);border:none;cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-border-light)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:var(--color-success-dark)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-dark)}.btn-warning{background:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background:var(--color-warning-dark)}.badge{padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.badge-success{background:#10b98126;color:var(--color-success);border:1px solid rgba(16,185,129,.2)}.badge-warning{background:#f59e0b26;color:var(--color-warning);border:1px solid rgba(245,158,11,.2)}.badge-danger{background:#ef444426;color:var(--color-danger);border:1px solid rgba(239,68,68,.2)}.badge-info{background:#3b82f626;color:var(--color-primary);border:1px solid rgba(59,130,246,.2)}.input{width:100%;padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.875rem;transition:all var(--transition-fast);box-sizing:border-box}.input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #3b82f61a}.input::placeholder{color:var(--color-text-muted)}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.375rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.grid{display:grid;gap:1.25rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.table-container{overflow-x:auto;width:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:1.25rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-header{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.modal-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius);transition:all var(--transition-fast)}.modal-close:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.modal-body{padding:1.25rem}.modal-footer{padding:.75rem 1.25rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.75rem}.modal-large{max-width:800px;width:95%}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.5rem}.status-online{background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.status-offline{background:var(--color-danger)}.status-warning{background:var(--color-warning)}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-text-muted);gap:1rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
