*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#f8fafc;color:#1e293b}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}.app{display:flex;height:100vh}.sidebar{width:260px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;flex-shrink:0}.env-config{padding:12px;border-bottom:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0}.env-config-title{font-size:12px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.env-config-field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.env-config-field:last-child{margin-bottom:0}.env-config-field label{font-size:11px;font-weight:500;color:#64748b}.env-config-field input{width:100%;padding:7px 8px;border:1px solid #cbd5e1;border-radius:6px;font-size:12px;background:#fff}.env-config-field input:focus{outline:2px solid #38bdf8;border-color:#38bdf8}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:16px;font-weight:600;border-bottom:1px solid #e2e8f0}.case-list{list-style:none;margin:0;padding:8px 0;overflow-y:auto;flex:1}.case-list li{display:flex;align-items:center}.case-check{display:flex;align-items:center;padding:0 4px 0 10px;flex-shrink:0;cursor:pointer}.case-check input{width:14px;height:14px;accent-color:#0ea5e9;cursor:pointer}.sidebar-run-all{padding:8px 12px;border-bottom:1px solid #e2e8f0;display:flex;flex-direction:column;gap:8px}.btn-gen-defaults{width:100%;font-size:12px}.btn-run-all{width:100%;font-size:13px;padding:8px 12px}.sidebar-io{display:flex;gap:8px;padding:10px 12px;border-top:1px solid #e2e8f0;flex-shrink:0}.sidebar-io-btn{flex:1}.sidebar-io-file{display:none}.case-item{flex:1;display:flex;align-items:center;min-width:0;padding:10px 8px 10px 16px;border:none;background:none;font-size:14px;color:#475569;text-align:left}.case-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;flex-shrink:0}.case-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.case-list-empty{padding:12px 16px;color:#94a3b8;font-size:13px}.case-name-field,.case-name-field input{min-width:200px}.case-item:hover{background:#f1f5f9}.case-item.active{background:#e0f2fe;color:#0369a1;font-weight:500}.case-delete{border:none;background:none;color:#94a3b8;font-size:18px;padding:4px 10px;line-height:1}.case-delete:hover{color:#ef4444}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:16px;gap:12px}.progress-bar-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;flex-shrink:0}.progress-bar-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;font-size:13px}.progress-bar-label{font-weight:500;color:#334155}.progress-bar-count{font-size:12px;color:#64748b;font-variant-numeric:tabular-nums;flex-shrink:0}.progress-bar-track{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#0ea5e9,#38bdf8);border-radius:999px;transition:width .25s ease}.progress-bar-fill.indeterminate{width:40%!important;animation:progress-indeterminate 1.2s ease-in-out infinite}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(350%)}}.config-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:12px;color:#64748b;font-weight:500}.field input,.field select{padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;min-width:180px}.field input:focus,.field select:focus{outline:2px solid #38bdf8;border-color:#38bdf8}.btn{padding:8px 16px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;font-size:14px;font-weight:500}.btn:hover{background:#f8fafc}.btn-primary{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.btn-primary:hover{background:#0284c7}.btn-success{background:#22c55e;color:#fff;border-color:#22c55e}.btn-success:hover{background:#16a34a}.btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.btn-sm{padding:4px 10px;font-size:12px;border:1px solid #cbd5e1;border-radius:4px;background:#fff}.content-row{display:flex;gap:12px;flex:1;min-height:0}.content-row .split-pane,.match-column-single{flex:1;min-width:0}.section-rules-panel{width:220px;flex-shrink:0;display:flex;flex-direction:column;background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;min-height:0}.section-rules-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;font-weight:600;border-bottom:1px solid #e2e8f0;background:#f8fafc}.section-rules-legend{font-size:11px;font-weight:500;color:#94a3b8}.section-rules-list{list-style:none;margin:0;padding:6px 0;overflow-y:auto;flex:1}.section-rules-item{display:flex;align-items:center;gap:4px;padding:6px 8px 6px 10px;font-size:12px}.section-rules-item:hover{background:#f8fafc}.section-rules-check{display:flex;align-items:center;gap:2px;cursor:pointer;flex-shrink:0}.section-rules-check input{width:13px;height:13px;margin:0;accent-color:#0ea5e9;cursor:pointer}.section-rules-check-label{font-size:10px;color:#94a3b8;width:18px}.section-rules-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#334155;font-weight:500}.section-rules-empty{margin:0;padding:12px;font-size:12px;color:#94a3b8;line-height:1.4}.split-pane{display:flex;flex:1;min-height:0;min-width:0;gap:0}.split-pane-panel{display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.match-column{display:flex;flex-direction:column;height:100%;min-height:0;gap:0}.match-column .json-panel{flex:1;min-height:0;border-radius:8px 8px 0 0}.match-footer{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px;padding:12px;background:#fff;border:1px solid #e2e8f0;border-top:none;border-radius:0 0 8px 8px;flex-shrink:0}.match-id-field{flex:1;min-width:200px}.match-id-field input{width:100%;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px}.baseline-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;background:#dbeafe;color:#1d4ed8}.split-pane-left{flex-shrink:0}.split-pane-right{flex:1}.split-pane-divider{width:6px;flex-shrink:0;cursor:col-resize;background:#e2e8f0;position:relative;transition:background .15s}.split-pane-divider:hover,.split-pane-divider:active{background:#0ea5e9}.split-pane-divider:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:32px;border-radius:1px;background:#94a3b8}.split-pane-divider:hover:after,.split-pane-divider:active:after{background:#fff}.json-panel{flex:1;display:flex;flex-direction:column;min-width:0;height:100%}.json-legend{display:flex;align-items:center;gap:12px;font-size:11px;font-weight:400;color:#64748b}.legend-check{display:inline-flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.json-body{flex:1;overflow:auto;padding:8px 10px;background:#fafafa;font-family:Consolas,Monaco,monospace;font-size:11px;line-height:1.45}.json-empty{margin:0;color:#94a3b8;font-family:system-ui,sans-serif;font-size:13px}.json-line{display:flex;align-items:flex-start;flex-wrap:wrap;gap:1px;min-height:18px;background:#fff;border-radius:2px}.json-line-passed{background:#dcfce7}.json-line-failed{background:#fee2e2}.json-key{color:#881391}.json-colon{color:#334155}.json-primitive{color:#1a1aa6;display:inline-flex;align-items:center;gap:2px;border-radius:2px;padding:0 2px}.json-primitive.json-passed{background:#bbf7d0}.json-primitive.json-failed{background:#fecaca}.json-bracket{color:#334155}.rule-cb{width:13px;height:13px;margin:2px 4px 0 0;flex-shrink:0;cursor:pointer;accent-color:#0ea5e9}.rule-cb-static{display:inline-block;width:13px;margin:2px 4px 0 0;flex-shrink:0;font-size:11px;line-height:1;color:#94a3b8;-webkit-user-select:none;user-select:none}.rule-cb-static.on{color:#0ea5e9}.legend-readonly{font-size:10px;color:#94a3b8;font-style:italic}.rule-cb-value{accent-color:#22c55e}.rule-cb-spacer{display:inline-block;width:13px;flex-shrink:0}.legend-passed{color:#166534;font-weight:500}.legend-failed{color:#991b1b;font-weight:500}.fail-info-btn{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:4px;padding:0;border:1px solid #dc2626;border-radius:50%;background:#fff;color:#dc2626;font-size:11px;font-weight:700;font-style:italic;font-family:Georgia,serif;line-height:1;flex-shrink:0;vertical-align:middle}.fail-info-btn:hover{background:#dc2626;color:#fff}.diff-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.diff-modal{background:#fff;border-radius:10px;box-shadow:0 20px 50px #0003;max-width:720px;width:100%;max-height:85vh;overflow:auto}.diff-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0}.diff-modal-header h3{margin:0;font-size:16px}.diff-close{border:none;background:none;font-size:24px;color:#94a3b8;line-height:1;padding:0 4px}.diff-close:hover{color:#334155}.diff-section{padding:12px 20px}.diff-section-baseline{background:#f0f9ff;border-bottom:1px solid #bae6fd}.diff-section-title{font-weight:600;color:#0369a1;margin-bottom:6px}.diff-meta{display:flex;flex-direction:column;gap:4px;font-size:13px;color:#475569}.diff-label{font-size:12px;font-weight:600;color:#64748b;margin-bottom:4px}.diff-path{font-size:12px;background:#f1f5f9;padding:4px 8px;border-radius:4px;word-break:break-all}.diff-message{font-size:13px;color:#991b1b}.diff-columns{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 20px 20px}.diff-col-title{font-size:12px;font-weight:600;margin-bottom:6px}.diff-col-baseline .diff-col-title{color:#0369a1}.diff-col-current .diff-col-title{color:#b45309}.diff-value{margin:0;padding:10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:11px;line-height:1.4;overflow:auto;max-height:200px;white-space:pre-wrap;word-break:break-all}.diff-col-baseline .diff-value{border-color:#7dd3fc;background:#f0f9ff}.diff-col-current .diff-value{border-color:#fcd34d;background:#fffbeb}.diff-meta-warn{color:#b45309;font-size:12px}.diff-actions{display:flex;flex-direction:column;gap:8px;padding:16px 20px 20px;border-top:1px solid #e2e8f0}.diff-accept-btn{align-self:flex-start}.diff-actions-hint{font-size:12px;color:#64748b}.panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.panel-header{padding:10px 14px;font-weight:600;font-size:13px;border-bottom:1px solid #e2e8f0;background:#f8fafc;display:flex;justify-content:space-between;align-items:center}.status-banner{padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500}.status-banner.passed{background:#dcfce7;color:#166534;border:1px solid #86efac}.status-banner.failed{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.status-banner.info{background:#e0f2fe;color:#075985;border:1px solid #7dd3fc}.failures-list{margin-top:8px;max-height:120px;overflow:auto;font-size:12px;font-family:monospace}.token-field input{min-width:280px}.api-log{font-size:12px}.api-log-entry{margin-top:4px;word-break:break-all}.api-status{display:inline-block;min-width:28px;padding:1px 6px;border-radius:4px;font-weight:600;margin-right:6px;text-align:center}.api-status.s200{background:#dcfce7;color:#166534}.api-status.s403,.api-status.s401{background:#fee2e2;color:#991b1b}.api-label{font-weight:600;margin-right:4px}
