.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-primary);bottom:0;display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:width var(--transition-normal);width:var(--sidebar-width);z-index:100}.sidebar.collapsed{width:72px}.sidebar-header{border-bottom:1px solid var(--border-primary);justify-content:space-between;min-height:var(--header-height);padding:var(--spacing-lg)}.logo,.sidebar-header{align-items:center;display:flex}.logo{gap:var(--spacing-sm)}.logo-icon{align-items:center;background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-cyan) 100%);border-radius:var(--radius-lg);color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.logo-text{color:var(--text-primary);font-size:var(--font-size-xl);font-weight:700;white-space:nowrap}.collapse-btn{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);display:flex;height:28px;justify-content:center;transition:all var(--transition-fast);width:28px}.collapse-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar.collapsed .collapse-btn{box-shadow:var(--shadow-md);position:absolute;right:-14px;top:50%;transform:translateY(-50%);z-index:10}.sidebar-section-label{color:var(--text-tertiary);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-sm)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:var(--spacing-sm)}.nav-item{align-items:center;border-radius:var(--radius-md);color:var(--text-secondary);display:flex;gap:var(--spacing-md);margin-bottom:4px;padding:var(--spacing-md);position:relative;transition:all var(--transition-fast)}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:#3b82f61a}.nav-item.active,.nav-item.active .nav-icon{color:var(--accent-blue-light)}.nav-icon{flex-shrink:0;height:24px;justify-content:center;width:24px}.nav-icon,.nav-label{align-items:center;display:flex}.nav-label{flex:1 1;font-size:var(--font-size-sm);font-weight:500;gap:6px;white-space:nowrap}.live-badge{animation:liveBlink 2s ease-in-out infinite;background:#ef444433;border:1px solid #ef444459;border-radius:4px;color:#f87171;font-size:9px;font-weight:800;letter-spacing:.08em;padding:1px 5px}@keyframes liveBlink{0%,to{opacity:1}50%{opacity:.5}}.active-indicator{background:var(--accent-blue);border-radius:0 var(--radius-sm) var(--radius-sm) 0;height:24px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-md)}.sidebar.collapsed .active-indicator{display:none}.sidebar-footer{border-top:1px solid var(--border-primary);padding:var(--spacing-md)}.user-profile{gap:var(--spacing-md);margin-bottom:var(--spacing-sm);padding:var(--spacing-sm)}.user-avatar,.user-profile{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#8b5cf6,#ec4899);border-radius:var(--radius-full);color:#fff;flex-shrink:0;font-size:var(--font-size-sm);font-weight:600;height:40px;justify-content:center;overflow:hidden;width:40px}.user-avatar img{height:100%;object-fit:cover;width:100%}.user-info{display:flex;flex-direction:column;overflow:hidden}.user-name{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{background:#3b82f626;border-radius:var(--radius-sm);color:var(--accent-blue);font-size:var(--font-size-xs);font-weight:500;margin-top:2px;padding:2px 8px;width:-webkit-fit-content;width:fit-content}.logout-btn{align-items:center;background:linear-gradient(135deg,#ef4444,#f97316);border-radius:var(--radius-md);color:#fff;display:flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-sm);justify-content:center;padding:var(--spacing-md);transition:all var(--transition-fast);width:100%}.logout-btn:hover{box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.sidebar.collapsed .user-profile{justify-content:center}.sidebar.collapsed .logout-btn span{display:none}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}}.header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);display:flex;height:var(--header-height);justify-content:space-between;left:var(--sidebar-width);padding:0 var(--spacing-xl);position:fixed;right:0;top:0;transition:left var(--transition-normal);z-index:50}.app.sidebar-collapsed .header{left:72px}.header-left{align-items:center;display:flex;gap:var(--spacing-lg)}.page-info{display:flex;flex-direction:column}.page-title{color:var(--text-primary);font-size:var(--font-size-xl);font-weight:700;line-height:1.2;margin:0}.page-subtitle{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0}.header-right{align-items:center;display:flex;gap:var(--spacing-lg)}.search-box{position:relative;width:280px}.search-icon{color:var(--text-tertiary);left:var(--spacing-md);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);height:40px;padding:0 var(--spacing-md) 0 40px;transition:all var(--transition-fast);width:100%}.search-input::placeholder{color:var(--text-tertiary)}.search-input:focus{background:var(--bg-card);border-color:var(--accent-blue);outline:none}.header-actions{align-items:center;display:flex;gap:var(--spacing-md)}.header-action-btn{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);display:flex;height:40px;justify-content:center;position:relative;transition:all var(--transition-fast);width:40px}.header-action-btn:hover{background:var(--bg-elevated);border-color:var(--border-accent);color:var(--text-primary)}.notification-badge{align-items:center;background:var(--severity-high);border-radius:var(--radius-full);color:#fff;display:flex;font-size:10px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 4px;position:absolute;right:-4px;top:-4px}.live-indicator{align-items:center;background:#22c55e26;border:1px solid #22c55e4d;border-radius:var(--radius-full);color:#22c55e;display:flex;font-size:var(--font-size-xs);font-weight:600;gap:var(--spacing-xs);padding:6px 12px}.live-indicator:before{animation:pulse 2s infinite;background:#22c55e;border-radius:var(--radius-full);content:"";height:6px;width:6px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@media (max-width:1024px){.header{left:0}.search-box{display:none}}@media (max-width:768px){.page-subtitle{display:none}}.button{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-weight:600;gap:var(--spacing-sm);justify-content:center;transition:all var(--transition-fast);white-space:nowrap}.button:disabled{cursor:not-allowed;opacity:.5}.button.sm{font-size:var(--font-size-xs);height:32px;padding:0 12px}.button.md{font-size:var(--font-size-sm);height:40px;padding:0 16px}.button.lg{font-size:var(--font-size-base);height:48px;padding:0 24px}.button.full-width{width:100%}.button.primary{background:linear-gradient(135deg,#ec4899,#8b5cf6);border:none;box-shadow:0 2px 8px #8b5cf64d;color:#fff}.button.primary:hover:not(:disabled){box-shadow:0 6px 20px #8b5cf666;transform:translateY(-1px)}.button.primary:active:not(:disabled){transform:translateY(0)}.button.secondary{background:var(--bg-tertiary);border:1px solid var(--border-secondary);color:var(--text-primary)}.button.secondary:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--border-accent)}.button.outline{background:#0000;border:1px solid var(--accent-blue);color:var(--accent-blue-light)}.button.outline:hover:not(:disabled){background:#3b82f61a}.button.ghost{background:#0000;border:none;color:var(--text-secondary)}.button.ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.button.danger{background:linear-gradient(135deg,#dc2626,#ef4444);border:none;color:#fff}.button.danger:hover:not(:disabled){box-shadow:0 4px 12px #ef444466}.button.success{background:linear-gradient(135deg,#16a34a,#22c55e);border:none;color:#fff}.button.success:hover:not(:disabled){box-shadow:0 4px 12px #22c55e66}.button.blue{background:var(--accent-blue);border:none;color:#fff}.button.blue:hover:not(:disabled){background:var(--accent-blue-light);box-shadow:0 4px 12px #3b82f666}.button-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:var(--radius-full);border-top-color:#fff;height:16px;width:16px}.button.icon-only{padding:0;width:40px}.button.icon-only.sm{width:32px}.button.icon-only.lg{width:48px}.gate-loading{align-items:center;display:flex;justify-content:center;min-height:60vh}.gate-spinner{animation:gateSpin .8s linear infinite;border:3px solid var(--border-secondary);border-radius:50%;border-top-color:var(--accent-blue);height:40px;width:40px}@keyframes gateSpin{to{transform:rotate(1turn)}}.gate-page{justify-content:center;min-height:70vh;padding:var(--spacing-xl)}.gate-card,.gate-page{align-items:center;display:flex}.gate-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:24px;border-radius:var(--radius-2xl,24px);box-shadow:0 24px 64px #0000004d;flex-direction:column;gap:var(--spacing-xl);max-width:480px;overflow:hidden;padding:3rem var(--spacing-2xl);position:relative;text-align:center;width:100%}.gate-card:before{background:radial-gradient(circle,#3b82f61f 0,#0000 70%);content:"";height:300px;left:50%;pointer-events:none;position:absolute;top:-60px;transform:translateX(-50%);width:300px}.gate-icon-wrap{align-items:center;background:linear-gradient(135deg,#3b82f626,#8b5cf626);border:1px solid #3b82f640;border-radius:50%;color:var(--accent-blue);display:flex;height:80px;justify-content:center;width:80px}.gate-title{color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:800;margin:0}.gate-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.6;margin:0}.gate-steps{flex-direction:column;text-align:left;width:100%}.gate-step,.gate-steps{display:flex;gap:var(--spacing-md)}.gate-step{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}.step-num{align-items:center;background:#3b82f626;border-radius:50%;color:var(--accent-blue);display:flex;flex-shrink:0;font-size:var(--font-size-xs);font-weight:800;height:26px;justify-content:center;width:26px}.kpi-card{align-items:flex-start;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;gap:var(--spacing-md);overflow:hidden;padding:var(--spacing-lg);position:relative;transition:all var(--transition-fast)}.kpi-card:before{content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity var(--transition-fast)}.kpi-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.kpi-card:hover:before{opacity:1}.kpi-card.blue:before{background:linear-gradient(90deg,var(--accent-blue) 0,var(--accent-cyan) 100%)}.kpi-card.blue .kpi-icon-wrapper{background:#3b82f626;color:var(--accent-blue-light)}.kpi-card.red:before{background:linear-gradient(90deg,#dc2626,#ef4444)}.kpi-card.red .kpi-icon-wrapper{background:var(--severity-high-bg);color:var(--severity-high)}.kpi-card.orange:before{background:linear-gradient(90deg,#ea580c,#f59e0b)}.kpi-card.orange .kpi-icon-wrapper{background:var(--severity-medium-bg);color:var(--severity-medium)}.kpi-card.green:before{background:linear-gradient(90deg,#16a34a,#22c55e)}.kpi-card.green .kpi-icon-wrapper{background:var(--severity-low-bg);color:var(--severity-low)}.kpi-card.cyan:before{background:linear-gradient(90deg,var(--accent-teal) 0,var(--accent-cyan) 100%)}.kpi-card.cyan .kpi-icon-wrapper{background:#22d3ee26;color:var(--accent-cyan)}.kpi-card.purple:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.kpi-card.purple .kpi-icon-wrapper{background:#8b5cf626;color:#a78bfa}.kpi-icon-wrapper{align-items:center;background:var(--bg-elevated);border-radius:var(--radius-lg);color:var(--text-secondary);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.kpi-content{min-width:0}.kpi-label{font-weight:600;letter-spacing:.05em;margin-bottom:var(--spacing-xs);text-transform:uppercase}.kpi-value-row{align-items:baseline;display:flex;gap:var(--spacing-sm)}.kpi-value{font-size:var(--font-size-3xl);line-height:1}.kpi-trend{border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;padding:2px 6px}.kpi-trend.up{background:var(--severity-high-bg);color:var(--severity-high)}.kpi-trend.down{background:var(--severity-low-bg);color:var(--severity-low)}.kpi-subtitle{color:var(--text-tertiary);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}@media (max-width:768px){.kpi-card{padding:var(--spacing-md)}.kpi-value{font-size:var(--font-size-2xl)}.kpi-icon-wrapper{height:40px;width:40px}}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-weight:600;justify-content:center;text-transform:capitalize;white-space:nowrap}.badge.sm{font-size:var(--font-size-xs);padding:2px 10px}.badge.md{font-size:var(--font-size-sm);padding:4px 12px}.badge.lg{font-size:var(--font-size-base);padding:6px 16px}.badge.default{background:var(--bg-elevated);border:1px solid var(--border-secondary);color:var(--text-secondary)}.badge.high,.badge.red{background:var(--severity-high-bg);border:1px solid var(--severity-high-border);color:var(--severity-high)}.badge.amber,.badge.medium,.badge.orange{background:var(--severity-medium-bg);border:1px solid var(--severity-medium-border);color:var(--severity-medium)}.badge.green,.badge.low{background:var(--severity-low-bg);border:1px solid var(--severity-low-border);color:var(--severity-low)}.badge.blue{background:#3b82f626;border:1px solid #3b82f64d;color:var(--accent-blue-light)}.badge.purple{background:#8b5cf626;border:1px solid #8b5cf64d;color:#a78bfa}.badge.cyan{background:#22d3ee26;border:1px solid #22d3ee4d;color:var(--accent-cyan)}.badge.pink{background:#ec489926;border:1px solid #ec48994d;color:#f472b6}.badge.gray,.badge.grey{background:#64748b26;border:1px solid #64748b4d;color:var(--text-secondary)}.badge.status{gap:6px}.badge.status:before{background:currentColor;border-radius:var(--radius-full);content:"";height:6px;width:6px}.badge.pending{background:#f59e0b26;border:1px solid var(--severity-medium-border);color:var(--severity-medium)}.badge.active{background:var(--severity-low-bg);border:1px solid var(--severity-low-border);color:var(--severity-low)}.badge.inactive{background:#64748b26;border:1px solid #64748b4d;color:var(--text-tertiary)}.data-table-wrapper{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden}.data-table-container{overflow-x:auto}.data-table{border-collapse:collapse;font-size:var(--font-size-sm);width:100%}.data-table thead{background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary)}.data-table th{color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td,.data-table th{padding:var(--spacing-md) var(--spacing-lg)}.data-table td{border-bottom:1px solid var(--border-primary);color:var(--text-primary);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-tertiary)}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.selected{background:#3b82f61a}.data-table tbody tr:last-child td{border-bottom:none}.align-center{text-align:center}.align-right{text-align:right}.index-cell{font-feature-settings:"tnum";color:var(--text-tertiary);font-variant-numeric:tabular-nums;text-align:center;width:50px}.checkbox-cell{text-align:center;width:40px}.table-checkbox{accent-color:var(--accent-blue);cursor:pointer;height:16px;width:16px}.empty-cell{color:var(--text-tertiary);padding:var(--spacing-2xl)!important;text-align:center}.table-pagination{align-items:center;background:var(--bg-tertiary);border-top:1px solid var(--border-primary);display:flex;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.pagination-info{color:var(--text-secondary);font-size:var(--font-size-sm)}.pagination-controls{align-items:center;display:flex;gap:var(--spacing-sm)}.pagination-btn{align-items:center;background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);display:flex;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.pagination-btn:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--border-accent);color:var(--text-primary)}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-pages{color:var(--text-secondary);font-size:var(--font-size-sm);padding:0 var(--spacing-md)}@media (max-width:768px){.data-table td,.data-table th{padding:var(--spacing-sm) var(--spacing-md)}.table-pagination{flex-direction:column;gap:var(--spacing-sm)}}.severity-breakdown{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--spacing-lg)}.severity-header{margin-bottom:var(--spacing-lg)}.severity-title{color:var(--text-primary);font-size:var(--font-size-base);font-weight:600;margin:0}.severity-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);display:flex;height:12px;overflow:hidden}.severity-segment{height:100%;transition:width var(--transition-slow)}.severity-segment.high{background:linear-gradient(90deg,#dc2626,#ef4444)}.severity-segment.medium{background:linear-gradient(90deg,#d97706,#f59e0b)}.severity-segment.low{background:linear-gradient(90deg,#16a34a,#22c55e)}.severity-legend{display:flex;flex-wrap:wrap;gap:var(--spacing-xl);margin-top:var(--spacing-lg)}.legend-dot{border-radius:var(--radius-full);height:10px;width:10px}.legend-dot.high{background:var(--severity-high)}.legend-dot.medium{background:var(--severity-medium)}.legend-dot.low{background:var(--severity-low)}.legend-value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600}.dashboard{display:flex;flex-direction:column;gap:var(--spacing-xl)}.kpi-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.violations-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.section-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between}.section-title-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.section-title{font-weight:700;margin:0}.section-subtitle{color:var(--text-tertiary);font-size:var(--font-size-sm)}.section-filters{align-items:center;display:flex;gap:var(--spacing-md)}.filter-select{background-position:right 10px center;height:36px;padding:0 var(--spacing-md);padding-right:32px;transition:all var(--transition-fast)}.filter-select:hover{border-color:var(--border-accent)}.filter-select:focus{border-color:var(--accent-blue);outline:none}.violation-id{color:var(--text-secondary);font-family:SF Mono,Monaco,Cascadia Code,monospace}.dataset-name{color:var(--text-secondary);display:block;font-size:var(--font-size-sm);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-meta{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.dashboard-meta,.last-run{align-items:center;display:flex}.last-run{font-size:var(--font-size-sm);gap:var(--spacing-xs)}.empty-state-dashboard,.error-hint,.last-run{color:var(--text-tertiary)}.empty-state-dashboard{align-items:center;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;padding:var(--spacing-2xl);text-align:center}@media (max-width:1200px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.section-header{align-items:flex-start;flex-direction:column}.section-filters{flex-wrap:wrap;width:100%}.filter-select{flex:1 1;min-width:140px}}@media (max-width:480px){.kpi-grid{grid-template-columns:1fr}}.chart-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);margin-top:var(--spacing-lg);padding:var(--spacing-xl)}.chart-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-lg)}.pie-chart-container{grid-gap:var(--spacing-xl);align-items:center;display:grid;gap:var(--spacing-xl);grid-template-columns:300px 1fr}.pie-chart{filter:drop-shadow(0 4px 12px rgba(0,0,0,.1));height:auto;max-width:300px;width:100%}.pie-chart path{cursor:pointer;transition:opacity var(--transition-fast)}.pie-chart path:hover{opacity:.8}.pie-legend{flex-direction:column}.legend-item,.pie-legend{display:flex;gap:var(--spacing-sm)}.legend-item{align-items:center;border-radius:var(--radius-sm);padding:var(--spacing-sm);transition:background var(--transition-fast)}.legend-item:hover{background:var(--bg-tertiary)}.legend-color{border-radius:var(--radius-sm);flex-shrink:0;height:16px;width:16px}.legend-label{color:var(--text-secondary);flex:1 1;font-weight:600;text-transform:capitalize}.legend-label,.legend-value{font-size:var(--font-size-sm)}.legend-value{color:var(--text-primary);font-weight:700}@media (max-width:768px){.pie-chart-container{grid-template-columns:1fr;justify-items:center}}.policy-vault{display:flex;flex-direction:column;gap:var(--spacing-xl)}.vault-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-lg);justify-content:space-between}.vault-stats{display:flex;gap:var(--spacing-xl)}.stat-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.stat-value{font-size:var(--font-size-2xl)}.vault-actions{display:flex;gap:var(--spacing-sm)}.vault-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.search-wrapper .search-input::placeholder{color:var(--text-tertiary)}.search-wrapper .search-input:focus{background:var(--bg-tertiary)}.filter-tabs{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);display:flex;gap:var(--spacing-xs);padding:4px}.filter-tab{border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;padding:8px 16px;transition:all var(--transition-fast)}.filter-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.filter-tab.active{background:var(--accent-blue);color:#fff}.status-filter{-webkit-appearance:none;appearance:none;background:var(--bg-card);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-sm);height:40px;padding:0 32px 0 var(--spacing-md)}.policy-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.policy-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);transition:all var(--transition-fast)}.policy-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-lg)}.policy-card-header{align-items:flex-start;display:flex;gap:var(--spacing-md)}.policy-icon{align-items:center;background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-cyan) 100%);border-radius:var(--radius-lg);color:#fff;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.policy-meta{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-xs)}.policy-id{color:var(--text-tertiary);font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs)}.policy-menu-btn{align-items:center;border-radius:var(--radius-md);color:var(--text-tertiary);display:flex;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.policy-menu-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.policy-card-body{display:flex;flex-direction:column;gap:var(--spacing-sm)}.policy-name{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:600;line-height:1.3;margin:0}.policy-description{line-clamp:2;color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin:0}.policy-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.policy-card-stats{border-top:1px solid var(--border-primary);display:flex;gap:var(--spacing-lg);padding-top:var(--spacing-md)}.policy-stat{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.policy-stat.violations{color:var(--severity-medium)}.policy-card-footer{align-items:center;border-top:1px solid var(--border-primary);display:flex;justify-content:space-between;padding-top:var(--spacing-md)}.policy-updated{color:var(--text-tertiary);font-size:var(--font-size-xs)}.policy-actions{display:flex;gap:var(--spacing-xs)}.action-btn{align-items:center;border-radius:var(--radius-md);color:var(--text-tertiary);display:flex;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.action-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.action-btn.danger:hover{background:var(--severity-high-bg);color:var(--severity-high)}.empty-state p{font-size:var(--font-size-sm)}.policy-menu-wrapper{position:relative}.policy-menu-dropdown{background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:160px;padding:var(--spacing-xs);position:absolute;right:0;top:100%;z-index:100}.policy-menu-dropdown button{align-items:center;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-fast);width:100%}.policy-menu-dropdown button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sql-details{width:100%}.sql-details summary{color:var(--text-tertiary);cursor:pointer;font-size:var(--font-size-xs);padding:var(--spacing-xs) 0;-webkit-user-select:none;user-select:none}.sql-hint-code{background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:SF Mono,Monaco,monospace;font-size:11px;margin-top:var(--spacing-xs);max-height:120px;overflow-x:auto;overflow-y:auto;padding:var(--spacing-sm);white-space:pre-wrap;word-break:break-all}@media (max-width:768px){.vault-header{align-items:flex-start;flex-direction:column}.vault-actions{width:100%}.vault-filters{align-items:stretch;flex-direction:column}.search-wrapper{max-width:none}.filter-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.policy-grid{grid-template-columns:1fr}}.policy-card.expanded{cursor:default;grid-column:1/-1}.policy-card{cursor:pointer;transition:all var(--transition-normal)}.policy-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-2px)}.policy-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden;transition:all var(--transition-normal)}.policy-description.expanded{-webkit-line-clamp:unset;display:block;margin-bottom:var(--spacing-md)}.policy-full-details{grid-gap:var(--spacing-md);border-top:1px solid var(--border-secondary);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.detail-row{flex-direction:column;gap:var(--spacing-xs)}.detail-row.full-width{grid-column:1/-1}.detail-label{font-weight:600}.detail-value{font-weight:500}.sql-hint-expanded{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-xs);margin-top:var(--spacing-xs);overflow-x:auto;padding:var(--spacing-md);white-space:pre-wrap;word-break:break-all}.scan-now-page{height:100%}.scan-layout{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:1fr 400px;height:100%}.scan-config-panel{display:flex;flex-direction:column;gap:var(--spacing-xl)}.panel-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--spacing-lg)}.section-title{align-items:center;display:flex;font-size:var(--font-size-base);gap:var(--spacing-sm);margin:0 0 var(--spacing-lg)}.upload-zone{background:var(--bg-tertiary);border:2px dashed var(--border-secondary);border-radius:var(--radius-lg);padding:var(--spacing-2xl);position:relative;text-align:center;transition:all var(--transition-fast)}.upload-zone.active,.upload-zone:hover{background:#3b82f60d;border-color:var(--accent-blue)}.file-input{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}.upload-label{cursor:pointer;flex-direction:column;gap:var(--spacing-md)}.upload-icon,.upload-label{align-items:center;display:flex}.upload-icon{background:#3b82f61a;border-radius:var(--radius-lg);color:var(--accent-blue);height:64px;justify-content:center;width:64px}.upload-text{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0}.upload-text span{color:var(--accent-blue);font-weight:600}.upload-hint{color:var(--text-tertiary);font-size:var(--font-size-xs);margin:0}.uploaded-files{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.file-item{align-items:center;background:var(--bg-elevated);border-radius:var(--radius-md);color:var(--text-secondary);display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.file-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.file-name{color:var(--text-primary);font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:var(--text-tertiary);font-size:var(--font-size-xs)}.remove-file-btn{align-items:center;border-radius:var(--radius-sm);color:var(--text-tertiary);display:flex;height:24px;justify-content:center;transition:all var(--transition-fast);width:24px}.remove-file-btn:hover{background:var(--severity-high-bg);color:var(--severity-high)}.policy-select-grid{display:flex;flex-direction:column;gap:var(--spacing-sm)}.policy-option{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);transition:all var(--transition-fast)}.policy-option:hover{background:var(--bg-elevated);border-color:var(--border-accent)}.policy-option.selected{background:#3b82f61a;border-color:var(--accent-blue)}.policy-option-header{align-items:center;display:flex;justify-content:space-between}.policy-option-name{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500}.check-icon{color:var(--accent-blue)}.policy-option-rules{color:var(--text-tertiary);font-size:var(--font-size-xs)}.scan-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.option-item{align-items:flex-start;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--spacing-md);padding:var(--spacing-md);transition:all var(--transition-fast)}.option-item:hover{background:var(--bg-elevated)}.option-item input{accent-color:var(--accent-blue);margin-top:2px}.option-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.option-label{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500}.option-desc{color:var(--text-tertiary);font-size:var(--font-size-xs)}.recent-scans-panel{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;height:-webkit-fit-content;height:fit-content;max-height:calc(100vh - 180px);padding:var(--spacing-lg)}.panel-header{justify-content:space-between;margin-bottom:var(--spacing-lg)}.panel-header,.panel-title{align-items:center;display:flex}.panel-title{gap:var(--spacing-sm);margin:0}.scans-list{display:flex;flex-direction:column;gap:var(--spacing-md);overflow-y:auto}.scan-item{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-left:3px solid var(--border-accent);border-radius:var(--radius-lg);padding:var(--spacing-md)}.scan-item.completed{border-left-color:var(--severity-low)}.scan-item.running{border-left-color:var(--accent-blue)}.scan-item.queued{border-left-color:var(--text-tertiary)}.scan-item-header{justify-content:space-between;margin-bottom:var(--spacing-sm)}.scan-info,.scan-item-header{align-items:center;display:flex}.scan-info{gap:var(--spacing-sm)}.scan-id{font-family:SF Mono,Monaco,monospace}.scan-id,.scan-time{color:var(--text-tertiary);font-size:var(--font-size-xs)}.scan-details{display:flex;flex-direction:column;gap:var(--spacing-xs)}.scan-file,.scan-policy{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.scan-progress{align-items:center;display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.progress-bar{background:var(--bg-elevated);flex:1 1;height:6px;overflow:hidden}.progress-bar,.progress-fill{border-radius:var(--radius-full)}.progress-fill{background:linear-gradient(90deg,var(--accent-blue),var(--accent-cyan));height:100%;transition:width var(--transition-slow)}.progress-text{color:var(--text-tertiary);font-size:var(--font-size-xs);min-width:36px}.scan-results{border-top:1px solid var(--border-primary);display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.result-item{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-xs)}.scan-log-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.log-box{background:#0d1117;border:1px solid #2d333b;border-radius:var(--radius-md);color:#3fb950;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:12px;line-height:1.65;margin-top:var(--spacing-md);max-height:640px;min-height:320px;overflow-y:auto;padding:var(--spacing-md)}.log-line{padding:1px 0;white-space:pre-wrap;word-break:break-all}.log-waiting{color:#8b949e;font-style:italic}.live-indicator{animation:livePulse 1s ease-in-out infinite;color:var(--severity-high);font-size:11px;font-weight:700;margin-left:var(--spacing-sm)}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.4}}.scan-result-banner{align-items:center;border-radius:var(--radius-md);display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding:var(--spacing-md)}.scan-result-banner.success{background:var(--severity-low-bg);border:1px solid var(--severity-low);color:var(--severity-low)}.scan-result-banner.error{background:var(--severity-high-bg);border:1px solid var(--severity-high);color:var(--severity-high)}.upload-skip-hint{background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:var(--font-size-xs);margin-top:var(--spacing-sm);padding:var(--spacing-sm)}.file-uploaded{color:var(--severity-low);font-size:var(--font-size-xs);font-weight:600}.empty-scans{flex-direction:column;justify-content:center;padding:var(--spacing-xl);text-align:center}.empty-scans,.loading-mini{align-items:center;color:var(--text-tertiary);display:flex;gap:var(--spacing-sm)}.loading-mini{font-size:var(--font-size-sm);padding:var(--spacing-md)}@media (max-width:1024px){.scan-layout{grid-template-columns:1fr}.recent-scans-panel{max-height:400px}}.policy-versions-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.section-hdr{justify-content:space-between;margin-bottom:var(--spacing-md)}.section-hdr,.section-ttl{align-items:center;display:flex}.section-ttl{color:var(--text-primary);font-size:var(--font-size-base);font-weight:700;gap:var(--spacing-sm);margin:0}.section-actions{align-items:center;display:flex;gap:var(--spacing-sm)}.compare-section,.versions-timeline-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.versions-list{display:flex;flex-direction:column}.version-item{display:flex;gap:var(--spacing-lg)}.version-marker{align-items:center;display:flex;flex-direction:column;flex-shrink:0;width:20px}.version-dot{background:var(--border-secondary);border:2px solid var(--bg-card);border-radius:50%;flex-shrink:0;height:14px;outline:2px solid var(--border-secondary);width:14px}.version-dot.current{background:var(--accent-blue);outline-color:#3b82f64d}.version-item.latest .version-dot{background:var(--severity-low);outline-color:#10b9814d}.version-line{background:var(--border-primary);flex:1 1;margin:4px 0;min-height:24px;width:2px}.version-content{flex:1 1;padding-bottom:var(--spacing-lg)}.version-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.version-badges{align-items:center;display:flex;gap:var(--spacing-sm)}.version-num{color:var(--text-primary);font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-sm);font-weight:700}.version-date{color:var(--text-tertiary);font-size:var(--font-size-xs)}.version-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.vmeta-item{align-items:center;display:flex;gap:4px}.version-current-hint,.vmeta-item{color:var(--text-tertiary);font-size:var(--font-size-xs)}.version-current-hint{margin:4px 0 0}.empty-versions{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-2xl);text-align:center}.empty-versions h3{color:var(--text-secondary);font-size:var(--font-size-lg);margin:0}.empty-versions p{font-size:var(--font-size-sm);margin:0}.compare-controls{align-items:flex-end;background:var(--bg-tertiary);border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.compare-select-group{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-xs);min-width:200px}.cmp-label{color:var(--text-tertiary);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;text-transform:uppercase}.cmp-select{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-sm);height:42px;padding:0 var(--spacing-md);transition:border-color var(--transition-fast)}.cmp-select:focus{border-color:var(--accent-blue);outline:none}.compare-arrow{align-items:center;color:var(--text-tertiary);display:flex;flex-shrink:0;justify-content:center;padding-bottom:2px}.diff-result{display:flex;flex-direction:column;gap:var(--spacing-lg)}.diff-summary{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr)}.diff-summary-card{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-xs);justify-content:center;padding:var(--spacing-md)}.diff-summary-card.added{background:#10b9811a;border:1px solid #10b98140;color:var(--severity-low)}.diff-summary-card.removed{background:var(--severity-high-bg);border:1px solid #ef444440;color:var(--severity-high)}.diff-summary-card.same{background:var(--bg-elevated);border:1px solid var(--border-secondary);color:var(--text-tertiary)}.diff-legend{background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}.diff-list{gap:var(--spacing-md)}.diff-group,.diff-list{display:flex;flex-direction:column}.diff-group{gap:4px}.diff-group-header{align-items:center;border-radius:var(--radius-sm);display:flex;font-size:var(--font-size-xs);font-weight:600;gap:var(--spacing-xs);letter-spacing:.05em;padding:var(--spacing-xs) var(--spacing-md);text-transform:uppercase}.diff-group-header.added{background:#10b98114;color:var(--severity-low)}.diff-group-header.removed{background:#ef444414;color:var(--severity-high)}.diff-group-header.same{background:var(--bg-elevated);color:var(--text-tertiary)}.diff-row{border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden}.diff-row.diff-added{border-left:3px solid var(--severity-low)}.diff-row.diff-removed{border-left:3px solid var(--severity-high)}.diff-row.diff-same{border-left:3px solid var(--border-secondary)}.diff-row-header{align-items:center;background:var(--bg-card);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:background var(--transition-fast);width:100%}.diff-row-header:hover{background:var(--bg-elevated)}.diff-kind-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.diff-kind-icon.added{background:#10b98126;color:var(--severity-low)}.diff-kind-icon.removed{background:#ef444426;color:var(--severity-high)}.diff-kind-icon.same{background:var(--bg-elevated);color:var(--text-tertiary)}.diff-rule-id{color:var(--text-tertiary);flex-shrink:0;font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs);white-space:nowrap}.diff-rule-desc{color:var(--text-primary);flex:1 1;font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.diff-row-detail{background:var(--bg-tertiary);border-top:1px solid var(--border-primary);padding:var(--spacing-md) var(--spacing-lg)}.diff-detail-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(3,1fr);margin-bottom:var(--spacing-sm)}.diff-detail-grid>div{display:flex;flex-direction:column;gap:2px}.dl{color:var(--text-tertiary);font-size:var(--font-size-xs);letter-spacing:.04em;text-transform:uppercase}.dv{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500}.diff-sql{background:var(--bg-elevated);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:SF Mono,Monaco,monospace;font-size:11px;max-height:100px;overflow-y:auto;padding:var(--spacing-sm);white-space:pre-wrap;word-break:break-all}@media (max-width:768px){.compare-controls{flex-direction:column}.diff-detail-grid,.diff-summary{grid-template-columns:1fr}}.configuration-page{display:flex;gap:var(--spacing-xl)}.config-tabs{display:flex;flex-direction:column;flex-shrink:0;gap:var(--spacing-xs);width:220px}.config-tab{align-items:center;border-radius:var(--radius-md);color:var(--text-secondary);display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);text-align:left;transition:all var(--transition-fast)}.config-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.config-tab.active{background:#3b82f61a;color:var(--accent-blue-light)}.config-content{display:flex;flex:1 1;flex-direction:column;gap:var(--spacing-xl)}.config-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.section-header{margin-bottom:var(--spacing-xl)}.section-title{color:var(--text-primary);font-size:var(--font-size-xl);font-weight:600;margin:0 0 var(--spacing-xs)}.section-desc{color:var(--text-tertiary);font-size:var(--font-size-sm);margin:0}.settings-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.setting-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setting-item.full-width{grid-column:1/-1}.setting-label{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500}.setting-input,.setting-select{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);height:44px;padding:0 var(--spacing-md);transition:all var(--transition-fast)}.setting-input:focus,.setting-select:focus{background:var(--bg-card);border-color:var(--accent-blue);outline:none}.setting-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.setting-hint{color:var(--text-tertiary);font-size:var(--font-size-xs)}.input-with-action{display:flex;gap:var(--spacing-sm)}.input-with-action .setting-input{flex:1 1}.theme-btn,.theme-toggle{display:flex;gap:var(--spacing-sm)}.theme-btn{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-lg);transition:all var(--transition-fast)}.theme-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.theme-btn.active{background:#3b82f61a;border-color:var(--accent-blue);color:var(--accent-blue-light)}.connection-status{align-items:center;background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:var(--spacing-xl);padding:var(--spacing-md) var(--spacing-lg)}.status-indicator{align-items:center;display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--spacing-sm)}.status-indicator.connected{color:var(--severity-low)}.status-indicator.disconnected{color:var(--severity-high)}.notification-channels{display:flex;flex-direction:column;gap:var(--spacing-md)}.channel-card{background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);overflow:hidden}.channel-header{gap:var(--spacing-md);padding:var(--spacing-lg)}.channel-header,.channel-icon{align-items:center;display:flex}.channel-icon{border-radius:var(--radius-lg);height:44px;justify-content:center;width:44px}.channel-icon.email{background:#3b82f626;color:var(--accent-blue)}.channel-icon.slack{background:#8b5cf626;color:#a78bfa}.channel-icon.webhook{background:#22c55e26;color:var(--severity-low)}.channel-info{display:flex;flex:1 1;flex-direction:column}.channel-name{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:600}.channel-desc{color:var(--text-tertiary);font-size:var(--font-size-xs)}.channel-config{padding:0 var(--spacing-lg) var(--spacing-lg)}.toggle-switch{align-items:center;cursor:pointer;display:inline-flex;position:relative}.toggle-switch.inline{gap:var(--spacing-md)}.toggle-switch input{height:0;opacity:0;position:absolute;width:0}.toggle-slider{background:var(--bg-elevated);height:24px;position:relative;width:44px}.toggle-slider,.toggle-slider:before{border-radius:var(--radius-full);transition:all var(--transition-fast)}.toggle-slider:before{background:var(--text-tertiary);content:"";height:18px;left:3px;position:absolute;top:3px;width:18px}.toggle-switch input:checked+.toggle-slider{background:var(--accent-blue)}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translateX(20px)}.toggle-label{color:var(--text-secondary);font-size:var(--font-size-sm)}.config-actions{border-top:1px solid var(--border-primary);display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-lg)}@media (max-width:1024px){.configuration-page{flex-direction:column}.config-tabs{-webkit-overflow-scrolling:touch;flex-direction:row;overflow-x:auto;padding-bottom:var(--spacing-sm);width:100%}.config-tab{white-space:nowrap}}@media (max-width:768px){.settings-grid{grid-template-columns:1fr}.config-actions{flex-direction:column}}.violations-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.violations-summary{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);gap:var(--spacing-md);padding:var(--spacing-lg)}.summary-card,.summary-icon{align-items:center;display:flex}.summary-icon{border-radius:var(--radius-lg);height:44px;justify-content:center;width:44px}.summary-icon.pending{background:var(--severity-medium-bg);color:var(--severity-medium)}.summary-icon.high{background:var(--severity-high-bg);color:var(--severity-high)}.summary-icon.confirmed{background:var(--severity-low-bg);color:var(--severity-low)}.summary-icon.escalated{background:#8b5cf626;color:#a78bfa}.summary-content{display:flex;flex-direction:column}.summary-value{color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:800}.summary-label{color:var(--text-tertiary);font-size:var(--font-size-xs)}.violations-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.violations-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.violation-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-fast)}.violation-card:hover{border-color:var(--border-secondary)}.violation-card.high{border-left:4px solid var(--severity-high)}.violation-card.medium{border-left:4px solid var(--severity-medium)}.violation-card.low{border-left:4px solid var(--severity-low)}.violation-header{align-items:flex-start;cursor:pointer;display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg)}.violation-main{flex:1 1;min-width:0}.violation-id-group{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.violation-id{color:var(--text-tertiary);font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs)}.violation-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--spacing-xs)}.violation-desc{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin:0}.violation-meta{display:flex;flex-direction:column;flex-shrink:0;gap:var(--spacing-sm)}.meta-item{font-size:var(--font-size-sm);gap:var(--spacing-xs);white-space:nowrap}.expand-btn,.meta-item{align-items:center;color:var(--text-tertiary);display:flex}.expand-btn{border-radius:var(--radius-md);flex-shrink:0;height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.expand-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.expand-btn.expanded{transform:rotate(180deg)}.violation-details{background:var(--bg-tertiary);border-top:1px solid var(--border-primary);padding:0 var(--spacing-lg) var(--spacing-lg)}.details-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:var(--spacing-lg) 0}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-value.code{background:var(--bg-card);padding:4px 8px}.detail-value.highlight{color:var(--severity-high);font-weight:600}.violation-actions{border-top:1px solid var(--border-primary);display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding-top:var(--spacing-md)}.detail-item.full-width{grid-column:1/-1}.sql-block{background:var(--bg-elevated);border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs);max-height:200px;overflow-y:auto;padding:var(--spacing-md);white-space:pre-wrap;word-break:break-all}.sample-table-wrap,.sql-block{border-radius:var(--radius-md);overflow-x:auto}.sample-table-wrap{border:1px solid var(--border-secondary)}.sample-table{border-collapse:collapse;font-size:var(--font-size-xs);width:100%}.sample-table th{background:var(--bg-elevated);border-bottom:1px solid var(--border-secondary);color:var(--text-tertiary);font-weight:600;letter-spacing:.04em;padding:6px 10px;text-align:left;text-transform:uppercase}.sample-table td{border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-family:monospace;padding:6px 10px}.sample-table tr:last-child td{border-bottom:none}.toast{align-items:center;animation:slideInToast .3s ease;border-radius:var(--radius-lg);bottom:2rem;box-shadow:0 8px 24px #0006;display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);position:fixed;right:2rem;z-index:9999}.toast-success{background:var(--severity-low-bg);border:1px solid var(--severity-low);color:var(--severity-low)}.toast-error{background:var(--severity-high-bg);border:1px solid var(--severity-high);color:var(--severity-high)}@keyframes slideInToast{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.error-hint{font-size:var(--font-size-xs)}@media (max-width:768px){.violations-filters{align-items:stretch;flex-direction:column}.search-wrapper{max-width:none}.violation-header{flex-direction:column}.violation-meta{flex-direction:row;flex-wrap:wrap}.violation-actions{flex-direction:column}.violation-actions .button{width:100%}}.audit-log-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.audit-stats{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card{align-items:center;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;padding:var(--spacing-lg);text-align:center}.stat-value{font-feature-settings:"tnum";color:var(--text-primary);font-size:var(--font-size-3xl);font-variant-numeric:tabular-nums;font-weight:800}.stat-label{color:var(--text-tertiary);font-size:var(--font-size-xs);letter-spacing:.05em;text-transform:uppercase}.audit-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.search-wrapper{flex:1 1;max-width:400px;min-width:250px;position:relative}.search-wrapper .search-icon{color:var(--text-tertiary);left:var(--spacing-md);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-wrapper .search-input{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);height:44px;padding:0 var(--spacing-md) 0 44px;transition:all var(--transition-fast);width:100%}.search-wrapper .search-input:focus{border-color:var(--accent-blue);outline:none}.filter-group{align-items:center;color:var(--text-tertiary);display:flex;gap:var(--spacing-sm)}.filter-select{-webkit-appearance:none;appearance:none;background:var(--bg-card);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid var(--border-secondary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-sm);height:40px;padding:0 32px 0 var(--spacing-md)}.audit-content{display:flex;gap:var(--spacing-xl)}.audit-timeline{display:flex;flex:1 1;flex-direction:column}.timeline-item{cursor:pointer;display:flex;gap:var(--spacing-lg);transition:all var(--transition-fast)}.timeline-item:hover .timeline-content{background:var(--bg-card-hover);border-color:var(--border-secondary)}.timeline-item.selected .timeline-content{background:#3b82f61a;border-color:var(--accent-blue)}.timeline-marker{flex-direction:column;flex-shrink:0}.marker-icon,.timeline-marker{align-items:center;display:flex}.marker-icon{border-radius:var(--radius-full);height:36px;justify-content:center;width:36px}.marker-icon.blue{background:#3b82f626;color:var(--accent-blue)}.marker-icon.green{background:var(--severity-low-bg);color:var(--severity-low)}.marker-icon.red{background:var(--severity-high-bg);color:var(--severity-high)}.marker-icon.orange{background:var(--severity-medium-bg);color:var(--severity-medium)}.marker-icon.purple{background:#8b5cf626;color:#a78bfa}.marker-icon.cyan{background:#22d3ee26;color:var(--accent-cyan)}.marker-icon.pink{background:#ec489926;color:#f472b6}.marker-icon.gray{background:#64748b26;color:var(--text-tertiary)}.timeline-line{background:var(--border-primary);flex:1 1;margin-top:var(--spacing-sm);min-height:24px;width:2px}.timeline-content{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);flex:1 1;margin-bottom:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);transition:all var(--transition-fast)}.timeline-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm)}.timeline-meta{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.event-id{color:var(--text-tertiary);font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs)}.timeline-time{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0}.time-date{color:var(--text-secondary)}.time-clock,.time-date{font-size:var(--font-size-xs)}.time-clock{color:var(--text-tertiary);font-family:SF Mono,Monaco,monospace}.timeline-details{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin:0 0 var(--spacing-sm)}.timeline-footer{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.footer-item{align-items:center;color:var(--text-tertiary);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-xs)}.audit-details-panel{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);height:-webkit-fit-content;height:fit-content;padding:var(--spacing-lg);position:-webkit-sticky;position:sticky;top:var(--spacing-xl);width:320px}.panel-title{border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-lg);padding-bottom:var(--spacing-md)}.details-content{flex-direction:column}.detail-row,.details-content{display:flex;gap:var(--spacing-md)}.detail-row{align-items:center;justify-content:space-between}.detail-row.full{align-items:flex-start;flex-direction:column}.detail-label{color:var(--text-tertiary);font-size:var(--font-size-xs);letter-spacing:.05em;text-transform:uppercase}.detail-value{color:var(--text-primary);font-size:var(--font-size-sm)}.detail-value.code{background:var(--bg-tertiary);border-radius:var(--radius-sm);font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs);padding:2px 8px}.detail-text{background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin:var(--spacing-sm) 0 0;padding:var(--spacing-md)}.empty-state{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;padding:var(--spacing-2xl);text-align:center}.empty-state svg{margin-bottom:var(--spacing-md);opacity:.5}.empty-state h3{color:var(--text-secondary);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-xs)}.detail-text{font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs);max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.error-state,.loading-state{min-height:300px}@media (max-width:1024px){.audit-content{flex-direction:column}.audit-details-panel{position:static;width:100%}}@media (max-width:768px){.audit-filters{align-items:stretch;flex-direction:column}.search-wrapper{max-width:none}.timeline-header{flex-direction:column;gap:var(--spacing-sm)}.timeline-time{align-items:flex-start}}.live-monitor-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.conn-bar{align-items:center;border-radius:var(--radius-lg);display:flex;font-size:var(--font-size-sm);font-weight:500;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.conn-bar.connected{background:#10b9811a;border:1px solid #10b9814d;color:var(--severity-low)}.conn-bar.disconnected{background:var(--severity-high-bg);border:1px solid var(--severity-high);color:var(--severity-high)}.conn-time{font-size:var(--font-size-xs);margin-left:auto;opacity:.8}.monitor-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.monitor-section-title{align-items:center;color:var(--text-primary);color:var(--text-tertiary);display:flex;font-size:var(--font-size-base);font-size:12px;font-weight:700;gap:var(--spacing-sm);letter-spacing:.06em;margin:0;text-transform:uppercase}.process-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.process-card{align-items:center;background:var(--bg-card);border:1px solid var(--border-primary);border-left:4px solid #0000;border-radius:var(--radius-xl);display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);transition:all var(--transition-fast)}.process-card.running{border-left-color:var(--severity-low)}.process-card.stopped{border-left-color:var(--severity-high);opacity:.8}.process-icon{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.process-icon.running{background:#10b98126;color:var(--severity-low)}.process-icon.stopped{background:var(--severity-high-bg);color:var(--severity-high)}.process-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.process-name{color:var(--text-primary);font-size:var(--font-size-base);font-weight:600}.process-status-row{align-items:center;display:flex;gap:6px}.status-text{font-size:var(--font-size-xs);font-weight:500}.status-text.running{color:var(--severity-low)}.status-text.stopped{color:var(--severity-high)}.pulse-dot{animation:pulseLive 1.4s ease-in-out infinite;background:var(--severity-low);border-radius:50%;flex-shrink:0;height:8px;width:8px}@keyframes pulseLive{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.service-hint{align-items:center;background:var(--severity-medium-bg);border:1px solid var(--severity-medium);border-radius:var(--radius-md);color:var(--severity-medium);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.service-hint code{background:#0003;border-radius:4px;font-family:monospace;font-size:11px;padding:2px 6px}.live-kpi-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.live-kpi-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);gap:var(--spacing-md);padding:var(--spacing-lg)}.kpi-icon,.live-kpi-card{align-items:center;display:flex}.kpi-icon{border-radius:var(--radius-lg);flex-shrink:0;height:44px;justify-content:center;width:44px}.kpi-icon.blue{background:#3b82f626;color:var(--accent-blue)}.kpi-icon.orange{background:var(--severity-medium-bg);color:var(--severity-medium)}.kpi-icon.red{background:var(--severity-high-bg);color:var(--severity-high)}.kpi-icon.purple{background:#8b5cf626;color:#a78bfa}.kpi-content{display:flex;flex-direction:column;gap:2px}.kpi-value{font-feature-settings:"tnum";color:var(--text-primary);font-size:var(--font-size-2xl);font-variant-numeric:tabular-nums;font-weight:800}.kpi-label{color:var(--text-tertiary);font-size:var(--font-size-xs)}.config-strip{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--spacing-lg)}.config-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-xl)}.config-item{display:flex;flex-direction:column;gap:2px}.config-label{color:var(--text-tertiary);font-size:var(--font-size-xs);letter-spacing:.05em;text-transform:uppercase}.config-value{font-feature-settings:"tnum";color:var(--text-primary);font-size:var(--font-size-base);font-variant-numeric:tabular-nums;font-weight:700}.live-violations-table-wrap{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden}.live-violations-table{border-collapse:collapse;width:100%}.live-violations-table th{background:var(--bg-elevated);color:var(--text-tertiary);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.05em;text-align:left;text-transform:uppercase}.live-violations-table td,.live-violations-table th{border-bottom:1px solid var(--border-primary);padding:var(--spacing-md) var(--spacing-lg)}.live-violations-table td{color:var(--text-primary);font-size:var(--font-size-sm);transition:background var(--transition-fast)}.live-violations-table tr:last-child td{border-bottom:none}.live-violations-table tr:hover td{background:var(--bg-tertiary)}.live-violations-table tr.row-triggered td{background:#ef444408}.rule-id-cell{color:var(--text-tertiary)!important;font-family:SF Mono,Monaco,monospace;font-size:var(--font-size-xs)!important}.count-cell{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:700}.empty-live{align-items:center;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-xl);color:var(--text-tertiary);display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;padding:var(--spacing-2xl);text-align:center}.empty-live h3{color:var(--text-secondary);font-size:var(--font-size-lg);font-weight:600;margin:0}.empty-live p{font-size:var(--font-size-sm);margin:0}.error-state,.loading-state{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:var(--spacing-md);justify-content:center;min-height:400px;text-align:center}.error-state h3{color:var(--severity-high);margin:0}.error-state p{margin:0}.error-hint code{background:var(--bg-elevated);border-radius:var(--radius-sm);font-family:monospace;padding:2px 6px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spinning{animation:spin 1s linear infinite}@media (max-width:768px){.live-kpi-grid{grid-template-columns:repeat(2,1fr)}.process-grid{grid-template-columns:1fr}.config-badges{flex-direction:column}}.app{background:var(--bg-primary)}.app,.main-wrapper{display:flex;min-height:100vh}.main-wrapper{flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left var(--transition-normal)}.app.sidebar-collapsed .main-wrapper{margin-left:72px}.main-content{background:var(--bg-primary);flex:1 1;overflow-y:auto;padding:var(--spacing-xl);padding-top:calc(var(--header-height) + var(--spacing-xl))}@media (max-width:1024px){.app.sidebar-collapsed .main-wrapper,.main-wrapper{margin-left:0}}:root{--bg-primary:#0a0e17;--bg-secondary:#0f1419;--bg-tertiary:#151b26;--bg-card:#1a2233;--bg-card-hover:#1e2738;--bg-elevated:#212d40;--border-primary:#1e2a3a;--border-secondary:#2a3a4d;--border-accent:#3d4f66;--text-primary:#fff;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-muted:#475569;--accent-blue:#3b82f6;--accent-blue-light:#60a5fa;--accent-blue-dark:#1d4ed8;--accent-cyan:#22d3ee;--accent-teal:#14b8a6;--severity-high:#ef4444;--severity-high-bg:#ef444426;--severity-high-border:#ef44444d;--severity-medium:#f59e0b;--severity-medium-bg:#f59e0b26;--severity-medium-border:#f59e0b4d;--severity-low:#22c55e;--severity-low-bg:#22c55e26;--severity-low-border:#22c55e4d;--status-pending:#f59e0b;--status-active:#22c55e;--status-inactive:#64748b;--button-primary:linear-gradient(135deg,#ec4899,#8b5cf6);--button-primary-hover:linear-gradient(135deg,#f472b6,#a78bfa);--button-secondary:#3b82f6;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0006;--shadow-glow-blue:0 0 20px #3b82f64d;--shadow-glow-pink:0 0 20px #ec48994d;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--font-size-4xl:2.5rem;--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:350ms ease;--sidebar-width:260px;--header-height:64px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:#0a0e17;background-color:var(--bg-primary);color:#fff;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{background:none;border:none;cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}ol,ul{list-style:none}img{height:auto;max-width:100%}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0f1419;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#3d4f66;background:var(--border-accent);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#64748b;background:var(--text-tertiary)}::selection{background:#3b82f6;background:var(--accent-blue);color:#fff}:focus-visible{outline:2px solid #3b82f6;outline:2px solid var(--accent-blue);outline-offset:2px}.container{margin:0 auto;max-width:1400px;padding:0 1.5rem;padding:0 var(--spacing-lg)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}
/*# sourceMappingURL=main.784dd72b.css.map*/