.compare-page{margin:15px;padding:2rem}.compare-page h1{margin-bottom:1.5rem}.compare-page p{color:#666}.top-nav-bar{background:#a3c5e8;border:1px solid #e2e8f0;margin-bottom:1rem;padding:.5rem}.top-nav-links{gap:.4rem;display:inline-flex}.top-nav-link{color:#334155;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;padding:.45rem .85rem;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.top-nav-link:hover{background:#f1f5f9}.top-nav-link.active{color:#1d4ed8;background:#dbeafe;border-color:#2563eb}.compare-inputs{grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem;display:grid}.input-group{background:#f8f8f8;border:1px solid #ddd;border-radius:8px;padding:1.5rem}.input-group h2{margin-top:0;margin-bottom:1rem;font-size:1.1rem}.input-group label{margin-bottom:.3rem;font-size:.9rem;font-weight:600;display:block}.input-group input{box-sizing:border-box;border:1px solid #ccc;border-radius:4px;width:100%;margin-bottom:.75rem;padding:.5rem;font-size:.95rem}.compare-actions{flex-wrap:wrap;gap:1rem;margin-bottom:2rem;display:flex}.compare-actions button{cursor:pointer;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;transition:background .2s}.btn-quick{color:#fff;background:#0070f3}.btn-quick:hover{background:#005bb5}.btn-full{color:#fff;background:#7928ca}.btn-full:hover{background:#5a1d9e}.btn-custom{color:#fff;background:#ff6b00}.btn-custom:hover{background:#c50}.compare-actions button:disabled{opacity:.5;cursor:not-allowed}.reports-filter-bar{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem;display:grid}.reports-filter-group{gap:.35rem;display:grid}.reports-filter-group label{color:#334155;font-size:.82rem;font-weight:700}.reports-filter-group input{border:1px solid #cbd5e1;border-radius:8px;padding:.5rem .65rem;font-size:.9rem}.test-runs-panel{background:#fafafa;border:1px solid #ddd;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.test-runs-panel-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.test-runs-panel-header h2{margin:0 0 .35rem}.test-runs-panel-header p{color:#666;margin:0}.test-runs-empty,.test-runs-error{border-radius:6px;margin:0;padding:.9rem 1rem}.test-runs-empty{color:#4b5563;background:#f3f4f6}.test-runs-error{color:#b91c1c;background:#fef2f2}.test-runs-table-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow-x:auto}.test-runs-pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1rem;display:flex}.test-runs-pagination-button{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:.5rem 1rem;font-size:.85rem}.test-runs-pagination-button:hover:not(:disabled){background:#f1f5f9}.test-runs-pagination-button:disabled{opacity:.5;cursor:not-allowed}.test-runs-pagination-status{color:#475569;font-size:.85rem}.test-runs-table,.test-run-tests-table{border-collapse:collapse;width:100%}.test-runs-table th,.test-runs-table td,.test-run-tests-table th,.test-run-tests-table td{text-align:left;padding:.85rem 1rem}.test-runs-table thead th,.test-run-tests-table thead th{color:#475569;letter-spacing:.03em;text-transform:uppercase;background:#f8fafc;border-bottom:1px solid #e5e7eb;font-size:.78rem;font-weight:700}.test-runs-table-row td,.test-run-tests-table tbody td{border-bottom:1px solid #eef2f7}.test-run-tests-table{border-collapse:separate;border-spacing:0 .65rem}.test-run-tests-table thead th{background:#e8eef5;border-bottom:1px solid #d5dee8}.test-run-module-row td{background:#fff;border-top:1px solid #dbe4ee;border-bottom:1px solid #dbe4ee;box-shadow:0 1px #0f172a05}.test-run-module-row td:first-child{border-left:1px solid #dbe4ee;border-top-left-radius:12px;border-bottom-left-radius:12px}.test-run-module-row td:last-child{border-right:1px solid #dbe4ee;border-top-right-radius:12px;border-bottom-right-radius:12px}.test-run-module-row:hover td{background:#f8fbff;border-color:#c7d4e2}.test-runs-table-actions{white-space:nowrap;width:1%}.test-run-test-cell-td{vertical-align:middle;padding:.8rem .9rem}.vertical-align-top{vertical-align:top}.test-run-log-preview-cell{gap:.5rem;display:grid}.test-run-toggle-group{flex-wrap:nowrap;align-items:center;gap:.5rem;display:flex;overflow-x:auto}.test-run-toggle-group>button{flex:none}.test-run-log-toggle-button,.test-run-http-log-toggle-button,.test-run-resource-toggle-button{color:#334155;cursor:pointer;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;width:fit-content;padding:.45rem .7rem;font-size:.8rem;font-weight:600;transition:background-color .12s,border-color .12s,color .12s}.test-run-log-toggle-button:hover,.test-run-http-log-toggle-button:hover,.test-run-resource-toggle-button:hover{background:#e2e8f0}.test-run-log-toggle-button[aria-expanded=true],.test-run-http-log-toggle-button[aria-expanded=true],.test-run-resource-toggle-button[aria-expanded=true]{color:#166534;background:#dcfce7;border-color:#86efac}.test-run-log-toggle-button[aria-expanded=true]:hover,.test-run-http-log-toggle-button[aria-expanded=true]:hover,.test-run-resource-toggle-button[aria-expanded=true]:hover{background:#bbf7d0}.test-run-primary-cell,.test-run-test-cell,.test-run-log-cell,.test-run-summary-inline{vertical-align:middle;gap:.35rem;font-size:13px;display:grid}.test-run-primary-cell{min-width:15rem}.test-run-key-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;width:100%;display:grid}.test-run-time-cell,.test-run-facts-cell{gap:.45rem;min-width:10rem;display:grid}:is(.test-run-time-cell,.test-run-facts-cell) .test-run-test-cell{gap:.15rem}:is(.test-run-time-cell,.test-run-facts-cell) .test-run-test-cell strong{font-size:.92rem;line-height:1.25}:is(.test-run-time-cell,.test-run-facts-cell) .test-run-test-cell span{color:#64748b;letter-spacing:.01em;font-size:.78rem}:is(.test-run-time-cell,.test-run-facts-cell) .test-run-log-cell strong{color:#334155;font-size:.76rem}:is(.test-run-time-cell,.test-run-facts-cell) .test-run-log-cell span{color:#0f172a;line-height:1.4}.test-run-meta-pair{gap:.1rem;padding:5px;font-size:13px;display:grid}.test-run-key-row .test-run-meta-pair{width:100%}.test-run-meta-label{color:#6b7280;letter-spacing:.02em;text-transform:uppercase;font-size:.76rem;font-weight:600}.test-run-primary-cell strong,.test-run-test-cell strong,.test-run-log-cell strong{color:#000}.test-run-primary-cell span,.test-run-test-cell span,.test-run-log-cell span{color:#000;font-size:.88rem}.test-run-status{text-transform:capitalize;color:#374151;background:#e5e7eb;border-radius:999px;align-items:center;padding:.35rem .7rem;font-size:.8rem;font-weight:700;display:inline-flex}.test-run-status.running{color:#1d4ed8;background:#dbeafe}.test-run-status.error,.test-run-module-status.error{color:#fee2e2;background:#f59820}.test-run-status.done,.test-run-module-status.done{color:#166534;background:#dcfce7}.test-run-status.fail,.test-run-status.failed,.test-run-module-status.fail,.test-run-module-status.failed{color:#b91c1c;background:#fee2e2}.test-run-status.pass,.test-run-module-status.pass{color:#15803d;background:#dcfce7}.test-run-status.pending,.test-run-module-status.pending{color:#1d4ed8;background:#dbeafe}.test-run-summary-inline{color:#475569;gap:.25rem;font-size:.88rem;display:grid}.test-run-facts-cell{color:#475569;font-size:.88rem}.test-run-details-button{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:.45rem .75rem;font-size:.88rem;font-weight:600}.test-run-details-button:hover{background:#f8fafc}.test-runs-detail-row{background:#a3c5e8;padding:5px}.test-runs-detail-row td{padding:5px}.test-runs-detail-panel{padding:1rem}.test-runs-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;margin-bottom:1rem;display:grid}.test-run-detail-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.9rem 1rem}.test-run-detail-card h3{color:#0f172a;margin:0 0 .75rem;font-size:.92rem}.test-run-detail-list{gap:.65rem;margin:0;display:grid}.test-run-detail-list div{gap:.15rem;display:grid}.test-run-detail-list dt{color:#64748b;letter-spacing:.03em;text-transform:uppercase;font-size:.76rem;font-weight:700}.test-run-detail-list dd{color:#111827;margin:0;font-size:.9rem}.test-run-log-detail-row td{background:#f3f4f6;border-left:8px solid #22c55e;padding:.9rem .75rem .9rem 3rem}.test-run-expanded-panel{background:#fff;border:1px solid #d1d5db;border-radius:10px;overflow:hidden}.test-run-expanded-panel-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:.65rem;padding:.65rem .85rem;display:flex}.test-run-expanded-panel-header h4{color:#1f2937;letter-spacing:.01em;margin:0;font-size:.86rem;font-weight:700}.test-run-expanded-panel-header span{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;font-size:.76rem;font-weight:700}.test-run-log-panel,.test-run-http-log-panel,.test-run-resource-panel{border-color:#d1d5db}.test-run-log-scrollbox{background:#fff;max-height:14rem;padding:.75rem .85rem;overflow-y:auto}.test-run-log-raw{color:#111827;white-space:pre-wrap;word-break:break-word;margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.82rem;line-height:1.5}.test-run-log-empty{color:#6b7280;background:#fff;margin:0;padding:.85rem;font-size:.88rem}.test-run-log-entry{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;gap:.25rem;margin-bottom:.5rem;padding:.58rem .6rem;display:grid}.test-run-log-entry:last-child{margin-bottom:0}.test-run-log-entry strong{color:#4b5563;font-size:.78rem}.test-run-log-entry span{color:#111827;white-space:pre-wrap;word-break:break-word;font-size:.88rem;line-height:1.45}.test-run-resource-list{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.test-run-resource-chip{color:#1f2937;white-space:nowrap;text-overflow:ellipsis;background:#f9fafb;border:1px solid #e5e7eb;border-radius:999px;align-items:center;max-width:min(100%,22rem);padding:.32rem .6rem;font-size:.78rem;font-weight:600;text-decoration:none;display:inline-flex;overflow:hidden}.test-run-resource-chip:hover{background:#f3f4f6;border-color:#d1d5db}.test-run-zip-download{flex-wrap:wrap;gap:.6rem;margin-bottom:1rem;display:flex}.test-run-zip-download-button{color:#fff;background:#2563eb;border:1px solid #1d4ed8;border-radius:8px;align-items:center;gap:.4rem;padding:.5rem .9rem;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex}.test-run-zip-download-button:hover{background:#1d4ed8;border-color:#1e40af}.test-run-module-status{text-transform:capitalize;border-radius:999px;justify-content:center;align-items:center;min-width:5.5rem;padding:.3rem .65rem;font-size:.85rem;font-weight:700;display:inline-flex}.test-run-module-status.running{color:#1d4ed8;background:#dbeafe}.test-run-status-cell{justify-items:start;gap:.45rem;display:grid}.test-run-status-cell.inline{flex-direction:row;justify-items:start;display:flex}.test-run-retry-button{color:#991b1b;cursor:pointer;background:#fff5f5;border:1px solid #b91c1c;border-radius:8px;padding:.35rem .65rem;font-size:.78rem;font-weight:700}.test-run-retry-button:hover:enabled{background:#fee2e2}.test-run-retry-button:disabled{cursor:not-allowed;opacity:.65}.test-run-tests-table tbody tr:last-child td{border-bottom:none}.test-runs-table thead th,.test-runs-table tbody td.text-center{text-align:center}.test-runs-table thead th.text-left{text-align:left}@media (max-width:900px){.compare-inputs,.reports-filter-bar{grid-template-columns:1fr}.test-runs-table th,.test-runs-table td,.test-run-tests-table th,.test-run-tests-table td{padding:.7rem .8rem}.test-run-summary-inline{min-width:8rem}.test-runs-detail-grid,.test-run-key-row{grid-template-columns:1fr}}.compare-results{background:#fafafa;border:1px solid #ddd;border-radius:8px;padding:1.5rem}.compare-results h2{margin-top:0;margin-bottom:1rem}.test-list{margin:0;padding:0;list-style:none}.test-item{border-bottom:1px solid #eee;font-size:.95rem}.test-item:last-child{border-bottom:none}.test-item-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;padding:.6rem 0;display:flex}.test-item-header:hover{background:#00000005}.test-progress-circle{width:22px;height:22px;transform:rotate(-90deg)}.test-progress-track{fill:none;stroke:#0000001f;stroke-width:2.5px}.test-progress-indicator{fill:none;stroke:#3b82f6cc;stroke-width:2.5px;stroke-linecap:round;transition:stroke-dasharray .3s}.test-expand-arrow{color:#999;flex-shrink:0;width:16px;font-size:.7rem;transition:transform .15s}.test-expand-arrow.expanded{transform:rotate(90deg)}.test-logs{color:#d4d4d4;background:#1e1e1e;border-radius:6px;max-height:400px;margin:0 0 .5rem 38px;padding:.75rem 1rem;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;line-height:1.6;overflow:auto}.test-logs .log-line{white-space:pre}.test-logs .log-ts{color:#6a9955;margin-right:.5rem}.test-logs .log-msg{color:#d4d4d4}.test-logs .log-msg.error{color:#f48771}.test-logs .log-msg.match{color:#6a9955}.test-logs .log-msg.mismatch{color:#f48771}.test-icon{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex}.test-icon.pending,.test-icon.running{color:#3b82f6;background:0 0}.test-icon.pass,.test-icon.done{background:#22c55e}.test-icon.fail,.test-icon.failed{background:#ef4444}.test-label{flex:1}.test-label.pending{color:#3b82f6}.test-label.pass,.test-label.done{color:#16a34a}.test-label.fail,.test-label.failed{color:#dc2626}.pointer{cursor:pointer}@media (max-width:700px){.test-run-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.test-run-card-header,.test-run-module-item{flex-direction:column;align-items:flex-start}}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:10px;min-width:400px;max-width:500px;padding:2rem;box-shadow:0 10px 40px #0003}.modal-content h2{margin-top:0;margin-bottom:.5rem}.modal-content p{color:#666;margin-bottom:1rem;font-size:.9rem}.custom-mode-options{grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem;display:grid}.mode-option{cursor:pointer;border:1px solid #ddd;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem;transition:border-color .2s,background .2s;display:flex}.mode-option.active{background:#fff6ef;border-color:#ff6b00}.mode-option input{margin:0}.file-drop-zone{text-align:center;color:#999;cursor:pointer;border:2px dashed #ccc;border-radius:8px;margin-bottom:1rem;padding:2rem;transition:border-color .2s}.file-drop-zone:hover{border-color:#ff6b00}.file-drop-zone.has-file{color:#16a34a;border-color:#22c55e}.random-config{border:1px solid #eee;border-radius:8px;margin-bottom:1rem;padding:1rem}.random-config label{margin-bottom:.4rem;font-weight:600;display:block}.random-config input{box-sizing:border-box;border:1px solid #ccc;border-radius:6px;width:100%;margin-bottom:.75rem;padding:.5rem}.btn-randomize{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:6px;padding:.45rem .8rem;font-size:.85rem}.btn-randomize:hover{background:#1f2937}.random-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;max-height:170px;margin-top:.9rem;padding:.75rem;overflow-y:auto}.random-preview-title{margin-bottom:.4rem;font-weight:600}.random-preview-item{color:#374151;margin-bottom:.25rem;font-size:.85rem}.custom-tests-config{border:1px solid #eee;border-radius:8px;margin-bottom:1rem;padding:1rem}.custom-tests-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.custom-tests-header label{font-weight:600}.custom-tests-actions{gap:.4rem;display:flex}.btn-test-action{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:.25rem .45rem;font-size:.8rem}.btn-test-action:hover{background:#f9fafb}.custom-tests-list{border:1px solid #f1f5f9;border-radius:6px;max-height:220px;overflow-y:auto}.custom-test-item{border-bottom:1px solid #f1f5f9;align-items:center;gap:.55rem;padding:.45rem .6rem;font-size:.88rem;display:flex}.custom-test-item:last-child{border-bottom:none}.custom-test-item.selected{background:#fff6ef}.custom-test-item input{margin:0}.custom-tests-warning{color:#b45309;margin-top:.55rem;font-size:.82rem}.report-actions{margin-top:.75rem}.btn-download-report{color:#fff;cursor:pointer;background:#111827;border:none;border-radius:6px;padding:.55rem .95rem;font-weight:600}.btn-download-report:hover{background:#1f2937}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.modal-actions button{cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.btn-cancel{color:#333;background:#eee}.btn-cancel:hover{background:#ddd}.btn-upload{color:#fff;background:#ff6b00}.btn-upload:hover{background:#c50}.btn-upload:disabled{opacity:.5;cursor:not-allowed}.compare-summary{border-radius:6px;margin-top:1rem;padding:.75rem 1rem;font-size:.95rem;font-weight:600}.compare-summary.all-pass{color:#16a34a;background:#dcfce7}.compare-summary.has-failures{color:#dc2626;background:#fef2f2}@media (max-width:700px){.compare-inputs{grid-template-columns:1fr}.modal-content{width:calc(100vw - 2rem);min-width:auto;max-width:500px}.custom-mode-options{grid-template-columns:1fr}}.test-run-tests-table{background:#a3c5e8;border-radius:8px}.resources-row td{background-color:#0000;padding:0 0 5px}
.cockpit-bg{background:#c89a75}.pim-bg{background:#8b96dd}.progress-bar{background-color:#e0e0e0;border-radius:10px;width:100%;height:10px;overflow:hidden}.progress-bar-fill{background-color:#4caf50;height:100%}
