.app{min-height:100vh;overflow-x:hidden;position:relative}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--card-background)}::-webkit-scrollbar-thumb{background:var(--chat-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--chat-secondary)}::selection{background:#3b82f6}::-moz-selection{background:#3b82f6}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}*,:after,:before{cursor:default}.MuiFilledInput-input,.MuiInput-input,.MuiInputBase-input,.MuiOutlinedInput-input,.MuiTextField-root input,.MuiTextField-root textarea,[contenteditable=true],input,textarea{cursor:text!important}.MuiAvatar-root,.MuiButton-root,.MuiCheckbox-root,.MuiChip-root,.MuiIconButton-root,.MuiListItem-root,.MuiListItemButton-root,.MuiMenuItem-root,.MuiRadio-root,.MuiSwitch-root,.MuiTab-root,[role=button],[role=menuitem],[role=tab],a,button{cursor:pointer!important}.MuiAccordion-root,.MuiAccordionDetails-root,.MuiAccordionSummary-root,.MuiAlert-root,.MuiAlertTitle-root,.MuiAvatar-root,.MuiBadge-root,.MuiBox-root,.MuiCard-root,.MuiCardContent-root,.MuiCardHeader-root,.MuiChip-deleteIcon,.MuiChip-label,.MuiDialog-root,.MuiDialogContent-root,.MuiDialogTitle-root,.MuiPaper-root,.MuiSkeleton-root,.MuiStep-root,.MuiStepContent-root,.MuiStepLabel-root,.MuiStepper-root,.MuiTabPanel-root,.MuiTable-root,.MuiTableBody-root,.MuiTableCell-root,.MuiTableCell-root:hover,.MuiTableContainer-root,.MuiTableHead-root,.MuiTableRow-root,.MuiTableRow-root:hover,.MuiTabs-root,.MuiTooltip-root,.MuiTypography-root{cursor:default!important}.MuiAvatar-root,.MuiButton-root,.MuiCheckbox-root,.MuiChip-root,.MuiIconButton-root,.MuiListItem-root,.MuiListItemButton-root,.MuiMenuItem-root,.MuiRadio-root,.MuiSwitch-root,.MuiTab-root{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}div,h1,h2,h3,h4,h5,h6,label,p,span,td,th,tr{cursor:default!important}html{scroll-behavior:smooth}.app-loading{opacity:0;transform:translateY(20px);transition:all .3s ease}.app-loaded{opacity:1;transform:translateY(0)}@media (max-width:768px){.app{background:var(--background-color)}}@media print{.app{background:#fff;color:#000}.app:before{display:none}}.error-banner{align-items:center;animation:slideDown .3s ease-out;background:#d32f2f;box-shadow:0 2px 8px #00000026;color:#fff;display:flex;justify-content:space-between;left:0;padding:12px 20px;position:fixed;right:0;top:0;z-index:1000}.error-banner span{font-size:14px;font-weight:500}.error-close{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:18px;padding:4px 8px;transition:background-color .2s}.error-close:hover{background-color:#ffffff1a}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:999}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#1976d2;height:40px;width:40px}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.error-banner{font-size:13px;padding:10px 16px}.loading-spinner{height:32px;width:32px}}:root{--primary-gradient:linear-gradient(135deg,#0099f7,#0052d4);--primary-start:#0099f7;--primary-end:#0052d4;--primary-light:#4fc3f7;--primary-dark:#003d82;--secondary:#43e6c2;--secondary-light:#80cbc4;--secondary-dark:#26a69a;--accent-gold:#ffb86b;--accent-coral:#ff6f61;--accent-mint:#a8e6cf;--bg-primary:#0f1216;--bg-secondary:#1a1d21;--bg-tertiary:#25282c;--bg-card:#ffffff0d;--bg-glass:#ffffff14;--text-primary:#fff;--text-secondary:#b0b7c3;--text-muted:#8a8f98;--text-inverse:#0f1216;--border-primary:#ffffff1a;--border-secondary:#ffffff0d;--border-accent:#43e6c24d;--shadow-light:#0000001a;--shadow-medium:#0003;--shadow-heavy:#0006;--shadow-glow:#0099f74d;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-heading:"Montserrat","Inter",sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px 0 var(--shadow-light);--shadow-md:0 4px 6px -1px var(--shadow-medium);--shadow-lg:0 10px 15px -3px var(--shadow-medium);--shadow-xl:0 20px 25px -5px var(--shadow-heavy);--shadow-glow:0 0 20px var(--shadow-glow);--transition-fast:150ms ease-in-out;--transition-normal:250ms ease-in-out;--transition-slow:350ms ease-in-out;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--glass-bg:#ffffff0d;--glass-border:#ffffff1a;--glass-shadow:0 8px 32px 0 #0000005e;--glass-backdrop:blur(10px)}[data-theme=dark]{--bg-primary:#0f1216;--bg-secondary:#1a1d21;--bg-tertiary:#25282c}[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#e9ecef;--text-primary:#0f1216;--text-secondary:#495057;--text-muted:#6c757d}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0f1216;background:var(--bg-primary);color:#fff;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:1rem;font-size:var(--font-size-base);font-weight:400;font-weight:var(--font-weight-normal);line-height:1.6;margin:0;padding:0}.text-xs{font-size:.75rem;font-size:var(--font-size-xs)}.text-sm{font-size:.875rem;font-size:var(--font-size-sm)}.text-base{font-size:1rem;font-size:var(--font-size-base)}.text-lg{font-size:1.125rem;font-size:var(--font-size-lg)}.text-xl{font-size:1.25rem;font-size:var(--font-size-xl)}.text-2xl{font-size:1.5rem;font-size:var(--font-size-2xl)}.text-3xl{font-size:1.875rem;font-size:var(--font-size-3xl)}.text-4xl{font-size:2.25rem;font-size:var(--font-size-4xl)}.font-light{font-weight:300;font-weight:var(--font-weight-light)}.font-normal{font-weight:400;font-weight:var(--font-weight-normal)}.font-medium{font-weight:500;font-weight:var(--font-weight-medium)}.font-semibold{font-weight:600;font-weight:var(--font-weight-semibold)}.font-bold{font-weight:700;font-weight:var(--font-weight-bold)}.text-primary{color:#fff;color:var(--text-primary)}.text-secondary{color:#b0b7c3;color:var(--text-secondary)}.text-muted{color:#8a8f98;color:var(--text-muted)}.p-xs{padding:.25rem;padding:var(--spacing-xs)}.p-sm{padding:.5rem;padding:var(--spacing-sm)}.p-md{padding:1rem;padding:var(--spacing-md)}.p-lg{padding:1.5rem;padding:var(--spacing-lg)}.p-xl{padding:2rem;padding:var(--spacing-xl)}.m-xs{margin:.25rem;margin:var(--spacing-xs)}.m-sm{margin:.5rem;margin:var(--spacing-sm)}.m-md{margin:1rem;margin:var(--spacing-md)}.m-lg{margin:1.5rem;margin:var(--spacing-lg)}.m-xl{margin:2rem;margin:var(--spacing-xl)}.rounded-sm{border-radius:4px;border-radius:var(--radius-sm)}.rounded-md{border-radius:8px;border-radius:var(--radius-md)}.rounded-lg{border-radius:12px;border-radius:var(--radius-lg)}.rounded-xl{border-radius:16px;border-radius:var(--radius-xl)}.rounded-2xl{border-radius:24px;border-radius:var(--radius-2xl)}.rounded-full{border-radius:9999px;border-radius:var(--radius-full)}:root{--chat-primary:#1e2a78;--chat-secondary:#14b8a6;--chat-background:#f9fafb;--chat-highlight:#facc15;--chat-coral:#fb7185;--chat-text-dark:#1f2937;--chat-text-light:#6b7280;--chat-border:#e5e7eb;--chat-shadow:0 1px 3px #0000001a;--chat-shadow-hover:0 4px 12px #00000026}.query-chat.dark-theme{--chat-background:#1a1d21;--chat-text-dark:#fff;--chat-text-light:#b0b7c3;--chat-border:#ffffff1a;--chat-shadow:0 1px 3px #0000004d;--chat-shadow-hover:0 4px 12px #0006}::selection{background-color:#3b82f6;color:#fff}::-moz-selection{background-color:#3b82f6;color:#fff}.message-text::selection{background-color:#3b82f6;color:#fff}.message-text::-moz-selection{background-color:#3b82f6;color:#fff}.input-container textarea::selection{background-color:#3b82f6;color:#fff}.input-container textarea::-moz-selection{background-color:#3b82f6;color:#fff}.query-chat{background:#f9fafb;background:var(--chat-background);border:1px solid #e5e7eb;border:1px solid var(--chat-border);border-radius:16px;box-shadow:0 1px 3px #0000001a;box-shadow:var(--chat-shadow);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;height:600px;overflow:hidden}.chat-header{background:linear-gradient(135deg,#1e2a7899,#1f293780);color:#fffffff2;padding:1rem 1.5rem;position:relative;text-align:center}.chat-header:after{background:linear-gradient(90deg,#0000,#14b8a6,#0000);background:linear-gradient(90deg,#0000,var(--chat-secondary),#0000);bottom:0;content:"";height:1px;left:0;position:absolute;right:0}.chat-header h3{font-size:1.2rem;font-weight:600;letter-spacing:-.025em;margin:0 0 .3rem}.chat-header p{font-size:.9rem;font-weight:400;margin:0;opacity:.8}.chat-messages{background:#f9fafb;background:var(--chat-background);flex:1 1;overflow-y:auto;padding:1.5rem}.message{animation:messageSlideIn .3s ease-out;display:flex;flex-direction:column;margin-bottom:1.2rem}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-items:flex-end}.message-content,.message.bot{align-items:flex-start}.message-content{display:flex;gap:.75rem;max-width:85%}.message.user .message-content{flex-direction:row-reverse}.bot-avatar{align-items:center;background:linear-gradient(135deg,#1e2a78e6,#14b8a6cc);border:2px solid #fff;border-radius:50%;display:flex;flex-shrink:0;font-size:1.1rem;height:36px;justify-content:center;width:36px}.bot-avatar,.message-text{box-shadow:0 1px 3px #0000001a;box-shadow:var(--chat-shadow)}.message-text{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:16px;color:#1f2937;color:var(--chat-text-dark);font-size:.95rem;line-height:1.6;padding:1rem 1.25rem;position:relative;transition:box-shadow .2s ease}.query-chat.dark-theme .message-text{background:#ffffff0d;border:1px solid #e5e7eb;border:1px solid var(--chat-border)}.message-text:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--chat-shadow-hover)}.message.user .message-text{background:#fff;border:1px solid #14b8a6;border:1px solid var(--chat-secondary);box-shadow:0 2px 8px #14b8a61a;color:#1f2937;color:var(--chat-text-dark)}.query-chat.dark-theme .message.user .message-text{background:#14b8a61a;border:1px solid #14b8a64d;box-shadow:0 2px 8px #14b8a633}.message.user .message-text:hover{box-shadow:0 4px 16px #14b8a626}.query-chat.dark-theme .message.user .message-text:hover{box-shadow:0 4px 16px #14b8a64d}.message.error .message-text{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.query-chat.dark-theme .message.error .message-text{background:#dc26261a;border:1px solid #dc26264d;color:#ff6b6b}.message-timestamp{color:#6b7280;color:var(--chat-text-light);font-size:.75rem;font-weight:400;margin-left:3rem;margin-top:.5rem}.message.user .message-timestamp{margin-left:0;margin-right:3rem;text-align:right}.typing-indicator{align-items:center;display:flex;gap:.25rem;padding:.5rem 0}.typing-indicator span{animation:typing 1.4s ease-in-out infinite;background:#14b8a6;background:var(--chat-secondary);border-radius:50%;height:6px;width:6px}.typing-indicator span:first-child{animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-input{border-top:1px solid #e5e7eb;border-top:1px solid var(--chat-border);padding:1.5rem;position:relative}.chat-input,.input-container{background:#f9fafb;background:var(--chat-background)}.input-container{align-items:flex-end;border:2px solid #0000;border-radius:20px;box-shadow:0 1px 3px #0000001a;box-shadow:var(--chat-shadow);display:flex;gap:.75rem;padding:.75rem;transition:all .2s ease}.input-container:focus-within{background:#fff;border-color:#14b8a6;border-color:var(--chat-secondary);box-shadow:0 4px 16px #14b8a61a}.query-chat.dark-theme .input-container:focus-within{background:#ffffff1a;box-shadow:0 4px 16px #14b8a633}.input-container textarea{background:#0000;border:none;color:#1f2937;color:var(--chat-text-dark);flex:1 1;font-family:inherit;font-size:.95rem;line-height:1.5;max-height:120px;min-height:24px;outline:none;padding:.5rem .75rem;resize:none}.input-container textarea::placeholder{color:#6b7280;color:var(--chat-text-light);font-weight:400}.send-button{align-items:center;background:linear-gradient(135deg,#1e2a78e6,#14b8a6cc);border:none;border-radius:50%;box-shadow:0 1px 3px #0000001a;box-shadow:var(--chat-shadow);color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.1rem;height:44px;justify-content:center;position:relative;transition:all .2s ease;width:44px}.send-button:before{background:#1f2937;background:var(--chat-text-dark);border-radius:6px;color:#fff;content:attr(data-tooltip);font-size:.8rem;margin-bottom:.5rem;padding:.5rem .75rem;white-space:nowrap}.send-button:after,.send-button:before{bottom:100%;left:50%;opacity:0;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s ease}.send-button:after{border:4px solid #0000;border-top:4px solid var(--chat-text-dark);content:"";margin-bottom:-4px}.send-button:hover:not(:disabled){box-shadow:0 6px 20px #1e2a784d;transform:scale(1.05)}.send-button:hover:not(:disabled):after,.send-button:hover:not(:disabled):before{opacity:1}.send-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#0000}.chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width:768px){.query-chat{border-radius:12px;height:500px}.message-content{max-width:90%}.chat-header{padding:1rem 1.5rem}.chat-header h3{font-size:1.2rem}.chat-input,.chat-messages{padding:1rem}.input-container{border-radius:16px;padding:.5rem}}.ui-explorer{margin:0 auto;max-width:1200px;padding:2rem}.explorer-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.header-content h2{color:#2e2e2e;font-size:1.8rem;font-weight:600;margin:0 0 .5rem}.header-content p{color:#6b7280;font-size:1rem;line-height:1.5;margin:0}.explore-button{background:linear-gradient(90deg,#0099f7,#0052d4);border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;min-width:180px;padding:.75rem 1.5rem;transition:all .2s ease}.explore-button:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.explore-button:disabled{cursor:not-allowed;opacity:.7}.explore-button.running{background:#6b7280}.exploration-status{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-bottom:2rem;padding:1rem}.status-indicator{align-items:center;color:#0369a1;display:flex;font-weight:500;gap:.75rem}.spinner{border:2px solid #e5e7eb;border-top-color:#0099f7;height:20px;width:20px}.exploration-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:2rem;padding:1rem}.error-content{align-items:center;color:#dc2626;display:flex;font-weight:500;gap:.75rem}.empty-state{background:#f9fafb;border-radius:12px;margin:2rem 0;padding:4rem 2rem;text-align:center}.empty-content{margin:0 auto;max-width:500px}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-content h3{color:#2e2e2e;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.empty-content p{color:#6b7280;line-height:1.6;margin:0 0 2rem}.feature-list{display:flex;flex-direction:column;gap:.75rem;text-align:left}.feature-item{align-items:center;color:#6b7280;display:flex;font-size:.95rem;gap:.75rem}.feature-icon{font-size:1.2rem;min-width:24px}.knowledge-section{margin-bottom:3rem}.knowledge-section h3{color:#2e2e2e;font-size:1.4rem;font-weight:600;margin:0 0 .5rem}.knowledge-section p{color:#6b7280;font-size:1rem;margin:0 0 1.5rem}.loading-knowledge{align-items:center;background:#f9fafb;border-radius:8px;color:#6b7280;display:flex;font-weight:500;gap:.75rem;padding:2rem}.knowledge-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.knowledge-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1.5rem;transition:all .2s ease}.knowledge-card:hover:not(.empty){border-color:#d1d5db;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.knowledge-card.empty{background:#f9fafb;opacity:.6}.card-header{align-items:center;display:flex;gap:.75rem;margin-bottom:1rem}.card-icon{font-size:1.5rem}.card-title{color:#2e2e2e;flex:1 1;font-weight:600}.card-count{background:#f3f4f6;border-radius:12px;color:#6b7280;font-size:.875rem;font-weight:600;padding:.25rem .75rem}.card-content{color:#6b7280;line-height:1.5}.empty-message{color:#9ca3af;font-style:italic;margin:0}.card-description{font-size:.95rem;margin:0}.test-cases-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin:2rem 0;padding:2rem 2.5rem;width:100%}.section-header{align-items:flex-end;border-bottom:1px solid #e5e7eb;display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.section-header h3{color:#2e2e2e;font-size:1.4rem;font-weight:700;letter-spacing:-.5px;margin:0}.section-actions{align-items:center;display:flex;gap:1rem}.section-stats{display:flex;gap:2.5rem;margin-left:auto}.stat{align-items:center;display:flex;flex-direction:column;gap:.15rem;min-width:70px}.stat-label{color:#9ca3af;font-size:.72rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase}.stat-value{color:#2e2e2e;font-size:1.15rem;font-weight:700}.stat-value.pending{color:#f59e0b}.stat-value.approved{color:#10b981}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#2e2e2e;font-size:1.3rem;font-weight:600;margin:0}.modal-close{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.25rem;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#2e2e2e}.modal-body{max-height:calc(80vh - 80px);overflow-y:auto;padding:1.5rem}.modal-list{display:flex;flex-direction:column;gap:1rem}.modal-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.modal-item h4{color:#2e2e2e;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.modal-item p{color:#6b7280;font-size:.95rem;line-height:1.5;margin:0 0 .75rem}.item-meta{align-items:center;display:flex;font-size:.85rem;gap:.5rem;margin:.5rem 0 0}.meta-label{color:#9ca3af;font-weight:500;min-width:50px}.meta-value{background:#f3f4f6;border-radius:4px;color:#374151;font-weight:500;padding:.2rem .5rem}.item-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{background:#e5e7eb;border-radius:12px;color:#6b7280;font-size:.75rem;font-weight:500;padding:.25rem .75rem}@media (max-width:768px){.ui-explorer{padding:1rem}.explorer-header{align-items:stretch;flex-direction:column;gap:1rem}.header-actions{display:flex;justify-content:center}.knowledge-grid{grid-template-columns:1fr}.section-header{align-items:stretch;flex-direction:column;gap:1rem}.section-stats{justify-content:space-around}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}}.refresh-button{align-items:center;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border:none;border-radius:6px;box-shadow:0 1px 3px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.refresh-button:hover:not(:disabled){box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.refresh-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.loading-message{color:#6b7280;font-style:italic;padding:2rem;text-align:center}.empty-message{color:#6b7280;padding:2rem .5rem;text-align:center}.empty-message p{margin:.5rem 0}@media (max-width:900px){.test-cases-section{padding:1.2rem .5rem}.section-header{align-items:flex-start;flex-direction:column;gap:.5rem}.section-stats{gap:1.2rem;margin-left:0}}.detect-features-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.detect-features-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.detect-features-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.modal-item .feature-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.feature-meta-item{background:#f8f9fa;border-radius:4px;color:#6c757d;font-size:.8rem;padding:.25rem .5rem}.feature-meta-item.high-value{background:#d4edda;color:#155724}.feature-meta-item.medium-value{background:#fff3cd;color:#856404}.feature-meta-item.low-value{background:#f8d7da;color:#721c24}.test-cases-modal{max-height:70vh;overflow-y:auto}.test-cases-header{border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.test-cases-header h4{color:#2e2e2e;font-size:1.2rem;font-weight:600;margin:0 0 .5rem}.test-cases-header p{color:#6b7280;font-size:.95rem;margin:0}.test-cases-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.table-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;font-size:.9rem;font-weight:600}.table-header,.table-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1fr 1fr 1fr;padding:1rem}.table-row{border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.table-row:hover{background:#f9fafb}.table-row:last-child{border-bottom:none}.table-cell{align-items:center;display:flex;font-size:.9rem}.title-cell{align-items:flex-start;flex-direction:column;gap:.25rem}.title-cell strong{color:#2e2e2e;font-weight:600}.test-case-description{color:#6b7280;font-size:.85rem;line-height:1.4;margin:0}.category-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.category-badge.authentication{background:#dbeafe;color:#1e40af}.category-badge.catalog{background:#d1fae5;color:#065f46}.category-badge.cart{background:#fef3c7;color:#92400e}.category-badge.checkout{background:#fce7f3;color:#be185d}.category-badge.unknown{background:#f3f4f6;color:#6b7280}.status-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.status-badge.approved{background:#d1fae5;color:#065f46}.status-badge.rejected{background:#fef2f2;color:#dc2626}.status-badge.pending{background:#fef3c7;color:#92400e}.source-badge{background:#e0e7ff;border-radius:12px;color:#3730a3;font-size:.8rem;font-weight:500;padding:.25rem .75rem}@media (max-width:768px){.table-header,.table-row{gap:.5rem;grid-template-columns:1fr}.table-cell{justify-content:flex-start}.header-cell{display:none}.table-row{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:.5rem;padding:.75rem}.table-row:last-child{margin-bottom:0}}.card-actions{border-top:1px solid #e5e7eb;margin-top:.75rem;padding-top:.75rem}.run-automation-button{background:linear-gradient(90deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 1px 3px #0000001a;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;width:100%}.run-automation-button:hover:not(:disabled){background:linear-gradient(90deg,#059669,#047857);box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.run-automation-button:disabled{cursor:not-allowed;opacity:.7}.error-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.error-container{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:40px;text-align:center;width:100%}.error-icon{animation:bounce 2s infinite;font-size:4rem;margin-bottom:20px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.error-title{color:#2d3748;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:2rem;font-weight:700;margin-bottom:16px}.error-message{color:#718096;font-size:1.1rem;line-height:1.6;margin-bottom:24px}.error-details{margin:24px 0;text-align:left}.error-details details{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.error-details summary{color:#4a5568;cursor:pointer;font-weight:600;margin-bottom:12px}.error-details summary:hover{color:#2d3748}.error-code{background:#edf2f7;border-radius:4px;color:#4a5568;font-family:Courier New,monospace;font-size:.9rem;margin:8px 0;padding:8px;word-break:break-word}.error-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin:32px 0}.error-button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.error-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.error-button.primary:hover{box-shadow:0 8px 16px #667eea4d;transform:translateY(-2px)}.error-button.secondary{background:#f7fafc;border:2px solid #e2e8f0;color:#4a5568}.error-button.secondary:hover{background:#edf2f7;border-color:#cbd5e0;transform:translateY(-2px)}.error-help{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:24px}.error-help p{color:#718096;font-size:.9rem;margin:0}@media (max-width:600px){.error-container{margin:10px;padding:24px}.error-title{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{align-items:center;flex-direction:column}.error-button{max-width:200px;width:100%}}.stratovai-loader-container{background:radial-gradient(circle at 60% 40%,#f8fafc 0,#f1f5f9 100%);height:100vh;left:0;min-height:100vh;position:fixed;top:0;width:100vw;z-index:9999}.stratovai-loader-container,.stratovai-loader-svg{align-items:center;display:flex;justify-content:center}.stratovai-loader-svg{flex-direction:column}.stratovai-loader-arc{animation:stratovai-spin 1.2s linear infinite;transform-origin:48px 48px}@keyframes stratovai-spin{to{transform:rotate(1turn)}}.stratovai-loader-dot{animation:stratovai-bounce 1.2s cubic-bezier(.4,0,.2,1) infinite}@keyframes stratovai-bounce{0%,to{cy:20}50%{cy:76}}.stratovai-loader-text{margin-top:1.5rem;text-align:center}.stratovai-loader-brand{color:#2563eb;display:block;font-size:2rem;font-weight:700;letter-spacing:.08em;text-shadow:0 2px 8px #2563eb14}.stratovai-loader-sub{color:#64748b;display:block;font-size:1.05rem;font-weight:500;letter-spacing:.04em;margin-top:.25rem}.user-manager{margin:0 auto;max-width:1200px;padding:20px}.user-manager-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.user-manager-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin:0}.impersonation-status{position:relative}.impersonation-banner{align-items:center;animation:pulse 2s infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:25px;box-shadow:0 4px 15px #667eea4d;color:#fff;display:flex;gap:15px;padding:10px 20px}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.end-impersonation-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:15px;color:#fff;cursor:pointer;font-size:.9rem;padding:5px 15px;transition:all .3s ease}.end-impersonation-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.user-manager-tabs{border-bottom:1px solid #e0e0e0;display:flex;gap:10px;margin-bottom:30px;padding-bottom:10px}.user-manager-tabs button{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#6c757d;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .3s ease}.user-manager-tabs button:hover{background:#e9ecef;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.user-manager-tabs button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 15px #667eea4d;color:#fff}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;justify-content:space-between;margin-bottom:20px;padding:15px}.error-message,.error-message button{align-items:center;color:#721c24;display:flex}.error-message button{background:none;border:none;cursor:pointer;font-size:1.5rem;height:30px;justify-content:center;padding:0;width:30px}.loading{align-items:center;color:#6c757d;display:flex;font-size:1.2rem;justify-content:center;padding:40px}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:30px;margin-right:15px;width:30px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.tab-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:30px}.users-tab{grid-gap:30px;display:grid;gap:30px}.create-user-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;padding:25px}.create-user-section h3{color:#2c3e50;font-size:1.5rem;margin:0 0 20px}.create-user-form{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group{display:flex;flex-direction:column}.form-group label{color:#495057;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:12px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group.checkbox{align-items:center;flex-direction:row;gap:10px}.form-group.checkbox input{height:20px;width:20px}button[type=submit]{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;grid-column:1/-1;justify-self:start;padding:12px 30px;transition:all .3s ease}button[type=submit]:hover{box-shadow:0 6px 20px #667eea4d;transform:translateY(-2px)}button[type=submit]:disabled{cursor:not-allowed;opacity:.6;transform:none}.users-list h3{color:#2c3e50;font-size:1.5rem;margin:0 0 20px}.users-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.user-card{background:#fff;border:1px solid #e9ecef;border-radius:10px;padding:20px;transition:all .3s ease}.user-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-5px)}.user-info h4{color:#2c3e50;font-size:1.3rem;margin:0 0 10px}.user-info p{color:#6c757d;margin:5px 0}.super-admin-badge{background:linear-gradient(135deg,gold,#ffed4e);border-radius:15px;color:#856404;display:inline-block;font-size:.8rem;font-weight:600;margin-top:10px;padding:4px 12px}.user-projects{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.user-projects strong{color:#495057}.user-projects ul{margin:10px 0 0;padding-left:20px}.user-projects li{color:#6c757d;margin:5px 0}.projects-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.project-card{background:#fff;border:1px solid #e9ecef;border-radius:10px;padding:20px;transition:all .3s ease}.project-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-3px)}.project-card h4{color:#2c3e50;font-size:1.3rem;margin:0 0 15px}.project-card p{color:#6c757d;margin:8px 0}.project-selector{margin-bottom:30px}.project-selector h3{color:#2c3e50;margin:0 0 15px}.project-selector select{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;max-width:400px;padding:12px;width:100%}.assign-user-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;margin-bottom:30px;padding:25px}.assign-user-form{grid-gap:20px;display:grid;gap:20px}.permissions-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:10px}.permission-checkbox{align-items:center;background:#fff;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background-color .3s ease}.permission-checkbox:hover{background:#e9ecef}.permission-checkbox input{height:16px;width:16px}.project-users-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.project-user-card{background:#fff;border:1px solid #e9ecef;border-radius:10px;padding:20px;position:relative}.role-badge{border-radius:15px;display:inline-block;font-size:.8rem;font-weight:600;margin-top:10px;padding:4px 12px}.role-super_admin{background:linear-gradient(135deg,gold,#ffed4e);color:#856404}.role-project_admin{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.role-project_manager{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.role-project_user{background:linear-gradient(135deg,#6c757d,#495057);color:#fff}.user-permissions{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.user-permissions ul{margin:10px 0 0;padding-left:20px}.user-permissions li{color:#6c757d;font-size:.9rem;margin:3px 0}.remove-user-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;position:absolute;right:15px;top:15px;transition:all .3s ease}.remove-user-btn:hover{background:#c82333;transform:scale(1.05)}.impersonation-info{background:#e3f2fd;border:1px solid #bbdefb;border-radius:10px;margin-bottom:30px;padding:20px}.impersonation-info h3{color:#1976d2;margin:0 0 10px}.impersonation-info p{color:#1565c0;margin:0}.impersonation-form{grid-gap:20px;display:grid;gap:20px;margin-bottom:30px;max-width:500px}.impersonation-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:10px;color:#856404;padding:20px}.impersonation-warning h4{color:#856404;margin:0 0 15px}.impersonation-warning ul{margin:0;padding-left:20px}.impersonation-warning li{margin:8px 0}.access-denied{color:#6c757d;padding:60px 20px;text-align:center}.access-denied h2{font-size:2rem;margin:0 0 20px}@media (max-width:768px){.user-manager{padding:15px}.user-manager-header{flex-direction:column;gap:20px;text-align:center}.user-manager-header h1{font-size:2rem}.user-manager-tabs{flex-wrap:wrap}.user-manager-tabs button{flex:1 1;min-width:120px}.tab-content{padding:20px}.create-user-form,.permissions-grid,.project-users-grid,.projects-grid,.users-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.02e6adef.css.map*/