.sidebar{background-color:var(--color-bg-sidebar);border-right:1px solid var(--color-border);height:100vh;left:0;position:fixed;top:0;width:276px;z-index:100}.sidebar,.sidebar-profile{display:flex;flex-direction:column}.sidebar-profile{align-items:center;border-bottom:1px solid var(--color-border);padding:var(--spacing-xl) var(--spacing-lg)}.profile-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary-light),var(--color-accent));border-radius:50%;display:flex;height:80px;justify-content:center;margin-bottom:var(--spacing-md);overflow:hidden;width:80px}.avatar-placeholder{font-size:3rem}.profile-name{color:var(--color-text-secondary);font-size:.95rem;font-weight:500}.sidebar-nav{flex:1 1;overflow-y:auto;padding:var(--spacing-lg) 0}.sidebar-nav-bottom{border-top:1px solid var(--color-border);flex:0 1;padding:var(--spacing-md) 0}.nav-item{align-items:center;background:#0000;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:.95rem;padding:var(--spacing-md) var(--spacing-lg);text-align:left;text-decoration:none;transition:all .2s;width:100%}.nav-item:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item-active{background-color:var(--color-primary-light);border-left:3px solid var(--color-accent);color:var(--color-text-primary);font-weight:500}.nav-icon{display:inline-block;font-size:1.2rem;margin-right:var(--spacing-md);text-align:center;width:24px}.nav-label{flex:1 1}.nav-item-logout{color:var(--color-text-muted)}.nav-item-logout:hover{background-color:#f443361a;color:#f44336}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.dashboard-page{animation:fadeIn .3s ease-in-out;margin:0 auto;max-width:1600px;padding:var(--spacing-xl)}.period-selector{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs)}.period-button{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.9rem;font-weight:500;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s}.period-button:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.period-button-active{background:linear-gradient(135deg,var(--color-accent),#6ba9ed);color:#fff}.health-banner{align-items:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.health-indicator{align-items:center;display:flex;gap:var(--spacing-md)}.status-dot{border-radius:50%;display:inline-block;height:12px;width:12px}.status-healthy{background-color:var(--color-risk-low);box-shadow:0 0 8px var(--color-risk-low)}.status-warning{background-color:var(--color-risk-medium);box-shadow:0 0 8px var(--color-risk-medium)}.status-error{background-color:var(--color-risk-high);box-shadow:0 0 8px var(--color-risk-high)}.health-text{color:var(--color-text-primary);font-size:1.1rem;font-weight:600}.health-providers{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.provider-status{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.9rem;gap:var(--spacing-sm)}.metrics-grid{grid-gap:var(--spacing-lg);animation:slideInUp .4s ease-out;display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:var(--spacing-2xl)}.metric-card{align-items:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg);transition:all .2s}.metric-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.metric-icon{align-items:center;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-md);display:flex;font-size:2.5rem;height:60px;justify-content:center;width:60px}.metric-content{flex:1 1}.metric-value{color:var(--color-text-primary);font-size:1.75rem;font-weight:700;line-height:1.2}.metric-label{color:var(--color-text-secondary);font-size:.875rem;margin-top:var(--spacing-xs)}.performance-section{margin-bottom:var(--spacing-2xl)}.section-title{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-lg)}.performance-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.perf-card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center}.perf-label{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:var(--spacing-sm)}.perf-value{color:var(--color-accent);font-size:1.5rem;font-weight:700}.daily-stats-section{margin-bottom:var(--spacing-2xl)}.table-container{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto}.stats-table{border-collapse:collapse;width:100%}.stats-table thead{background-color:var(--color-primary-dark);border-bottom:2px solid var(--color-border)}.stats-table th{color:var(--color-text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.5px;text-align:left;text-transform:uppercase}.stats-table td,.stats-table th{padding:var(--spacing-md) var(--spacing-lg)}.stats-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.stats-table tbody tr:hover{background-color:var(--color-bg-hover)}.stats-table tbody tr:last-child td{border-bottom:none}.text-warning{color:var(--color-risk-medium);font-weight:600}.loading-state{min-height:400px}.project-card{background-color:var(--color-bg-card);border:1px solid #0000;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);cursor:pointer;padding:var(--spacing-lg);transition:all .2s}.project-card:hover{border-color:var(--color-border);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.project-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.last-update{font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.last-update,.menu-button{color:var(--color-text-muted)}.menu-button{align-items:center;background:#0000;border-radius:var(--radius-sm);display:flex;font-size:1.5rem;height:32px;justify-content:center;line-height:1;padding:var(--spacing-xs);width:32px}.menu-button:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.project-title{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-md)}.providers-section{background-color:var(--color-bg-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.providers-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.providers-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.provider-badge{align-items:center;border-radius:.5rem;display:inline-flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s}.provider-badge:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.provider-ga{background:linear-gradient(135deg,#ff6b35,#ff8c42);box-shadow:0 2px 4px #ff6b354d;color:#fff}.provider-gtm{background:linear-gradient(135deg,#4285f4,#5e9ff5);box-shadow:0 2px 4px #4285f44d;color:#fff}.provider-gtags{background:linear-gradient(135deg,#34a853,#57bb6e);box-shadow:0 2px 4px #34a8534d;color:#fff}.project-info-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr);margin-bottom:var(--spacing-lg)}.info-section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.info-value{color:var(--color-text-primary);font-size:.875rem}.team-avatars{display:flex;gap:-8px}.avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border:2px solid var(--color-bg-card);border-radius:50%;color:#fff;display:flex;font-size:.875rem;font-weight:600;height:36px;justify-content:center;margin-left:-8px;overflow:hidden;width:36px}.avatar:first-child{margin-left:0}.avatar img{height:100%;object-fit:cover;width:100%}.avatar-more{background:var(--color-bg-hover);color:var(--color-text-secondary);font-size:.75rem}.risk-badge,.stage-badge{border-radius:1rem;display:inline-block;font-size:.875rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.stage-badge-development{background-color:#2196f326;border:1px solid #2196f34d;color:#64b5f6}.stage-badge-staging{background-color:#9c27b026;border:1px solid #9c27b04d;color:#ba68c8}.stage-badge-production{background-color:#4caf5026;border:1px solid #4caf504d;color:#81c784}.stage-badge-archived{background-color:#75757526;border:1px solid #7575754d;color:#bdbdbd}.risk-badge-low{background-color:#4caf5026;border:1px solid #4caf504d;color:#81c784}.risk-badge-medium{background-color:#ff980026;border:1px solid #ff98004d;color:#ffb74d}.risk-badge-high{background-color:#f4433626;border:1px solid #f443364d;color:#e57373}.risk-badge-critical{background-color:#d32f2f26;border:1px solid #d32f2f4d;color:#ef5350}.metrics-summary{border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-lg);padding-top:var(--spacing-lg)}.metric{display:flex;flex-direction:column;gap:var(--spacing-xs)}.metric-value{color:var(--color-accent);font-size:1.125rem;font-weight:600}.metric-label{color:var(--color-text-muted);font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.modal-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.modal-header h2{color:#1e3a8a;font-size:24px;font-weight:600;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.close-button:hover{background:#f3f4f6;color:#1f2937}.project-form{padding:24px}.error-banner{background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b;padding:12px 16px}.error-banner,.form-group{margin-bottom:20px}.form-group label{margin-bottom:8px}.required{color:#dc2626}.form-group input[type=text],.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.form-group input[type=text]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.provider-checkboxes{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:8px}.checkbox-label{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background .2s}.checkbox-label:hover{background:#f9fafb}.checkbox-label input[type=checkbox]{cursor:pointer}.checkbox-label span{color:#4b5563;font-size:13px;text-transform:capitalize}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.button{border:none;border-radius:6px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.button:disabled{cursor:not-allowed;opacity:.5}.button-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.button-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.button-primary{background:#1e3a8a;color:#fff}.button-primary:hover:not(:disabled){background:#1e40af;box-shadow:0 2px 8px #1e3a8a4d}@media (max-width:640px){.modal-content{border-radius:0;max-height:100vh;max-width:100%}.form-row,.provider-checkboxes{grid-template-columns:1fr}}.registry-page{animation:fadeIn .3s ease-in-out;margin:0 auto;max-width:1600px;padding:var(--spacing-xl)}.page-header{flex-wrap:wrap;gap:var(--spacing-lg);justify-content:space-between;margin-bottom:var(--spacing-2xl)}.page-title{color:var(--color-text-primary);font-size:2rem;font-weight:600}.header-actions{gap:var(--spacing-md)}.header-actions,.search-container{align-items:center;display:flex}.search-icon{color:var(--color-text-muted);left:var(--spacing-md)}.search-input{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.95rem;min-width:250px;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 2.5rem;transition:all .2s}.search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #4a90e21a}.search-input::placeholder{color:var(--color-text-muted)}.filter-button{align-items:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);display:flex;font-size:.95rem;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);transition:all .2s}.filter-button:hover{background-color:var(--color-bg-hover);border-color:var(--color-accent);color:var(--color-text-primary)}.add-button{align-items:center;background:linear-gradient(135deg,var(--color-accent),#6ba9ed);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:#fff;display:flex;font-size:.95rem;font-weight:500;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);transition:all .2s}.add-button:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.add-button:active{transform:translateY(0)}.projects-container{min-height:400px}.projects-grid{grid-gap:var(--spacing-lg);animation:slideInUp .4s ease-out;display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(420px,1fr))}@media (max-width:1400px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}}@media (max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}}.loading-state{color:var(--color-text-secondary)}.empty-state,.loading-state{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-lg);justify-content:center;padding:var(--spacing-2xl)}.empty-state{text-align:center}.empty-icon{font-size:5rem;opacity:.3}.empty-state h2{color:var(--color-text-primary);font-size:1.5rem;margin:0}.empty-state p{color:var(--color-text-secondary);margin:0;max-width:400px}.empty-state .add-button{margin-top:var(--spacing-md)}.project-config-page{margin:0 auto;max-width:1200px;padding:2rem}.page-header{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.page-header h1{color:#1a1a1a;font-size:2rem;font-weight:600;margin:0}.back-button{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.back-button:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.alert{align-items:center;border-radius:8px;display:flex;font-size:.95rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.alert-icon{font-size:1.25rem}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.alert-warning{background:#fefce8;border:1px solid #fde68a;color:#854d0e}.config-sections{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}.config-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.config-section h2{color:#1a1a1a;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.section-description{color:#6b7280;font-size:.9rem;margin-bottom:1.5rem}.populate-button{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:background .2s}.populate-button:hover:not(:disabled){background:#2563eb}.populate-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{color:#374151;display:block;font-size:.95rem;margin-bottom:.5rem}.form-input{border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;padding:.75rem 1rem;transition:all .2s;width:100%}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-hint{color:#6b7280;display:block;font-size:.85rem;margin-top:.5rem}.provider-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.provider-checkbox{align-items:center;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .2s}.provider-checkbox:hover{background:#f9fafb;border-color:#3b82f6}.provider-checkbox input[type=checkbox]{cursor:pointer;height:18px;width:18px}.provider-label{color:#374151;font-size:.9rem;font-weight:500}.project-metadata{display:flex;flex-direction:column;gap:1rem}.metadata-row{border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.75rem 0}.metadata-row:last-child{border-bottom:none}.metadata-label{color:#6b7280;font-size:.9rem;font-weight:500}.metadata-value{color:#1a1a1a;font-size:.9rem;text-align:right}.action-buttons{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;padding-top:2rem}.cancel-button,.save-button{border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 2rem;transition:all .2s}.cancel-button{background:#fff;border:1px solid #d1d5db;color:#6b7280}.cancel-button:hover:not(:disabled){background:#f9fafb;color:#374151}.save-button{background:#3b82f6}.save-button:hover:not(:disabled){background:#2563eb}.cancel-button:disabled,.save-button:disabled{cursor:not-allowed;opacity:.6}.error-state,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.spinner{animation:spin .8s linear infinite;border:4px solid #e5e7eb;border-top-color:#3b82f6;height:48px;width:48px}.error-state p,.loading-state p{color:#6b7280;font-size:.95rem;margin-top:1rem}.error-state h2{color:#dc2626;font-size:1.5rem;margin-bottom:1rem}@media (max-width:768px){.project-config-page{padding:1rem}.page-header,.section-header{align-items:flex-start;flex-direction:column}.section-header{gap:1rem}.provider-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column-reverse}.cancel-button,.save-button{width:100%}}.jobs-page{display:flex;flex-direction:column;height:100%;max-width:100%;padding:2rem}.jobs-header{margin-bottom:1.5rem}.jobs-header h1{color:#1a1a1a;font-size:2rem;font-weight:600;margin:0 0 .5rem}.jobs-subtitle{color:#666;font-size:.95rem;margin:0}.jobs-dashboard-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;flex:1 1;margin-bottom:2rem;min-height:600px;overflow:hidden}.jobs-dashboard-frame{border:none;display:block;height:100%;min-height:600px;width:100%}.jobs-info{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:2rem}.info-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;text-align:center}.info-icon{font-size:2.5rem;margin-bottom:.75rem}.info-card h3{color:#1a1a1a;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.info-card p{color:#666;font-size:.9rem;line-height:1.5;margin:0}@media (max-width:768px){.jobs-page{padding:1rem}.jobs-header h1{font-size:1.5rem}.jobs-dashboard-container,.jobs-dashboard-frame{min-height:500px}.jobs-info{gap:1rem;grid-template-columns:1fr}}@media (prefers-color-scheme:dark){.jobs-header h1{color:#f0f0f0}.jobs-subtitle{color:#b0b0b0}.jobs-dashboard-container{background:#1a1a1a;border-color:#333}.info-card{background:#2a2a2a;border-color:#333}.info-card h3{color:#f0f0f0}.info-card p{color:#b0b0b0}}.connector-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:12px;min-height:200px;padding:20px;position:relative;transition:all .2s ease}.connector-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.connector-card-header{align-items:center;display:flex;justify-content:space-between}.connector-icon{font-size:32px;line-height:1}.auth-badge{background:#fef3c7;border-radius:6px;cursor:help;font-size:16px;padding:4px 8px}.connector-name{color:#111827;font-size:18px;font-weight:600;line-height:1.4;margin:0}.connector-category{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.connector-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#4b5563;display:-webkit-box;flex-grow:1;font-size:14px;line-height:1.5;margin:0;overflow:hidden}.connector-footer{align-items:center;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-top:auto;padding-top:8px}.connector-package{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:6px;overflow:hidden}.package-icon{flex-shrink:0;font-size:14px}.package-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.connector-link{flex-shrink:0;font-size:18px;text-decoration:none;transition:transform .2s ease}.connector-link:hover{transform:scale(1.2)}.env-vars-indicator{align-items:center;background:#f3f4f6;border-radius:6px;color:#6b7280;cursor:help;display:flex;font-size:12px;gap:6px;padding:6px 10px;width:-webkit-fit-content;width:fit-content}.env-icon{font-size:14px}.env-count{font-weight:500}@media (max-width:768px){.connector-card{min-height:180px;padding:16px}.connector-name{font-size:16px}.connector-description{font-size:13px}}.connector-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.connector-modal{animation:slideUp .3s ease-out;background:#1a1a1a;background:var(--bg-primary,#1a1a1a);border-radius:12px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:900px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.connector-modal-header{align-items:center;border-bottom:1px solid #333;border-bottom:1px solid var(--border-color,#333);display:flex;flex-shrink:0;justify-content:space-between;padding:24px 28px}.modal-title-section{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.connector-modal-header h2{color:#fff;color:var(--text-primary,#fff);font-size:24px;font-weight:600;margin:0}.modal-category{background:#3b82f6;background:var(--accent-color,#3b82f6);border-radius:20px;color:#fff;display:inline-block;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.modal-close-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#888;color:var(--text-secondary,#888);cursor:pointer;display:flex;flex-shrink:0;font-size:32px;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.modal-close-btn:hover{background:#ffffff1a;color:#fff;color:var(--text-primary,#fff)}.connector-modal-content{flex:1 1;overflow-y:auto;padding:28px}.modal-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.modal-loading .spinner{animation:spin 1s linear infinite;border:4px solid #ffffff1a;border-radius:50%;border-top:4px solid var(--accent-color,#3b82f6);height:48px;width:48px}.modal-loading p{color:#888;color:var(--text-secondary,#888);font-size:14px}.modal-error{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444;display:flex;gap:12px;padding:20px}.error-icon{font-size:24px}.markdown-content{color:#e5e5e5;color:var(--text-primary,#e5e5e5);font-size:15px;line-height:1.7}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{color:#fff;color:var(--text-primary,#fff);font-weight:600;line-height:1.3;margin-bottom:16px;margin-top:28px}.markdown-content h1{border-bottom:1px solid #333;border-bottom:1px solid var(--border-color,#333);font-size:28px;padding-bottom:12px}.markdown-content h2{border-bottom:1px solid #ffffff1a;font-size:24px;padding-bottom:10px}.markdown-content h3{font-size:20px}.markdown-content h4{font-size:18px}.markdown-content p{margin-bottom:16px}.markdown-content a{color:#3b82f6;color:var(--accent-color,#3b82f6);text-decoration:none;transition:color .2s ease}.markdown-content a:hover{color:#60a5fa;color:var(--accent-hover,#60a5fa);text-decoration:underline}.markdown-content code{background:#ffffff14;border-radius:4px;color:#e879f9;font-family:Monaco,Courier New,monospace;font-size:.9em;padding:2px 6px}.markdown-content pre{background:#0d1117;border:1px solid #ffffff1a;border-radius:8px;margin:16px 0;overflow-x:auto;padding:16px}.markdown-content pre code{background:#0000;color:inherit;font-size:14px;padding:0}.markdown-content ol,.markdown-content ul{margin-bottom:16px;padding-left:28px}.markdown-content li{margin-bottom:8px}.markdown-content blockquote{border-left:4px solid #3b82f6;border-left:4px solid var(--accent-color,#3b82f6);color:#888;color:var(--text-secondary,#888);font-style:italic;margin:16px 0;padding-left:16px}.markdown-content table{border-collapse:collapse;font-size:14px;margin:20px 0;width:100%}.markdown-content table td,.markdown-content table th{border:1px solid #333;border:1px solid var(--border-color,#333);padding:10px 12px;text-align:left}.markdown-content table th{background:#ffffff0d;color:#fff;color:var(--text-primary,#fff);font-weight:600}.markdown-content table tr:hover{background:#ffffff08}.markdown-content hr{border:none;border-top:1px solid #333;border-top:1px solid var(--border-color,#333);margin:28px 0}.markdown-content img{border-radius:8px;height:auto;margin:16px 0;max-width:100%}.connector-modal-footer{align-items:center;border-top:1px solid #333;border-top:1px solid var(--border-color,#333);display:flex;flex-shrink:0;flex-wrap:wrap;gap:16px;padding:20px 28px}.footer-badge{align-items:center;background:#ffffff0d;border-radius:20px;color:#aaa;color:var(--text-secondary,#aaa);display:flex;font-size:13px;gap:8px;padding:8px 14px}.badge-icon{font-size:16px}.footer-link{align-items:center;background:#3b82f6;background:var(--accent-color,#3b82f6);border-radius:20px;color:#fff;display:flex;font-size:13px;font-weight:500;gap:6px;margin-left:auto;padding:8px 14px;text-decoration:none;transition:all .2s ease}.footer-link:hover{background:#60a5fa;background:var(--accent-hover,#60a5fa);transform:translateY(-1px)}@media (max-width:768px){.connector-modal{margin:10px;max-height:95vh}.connector-modal-header{padding:20px}.connector-modal-header h2{font-size:20px}.connector-modal-content{padding:20px}.markdown-content{font-size:14px}.markdown-content h1{font-size:24px}.markdown-content h2{font-size:20px}.connector-modal-footer{padding:16px 20px}}.connector-modal-content::-webkit-scrollbar{width:10px}.connector-modal-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}.connector-modal-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:10px}.connector-modal-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}
/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{background:#0d1117;color:#c9d1d9}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#79c0ff}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-code,.hljs-comment,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{background-color:#033a16;color:#aff5b4}.hljs-deletion{background-color:#67060c;color:#ffdcd7}.connectors-page{margin:0 auto;max-width:1400px;padding:32px}.connectors-header{align-items:flex-start;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.header-content h1{color:#111827;font-size:32px;font-weight:700;margin:0 0 8px}.subtitle{color:#6b7280;font-size:16px;margin:0}.connectors-count{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;color:#fff;display:flex;flex-direction:column;padding:16px 24px}.count-number{font-size:36px;font-weight:700;line-height:1}.count-label{font-size:14px;font-weight:500;margin-top:4px;opacity:.9}.connectors-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:32px}.search-container{flex:1 1;max-width:400px;min-width:250px;position:relative}.search-icon{font-size:18px;left:16px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{border:2px solid #e5e7eb;border-radius:10px;font-size:15px;padding:12px 40px 12px 48px;transition:all .2s ease;width:100%}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.clear-search{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;padding:0;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .2s ease;width:24px}.clear-search:hover{color:#ef4444}.filter-container{align-items:center;display:flex;gap:12px}.filter-label{color:#4b5563;font-size:14px;font-weight:500;white-space:nowrap}.category-select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;font-size:15px;min-width:180px;padding:12px 40px 12px 16px;transition:all .2s ease}.category-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.category-select:hover{border-color:#9ca3af}.clear-filters-btn{background:#fff;border:2px solid #e5e7eb;border-radius:10px;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s ease;white-space:nowrap}.clear-filters-btn:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.connectors-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:32px}.no-results{background:#f9fafb;border-radius:16px;margin-bottom:32px;padding:80px 32px;text-align:center}.no-results-icon{font-size:64px;margin-bottom:16px;opacity:.5}.no-results h3{color:#111827;font-size:24px;font-weight:600;margin:0 0 8px}.no-results p{color:#6b7280;font-size:16px;margin:0 0 24px}.reset-btn{background:#3b82f6;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s ease}.reset-btn:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.info-banner{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-left:4px solid #3b82f6;border-radius:12px;display:flex;gap:20px;padding:24px}.info-icon{flex-shrink:0;font-size:32px}.info-content h3{color:#1e40af;font-size:18px;font-weight:600;margin:0 0 8px}.info-content p{color:#1e40af;font-size:14px;line-height:1.6;margin:0}@media (max-width:1024px){.connectors-grid{gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.connectors-page{padding:20px}.connectors-header{flex-direction:column;gap:20px}.connectors-count{align-self:flex-start}.header-content h1{font-size:28px}.connectors-controls{align-items:stretch;flex-direction:column}.clear-filters-btn,.filter-container,.search-container{max-width:none;width:100%}.filter-container{align-items:stretch;flex-direction:column;gap:8px}.category-select{width:100%}.connectors-grid{gap:16px;grid-template-columns:1fr}.info-banner{flex-direction:column;text-align:center}.info-icon{align-self:center}}.auth-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-container{max-width:450px;width:100%}.auth-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;padding:40px}.auth-header{margin-bottom:32px;text-align:center}.auth-header h1{color:#1a202c;font-size:28px;font-weight:600;margin:0 0 8px}.auth-header p{color:#718096;font-size:14px;margin:0}.auth-error{align-items:center;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c53030;display:flex;font-size:14px;gap:8px;margin-bottom:24px;padding:12px 16px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-hint{color:#718096;font-size:12px}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;margin-top:8px;padding:12px 24px;transition:transform .2s,box-shadow .2s;width:100%}.auth-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{cursor:not-allowed;opacity:.6}.auth-footer{margin-top:24px;text-align:center}.auth-footer p{color:#718096;font-size:14px;margin:0}.auth-footer a{color:#667eea;font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}@media (max-width:480px){.auth-card{padding:32px 24px}.auth-header h1{font-size:24px}}.profile-page{margin:0 auto;max-width:800px;padding:40px 20px}.profile-container{display:flex;flex-direction:column;gap:24px}.profile-header h1{color:#1a202c;font-size:32px;font-weight:600;margin:0 0 8px}.profile-header p{color:#718096;font-size:16px;margin:0}.profile-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.profile-section{padding:32px}.profile-section h2{color:#1a202c;font-size:20px;font-weight:600;margin:0 0 24px}.profile-divider{background:#e2e8f0;height:1px}.info-row{align-items:center;border-bottom:1px solid #f7fafc;display:flex;justify-content:space-between;padding:16px 0}.info-row:last-child{border-bottom:none}.info-row label{color:#4a5568;font-size:14px;font-weight:500}.info-value{align-items:center;color:#1a202c;display:flex;font-size:14px;gap:8px}.info-value.mono{color:#718096;font-family:Monaco,Courier New,monospace;font-size:12px}.badge{background:#c6f6d5;border-radius:4px;color:#22543d;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;text-transform:uppercase}.profile-success{background:#c6f6d5;border:1px solid #9ae6b4;border-radius:8px;color:#22543d}.profile-error,.profile-success{font-size:14px;margin-bottom:20px;padding:12px 16px}.profile-error{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c53030}.profile-form{gap:20px}.form-group,.profile-form{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{color:#2d3748;font-size:14px;font-weight:500}.form-group input{border:1px solid #e2e8f0;border-radius:8px;font-size:15px;padding:12px 16px;transition:all .2s}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.save-button{align-self:flex-start;background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.save-button:hover:not(:disabled){background:#5568d3;transform:translateY(-1px)}.save-button:disabled{cursor:not-allowed;opacity:.6}.signout-button{background:#fff;border:1px solid #e53e3e;border-radius:8px;color:#e53e3e;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.signout-button:hover{background:#fff5f5;transform:translateY(-1px)}@media (max-width:768px){.profile-page{padding:20px 16px}.profile-section{padding:24px 20px}.info-row{align-items:flex-start;flex-direction:column;gap:8px}}:root{--color-primary:#1e3a5f;--color-primary-dark:#152a45;--color-primary-light:#2d4f75;--color-secondary:#3b5f8f;--color-accent:#4a90e2;--color-bg-main:#1a2332;--color-bg-card:#243447;--color-bg-sidebar:#1e2838;--color-bg-hover:#2d3f54;--color-text-primary:#fff;--color-text-secondary:#b0c4d9;--color-text-muted:#7a8fa6;--color-risk-low:#4caf50;--color-risk-medium:#ff9800;--color-risk-high:#f44336;--color-risk-critical:#d32f2f;--color-stage-development:#2196f3;--color-stage-staging:#9c27b0;--color-stage-production:#4caf50;--color-stage-archived:#757575;--color-border:#334155;--color-divider:#2d3f54;--color-shadow:#0000004d;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0006,0 10px 10px -5px #0000000a;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-mono:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,"Courier New",monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-sans);height:100%}body{background-color:#1a2332;background-color:var(--color-bg-main);color:#fff;color:var(--color-text-primary);line-height:1.5}#root{height:100%}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin-bottom:1rem;margin-bottom:var(--spacing-md)}a{color:#4a90e2;color:var(--color-accent);text-decoration:none;transition:color .2s}a:hover{color:#6ba9ed}button{border:none;cursor:pointer;font-family:inherit;outline:none;transition:all .2s}button:disabled{cursor:not-allowed;opacity:.5}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#1a2332;background:var(--color-bg-main)}::-webkit-scrollbar-thumb{background:#2d4f75;background:var(--color-primary-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3b5f8f;background:var(--color-secondary)}.text-muted{color:#7a8fa6;color:var(--color-text-muted)}.text-secondary{color:#b0c4d9;color:var(--color-text-secondary)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex-center{align-items:center;display:flex;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.animate-fade-in{animation:fadeIn .3s ease-in-out}.animate-slide-up{animation:slideInUp .3s ease-out}.animate-slide-right{animation:slideInRight .3s ease-out}.spinner{animation:spin 1s linear infinite;border:3px solid #334155;border-top:3px solid #4a90e2;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-accent);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-container{background-color:var(--color-bg-main);display:flex;height:100vh;overflow:hidden;width:100%}.main-content{flex:1 1;margin-left:276px;min-height:100vh;overflow-y:auto}.placeholder-page{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:var(--spacing-xl)}.placeholder-content{max-width:500px;text-align:center}.placeholder-icon{font-size:5rem;margin-bottom:var(--spacing-lg);opacity:.5}.placeholder-content h1{color:var(--color-text-primary);font-size:2rem;margin-bottom:var(--spacing-md)}.placeholder-content p{color:var(--color-text-secondary);font-size:1.125rem;margin-bottom:0}@media (max-width:768px){.main-content{margin-left:0}.sidebar{transform:translateX(-100%);transition:transform .3s}.sidebar.sidebar-open{transform:translateX(0)}}
/*# sourceMappingURL=main.15410741.css.map*/