.threshold-editor-compact{margin:20px 0;text-align:center}.threshold-editor-compact .expand-btn{background:#2196f3;color:#fff;padding:12px 24px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.threshold-editor-compact .expand-btn:hover{background:#1976d2}.threshold-editor{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin:20px 0}.threshold-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.threshold-header h3{margin:0;font-size:18px;color:#333}.close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:5px}.threshold-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.threshold-item{display:flex;flex-direction:column}.threshold-item label{font-size:12px;font-weight:600;color:#666;margin-bottom:5px}.threshold-item input{padding:8px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.threshold-actions{display:flex;gap:10px;justify-content:center;margin-bottom:15px}.save-btn,.reset-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.save-btn{background:#28a745;color:#fff}.save-btn:hover{background:#218838}.reset-btn{background:#6c757d;color:#fff}.reset-btn:hover{background:#5a6268}.threshold-note{font-size:12px;color:#666;text-align:center;margin:0;font-style:italic}.batch-upload-compact{margin:20px 0;text-align:center}.batch-upload-compact .expand-btn{background:#6f42c1;color:#fff;padding:12px 24px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.batch-upload-compact .expand-btn:hover{background:#5a32a3}.batch-upload{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin:20px 0}.batch-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.batch-header h3{margin:0;font-size:18px;color:#333}.close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}.batch-controls{display:flex;gap:15px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.profile-selector{display:flex;align-items:center;gap:10px}.profile-selector label{font-size:14px;font-weight:600;color:#666}.profile-selector select{padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.drop-zone{flex:1;border:2px dashed #ced4da;border-radius:8px;padding:30px;text-align:center;background:#fff;cursor:pointer;transition:all .2s}.drop-zone:hover{border-color:#007bff;background:#f0f8ff}.drop-zone.dragging{border-color:#28a745;background:#e8f5e9}.drop-zone-content{pointer-events:none}.drop-icon{font-size:48px;display:block;margin-bottom:10px}.drop-zone p{margin:5px 0;color:#333}.drop-hint{font-size:12px;color:#666!important}.select-btn,.upload-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.upload-btn{background:#28a745;color:#fff;width:100%;margin-top:10px}.upload-btn:hover{background:#218838}.batch-list{margin-bottom:15px;overflow-x:auto}.batch-list table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden}.batch-list thead{background:#e9ecef}.batch-list th{padding:12px;text-align:left;font-size:12px;font-weight:600;color:#495057;text-transform:uppercase;letter-spacing:.5px}.batch-list td{padding:12px;border-top:1px solid #dee2e6;font-size:14px;color:#333;vertical-align:middle}.batch-list tr:hover{background:#f8f9fa}.batch-note{font-size:12px;color:#666;text-align:center;margin:0;font-style:italic}.zip-analysis-view{background:#fff;border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 2px 4px #0000001a}.zip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.zip-header h3{margin:0;font-size:18px;font-weight:600}.zip-stats{display:flex;gap:20px;font-size:14px;color:#666}.zip-file-table{width:100%;border-collapse:collapse;font-size:14px}.zip-file-table thead th{text-align:left;padding:12px 8px;border-bottom:2px solid #e0e0e0;font-weight:600;color:#333}.zip-file-table tbody tr{border-bottom:1px solid #f0f0f0}.zip-file-table tbody tr:hover{background-color:#f9f9f9}.file-row td{padding:10px 8px}.folder-row td{padding:12px 8px;background-color:#f5f5f5;font-weight:500}.folder-icon,.file-icon{margin-right:8px;font-size:16px}.file-path{display:flex;align-items:center;max-width:300px}.file-size{text-align:right;font-family:Courier New,monospace;color:#666}.file-optimization{text-align:center}.status-optimized{color:#4caf50;font-weight:500}.status-not-optimized{color:#f44336;font-weight:500}.status-not-optimized strong{color:#d32f2f;font-weight:700;margin-left:4px}.status-na{color:#999}.file-savings{text-align:right;font-family:Courier New,monospace;color:#666}.file-bar{padding:4px}.size-bar{height:20px;border-radius:4px;min-width:2px;transition:width .3s ease}.network-breakdown{background:#fff;border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 2px 4px #0000001a}.network-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding-bottom:10px;border-bottom:2px solid #e0e0e0;margin-bottom:15px}.network-header:hover{opacity:.8}.network-header h3{margin:0;font-size:18px;font-weight:600}.network-stats{display:flex;align-items:center;gap:15px;font-size:14px;color:#666}.expand-icon{font-size:12px;color:#999}.network-table{width:100%;border-collapse:collapse;font-size:13px}.network-table thead th{text-align:left;padding:10px 8px;border-bottom:2px solid #e0e0e0;font-weight:600;color:#333}.network-table tbody tr{border-bottom:1px solid #f0f0f0}.network-table tbody tr:hover{background-color:#f9f9f9}.network-table tbody td{padding:10px 8px}.network-url{display:flex;align-items:center;gap:6px;max-width:250px}.https-lock{color:#4caf50;font-size:14px}.http-warning{color:#ff9800;font-size:14px}.url-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1976d2}.network-status{text-align:center;font-weight:600;font-family:Courier New,monospace}.network-protocol{text-align:center}.protocol-badge{background:#e3f2fd;color:#1976d2;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.network-encoding{text-align:center;font-family:Courier New,monospace;color:#666}.network-timing,.network-size{text-align:right;font-family:Courier New,monospace;color:#666}.network-bar{padding:4px}.size-bar{height:18px;background:linear-gradient(90deg,#2196f3,#1976d2);border-radius:4px;min-width:2px;transition:width .3s ease}.backup-ad-timeline{margin:2rem 0;padding:1.5rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px}.timeline-header{display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.timeline-frames{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.timeline-frame{display:flex;flex-direction:column;gap:.5rem}.frame-time{font-weight:600;color:#1976d2}.frame-image{aspect-ratio:16/9;border:1px solid #ddd;border-radius:4px;overflow:hidden;background:#f5f5f5}.frame-image img{width:100%;height:100%;object-fit:contain}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease-out}.check-detail-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:1001;max-width:600px;width:90%;max-height:85vh;display:flex;flex-direction:column;animation:slideIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.check-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.check-detail-modal .modal-header h2{margin:0;font-size:20px;font-weight:600;color:#111827}.check-detail-modal .close-btn{background:none;border:none;font-size:32px;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s,color .2s}.check-detail-modal .close-btn:hover{background-color:#f3f4f6;color:#111827}.check-detail-modal .modal-body{padding:24px;overflow-y:auto;flex:1}.check-detail-modal .section{margin-bottom:24px}.check-detail-modal .section:last-child{margin-bottom:0}.check-detail-modal .section h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#374151}.check-detail-modal .section p{margin:0;font-size:14px;line-height:1.6;color:#4b5563}.check-detail-modal .description{font-size:15px;color:#111827;line-height:1.6}.current-result{background:#f9fafb;border-radius:6px;padding:16px;margin-bottom:24px;border-left:4px solid #6b7280}.current-result.pass{background:#ecfdf5;border-left-color:#10b981}.current-result.fail{background:#fef2f2;border-left-color:#ef4444}.current-result.warn{background:#fffbeb;border-left-color:#f59e0b}.result-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:8px}.result-value{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#111827}.status-badge{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}.status-badge.warn{background:#f59e0b}.status-badge.info{background:#6b7280}.result-message{margin-top:8px;font-size:13px;color:#6b7280}.accepted-values-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:12px}.value-chip{background:#f3f4f6;color:#374151;padding:6px 12px;border-radius:6px;font-size:13px;font-weight:500;text-align:center;font-family:ui-monospace,monospace;border:1px solid #e5e7eb}.accepted-values-categories .value-category{margin-bottom:16px}.accepted-values-categories .value-category:last-child{margin-bottom:0}.accepted-values-categories h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#6b7280}.profile-rules{display:flex;flex-direction:column;gap:12px}.profile-rule{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.profile-name{font-weight:600;color:#374151;min-width:140px}.profile-rule .severity{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.05em}.profile-rule .severity.fail{background:#fee2e2;color:#991b1b}.profile-rule .severity.warn{background:#fef3c7;color:#92400e}.profile-rule .severity.info{background:#dbeafe;color:#1e40af}.profile-rule .threshold{font-size:13px;color:#6b7280;font-family:ui-monospace,monospace}.remediation{background:#eff6ff;border-radius:6px;padding:16px;border-left:4px solid #3b82f6}.remediation h3{color:#1e40af}.remediation p{color:#1e3a8a;font-weight:500}.learn-more-link{display:inline-flex;align-items:center;gap:6px;color:#2563eb;text-decoration:none;font-weight:600;font-size:14px;transition:color .2s}.learn-more-link:hover{color:#1d4ed8;text-decoration:underline}.check-detail-modal .modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}.check-detail-modal .primary-btn{background:#2563eb;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s}.check-detail-modal .primary-btn:hover{background:#1d4ed8;transform:translateY(-1px)}.check-detail-modal .primary-btn:active{transform:translateY(0)}@media (max-width: 640px){.check-detail-modal{max-width:95%;max-height:90vh}.check-detail-modal .modal-header,.check-detail-modal .modal-body{padding:16px}.check-detail-modal .modal-header h2{font-size:18px}.accepted-values-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.profile-rule{flex-direction:column;align-items:flex-start}.profile-name{min-width:auto}}.historical-comparison{margin-top:40px;padding:24px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.comparison-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.scans-table{overflow-x:auto}.scans-table table{width:100%;border-collapse:collapse;table-layout:auto;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.scans-table th{text-align:left;padding:10px 12px;background:#f9fafb;border-bottom:2px solid #e5e7eb;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.scans-table td{padding:12px;border-bottom:1px solid #f3f4f6;vertical-align:middle;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.scans-table tr:hover{background:#fafbfc}.status-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:500;white-space:nowrap;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.status-pill.pass{background:#ecfdf5;color:#047857;border:1px solid #d1fae5}.status-pill.fail{background:#fef2f2;color:#dc2626;border:1px solid #fee2e2}.status-icon{font-size:10px;font-weight:700}.profile-tag{display:inline-block;padding:2px 7px;background:#eff6ff;color:#1e40af;border:1px solid #dbeafe;border-radius:4px;font-size:11px;font-weight:500;white-space:nowrap;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.scan-id-link{color:#2563eb;text-decoration:none;font-family:Monaco,Menlo,Consolas,monospace;font-size:11px;transition:color .2s}.scan-id-link:hover{color:#1d4ed8;text-decoration:underline}.filename-cell{font-size:11px;color:#374151;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.date-cell{font-size:11px;color:#6b7280;white-space:nowrap;font-family:system-ui,-apple-system,Segoe UI,sans-serif}.loading{text-align:center;padding:40px;color:#6b7280}.scans-table th:nth-child(1),.scans-table td:nth-child(1){width:60px}.scans-table th:nth-child(2),.scans-table td:nth-child(2){width:100px}.scans-table th:nth-child(3),.scans-table td:nth-child(3){width:auto;min-width:150px}.scans-table th:nth-child(4),.scans-table td:nth-child(4){width:280px}.scans-table th:nth-child(5),.scans-table td:nth-child(5){width:110px}.scans-table th:nth-child(6),.scans-table td:nth-child(6){width:90px}.side-by-side-compare{padding:20px;max-width:1800px;margin:0 auto}.compare-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.compare-header h2{margin:0;font-size:28px;color:#1f2937}.view-toggle{display:flex;gap:10px}.view-toggle button{padding:8px 20px;border:1px solid #d1d5db;background:#fff;color:#6b7280;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.view-toggle button:hover{background:#f9fafb;border-color:#9ca3af}.view-toggle button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.scan-selectors{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px}.selector{display:flex;flex-direction:column;gap:8px}.selector label{font-weight:600;color:#374151;font-size:14px}.selector select{padding:12px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.selector select:hover{border-color:#9ca3af}.selector select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.loading{text-align:center;padding:40px;color:#6b7280;font-size:16px}.comparison-view{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden}.overview-comparison,.screenshots-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:0}.scan-column{padding:30px}.scan-column h3{margin:0 0 15px;font-size:18px;color:#1f2937;font-weight:600}.divider{width:2px;background:linear-gradient(to bottom,#e5e7eb,#d1d5db,#e5e7eb)}.status-badge-compact{display:inline-block;padding:6px 14px;border-radius:6px;font-weight:700;font-size:12px;letter-spacing:.5px;margin-bottom:20px}.status-badge-compact.pass{background:#dcfce7;color:#166534}.status-badge-compact.fail{background:#fee2e2;color:#991b1b}.metrics{display:flex;flex-direction:column;gap:10px}.metric{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f9fafb;border-radius:6px;border-left:3px solid #d1d5db}.metric.fail{border-left-color:#ef4444;background:#fef2f2}.metric.warn{border-left-color:#f59e0b;background:#fffbeb}.metric.info{border-left-color:#3b82f6;background:#eff6ff}.metric .label{font-weight:500;color:#6b7280;font-size:13px}.metric .value{font-weight:600;color:#1f2937;font-size:14px}.findings-comparison-table{padding:20px;overflow-x:auto}.findings-comparison-table table{width:100%;border-collapse:collapse;font-size:14px}.findings-comparison-table thead{background:#1f2937;color:#fff;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:10}.findings-comparison-table th{padding:14px 16px;text-align:left;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.8px}.findings-comparison-table tbody tr{border-bottom:1px solid #e5e7eb}.findings-comparison-table tbody tr:hover{background:#f9fafb}.findings-comparison-table td{padding:14px 16px;vertical-align:middle}.check-name{font-weight:500;color:#1f2937}.check-title{font-size:14px;margin-bottom:4px;font-weight:600}.check-category{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.check-result{font-size:14px;color:#1f2937;font-weight:500}.check-result.fail{background:#fef2f2;color:#991b1b}.check-result.warn{background:#fffbeb;color:#92400e}.check-result.info{background:#eff6ff;color:#1e40af}.check-value{display:block;padding:4px 0}.screenshot-container{display:flex;justify-content:center;align-items:flex-start;padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.screenshot{max-width:100%;height:auto;border-radius:4px;box-shadow:0 2px 8px #0000001a;object-fit:contain;display:block}.no-screenshot{padding:60px 20px;text-align:center;color:#9ca3af;background:#f9fafb;border-radius:8px;border:2px dashed #d1d5db}.empty-state{text-align:center;padding:80px 20px;color:#6b7280}.empty-state p{font-size:16px;margin:0}@media (max-width: 1200px){.overview-comparison,.screenshots-comparison{grid-template-columns:1fr}.divider{width:100%;height:2px}.scan-selectors{grid-template-columns:1fr}.findings-comparison-table{overflow-x:scroll}.findings-comparison-table table{min-width:900px}}.gallery-container{padding:32px;max-width:1400px;margin:0 auto;min-height:100vh;background:#f9fafb}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}.gallery-header h1{margin:0;font-size:28px;font-weight:700;color:#111827}.header-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.search-input{padding:10px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;width:180px;background:#fff}.search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.filter-select{padding:10px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#6366f1}.sort-btn,.refresh-btn{padding:10px 14px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-size:16px;cursor:pointer;transition:all .15s}.sort-btn:hover,.refresh-btn:hover{background:#f3f4f6}.loading-state,.empty-state{text-align:center;padding:80px 20px;color:#6b7280}.spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.gallery-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014;transition:all .2s ease;cursor:pointer;position:relative}.gallery-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.gallery-card.pass,.gallery-card.fail{border:1px solid #e5e7eb}.card-preview{position:relative;background:#f3f4f6;display:flex;align-items:center;justify-content:center;min-height:180px;max-height:280px;overflow:hidden}.card-preview img{max-width:100%;max-height:280px;object-fit:contain}.no-preview{color:#9ca3af;font-size:14px;padding:60px 20px}.status-badge{position:absolute;top:12px;right:12px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;box-shadow:0 2px 6px #0003}.status-badge.pass{background:#10b981}.status-badge.fail{background:#ef4444}.card-info{padding:16px}.card-info h3{margin:0 0 8px;font-size:14px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:#6b7280}.card-meta span{background:#f3f4f6;padding:2px 8px;border-radius:4px}.card-issues{margin-top:10px;display:flex;gap:8px}.issue-count{font-size:12px;color:#dc2626;background:#fef2f2;padding:2px 8px;border-radius:4px}.warn-count{font-size:12px;color:#d97706;background:#fffbeb;padding:2px 8px;border-radius:4px}.delete-btn{position:absolute;top:8px;left:8px;width:24px;height:24px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:16px;cursor:pointer;opacity:0;transition:opacity .2s;display:flex;align-items:center;justify-content:center;line-height:1}.gallery-card:hover .delete-btn{opacity:1}.delete-btn:hover{background:#ef4444}@media (max-width: 640px){.gallery-container{padding:16px}.gallery-header{flex-direction:column;align-items:flex-start}.header-controls,.search-input{width:100%}.gallery-grid{grid-template-columns:1fr}}.optimization-toolbox{padding:20px;max-width:900px;margin:0 auto}.toolbox-header{text-align:center;margin-bottom:40px}.toolbox-header h2{margin:0 0 10px;font-size:32px;color:#1f2937}.toolbox-header p{margin:0;color:#6b7280;font-size:16px}.upload-zone{border:3px dashed #d1d5db;border-radius:16px;padding:60px 40px;text-align:center;background:#f9fafb;cursor:pointer;transition:all .3s;margin-bottom:30px}.upload-zone:hover{border-color:#3b82f6;background:#eff6ff}.upload-zone.dragging{border-color:#3b82f6;background:#dbeafe;transform:scale(1.02)}.upload-zone.has-file{border-color:#10b981;background:#ecfdf5}.upload-icon{font-size:64px;margin-bottom:20px}.file-icon{font-size:64px;margin-bottom:20px;color:#10b981}.upload-text{font-size:18px;font-weight:600;color:#374151;margin:0 0 8px}.upload-hint{font-size:14px;color:#9ca3af;margin:0}.file-name{font-size:18px;font-weight:600;color:#059669;margin:0 0 8px}.file-size{font-size:14px;color:#6b7280;margin:0 0 15px}.change-file-btn{padding:8px 20px;background:#fff;border:2px solid #d1d5db;border-radius:8px;color:#374151;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.change-file-btn:hover{border-color:#3b82f6;color:#3b82f6}.error-message{padding:15px 20px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:14px;margin-bottom:20px}.optimization-options{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 4px #0000000d;margin-bottom:30px}.optimization-options h3{margin:0 0 25px;font-size:20px;color:#1f2937}.option-group{margin-bottom:25px}.option-group:last-child{margin-bottom:0}.option-group label{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:600;color:#374151;font-size:15px}.quality-value{color:#3b82f6;font-size:16px}.quality-slider{width:100%;height:8px;border-radius:4px;background:#e5e7eb;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.quality-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#3b82f6;cursor:pointer;box-shadow:0 2px 4px #0003}.quality-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#3b82f6;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.slider-labels{display:flex;justify-content:space-between;margin-top:5px;font-size:12px;color:#9ca3af}.checkbox-group{display:flex;flex-direction:column;gap:15px}.checkbox-label{display:flex!important;align-items:center;gap:10px;cursor:pointer;font-weight:500!important}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6}.action-buttons{display:flex;gap:15px;margin-bottom:30px}.btn{flex:1;padding:16px 32px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 6px -1px #3b82f64d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 12px -2px #3b82f666}.btn-secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.btn-secondary:hover:not(:disabled){border-color:#3b82f6;color:#3b82f6}.optimization-results{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 4px #0000000d}.optimization-results h3{margin:0 0 25px;font-size:20px;color:#1f2937}.savings-summary{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:30px;padding:20px;background:#f9fafb;border-radius:10px}.summary-card{flex:1;text-align:center;padding:20px;background:#fff;border-radius:8px;border:2px solid #e5e7eb}.summary-card.savings{border-color:#10b981;background:#ecfdf5}.card-label{font-size:13px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.card-value{font-size:24px;font-weight:700;color:#1f2937}.summary-card.savings .card-value{color:#059669}.percent{font-size:16px;color:#6b7280;margin-left:5px}.summary-arrow{font-size:32px;color:#d1d5db}.file-breakdown{border-top:2px solid #e5e7eb;padding-top:20px}.file-breakdown h4{margin:0 0 15px;font-size:16px;color:#374151;font-weight:600}.file-list{max-height:400px;overflow-y:auto}.file-result{padding:12px;background:#f9fafb;border-radius:6px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.file-result-name{font-size:14px;color:#374151;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:15px}.file-result-stats{display:flex;align-items:center;gap:10px;font-size:13px;color:#6b7280}.savings-badge{padding:4px 8px;background:#dcfce7;color:#166534;border-radius:4px;font-weight:600;font-size:12px}@media (max-width: 768px){.action-buttons,.savings-summary{flex-direction:column}.summary-arrow{transform:rotate(90deg)}.upload-zone{padding:40px 20px}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center}.app-header h1{margin:0 0 .5rem;font-size:2.5rem}.app-header p{margin:0;opacity:.9}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}.app-footer{background:#f5f5f5;padding:1rem;text-align:center;color:#666}.upload-form{max-width:600px;margin:0 auto;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.form-group input[type=file],.form-group select{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:4px;font-size:1rem}.file-info{margin-top:.5rem;font-size:.9rem;color:#666}button{background:#667eea;color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}button:hover:not(:disabled){background:#5568d3}button:disabled{background:#ccc;cursor:not-allowed}button.secondary{background:#6c757d}button.secondary:hover:not(:disabled){background:#5a6268}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c33}.results{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.results-header{padding:2rem;color:#fff}.results-header.pass{background:linear-gradient(135deg,#43a047,#66bb6a)}.results-header.fail{background:linear-gradient(135deg,#e53935,#ef5350)}.results-header h2{margin:0 0 1rem}.results-meta{display:flex;gap:2rem;flex-wrap:wrap}.results-meta p{margin:0}.results-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;padding:2rem;background:#f9f9f9}.summary-stat{text-align:center;padding:1rem;border-radius:4px;background:#fff}.summary-stat.fail{border-left:4px solid #e53935}.summary-stat.warn{border-left:4px solid #fb8c00}.summary-stat.info{border-left:4px solid #039be5}.stat-value{display:block;font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-label{display:block;font-size:.9rem;color:#666}.findings-list{padding:2rem}.findings-group{margin-bottom:2rem}.findings-group h3{margin:0 0 1rem;color:#333}.finding{background:#f9f9f9;border-left:4px solid #ccc;padding:1rem;margin-bottom:1rem;border-radius:4px}.finding.severity-fail{border-left-color:#e53935;background:#ffebee}.finding.severity-warn{border-left-color:#fb8c00;background:#fff3e0}.finding.severity-info{border-left-color:#039be5;background:#e1f5fe}.finding-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.finding-rule{font-weight:600;color:#333}.finding-location{font-size:.9rem;color:#666;font-family:monospace}.finding-message{margin:.5rem 0;color:#333}.finding-evidence{background:#f5f5f5;border:1px solid #ddd;padding:.5rem;border-radius:4px;overflow-x:auto;font-size:.9rem;margin:.5rem 0}.finding-remediation{background:#e8f5e9;padding:.75rem;border-radius:4px;margin-top:.5rem;font-size:.9rem}.finding-docs{display:inline-block;margin-top:.5rem;color:#667eea;text-decoration:none;font-weight:600}.finding-docs:hover{text-decoration:underline}.results-actions{padding:2rem;display:flex;gap:1rem;justify-content:center;border-top:1px solid #eee}.visual-preview{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a}.visual-preview h3{margin:0 0 15px;font-size:16px;font-weight:600;color:#333}.preview-controls{display:flex;gap:10px;margin-bottom:15px}.preview-controls button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.screenshot-btn{background:#3b82f6;color:#fff}.screenshot-btn:hover{background:#2563eb}.live-preview-btn{background:#10b981;color:#fff}.live-preview-btn:hover{background:#059669}.test-click-btn{background:#22c55e;color:#fff}.test-click-btn:hover{background:#16a34a}.preview-container{text-align:center}.preview-dimensions{margin-top:10px;font-size:12px;color:#666}.results-enhanced{max-width:1600px;margin:0 auto;padding:16px}.results-header{padding:16px 20px;border-radius:6px;margin-bottom:20px}.results-header.pass{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.results-header.fail{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.results-header h2{margin:0 0 10px;font-size:22px;font-weight:600}.results-meta{display:flex;gap:20px;font-size:13px}.results-meta span{opacity:.9}.results-meta strong{font-weight:600;opacity:1}.visual-preview{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:16px;margin-bottom:20px}.visual-preview h3{margin:0 0 12px;font-size:16px;color:#111827}.preview-container{display:flex;flex-direction:column;align-items:center;gap:8px}.preview-dimensions{font-size:12px;color:#6b7280;font-family:monospace}.things-to-fix{background:#fef2f2;border:1px solid #fee2e2;border-radius:6px;padding:16px;margin-bottom:20px}.things-to-fix h3{margin:0 0 14px;font-size:16px;color:#991b1b}.fix-item{background:#fff;border-left:3px solid #ef4444;padding:10px 12px;margin-bottom:8px;border-radius:3px}.fix-item:last-child{margin-bottom:0}.fix-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.fix-icon{font-size:14px;color:#ef4444}.fix-header strong{font-size:13px;color:#111827}.fix-remediation{margin:0;padding-left:20px;font-size:12px;color:#4b5563;line-height:1.5}.checks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}@media (max-width: 1400px){.checks-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1000px){.checks-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.checks-grid{grid-template-columns:1fr}}.checks-category{background:#fff;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.category-title{background:#f9fafb;padding:8px 12px;margin:0;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e7eb}.checks-list{padding:4px 0}.category-divider{background:#f3f4f6;padding:6px 12px;margin:0;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.category-divider span{font-size:10px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.check-row{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;border-bottom:1px solid #f3f4f6;transition:background-color .15s;min-height:32px}.check-row:last-child{border-bottom:none}.check-row:hover{background-color:#f9fafb}.check-label{display:flex;align-items:center;gap:8px;font-size:12px;color:#374151;font-weight:500;line-height:1.3}.check-status{font-size:14px;font-weight:700;min-width:18px;flex-shrink:0}.check-value{font-size:12px;font-weight:600;color:#111827;font-family:ui-monospace,monospace;white-space:nowrap}.results-actions{display:flex;gap:10px;justify-content:center;margin-top:20px}.results-actions button{padding:10px 20px;font-size:13px;font-weight:600;border-radius:5px;border:none;cursor:pointer;transition:all .2s}.results-actions button.primary{background:#2563eb;color:#fff}.results-actions button.primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.results-actions button.secondary{background:#6b7280;color:#fff}.results-actions button.secondary:hover{background:#4b5563;transform:translateY(-1px)}@media (max-width: 640px){.results-enhanced{padding:12px}.results-header{padding:12px 16px}.results-header h2{font-size:18px}.results-meta{flex-direction:column;gap:6px;font-size:12px}.results-actions{flex-direction:column}.results-actions button{width:100%}.check-label,.check-value{font-size:11px}}@media print{.results-enhanced{padding:0}.results-actions{display:none}.checks-grid{grid-template-columns:repeat(2,1fr);gap:10px}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
