:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.snapshot-list{padding:1rem;overflow-y:auto;height:100%}.snapshot-list-loading{display:flex;align-items:center;justify-content:center;height:100%}.test-header{padding:1.25rem;background:linear-gradient(135deg,#667eea15,#764ba215);margin-bottom:1rem;border-radius:10px;border:2px solid #667eea30}.test-header-title{font-weight:700;color:#667eea;font-size:1.1rem;margin-bottom:.5rem}.test-header-stats{font-size:.8rem;color:#666}.snapshot-item{padding:1.25rem;border:2px solid #e0e0e0;border-radius:10px;margin-bottom:.75rem;cursor:pointer;transition:all .2s;background:#fff}.snapshot-item:hover{border-color:#667eea;transform:translate(4px)}.snapshot-item.active{border-color:#667eea;background:linear-gradient(135deg,#667eea10,#764ba210)}.snapshot-title{font-weight:700;color:#1e1e1e;margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:center}.edit-btn{padding:.375rem .75rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:.8rem;cursor:pointer;font-weight:600;transition:background .2s}.edit-btn:hover{background:#5568d3}.action-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.8rem;font-weight:700}.badge-fill{background:#e3f2fd;color:#1976d2}.badge-click{background:#fce4ec;color:#c2185b}.badge-goto{background:#f3e5f5;color:#7b1fa2}.action-value{font-size:.875rem;color:#2e7d32;font-weight:600;margin-top:.5rem;padding:.5rem;background:#e8f5e9;border-radius:6px;word-break:break-all}.action-selector{font-size:.75rem;color:#666;margin-top:.5rem;font-family:Monaco,Courier New,monospace;word-break:break-all}.snapshot-viewer{width:100%;height:100%;padding:2rem}.snapshot-viewer-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#666;font-size:1.1rem}.snapshot-iframe{width:100%;height:100%;border:2px solid #e0e0e0;border-radius:12px;background:#fff}.action-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:flex-end;z-index:10000;padding:120px 30px 30px;overflow-y:auto}.action-modal{background:#fff;padding:2.5rem 1.5rem 1.5rem;border-radius:12px;box-shadow:0 10px 40px #0000004d;width:420px;max-height:calc(100vh - 160px);overflow-y:auto;position:relative;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#f5f5f5;color:#333}.modal-title{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem}.element-info{background:linear-gradient(135deg,#667eea15,#764ba215);padding:1rem;border-radius:10px;font-size:.8rem;margin-bottom:1.5rem;border:2px solid #667eea30}.element-info.warning{background:#fff3e0;border-color:#f57c00;color:#f57c00}.element-info-header{color:#667eea;font-weight:700;margin-bottom:.5rem}.element-info.warning .element-info-header{color:#f57c00}.element-info-row{margin-bottom:.5rem}.element-info-row strong{color:#667eea}.element-info-row code{background:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem}.xpath-row{margin-top:.75rem}.xpath-value{font-size:.7rem;background:#fff;padding:.5rem;border-radius:6px;word-break:break-all;font-family:Monaco,Courier New,monospace;margin-top:.25rem}.alternatives-toggle{margin-top:.5rem;padding:.5rem;background:#fff;border:1px solid #667eea;color:#667eea;border-radius:6px;cursor:pointer;width:100%;text-align:left;font-size:.75rem;font-weight:600}.alternatives-toggle:hover{background:#f5f5f5}.alternatives-list{margin-top:.75rem;max-height:200px;overflow-y:auto}.alternative-item{background:#fff;padding:.75rem;border-radius:6px;margin-bottom:.5rem;cursor:pointer;border:2px solid transparent;transition:all .2s}.alternative-item:hover{border-color:#667eea;transform:translate(2px)}.alternative-item.primary{border-color:#2e7d32;background:#e8f5e9}.alt-label{font-weight:700;font-size:.75rem;margin-bottom:.25rem;display:flex;justify-content:space-between;align-items:center}.primary-badge{background:#2e7d32;color:#fff;padding:.125rem .375rem;border-radius:4px;font-size:.65rem}.alt-xpath{font-size:.65rem;font-family:Monaco,Courier New,monospace;color:#666;word-break:break-all;margin-bottom:.25rem}.alt-confidence{font-size:.65rem;font-weight:600;text-transform:uppercase}.confidence-high{color:#2e7d32}.confidence-medium{color:#f57c00}.confidence-low{color:#d32f2f}.modal-field{margin-bottom:1.25rem}.modal-field label{display:block;font-weight:700;margin-bottom:.5rem;font-size:.875rem}.modal-field select,.modal-field input,.modal-field textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.875rem;font-family:inherit}.modal-field textarea{font-family:Monaco,Courier New,monospace;resize:vertical;min-height:80px}.modal-field select:focus,.modal-field input:focus,.modal-field textarea:focus{outline:none;border-color:#667eea}.selection-hint{padding:.75rem;background:#fff3e0;border-radius:8px;font-size:.8rem;color:#f57c00;margin-bottom:1rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.modal-actions button{flex:1;padding:.875rem;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s}.btn-delete{background:#dc3545;color:#fff;flex:.5}.btn-delete:hover{background:#c82333}.btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-confirm:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.test-modification-editor{display:flex;flex-direction:column;height:100vh;width:100%;background:#f5f7fa;overflow:hidden}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#fff;border-bottom:2px solid #e5e7eb;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.header-left h1{font-size:1.5rem;margin:0;color:#1e293b;font-weight:700}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:.9rem;color:#64748b;transition:all .2s}.back-btn:hover{background:#f8fafc;border-color:#667eea;color:#667eea}.header-actions{display:flex;gap:.75rem}.header-actions button{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s}.header-actions button:hover{background:#5568d3;transform:translateY(-1px)}.editor-container{display:flex;flex:1;overflow:hidden;gap:0}.snapshots-panel{width:400px;min-width:350px;max-width:500px;background:#fff;border-right:2px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden;resize:horizontal}.panel-header{padding:1rem 1.5rem;background:#f8fafc;border-bottom:2px solid #e5e7eb;font-weight:700;color:#334155;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.viewer-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f7fa}.controls{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fff;border-bottom:2px solid #e5e7eb;flex-shrink:0;flex-wrap:wrap}.controls button{padding:.5rem 1rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;color:#475569;transition:all .2s}.controls button:hover:not(:disabled){border-color:#667eea;color:#667eea}.controls button:disabled{opacity:.5;cursor:not-allowed}.mode-buttons{display:flex;gap:.5rem;margin-left:auto}.mode-btn{padding:.5rem 1rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;color:#475569;transition:all .2s}.mode-btn:hover{border-color:#667eea;color:#667eea}.mode-btn.active{background:#667eea;border-color:#667eea;color:#fff}.mode-badge{display:inline-flex;align-items:center;padding:.5rem 1rem;background:#f8fafc;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;font-weight:600;color:#64748b;transition:all .3s}.mode-badge.selecting{background:#fef3c7;border-color:#fbbf24;color:#92400e;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.loading-spinner{width:50px;height:50px;border:5px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.editor-loading p{color:#64748b;font-size:1rem}.editor-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:2rem;text-align:center;gap:1rem}.editor-error h2{color:#dc2626;margin:0}.editor-error p{color:#64748b;max-width:500px}.error-actions{display:flex;gap:1rem;margin-top:1rem}.error-actions button{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.error-actions button:hover{background:#5568d3}@media(max-width:1024px){.snapshots-panel{width:350px;min-width:300px}}@media(max-width:768px){.editor-container{flex-direction:column}.snapshots-panel{width:100%;max-width:100%;height:40vh;border-right:none;border-bottom:2px solid #e5e7eb}.viewer-pane{height:60vh}.controls{flex-wrap:wrap;gap:.5rem}.mode-buttons{margin-left:0;width:100%}}.test-selection-container{display:flex;flex-direction:column;height:100vh;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.selection-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;box-shadow:0 2px 8px #00000026;display:flex;justify-content:space-between;align-items:flex-start}.header-content h1{font-size:2rem;font-weight:700;margin-bottom:1rem}.project-info{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem;opacity:.9}.project-info>div{display:flex;gap:.5rem}.project-info strong{opacity:.8}.refresh-btn{padding:.75rem 1.5rem;border:none;background:#fff3;color:#fff;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s}.refresh-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.test-list-container{flex:1;overflow-y:auto;padding:2rem}.test-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem;max-width:1400px;margin:0 auto}.test-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:1rem}.test-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 24px #667eea33}.test-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.test-name{font-size:1.25rem;font-weight:700;color:#1e1e1e;margin:0;flex:1}.status-badge{display:inline-block;padding:.375rem .75rem;border-radius:6px;font-size:.8rem;font-weight:700;white-space:nowrap}.status-passed{background:#e8f5e9;color:#2e7d32}.status-failed{background:#ffebee;color:#c62828}.status-running{background:#fff3e0;color:#f57c00}.status-pending{background:#e3f2fd;color:#1976d2}.status-unknown{background:#f5f5f5;color:#666}.test-card-body{flex:1}.test-meta{display:flex;flex-direction:column;gap:.5rem}.meta-item{display:flex;gap:.5rem;font-size:.875rem}.meta-label{color:#666;font-weight:600;min-width:80px}.meta-value{color:#1e1e1e;font-family:Monaco,Courier New,monospace;word-break:break-all}.test-card-footer{padding-top:1rem;border-top:1px solid #e0e0e0}.edit-test-btn{width:100%;padding:.75rem;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.edit-test-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.5rem;color:#666;margin-bottom:.5rem}.empty-state p{color:#999;margin-bottom:1.5rem}.empty-state button{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.empty-state button:hover{background:#5568d3;transform:translateY(-2px)}@media(max-width:768px){.test-list{grid-template-columns:1fr}.selection-header{flex-direction:column;gap:1rem}.refresh-btn{align-self:flex-start}}#root{width:100%;height:100vh;margin:0;padding:0;overflow:hidden}
