.config-tab{padding:2rem;max-width:1200px;margin:0 auto}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.config-header h2{margin:0;color:#1f2937}.config-message{padding:.75rem 1rem;border-radius:6px;font-size:.875rem}.config-message.success{background-color:#d1fae5;color:#065f46}.config-message.error{background-color:#fee2e2;color:#991b1b}.config-tabs{display:flex;gap:.5rem;border-bottom:2px solid #e5e7eb;margin-bottom:2rem}.config-tabs button{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.875rem;font-weight:500;color:#6b7280;transition:all .2s;margin-bottom:-2px}.config-tabs button:hover{color:#1f2937}.config-tabs button.active{color:#3b82f6;border-bottom-color:#3b82f6}.config-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.config-section h3{margin-top:0;margin-bottom:.5rem;color:#1f2937}.config-description{color:#6b7280;font-size:.875rem;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;transition:border-color .2s}.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.code-textarea{font-family:Courier New,monospace;font-size:.8rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group small{display:block;margin-top:.25rem;color:#6b7280;font-size:.75rem}.category-list{margin-bottom:1.5rem}.category-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:.5rem;background:#f9fafb}.category-main-row{display:flex;align-items:center;gap:1rem;width:100%}.category-checkbox{width:18px;height:18px;cursor:pointer}.category-input{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem}.category-description{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;font-family:inherit;resize:vertical;min-height:50px;background:#fff}.category-description:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.delete-button{padding:.5rem 1rem;background-color:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.delete-button:hover{background-color:#dc2626}.add-category{display:flex;gap:.5rem;margin-bottom:1.5rem}.add-button{padding:.5rem 1rem;background-color:#10b981;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.add-button:hover{background-color:#059669}.save-button{padding:.75rem 1.5rem;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.save-button:hover:not(:disabled){background-color:#2563eb}.save-button:disabled{opacity:.6;cursor:not-allowed}.api-key-input{display:flex;gap:.5rem}.api-key-input .form-input{flex:1}.toggle-button{padding:.75rem 1rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.toggle-button:hover{background-color:#e5e7eb}.config-loading,.config-error{padding:2rem;text-align:center;color:#6b7280}.config-error{color:#ef4444}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-checkbox{width:18px;height:18px;cursor:pointer}.expand-button{padding:.25rem .5rem;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:.75rem;color:#6b7280;transition:background-color .2s}.expand-button:hover{background-color:#e5e7eb}.category-details{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:1rem}.list-editor{margin-bottom:1rem}.list-editor label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.list-items{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.list-item{display:flex;gap:.5rem;align-items:center}.list-item-input{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem}.list-item-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.remove-item-button{padding:.5rem;background-color:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.remove-item-button:hover{background-color:#dc2626}.add-item{display:flex;gap:.5rem}.add-item-button{padding:.5rem 1rem;background-color:#10b981;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.add-item-button:hover{background-color:#059669}.tag-editor{margin-bottom:1rem}.tag-editor label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;min-height:2rem}.tag{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background-color:#dbeafe;color:#1e40af;border-radius:9999px;font-size:.875rem}.tag-remove{background:none;border:none;color:#1e40af;cursor:pointer;font-size:1.25rem;line-height:1;padding:0;margin-left:.25rem;transition:color .2s}.tag-remove:hover{color:#1e3a8a}.add-tag{display:flex;gap:.5rem}.tag-input{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem}.tag-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.add-tag-button{padding:.5rem 1rem;background-color:#10b981;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.add-tag-button:hover{background-color:#059669}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.groups-section{margin-top:2rem}.groups-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.groups-section h4{margin:0;color:#374151}.group-card{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1rem;overflow:hidden;transition:box-shadow .2s}.group-card:hover{box-shadow:0 2px 8px #0000001a}.group-card.expanded{border-color:#3b82f6}.group-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#f9fafb;cursor:pointer;transition:background-color .2s}.group-header:hover{background-color:#f3f4f6}.group-info{display:flex;align-items:center;gap:1rem}.group-id{font-family:monospace;font-size:.75rem;color:#6b7280;background-color:#e5e7eb;padding:.25rem .5rem;border-radius:4px}.group-name{font-weight:600;color:#1f2937}.category-count{font-size:.875rem;color:#6b7280}.group-actions{display:flex;gap:.5rem}.group-details{padding:1.5rem;border-top:1px solid #e5e7eb;background-color:#fff}.category-checkboxes{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem;border:1px solid #e5e7eb;border-radius:4px;background-color:#f9fafb}.checkbox-label.small{font-size:.875rem;padding:.25rem}.checkbox-label.small span.disabled{color:#9ca3af}@media (max-width: 768px){.form-row,.category-checkboxes{grid-template-columns:1fr}}.benchmark-tab{padding:2rem;max-width:1400px;margin:0 auto}.benchmark-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.benchmark-header h2{margin:0;color:#1f2937}.benchmark-message{padding:.75rem 1rem;border-radius:6px;font-size:.875rem}.benchmark-message.success{background-color:#d1fae5;color:#065f46}.benchmark-message.error{background-color:#fee2e2;color:#991b1b}.benchmark-actions{display:flex;gap:1rem}.action-button{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.import-button{background-color:#10b981;color:#fff;display:inline-block}.import-button:hover:not(:disabled){background-color:#059669}.import-button input[type=file]{display:none}.run-button{background-color:#3b82f6;color:#fff}.run-button:hover:not(:disabled){background-color:#2563eb}.action-button:disabled{opacity:.6;cursor:not-allowed}.benchmark-stats{display:flex;gap:2rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;min-width:100px}.stat-value{font-size:2rem;font-weight:700;color:#1f2937}.stat.good .stat-value{color:#10b981}.stat.medium .stat-value{color:#f59e0b}.stat.poor .stat-value{color:#ef4444}.stat-label{font-size:.875rem;color:#6b7280;margin-top:.25rem}.test-cases-section{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.test-cases-section h3{margin-top:0;margin-bottom:1rem;color:#1f2937}.empty-state{padding:3rem;text-align:center;color:#6b7280}.test-cases-table-container{overflow-x:auto}.test-cases-table{width:100%;border-collapse:collapse;font-size:.875rem}.test-cases-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.test-cases-table th{padding:.75rem;text-align:left;font-weight:600;color:#374151}.test-cases-table td{padding:.75rem;border-bottom:1px solid #e5e7eb}.test-cases-table tbody tr{cursor:pointer;transition:background-color .15s}.test-cases-table tbody tr:hover{background-color:#f9fafb}.test-cases-table tbody tr.correct{background-color:#d1fae5}.test-cases-table tbody tr.incorrect{background-color:#fee2e2}.test-cases-table tbody tr.pending{background-color:#fef3c7}.test-cases-table tbody tr.unlabeled{background-color:#f3f4f6}.subject-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-select{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;background:#fff}.category-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.predicted-cell{font-weight:500}.status-cell{text-align:center}.status-icon{font-size:1.25rem}.delete-test-button{padding:.5rem 1rem;background-color:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.delete-test-button:hover{background-color:#dc2626}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;color:#1f2937}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#f3f4f6}.modal-body{padding:1.5rem}.detail-row{margin-bottom:1rem}.detail-row label{display:block;font-weight:500;color:#374151;margin-bottom:.25rem;font-size:.875rem}.detail-row span{display:block;color:#6b7280;word-break:break-word}.detail-row span.correct{color:#10b981;font-weight:500}.detail-row span.incorrect{color:#ef4444;font-weight:500}.email-body-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.email-body-content{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:1rem;max-height:400px;overflow-y:auto}.email-body-content pre{margin:0;white-space:pre-wrap;word-wrap:break-word;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:.875rem;line-height:1.5;color:#374151}.email-body-content .no-content{color:#9ca3af;font-style:italic}.confidence-cell{text-align:center;width:70px}.confidence-badge{display:inline-block;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.confidence-badge.high{background-color:#d1fae5;color:#065f46}.confidence-badge.medium{background-color:#fef3c7;color:#92400e}.confidence-badge.low{background-color:#fee2e2;color:#991b1b}.confidence-row .confidence-display{display:flex;align-items:center;gap:.75rem}.confidence-bar-small{flex:1;max-width:150px;height:12px;background-color:#e5e7eb;border-radius:6px;overflow:hidden}.confidence-fill{height:100%;border-radius:6px;transition:width .3s ease}.confidence-fill.high{background:linear-gradient(90deg,#10b981,#059669)}.confidence-fill.medium{background:linear-gradient(90deg,#f59e0b,#d97706)}.confidence-fill.low{background:linear-gradient(90deg,#ef4444,#dc2626)}.confidence-display .confidence-value{font-weight:600;font-size:.875rem;color:#374151;min-width:50px}.needs-review-badge{background-color:#fef3c7;color:#92400e;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.stage-confidence{color:#6b7280;font-size:.875rem}.justification-text{white-space:pre-line;line-height:1.5}.intent-summary-row{margin-bottom:1rem}.intent-summary-box{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:6px;padding:.75rem;margin-top:.25rem}.intent-summary-text{margin:0 0 .5rem;color:#334155;font-style:italic;line-height:1.5;font-size:.875rem}.key-action-badge-small{display:inline-block;background:#0ea5e9;color:#fff;padding:.25rem .5rem;border-radius:8px;font-size:.75rem;font-weight:500}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#1f2937;color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a;position:relative}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;min-height:calc(100% - 3rem)}.header-left{flex:1;padding-right:250px}.app-header h1{font-size:1.5rem;margin-bottom:.25rem}.subtitle{font-size:.875rem;color:#d1d5db;margin-bottom:0}.header-right{display:flex;align-items:center;position:absolute;right:2rem;top:50%;transform:translateY(-50%)}.logo-link{display:inline-block;transition:opacity .2s}.logo-link:hover{opacity:.8}.header-logo{height:80px;width:auto;max-width:400px}.app-nav{display:flex;gap:.5rem;margin-top:1rem}.app-nav button{padding:.5rem 1rem;background-color:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.app-nav button:hover{background-color:#ffffff26}.app-nav button.active{background-color:#3b82f6;border-color:#3b82f6}.app-content{flex:1;display:flex;gap:1rem;padding:1.5rem;max-width:1600px;margin:0 auto;width:100%}.email-list-panel{flex:0 0 400px;background:#fff;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column}.email-list-panel h2{font-size:1.125rem;margin-bottom:1rem;color:#1f2937}.email-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.email-list.empty{display:flex;align-items:center;justify-content:center;color:#6b7280;font-style:italic}.email-card{padding:1rem;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s;background:#fff}.email-card:hover{border-color:#3b82f6;box-shadow:0 2px 4px #0000001a}.email-card.selected{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 2px 4px #3b82f633}.email-card-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:.375rem}.email-subject{font-weight:600;color:#1f2937;font-size:.875rem;line-height:1.4;flex:1}.email-card-body{font-size:.75rem;color:#6b7280}.email-from,.email-date{margin-bottom:.25rem}.email-category-preview{margin-top:.5rem;padding:.25rem .5rem;background-color:#eff6ff;color:#1e40af;border-radius:4px;font-size:.7rem;display:inline-block}.email-detail-panel{flex:1;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;overflow-y:auto}.email-detail.empty{display:flex;align-items:center;justify-content:center;height:100%;color:#6b7280;font-style:italic}.email-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.header-left{flex:1;display:flex;flex-direction:column;gap:.75rem}.email-detail-header h2{font-size:1.5rem;color:#1f2937;flex:1}.email-detail-meta{margin-bottom:1.5rem}.meta-row{margin-bottom:.75rem;font-size:.875rem;color:#374151}.meta-row strong{color:#1f2937;margin-right:.5rem}.meta-row.error{color:#dc2626}.email-detail-body{margin-bottom:1.5rem}.email-detail-body h3{font-size:1rem;color:#1f2937;margin-bottom:.75rem}.email-content{background-color:#f9fafb;padding:1rem;border-radius:6px;border:1px solid #e5e7eb;white-space:pre-wrap;word-wrap:break-word;font-size:.875rem;line-height:1.6;color:#374151;max-height:400px;overflow-y:auto}.email-classification{margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.email-classification h3{font-size:1rem;color:#1f2937;margin-bottom:.75rem}.intent-summary-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:8px;padding:1rem;margin-bottom:1rem}.intent-summary-section h4{margin:0 0 .5rem;color:#0369a1;font-size:.875rem;font-weight:600}.intent-box{background:#fff;border-radius:6px;padding:.75rem}.intent-text{margin:0 0 .5rem;color:#334155;font-style:italic;line-height:1.5}.key-action-badge{display:inline-block;background:#0ea5e9;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.classification-category{margin-bottom:1rem;font-size:.875rem;color:#374151}.classification-category strong{color:#1f2937;margin-right:.5rem}.classification-justification{font-size:.875rem;color:#374151}.classification-justification strong{color:#1f2937;display:block;margin-bottom:.5rem}.classification-justification p{background-color:#f9fafb;padding:.75rem;border-radius:6px;border-left:3px solid #3b82f6;line-height:1.6;white-space:pre-line}.needs-review-warning{background-color:#fef3c7;border:1px solid #f59e0b;color:#92400e;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;font-weight:500}.classification-group{margin-bottom:1rem;font-size:.875rem;color:#374151;display:flex;align-items:center;gap:.5rem}.classification-group strong{color:#1f2937;margin-right:.25rem}.group-id-badge{font-family:monospace;font-size:.75rem;background-color:#e5e7eb;color:#6b7280;padding:.125rem .375rem;border-radius:4px}.classification-confidence{margin-bottom:1rem}.classification-confidence strong{color:#1f2937;display:block;margin-bottom:.5rem;font-size:.875rem}.confidence-bar-container{position:relative;height:24px;background-color:#e5e7eb;border-radius:12px;overflow:hidden;margin-bottom:.5rem}.confidence-bar{height:100%;border-radius:12px;transition:width .3s ease}.confidence-bar.high{background:linear-gradient(90deg,#10b981,#059669)}.confidence-bar.medium{background:linear-gradient(90deg,#f59e0b,#d97706)}.confidence-bar.low{background:linear-gradient(90deg,#ef4444,#dc2626)}.confidence-value{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:600;color:#1f2937}.confidence-breakdown{display:flex;gap:1rem;margin-top:.5rem}.stage-confidence{display:flex;gap:.5rem;font-size:.75rem;color:#6b7280}.stage-confidence span:last-child{font-weight:600;color:#374151}.reclassify-button{padding:.5rem 1rem;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;align-self:flex-start}.reclassify-button:hover:not(:disabled){background-color:#2563eb}.reclassify-button:disabled{opacity:.6;cursor:not-allowed}.reclassify-error{margin-top:1rem;padding:.75rem;background-color:#fee2e2;color:#991b1b;border-radius:6px;font-size:.875rem}.badge{display:inline-block;padding:.375rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge.received{background-color:#e5e7eb;color:#374151}.badge.processing{background-color:#fef3c7;color:#92400e}.badge.queued{background-color:#ede9fe;color:#6d28d9}.badge.classified{background-color:#d1fae5;color:#065f46}.badge.error{background-color:#fee2e2;color:#991b1b}.classification-result{display:flex;flex-direction:column;gap:.5rem}.justification{font-size:.75rem;color:#6b7280;font-style:italic}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:1.125rem;color:#6b7280}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;font-size:1.125rem;color:#dc2626;text-align:center;padding:2rem}.error-message small{margin-top:.5rem;font-size:.875rem;color:#6b7280}@media (max-width: 1024px){.app-content{flex-direction:column}.email-list-panel{flex:0 0 auto;max-height:400px}}
