:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--primary-dark: #1d4ed8;--secondary-color: #64748b;--success-color: #22c55e;--warning-color: #f59e0b;--danger-color: #ef4444;--info-color: #06b6d4;--severity-high: #ef4444;--severity-medium: #f59e0b;--severity-low: #22c55e;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-hover: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-light: #475569;--sidebar-width: 280px;--header-height: 70px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .3);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition: all .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1;margin-top:var(--header-height)}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:100}.header-left{display:flex;align-items:center;gap:16px}.logo{display:flex;align-items:center;gap:10px}.logo-icon{width:32px;height:32px;color:var(--primary-color)}.logo h1{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.tagline{color:var(--text-muted);font-size:.875rem;padding-left:16px;border-left:1px solid var(--border-color)}.header-center{display:flex;align-items:center}.selection-badge{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);padding:8px 16px;border-radius:var(--radius-md)}.badge-number{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.badge-label{color:var(--text-secondary);font-size:.875rem}.header-right{display:flex;align-items:center;gap:20px}.format-selector{display:flex;align-items:center;gap:12px}.format-selector label{color:var(--text-secondary);font-size:.875rem}.format-buttons{display:flex;gap:4px;background:var(--bg-tertiary);padding:4px;border-radius:var(--radius-md)}.format-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition);font-size:.875rem}.format-btn:hover{color:var(--text-primary)}.format-btn.active{background:var(--primary-color);color:#fff}.format-icon{width:16px;height:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-icon{width:18px;height:18px}.btn-sm{padding:6px 12px;font-size:.813rem}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover)}.btn-warning{background:var(--warning-color);color:var(--bg-primary)}.btn-warning:hover{filter:brightness(1.1)}.generate-btn{padding:12px 24px}.sidebar{position:fixed;left:0;top:var(--header-height);bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:var(--transition);z-index:50}.sidebar.collapsed{width:48px}.sidebar-toggle{position:absolute;right:-12px;top:16px;width:24px;height:24px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:var(--transition)}.sidebar-toggle:hover{background:var(--primary-color);border-color:var(--primary-color)}.sidebar-toggle svg{width:14px;height:14px;color:var(--text-secondary)}.sidebar-toggle:hover svg{color:#fff}.sidebar-content{flex:1;overflow-y:auto;padding:20px}.sidebar-section{margin-bottom:24px}.section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.sidebar-select{width:100%;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer}.sidebar-select:focus{outline:none;border-color:var(--primary-color)}.profile-description{margin-top:8px;font-size:.813rem;color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.stat-item{background:var(--bg-tertiary);padding:12px;border-radius:var(--radius-md);text-align:center}.stat-item.highlight{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark))}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-secondary)}.stat-item.highlight .stat-label{color:#fffc}.severity-stats{display:flex;gap:8px}.severity-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.severity-dot{width:8px;height:8px;border-radius:50%;margin-bottom:4px}.severity-stat.high .severity-dot{background:var(--severity-high)}.severity-stat.medium .severity-dot{background:var(--severity-medium)}.severity-stat.low .severity-dot{background:var(--severity-low)}.severity-count{font-weight:600;font-size:.875rem}.severity-label{font-size:.688rem;color:var(--text-muted)}.coverage-score{margin-bottom:16px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.coverage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.coverage-label{font-size:.813rem;font-weight:500;color:var(--text-secondary)}.coverage-percent{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.coverage-bar{height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;margin-bottom:6px}.coverage-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--info-color));border-radius:4px;transition:width .3s ease}.coverage-detail{font-size:.75rem;color:var(--text-muted);text-align:center}.configurable-stat{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;padding:10px;background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px dashed var(--info-color)}.configurable-stat .config-icon{width:16px;height:16px;color:var(--info-color)}.configurable-stat .config-count{font-weight:600;font-size:.9rem;color:var(--info-color)}.configurable-stat .config-label{font-size:.75rem;color:var(--text-muted)}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);font-size:.813rem;cursor:pointer;transition:var(--transition)}.filter-chip:hover{border-color:var(--primary-color)}.filter-chip.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.chip-dot{width:8px;height:8px;border-radius:50%}.category-list{display:flex;flex-direction:column;gap:4px}.category-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.category-item:hover{background:var(--bg-tertiary)}.category-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color)}.category-name{font-size:.875rem;color:var(--text-secondary)}.category-item:hover .category-name,.category-item input:checked+.category-name{color:var(--text-primary)}.content{flex:1;margin-left:var(--sidebar-width);padding:24px;transition:var(--transition)}.content.sidebar-collapsed{margin-left:48px}.content-header{margin-bottom:24px}.search-sort-bar{display:flex;gap:16px;margin-bottom:16px}.search-container{flex:1;position:relative}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted)}.search-input{width:100%;padding:12px 40px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem}.search-input:focus{outline:none;border-color:var(--primary-color)}.search-input::placeholder{color:var(--text-muted)}.clear-search{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:4px}.clear-search:hover{color:var(--text-primary)}.sort-controls{display:flex;align-items:center;gap:8px}.sort-controls label{color:var(--text-secondary);font-size:.875rem;white-space:nowrap}.sort-select{padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem}.sort-order-btn{padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;cursor:pointer;transition:var(--transition)}.sort-order-btn:hover{background:var(--bg-tertiary)}.selection-controls{display:flex;align-items:center;justify-content:space-between}.results-count{color:var(--text-secondary);font-size:.875rem}.selection-buttons{display:flex;gap:8px}.quick-filters{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.quick-filters-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.quick-filter-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:var(--transition)}.quick-filter-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-light)}.quick-filter-btn:disabled{opacity:.5;cursor:not-allowed}.quick-filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.quick-filter-btn.active:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.quick-filter-btn.clear-filters{background:transparent;border-color:var(--danger-color);color:var(--danger-color)}.quick-filter-btn.clear-filters:hover{background:var(--danger-color);color:#fff}.quick-filter-btn .filter-icon{width:14px;height:14px}.rule-list{display:flex;flex-direction:column;gap:32px}.rule-category{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden}.category-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.category-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.category-count{font-size:.813rem;color:var(--text-muted);background:var(--bg-secondary);padding:4px 10px;border-radius:20px}.category-rules{display:flex;flex-direction:column}.rule-card{border-bottom:1px solid var(--border-color);transition:var(--transition)}.rule-card:last-child{border-bottom:none}.rule-card:hover{background:var(--bg-tertiary)}.rule-card.selected{background:#3b82f61a;border-left:3px solid var(--primary-color)}.rule-header{display:flex;align-items:center;gap:16px;padding:16px 20px}.rule-checkbox{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer}.rule-checkbox input{width:20px;height:20px;accent-color:var(--primary-color);cursor:pointer}.rule-info{flex:1;cursor:pointer}.rule-title{font-size:.938rem;font-weight:500;color:var(--text-primary);margin-bottom:4px}.rule-id{font-size:.75rem;color:var(--text-muted);font-family:monospace}.rule-badges{display:flex;gap:8px}.badge{padding:4px 10px;border-radius:20px;font-size:.688rem;font-weight:600;text-transform:uppercase}.badge.severity-high{background:#ef444433;color:var(--severity-high)}.badge.severity-medium{background:#f59e0b33;color:var(--severity-medium)}.badge.severity-low{background:#22c55e33;color:var(--severity-low)}.badge.complexity{background:var(--bg-tertiary);color:var(--text-secondary)}.badge.configurable{background:#06b6d433;color:var(--info-color)}.search-highlight{background:#fbbf244d;color:var(--text-primary);padding:2px 0;border-radius:2px;font-weight:600}.notes-indicator{margin-left:8px;color:var(--info-color);display:inline-flex;align-items:center}.notes-editor{display:flex;flex-direction:column;gap:8px}.notes-textarea{width:100%;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:.875rem;line-height:1.5;resize:vertical}.notes-textarea:focus{outline:none;border-color:var(--primary-color)}.notes-display{display:flex;flex-direction:column;gap:8px}.notes-content{padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--info-color);white-space:pre-wrap;font-size:.875rem;line-height:1.6}.bookmark-btn{padding:8px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:var(--text-muted)}.bookmark-btn:hover{background:var(--bg-tertiary);color:var(--warning-color)}.bookmark-btn.bookmarked{color:var(--warning-color)}.bookmark-btn svg{width:18px;height:18px}.expand-btn{padding:8px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.expand-btn:hover{background:var(--bg-tertiary)}.expand-btn svg{width:20px;height:20px;color:var(--text-muted)}.rule-details{padding:0 20px 20px 56px}.detail-section{margin-bottom:20px}.detail-section:last-child{margin-bottom:0}.detail-section h4{font-size:.813rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.detail-section p{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.identifiers{display:flex;flex-wrap:wrap;gap:12px}.identifier{font-size:.813rem;color:var(--text-secondary)}.identifier strong{color:var(--text-muted)}.profile-tags{display:flex;flex-wrap:wrap;gap:6px}.profile-tag{padding:4px 10px;background:var(--bg-tertiary);border-radius:20px;font-size:.75rem;color:var(--text-secondary)}.variables-list{display:flex;flex-direction:column;gap:8px}.variable-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm)}.variable-item code{font-family:monospace;color:var(--primary-color);font-size:.813rem}.var-default{font-size:.75rem;color:var(--text-muted)}.var-desc{flex:1;font-size:.813rem;color:var(--text-secondary)}.remediation-tabs details{margin-bottom:8px}.remediation-tabs summary{cursor:pointer;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text-secondary);transition:var(--transition)}.remediation-tabs summary:hover{color:var(--text-primary)}.code-block{margin-top:8px;padding:16px;background:var(--bg-primary);border-radius:var(--radius-md);overflow-x:auto}.code-block code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.813rem;color:var(--text-secondary);white-space:pre}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center}.empty-icon{width:64px;height:64px;color:var(--text-muted);margin-bottom:16px}.empty-state h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:8px}.empty-state p{color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px;border-bottom:1px solid var(--border-color)}.modal-title h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.modal-subtitle{font-size:.875rem;color:var(--text-muted)}.modal-close{padding:8px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.modal-close:hover{background:var(--bg-tertiary)}.modal-close svg{width:20px;height:20px;color:var(--text-muted)}.modal-actions{display:flex;gap:12px;padding:16px 24px;border-bottom:1px solid var(--border-color)}.script-container{flex:1;overflow:hidden;display:flex;flex-direction:column}.script-info{display:flex;gap:24px;padding:16px 24px;background:var(--bg-tertiary)}.info-item{display:flex;gap:8px;font-size:.875rem}.info-label{color:var(--text-muted)}.info-value{color:var(--text-primary);font-weight:500}.code-output{flex:1;margin:0;padding:24px;background:var(--bg-primary);overflow:auto;max-height:400px}.code-output code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.813rem;color:#a8d4a8;white-space:pre;line-height:1.6}.code-output.ansible code{color:#a8c8e8}.modal-footer{padding:24px;border-top:1px solid var(--border-color)}.usage-instructions h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.usage-instructions ol{padding-left:20px;color:var(--text-secondary);font-size:.875rem}.usage-instructions li{margin-bottom:8px}.usage-instructions code{background:var(--bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-family:monospace;font-size:.813rem;color:var(--primary-color)}.variables-section{border-bottom:1px solid var(--border-color)}.variables-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:16px 24px;background:var(--bg-tertiary);border:none;color:var(--text-primary);font-size:.938rem;font-weight:500;cursor:pointer;transition:var(--transition)}.variables-toggle:hover{background:var(--bg-hover)}.variables-toggle .btn-icon{width:18px;height:18px;color:var(--info-color)}.variables-toggle .chevron{width:16px;height:16px;margin-left:auto;color:var(--text-muted)}.variables-editor{padding:16px 24px;background:var(--bg-primary);max-height:300px;overflow-y:auto}.variable-row{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;padding:12px 0;border-bottom:1px solid var(--border-color)}.variable-row:last-child{border-bottom:none}.variable-info{flex:1;min-width:0}.variable-info label{display:block;font-size:.875rem;color:var(--text-primary);margin-bottom:4px}.variable-info .variable-name{display:block;font-size:.75rem;color:var(--primary-color);margin-bottom:2px}.variable-info .variable-rules{font-size:.688rem;color:var(--text-muted)}.variable-input{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:200px}.variable-input input,.variable-input select{width:100%;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:monospace}.variable-input input:focus,.variable-input select:focus{outline:none;border-color:var(--primary-color)}.variable-input .default-hint{font-size:.688rem;color:var(--text-muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.loading-overlay{display:flex;align-items:center;justify-content:center;flex:1;margin-top:var(--header-height);background:var(--bg-primary)}.loading-container{display:flex;flex-direction:column;align-items:center;gap:24px;padding:40px}.loading-spinner{position:relative;width:60px;height:60px}.spinner{width:100%;height:100%;border:4px solid var(--bg-tertiary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{color:var(--text-secondary);font-size:1rem;text-align:center}.loading-progress{display:flex;align-items:center;gap:12px;width:200px}.progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-color);border-radius:3px;transition:width .3s ease}.progress-text{font-size:.813rem;color:var(--text-muted);min-width:40px}.error-overlay{display:flex;align-items:center;justify-content:center;flex:1;margin-top:var(--header-height);background:var(--bg-primary);padding:40px}.error-message{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--danger-color);text-align:center;max-width:400px}.error-message h2{font-size:1.25rem;color:var(--danger-color)}.error-message p{color:var(--text-secondary);font-size:.875rem}@media (max-width: 1024px){.sidebar{width:240px}.content{margin-left:240px}.header-left .tagline{display:none}}@media (max-width: 768px){.sidebar{position:fixed;transform:translate(-100%)}.sidebar:not(.collapsed){transform:translate(0)}.content{margin-left:0}.header{padding:0 16px}.header-center,.format-selector label{display:none}.search-sort-bar{flex-direction:column}.selection-controls{flex-direction:column;gap:12px;align-items:flex-start}}.history-modal{max-width:700px;max-height:80vh;display:flex;flex-direction:column}.history-list{flex:1;overflow-y:auto;padding:20px}.history-entry{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:12px;transition:var(--transition)}.history-entry:hover{background:var(--bg-tertiary)}.history-main{display:flex;align-items:center;gap:16px;flex:1}.history-icon{width:40px;height:40px;background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.history-icon svg{width:20px;height:20px}.history-details{flex:1}.history-title{font-size:.938rem;color:var(--text-primary);margin-bottom:6px}.history-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.history-badge{padding:2px 8px;background:var(--bg-tertiary);border-radius:12px;font-size:.688rem;color:var(--text-secondary);text-transform:uppercase;font-weight:600}.history-date{font-size:.75rem;color:var(--text-muted)}.history-delete{padding:8px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:var(--transition)}.history-delete:hover{background:var(--danger-color);color:#fff}.history-delete svg{width:18px;height:18px}.history-btn{margin-right:12px}
