:root{--primary: #3b82f6;--primary-hover: #2563eb;--bg-color: #f8fafc;--card-bg: #ffffff;--text-main: #1e293b;--text-muted: #64748b;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-md: .5rem;--radius-lg: .75rem;--radius-sm: .375rem;--font-sans: "Inter", system-ui, -apple-system, sans-serif}body{margin:0;padding:0;font-family:var(--font-sans);background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;line-height:1.5}.page{max-width:1400px;margin:0 auto;padding:2rem;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;min-width:320px}.title{font-size:2rem;font-weight:800;letter-spacing:-.025em;margin:0;background:linear-gradient(to right,#1e293b,#3b82f6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.subtitle{color:var(--text-muted);font-size:1rem;margin-top:.5rem;max-width:600px}.status{background-color:var(--card-bg);padding:.75rem 1.25rem;border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);font-size:.875rem;font-weight:500;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.status strong{color:var(--text-main)}.status-authenticated{border-color:#86efac;background-color:#f0fdf4;color:#166534}.auth-panel{display:flex;align-items:center;justify-content:flex-end;width:100%;min-height:42px}.auth-login{display:flex;justify-content:flex-end;width:100%}.auth-user{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;width:100%}.auth-avatar{width:2rem;height:2rem;border-radius:9999px;border:1px solid var(--border-color);object-fit:cover}.auth-user-meta{display:flex;flex-direction:column;text-align:right;line-height:1.2}.auth-user-meta strong{font-size:.85rem;color:var(--text-main)}.auth-user-meta span{font-size:.75rem;color:var(--text-muted)}.auth-logout-btn{padding:.5rem .8rem;font-size:.8rem}.auth-message{font-size:.8rem;color:var(--text-muted)}.auth-config-missing{color:#b45309}.auth-warning-banner{margin-bottom:1rem;padding:.75rem 1rem;border:1px solid #fcd34d;border-radius:var(--radius-md);background:#fffbeb;color:#92400e;font-size:.9rem}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--card-bg);padding:.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-weight:500;color:var(--text-muted)}.tab:hover{background:#f1f5f9;color:var(--text-main)}.tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-md)}.tab-number{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;background:#0000001a;font-size:.75rem;font-weight:700}.tab.active .tab-number{background:#fff3}.tab-label{font-size:.875rem}.tab-content{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md);min-height:500px}.panel{padding:2rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.panel-title{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;color:var(--text-main)}.panel-description{color:var(--text-muted);margin-bottom:2rem;font-size:1rem}.panel-form{display:grid;gap:1rem;max-width:600px}.panel-form.two-cols{max-width:100%;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.panel-form.button-row{display:flex;gap:1rem;max-width:100%}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-main)}input[type=text],input[type=number],input[type=email],textarea,select,.panel input:not([type=file]){width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:#f8fafc;color:var(--text-main);font-size:.95rem;transition:all .2s;box-sizing:border-box}input:focus{outline:none;border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 3px #3b82f61a}input::placeholder{color:#94a3b8}button{background-color:var(--primary);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem}button:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0)}button:disabled{background-color:#cbd5e1;cursor:not-allowed;opacity:.7}button.secondary{background-color:#475569}button.secondary:hover:not(:disabled){background-color:#334155}input[type=file]{font-size:.875rem;color:var(--text-muted)}input[type=file]::file-selector-button{margin-right:1rem;padding:.75rem 1.25rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background-color:#fff;color:var(--text-main);cursor:pointer;transition:all .2s;font-weight:500}input[type=file]::file-selector-button:hover{background-color:#f1f5f9}.panel-nav{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.result-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.result-section h3{font-size:1.125rem;font-weight:600;margin:0 0 1rem;color:var(--text-main)}.review-banner{margin-top:1.5rem;padding:1rem 1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.review-approved{background:#f0fdf4;border-color:#86efac}.review-needs-work{background:#fff7ed;border-color:#fdba74}.review-banner-header{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-bottom:.5rem;font-size:.95rem}.review-banner p{margin:0;color:var(--text-main)}.review-issues{margin:.75rem 0 0;padding-left:1.25rem;color:#9a3412}.coverage-plan-list{display:grid;gap:1rem}.coverage-plan-card{background:#f8fafc;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem}.coverage-plan-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:.75rem}.coverage-plan-id{font-size:.8rem;font-weight:700;color:#2563eb;margin-bottom:.2rem}.coverage-plan-text{color:var(--text-main);font-size:.9rem}.coverage-plan-summary{white-space:nowrap;background:#fff;border:1px solid var(--border-color);border-radius:9999px;padding:.35rem .7rem;font-size:.75rem;color:var(--text-muted)}.coverage-chip-row{display:flex;flex-wrap:wrap;gap:.5rem}.coverage-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .6rem;border-radius:9999px;font-size:.75rem;font-weight:600;border:1px solid transparent}.coverage-chip.required:before{content:"●";font-size:.55rem}.coverage-chip.recommended:before{content:"○";font-size:.6rem}.coverage-chip.covered{background:#dcfce7;color:#166534;border-color:#86efac}.coverage-chip.missing{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.requirements-list{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}.requirements-list li{background:#f8fafc;padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid var(--border-color);font-size:.9rem}.requirements-list li strong{color:var(--primary)}pre{background-color:#1e293b;color:#e2e8f0;padding:1rem;border-radius:var(--radius-md);overflow-x:auto;font-size:.85rem;margin-top:1rem;border:1px solid #334155;white-space:pre-wrap;max-height:300px}.test-cases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1rem}.test-cases-table-wrapper{overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.test-cases-table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:900px}.test-cases-table thead{background:#f1f5f9}.test-cases-table th{text-align:left;padding:1rem;font-weight:600;color:var(--text-main);border-bottom:2px solid var(--border-color);white-space:nowrap}.test-cases-table td{padding:1rem;vertical-align:top;border-bottom:1px solid var(--border-color)}.test-cases-table tbody tr:hover{background-color:#f8fafc}.test-cases-table tbody tr:last-child td{border-bottom:none}.test-cases-table .tc-id{background:#eff6ff;color:#2563eb;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:700;white-space:nowrap;display:inline-block}.test-cases-table .tc-title{font-weight:600;color:var(--text-main);min-width:200px}.test-cases-table .tc-preconditions{color:var(--text-muted);font-size:.85rem;min-width:150px}.test-cases-table .tc-steps{min-width:300px}.test-cases-table .tc-steps ol{margin:0;padding-left:1.25rem}.test-cases-table .tc-steps li{margin-bottom:.75rem;line-height:1.4}.test-cases-table .tc-steps li:last-child{margin-bottom:0}.test-cases-table .tc-steps strong{color:var(--text-main)}.test-cases-table .tc-steps em{color:var(--text-muted);font-size:.85rem}.test-cases-table .tc-tags{display:flex;flex-wrap:wrap;gap:.35rem;min-width:100px}.case-card{background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.25rem;font-size:.9rem;transition:all .2s}.case-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.case-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.case-id{background:#eff6ff;color:#2563eb;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700;white-space:nowrap}.case-title{font-weight:600;color:var(--text-main)}.case-preconditions{font-size:.85rem;color:var(--text-muted);margin:.5rem 0;padding:.5rem;background:#fef3c7;border-radius:4px}.case-steps{margin-top:.75rem}.case-steps strong{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.case-steps ol{margin:.5rem 0 0;padding-left:1.25rem}.case-steps li{margin-bottom:.5rem;padding-left:.25rem}.step-action{color:var(--text-main)}.step-expected{color:var(--text-muted);font-size:.85rem;margin-left:.5rem}.case-tags{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.tag{background:#f1f5f9;color:#475569;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.helper-text{font-size:.875rem;color:var(--text-muted);margin-top:1rem;display:block}.priority-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.priority-critical{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.priority-high{background:#fff7ed;color:#ea580c;border:1px solid #fed7aa}.priority-medium{background:#fefce8;color:#ca8a04;border:1px solid #fef08a}.priority-low{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.status-draft{background:#f1f5f9;color:#64748b}.status-ready{background:#dbeafe;color:#2563eb}.status-review{background:#fef3c7;color:#d97706}.status-approved{background:#dcfce7;color:#16a34a}.automation-badge{padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;white-space:nowrap}.automation-badge.manual{background:#f1f5f9;color:#64748b}.automation-badge.to-be-automated{background:#fef3c7;color:#d97706}.automation-badge.automated{background:#dcfce7;color:#16a34a}.test-cases-table{min-width:1400px}.test-cases-table tbody tr{cursor:pointer;transition:background-color .2s}.test-cases-table tbody tr.expanded{background-color:#f8fafc}.title-cell{display:flex;align-items:flex-start;gap:.5rem}.expand-icon{color:var(--text-muted);font-size:.7rem;flex-shrink:0;margin-top:.2rem}.tc-description{font-size:.8rem;color:var(--text-muted);margin-top:.5rem;font-weight:400}.step-expected{display:block;color:var(--text-muted);font-size:.85rem;margin-left:0;font-style:italic}.step-data{display:block;color:#7c3aed;font-size:.8rem;margin-top:.25rem}.more-steps{color:var(--primary);font-style:italic;font-size:.85rem}.col-id{width:80px}.col-title{min-width:200px}.col-priority{width:80px}.col-type{width:100px}.col-status{width:80px}.col-preconditions{min-width:150px}.col-steps{min-width:280px}.col-expected{min-width:150px}.col-testdata{min-width:120px}.col-time{width:80px}.col-automation,.col-component{width:100px}.col-tags{min-width:120px}.tc-expected-result,.tc-testdata,.tc-time,.tc-component{font-size:.85rem;color:var(--text-muted)}.tc-type{font-size:.85rem}.feedback-section{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:var(--radius-lg);border:1px solid #bae6fd}.feedback-section h3{font-size:1.125rem;font-weight:600;margin:0 0 .5rem;color:#0369a1}.feedback-description{font-size:.875rem;color:#0c4a6e;margin-bottom:1rem}.feedback-textarea{width:100%;padding:1rem;border:1px solid #7dd3fc;border-radius:var(--radius-md);background-color:#fff;color:var(--text-main);font-size:.95rem;resize:vertical;font-family:var(--font-sans);box-sizing:border-box}.feedback-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f633}.feedback-textarea::placeholder{color:#94a3b8}.feedback-actions{margin-top:1rem;display:flex;gap:1rem}.feedback-button{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-weight:600;display:flex;align-items:center;gap:.5rem}.feedback-button:hover:not(:disabled){background:linear-gradient(135deg,#0284c7,#0369a1)}.case-description{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem;padding:.5rem;background:#f8fafc;border-radius:4px}.case-meta{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem;align-items:center}.meta-item{font-size:.8rem;color:var(--text-muted)}.case-expected{margin-top:.75rem;padding:.5rem;background:#ecfdf5;border-radius:4px;font-size:.85rem}@media (max-width: 768px){.header{flex-direction:column;gap:1rem}.header-right{width:100%;min-width:0;align-items:stretch}.auth-panel,.auth-login{justify-content:flex-start}.auth-user{justify-content:flex-start;flex-wrap:wrap}.auth-user-meta{text-align:left}.tabs{flex-direction:column}.tab{justify-content:flex-start}.panel-form.two-cols{grid-template-columns:1fr}.review-banner-header,.coverage-plan-header{flex-direction:column;align-items:flex-start}.test-cases-grid{grid-template-columns:1fr}.panel-nav{flex-direction:column}.panel-nav button{width:100%}.feedback-section{padding:1rem}.export-buttons{grid-template-columns:1fr}.integration-grid{grid-template-columns:repeat(2,1fr)}}.export-section{margin-bottom:1.5rem}.section-subtitle{font-size:1.1rem;font-weight:600;color:var(--text-main);margin-bottom:.5rem}.section-divider{border:none;border-top:1px solid var(--border-color);margin:2rem 0}.export-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem}.export-btn{display:flex;flex-direction:column;align-items:center;padding:1.25rem 1rem;border-radius:var(--radius-md);border:2px solid var(--border-color);background:#fff;cursor:pointer;transition:all .2s ease}.export-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.export-btn:disabled{opacity:.5;cursor:not-allowed}.export-btn.csv:hover:not(:disabled){border-color:#22c55e;background:#f0fdf4}.export-btn.excel:hover:not(:disabled){border-color:#16a34a;background:#f0fdf4}.export-btn.json:hover:not(:disabled){border-color:#f59e0b;background:#fffbeb}.export-btn.jira{flex-direction:row;gap:.5rem;padding:.875rem 1.5rem;background:var(--primary);color:#fff;border:none;font-weight:600}.export-btn.jira:hover:not(:disabled){background:var(--primary-dark)}.export-icon{font-size:2rem;margin-bottom:.5rem}.export-label{font-size:1rem;font-weight:600;color:var(--text-main)}.export-btn.jira .export-label{color:#fff}.export-desc{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.helper-text.warning{color:#b45309;display:block;margin-top:.75rem;font-size:.85rem}.integration-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem}.integration-card{display:flex;flex-direction:column;align-items:center;padding:1.25rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:#f8fafc}.integration-card.disabled{opacity:.6}.integration-icon{font-size:1.75rem;margin-bottom:.5rem}.integration-name{font-weight:600;color:var(--text-main);font-size:.9rem}.integration-status{font-size:.7rem;color:var(--text-muted);background:#e2e8f0;padding:.2rem .5rem;border-radius:var(--radius-sm);margin-top:.5rem}
