@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--cp-magenta: #B61F7E;--cp-magenta-dark: #902367;--cp-magenta-light: #D43399;--cp-magenta-subtle: #F7E6F1;--cp-teal: #00395A;--cp-teal-dark: #002940;--cp-teal-light: #005580;--cp-teal-subtle: #E6EEF2;--primary-color: #B61F7E;--primary-dark: #902367;--primary-light: #D43399;--primary-subtle: #F7E6F1;--secondary-color: #00395A;--secondary-dark: #002940;--secondary-light: #005580;--danger-color: #E63946;--danger-dark: #C42935;--success-color: #06D6A0;--success-dark: #05B387;--warning-color: #FFB703;--warning-dark: #E6A502;--info-color: #00395A;--navy-900: #0A1929;--navy-800: #132F4C;--navy-700: #1E4976;--navy-600: #2D5F8D;--gray-900: #0F1419;--gray-800: #1A1F28;--gray-700: #2D3748;--gray-600: #4A5568;--gray-500: #718096;--gray-400: #A0AEC0;--gray-300: #CBD5E0;--gray-200: #E2E8F0;--gray-100: #F7FAFC;--text-primary: #1A202C;--text-secondary: #4A5568;--text-muted: #718096;--text-inverse: #FFFFFF;--surface-base: #FAFBFC;--surface-elevated: #FFFFFF;--surface-overlay: rgba(10, 25, 41, .92);--surface-glass: rgba(255, 255, 255, .95);--border-color: #E2E8F0;--border-subtle: #EDF2F7;--divider-color: rgba(226, 232, 240, .6);--shadow-xs: 0 1px 2px 0 rgba(10, 25, 41, .05);--shadow-sm: 0 1px 3px 0 rgba(10, 25, 41, .08), 0 1px 2px 0 rgba(10, 25, 41, .04);--shadow-md: 0 4px 6px -1px rgba(10, 25, 41, .08), 0 2px 4px -1px rgba(10, 25, 41, .04);--shadow-lg: 0 10px 15px -3px rgba(10, 25, 41, .08), 0 4px 6px -2px rgba(10, 25, 41, .04);--shadow-xl: 0 20px 25px -5px rgba(10, 25, 41, .08), 0 10px 10px -5px rgba(10, 25, 41, .04);--shadow-2xl: 0 25px 50px -12px rgba(10, 25, 41, .15);--sidebar-width: 280px;--header-height: 72px;--border-radius-sm: 6px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--transition-fast: .12s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:IBM Plex Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:var(--font-size-sm);font-weight:400;line-height:1.6;color:var(--text-primary);background:var(--surface-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}::-webkit-scrollbar{width:14px;height:14px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#b61f7e33;border-radius:10px;border:3px solid transparent;background-clip:padding-box;transition:all var(--transition-base)}::-webkit-scrollbar-thumb:hover{background:#b61f7e66;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:active{background:#b61f7e99}*{scrollbar-width:auto;scrollbar-color:rgba(182,31,126,.3) transparent}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,var(--cp-teal) 0%,var(--cp-teal-dark) 100%);color:var(--text-inverse);position:fixed;top:0;left:0;bottom:0;overflow-y:auto;border-right:1px solid rgba(255,255,255,.06);box-shadow:var(--shadow-xl);z-index:100;display:flex;flex-direction:column}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:180px;background:radial-gradient(ellipse at top left,rgba(182,31,126,.2) 0%,transparent 60%);pointer-events:none}.sidebar-header{padding:28px 24px;border-bottom:1px solid rgba(255,255,255,.08);position:relative;z-index:1;display:flex;align-items:center;justify-content:center}.sidebar-header-logo{max-width:100%;height:auto;max-height:48px;opacity:.95;transition:opacity var(--transition-base)}.sidebar-header-logo:hover{opacity:1}.sidebar-nav{padding:20px 16px;position:relative;z-index:1;flex:1;display:flex;flex-direction:column}.sidebar-nav .sidebar-logo{margin-top:auto;padding-top:24px}.nav-item{display:flex;align-items:center;padding:9px 16px;margin-bottom:3px;color:#e8f0f7;text-decoration:none;border-radius:var(--border-radius-md);transition:all var(--transition-base);position:relative;overflow:hidden;font-weight:500;font-size:var(--font-size-sm)}.nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-color);transform:scaleY(0);transition:transform var(--transition-base)}.nav-item:hover{background:#ffffff1f;color:#fff;transform:translate(2px)}.nav-item.active{background:#b61f7e40;color:#fff;box-shadow:0 2px 8px #b61f7e4d}.nav-item.active:before{transform:scaleY(1)}.nav-icon{width:34px;height:34px;margin-right:12px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);font-weight:700;font-family:JetBrains Mono,monospace;color:#fff;transition:all var(--transition-base);flex-shrink:0}.nav-icon svg{flex-shrink:0}.nav-item:hover .nav-icon{background:#ffffff2e;color:#fff;transform:scale(1.05)}.nav-item.active .nav-icon{background:var(--cp-magenta);color:#fff;box-shadow:0 4px 12px #b61f7e66}.nav-label{flex:1;letter-spacing:-.01em}.sidebar-footer{padding:20px 24px 24px;border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:1;margin-top:auto;display:flex;flex-direction:column;gap:16px}.sidebar-logo{display:flex;align-items:center;justify-content:center;padding:16px 8px}.sidebar-logo img{max-width:140px;height:auto;opacity:.75;transition:opacity var(--transition-base)}.sidebar-logo img:hover{opacity:.95}.sidebar-version{display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:#ffffff0f;border-radius:var(--border-radius-md);border:1px solid rgba(255,255,255,.08)}.version-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#a8c5d8;font-family:JetBrains Mono,monospace}.version-value{font-size:var(--font-size-sm);font-weight:600;color:#e8f0f7;font-family:JetBrains Mono,monospace;letter-spacing:-.01em}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.app-header{height:var(--header-height);background:var(--surface-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 32px;position:sticky;top:0;z-index:90;box-shadow:var(--shadow-sm);gap:24px}.header-title{min-width:150px;font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.header-user{display:flex;align-items:center;gap:16px;padding:8px 16px;border-radius:var(--border-radius-lg);background:var(--surface-elevated);border:1px solid var(--border-subtle);transition:all var(--transition-base);flex-shrink:0}.header-user:hover{box-shadow:var(--shadow-sm);border-color:var(--border-color)}.user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);letter-spacing:-.01em}.header-actions{display:flex;gap:12px;align-items:center}.page-content{padding:32px;flex:1;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background:var(--surface-elevated);cursor:pointer;font-family:IBM Plex Sans,sans-serif;font-size:var(--font-size-sm);font-weight:500;letter-spacing:-.01em;transition:all var(--transition-base);position:relative;overflow:hidden;white-space:nowrap}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-base)}.btn:hover:before{opacity:1}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:var(--gray-400)}.btn:active{transform:translateY(0);box-shadow:none}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn:disabled:hover{box-shadow:none;border-color:var(--border-color)}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);border-color:transparent;color:#fff;font-weight:600;box-shadow:0 2px 8px #06f3}.btn-primary:hover{box-shadow:0 4px 16px #0066ff4d;border-color:transparent}.btn-danger{background:linear-gradient(135deg,var(--danger-color) 0%,var(--danger-dark) 100%);border-color:transparent;color:#fff;font-weight:600;box-shadow:0 2px 8px #e6394633}.btn-danger:hover{box-shadow:0 4px 16px #e639464d;border-color:transparent}.btn-sm{padding:6px 12px;font-size:var(--font-size-xs)}.btn-text{border:none;background:transparent;color:var(--text-secondary);box-shadow:none}.btn-text:hover{background:var(--gray-100);color:var(--text-primary);box-shadow:none}.btn-block{width:100%}.form-group{margin-bottom:28px;position:relative}.form-group label{display:block;margin-bottom:10px;font-weight:600;font-size:var(--font-size-sm);color:var(--text-primary);letter-spacing:-.01em}.form-group label.checkbox-label,.form-group label.radio-label,.form-group label.toggle-label{margin-bottom:0}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=number],.form-group input[type=url],.form-group textarea{width:100%;padding:14px 18px;border:2px solid var(--border-color);border-radius:var(--border-radius-md);font-family:IBM Plex Sans,sans-serif;font-size:var(--font-size-sm);color:var(--text-primary);background:var(--surface-elevated);transition:all var(--transition-base);position:relative}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);font-weight:400}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--cp-magenta);box-shadow:0 0 0 4px #b61f7e14;background:#fff}.form-group input:hover:not(:focus),.form-group textarea:hover:not(:focus){border-color:var(--gray-500)}.form-group select{width:100%;padding:14px 44px 14px 18px;border:2px solid var(--border-color);border-radius:var(--border-radius-md);font-family:IBM Plex Sans,sans-serif;font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);background:var(--surface-elevated);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234A5568' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:12px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:all var(--transition-base)}.form-group select:focus{outline:none;border-color:var(--cp-magenta);box-shadow:0 0 0 4px #b61f7e14;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23B61F7E' d='M6 8L2 4h8z'/%3E%3C/svg%3E")}.form-group select:hover:not(:focus){border-color:var(--gray-500);background-color:var(--gray-100)}.checkbox-label{display:flex!important;align-items:flex-start;gap:14px;cursor:pointer;position:relative;padding:4px 0;-webkit-user-select:none;user-select:none;margin-bottom:0!important;width:fit-content;max-width:100%}.checkbox-label input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0;margin:0}.checkbox-custom{position:relative;width:22px;height:22px;background:var(--surface-elevated);border:2px solid var(--border-color);border-radius:6px;transition:all var(--transition-base);flex-shrink:0;display:block;margin-top:1px}.checkbox-custom:after{content:"";position:absolute;width:5px;height:10px;border:solid white;border-width:0 2.5px 2.5px 0;transform:rotate(45deg) scale(0);transition:transform var(--transition-spring);top:50%;left:50%;margin-top:-6px;margin-left:-2px}.checkbox-label:hover .checkbox-custom{border-color:var(--cp-magenta);background:#b61f7e0d}.checkbox-label input[type=checkbox]:checked~.checkbox-custom{background:linear-gradient(135deg,var(--cp-magenta) 0%,var(--cp-magenta-dark) 100%);border-color:var(--cp-magenta);box-shadow:0 2px 8px #b61f7e4d}.checkbox-label input[type=checkbox]:checked~.checkbox-custom:after{transform:rotate(45deg) scale(1)}.checkbox-label input[type=checkbox]:focus~.checkbox-custom{box-shadow:0 0 0 4px #b61f7e26}.checkbox-label>span:not(.checkbox-custom){font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);letter-spacing:-.01em;line-height:1.6;flex:1;display:inline-block;min-width:0}.checkbox-wrapper{margin-bottom:20px}.checkbox-description{display:block;font-size:var(--font-size-xs);color:var(--text-muted);margin-left:36px;margin-top:4px;line-height:1.5}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background:var(--gray-100);color:var(--text-muted);cursor:not-allowed;opacity:.6}.checkbox-label input[type=checkbox]:disabled~.checkbox-custom{background:var(--gray-100);border-color:var(--gray-300);cursor:not-allowed;opacity:.6}.checkbox-label input[type=checkbox]:disabled~span{color:var(--text-muted);cursor:not-allowed}.radio-label{display:flex;align-items:center;gap:12px;cursor:pointer;position:relative;padding:8px 0;-webkit-user-select:none;user-select:none}.radio-label input[type=radio]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.radio-custom{position:relative;width:22px;height:22px;background:var(--surface-elevated);border:2px solid var(--border-color);border-radius:50%;transition:all var(--transition-base);flex-shrink:0;display:flex;align-items:center;justify-content:center}.radio-custom:after{content:"";width:10px;height:10px;border-radius:50%;background:#fff;transform:scale(0);transition:transform var(--transition-spring)}.radio-label:hover .radio-custom{border-color:var(--cp-magenta);background:#b61f7e0d}.radio-label input[type=radio]:checked~.radio-custom{background:linear-gradient(135deg,var(--cp-magenta) 0%,var(--cp-magenta-dark) 100%);border-color:var(--cp-magenta);box-shadow:0 2px 8px #b61f7e4d}.radio-label input[type=radio]:checked~.radio-custom:after{transform:scale(1)}.radio-label input[type=radio]:focus~.radio-custom{box-shadow:0 0 0 4px #b61f7e26}.radio-label span{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);letter-spacing:-.01em}.toggle-label{display:flex;align-items:center;gap:12px;cursor:pointer;position:relative;padding:8px 0;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.toggle-switch{position:relative;width:48px;height:26px;background:var(--gray-300);border-radius:13px;transition:all var(--transition-base);flex-shrink:0}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:all var(--transition-spring);box-shadow:0 2px 4px #0003}.toggle-label:hover .toggle-switch{background:var(--gray-400)}.toggle-label input[type=checkbox]:checked~.toggle-switch{background:linear-gradient(135deg,var(--cp-magenta) 0%,var(--cp-magenta-dark) 100%);box-shadow:0 2px 8px #b61f7e4d}.toggle-label input[type=checkbox]:checked~.toggle-switch:after{transform:translate(22px)}.toggle-label input[type=checkbox]:focus~.toggle-switch{box-shadow:0 0 0 4px #b61f7e26}.toggle-label span{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);letter-spacing:-.01em}.form-group-inline{display:flex;gap:24px;flex-wrap:wrap}.input-with-icon{position:relative}.input-with-icon input{padding-left:44px}.input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:18px;pointer-events:none}.input-with-icon input:focus~.input-icon{color:var(--cp-magenta)}.table-container{background:var(--surface-elevated);border-radius:var(--border-radius-lg);overflow:hidden;border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table th,.data-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--border-subtle)}.data-table th{background:var(--gray-100);font-weight:600;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);position:sticky;top:0;z-index:10}.data-table tbody tr{transition:all var(--transition-base);position:relative}.data-table tbody tr:hover{background:var(--primary-subtle);cursor:pointer}.data-table tbody tr:hover td{color:var(--text-primary)}.data-table tr:last-child td{border-bottom:none}.data-table td{font-size:var(--font-size-sm);color:var(--text-secondary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:16px;font-size:var(--font-size-xs);font-weight:600;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.03em;background:var(--gray-200);color:var(--gray-700);border:1px solid transparent}.badge.active{background:#06d6a01a;color:var(--success-dark);border-color:#06d6a033}.badge.inactive{background:#e639461a;color:var(--danger-dark);border-color:#e6394633}.badge.admin{background:#0066ff1a;color:var(--primary-dark);border-color:#06f3}.badge.running{background:#ffb7031a;color:var(--warning-dark);border-color:#ffb70333}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--surface-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--border-radius-xl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-2xl);animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:24px 28px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-muted);line-height:1;transition:all var(--transition-base);padding:4px;border-radius:var(--border-radius-sm)}.modal-close:hover{color:var(--text-primary);background:var(--gray-100);transform:rotate(90deg)}.modal-body{padding:28px}.modal-actions{padding:20px 28px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:12px;background:var(--gray-100)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--cp-teal-dark) 0%,var(--cp-teal) 50%,#004566 100%);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(182,31,126,.2) 0%,transparent 70%);top:-200px;right:-200px;animation:float 20s ease-in-out infinite}.login-page:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(182,31,126,.15) 0%,transparent 70%);bottom:-100px;left:-100px;animation:float 25s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}.login-card{background:var(--surface-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--border-radius-xl);padding:48px;width:100%;max-width:440px;box-shadow:var(--shadow-2xl);position:relative;z-index:1;animation:slideUp .6s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-header h1{font-size:var(--font-size-3xl);font-weight:700;letter-spacing:-.02em;margin-bottom:8px;background:linear-gradient(135deg,var(--text-primary) 0%,var(--gray-600) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:var(--text-muted);font-size:var(--font-size-sm);font-weight:500}.login-footer{margin-top:28px;padding-top:28px;border-top:1px solid var(--border-subtle);text-align:center;color:var(--text-muted);font-size:var(--font-size-xs)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--border-radius-lg);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-sm);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--cp-magenta) 0%,var(--cp-magenta-light) 100%);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--cp-magenta)}.stat-card:hover:before{transform:scaleX(1)}.stat-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--cp-magenta-subtle) 0%,rgba(182,31,126,.12) 100%);border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;font-family:JetBrains Mono,monospace;color:var(--cp-magenta);flex-shrink:0;transition:all var(--transition-base)}.stat-card:hover .stat-icon{transform:scale(1.05) rotate(-5deg)}.stat-content{flex:1}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px;font-family:JetBrains Mono,monospace}.stat-label{color:var(--text-muted);font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-trend{font-size:11px;font-weight:600;margin-top:6px;display:flex;align-items:center;gap:4px}.stat-trend.positive{color:var(--success-color)}.stat-trend.negative{color:var(--danger-color)}.stat-trend.neutral{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:10px}.dashboard-actions{display:flex;align-items:center;gap:16px}.last-updated{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500}.alerts-container{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.alert-banner{display:flex;align-items:flex-start;gap:16px;padding:16px 20px;border-radius:var(--border-radius-lg);border-left:4px solid;background:var(--surface-elevated);box-shadow:var(--shadow-sm);animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.alert-banner.warning{border-left-color:var(--warning-color);background:#ffb7030d}.alert-banner.info{border-left-color:var(--info-color);background:#00395a0d}.alert-icon{font-size:20px;flex-shrink:0}.alert-content{flex:1}.alert-message{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);margin-bottom:4px}.alert-time{font-size:var(--font-size-xs);color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}.dashboard-main{display:flex;flex-direction:column;gap:24px}.dashboard-sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:calc(var(--header-height) + 32px)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-badge{font-size:10px;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--text-muted);padding:4px 8px;background:var(--gray-200);border-radius:4px;letter-spacing:.05em}.health-grid{display:flex;flex-direction:column;gap:20px;background:var(--surface-elevated);padding:24px;border-radius:var(--border-radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.health-metric{display:flex;flex-direction:column;gap:10px}.health-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary)}.health-bar{height:32px;background:var(--gray-200);border-radius:var(--border-radius-md);overflow:hidden;position:relative}.health-bar-fill{height:100%;background:linear-gradient(90deg,var(--cp-magenta) 0%,var(--cp-magenta-light) 100%);display:flex;align-items:center;justify-content:flex-end;padding:0 12px;font-size:var(--font-size-xs);font-weight:700;font-family:JetBrains Mono,monospace;color:#fff;transition:width .6s cubic-bezier(.4,0,.2,1)}.health-bar.success .health-bar-fill{background:linear-gradient(90deg,var(--success-color) 0%,var(--success-dark) 100%)}.health-info-display{height:32px;display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--gray-100);border-radius:var(--border-radius-md)}.health-info-value{font-size:18px;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--text-primary)}.health-info-label{font-size:var(--font-size-xs);color:var(--text-muted)}.quota-bar{position:relative;height:24px;background:var(--gray-200);border-radius:12px;overflow:hidden;min-width:100px}.quota-fill{position:absolute;top:0;left:0;bottom:0;background:linear-gradient(90deg,var(--cp-teal) 0%,var(--cp-teal-light) 100%);transition:width .4s ease-out}.quota-fill.warning{background:linear-gradient(90deg,var(--warning-color) 0%,var(--warning-dark) 100%)}.quota-text{position:relative;display:flex;align-items:center;justify-content:center;height:100%;font-size:11px;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--text-primary);z-index:1}.activity-feed{display:flex;flex-direction:column;gap:16px;background:var(--surface-elevated);padding:20px;border-radius:var(--border-radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.activity-item{display:flex;gap:14px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle);animation:fadeIn .4s ease-out backwards}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-item:nth-child(1){animation-delay:.05s}.activity-item:nth-child(2){animation-delay:.1s}.activity-item:nth-child(3){animation-delay:.15s}.activity-item:nth-child(4){animation-delay:.2s}.activity-item:nth-child(5){animation-delay:.25s}.activity-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-md);background:var(--gray-100);font-size:16px;flex-shrink:0}.activity-icon.deploy{background:#b61f7e1a}.activity-icon.create{background:#06d6a01a}.activity-icon.activate{background:#00395a1a}.activity-icon.update{background:#ffb7031a}.activity-icon.schedule{background:#457b9d1a}.activity-content{flex:1;min-width:0}.activity-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:4px}.activity-text strong{color:var(--text-primary);font-weight:600}.activity-text em{color:var(--cp-magenta);font-style:normal;font-weight:500}.activity-time{font-size:var(--font-size-xs);color:var(--text-muted)}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;background:var(--surface-elevated);padding:20px;border-radius:var(--border-radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px 12px;background:var(--surface-base);border:1px solid var(--border-color);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-base);font-family:IBM Plex Sans,sans-serif}.quick-action-btn:hover{background:var(--cp-magenta-subtle);border-color:var(--cp-magenta);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-icon{font-size:24px;filter:grayscale(30%)}.quick-action-btn:hover .action-icon{filter:grayscale(0%);transform:scale(1.1)}.action-label{font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary);text-align:center}.quick-action-btn:hover .action-label{color:var(--cp-magenta)}.project-name{font-weight:500;color:var(--text-primary)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{font-size:12px;color:var(--text-muted);text-transform:uppercase}.info-item span{font-weight:500}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:2px solid var(--border-subtle);position:sticky;top:72px;background:#fff;z-index:89;margin-left:-32px;margin-right:-32px;padding:20px 32px}.page-header h2{margin:0;font-size:var(--font-size-2xl);font-weight:700;letter-spacing:-.02em;color:var(--text-primary);position:relative;padding-left:16px}.page-header h2:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:28px;background:linear-gradient(180deg,var(--cp-magenta) 0%,var(--cp-magenta-light) 100%);border-radius:2px}.section{margin-bottom:32px}.section h3{margin-bottom:20px;font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.info-bar{display:flex;gap:8px;margin-bottom:16px;color:var(--text-muted);font-size:13px}.filters{display:flex;gap:16px;margin-bottom:16px;align-items:center}.search-input{padding:10px 16px 10px 40px;border:1px solid var(--border-color);border-radius:var(--border-radius-md);width:280px;font-family:IBM Plex Sans,sans-serif;font-size:var(--font-size-sm);background:var(--surface-elevated);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center;transition:all var(--transition-base)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0066ff1a;transform:translateY(-1px)}.search-input:hover:not(:focus){border-color:var(--gray-400)}.action-buttons{display:flex;gap:8px}.text-muted{color:var(--text-muted);font-size:12px}.text-center{text-align:center}.ml-2{margin-left:8px}.loading,.error{padding:40px;text-align:center}.error{color:var(--danger-color)}.alert{padding:12px 16px;border-radius:4px;margin-bottom:16px}.alert-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.loading-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-base)}.spinner{width:48px;height:48px;border:3px solid var(--border-subtle);border-top-color:var(--primary-color);border-right-color:var(--primary-light);border-radius:50%;animation:spin .8s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 4px 12px #0066ff1a}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{margin-top:20px;color:var(--text-muted);font-size:var(--font-size-sm);font-weight:500;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer}.checkbox-label input{width:auto}.project-config-page{height:100%}.project-config-layout{display:flex;gap:24px;align-items:flex-start}.project-config-content{flex:1;min-width:0}.project-config-sidebar{width:240px;flex-shrink:0;position:sticky;top:calc(var(--header-height) + 24px);max-height:calc(100vh - var(--header-height) - 48px);overflow-y:auto}.config-sidebar{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--border-radius-lg);padding:20px 0;box-shadow:var(--shadow-sm)}.config-nav-section{margin-bottom:28px}.config-nav-section:last-child{margin-bottom:0}.config-nav-category{font-size:var(--font-size-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;padding:12px 20px 10px;font-family:JetBrains Mono,monospace}.config-nav-items{display:flex;flex-direction:column;gap:2px;padding:0 12px}.config-nav-item{padding:10px 14px 10px 20px;color:var(--text-secondary);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-base);border-left:3px solid transparent;border-radius:var(--border-radius-md);display:block;position:relative}.config-nav-item:after{content:"";position:absolute;right:14px;top:50%;transform:translateY(-50%) rotate(-90deg);width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;opacity:0;transition:all var(--transition-base)}.config-nav-item:hover{background:var(--primary-subtle);color:var(--primary-color);transform:translate(2px)}.config-nav-item:hover:after{opacity:.5}.config-nav-item.active{background:var(--primary-subtle);color:var(--primary-color);border-left-color:var(--primary-color);font-weight:600}.config-nav-item.active:after{opacity:1}.config-tab{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.config-tab h3{margin-bottom:24px;font-size:20px}.config-tab h4{margin-bottom:16px;font-size:16px;color:var(--text-color)}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.tab-header h3{margin:0}.form-section{margin-bottom:40px;padding-bottom:32px;border-bottom:2px solid var(--border-subtle);position:relative}.form-section:before{content:"";position:absolute;bottom:-2px;left:0;width:60px;height:2px;background:linear-gradient(90deg,var(--cp-magenta) 0%,transparent 100%)}.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section:last-child:before{display:none}.form-section h4{margin-bottom:20px;font-size:var(--font-size-base);font-weight:700;color:var(--text-primary);letter-spacing:-.01em;display:flex;align-items:center;gap:10px}.form-section h4:before{content:"";width:4px;height:20px;background:linear-gradient(180deg,var(--cp-magenta) 0%,var(--cp-magenta-light) 100%);border-radius:2px}.form-section small,.form-helper{display:block;color:var(--text-muted);font-size:var(--font-size-xs);margin-top:6px;line-height:1.5}.form-helper-success{color:var(--success-color)}.form-helper-error{color:var(--danger-color);font-weight:500}.form-actions{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:8px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:var(--font-size-xs);font-weight:600;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.04em;border:1px solid transparent;transition:all var(--transition-base)}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block}.status-badge.active{background:#06d6a01f;color:var(--success-dark);border-color:#06d6a040}.status-badge.active:before{background:var(--success-color);box-shadow:0 0 6px #06d6a099}.status-badge.inactive{background:#e639461f;color:var(--danger-dark);border-color:#e6394640}.status-badge.inactive:before{background:var(--danger-color)}.status-badge.enabled{background:#0066ff1f;color:var(--primary-dark);border-color:#0066ff40}.status-badge.enabled:before{background:var(--primary-color);box-shadow:0 0 6px #06f9}.status-badge.disabled{background:var(--gray-200);color:var(--gray-600);border-color:var(--gray-300)}.status-badge.disabled:before{background:var(--gray-500)}.status-badge.pending{background:#ffb7031f;color:var(--warning-dark);border-color:#ffb70340}.status-badge.pending:before{background:var(--warning-color);animation:pulse 1.5s ease-in-out infinite}.usage-bar{margin-top:8px;margin-bottom:16px}.usage-bar-track{height:20px;background:#e9ecef;border-radius:4px;overflow:hidden;position:relative}.usage-bar-fill{height:100%;background:var(--primary-color);transition:width .3s;display:flex;align-items:center;justify-content:flex-end;padding:0 8px;font-size:11px;color:#fff;font-weight:600}.usage-bar-fill.warning{background:var(--warning-color)}.usage-bar-fill.danger{background:var(--danger-color)}.usage-info{display:flex;justify-content:space-between;margin-bottom:4px;font-size:12px}.usage-info span{color:var(--text-muted)}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;font-size:12px}.tag-remove{background:none;border:none;cursor:pointer;padding:0;font-size:16px;line-height:1;color:var(--text-muted);margin-left:4px}.tag-remove:hover{color:var(--danger-color)}.modal{background:#fff;border-radius:8px;padding:24px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0003}.modal h3{margin-bottom:20px;font-size:18px}.connection-status{display:inline-flex;align-items:center;gap:6px;font-size:12px}.connection-dot{width:8px;height:8px;border-radius:50%;background:var(--danger-color)}.connection-dot.connected{background:var(--success-color)}.nested-table{margin-top:8px;margin-left:24px;border-left:2px solid var(--border-color);padding-left:16px}.nested-table table{font-size:12px}.nested-table th,.nested-table td{padding:8px 12px}.file-input-wrapper{position:relative;display:inline-block}.file-input-label{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#fff;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s}.file-input-label:hover{background:var(--bg-color)}.file-input-wrapper.has-file .file-input-label{border-color:var(--primary-color);background:#e7f3ff}.drop-zone{border:2px dashed var(--border-color);border-radius:4px;padding:32px;text-align:center;transition:all .2s;cursor:pointer}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--primary-color);background:#f0f8ff}.drop-zone-icon{font-size:48px;color:var(--text-muted);margin-bottom:12px}.drop-zone-text{color:var(--text-muted);font-size:14px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:14px}.master-indicator{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#fff3cd;border-radius:4px;font-size:11px;font-weight:500;color:#856404}.readonly-field{background:var(--bg-color);color:var(--text-muted);cursor:not-allowed}.inline-actions{display:flex;gap:8px;align-items:center}.table-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.btn-small{padding:6px 12px;font-size:13px;border-radius:4px;font-weight:500;white-space:nowrap;transition:all .2s}.btn-small:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-small.btn-secondary{background:#fff;border-color:var(--border-color);color:var(--text-color)}.btn-small.btn-secondary:hover:not(:disabled){background:var(--bg-color);border-color:#999}.btn-small.btn-danger:hover:not(:disabled){background:#bd2130;box-shadow:0 2px 6px #dc35454d}.error-message{color:var(--danger-color);font-size:12px;margin-top:4px;padding:8px 12px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.data-table input[type=checkbox]{width:auto;cursor:pointer}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;cursor:pointer;animation:slideIn .3s ease-out;border-left:4px solid;transition:transform .2s,box-shadow .2s}.toast-clickable:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003,0 3px 6px #00000026}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:20px;font-weight:700;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.toast-message{flex:1;font-size:14px;line-height:1.4;color:#333}.toast-success{border-left-color:#28a745}.toast-success .toast-icon{background:#d4edda;color:#28a745}.toast-error{border-left-color:#dc3545}.toast-error .toast-icon{background:#f8d7da;color:#dc3545}.toast-warning{border-left-color:#ffc107}.toast-warning .toast-icon{background:#fff3cd;color:#856404}.toast-info{border-left-color:#17a2b8}.toast-info .toast-icon{background:#d1ecf1;color:#17a2b8}.tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid var(--border-color);position:sticky;top:148px;background:#fff;z-index:88;margin-left:-32px;margin-right:-32px;padding:16px 32px 0}.tab{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s;margin-bottom:-2px}.tab:hover{color:var(--primary-color);background:#007bff0d}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:600}.info-bar{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#f8f9fa;border-radius:6px;margin-bottom:20px;font-size:14px;color:#666}.info-bar span:not(:last-child):after{content:""}.module-row.clickable{cursor:pointer}.module-row.clickable:hover{background:#007bff08}.module-row.expanded{background:#f8f9fa}.module-components{background:#f8f9fa;border-top:1px solid var(--border-color)}.module-components td{padding:0!important}.components-list{padding:16px 20px}.component-item{display:flex;align-items:center;padding:8px 12px;background:#fff;border-radius:4px;margin-bottom:8px;font-size:13px}.component-item:last-child{margin-bottom:0}.component-name{flex:1;font-weight:500}.component-type{padding:2px 8px;background:#e9ecef;border-radius:3px;font-size:11px;margin-right:8px;color:#495057}.component-version{color:#6c757d;font-size:12px}.component-item.highlighted{animation:highlightPulse 2s ease-in-out 3;background:#007bff14!important}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.checkbox-label input[type=checkbox]{margin:0}.badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;margin-right:8px;margin-bottom:6px}.badge.system{background:#6c757d;color:#fff}.badge.active{background:#28a745;color:#fff}.badge.inactive{background:#6c757d;color:#fff}.file-input-wrapper{position:relative;display:inline-block;width:100%}.file-input-wrapper input[type=file]{position:absolute;left:-9999px}.file-input-label{display:flex;align-items:center;gap:16px;padding:10px 16px;background:#fff;border:2px dashed var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s;min-height:48px}.file-input-label:hover{border-color:var(--primary-color);background:#007bff05}.file-input-button{padding:6px 16px;background:var(--primary-color);color:#fff;border-radius:4px;font-size:14px;font-weight:500;flex-shrink:0;margin-right:8px}.file-input-text{flex:1;color:#6c757d;font-size:14px}.file-input-text.has-file{color:#333;font-weight:500}.search-bar{margin-bottom:16px;position:sticky;top:202px;background:#fff;z-index:87;margin-left:-32px;margin-right:-32px;padding:8px 32px 12px;border-bottom:1px solid var(--border-color)}.search-input-wrapper{position:relative;width:100%}.search-input{width:100%;padding:12px 40px 12px 16px;font-size:14px;border:1px solid var(--border-color);border-radius:6px;background:#fff;transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff1a}.search-input::placeholder{color:#999}.search-clear-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;font-size:18px;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s}.search-clear-btn:hover{color:#333}.module-row.highlighted{animation:highlightPulse 2s ease-in-out 3}@keyframes highlightPulse{0%,to{background-color:transparent}50%{background-color:#007bff14}}.data-table tbody tr:hover{background-color:#007bff0d}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1.5px solid;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);margin-right:6px;position:relative;background:#fff}.btn-icon:last-child{margin-right:0}.btn-icon:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #00000014}.btn-icon:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000000d}.btn-icon:disabled{opacity:.35;cursor:not-allowed;border-color:var(--gray-300);color:var(--gray-400);background:var(--gray-100)}.btn-icon-success{border-color:var(--success-color);color:var(--success-dark);background:linear-gradient(135deg,#06d6a014,#06d6a005)}.btn-icon-success:hover:not(:disabled){border-color:var(--success-dark);background:linear-gradient(135deg,#06d6a026,#06d6a00d);box-shadow:0 4px 12px #06d6a033}.btn-icon-success:active:not(:disabled){background:linear-gradient(135deg,#06d6a033,#06d6a014)}.btn-icon-danger{border-color:var(--danger-color);color:var(--danger-dark);background:linear-gradient(135deg,#e6394614,#e6394605);font-size:18px;font-weight:700}.btn-icon-danger:hover:not(:disabled){border-color:var(--danger-dark);background:linear-gradient(135deg,#e6394626,#e639460d);box-shadow:0 4px 12px #e6394633}.btn-icon-danger:active:not(:disabled){background:linear-gradient(135deg,#e6394633,#e6394614)}.btn-icon-warning{border-color:var(--warning-color);color:var(--warning-dark);background:linear-gradient(135deg,#ffb70314,#ffb70305);font-size:18px;font-weight:700}.btn-icon-warning:hover:not(:disabled){border-color:var(--warning-dark);background:linear-gradient(135deg,#ffb70326,#ffb7030d);box-shadow:0 4px 12px #ffb70333}.btn-icon-warning:active:not(:disabled){background:linear-gradient(135deg,#ffb70333,#ffb70314)}.btn-icon-disabled{border-color:var(--gray-300);color:var(--gray-400);background:var(--gray-100)}.btn-icon-disabled:disabled{opacity:.4}.coming-soon-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:linear-gradient(135deg,#ffb7031a,#ffb7030d);border:1.5px solid var(--warning-color);border-radius:6px;font-size:14px}.coming-soon-icon{font-size:18px}.coming-soon-content{display:flex;flex-direction:column;gap:2px}.coming-soon-feature{font-size:12px;color:var(--text-muted)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.server-metrics-bar{display:flex;align-items:center;justify-content:center;gap:1.25rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#00395a14,#00395a0a);border-radius:10px;border:1.5px solid rgba(0,57,90,.15);box-shadow:0 2px 8px #00395a0f;flex:1;min-width:0}.metrics-loading{font-size:13px;color:#4b5563;font-weight:500}.metrics-group{display:flex;align-items:center;gap:.625rem}.metrics-divider{width:2px;height:28px;background:linear-gradient(180deg,transparent 0%,rgba(0,57,90,.25) 50%,transparent 100%);border-radius:1px}.metric-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.04em;transition:all .2s ease;box-shadow:0 1px 3px #00000014;position:relative;cursor:pointer}.metric-badge:hover{transform:translateY(-1px);box-shadow:0 2px 6px #0000001f}.metric-tooltip{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);background:#fff;border:1.5px solid rgba(0,57,90,.15);border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:220px;animation:tooltipFadeIn .2s ease}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.metric-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#00395a26}.metric-tooltip:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-bottom-color:#fff;margin-bottom:-1px}.metric-tooltip-header{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.metric-tooltip-stats{display:flex;justify-content:space-between;gap:8px;margin-top:8px;font-size:10px;font-family:JetBrains Mono,monospace;color:#6b7280}.sparkline{display:block;width:100%;height:auto}.metric-label{color:inherit;opacity:.85;font-size:11px}.metric-value{font-weight:700;font-size:13px}.metric-badge-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border:1.5px solid #10b981}.metric-badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1.5px solid #f59e0b}.metric-badge-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;border:1.5px solid #ef4444}.metric-badge-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1.5px solid #3b82f6}.metric-badge-neutral{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#374151;border:1.5px solid #9ca3af}.metrics-uptime{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#ffffff80;border-radius:6px;border:1px solid rgba(0,57,90,.12)}.uptime-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.uptime-value{font-family:JetBrains Mono,monospace;font-weight:700;font-size:13px;color:#111827}.logs-page{display:flex;flex-direction:column;height:calc(100vh - var(--header-height));background:var(--surface-base)}.connection-error{color:var(--danger-color);font-size:var(--font-size-sm);font-weight:500}.connection-loading{color:var(--text-muted);font-size:var(--font-size-sm)}.log-controls{display:flex;align-items:center;gap:12px;padding:16px 24px;background:var(--surface-elevated);border-bottom:1px solid var(--border-color)}.log-control-select{height:32px;padding:0 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--surface-base);font-size:var(--font-size-sm);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast)}.log-control-select:hover{border-color:var(--primary-color)}.log-control-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #b61f7e1a}.log-search-wrapper{flex:1;min-width:200px}.log-search-input{width:100%;height:32px;padding:0 12px 0 32px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--surface-base);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:8px center;font-size:var(--font-size-sm);color:var(--text-primary);transition:border-color var(--transition-fast)}.log-search-input::placeholder{color:var(--text-muted)}.log-search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #b61f7e1a}.log-entry-count{padding:6px 12px;background:var(--gray-100);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:500}.log-control-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--surface-base);color:var(--text-secondary);font-size:16px;cursor:pointer;transition:all var(--transition-fast)}.log-control-btn:hover{border-color:var(--primary-color);background:var(--primary-subtle);color:var(--primary-color)}.log-control-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.log-entries-container{flex:1;overflow-y:auto;background:var(--surface-base)}.log-empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);font-size:var(--font-size-sm)}.log-entry{border-bottom:1px solid var(--border-subtle);padding:8px 24px;transition:background var(--transition-fast)}.log-entry:hover{background:#b61f7e05}.log-entry-expandable{cursor:pointer}.log-entry-main{display:flex;align-items:flex-start;gap:12px;font-size:var(--font-size-xs)}.log-expand-icon{flex-shrink:0;width:16px;color:var(--text-muted);font-size:10px}.log-timestamp{flex-shrink:0;width:140px;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:var(--font-size-xs)}.log-level-badge,.log-source-badge{flex-shrink:0;padding:2px 8px;border-radius:var(--border-radius-sm);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.log-level-debug{background:var(--gray-100);color:var(--gray-600)}.log-level-info{background:#e3f2fd;color:#1565c0}.log-level-warn{background:#fff3e0;color:#e65100}.log-level-error{background:#ffebee;color:#c62828}.log-level-fatal{background:#c62828;color:#fff;font-weight:700}.log-source-firstspirit{background:#e8f5e9;color:#2e7d32}.log-source-tomcat{background:#fff3e0;color:#ef6c00}.log-source-system{background:#f3e5f5;color:#6a1b9a}.log-logger{flex-shrink:0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:var(--font-size-xs)}.log-message{flex:1;word-break:break-word;font-family:JetBrains Mono,monospace;font-size:var(--font-size-xs);line-height:1.5}.log-message.log-level-debug{color:var(--text-muted)}.log-message.log-level-info{color:var(--text-primary)}.log-message.log-level-warn{color:#e65100}.log-message.log-level-error{color:#c62828}.log-message.log-level-fatal{color:#c62828;font-weight:600}.log-action-btn{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted);font-size:14px;cursor:pointer;opacity:0;transition:opacity var(--transition-fast)}.log-entry:hover .log-action-btn{opacity:1}.log-action-btn:hover{color:var(--primary-color)}.log-details{margin:12px 0 0 28px;padding:12px;background:var(--gray-100);border-left:3px solid var(--primary-color);border-radius:var(--border-radius-sm);font-family:JetBrains Mono,monospace;font-size:var(--font-size-xs);color:var(--text-secondary);white-space:pre-wrap;overflow-x:auto}.log-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--gray-100);border-top:1px solid var(--border-color);font-size:var(--font-size-xs);color:var(--text-muted)}
