*{box-sizing:border-box;margin:0;padding:0}:root{--primary-50: #f0fdfa;--primary-100: #ccfbf1;--primary-200: #99f6e4;--primary-300: #5eead4;--primary-400: #2dd4bf;--primary-500: #14b8a6;--primary-600: #0d9488;--primary-700: #0f766e;--accent-400: #a78bfa;--accent-500: #8b5cf6;--accent-600: #7c3aed;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .3);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .08)}body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:linear-gradient(135deg,#f0fdfa,#f3f4f6,#faf5ff);background-attachment:fixed;color:var(--gray-800);min-height:100vh}.app{display:flex;flex-direction:column;height:100vh;background:transparent}.app-header{position:fixed;top:0;left:0;right:0;padding:16px 24px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);box-shadow:0 4px 20px #0000000a;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:24px}.assistant-title{display:flex;align-items:center;gap:12px}.assistant-title-name{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.test-case-selector{display:flex;align-items:center;gap:12px;flex:1;justify-content:flex-end}.test-case-selector label{font-size:13px;font-weight:600;color:var(--gray-600);white-space:nowrap}.group-id-select{padding:10px 40px 10px 16px;border:1px solid var(--gray-200);border-radius:12px;font-size:14px;font-weight:500;background:#fff;color:var(--gray-800);cursor:pointer;min-width:400px;max-width:500px;outline:none;transition:all .2s ease;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;box-shadow:0 1px 3px #0000000a}.group-id-select:hover{border-color:var(--primary-300);box-shadow:0 2px 8px #14b8a61a}.group-id-select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #14b8a626,0 2px 8px #14b8a61a}.group-id-select:disabled{opacity:.5;cursor:not-allowed;background-color:var(--gray-50)}.test-case-detail-btn{padding:10px 16px;border:1px solid var(--primary-300);border-radius:12px;font-size:14px;font-weight:600;background:linear-gradient(135deg,var(--primary-50) 0%,white 100%);color:var(--primary-700);cursor:pointer;transition:all .2s ease;white-space:nowrap}.test-case-detail-btn:hover{background:linear-gradient(135deg,var(--primary-100) 0%,var(--primary-50) 100%);border-color:var(--primary-400);box-shadow:0 2px 8px #14b8a626}.test-case-detail-btn:active{transform:translateY(1px)}.app-content{display:flex;flex:1;overflow:hidden;gap:16px;padding:80px 16px 16px;max-width:1900px;margin:0 auto;width:100%}.screenshot-section{width:420px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);overflow:hidden;display:flex;flex-direction:column;transition:width .3s ease,opacity .3s ease}.screenshot-section.collapsed{width:56px}.screenshot-panel{display:flex;flex-direction:column;height:100%}.screenshot-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--gray-100);background:#ffffff80}.screenshot-panel-header h3{font-size:15px;font-weight:700;color:var(--primary-700);margin:0}.screenshot-panel-actions,.screenshot-step-selector{display:flex;align-items:center;gap:8px}.step-select{padding:8px 32px 8px 12px;border:1px solid var(--gray-200);border-radius:10px;font-size:13px;font-weight:500;background:#fff;color:var(--gray-700);cursor:pointer;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:all .2s ease}.step-select:hover{border-color:var(--primary-300)}.step-select:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #14b8a626}.screenshot-collapse-btn{width:32px;height:32px;border:1px solid var(--gray-200);border-radius:8px;background:#fff;color:var(--gray-500);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s ease}.screenshot-collapse-btn:hover{border-color:var(--primary-300);color:var(--primary-600)}.screenshot-content{flex:1;overflow-y:auto;padding:16px;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}.screenshot-content::-webkit-scrollbar{width:6px}.screenshot-content::-webkit-scrollbar-track{background:transparent}.screenshot-content::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.screenshot-list{display:flex;flex-direction:column;gap:16px}.screenshot-card{background:#fff;border-radius:12px;border:2px solid var(--gray-200);overflow:hidden;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000000a}.screenshot-card:hover{border-color:var(--primary-300);box-shadow:0 8px 24px #14b8a626;transform:scale(1.02)}.screenshot-card.selected{border-color:var(--primary-500);box-shadow:0 8px 24px #14b8a640;transform:scale(1.03)}.screenshot-card.selected .screenshot-card-header{background:linear-gradient(135deg,var(--primary-50) 0%,var(--primary-100) 100%);border-bottom-color:var(--primary-200)}.screenshot-card-header{padding:12px 14px;background:var(--gray-50);border-bottom:1px solid var(--gray-100);display:flex;flex-direction:column;gap:4px}.screenshot-card-step{font-size:11px;font-weight:700;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-transform:uppercase;letter-spacing:.5px}.screenshot-card-action{font-size:13px;font-weight:500;color:var(--gray-700);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.screenshot-card-image{position:relative;background:var(--gray-100)}.screenshot-card-image img{width:100%;height:auto;display:block;transition:transform .3s ease}.screenshot-card:hover .screenshot-card-image img,.screenshot-card.selected .screenshot-card-image img{transform:scale(1.02)}.screenshot-card-no-image{display:flex;align-items:center;justify-content:center;min-height:120px;color:var(--gray-400);font-size:13px}.screenshot-card-summary{border-color:var(--accent-300);background:linear-gradient(135deg,#f59e0b0d,#f973160d)}.screenshot-card-summary .screenshot-card-header{background:linear-gradient(135deg,#f59e0b1a,#f973161a);border-bottom-color:var(--accent-200)}.screenshot-card-step-summary{background:linear-gradient(135deg,var(--accent-600) 0%,var(--accent-500) 100%)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.screenshot-card-summary.selected{border-color:var(--accent-500);box-shadow:0 8px 24px #f59e0b40}.screenshot-card-summary.selected .screenshot-card-header{background:linear-gradient(135deg,#f59e0b26,#f9731626)}.screenshot-loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--gray-400);font-size:14px}.screenshot-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:var(--gray-400);font-size:14px;text-align:center}.chat-section{flex:1;display:flex;flex-direction:column;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:24px 0;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.memory-section{width:380px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:20px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);overflow:hidden;display:flex;flex-direction:column;transition:width .3s ease,opacity .3s ease}.memory-section.collapsed{width:56px}.message-list{display:flex;flex-direction:column;gap:20px;max-height:100%;overflow-y:auto;padding:0 20px;margin:0 auto;width:100%;max-width:800px;scrollbar-width:none}.message-list::-webkit-scrollbar{display:none}.message-row{display:flex;width:100%}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message{padding:14px 18px;border-radius:16px;line-height:1.6;white-space:normal;max-width:85%;display:flex;flex-direction:column;position:relative}.message.user{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border-bottom-right-radius:6px;box-shadow:0 4px 12px #14b8a640}.message.assistant{background:#fff;color:var(--gray-800);border-bottom-left-radius:6px;border:1px solid var(--gray-100);box-shadow:0 2px 8px #0000000a}.message.user{padding-top:6px;padding-bottom:6px}.message.user .message-meta{margin-bottom:2px}.message.user .message-footer{margin-top:2px}.message-meta{font-size:11px;opacity:.7;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.message-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:8px}.message-time{font-size:11px;opacity:.5}.copy-icon{flex:0 0 auto;width:18px;height:18px;border-radius:4px;border:none;background:transparent;color:var(--gray-400);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .2s ease}.message:hover .copy-icon{opacity:1;pointer-events:auto}.copy-icon:hover{color:var(--primary-600);background:var(--primary-50)}.copy-icon:focus{outline:2px solid var(--primary-400);outline-offset:2px}.history-divider{display:flex;justify-content:center;align-items:center;margin:20px 0;color:var(--gray-400);font-size:12px;font-weight:500}.history-divider:before,.history-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gray-200),transparent);margin:0 16px}.history-response.history-collapsed{max-height:240px;overflow:hidden;position:relative}.history-response.history-expanded{max-height:none}.history-toggle{margin-top:10px;align-self:flex-start;border:1px solid var(--gray-200);background:#fff;color:var(--gray-600);padding:8px 14px;border-radius:10px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.history-toggle:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.initial-questions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:800px;margin:16px auto 0;padding:0 20px 16px}.initial-questions-title{font-size:13px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.initial-questions-list,.followup-list{display:flex;flex-wrap:wrap;gap:10px}.followup{color:transparent;background:transparent}.initial-question-chip{width:fit-content;max-width:100%;text-align:left;border:1px solid var(--gray-200);background:#fff;color:var(--gray-700);border-radius:12px;padding:10px 16px;font-size:14px;font-weight:500;line-height:1.4;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000a}.initial-question-chip:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-300);color:var(--primary-700);transform:translateY(-1px);box-shadow:0 4px 12px #14b8a626}.initial-question-chip:disabled{opacity:.5;cursor:not-allowed}.empty-state{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:32px 24px}.empty-composer{width:100%;max-width:720px}.empty-textarea{width:100%;resize:none;border:2px solid var(--gray-200);border-radius:20px;padding:20px 24px;min-height:120px;max-height:200px;outline:none;font-size:16px;line-height:1.6;background:#fff;color:var(--gray-800);box-shadow:0 4px 20px #0000000f;transition:all .2s ease}.empty-textarea:focus{border-color:var(--primary-400);box-shadow:0 0 0 4px #14b8a61f,0 8px 30px #00000014}.empty-textarea::placeholder{color:var(--gray-400)}.empty-initial-questions{margin-top:20px}.chat-input{display:flex;flex-direction:column;gap:10px;padding:16px 20px;background:#fffc;border-top:1px solid var(--glass-border);justify-content:center;align-items:center}.chat-input textarea{flex:1;width:100%;max-width:800px;margin:0 auto;resize:none;border:1px solid var(--gray-200);border-radius:16px;padding:14px 18px;min-height:56px;max-height:140px;outline:none;font-size:15px;line-height:1.5;color:var(--gray-800);background:#fff;box-shadow:0 2px 8px #0000000a;transition:all .2s ease}.chat-input textarea:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #14b8a61f,0 4px 12px #0000000f}.chat-input textarea::placeholder{color:var(--gray-400)}.process-indicator{padding:8px 4px 0;font-size:13px;color:var(--primary-600);background:transparent;width:100%;max-width:800px;margin:0 auto;text-align:left;font-weight:500;display:flex;align-items:center;gap:8px}.process-indicator:before{content:"";width:8px;height:8px;background:var(--primary-400);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.markdown-content,.message.assistant .markdown-content{white-space:normal}.message.assistant .markdown-content>:last-child{margin-bottom:0}.message.assistant .message-footer{margin-top:4px}.markdown-content a{color:var(--primary-600);text-decoration:none;font-weight:500;border-bottom:1px solid var(--primary-200);transition:all .2s ease}.markdown-content a:hover{color:var(--primary-700);border-bottom-color:var(--primary-400)}.markdown-content strong{color:var(--accent-600);font-weight:700;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.markdown-content p{margin:0 0 .85em}.markdown-content pre{background:var(--gray-900);color:var(--gray-100);padding:16px;border-radius:12px;overflow-x:auto;white-space:pre;margin:12px 0}.markdown-content code{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9em}.markdown-content ul,.markdown-content ol{margin:0 0 .85em 1.5em}.markdown-content li{margin-bottom:.4em}.memory-panel{display:flex;flex-direction:column;height:100%}.memory-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--gray-100);background:#ffffff80}.memory-panel-header h3{font-size:14px;font-weight:700;color:var(--primary-700);display:flex;align-items:center;gap:8px}.memory-icon{width:20px;height:20px;border-radius:4px}.memory-panel-actions{display:flex;gap:8px;align-items:center}.toggle-button{border:1px solid var(--gray-200);background:#fff;padding:8px 12px;border-radius:10px;cursor:pointer;font-size:12px;font-weight:500;color:var(--gray-600);transition:all .2s ease}.toggle-button:hover:not(:disabled){border-color:var(--primary-300);color:var(--primary-600)}.toggle-button:disabled{opacity:.4;cursor:not-allowed}.collapse-button{border:1px solid var(--gray-200);background:#fff;padding:8px 12px;border-radius:10px;cursor:pointer;font-size:12px;font-weight:500;color:var(--gray-600);transition:all .2s ease}.collapse-button:hover{border-color:var(--primary-300);color:var(--primary-600)}.memory-panel.collapsed .memory-panel-header h3,.memory-panel.collapsed .toggle-button{display:none}.memory-panel-empty{padding:20px;color:var(--gray-500);font-size:13px;text-align:center}.memory-list{padding:12px 14px;overflow:auto;flex:1}.memory-turn{border:1px solid var(--gray-100);border-radius:14px;margin-bottom:12px;overflow:hidden;background:#fff;transition:all .2s ease}.memory-turn:hover{border-color:var(--primary-200);box-shadow:0 2px 8px #14b8a614}.memory-turn-header{display:flex;gap:10px;align-items:center;padding:12px 14px;background:var(--gray-50);cursor:pointer;font-size:12px;transition:background .2s ease}.memory-turn-header:hover{background:var(--primary-50)}.memory-turn-title{font-weight:700;color:var(--primary-700)}.memory-turn-query{color:var(--gray-500);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.memory-turn-count{color:var(--gray-400);font-size:11px;background:var(--gray-100);padding:2px 8px;border-radius:10px}.memory-item{padding:12px 14px;border-top:1px solid var(--gray-100)}.memory-item-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.memory-item-title{display:flex;gap:10px;align-items:center;font-size:12px}.memory-index{color:var(--primary-600);text-decoration:none;font-weight:700;background:var(--primary-50);padding:2px 8px;border-radius:6px;transition:all .2s ease}.memory-index:hover{color:#fff;background:var(--primary-500)}.memory-date{color:var(--gray-400);font-size:11px}.memory-subject{color:var(--gray-700);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.memory-preview{margin-top:8px;font-size:12px;color:var(--gray-500);line-height:1.5}.memory-item-content{margin-top:10px;font-size:12px;color:var(--gray-700);line-height:1.5}.memory-item-content strong,.memory-preview strong{background:linear-gradient(135deg,var(--accent-500) 0%,var(--primary-600) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}.memory-summary,.memory-episode,.memory-score{margin-bottom:8px}.memory-summary strong,.memory-episode strong,.memory-score strong{display:inline-block;margin-bottom:4px;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.memory-score{display:flex;align-items:center;gap:8px}.memory-score strong{margin-bottom:0}.memory-score p{background:linear-gradient(135deg,var(--primary-200) 0%,var(--primary-300) 100%);color:var(--primary-800);font-weight:700;padding:2px 10px;border-radius:10px;font-size:12px}.label-highlight{color:var(--accent-600);font-weight:700}.memory-label{display:inline-block;color:var(--primary-600);font-weight:600;margin-right:4px}.score-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,var(--primary-200) 0%,var(--primary-300) 100%);color:var(--primary-700);font-weight:600;font-size:11px;padding:2px 8px;border-radius:10px}.score-badge .score-label{color:var(--primary-700);font-weight:700}.memory-type-badge{display:inline-block;background:var(--accent-500);color:#fff;font-size:10px;font-weight:600;padding:2px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.3px}.memory-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:200}.memory-modal-content{background:#fff;border-radius:20px;width:100%;max-width:720px;max-height:80vh;overflow:hidden;box-shadow:0 25px 80px #00000040;display:flex;flex-direction:column}.memory-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--gray-100);background:linear-gradient(135deg,var(--primary-50) 0%,var(--gray-50) 100%)}.memory-modal-header h3{font-size:16px;font-weight:700;color:var(--primary-700)}.memory-modal-close{border:none;background:transparent;font-size:24px;cursor:pointer;color:var(--gray-400);padding:4px;border-radius:8px;transition:all .2s ease;line-height:1}.memory-modal-close:hover{color:var(--gray-600);background:var(--gray-100)}.memory-modal-body{padding:20px;overflow-y:auto}.memory-modal-field{margin-bottom:16px}.memory-modal-meta{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--gray-100)}.memory-modal-date{font-size:13px;color:var(--gray-500)}.memory-modal-field label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;background:linear-gradient(135deg,var(--accent-500) 0%,var(--primary-600) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.memory-modal-field p,.memory-modal-field pre{font-size:14px;color:var(--gray-700);line-height:1.6}.memory-modal-score{display:flex;align-items:center;gap:12px}.memory-modal-score label{margin-bottom:0}.memory-modal-score .score-value{background:linear-gradient(135deg,var(--primary-200) 0%,var(--primary-300) 100%);color:var(--primary-800);font-weight:700;padding:4px 12px;border-radius:12px;font-size:14px}@media (max-width: 1024px){.app-header{flex-direction:column;align-items:flex-start;gap:12px;padding:12px 16px}.test-case-selector{width:100%;justify-content:flex-start}.group-id-select{min-width:0;flex:1;max-width:none}.app-content{flex-direction:column;padding-top:120px}.screenshot-section{width:100%;max-height:400px;order:-1}.screenshot-section.collapsed{width:100%;max-height:56px}.memory-section{width:100%;max-height:300px}.memory-section.collapsed{width:100%;max-height:56px}}@media (max-width: 1200px){.screenshot-section{width:320px}}@media (max-width: 640px){.app-header{padding:10px 12px}.assistant-title-name{font-size:1.1rem}.group-id-select{font-size:13px;padding:8px 12px}.app-content{padding:110px 10px 10px;gap:10px}.chat-section{border-radius:16px}.message{max-width:90%;padding:12px 14px}}.test-case-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.test-case-modal-content{background:#fff;border-radius:20px;width:100%;max-width:700px;max-height:85vh;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;overflow:hidden}.test-case-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--gray-100)}.test-case-modal-header h3{font-size:18px;font-weight:700;color:var(--primary-700);margin:0}.test-case-modal-close{border:none;background:transparent;font-size:28px;color:var(--gray-400);cursor:pointer;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.test-case-modal-close:hover{color:var(--gray-600);background:var(--gray-100)}.test-case-modal-body{padding:24px;overflow-y:auto}.test-case-modal-meta{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.test-case-id-badge{background:linear-gradient(135deg,var(--primary-100) 0%,var(--primary-200) 100%);color:var(--primary-700);font-size:12px;font-weight:700;padding:6px 12px;border-radius:8px;font-family:monospace}.test-case-status-badge{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:12px;font-weight:600;padding:6px 12px;border-radius:8px}.test-case-modal-section{margin-bottom:24px}.test-case-modal-section:last-child{margin-bottom:0}.test-case-section-title{font-size:14px;font-weight:700;color:var(--primary-600);margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid var(--primary-100)}.test-case-modal-field{margin-bottom:16px}.test-case-modal-field:last-child{margin-bottom:0}.test-case-modal-field label{display:block;font-size:12px;font-weight:700;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.test-case-modal-field p{font-size:14px;color:var(--gray-700);line-height:1.6;margin:0}.test-case-link{color:var(--primary-600);text-decoration:none;font-size:14px;word-break:break-all}.test-case-link:hover{color:var(--primary-700);text-decoration:underline}@media (max-width: 640px){.test-case-modal-content{max-width:100%;max-height:90vh;border-radius:16px}.test-case-modal-body,.test-case-modal-header{padding:16px}}.homepage{min-height:100vh;padding:40px 24px;display:flex;flex-direction:column;align-items:center}.homepage-header{text-align:center;margin-bottom:48px}.homepage-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.homepage-subtitle{font-size:1.125rem;color:var(--gray-500);font-weight:400}.homepage-content{width:100%;max-width:1400px}.homepage-loading,.homepage-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;color:var(--gray-500)}.homepage-error button{padding:10px 20px;background:var(--primary-500);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.test-case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.test-case-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);overflow:hidden;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column}.test-case-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000001f;border-color:var(--primary-300)}.test-case-card-header{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#ffffff80;border-bottom:1px solid var(--gray-100)}.test-case-card-id{font-size:14px;font-weight:700;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.test-case-card-status{font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px}.test-case-card-status.success{background:#10b9811a;color:#059669}.test-case-card-status.failed{background:#ef44441a;color:#dc2626}.test-case-card-status.pending{background:#f59e0b1a;color:#d97706}.test-case-card-status.default{background:var(--gray-100);color:var(--gray-600)}.test-case-card-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:12px}.test-case-card-title{font-size:15px;font-weight:600;color:var(--gray-800);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.test-case-card-description{font-size:13px;color:var(--gray-600);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.test-case-card-description.compact{-webkit-line-clamp:2}.test-case-card-meta{display:flex;flex-direction:column;gap:8px;margin-top:auto}.test-case-card-goal,.test-case-card-usecase{display:flex;gap:8px;font-size:12px}.meta-label{font-weight:600;color:var(--gray-500);white-space:nowrap}.meta-value{color:var(--gray-600);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.test-case-card-footer{padding:12px 16px;border-top:1px solid var(--gray-100);background:#ffffff4d}.test-case-card-select-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.test-case-card-select-btn:hover{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);transform:translateY(-1px)}.test-case-card.compact{min-height:auto}.test-case-card.compact .test-case-card-body,.test-case-card.compact .test-case-card-header{padding:12px}.test-case-card.compact .test-case-card-footer{padding:10px 12px}.back-to-home-btn{padding:8px 16px;border:1px solid var(--gray-200);border-radius:10px;font-size:14px;font-weight:500;background:#fff;color:var(--gray-600);cursor:pointer;transition:all .2s ease;white-space:nowrap}.back-to-home-btn:hover{border-color:var(--primary-300);color:var(--primary-600);background:var(--primary-50)}.test-case-switch-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--gray-200);border-radius:12px;font-size:14px;font-weight:500;background:#fff;color:var(--gray-800);cursor:pointer;max-width:400px;text-align:left;transition:all .2s ease;box-shadow:0 1px 3px #0000000a}.test-case-switch-btn:hover:not(:disabled){border-color:var(--primary-300);box-shadow:0 2px 8px #14b8a61a}.test-case-switch-btn:disabled{opacity:.5;cursor:not-allowed}.test-case-switch-btn .switch-icon{font-size:10px;color:var(--gray-400);margin-left:auto}.test-case-selector-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.test-case-selector-modal{background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:1200px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.test-case-selector-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--gray-100)}.test-case-selector-modal-header h2{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--primary-600) 0%,var(--accent-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.test-case-selector-modal-close{width:36px;height:36px;border:none;background:var(--gray-100);border-radius:10px;font-size:24px;color:var(--gray-500);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.test-case-selector-modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.test-case-selector-modal-content{padding:24px;overflow-y:auto}.test-case-selector-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px;color:var(--gray-500)}.test-case-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}@media (max-width: 768px){.homepage{padding:24px 16px}.homepage-title{font-size:1.75rem}.homepage-subtitle{font-size:1rem}.test-case-grid{grid-template-columns:1fr}.test-case-selector-modal{max-width:100%;max-height:90vh;border-radius:16px}.test-case-selector-grid{grid-template-columns:1fr}.test-case-switch-btn{max-width:200px;font-size:13px}}
