@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&display=swap";:root{font-family:Montserrat,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;--white: #FFFFFF;--golden-yellow: #eccd8f;--light-golden: #f3d9b7;--golden-alt: #f2be6e;--text-dark: #2C2C2C;--text-light: #666666;--shadow: 0 4px 20px rgba(236, 205, 143, .1);--shadow-hover: 0 8px 30px rgba(242, 190, 110, .2);color:var(--text-dark);background-color:var(--white);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--golden-yellow);text-decoration:none;transition:color .3s ease}a:hover{color:var(--golden-alt)}body{margin:0;padding:0;display:flex;justify-content:center;align-items:center;min-width:320px;min-height:100vh;background:linear-gradient(135deg,#fff,#fefcf7)}h1{font-size:2.5rem;line-height:1.2;font-weight:600;color:var(--text-dark);margin:0;letter-spacing:-.02em}button{border-radius:12px;border:none;padding:.875rem 2rem;font-size:1rem;font-weight:500;font-family:inherit;background:linear-gradient(135deg,var(--golden-yellow) 0%,var(--golden-alt) 100%);color:var(--white);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow);letter-spacing:.02em}button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-hover)}button:active:not(:disabled){transform:translateY(0)}button:focus,button:focus-visible{outline:2px solid var(--golden-yellow);outline-offset:2px}button:disabled{background:var(--text-light);cursor:not-allowed;transform:none;box-shadow:none}*{box-sizing:border-box}*:before,*:after{box-sizing:border-box}.landing-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#fff,#fefcf7)}.welcome-container{text-align:center;padding:3rem;background:var(--white);border-radius:16px;box-shadow:var(--shadow-hover);max-width:500px}.welcome-container h1{color:var(--text-dark);margin-bottom:1rem}.welcome-container>p{color:var(--text-light);font-size:1.1rem;margin-bottom:2rem}.auth-message{padding:1.5rem;background:var(--light-golden);border-radius:12px;border-left:4px solid var(--golden-yellow)}.auth-message p{margin:.5rem 0;color:var(--text-dark)}.auth-message .hint{font-size:.9rem;color:var(--text-light)}.loading-container{text-align:center;color:var(--text-dark)}.loading-container p{margin-top:1.5rem;font-size:1.1rem;color:var(--text-light)}.spinner{width:50px;height:50px;margin:0 auto;border:4px solid var(--light-golden);border-top:4px solid var(--golden-yellow);border-radius:50%;animation:spin 1s linear infinite}.spinner{display:inline-block;border-radius:50%;border-style:solid;border-color:transparent;border-top-color:currentColor;animation:spinner-rotate .6s linear infinite}.spinner-small{width:16px!important;height:16px!important;border-width:3px!important;border-color:#d4a63a33!important;border-top-color:#d4a63a!important}.spinner-medium{width:24px!important;height:24px!important;border-width:4px!important;border-color:#d4a63a33!important;border-top-color:#d4a63a!important}.spinner-large{width:80px!important;height:80px!important;border-width:6px!important;border-color:#d4a63a33!important;border-top-color:#d4a63a!important}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-small,.spinner-medium{vertical-align:middle;margin-right:4px}.document-uploader{width:100%}.uploader-card{background:var(--white);border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.uploader-card h2{margin:0 0 1.5rem;color:var(--text-dark);font-size:1.5rem}.drop-zone{border:3px dashed var(--golden-yellow);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#fefcf7,#fff)}.drop-zone:hover{border-color:var(--golden-alt);background:var(--light-golden);transform:scale(1.01)}.drop-zone.dragging{border-color:var(--golden-alt);background:var(--light-golden);border-style:solid}.drop-zone.classifying{border-color:var(--brand-primary);background:var(--brand-primary-light);cursor:not-allowed;opacity:.8}.drop-zone-content{pointer-events:none}.drop-icon{font-size:3rem;display:block;margin-bottom:1rem}.drop-icon.loading{animation:pulse 1.5s ease-in-out infinite}.spinner-container{display:flex;justify-content:center;align-items:center;margin-bottom:2rem}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}.drop-text{font-size:1.1rem;color:var(--text-dark);margin:0 0 .5rem;font-weight:500}.drop-text-large{font-size:1.5rem;color:var(--text-dark);margin:0 0 1.5rem;font-weight:600}.drop-hint{font-size:.9rem;color:var(--text-light);margin:0}.drop-hint.current-file{margin-top:.5rem;padding:.75rem 1.25rem;background:#d4a63a26;border-radius:10px;font-size:.95rem;color:var(--text-dark);font-family:Monaco,Courier New,monospace;max-width:85%;margin-left:auto;margin-right:auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid rgba(212,166,58,.3)}.selected-files{margin-top:1.5rem}.selected-files h3{font-size:1rem;color:var(--text-dark);margin:0 0 1rem}.file-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.file-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--light-golden);border-radius:8px;transition:all .2s ease}.file-item:hover{background:var(--golden-yellow)}.file-name{flex:1;font-weight:500;color:var(--text-dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:var(--text-light);font-size:.85rem}.remove-file-btn{background:none;border:none;color:var(--text-dark);cursor:pointer;padding:.25rem .5rem;font-size:1.2rem;line-height:1;transition:all .2s ease}.remove-file-btn:hover:not(:disabled){color:#d32f2f;transform:scale(1.2)}.error-message{margin-top:1rem;padding:1rem;background:#ffebee;border-left:4px solid #d32f2f;border-radius:8px;color:#c62828;font-size:.9rem}.uploader-actions{margin-top:1.5rem;display:flex;gap:1rem;flex-wrap:wrap}.classify-btn{flex:1;min-width:200px;font-size:1.1rem;padding:1rem 2rem}.clear-btn{background:var(--white);color:var(--text-dark);border:2px solid var(--golden-yellow);padding:1rem 2rem;font-size:1rem}.clear-btn:hover:not(:disabled){background:var(--light-golden);border-color:var(--golden-alt)}@media (max-width: 768px){.uploader-card{padding:1.5rem}.drop-zone{padding:2rem 1rem}.uploader-actions{flex-direction:column}.classify-btn,.clear-btn{width:100%;min-width:unset}}.project-sidebar{width:320px;height:100%;background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid var(--border-primary);display:flex;flex-direction:column;gap:var(--space-md);background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-accent) 100%);color:var(--text-primary)}.project-info{flex:1;min-width:0}.delete-project-btn{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:2px solid rgba(239,68,68,.5);background:#ef44441a;color:#dc2626;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.delete-project-btn:hover:not(:disabled){background:#dc2626;color:#fff;border-color:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.delete-project-btn:disabled{opacity:.6;cursor:not-allowed}.project-name{font-size:var(--font-size-lg);font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.file-count{font-size:var(--font-size-sm);margin:var(--space-xs) 0 0 0;color:var(--text-secondary)}.exit-project-btn{align-self:flex-start;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);border:2px solid rgba(255,255,255,.3);background:#ffffff1a;color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:var(--space-xs)}.exit-project-btn:hover{background:#fff3;border-color:#ffffff80;transform:translate(-2px)}.files-list{flex:1;overflow-y:auto;padding:8px}.files-list::-webkit-scrollbar{width:6px}.files-list::-webkit-scrollbar-track{background:transparent}.files-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.files-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#9ca3af}.empty-text{font-size:var(--font-size-base);font-weight:500;margin:0 0 var(--space-sm) 0;color:var(--text-secondary)}.empty-hint{font-size:var(--font-size-sm);margin:0;color:var(--text-tertiary)}.file-item{display:flex;align-items:center;padding:var(--space-md);margin-bottom:var(--space-xs);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;border:1px solid transparent;background:var(--bg-primary)}.file-item:hover{background:var(--bg-secondary);border-color:var(--border-primary)}.file-item.selected{background:var(--brand-primary-light);border-color:var(--brand-primary);box-shadow:var(--shadow-sm)}.file-item.error{background:var(--color-error-light);border-color:var(--color-error)}.file-item.error:hover{background:var(--color-error-light);opacity:.9}.file-icon{font-size:24px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg-secondary);border-radius:var(--radius-md)}.file-item.selected .file-icon,.file-item.error .file-icon{background:var(--bg-primary)}.file-info{flex:1;min-width:0;margin:0 var(--space-md)}.file-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:var(--space-xs)}.file-category{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs)}.category-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.category-name{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-status{font-size:16px;flex-shrink:0}.file-delete-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#dc2626;font-size:16px;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s;flex-shrink:0;margin-left:var(--space-xs)}.file-delete-btn:hover:not(:disabled){background:#fee2e2;transform:scale(1.1)}.file-delete-btn:disabled{opacity:.5;cursor:not-allowed}.file-item.deleting{opacity:.6;pointer-events:none}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;flex-direction:column;gap:var(--space-sm)}.add-files-btn{width:100%;padding:var(--space-md);border-radius:var(--radius-md);border:2px solid var(--brand-primary);background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-accent) 100%);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s}.add-files-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.export-project-btn{width:100%;padding:var(--space-md);border-radius:var(--radius-md);border:2px solid var(--brand-primary);background:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s}.export-project-btn:hover{background:var(--brand-primary-light);border-color:var(--brand-primary-dark);box-shadow:var(--shadow-md)}.export-project-btn:active{transform:scale(.98)}.project-selection-page{flex:1;width:100%;display:flex;align-items:center;justify-content:center;padding:var(--space-3xl);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);overflow-y:auto}.project-selection-container{max-width:1000px;width:100%;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-3xl);animation:fadeInUp .3s ease-out}.page-header{text-align:center;margin-bottom:var(--space-3xl);position:relative;min-height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center}.project-selection-page .page-header .back-btn{position:absolute;left:0;top:50%;background:transparent;color:var(--text-secondary);border:2px solid transparent;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;display:flex;align-items:center;gap:var(--space-xs);transform:translateY(-50%);transition:background-color .2s,color .2s;will-change:background-color,color}.project-selection-page .page-header .back-btn:hover{background:var(--bg-secondary);color:var(--brand-primary);transform:translateY(-50%)}.page-title{font-size:var(--font-size-3xl);color:var(--text-primary);margin:0 0 var(--space-sm) 0;font-weight:600}.page-subtitle{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.loading-state{text-align:center;padding:var(--space-3xl);color:var(--text-secondary)}.loading-spinner{width:50px;height:50px;margin:0 auto var(--space-lg);border:4px solid var(--border-primary);border-top:4px solid var(--brand-primary);border-radius:50%;animation:spin 1s linear infinite}.projects-list{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-2xl);max-height:500px;overflow-y:auto;padding:var(--space-xs)}.project-item{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.project-item:hover{background:var(--brand-primary-light);border-color:var(--brand-primary);transform:translate(4px);box-shadow:var(--shadow-md)}.project-icon{font-size:36px;flex-shrink:0}.project-item-name{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-xs) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-item-meta{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.project-arrow{font-size:24px;color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.project-item:hover .project-arrow{transform:translate(4px);color:var(--brand-primary)}.project-form{display:flex;flex-direction:column;gap:var(--space-xl)}.project-form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.project-form-label{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.project-form-icon{font-size:20px}.project-form-input{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border-primary);border-radius:var(--radius-md);transition:all .2s;font-family:inherit}.project-form-input:focus{outline:none;border-color:var(--brand-primary);background:var(--bg-primary);box-shadow:0 0 0 3px #3b82f61a}.project-form-input::placeholder{color:var(--text-tertiary)}.form-error{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:#ef44441a;border:2px solid var(--error-primary);border-radius:var(--radius-md);color:var(--error-primary);font-size:var(--font-size-sm)}.error-icon{font-size:20px;flex-shrink:0}.error-text{flex:1}.page-actions{display:flex;justify-content:center;gap:var(--space-md);padding-top:var(--space-lg);border-top:1px solid var(--border-primary)}.btn-primary,.btn-secondary{padding:var(--space-md) var(--space-2xl);font-size:var(--font-size-base);font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;border:2px solid transparent;display:flex;align-items:center;gap:var(--space-sm)}.btn-primary{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.btn-primary:hover:not(:disabled){background:var(--brand-primary-dark);border-color:var(--brand-primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--brand-primary);transform:translateY(-2px)}@media (max-width: 768px){.project-selection-page{padding:var(--space-lg)}.project-selection-container{padding:var(--space-xl)}.page-title{font-size:var(--font-size-2xl)}.back-btn{position:static;margin-bottom:var(--space-lg);align-self:flex-start}.project-item{flex-direction:column;text-align:center;padding:var(--space-md)}.project-details{text-align:center}.page-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}}@media (max-width: 480px){.project-selection-page{padding:var(--space-md)}.project-selection-container{padding:var(--space-lg)}.page-title{font-size:var(--font-size-xl)}.project-icon{font-size:28px}}.sheet-tab-navigator{background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:.5rem 1rem;margin-bottom:1.5rem}.excel-file-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.5rem;background-color:#fff;border-radius:6px;border:1px solid #e0e0e0}.excel-icon{font-size:1.5rem}.excel-filename{font-weight:600;color:#2c3e50;flex:1}.sheet-count{font-size:.875rem;color:#6c757d;padding:.25rem .75rem;background-color:#f0f0f0;border-radius:12px}.sheet-tabs{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem 0}.sheet-tabs::-webkit-scrollbar{height:6px}.sheet-tabs::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.sheet-tabs::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.sheet-tabs::-webkit-scrollbar-thumb:hover{background:#555}.sheet-tab{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem 1rem;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease;min-width:150px;white-space:nowrap}.sheet-tab:hover{border-color:#007bff;background-color:#f0f7ff;transform:translateY(-2px);box-shadow:0 2px 4px #0000001a}.sheet-tab.active{border-color:#007bff;background-color:#007bff;color:#fff;box-shadow:0 2px 8px #007bff4d}.sheet-tab.active:hover{background-color:#0056b3;border-color:#0056b3}.sheet-name{font-weight:600;font-size:.95rem}.sheet-category-badge{font-size:.75rem;padding:.15rem .5rem;border-radius:10px;background-color:#0000001a;max-width:200px;overflow:hidden;text-overflow:ellipsis}.sheet-tab.active .sheet-category-badge{background-color:#ffffff4d}.sheet-tab[title*=Migliorie]{border-color:#ff6b6b}.sheet-tab[title*=Migliorie]:hover{border-color:#ff6b6b;background-color:#fff5f5}.sheet-tab[title*=Migliorie].active{border-color:#ff6b6b;background-color:#ff6b6b;box-shadow:0 2px 8px #ff6b6b4d}.sheet-tab[title*=Migliorie].active:hover{background-color:#ee5a52;border-color:#ee5a52}.sheet-tab[title*=Migliorie] .sheet-category-badge{background-color:#ff6b6b33;color:#ff6b6b;font-weight:600}.sheet-tab[title*=Migliorie].active .sheet-category-badge{background-color:#ffffff4d;color:#fff}.sheet-tab[title*=Obiettivi]{border-color:#f7c948}.sheet-tab[title*=Obiettivi]:hover{border-color:#f7c948;background-color:#fffef5}.sheet-tab[title*=Obiettivi].active{border-color:#f7c948;background-color:#f7c948;box-shadow:0 2px 8px #f7c9484d}.sheet-tab[title*=Obiettivi].active:hover{background-color:#f0b429;border-color:#f0b429}.sheet-tab[title*=Obiettivi] .sheet-category-badge{background-color:#f7c94833;color:#d4a500;font-weight:600}.sheet-tab[title*=Obiettivi].active .sheet-category-badge{background-color:#ffffff4d;color:#2c2c2c}@media (max-width: 768px){.sheet-tab-navigator{padding:.5rem}.excel-file-header{flex-wrap:wrap;gap:.5rem}.sheet-tabs{gap:.25rem}.sheet-tab{min-width:120px;padding:.5rem .75rem}.sheet-name{font-size:.875rem}.sheet-category-badge{font-size:.7rem}}.file-detail{height:100%;overflow-y:auto;background:var(--bg-tertiary)}.file-detail::-webkit-scrollbar{width:8px}.file-detail::-webkit-scrollbar-track{background:transparent}.file-detail::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:var(--radius-sm)}.file-detail::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.error-view{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:40px;text-align:center}.error-icon{font-size:64px;margin-bottom:20px}.error-view h2{font-size:var(--font-size-2xl);color:var(--color-error);margin:0 0 var(--space-md) 0}.error-filename{font-size:var(--font-size-base);color:var(--text-secondary);margin:0 0 var(--space-2xl) 0;font-weight:500}.error-message{max-width:600px;padding:var(--space-lg);background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-lg);text-align:left}.error-message strong{display:block;margin-bottom:var(--space-sm);color:var(--color-error);font-weight:600}.error-message p{margin:0;color:var(--text-primary);line-height:1.6}.file-detail-header{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);padding:var(--space-lg) var(--space-2xl);position:sticky;top:0;z-index:10;display:flex;justify-content:flex-end;align-items:center}.extract-criteria-btn-top{padding:10px 20px;font-size:14px;font-weight:500;color:#fff;background:var(--brand-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.extract-criteria-btn-top:hover:not(:disabled){background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #d4a63a4d}.extract-criteria-btn-top:disabled{opacity:.6;cursor:not-allowed}.file-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-sm) 0;word-break:break-word}.file-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.meta-item{display:flex;gap:var(--space-xs)}.meta-label{font-weight:500;color:var(--text-secondary)}.meta-value{color:var(--text-tertiary)}.meta-separator{color:var(--border-secondary)}.file-detail-body{padding:var(--space-lg) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.classification-card,.preview-card,.criteria-card,.info-card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.card-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-primary);background:linear-gradient(135deg,#fefcf9,#fff);display:flex;justify-content:space-between;align-items:center}.card-header h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.02em}.extract-criteria-btn{padding:8px 16px;font-size:14px;font-weight:500;color:#fff;background:var(--brand-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.extract-criteria-btn:hover:not(:disabled){background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #d4a63a4d}.extract-criteria-btn:disabled{opacity:.6;cursor:not-allowed}.no-criteria{margin:0;padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);text-align:center}.card-body{padding:var(--space-lg)}.card-body .services-table-container{margin:calc(-1 * var(--space-lg));margin-top:0;border-radius:0 0 12px 12px}.classification-result{display:flex;flex-direction:column;gap:var(--space-2xl)}.category-badge-large{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-md);color:var(--text-inverse);font-size:var(--font-size-lg);font-weight:600;align-self:flex-start}.confidence-section{display:flex;flex-direction:column;gap:var(--space-sm)}.confidence-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.confidence-bar-container{height:8px;background:var(--border-primary);border-radius:var(--radius-sm);overflow:hidden}.confidence-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease}.confidence-value{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.text-preview{font-size:var(--font-size-sm);line-height:1.8;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-md);max-height:300px;overflow-y:auto}.criteria-count{font-size:var(--font-size-sm);color:#fff;font-weight:600;padding:6px 14px;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dark) 100%);border-radius:20px;box-shadow:0 2px 8px #d4a63a40}.criteria-list{padding:var(--space-lg);margin:0;display:flex;flex-direction:column;gap:var(--space-lg);background:var(--bg-primary)}.criterion-item{position:relative;padding:0;background:transparent;border:none;box-shadow:none}.criterion-icon{display:none}.criterion-main-level{position:relative;padding:var(--space-lg) var(--space-xl);background:#fff;border-radius:12px;border:1px solid var(--border-primary);box-shadow:0 2px 8px #0000000d;transition:all .2s ease;margin-bottom:0}.criterion-main-level.expandable{cursor:pointer}.criterion-main-level.expandable:hover{background:linear-gradient(135deg,#fffdf8,#fffbf3);border-color:var(--brand-primary);box-shadow:0 4px 12px #d4a63a26}.criterion-main-level.expanded{background:linear-gradient(135deg,#fef8ed,#fffbf3);border-color:var(--brand-primary)}.criterion-main-level:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--brand-primary) 0%,var(--brand-primary-dark) 100%);border-radius:12px 0 0 12px;transition:all .2s ease}.criterion-main-level.expandable:hover:before{width:5px}.criterion-main-level.expanded:before{width:5px;background:linear-gradient(180deg,var(--brand-primary-dark) 0%,var(--brand-primary) 100%)}.criterion-header{display:flex;align-items:center;gap:var(--space-md);width:100%}.criterion-number{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dark) 100%);color:#fff;border-radius:8px;font-weight:700;font-size:14px;box-shadow:0 2px 6px #d4a63a40}.criterion-number.sub-number{min-width:36px;height:28px;padding:0 8px;background:linear-gradient(135deg,var(--brand-primary-light) 0%,var(--brand-primary) 100%);color:var(--text-primary);font-size:13px;box-shadow:0 1px 4px #d4a63a33}.criterion-number.subsub-number{min-width:40px;height:24px;padding:0 6px;background:var(--brand-primary-light);color:var(--text-primary);font-size:11px;font-weight:600;box-shadow:0 1px 3px #d4a63a26;border-radius:6px}.criterion-controls{flex-shrink:0;display:flex;align-items:center;gap:var(--space-sm)}.criterion-count{font-size:11px;color:#5a5a5a;font-weight:600;padding:6px 12px;background:linear-gradient(135deg,#f7f7f7,#e8e8e8);border:1px solid rgba(0,0,0,.08);border-radius:16px;letter-spacing:.02em;text-transform:uppercase;box-shadow:0 1px 3px #0000000a;transition:all .2s ease;white-space:nowrap}.criterion-main-level:hover .criterion-count{background:linear-gradient(135deg,#fff,#f0f0f0);border-color:#0000001f;box-shadow:0 2px 4px #0000000f}.expand-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--brand-primary);font-size:12px;transition:transform .2s ease;font-weight:700}.expand-icon.expanded{transform:rotate(0)}.criterion-main-level.clickable{cursor:pointer}.criterion-main-level.clickable:hover{background:linear-gradient(135deg,#fffdf8,#fffbf3);transform:translate(4px);box-shadow:-4px 0 12px #d4a63a1f}.criterion-main-level.clickable:active{transform:translate(2px);background:#fef8ed}.criterion-sub-level{position:relative;padding:var(--space-md) var(--space-lg);padding-left:var(--space-xl);background:#fff;border-radius:8px;border:1px solid var(--border-primary);border-left:3px solid var(--brand-primary);margin-left:var(--space-xl);margin-top:var(--space-sm);margin-bottom:var(--space-sm);transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.criterion-sub-level:hover{background:linear-gradient(135deg,#fefcf9,#fff);border-left-color:var(--brand-primary-dark);box-shadow:0 2px 8px #d4a63a14;transform:translate(2px)}.clickable-subcriterio{cursor:pointer;transition:all .2s ease}.clickable-subcriterio:hover{background:linear-gradient(135deg,#f8f4ff,#faf5ff)!important;border-left-color:#8b5cf6!important;box-shadow:0 3px 12px #8b5cf626!important;transform:translate(4px)!important}.clickable-subcriterio:active{transform:translate(2px)!important;background:#f3e8ff!important}.clickable-subcriterio:after{content:"→";position:absolute;right:20px;top:50%;transform:translateY(-50%);color:#8b5cf6;font-size:18px;opacity:0;transition:opacity .2s ease}.clickable-subcriterio:hover:after{opacity:1}.criterion-subsub-level{position:relative;padding:var(--space-sm) var(--space-md);padding-left:var(--space-lg);background:#fafaf8;border-radius:6px;border-left:2px solid var(--brand-primary-light);margin-left:var(--space-lg);margin-top:var(--space-xs);margin-bottom:var(--space-xs);transition:all .2s ease}.criterion-subsub-level:hover{background:#fef8ed;border-left-color:var(--brand-primary);transform:translate(2px)}.criterion-text-display{margin:0;color:#2c2c2c;font-size:15px;line-height:1.7;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;flex:1;min-width:0}.criterion-main-level .criterion-text-display{font-size:15px;font-weight:600;color:#1a1a1a}.criterion-sub-level .criterion-text-display{font-size:14px;color:#3c3c3c;font-weight:500;line-height:1.6}.criterion-subsub-level .criterion-text-display{font-size:13px;color:var(--text-tertiary);line-height:1.6}.criterion-content{width:100%}.subcriteria-container{margin-top:var(--space-md)}.criterion-main-level.editing{background:linear-gradient(135deg,#fff9ed,#fff5e0);border-color:var(--brand-primary);box-shadow:0 4px 16px #d4a63a33}.criterion-text-edit{width:100%;padding:var(--space-md);border:2px solid var(--brand-primary);border-radius:var(--radius-md);font-size:15px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#1a1a1a;resize:vertical;min-height:80px;background:#fff;transition:all .2s ease}.criterion-text-edit:focus{outline:none;border-color:var(--brand-primary-dark);box-shadow:0 0 0 3px #d4a63a1a}.subcriteria-container.editing{background:#fff9ed80;padding:var(--space-lg);border-radius:var(--radius-md);border:1px dashed var(--brand-primary)}.subcriteria-container.editing h5{margin:0 0 var(--space-md) 0;font-size:14px;font-weight:600;color:var(--brand-primary-dark);text-transform:uppercase;letter-spacing:.5px}.subcriterio-edit-item{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-md)}.subcriterio-number{flex-shrink:0;font-weight:700;color:var(--brand-primary);font-size:14px;padding:6px 12px;background:#fff;border-radius:var(--radius-sm);border:1px solid var(--brand-primary);min-width:50px;text-align:center}.subcriterio-text-edit{flex:1;padding:var(--space-sm) var(--space-md);border:2px solid var(--border-secondary);border-radius:var(--radius-md);font-size:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#3c3c3c;resize:vertical;min-height:60px;background:#fff;transition:all .2s ease}.subcriterio-text-edit:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #d4a63a1a}.add-criterio-container{margin-top:var(--space-lg);display:flex;justify-content:center;padding:var(--space-lg) 0}.add-criterio-btn{padding:var(--space-md) var(--space-xl);font-size:15px;font-weight:600;color:var(--brand-primary);background:#fff;border:2px dashed var(--brand-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:var(--space-sm)}.add-criterio-btn:hover:not(:disabled){background:linear-gradient(135deg,#fff9ed,#fff5e0);border-color:var(--brand-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #d4a63a33}.add-criterio-btn:disabled{opacity:.5;cursor:not-allowed}.add-subcriterio-btn,.add-subcriterio-btn-inline{padding:var(--space-sm) var(--space-md);font-size:13px;font-weight:600;color:var(--brand-primary);background:#fff;border:1px solid var(--brand-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;margin-top:var(--space-md)}.add-subcriterio-btn:hover:not(:disabled),.add-subcriterio-btn-inline:hover:not(:disabled){background:var(--brand-primary);color:#fff;transform:translate(4px)}.add-subcriterio-btn:disabled,.add-subcriterio-btn-inline:disabled{opacity:.5;cursor:not-allowed}.add-subcriterio-form{display:flex;align-items:flex-start;gap:var(--space-md);margin-top:var(--space-md);padding:var(--space-md);background:#fff9ed4d;border-radius:var(--radius-md);border:1px dashed var(--brand-primary)}.add-subcriterio-actions{display:flex;gap:var(--space-sm)}.subcriteri-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.delete-subcriterio-btn{flex-shrink:0;padding:6px 10px;background:transparent;border:1px solid var(--color-error);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;font-size:14px}.delete-subcriterio-btn:hover:not(:disabled){background:var(--color-error);transform:scale(1.1)}.delete-subcriterio-btn:disabled{opacity:.5;cursor:not-allowed}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg);padding:0}.service-card{background:linear-gradient(145deg,#fff,#fefcf9,#f9f6f0);border:none;border-radius:20px;padding:var(--space-2xl);cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;flex-direction:column;justify-content:space-between;height:200px;width:100%;position:relative;overflow:hidden;box-shadow:0 10px 20px #00000014,0 6px 6px #0000000f,inset 0 -2px 4px #00000008,inset 0 2px 4px #fffc;transform:perspective(1000px) rotateX(0) rotateY(0)}.service-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#d4a63a0d,#eccd8f14,#d4a63a0d);opacity:0;transition:opacity .4s ease;pointer-events:none}.service-card:after{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--brand-primary) 0%,var(--brand-primary-dark) 50%,var(--brand-primary) 100%);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.68,-.55,.265,1.55);border-radius:20px 20px 0 0}.service-card:hover:before{opacity:1}.service-card:hover:after{transform:scaleX(1)}.service-card:hover{transform:perspective(1000px) rotateX(2deg) rotateY(-2deg) translateY(-8px) scale(1.02);box-shadow:0 20px 40px #d4a63a33,0 15px 25px #0000001a,0 5px 10px #00000014,inset 0 -3px 6px #0000000a,inset 0 3px 6px #ffffffe6}.service-card:active{transform:perspective(1000px) rotateX(1deg) rotateY(-1deg) translateY(-4px) scale(1.01);box-shadow:0 12px 24px #d4a63a26,0 8px 16px #00000014,inset 0 -2px 4px #00000008,inset 0 2px 4px #fffc}.service-card-icon{font-size:32px;line-height:1;background:linear-gradient(135deg,var(--brand-primary-light) 0%,var(--brand-primary) 100%);border-radius:12px;padding:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #d4a63a26}.service-card-content{flex:1;display:flex;flex-direction:column;gap:var(--space-sm);width:100%;overflow:hidden}.service-card-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.02em;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.service-card-subtitle{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5;font-weight:400;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.service-card-arrow{font-size:24px;color:var(--brand-primary);transition:transform .3s ease;align-self:flex-end;line-height:1}.service-card:hover .service-card-arrow{transform:translate(6px)}.field-group{display:flex;flex-direction:column;gap:4px}.field-label{font-size:14px;font-weight:600;color:var(--brand-primary-dark);letter-spacing:-.01em;display:block}.field-value{font-size:15px;color:var(--text-primary);line-height:1.6;font-weight:400}.field-group ul{padding-left:20px;margin:8px 0}.field-group li{color:var(--text-primary);font-size:14px;line-height:1.7;margin-bottom:6px}.field-group li:last-child{margin-bottom:0}.info-grid{display:grid;gap:var(--space-md);margin:0}.info-row{display:grid;grid-template-columns:200px 1fr;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--border-primary)}.info-key{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin:0}.info-value{font-size:var(--font-size-sm);color:var(--text-primary);margin:0;word-break:break-word}@media (max-width: 768px){.file-detail-header,.file-detail-body{padding:20px}.file-title{font-size:20px}.info-row{grid-template-columns:1fr;gap:8px}.services-grid{grid-template-columns:1fr;gap:var(--space-md)}.service-card{height:180px}.service-card-title{font-size:16px}.service-card-subtitle{font-size:13px}.services-table-container{overflow-x:auto}}.search-container{padding:var(--space-md) var(--space-lg);padding-bottom:var(--space-md);background:transparent;display:flex;justify-content:flex-end;align-items:center;gap:12px}.search-input-wrapper{position:relative;display:inline-block}.search-input-wrapper:before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;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='%23a67c2a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-size:16px 16px;background-repeat:no-repeat;pointer-events:none;z-index:1}.search-input{width:200px!important;padding:var(--space-xs) var(--space-sm)!important;padding-left:36px!important;padding-right:30px!important;font-size:13px;color:var(--text-primary);background:linear-gradient(135deg,var(--brand-primary-light) 0%,#fef8ed 100%)!important;border:1px solid var(--brand-primary);border-radius:var(--radius-md);transition:all .2s;font-family:inherit}.search-input:focus{outline:none;border-color:var(--brand-primary-dark);background:#fff!important;box-shadow:0 0 0 3px #d4a63a26}.search-input::placeholder{color:var(--text-tertiary);font-size:13px}.clear-search-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:transparent;color:var(--text-secondary);border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:12px;font-weight:700}.clear-search-btn:hover{background:var(--brand-primary-light);color:var(--text-primary);transform:translateY(-50%) scale(1.1)}.no-results{padding:var(--space-3xl);text-align:center;color:var(--text-secondary);font-style:italic}.no-results p{margin:0;font-size:var(--font-size-lg)}.services-table-container{width:100%;overflow-x:auto;border-radius:12px;border:none;background:#fff;box-shadow:0 4px 20px #00000014;margin:0}.services-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;background:#fff}.services-table thead{background:linear-gradient(135deg,#d4a63a,#b8902f);position:sticky;top:0;z-index:10;box-shadow:0 4px 12px #d4a63a40}.services-table thead th{padding:18px 24px;text-align:left;font-weight:700;color:#fff;font-size:12px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border-bottom:none;text-shadow:0 1px 2px rgba(0,0,0,.1)}.services-table thead th:first-child{border-top-left-radius:12px;padding-left:32px}.services-table thead th:last-child{border-top-right-radius:12px;padding-right:20px}.services-table tbody tr{transition:all .2s cubic-bezier(.4,0,.2,1);border-bottom:1px solid #e8e8e8}.services-table tbody tr:last-child{border-bottom:none}.services-table tbody tr:last-child td:first-child{border-bottom-left-radius:12px}.services-table tbody tr:last-child td:last-child{border-bottom-right-radius:12px}.services-table tbody tr.table-row-clickable{cursor:pointer}.services-table tbody tr.table-row-clickable:hover{background:linear-gradient(135deg,#fffdf8,#fffbf3);transform:translate(4px);box-shadow:-4px 0 12px #d4a63a1f}.services-table tbody tr.table-row-clickable:active{transform:translate(2px);background:#fef8ed}.services-table tbody td{padding:20px 24px;color:#2c2c2c;font-size:14px;line-height:1.8;vertical-align:top;max-width:500px;white-space:pre-wrap;word-break:break-word}.services-table tbody td:first-child{padding-left:32px}.services-table tbody td:last-child{padding-right:20px}.services-table tbody td:first-child{font-weight:700;color:#1a1a1a;font-size:15px;position:relative;background:linear-gradient(90deg,rgba(212,166,58,.02) 0%,transparent 100%)}.services-table tbody td:first-child:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--brand-primary);opacity:0;transition:opacity .25s ease}.services-table tbody tr.table-row-clickable:hover td:first-child:before{opacity:1}.services-table tbody tr:nth-child(2n){background:#fafafa}.services-table tbody tr:nth-child(odd){background:#fff}.services-table tbody tr:nth-child(2n):hover,.services-table tbody tr:nth-child(odd):hover{background:linear-gradient(135deg,#fffdf8,#fffbf3)}.services-table tbody td{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.services-table thead th.col-nome-servizio,.services-table tbody td.col-nome-servizio{width:350px;max-width:400px;min-width:300px}.services-table thead th.col-modalita,.services-table tbody td.col-modalita{width:250px;max-width:300px;min-width:200px}.services-table thead th.col-frequenza,.services-table tbody td.col-frequenza{width:180px;max-width:220px;min-width:150px}.services-table thead th.col-attrezzature,.services-table tbody td.col-attrezzature{width:250px;max-width:350px;min-width:200px}.services-table thead th.col-mezzi,.services-table tbody td.col-mezzi{width:180px;max-width:220px;min-width:150px}.services-table thead th:not(.col-nome-servizio):not(.col-modalita):not(.col-frequenza):not(.col-attrezzature):not(.col-mezzi),.services-table tbody td:not(.col-nome-servizio):not(.col-modalita):not(.col-frequenza):not(.col-attrezzature):not(.col-mezzi){min-width:400px;max-width:800px}.detail-key{display:inline-block;font-weight:700;color:#1a1a1a;background:linear-gradient(135deg,#fef8ed,#fdf5e6);padding:4px 12px;border-radius:6px;margin:4px 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.05em;border-left:3px solid var(--brand-primary);box-shadow:0 2px 4px #d4a63a1a}.services-table tbody td{line-height:1.9}.services-table tbody td br+span{padding-left:12px;color:#4a4a4a;display:block;margin-bottom:16px}.services-table tbody tr td.empty-cell{text-align:center;color:var(--text-tertiary);font-style:italic;padding:var(--space-3xl)}.services-table-container::-webkit-scrollbar{height:8px}.services-table-container::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:var(--radius-sm)}.services-table-container::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:var(--radius-sm)}.services-table-container::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.obiettivi-section{background:linear-gradient(135deg,#fffef5,#fff9e6);border:2px solid #f7c948;border-radius:var(--radius-lg);margin:var(--space-lg) 0;overflow:hidden;box-shadow:0 4px 12px #f7c94826}.obiettivi-section:first-child{margin-top:0}.obiettivi-section:last-child{margin-bottom:var(--space-lg)}.obiettivi-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#f7c948,#f0b429);border-bottom:1px solid #e6a800}.obiettivi-icon{font-size:18px;line-height:1}.obiettivi-header h4{flex:1;margin:0;font-size:16px;font-weight:700;color:#2c2c2c;letter-spacing:.02em;text-transform:uppercase}.obiettivi-count{font-size:13px;color:#2c2c2c;font-weight:600;padding:4px 12px;background:#ffffff80;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.obiettivi-list{padding:var(--space-lg);display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-md);max-height:300px;overflow-y:auto}.obiettivo-item{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background:#fff;border-left:4px solid #f7c948;border-radius:var(--radius-md);box-shadow:0 2px 6px #00000014;transition:all .2s ease}.obiettivo-item:hover{transform:translate(4px);box-shadow:0 4px 12px #f7c94833;border-left-color:#f0b429}.obiettivo-label{font-size:11px;font-weight:700;color:#d4a500;text-transform:uppercase;letter-spacing:.05em}.obiettivo-value{font-size:16px;color:#2c2c2c;font-weight:700;line-height:1.6}.obiettivi-list::-webkit-scrollbar{width:6px}.obiettivi-list::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.obiettivi-list::-webkit-scrollbar-thumb{background:#f7c948;border-radius:3px}.obiettivi-list::-webkit-scrollbar-thumb:hover{background:#f0b429}.migliorie-section{background:linear-gradient(135deg,#fff5f5,#ffe8e8);border:2px solid #ff6b6b;border-radius:var(--radius-lg);margin:var(--space-lg) 0;overflow:hidden;box-shadow:0 4px 12px #ff6b6b26}.migliorie-section:first-child{margin-top:0}.migliorie-section:last-child{margin-bottom:0}.migliorie-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#ff6b6b,#ee5a52);border-bottom:1px solid #ff5252}.migliorie-icon{font-size:18px;line-height:1}.migliorie-header h4{flex:1;margin:0;font-size:16px;font-weight:700;color:#fff;letter-spacing:.02em;text-transform:uppercase}.migliorie-count{font-size:13px;color:#fff;font-weight:600;padding:4px 12px;background:#ffffff40;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.migliorie-list{padding:var(--space-lg);display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-md);max-height:400px;overflow-y:auto}.miglioria-item{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background:#fff;border-left:4px solid #ff6b6b;border-radius:var(--radius-md);box-shadow:0 2px 6px #00000014;transition:all .2s ease}.miglioria-item:hover{transform:translate(4px);box-shadow:0 4px 12px #ff6b6b33;border-left-color:#ee5a52}.miglioria-label{font-size:11px;font-weight:700;color:#ff6b6b;text-transform:uppercase;letter-spacing:.05em}.miglioria-value{font-size:14px;color:#2c2c2c;font-weight:500;line-height:1.6}.migliorie-list::-webkit-scrollbar{width:6px}.migliorie-list::-webkit-scrollbar-track{background:#ff6b6b1a}.migliorie-list::-webkit-scrollbar-thumb{background:#ff6b6b;border-radius:var(--radius-sm)}.migliorie-list::-webkit-scrollbar-thumb:hover{background:#ee5a52}.editable-item{position:relative}.item-actions{display:flex;gap:var(--space-xs);flex-shrink:0;opacity:1;transition:opacity .2s}.editable-item:hover .item-actions,.criterion-main-level .item-actions,.criterion-main-level:hover .item-actions{opacity:1}.edit-btn,.delete-btn{padding:4px 8px;border:none;background:transparent;cursor:pointer;font-size:16px;border-radius:var(--radius-sm);transition:all .2s}.edit-btn:hover:not(:disabled){background:#3b82f61a;transform:scale(1.1)}.edit-btn:disabled{opacity:.3;cursor:not-allowed}.delete-btn:hover:not(:disabled){background:#ef44441a;transform:scale(1.1)}.delete-btn:disabled{opacity:.3;cursor:not-allowed}.edit-form{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm);background:#3b82f60d;border-radius:var(--radius-md);width:100%}.edit-input{padding:var(--space-sm) var(--space-md);border:2px solid var(--border-primary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:inherit;transition:all .2s}.edit-input:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #3b82f61a}.edit-input.edit-key{font-weight:600}.edit-input.edit-value{flex:1}.edit-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;flex-shrink:0}.save-btn,.cancel-btn{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s;border:2px solid transparent}.save-btn{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.save-btn:hover:not(:disabled){background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.save-btn:disabled{opacity:.5;cursor:not-allowed}.cancel-btn{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-primary)}.cancel-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-secondary)}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.add-entry-btn{padding:var(--space-xs) var(--space-md);background:var(--brand-primary);color:#fff;border:2px solid var(--brand-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s;margin-left:auto;display:flex;align-items:center;gap:var(--space-xs)}.add-entry-btn .btn-icon{color:#fff;font-size:1.1em;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center}.add-entry-btn:hover:not(:disabled){background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.add-entry-btn:disabled{opacity:.5;cursor:not-allowed}.obiettivi-header,.migliorie-header{display:flex;align-items:center;gap:var(--space-md)}.obiettivo-item.editable-item,.miglioria-item.editable-item{display:flex;align-items:center;justify-content:space-between}.table-row-editable{cursor:default;transition:background-color .2s}.table-row-editable:hover{background-color:var(--bg-secondary)}.table-row-editing{background-color:#3b82f60d}.table-row-editing .edit-input{width:100%;min-width:100px}.col-actions{width:100px;text-align:center;white-space:nowrap}.ai-response-btn{background-color:#8b5cf6;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;gap:6px}.ai-response-btn:hover:not(:disabled){background-color:#7c3aed;transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf64d}.ai-response-btn:disabled{background-color:#ddd;cursor:not-allowed;opacity:.6}.ai-response-container{margin-top:12px;margin-left:24px;background-color:#f8f4ff;border:2px solid #e9d5ff;border-radius:8px;padding:16px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.ai-response-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e9d5ff}.ai-response-label{font-weight:600;color:#7c3aed;font-size:14px}.close-response-btn{background-color:transparent;border:none;color:#9ca3af;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px;transition:all .2s ease}.close-response-btn:hover{background-color:#e9d5ff;color:#7c3aed}.ai-response-content{font-size:14px;line-height:1.6;color:#1f2937;white-space:pre-wrap;word-wrap:break-word}.user-portal{height:100vh;display:flex;flex-direction:column;background:var(--bg-tertiary);overflow:hidden}.portal-header{background:linear-gradient(135deg,#f5f0e8,#faf7f2);color:var(--text-primary);padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-md);flex-shrink:0;border-bottom:1px solid var(--border-primary);position:relative;z-index:100}.header-content{display:flex;align-items:center;gap:16px}.portal-logo{height:50px;width:auto;object-fit:contain}.header-content h1{margin:0;font-size:var(--font-size-2xl);font-weight:600;color:var(--text-primary)}.header-subtitle{margin:4px 0 0;font-size:var(--font-size-sm);color:var(--text-secondary)}.header-actions{display:flex;align-items:center;gap:20px}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.user-email{font-size:14px;font-weight:500}.user-role-badge{background:var(--brand-primary-light);color:var(--text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);font-size:var(--font-size-xs);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.admin-portal-btn{background:linear-gradient(135deg,var(--brand-primary-light) 0%,#fef8ed 100%);color:var(--text-primary);border:2px solid var(--brand-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:var(--space-xs)}.admin-portal-btn:hover{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dark) 100%);color:#fff;border-color:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.logout-btn{background:linear-gradient(135deg,var(--brand-primary-light) 0%,#fef8ed 100%);color:var(--text-primary);border:2px solid var(--brand-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s}.logout-btn:hover{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dark) 100%);color:#fff;border-color:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.breadcrumb-bar{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-accent) 100%);padding:12px 24px;display:flex;align-items:center;gap:12px;border-bottom:2px solid var(--brand-primary-dark);box-shadow:0 2px 8px #d4a63a26;flex-shrink:0;position:relative;z-index:150}.back-to-projects-btn{background:#fff;color:var(--brand-primary-dark);border:2px solid var(--brand-primary-dark);padding:8px 16px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.back-to-projects-btn:hover{background:var(--brand-primary-dark);color:#fff;transform:translate(-3px);box-shadow:0 4px 12px #d4a63a4d}.breadcrumb-separator{color:#2c2c2c66;font-size:18px;font-weight:300}.current-project-breadcrumb{color:var(--text-primary);font-size:var(--font-size-base);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.portal-layout{flex:1;display:flex;overflow:hidden}.portal-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-3xl);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%)}.welcome-content{max-width:600px;width:100%;text-align:center}.welcome-content h2{font-size:var(--font-size-3xl);color:var(--text-primary);margin:0 0 var(--space-md) 0;font-weight:600}.welcome-content>p{font-size:var(--font-size-base);color:var(--text-secondary);margin:0 0 var(--space-3xl) 0}.no-selection{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-3xl);background:var(--bg-tertiary)}.no-selection-content{max-width:600px;width:100%;text-align:center}.no-selection-icon{font-size:64px;margin:0 0 var(--space-lg) 0}.no-selection-text{font-size:var(--font-size-lg);color:var(--text-secondary);margin:0 0 var(--space-3xl) 0;font-weight:500}.upload-modal{max-width:700px!important;width:90%!important}.modal-body{padding:var(--space-2xl)}@media (max-width: 768px){.portal-layout{flex-direction:column}.portal-header{flex-direction:column;gap:12px;text-align:center}.header-actions{flex-direction:column;width:100%}.user-info{align-items:center}.welcome-content h2{font-size:24px}.no-selection-icon{font-size:48px}}.modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.modal-overlay .modal-content{background:#fff!important;border-radius:24px!important;box-shadow:0 20px 60px #0000004d!important;max-width:1200px!important;width:85%!important;max-height:85vh!important;overflow-y:auto!important;animation:slideUp .3s ease!important;border:1px solid #e5e7eb!important}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-overlay .modal-content .modal-header{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;padding:50px 60px!important;border-bottom:3px solid #d4a63a!important;background:linear-gradient(135deg,#eccd8f,#f2be6e)!important;border-radius:24px 24px 0 0!important;position:relative!important;text-align:center!important}.modal-title{font-size:2.75rem;font-weight:700;color:#2c2c2c;margin:0;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(255,255,255,.5);line-height:1.2}.modal-subtitle{font-size:1.15rem;color:#4a4a4a;margin:14px 0 0;font-weight:400;opacity:.95;max-width:900px;line-height:1.5}.modal-close-btn{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;border:2px solid rgba(74,74,74,.3);background:#4a4a4ae6;color:#fff;font-size:1.5rem;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 12px #00000040,0 1px 3px #00000026;z-index:10}.modal-close-btn:hover{background:#d4a63af2;border-color:#d4a63a;color:#fff;transform:scale(1.12) rotate(90deg);box-shadow:0 6px 24px #d4a63a80,0 2px 8px #0003}.modal-close-btn:active{transform:scale(.95) rotate(90deg)}.modal-form{padding:45px 70px;background:#fff}.project-form-group{margin-bottom:40px}.project-form-label{display:flex;align-items:center;gap:16px;font-size:1.5rem;font-weight:600;color:#2c2c2c;margin-bottom:20px;padding:8px 0}.project-form-icon{font-size:2rem}.project-form-label .required{color:#dc2626;margin-left:2px;font-size:1.5rem}.project-form-input{width:100%;padding:28px 30px;border:2px solid #d1d5db;border-radius:14px;font-size:1.375rem;color:#2c2c2c;background:#f9fafb;transition:all .2s;font-family:inherit;line-height:1.5}.project-form-input:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 4px #eccd8f33;background:#fff}.project-form-input:disabled{opacity:.6;cursor:not-allowed}.project-form-input::placeholder{color:#9ca3af}.form-error{display:flex;align-items:center;gap:12px;padding:18px 24px;background:#fee2e2;border:2px solid #dc2626;border-radius:12px;margin-bottom:24px}.error-icon{font-size:1.5rem;flex-shrink:0}.error-text{font-size:1.125rem;color:#dc2626;font-weight:500;line-height:1.5}.modal-actions{display:flex;gap:20px;justify-content:flex-end;padding-top:32px;border-top:3px solid #f3d9b7;margin-top:32px}.btn-primary,.btn-secondary{padding:20px 40px;border-radius:12px;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;justify-content:center;gap:12px;min-height:64px;min-width:220px}.btn-primary{background:linear-gradient(135deg,#eccd8f,#f2be6e)!important;color:#2c2c2c!important;box-shadow:0 4px 12px #d4a63a4d!important;font-weight:600!important}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #d4a63a73;transform:translateY(-2px);background:linear-gradient(135deg,#f2be6e,#eccd8f)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:#2c2c2c;border:2px solid #eccd8f}.btn-secondary:hover:not(:disabled){background:#f3d9b7;border-color:#d4a63a;transform:translateY(-1px)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.projects-list{padding:30px 60px;display:flex;flex-direction:column;gap:16px;max-height:50vh;overflow-y:auto}.project-item{display:flex;align-items:center;gap:20px;padding:24px 28px;background:#fff;border:2px solid #e5e7eb;border-radius:14px;cursor:pointer;transition:all .2s}.project-item:hover{border-color:#eccd8f;background:#fefdf8;transform:translate(4px);box-shadow:0 4px 12px #d4a63a26}.project-icon{font-size:2.5rem;flex-shrink:0}.project-details{flex:1;min-width:0}.project-item-name{font-size:1.5rem;font-weight:600;color:#2c2c2c;margin:0 0 8px}.project-item-meta{font-size:1.125rem;color:#6b7280;margin:0}.project-arrow{font-size:1.75rem;color:#eccd8f;flex-shrink:0;transition:transform .2s}.project-item:hover .project-arrow{transform:translate(4px)}.loading-state{padding:60px;text-align:center;font-size:1.25rem;color:#6b7280}.back-btn{position:absolute;top:24px;left:24px;width:48px;height:48px;border-radius:12px;border:none;background:#ffffff4d;color:#2c2c2c;font-size:1.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a}.back-btn:hover{background:#ffffff80;transform:scale(1.05)}@media (max-width: 1400px){.modal-content{max-width:1100px}.modal-form{padding:50px 60px}}@media (max-width: 1024px){.modal-content{max-width:900px}.modal-form{padding:40px 50px}.modal-title{font-size:2.5rem}}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.modal-header{padding:40px 30px}.modal-title{font-size:2rem}.modal-subtitle{font-size:1rem}.modal-form{padding:30px 24px}.modal-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.criterion-detail-container{min-height:100vh;height:100vh;background:#f5f5f7;display:flex;flex-direction:column;overflow:hidden}.criterion-detail-header{background:#fffffff2;border-bottom:.5px solid rgba(0,0,0,.08);padding:20px 40px;box-shadow:0 1px #00000005;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);flex-shrink:0}.criterion-detail-header .back-btn,.criterion-detail-container button.back-btn{padding:8px 16px!important;font-size:14px!important;font-weight:500!important;color:#8b6f47!important;background:transparent!important;border:1px solid rgba(212,166,58,.3)!important;border-radius:8px!important;cursor:pointer!important;transition:all .2s ease!important;display:inline-flex!important;align-items:center!important;gap:6px!important;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif!important;margin-bottom:0!important;text-decoration:none!important;box-shadow:none!important;white-space:nowrap!important}.criterion-detail-header .back-btn:hover,.criterion-detail-container button.back-btn:hover{background:#d4a63a1a!important;border-color:#d4a63a80!important;color:#8b6f47!important}.criterion-detail-header .back-btn:active,.criterion-detail-container button.back-btn:active{background:#d4a63a33!important;transform:scale(.98)!important}.header-info{margin-top:0;display:none}.file-breadcrumb{font-size:11px;color:#86868b;margin:0;font-weight:400;letter-spacing:.01em;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}.criterion-title{font-size:24px;font-weight:700;color:#1d1d1f;margin:0;letter-spacing:-.02em;line-height:1.1;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif}.criterion-detail-main{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0}.criterion-detail-card{flex:1;background:transparent;border:none;padding:0;box-shadow:none;overflow-y:auto;height:100%}.criterion-detail-card::-webkit-scrollbar{width:8px}.criterion-detail-card::-webkit-scrollbar-track{background:transparent}.criterion-detail-card::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.criterion-detail-card::-webkit-scrollbar-thumb:hover{background:#0000004d}.criterion-main-text{margin-bottom:var(--space-2xl);padding:var(--space-2xl)}.criterion-main-text h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-lg) 0;letter-spacing:-.01em}.criterion-content-text{font-size:18px;line-height:1.8;color:var(--text-primary);margin:0;letter-spacing:-.01em}.subcriteria-section{margin-top:var(--space-2xl);padding-top:var(--space-2xl);border-top:1px solid var(--border-primary)}.subcriteria-title{font-size:18px;font-weight:600;color:var(--text-secondary);margin:0 0 var(--space-lg) 0;letter-spacing:-.01em}.subcriteria-list-detail{display:flex;flex-direction:column;gap:var(--space-lg)}.subcriterion-detail-item{padding:var(--space-lg);background:linear-gradient(135deg,#fefcf9,#fff);border-left:3px solid var(--brand-primary-light);border-radius:var(--radius-md);transition:all .2s ease}.subcriterion-detail-item:hover{background:var(--bg-secondary);border-left-color:var(--brand-primary)}.subcriterion-text{font-size:16px;line-height:1.7;color:var(--text-secondary);margin:0}.subcriteria-section.level-2{margin-left:var(--space-2xl);margin-top:var(--space-lg);padding-top:var(--space-lg);border-top-color:var(--border-secondary)}.subcriteria-section.level-2 .subcriteria-title{font-size:16px;color:var(--text-tertiary)}.subcriteria-section.level-2 .subcriterion-detail-item{padding:var(--space-md);border-left-width:2px}.subcriteria-section.level-2 .subcriterion-text{font-size:15px;color:var(--text-tertiary)}.future-work-section{display:none}.detail-hero{background:#fff;padding:48px 40px 40px;border-bottom:.5px solid rgba(0,0,0,.1)}.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:1400px}.hero-item{display:flex;flex-direction:column;gap:8px}.hero-label{font-size:13px;font-weight:600;color:#86868b;letter-spacing:-.01em;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}.hero-value{font-size:28px;font-weight:600;color:#1d1d1f;letter-spacing:-.02em;line-height:1.2;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif}.fields-container{background:#fff;padding:0}.field-detail-item{padding:24px 40px;border-bottom:.5px solid rgba(0,0,0,.08);transition:background-color .15s ease}.field-detail-item:hover{background-color:#00000005}.field-detail-item:last-child{border-bottom:none}.field-detail-label{font-size:13px;font-weight:600;color:#86868b;margin-bottom:8px;display:block;letter-spacing:-.01em;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}.field-detail-value{font-size:17px;line-height:1.47059;color:#1d1d1f;font-weight:400;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}.field-detail-value span{display:block}.field-detail-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.field-list-item{padding:12px 16px;background:#f5f5f7;border-radius:8px;font-size:15px;line-height:1.47059;color:#1d1d1f;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;transition:background-color .15s ease}.field-list-item:hover{background:#e8e8ed}.field-list-item:empty{opacity:.5;font-style:italic;color:#86868b}.criterion-main-content{padding:0}.criterion-main-content h2{display:none}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.error-state h2{font-size:24px;color:var(--text-primary);margin:0 0 var(--space-lg) 0}@media (max-width: 768px){.criterion-detail-header{padding:16px 20px}.back-btn{padding:6px 12px;font-size:13px}.criterion-title{font-size:20px}.file-breadcrumb{font-size:10px}.detail-hero{padding:32px 20px 24px}.hero-grid{grid-template-columns:1fr;gap:24px}.hero-label{font-size:12px}.hero-value{font-size:24px}.field-detail-item{padding:20px}.field-detail-label{font-size:12px}.field-detail-value{font-size:16px}.field-list-item{font-size:14px;padding:10px 14px}.subcriteria-section.level-2{margin-left:16px}}.criterio-detail-container{max-width:1200px;margin:0 auto;padding:40px 20px;min-height:100vh;background:linear-gradient(to bottom,#fefefe,#f8f9fa)}.criterio-detail-header{margin-bottom:40px}.criterio-detail-container .criterio-detail-header button.criterio-back-btn{background:linear-gradient(135deg,#fff,#fefcf7)!important;color:#2c2c2c!important;border:2px solid #eccd8f!important;padding:12px 24px!important;border-radius:12px!important;cursor:pointer!important;font-size:15px!important;font-weight:600!important;transition:all .3s ease!important;margin-bottom:24px!important;display:inline-flex!important;align-items:center!important;gap:10px!important;box-shadow:0 2px 8px #eccd8f33!important;white-space:nowrap!important;min-width:fit-content!important}.criterio-detail-container .criterio-detail-header button.criterio-back-btn:hover{background:linear-gradient(135deg,#fefcf7,#f2be6e)!important;border-color:#f2be6e!important;transform:translate(-4px)!important;box-shadow:0 4px 12px #f2be6e4d!important}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px;color:#6c757d;flex-wrap:wrap}.project-name{font-weight:600;color:#495057}.separator{margin:0 4px;color:#adb5bd}.hierarchy-item{color:#f2be6e;font-weight:500}.criterio-detail-content{background:#fff;border-radius:16px;padding:40px;box-shadow:0 4px 20px #00000014}.criterio-number-large{display:inline-block;background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#2c2c2c;padding:12px 24px;border-radius:12px;font-size:24px;font-weight:700;margin-bottom:20px;box-shadow:0 4px 12px #eccd8f4d}.criterio-text-large{font-size:18px;line-height:1.8;color:#2d3748;margin-bottom:40px;padding:20px;background:#fefcf7;border-left:4px solid #eccd8f;border-radius:8px}.ai-section{margin-top:40px}.ai-controls{margin-bottom:30px;display:flex;flex-direction:column;gap:20px}.control-group{display:flex;flex-direction:column;gap:8px}.control-label{font-size:14px;font-weight:600;color:#4a5568}.response-length-select{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s ease;max-width:300px}.response-length-select:hover:not(:disabled){border-color:#eccd8f}.response-length-select:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 3px #eccd8f26}.response-length-select:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.additional-instructions{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:all .2s ease;width:100%}.additional-instructions:hover:not(:disabled){border-color:#eccd8f}.additional-instructions:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 3px #eccd8f26}.additional-instructions:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.additional-instructions::placeholder{color:#a0aec0;font-style:italic}.file-upload-container{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.file-upload-btn{padding:12px 20px;background:#fff;border:2px dashed #eccd8f;border-radius:8px;color:#f2be6e;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.file-upload-btn:hover{background:#fefcf7;border-color:#f2be6e;transform:translateY(-1px)}.uploaded-file-info{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fefcf7;border:1px solid #f3d9b7;border-radius:8px;max-width:400px}.file-name{font-size:14px;color:#4a5568;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.remove-file-btn{background:transparent;border:none;color:#f2be6e;cursor:pointer;font-size:16px;padding:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.remove-file-btn:hover:not(:disabled){background:#fefcf7;color:#eccd8f}.remove-file-btn:disabled{opacity:.5;cursor:not-allowed}.file-upload-hint{font-size:12px;color:#718096;font-style:italic;margin-top:6px;width:100%}.generate-btn-large{background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#2c2c2c;border:none;padding:18px 36px;border-radius:12px;cursor:pointer;font-size:18px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:12px;margin:0 auto;box-shadow:0 6px 20px #eccd8f66}.generate-btn-large:hover:not(:disabled){background:linear-gradient(135deg,#f2be6e,#eccd8f);transform:translateY(-2px);box-shadow:0 8px 25px #f2be6e80}.generate-btn-large:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background:#fee;color:#c33;padding:16px;border-radius:8px;margin-top:20px;border-left:4px solid #c33}.ai-response-section{margin-top:40px;background:linear-gradient(to bottom,#fefcf7,#fffbf5);border:2px solid #f3d9b7;border-radius:16px;padding:0;overflow:hidden;animation:fadeIn .5s ease-out}.ai-response-header-large{background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#2c2c2c;padding:20px 30px;display:flex;justify-content:space-between;align-items:center}.ai-label{font-size:18px;font-weight:600;display:flex;align-items:center;gap:10px}.response-actions{display:flex;align-items:center;gap:10px}.copy-response-btn{background:linear-gradient(135deg,#fff,#f8f9fa);color:#2c2c2c;border:2px solid rgba(44,44,44,.15);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #0000000d}.copy-response-btn:hover{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-color:#2c2c2c40;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.delete-response-btn{background:linear-gradient(135deg,#fff,#fff5f5);color:#c53030;border:2px solid rgba(197,48,48,.2);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #c5303014}.delete-response-btn:hover{background:linear-gradient(135deg,#fff5f5,#fed7d7);border-color:#c5303059;transform:translateY(-1px);box-shadow:0 4px 12px #c5303026}.edit-response-btn{background:linear-gradient(135deg,#fff,#f0f8ff);color:#2c5282;border:2px solid rgba(44,82,130,.2);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #2c528214}.edit-response-btn:hover{background:linear-gradient(135deg,#f0f8ff,#dbeafe);border-color:#2c528259;transform:translateY(-1px);box-shadow:0 4px 12px #2c528226}.save-edit-btn{background:linear-gradient(135deg,#38a169,#48bb78);color:#fff;border:2px solid rgba(56,161,105,.3);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #38a1694d}.save-edit-btn:hover:not(:disabled){background:linear-gradient(135deg,#2f855a,#38a169);border-color:#38a16980;transform:translateY(-1px);box-shadow:0 4px 12px #38a16966}.save-edit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.cancel-edit-btn{background:linear-gradient(135deg,#e2e8f0,#cbd5e0);color:#2d3748;border:2px solid rgba(45,55,72,.2);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #2d374814}.cancel-edit-btn:hover:not(:disabled){background:linear-gradient(135deg,#cbd5e0,#a0aec0);border-color:#2d374859;transform:translateY(-1px);box-shadow:0 4px 12px #2d374826}.cancel-edit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.ai-response-edit-textarea{width:100%;min-height:400px;padding:30px;font-size:16px;line-height:1.8;color:#2d3748;background:#fefcf7;border:2px solid #eccd8f;border-radius:0 0 12px 12px;font-family:inherit;resize:vertical;transition:all .2s ease}.ai-response-edit-textarea:focus{outline:none;border-color:#f2be6e;background:#fff;box-shadow:0 0 0 3px #eccd8f1a}.ai-response-edit-textarea:disabled{opacity:.6;cursor:not-allowed}.clear-response-btn{background:#2c2c2c1a;color:#2c2c2c;border:1px solid rgba(44,44,44,.2);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-response-btn:hover{background:#2c2c2c33;transform:rotate(90deg)}.ai-response-text{padding:30px;font-size:16px;line-height:1.8;color:#2d3748;white-space:pre-wrap;word-wrap:break-word}.loading,.error{text-align:center;padding:60px 20px;font-size:18px;color:#6c757d}.error{color:#c33}.saved-badge{display:inline-block;margin-left:12px;padding:4px 12px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border-radius:12px;font-size:12px;font-weight:600;box-shadow:0 2px 8px #28a7454d;transition:all .2s ease}.saved-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #28a74566}.edited-badge{display:inline-block;margin-left:12px;padding:4px 12px;background:linear-gradient(135deg,#3182ce,#4299e1);color:#fff;border-radius:12px;font-size:12px;font-weight:600;box-shadow:0 2px 8px #3182ce4d;transition:all .2s ease}.edited-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3182ce66}.loading-saved-response{padding:20px;background:#e7f3ff;border:2px solid #0077cc;border-radius:12px;color:#004d99;font-size:14px;font-weight:500;text-align:center;margin-top:20px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.admin-layout{min-height:100vh}.admin-banner{background:linear-gradient(135deg,var(--golden-yellow) 0%,var(--golden-alt) 100%);padding:.75rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000}.admin-banner-content{display:flex;align-items:center;gap:1.5rem}.admin-badge{background:var(--white);color:var(--text-dark);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;box-shadow:0 2px 8px #0000001a}.admin-user{color:var(--white);font-size:.9rem;font-weight:500}.admin-banner-actions{display:flex;align-items:center;gap:1rem}.admin-layout .settings-btn,.admin-layout .nav-btn,.admin-layout .back-btn,.admin-layout .switch-portal-btn{background:var(--white);color:var(--text-dark);padding:.5rem 1.25rem;font-size:.9rem;border:none;box-shadow:0 2px 8px #0000001a;white-space:nowrap;cursor:pointer;border-radius:8px;transition:all .2s}.admin-layout .settings-btn{background:linear-gradient(135deg,var(--brand-primary-light) 0%,#fef8ed 100%);color:var(--text-primary);border:2px solid var(--brand-primary)!important;font-weight:600}.admin-layout .settings-btn:hover{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dark) 100%);color:#fff!important;border-color:var(--brand-primary-dark)!important;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.admin-layout .nav-btn{background:linear-gradient(135deg,#10b981,#059669);color:var(--white);font-weight:600}.admin-layout .nav-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.admin-layout .back-btn{background:linear-gradient(135deg,#2196f3,#1976d2);color:var(--white);font-weight:600}.admin-layout .back-btn:hover,.admin-layout .switch-portal-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}@media (max-width: 768px){.admin-banner{flex-direction:column;gap:.75rem;padding:1rem}.admin-banner-content{flex-direction:column;gap:.5rem;text-align:center}.switch-portal-btn{width:100%}}.settings-panel{min-height:100vh;background:linear-gradient(135deg,#fff,#fefcf7);padding:2rem}.settings-header{max-width:1200px;margin:0 auto 2rem}.settings-header h1{margin:0 0 .5rem;color:var(--text-dark);font-size:2rem}.settings-subtitle{color:var(--text-light);font-size:1.1rem;margin:0}.settings-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.settings-section{background:var(--white);border-radius:16px;padding:2rem;box-shadow:var(--shadow)}.settings-section h2{margin:0 0 .5rem;color:var(--text-dark);font-size:1.5rem}.section-description{color:var(--text-light);margin:0 0 1.5rem;font-size:.95rem}.type-selector{display:flex;gap:1rem}.type-button{flex:1;padding:1rem 2rem;font-size:1.1rem;background:var(--white);color:var(--text-dark);border:2px solid var(--light-golden);border-radius:12px;cursor:pointer;transition:all .3s ease;font-weight:500}.type-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.type-button.active{background:linear-gradient(135deg,var(--golden-yellow) 0%,var(--golden-alt) 100%);color:var(--white);border-color:var(--golden-alt);font-weight:600}.setting-card{background:var(--light-golden);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.setting-label{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid var(--golden-yellow)}.setting-label strong{color:var(--text-dark);font-size:1.1rem}.current-value{background:var(--golden-yellow);color:var(--white);padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.model-selector,.instruction-selector{display:flex;flex-direction:column;gap:.75rem}.model-selector label,.instruction-selector label{font-weight:600;color:var(--text-dark);font-size:1rem}.model-dropdown,.instruction-dropdown{padding:.75rem 1rem;font-size:1rem;border:2px solid var(--golden-yellow);border-radius:8px;background:var(--white);color:var(--text-dark);cursor:pointer;transition:all .2s ease;font-family:inherit}.model-dropdown:hover:not(:disabled),.instruction-dropdown:hover:not(:disabled){border-color:var(--golden-alt);box-shadow:0 0 0 3px #eccd8f1a}.model-dropdown:focus,.instruction-dropdown:focus{outline:none;border-color:var(--golden-alt);box-shadow:0 0 0 3px #eccd8f33}.model-dropdown:disabled,.instruction-dropdown:disabled{opacity:.5;cursor:not-allowed}.success-message{background:#e8f5e9;border-left:4px solid #4caf50;color:#2e7d32;padding:1rem;border-radius:8px;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.info-box{background:#fff3e0;border-left:4px solid #ff9800;color:#e65100;padding:1rem;border-radius:8px;font-size:.9rem}.info-box strong{display:block;margin-bottom:.5rem}.instructions-preview{background:var(--white);border-radius:8px;padding:1rem}.instructions-preview h4{margin:0 0 .75rem;color:var(--text-dark);font-size:1rem}.instructions-text{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;padding:1rem;font-size:.85rem;line-height:1.6;color:var(--text-dark);white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;margin:0;font-family:Courier New,Courier,monospace}.settings-summary{background:linear-gradient(135deg,var(--golden-yellow) 0%,var(--golden-alt) 100%);border-radius:16px;padding:2rem;color:var(--white);box-shadow:var(--shadow-hover)}.settings-summary h3{margin:0 0 1.5rem;font-size:1.5rem}.summary-content{background:#fff3;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.3)}.summary-item:last-child{border-bottom:none}.summary-label{font-weight:600;font-size:1rem}.summary-value{background:var(--white);color:var(--text-dark);padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.summary-value.code{font-family:Courier New,Courier,monospace;font-size:.85rem}.summary-note{background:#fff3;padding:1rem;border-radius:8px;text-align:center;font-weight:500;font-size:1rem}.model-list{margin-top:2rem;padding-top:2rem;border-top:2px solid #e0e0e0}.model-list h4{margin:0 0 1rem;color:var(--text-dark);font-size:1rem;font-weight:600}.model-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.model-description{font-size:.85rem;color:var(--text-light);font-weight:400}.model-active-badge{background:#4caf50;color:#fff;padding:.35rem .75rem;border-radius:12px;font-size:.8rem;font-weight:600;white-space:nowrap}.category-list h4,.category-add-form h4,.model-list h4{margin:0 0 1rem;color:var(--text-dark);font-size:1rem;font-weight:600}.no-categories{color:var(--text-light);font-style:italic;padding:1rem;text-align:center}.categories-items{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.75rem}.category-item{background:var(--white);border-radius:8px;padding:.75rem 1rem;border:1px solid #e0e0e0}.category-display{display:flex;justify-content:space-between;align-items:center;gap:1rem}.category-name{font-weight:600;color:var(--text-dark);font-size:1rem;flex:1}.category-edit-btn,.category-delete-btn,.category-save-btn,.category-cancel-btn{padding:.5rem .75rem;font-size:.85rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500}.category-edit-btn{background:#2196f3;color:#fff}.category-edit-btn:hover:not(:disabled){background:#1976d2}.category-delete-btn{background:#f44336;color:#fff}.category-delete-btn:hover:not(:disabled){background:#d32f2f}.category-delete-btn:disabled{background:#bdbdbd;cursor:not-allowed;opacity:.5}.category-edit-form{display:flex;gap:.5rem;align-items:center}.category-edit-input{flex:1;padding:.5rem;border:2px solid var(--golden-yellow);border-radius:6px;font-size:1rem;font-family:inherit}.category-edit-input:focus{outline:none;border-color:var(--golden-alt)}.category-save-btn{background:#4caf50;color:#fff}.category-save-btn:hover:not(:disabled){background:#45a049}.category-cancel-btn{background:#9e9e9e;color:#fff}.category-cancel-btn:hover:not(:disabled){background:#757575}.category-add-form{padding-top:1.5rem;border-top:2px solid #e0e0e0}.add-category-inputs{display:flex;gap:.75rem}.category-input{flex:1;padding:.75rem 1rem;border:2px solid var(--golden-yellow);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s ease}.category-input:focus{outline:none;border-color:var(--golden-alt);box-shadow:0 0 0 3px #eccd8f1a}.category-add-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--golden-yellow) 0%,var(--golden-alt) 100%);color:var(--white);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow);white-space:nowrap}.category-add-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-hover)}.category-add-btn:disabled{background:#bdbdbd;cursor:not-allowed;transform:none;box-shadow:none}.instructions-editor{display:flex;flex-direction:column;gap:.75rem}.instructions-editor label{font-weight:600;color:var(--text-dark);font-size:1rem}.instructions-textarea{padding:1rem;font-size:.95rem;border:2px solid var(--golden-yellow);border-radius:8px;background:var(--white);color:var(--text-dark);font-family:Courier New,Courier,monospace;resize:vertical;min-height:200px;transition:all .2s ease}.instructions-textarea:hover:not(:disabled){border-color:var(--golden-alt);box-shadow:0 0 0 3px #eccd8f1a}.instructions-textarea:focus{outline:none;border-color:var(--golden-alt);box-shadow:0 0 0 3px #eccd8f33}.instructions-textarea:disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5}.save-settings-btn{padding:1rem 2rem;background:linear-gradient(135deg,var(--golden-yellow) 0%,var(--golden-alt) 100%);color:var(--white);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow);align-self:flex-start}.save-settings-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-hover)}.save-settings-btn:disabled{background:#bdbdbd;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.settings-panel{padding:1rem}.settings-section{padding:1.5rem}.type-selector{flex-direction:column}.setting-label,.summary-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.criterio-response-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.dashboard-subtitle{font-size:1rem;color:#666;margin:0}.alert{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:1.5rem;border-radius:8px;font-weight:500}.alert-error{background-color:#fee;color:#c00;border:1px solid #fcc}.alert-success{background-color:#efe;color:#060;border:1px solid #cfc}.alert button{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;color:inherit}.tabs{display:flex;gap:.5rem;border-bottom:2px solid #e0e0e0;margin-bottom:2rem}.tab{padding:1rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;font-size:1rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s}.tab:hover{color:#333;background-color:#f5f5f5}.tab.active{color:#2563eb;border-bottom-color:#2563eb;background-color:#eff6ff}.card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.card h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin-top:0;margin-bottom:1.5rem}.card h3{font-size:1.25rem;font-weight:600;color:#333;margin-top:1.5rem;margin-bottom:1rem}.card h4{font-size:1.1rem;font-weight:600;color:#444;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;color:#333;margin-bottom:.5rem}.form-control{width:100%;padding:.75rem;border:1px solid #d0d0d0;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-control:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-range{width:100%}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-right:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-success{background-color:#059669;color:#fff}.btn-success:hover:not(:disabled){background-color:#047857}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-warning{background-color:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background-color:#d97706}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.data-table{width:100%;border-collapse:collapse;margin-top:1rem}.data-table thead{background-color:#f9fafb}.data-table th{text-align:left;padding:1rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.data-table td{padding:1rem;border-bottom:1px solid #e5e7eb;vertical-align:top}.data-table tbody tr:hover{background-color:#f9fafb}.data-table input[type=checkbox]{width:18px;height:18px;cursor:pointer}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:capitalize}.status-badge-pending{background-color:#fef3c7;color:#92400e}.status-badge-running{background-color:#dbeafe;color:#1e40af}.status-badge-success{background-color:#d1fae5;color:#065f46}.status-badge-error{background-color:#fee2e2;color:#991b1b}.status-badge-cancelled{background-color:#e5e7eb;color:#374151}.criterio-preview{background-color:#eff6ff;border:2px solid #bfdbfe;border-radius:8px;padding:1.25rem;margin-bottom:1.5rem;margin-top:.5rem}.criterio-preview-header{margin-bottom:.75rem}.criterio-preview-label{font-size:.75rem;font-weight:600;color:#1e40af;text-transform:uppercase;letter-spacing:.5px}.criterio-preview-hierarchy{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem;background-color:#dbeafe;border-radius:6px}.hierarchy-item{font-weight:600;color:#1e3a8a;font-size:.95rem}.hierarchy-separator{color:#60a5fa;font-weight:400;font-size:1.1rem}.criterio-preview-text{font-size:.95rem;line-height:1.6;color:#1f2937;padding:.75rem;background-color:#fff;border-radius:6px;border-left:4px solid #3b82f6}.dataset-create-section{background-color:#f0f9ff;border:2px solid #bfdbfe;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.dataset-create-section h3{margin-top:0;color:#1e40af}.dataset-description{font-size:.875rem;color:#666;margin-top:.25rem}.response-preview{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;color:#666}.model-id{font-size:.75rem;color:#666;font-family:monospace;margin-top:.25rem}.empty-state{text-align:center;padding:3rem;color:#9ca3af;font-style:italic}.token-stats{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.token-stats h4{margin:0 0 1rem;color:#15803d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.875rem;color:#666}.stat-value{font-size:1.25rem;font-weight:600;color:#1a1a1a}@media (max-width: 768px){.criterio-response-dashboard{padding:1rem}.tabs{flex-direction:column}.tab{text-align:left;border-bottom:1px solid #e0e0e0}.tab.active{border-left:4px solid #2563eb}.data-table{font-size:.875rem}.data-table th,.data-table td{padding:.75rem .5rem}.btn{width:100%;margin-bottom:.5rem}.stats-grid{grid-template-columns:1fr}}.token-stats-detail{margin-top:2rem;border:2px solid #2563eb}.token-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.token-stats-header h2{font-size:1.5rem;color:#1a1a1a;margin:0}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#f9fafb;border-radius:8px}.stat-box{display:flex;flex-direction:column;gap:.5rem}.stat-box .stat-value{font-size:1.5rem;font-weight:700;color:#1a1a1a}.stat-box .stat-value.warning{color:#dc2626}.examples-breakdown{margin-top:2rem}.examples-breakdown h3{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin-bottom:1rem}.examples-table-container{overflow-x:auto;margin-bottom:2rem}.token-table{font-size:.875rem;white-space:nowrap}.token-table thead{background:#f3f4f6;position:sticky;top:0;z-index:10}.token-table th{font-weight:600;color:#374151;text-align:right;padding:.75rem .5rem}.token-table th:first-child,.token-table th:nth-child(2){text-align:left}.token-table td{text-align:right;padding:.75rem .5rem;font-variant-numeric:tabular-nums}.token-table td:first-child,.token-table .criterio-cell{text-align:left}.criterio-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;cursor:help}.highlight-servizi{background:#fef3c7;font-weight:600}.highlight-obiettivi{background:#dbeafe;font-weight:600}.highlight-migliorie{background:#d1fae5;font-weight:600}.highlight-excel{background:#e9d5ff;font-weight:600}.total-tokens{background:#f3f4f6;font-size:.95rem}.total-tokens.error{background:#fee2e2;color:#dc2626}.skipped-examples-section{margin-top:2rem;padding:1.5rem;background:#fef2f2;border:2px solid #fca5a5;border-radius:8px}.warning-header{color:#dc2626;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.skipped-row{background:#fee2e2;opacity:.85}.skipped-row:hover{opacity:1;background:#fecaca}.token-count-ok{color:#059669;font-weight:600;font-variant-numeric:tabular-nums}.token-count-error{color:#dc2626;font-weight:700;font-variant-numeric:tabular-nums}.token-count-na{color:#9ca3af;font-style:italic}.annotations-list .data-table td .btn{width:auto!important;margin-bottom:0!important;flex-shrink:0;white-space:nowrap}.expanded-row{background:#f9fafb}.expanded-row td{padding:1.5rem!important}.token-breakdown-expanded{border:2px solid #e5e7eb;border-radius:8px;padding:1.5rem;background:#fff}.token-breakdown-expanded h4{margin:0 0 1rem;font-size:1.1rem;color:#1a1a1a}.token-breakdown-expanded .token-table{width:100%;margin:0}.token-breakdown-grid{display:flex;flex-direction:column;gap:1.5rem}.token-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem}.token-section-header{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.token-item{padding:.75rem 0}.token-item-minor{opacity:.7;font-size:.875rem}.token-item-major{padding:1rem;margin:.5rem 0;border-radius:6px;background:#fff;border:2px solid transparent}.token-item-servizi{border-color:#fbbf24!important;background:#fffbeb!important}.token-item-obiettivi{border-color:#60a5fa!important;background:#eff6ff!important}.token-item-migliorie{border-color:#34d399!important;background:#ecfdf5!important}.token-item-excel{border-color:#c084fc!important;background:#faf5ff!important}.token-item-label{font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.95rem}.token-item-value{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.token-number{font-size:1.5rem;font-weight:700;color:#1a1a1a;font-variant-numeric:tabular-nums}.token-percent{font-size:1.125rem;font-weight:600;color:#6b7280}.token-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.token-bar-fill{height:100%;transition:width .3s ease}.token-bar-system{background:#9ca3af}.token-bar-servizi{background:#fbbf24}.token-bar-obiettivi{background:#60a5fa}.token-bar-migliorie{background:#34d399}.token-bar-excel{background:#c084fc}.token-bar-ground-truth{background:#f472b6}.token-compact-group{margin-bottom:1.5rem}.token-compact-title{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:.75rem}.token-compact-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;margin:.25rem 0;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.token-compact-item.token-item-servizi{background:#fffbeb;border-color:#fbbf24}.token-compact-item.token-item-obiettivi{background:#eff6ff;border-color:#60a5fa}.token-compact-item.token-item-migliorie{background:#ecfdf5;border-color:#34d399}.token-compact-item.token-item-excel{background:#faf5ff;border-color:#c084fc}.token-compact-label{font-weight:600;color:#374151;font-size:.9rem}.token-compact-right{display:flex;gap:1rem;align-items:baseline}.token-compact-number{font-size:1.125rem;font-weight:700;color:#1a1a1a;font-variant-numeric:tabular-nums}.token-compact-percent{font-size:.875rem;font-weight:600;color:#6b7280;min-width:50px;text-align:right}.token-compact-total{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-top:1rem;background:#1f2937;color:#fff;border-radius:6px;font-weight:700}.token-compact-total .token-compact-number{color:#fff;font-size:1.5rem}.token-compact-total .token-compact-percent{color:#fff;font-size:1.125rem}:root{--brand-primary: #eccd8f;--brand-primary-light: #f3d9b7;--brand-primary-dark: #d4a63a;--brand-accent: #f2be6e;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-info: #3b82f6;--color-info-light: #dbeafe;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-tertiary: #737373;--text-muted: #9ca3af;--text-inverse: #ffffff;--bg-primary: #ffffff;--bg-secondary: #fefcf9;--bg-tertiary: #f9fafb;--bg-surface: #ffffff;--bg-overlay: rgba(0, 0, 0, .5);--border-primary: #e5e7eb;--border-secondary: #d1d5db;--border-accent: var(--brand-primary);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--font-family-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .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;--primary: var(--brand-primary);--primary-light: var(--brand-primary-light);--primary-accent: var(--brand-accent);--primary-shadow: rgba(236, 205, 143, .3);--background-primary: var(--bg-primary);--background-secondary: var(--bg-secondary);--background-tertiary: var(--brand-primary-light);--border-primary: var(--border-primary);--border-secondary: var(--brand-primary);--primary-yellow: var(--brand-primary);--primary-yellow-dark: var(--brand-primary-dark);--primary-yellow-light: var(--brand-primary-light);--green: var(--color-success);--green-dark: #059669;--red: var(--color-error);--red-dark: #dc2626;--orange: var(--color-warning);--orange-dark: #d97706;--blue: var(--color-info);--blue-dark: #2563eb}*{margin:0;padding:0;box-sizing:border-box}.skip-to-main{position:absolute;top:-40px;left:6px;background:var(--primary);color:#fff;padding:8px;text-decoration:none;z-index:1000;border-radius:4px;transition:top .3s}.skip-to-main:focus{top:6px}*:focus{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:2px}html,body,#root{margin:0;padding:0;width:100%;height:100%}.app-container{display:flex;height:100vh;width:100vw;background:var(--bg-secondary);font-family:var(--font-family-sans);color:var(--text-primary);overflow:hidden;margin:0;padding:0}.app-logo{height:32px;width:auto;object-fit:contain;opacity:.9;cursor:pointer;transition:opacity .2s;margin-right:.5rem}.app-logo:hover{opacity:1}.sidebar.collapsed .app-logo{height:28px;width:auto;max-width:60px;margin-right:0}.sidebar{width:280px;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:var(--shadow-md);flex-shrink:0}.sidebar.collapsed{width:110px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid #f1f3f4;margin-top:0;min-height:60px;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left{display:flex;align-items:center;gap:.75rem}.sidebar-header h1,.sidebar-header h3{margin:0;font-size:.875rem;font-weight:600;color:var(--text-secondary);opacity:1;transition:opacity .2s ease;letter-spacing:-.01em;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-header h1,.sidebar.collapsed .sidebar-header h3{opacity:0;width:0}.sidebar-toggle{background:none;border:none;font-size:1rem;cursor:pointer;padding:.5rem;border-radius:4px;color:#6b7280;transition:all .15s ease;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background:#f9fafb;color:#374151}.sidebar-nav{flex:1;padding:1rem;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:none;background:none;border-radius:6px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:left;width:100%;font-size:.8rem;color:var(--text-secondary);position:relative;font-weight:500;border:1px solid transparent}.nav-item:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:var(--text-primary);border-color:#e2e8f0;transform:translate(2px)}.nav-item.active{background:linear-gradient(135deg,var(--primary-yellow) 0%,var(--primary-yellow-dark) 100%);color:#fff;box-shadow:0 4px 12px #e8ba4e66,0 2px 4px #e8ba4e33;border-color:var(--primary-yellow-dark);transform:translate(4px)}.nav-item.active:hover{background:linear-gradient(135deg,var(--primary-yellow-light) 0%,var(--primary-yellow) 100%);transform:translate(4px)}.nav-icon{font-size:1rem;min-width:20px;text-align:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.nav-label{font-weight:500;font-size:.8rem;transition:all .2s ease;white-space:nowrap;letter-spacing:-.01em}.sidebar.collapsed .nav-label{opacity:0;width:0}.sidebar.collapsed .nav-item{justify-content:center;padding:.875rem .5rem;margin:.125rem .5rem;border-radius:8px;position:relative;max-width:calc(100% - 1rem)}.sidebar.collapsed .nav-item:hover{transform:none}.sidebar.collapsed .nav-item.active{background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-dark));color:#fff;transform:none!important;box-shadow:0 2px 8px #eccd8f4d}.sidebar.collapsed .nav-item.active:hover{transform:none!important}.sidebar.collapsed .sidebar-nav{padding:.75rem 0;gap:2px}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1rem .5rem}.sidebar.collapsed .header-left{justify-content:center}.sidebar.collapsed .sidebar-toggle{position:absolute;top:8px;right:8px;width:24px;height:24px;font-size:.75rem}.sidebar.collapsed .nav-item{position:relative}.sidebar.collapsed .nav-item:hover:after{content:attr(data-tooltip);position:absolute;left:100%;top:50%;transform:translateY(-50%);background:var(--text-primary);color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.75rem;white-space:nowrap;z-index:1000;margin-left:.5rem;opacity:0;animation:tooltipFadeIn .2s forwards}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(-5px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--background-primary)}.main-content .evaluation-dashboard{flex:1;height:100vh;margin:0;padding:0;background:none}.content-header{background:#fff;padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;display:flex;justify-content:flex-end;align-items:center;min-height:64px}.content-body{flex:1;padding:1.5rem;overflow-y:auto;background:#fafafa}.tool-content{max-width:none;width:100%;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;margin:0;height:fit-content}.tool-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.tool-header h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#111827;letter-spacing:-.025em}.tool-description{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5;font-weight:400}.header-controls{display:flex;align-items:center;gap:1rem}.instructions-toggle-btn{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.instructions-toggle-btn:hover{background:#f9fafb;border-color:#9ca3af;color:#111827}.model-selector{display:flex;align-items:center;gap:.75rem}.model-selector label{font-size:.875rem;font-weight:500;color:#374151;white-space:nowrap}.model-dropdown{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#111827;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;outline:none;min-width:140px}.model-dropdown:hover{border-color:#9ca3af;background:#f9fafb}.model-dropdown:focus{border-color:#eccd8f;box-shadow:0 0 0 3px #e8ba4e1a}.model-dropdown:disabled{opacity:.6;cursor:not-allowed;background:#f9fafb}.input-toggle{display:flex;background:#f3f4f6;border-radius:8px;padding:4px;margin-bottom:1.5rem;gap:4px}.toggle-btn{flex:1;padding:.75rem 1rem;border:none;border-radius:6px;background:transparent;color:#6b7280;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.toggle-btn.active{background:#fff;color:#111827;box-shadow:0 1px 3px #0000001a}.toggle-btn:hover:not(.active){color:#374151}.classifier-container{display:flex;flex-direction:column;gap:2rem;align-items:stretch}textarea{width:100%;padding:1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit;font-weight:400;line-height:1.5;resize:vertical;min-height:120px;background:#fff;color:#111827;transition:all .15s ease;outline:none}textarea:focus{border-color:#eccd8f;box-shadow:0 0 0 3px #e8ba4e1a}textarea::placeholder{color:#9ca3af;opacity:1}.classify-btn{align-self:center;min-width:180px;padding:.75rem 1.5rem;border:none;border-radius:6px;background:var(--primary-yellow);color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease}.classify-btn:hover:not(:disabled){background:var(--primary-yellow-dark)}.classify-btn:disabled{opacity:.6;cursor:not-allowed}.file-upload-section{display:flex;flex-direction:column;gap:1.5rem}.file-drop-zone{border:2px dashed #d1d5db;border-radius:12px;padding:2rem;background:#fafafa;cursor:pointer;transition:all .2s ease;min-height:200px;display:flex;align-items:center;justify-content:center}.file-drop-zone:hover{border-color:#9ca3af;background:#f3f4f6}.file-drop-zone.drag-over{border-color:#eccd8f;background:#f0d28d;border-style:solid}.file-drop-zone.has-file{border-style:solid;border-color:#eccd8f;background:#ecfdf5}.drop-message{text-align:center;color:#6b7280}.upload-icon{font-size:3rem;margin-bottom:1rem;opacity:.7}.drop-message p{margin:.5rem 0;font-size:1rem;color:#374151;font-weight:500}.file-types{font-size:.875rem;color:#9ca3af}.browse-text{display:inline-block;margin-top:1rem;padding:.5rem 1rem;background:#eccd8f;border-radius:6px;font-size:.875rem;color:#fff;font-weight:500}.file-selected{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.file-icon{font-size:2rem;opacity:.8}.file-info{flex:1;text-align:left}.file-name{font-weight:500;color:#111827;margin-bottom:.25rem;word-break:break-word}.file-size{font-size:.875rem;color:#9ca3af}.remove-file{width:28px;height:28px;border-radius:50%;border:none;background:#f3f4f6;color:#6b7280;font-size:1rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.remove-file:hover{background:#ef4444;color:#fff}.text-input-section{display:flex;flex-direction:column;gap:1.5rem}.text-input-container{position:relative}.text-input-container textarea{padding-right:3rem}.clear-text{position:absolute;top:1rem;right:1rem;width:24px;height:24px;border-radius:50%;border:none;background:#f3f4f6;color:#9ca3af;font-size:.875rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.clear-text:hover{background:#6b7280;color:#fff}.instructions-panel{margin-top:2rem;padding:1.5rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.instructions-panel h3{margin-top:0;margin-bottom:1rem;color:#111827;font-weight:600;font-size:1.125rem}.instructions-view{display:flex;flex-direction:column;gap:1.5rem}.instructions-text{background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;padding:1rem;max-height:200px;overflow-y:auto}.instructions-text pre{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;line-height:1.5;color:#374151;white-space:pre-wrap;word-wrap:break-word}.instructions-edit{display:flex;flex-direction:column;gap:1.5rem}.instructions-textarea{width:100%;padding:1rem;border:1px solid #d1d5db;border-radius:6px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;line-height:1.5;color:#111827;background:#fff;resize:vertical;min-height:150px;outline:none;transition:border-color .15s ease}.instructions-textarea:focus{border-color:#eccd8f;box-shadow:0 0 0 3px #e8ba4e1a}.instructions-actions{display:flex;gap:1rem;flex-wrap:wrap}.edit-instructions-btn,.save-instructions-btn{padding:.75rem 1rem;border:none;border-radius:6px;background:#eccd8f;color:#fff;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease}.edit-instructions-btn:hover,.save-instructions-btn:hover{background:#d4b373}.save-instructions-btn:disabled{opacity:.6;cursor:not-allowed;background:#9ca3af}.close-instructions-btn,.cancel-edit-btn{padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease}.close-instructions-btn:hover,.cancel-edit-btn:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}@media (max-width: 1024px){.sidebar{width:100px}.tool-content{padding:2rem;margin:0 1rem}.content-body{padding:1.5rem}}@media (max-width: 768px){.app-container{flex-direction:column}.sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.sidebar.collapsed{width:100%;height:70px}.sidebar-header{margin-top:0;padding:1rem 1.5rem}.sidebar.collapsed .sidebar-header h1,.sidebar.collapsed .sidebar-header h3{opacity:1}.sidebar-nav{flex-direction:row;overflow-x:auto;padding:.5rem;gap:.25rem}.sidebar.collapsed .sidebar-nav{display:none}.nav-item{min-width:120px;flex-shrink:0}.sidebar.collapsed .nav-label{opacity:1}.sidebar.collapsed .nav-item{justify-content:flex-start;padding:1rem 1.25rem}.main-content{height:calc(100vh - 70px)}.app-logo{display:none}.content-header,.content-body{padding:1rem}.tool-content{padding:1.5rem;margin:0;border-radius:8px}.tool-header h2{font-size:1.5rem}.header-controls{gap:1rem}.model-selector{flex-direction:column;gap:.5rem;align-items:flex-start}.model-selector label{font-size:.8rem}.model-dropdown{min-width:100px;font-size:.8rem}.instructions-toggle-btn{padding:.5rem;font-size:.8rem}}@media (max-width: 480px){.tool-content{padding:1rem}.tool-header{margin-bottom:1.5rem;padding-bottom:1rem}.tool-header h2{font-size:1.3rem}.input-toggle{flex-direction:column;gap:.5rem}.toggle-btn{padding:1rem;font-size:.9rem}.file-drop-zone{min-height:150px}.instructions-panel{margin-top:1rem;padding:1rem}.content-header{flex-direction:column;gap:1rem;align-items:stretch}.header-controls{flex-direction:column;gap:.5rem}}.button-group{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.debug-btn{align-self:center;min-width:150px;padding:.75rem 1.5rem;border:1px solid #6b7280;border-radius:6px;background:#6b7280;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.debug-btn:hover:not(:disabled){background:#4b5563;border-color:#4b5563}.debug-btn:disabled{background:#d1d5db;border-color:#d1d5db;color:#9ca3af;cursor:not-allowed}.debug-result{margin-top:1rem;padding:1.5rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.debug-result h3{margin:0 0 1rem;color:#111827;font-size:1rem;font-weight:600}.extracted-text{max-height:300px;overflow-y:auto;background:#f9fafb;border:1px solid #d1d5db;border-radius:6px;padding:1rem;margin-bottom:1rem}.extracted-text pre{margin:0;white-space:pre-wrap;word-wrap:break-word;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8125rem;line-height:1.5;color:#374151}.close-debug,.show-debug{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;font-size:.875rem;cursor:pointer;transition:all .15s ease;margin-top:.5rem}.close-debug:hover,.show-debug:hover{background:#f9fafb;color:#374151}.result{margin-top:1.5rem;padding:2rem;background:linear-gradient(135deg,#f8f4e6,khaki);border-radius:12px;border:2px solid #daa520;box-shadow:0 8px 25px #daa52026;position:relative;overflow:hidden;transition:all .3s ease}.result:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#daa520,#b8860b,#daa520);animation:shimmer 2s ease-in-out infinite alternate}@keyframes shimmer{0%{opacity:.7}to{opacity:1}}.result:hover{transform:translateY(-2px);box-shadow:0 12px 35px #daa52040}.result h3{margin:0;color:#8b6914;font-size:1.4rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.75rem;text-shadow:0 1px 2px rgba(255,255,255,.8);letter-spacing:.5px}.result h3:before{content:"🎯";font-size:1.5rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.save-as-new-btn{padding:.5rem .75rem;border:1px solid #eccd8f;border-radius:6px;background:#eccd8f;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.save-as-new-btn:hover:not(:disabled){background:#f2be6e;border-color:#f2be6e}.save-as-new-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;padding:1.5rem;min-width:400px;max-width:90vw;box-shadow:0 20px 60px #0003;border:1px solid #e5e7eb}.modal-content h3{margin:0 0 1rem;font-size:1.25rem;font-weight:700;color:#111827;display:flex;align-items:center;gap:.5rem}.modal-body label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:#374151}.instruction-name-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:all .15s ease;outline:none}.instruction-name-input:focus{border-color:#eccd8f;box-shadow:0 0 0 3px #e8ba4e1a}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.save-modal-btn{padding:.5rem 1rem;border:1px solid #eccd8f;border-radius:6px;background:#eccd8f;color:#8b6914;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.save-modal-btn:hover:not(:disabled){background:#d4a438;border-color:#d4a438}.save-modal-btn:disabled{opacity:.5;cursor:not-allowed}.cancel-modal-btn{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}@media (max-width: 640px){.tool-content{padding:1rem}.tool-header h2{font-size:1.25rem}.toggle-btn{padding:.5rem .75rem;font-size:.8125rem}textarea{padding:.875rem;font-size:.8125rem}.classify-btn{min-width:140px;padding:.75rem 1rem;font-size:.8125rem}.file-drop-zone{padding:1.5rem 1rem;min-height:120px}.upload-icon{font-size:2rem}.drop-message p{font-size:.875rem}.file-selected{padding:.75rem;gap:.75rem}.file-icon{font-size:1.25rem}.button-group{gap:.75rem}.debug-btn{min-width:120px;padding:.625rem 1rem;font-size:.8125rem}}.instructions-tab-content{display:flex;flex-direction:column;gap:2rem}.instruction-set-selector,.model-selector-section{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000a}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.25rem}.select-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:.75rem 2.5rem .75rem 1rem;font-size:.875rem;color:#1f2937;transition:all .2s ease;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5rem 1.5rem}.select-dropdown:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61a}.select-dropdown:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.instructions-editor{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000a}.editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f3f4f6}.editor-header h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0}.editor-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.edit-btn,.save-btn,.cancel-btn{background:#eccd8f;border:1px solid #d1d5db;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.25rem;color:#78350f}.edit-btn:hover,.cancel-btn:hover{background:#f9fafb;border-color:#9ca3af;color:#374151}.edit-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.save-btn.primary{background:#eccd8f;color:#fff;border-color:#eccd8f}.save-btn.primary:hover{background:#f2be6e;border-color:#f2be6e}.save-btn.secondary{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.save-btn.secondary:hover{background:var(--brand-accent);border-color:var(--brand-accent)}.cancel-btn{background:#ef4444;color:#fff;border-color:#ef4444}.cancel-btn:hover{background:#dc2626;border-color:#dc2626}.instructions-view{min-height:200px}.instructions-text pre{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.8125rem;line-height:1.5;color:#1e293b;white-space:pre-wrap;word-wrap:break-word;margin:0;max-height:300px;overflow-y:auto}.instructions-textarea{width:100%;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.8125rem;line-height:1.5;color:#1e293b;resize:vertical;min-height:200px;transition:all .2s ease}.instructions-textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61a}.model-tab-content{display:flex;flex-direction:column;gap:2rem}.model-info{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000a}.model-info h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid #f3f4f6}.model-details{display:flex;flex-direction:column;gap:.75rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.detail-item .label{font-size:.875rem;font-weight:500;color:#6b7280}.detail-item .value{font-size:.875rem;font-weight:600;color:#1f2937}.detail-item .value.code{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-size:.75rem}.status.active{color:#f2be6e;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.model-capabilities{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000a}.model-capabilities h3{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid #f3f4f6}.capabilities-grid{display:grid;grid-template-columns:1fr;gap:1rem}.capability-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#ffffff80;border:1px solid #f3f4f6;border-radius:8px;transition:all .2s ease}.capability-item:hover{background:#fffc;border-color:#d1d5db;box-shadow:0 2px 4px #0000000a}.capability-icon{font-size:1.5rem;flex-shrink:0}.capability-content h4{font-size:.875rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.capability-content p{font-size:.8125rem;color:#6b7280;margin:0;line-height:1.4}@media (min-width: 768px){.capabilities-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.editor-actions{justify-content:flex-start}}.instruction-sets-list{margin:2rem 0}.instruction-sets-list h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.instruction-sets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1rem}.instruction-set-card{background:#ffffffe6;border:2px solid #e5e7eb;border-radius:12px;padding:1rem;transition:all .2s ease;position:relative;cursor:pointer}.instruction-set-card:hover{border-color:#eccd8f;box-shadow:0 4px 12px #e8ba4e26;transform:translateY(-2px)}.instruction-set-card.active{border-color:#eccd8f;background:linear-gradient(135deg,#e8ba4e0d,#fffffff2);box-shadow:0 4px 16px #e8ba4e33}.instruction-set-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.instruction-set-name{font-weight:600;font-size:1rem;color:#1f2937}.instruction-set-actions{display:flex;gap:.5rem}.delete-instruction-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s ease;opacity:.6}.delete-instruction-btn:hover{background:#ef44441a;opacity:1;transform:scale(1.1)}.delete-instruction-btn:disabled{opacity:.3;cursor:not-allowed}.instruction-set-preview{color:#6b7280;font-size:.875rem;line-height:1.4;margin-bottom:.75rem;background:#f9fafb;padding:.75rem;border-radius:6px;border-left:3px solid #e5e7eb}.active-indicator{position:absolute;top:-8px;right:-8px;background:#eccd8f;color:#fff;font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:12px;box-shadow:0 2px 8px #10b9814d}.delete-confirmation .modal-body p{margin-bottom:.75rem;color:#374151;line-height:1.5}.delete-confirmation .modal-body strong{color:#ef4444;font-weight:600}.delete-confirm-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem;box-shadow:0 2px 8px #ef44444d}.delete-confirm-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.instruction-sets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.instruction-sets-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.add-instruction-btn{background:linear-gradient(135deg,#eccd8f,#d4a843);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem;box-shadow:0 2px 8px #e8ba4e4d;display:flex;align-items:center;gap:.5rem}.add-instruction-btn:hover{background:linear-gradient(135deg,#d4a843,#c59738);box-shadow:0 4px 12px #e8ba4e66;transform:translateY(-1px)}.add-instruction-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.classification-type-selector{margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 2px 4px #0000000a}.classification-type-selector h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.type-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.type-card{padding:1.5rem;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s ease;background:#fafafa;display:flex;align-items:center;gap:1rem;position:relative}.type-card:hover{border-color:var(--blue);background:#f8faff;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.type-card.active{border-color:var(--blue);background:linear-gradient(135deg,#dbeafe,#bfdbfe);box-shadow:0 4px 12px #3b82f633}.type-card.active:before{content:"✓";position:absolute;top:.75rem;right:.75rem;width:20px;height:20px;background:var(--blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.type-icon{font-size:2rem;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:12px;background:#fffc;border:1px solid rgba(0,0,0,.1)}.type-card.active .type-icon{background:#ffffffe6}.type-info{flex:1}.type-info h4{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.type-description{font-size:.875rem;color:#6b7280;margin-bottom:.75rem;line-height:1.4}.type-formats{font-size:.75rem;color:#4b5563;background:#0000000d;padding:.25rem .5rem;border-radius:6px;display:inline-block;margin-bottom:.25rem;font-weight:500}.type-categories{font-size:.75rem;color:#f2be6e;font-weight:500}.type-card.active .type-formats{background:#3b82f61a;color:#4b5563}.type-card.active .type-categories{color:#047857}@media (max-width: 768px){.type-cards{grid-template-columns:1fr}.type-card{padding:1rem;gap:.75rem}.type-icon{width:50px;height:50px;font-size:1.5rem}.classification-type-selector{padding:1rem}}.classification-type-selector{padding:1rem;border-bottom:1px solid #e5e7eb;margin-bottom:1rem}.type-toggle-container{display:flex;flex-direction:column;gap:.75rem}.type-toggle-header{display:flex;align-items:center;justify-content:center}.toggle-label{font-size:.65rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.type-toggle-switch{display:flex;background:#f3f4f6;border-radius:8px;padding:.25rem;gap:.25rem}.type-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .4rem;border:none;border-radius:6px;background:transparent;cursor:pointer;transition:all .2s ease;font-size:.75rem;font-weight:500;color:var(--text-tertiary)}.type-option:hover{background:#e5e7eb;color:#374151}.type-option.active{background:linear-gradient(135deg,#eccd8f,#d4b373);color:#fff;box-shadow:0 2px 4px #e8ba4e4d;transform:translateY(-1px)}.option-icon{font-size:.9rem}.option-text{font-weight:500;font-size:.75rem}.type-indicator-collapsed{padding:.75rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.current-type-badge{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand-primary-light) 0%,var(--brand-primary) 100%);width:36px;height:36px;border-radius:8px;font-size:1rem;border:1px solid var(--brand-primary);box-shadow:var(--shadow-sm)}.change-type-btn-collapsed{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:.7rem;color:var(--text-secondary)}.change-type-btn-collapsed:hover{background:var(--brand-primary-light);border-color:var(--brand-primary);color:var(--text-primary);transform:rotate(90deg)}.type-info-bar{display:flex;gap:1rem;margin-top:.75rem;padding:.75rem;background:#3b82f60d;border:1px solid rgba(59,130,246,.1);border-radius:8px}.info-item{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#4b5563}.header-icon{margin-right:.5rem}.sidebar.collapsed .classification-type-selector{padding:.75rem;margin:.5rem .25rem}.sidebar.collapsed .type-toggle-container{display:none}.sidebar.collapsed .type-selector-collapsed{padding:.75rem .5rem}.collapsed-type-options{display:flex;flex-direction:column;gap:.25rem;align-items:center}.collapsed-type-option{width:32px;height:32px;border-radius:6px;border:1px solid var(--border-primary);background:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.collapsed-type-option:hover{background:var(--brand-primary-light);border-color:var(--brand-primary);transform:scale(1.05)}.collapsed-type-option.active{background:linear-gradient(135deg,var(--brand-primary),var(--brand-primary-dark));border-color:var(--brand-primary-dark);color:#fff;box-shadow:var(--shadow-sm)}@media (max-width: 768px){.type-info-bar{flex-direction:column;gap:.5rem}.classification-type-selector{padding:.75rem}}.categories-management{padding:1.5rem 0}.categories-list .section-header,.models-list .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#eccd8f0f,#f2be6e17);border:1px solid rgba(236,205,143,.15);border-left:4px solid var(--brand-primary);border-radius:12px;position:relative;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1)}.categories-list .section-header:hover,.models-list .section-header:hover{background:linear-gradient(135deg,#eccd8f14,#f2be6e1f);border-color:#eccd8f40;border-left-color:var(--brand-accent);transform:translate(2px);box-shadow:0 4px 16px #eccd8f1f,0 2px 6px #eccd8f14}.categories-list .section-header h3,.models-list .section-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);letter-spacing:-.025em}.section-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#374151}.add-category-btn{background:linear-gradient(135deg,#eccd8f,#d4b373);color:#fff;border:none;padding:.75rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #e8ba4e33}.add-category-btn:hover{background:linear-gradient(135deg,#f2daa5,#eccd8f);transform:translateY(-1px);box-shadow:0 4px 8px #e8ba4e4d}.add-category-btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.category-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.category-card:hover{box-shadow:0 4px 6px #0000001a;border-color:#eccd8f}.category-display{display:flex;justify-content:space-between;align-items:center}.category-name{font-size:1rem;font-weight:500;color:#374151}.category-actions{display:flex;gap:.5rem}.edit-btn,.delete-btn{background:transparent;border:none;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s ease;font-size:1rem}.edit-btn:hover{background:#3b82f61a}.delete-btn:hover{background:#ef44441a}.edit-btn:disabled,.delete-btn:disabled{cursor:not-allowed;opacity:.5}.edit-category{display:flex;flex-direction:column;gap:.75rem}.category-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s ease}.category-input:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 3px #e8ba4e1a}.edit-buttons{display:flex;gap:.5rem}.save-btn,.cancel-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.save-btn{background:#eccd8f;color:#fff}.save-btn:hover{background:#f2be6e}.save-btn:disabled{background:#9ca3af;cursor:not-allowed}.cancel-btn{background:#f3f4f6;color:#6b7280}.cancel-btn:hover{background:#e5e7eb;color:#374151}.cancel-btn:disabled{background:#f9fafb;cursor:not-allowed}.add-category-form{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#fefcf9,#fef9f3);border:2px dashed #eccd8f;border-radius:8px}.add-category-form .form-header h3{margin:0 0 1rem;color:#374151;font-size:1rem}.form-content{display:flex;flex-direction:column;gap:1rem}.form-buttons{display:flex;gap:.75rem}.form-buttons .save-btn{background:linear-gradient(135deg,#eccd8f,#d4b373);color:#fff;padding:.75rem 1.25rem}.form-buttons .save-btn:hover{background:linear-gradient(135deg,#f2daa5,#eccd8f)}.form-buttons .cancel-btn{background:#f3f4f6;color:#6b7280;padding:.75rem 1.25rem}@media (max-width: 768px){.categories-grid{grid-template-columns:1fr}.categories-list .section-header,.models-list .section-header{flex-direction:column;gap:1rem;align-items:stretch;padding:1rem 1.25rem;border-left-width:3px}.categories-list .section-header h3,.models-list .section-header h3{font-size:1rem}.add-category-btn{width:100%;justify-content:center}}.classification-config{margin-bottom:2rem}.section-header{margin-bottom:1rem}.section-header h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.classification-config .section-header,.classification-input .section-header{position:relative;padding:1rem 1.25rem;background:linear-gradient(135deg,#eccd8f14,#f2be6e1f);border:1px solid rgba(236,205,143,.2);border-left:4px solid var(--brand-primary);border-radius:8px;color:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:1.5rem}.classification-config .section-header:before,.classification-input .section-header:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-accent) 100%);opacity:0;border-radius:7px;transition:opacity .3s ease;z-index:-1}.classification-config .section-header:hover:before,.classification-input .section-header:hover:before{opacity:.05}.classification-config .section-header:hover,.classification-input .section-header:hover{border-left-color:var(--brand-accent);transform:translate(2px);box-shadow:0 2px 8px #eccd8f26,0 0 0 1px #eccd8f1a}.classification-config .section-header h3,.classification-input .section-header h3{color:var(--text-primary);margin:0;font-size:1.125rem;font-weight:600;letter-spacing:-.025em;display:flex;align-items:center;gap:.75rem}.classification-config .section-header h3:before,.classification-input .section-header h3:before{content:attr(data-icon);display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-accent) 100%);border-radius:6px;color:#fff;font-size:.875rem;font-weight:500;box-shadow:0 2px 4px #eccd8f40;transition:all .3s ease}.classification-config .section-header:hover h3:before,.classification-input .section-header:hover h3:before{transform:scale(1.05);box-shadow:0 4px 8px #eccd8f59}@media (max-width: 768px){.classification-config .section-header,.classification-input .section-header{padding:.875rem 1rem;border-left-width:3px}.classification-config .section-header h3,.classification-input .section-header h3{font-size:1rem;gap:.625rem}.classification-config .section-header h3:before,.classification-input .section-header h3:before{width:1.75rem;height:1.75rem;font-size:.8rem}}.config-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-primary);padding:var(--space-xl);box-shadow:var(--shadow-sm);transition:all .2s ease}.config-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-accent)}.config-grid{display:grid;grid-template-columns:1fr 1fr 2fr;gap:1.5rem;align-items:start}.config-item{display:flex;flex-direction:column;gap:var(--space-sm)}.config-item label{font-weight:500;color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:.25rem}.config-select{padding:var(--space-md) var(--space-lg);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.config-select:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #eccd8f1a}.config-select:hover{border-color:var(--brand-primary-light)}.config-select:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.categories-preview{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.category-badge{display:inline-flex!important;align-items:center;padding:.375rem .75rem;background:#eccd8f!important;background:linear-gradient(135deg,#eccd8f,#d4a63a)!important;color:#fff!important;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap;box-shadow:0 1px 2px #0000000d;border:1px solid #d4a63a!important;opacity:1!important;visibility:visible!important;min-width:40px;min-height:24px;text-align:center;position:relative;z-index:1}.no-categories-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;color:#92400e;font-size:.875rem}.warning-icon{font-size:1rem}.config-link{color:var(--blue);text-decoration:none;font-weight:500;margin-left:.5rem;transition:color .2s}.config-link:hover{color:#4b5563;text-decoration:underline}.config-warning{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;color:#92400e;font-size:.875rem}.classification-input{margin-bottom:2rem}.input-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-primary);padding:var(--space-xl);box-shadow:var(--shadow-sm);transition:all .2s ease}.input-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-accent)}.input-toggle{display:flex;gap:var(--space-xs);margin-bottom:var(--space-xl);padding:var(--space-xs);background:var(--bg-tertiary);border-radius:var(--radius-md);width:fit-content;border:1px solid var(--border-primary)}.toggle-btn{padding:var(--space-sm) var(--space-md);border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;transition:all .2s ease;cursor:pointer;white-space:nowrap}.toggle-btn.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--brand-primary-light)}.toggle-btn:hover:not(.active){color:var(--text-primary);background:var(--bg-primary);opacity:.8}.file-upload-section{flex:1}.file-drop-zone{border:2px dashed var(--border-secondary);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-xl);text-align:center;cursor:pointer;transition:all .3s ease;background:var(--bg-tertiary);min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.file-drop-zone:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 49%,var(--brand-primary-light) 49%,var(--brand-primary-light) 51%,transparent 51%);opacity:0;transition:opacity .3s ease}.file-drop-zone:hover,.file-drop-zone.drag-over{border-color:var(--brand-primary);background:var(--brand-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.file-drop-zone:hover:before,.file-drop-zone.drag-over:before{opacity:.1}.file-drop-zone.has-file{border-color:var(--color-success);background:var(--color-success-light);border-style:solid}.upload-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.7;color:var(--text-secondary)}.drop-message p{font-size:var(--font-size-lg);font-weight:500;color:var(--text-primary);margin-bottom:var(--space-sm)}.file-types{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-bottom:var(--space-lg)}.browse-text{font-size:var(--font-size-sm);color:var(--text-inverse);font-weight:500}.file-selected{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-primary);max-width:500px;min-width:400px;box-shadow:var(--shadow-sm);transition:all .2s ease}.file-selected:hover{box-shadow:var(--shadow-md);border-color:var(--brand-primary-light)}.file-icon{font-size:2rem;color:var(--text-secondary)}.file-info{flex:1;text-align:left;min-width:0}.file-name{font-weight:500;color:var(--text-primary);margin-bottom:var(--space-xs);word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;max-height:2.8em}.file-size{font-size:var(--font-size-sm);color:var(--text-tertiary)}.remove-file{background:#ffffffe6;color:var(--text-secondary);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-sm);width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);transition:all .2s ease;flex-shrink:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.remove-file:hover{background:var(--color-error);color:#fff;border-color:var(--color-error);transform:scale(1.1);box-shadow:0 2px 8px #ef44444d}.remove-file:active{transform:scale(.95)}.text-input-section{flex:1}.text-input-container{position:relative;margin-bottom:1rem}.text-input-container textarea{width:100%;min-height:120px;padding:1rem;border:1.5px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:.875rem;line-height:1.5;color:#374151;background:#fff;resize:vertical;transition:all .2s}.text-input-container textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61a}.clear-text{position:absolute;top:.75rem;right:.75rem;background:#ef4444;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;transition:all .2s}.clear-text:hover{background:#dc2626}.test-actions{display:flex;gap:1rem;align-items:center;justify-content:center;margin-top:1.5rem}.test-classify-btn{background:linear-gradient(135deg,var(--brand-primary),var(--brand-accent));color:var(--text-inverse);border:none;border-radius:var(--radius-lg);padding:var(--space-lg) var(--space-2xl);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-lg);min-width:200px;border:1px solid var(--brand-primary-dark)}.test-classify-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--brand-accent),var(--brand-primary-dark));transform:translateY(-2px);box-shadow:var(--shadow-xl)}.test-classify-btn:disabled{background:var(--brand-primary-light);color:var(--brand-primary-dark);cursor:not-allowed;transform:none;opacity:.6;box-shadow:none}.toggle-debug-btn{background:#6b7280;color:#fff;border:none;border-radius:8px;padding:.625rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s}.toggle-debug-btn:hover{background:#374151}.test-results{margin-top:2rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.test-results h3{font-size:1.2rem;font-weight:600;color:#1a1a1a;margin-bottom:1rem}.classification-result{display:flex;flex-direction:column;gap:1.5rem}.result-header{display:flex;align-items:center;gap:1rem}.result-category{display:inline-flex;align-items:center;padding:.75rem 1.5rem;background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border-radius:25px;font-size:1.125rem;font-weight:600;box-shadow:0 4px 12px #10b9814d}.test-config-summary h4,.instructions-used h4{font-size:1rem;font-weight:600;color:#374151;margin-bottom:.75rem}.config-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.config-summary-item{padding:.75rem;background:#f9fafb;border-radius:8px;font-size:.875rem}.config-summary-item strong{color:#1f2937;margin-right:.5rem}.instructions-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-top:.5rem}.instructions-preview pre{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;color:#374151;white-space:pre-wrap;word-wrap:break-word}.debug-result{margin-top:1.5rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.debug-result h3{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin-bottom:1rem}.extracted-text{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;max-height:300px;overflow-y:auto}.extracted-text pre{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;line-height:1.4;color:#374151;white-space:pre-wrap;word-wrap:break-word}.close-debug{margin-top:1rem;background:#6b7280;color:#fff;border:none;border-radius:8px;padding:.625rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s}.close-debug:hover{background:#374151}@media (max-width: 1024px){.config-grid{grid-template-columns:1fr;gap:1rem}.config-summary-grid{grid-template-columns:1fr}.test-actions{flex-direction:column}.file-drop-zone{padding:2rem 1rem;min-height:150px}.upload-icon{font-size:2.5rem}}.auth-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;width:100vw}.loading-spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid var(--brand-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.auth-loading p{color:#6b7280;font-size:1rem;margin:0}.sidebar-footer{margin-top:auto;padding:16px;border-top:1px solid #e5e7eb}.user-section{display:flex;align-items:center}.user-profile-btn{display:flex;align-items:center;width:100%;padding:12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s;gap:12px}.user-profile-btn:hover{background:#eccd8f1a}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-accent) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0}.user-info{display:flex;flex-direction:column;align-items:flex-start;overflow:hidden}.user-name{font-weight:600;color:#1f2937;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.user-role{font-size:.8rem;color:#6b7280;text-transform:capitalize}.evaluation-dashboard{width:100%;height:100vh;background:linear-gradient(135deg,#fefaf4,#f9f6f0);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1e293b;overflow:hidden;padding:0}.dashboard-header{background:linear-gradient(135deg,#eccd8f0a,#f2be6e14);border:1px solid rgba(236,205,143,.12);border-bottom:2px solid rgba(236,205,143,.2);color:#1e293b;padding:1.5rem 2rem;border-radius:16px;margin:8px 12px 12px;position:relative;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .3s cubic-bezier(.4,0,.2,1)}.dashboard-header:before{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:80px;height:2px;background:linear-gradient(90deg,var(--brand-primary) 0%,var(--brand-accent) 100%);border-radius:2px 2px 0 0}.dashboard-header:hover{background:linear-gradient(135deg,#eccd8f0f,#f2be6e1f);border-color:#eccd8f2e;border-bottom-color:#eccd8f4d;transform:translateY(-1px);box-shadow:0 8px 25px #eccd8f1f,0 3px 10px #eccd8f14}@media (max-width: 768px){.dashboard-header{padding:1.25rem 1.5rem;margin:8px 8px 12px;border-radius:12px}.header-content h2{font-size:1.5rem}.header-content p{font-size:.875rem}}.header-content h2{margin:0 0 6px;font-size:1.75rem;font-weight:600;letter-spacing:-.02em;position:relative}.header-description{margin:0;opacity:.9;font-size:.95rem;font-weight:400;position:relative}.dashboard-tabs{display:flex;justify-content:center;background:#fff;border-radius:10px;padding:3px;box-shadow:0 2px 12px #00000014;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);margin:0 12px 8px;gap:1px}.tab{padding:8px 20px;border:none;background:none;border-radius:8px;font-size:.875rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;position:relative;overflow:hidden}.tab:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#eccd8f,#d4a438);opacity:0;transition:opacity .3s ease;border-radius:16px;z-index:-1}.tab:hover{color:#475569;transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.tab.active{color:#fff;transform:translateY(-2px);box-shadow:0 8px 25px #e8ba4e66}.tab.active:before{opacity:1}.dashboard-content{flex:1;overflow-y:auto;padding:12px}.eval-run-section{max-width:700px;margin:0 auto}.eval-form-header{text-align:center;margin-bottom:16px}.eval-form-header h3{font-size:1.125rem;font-weight:600;margin:0 0 4px;color:#1e293b}.eval-description{color:#64748b;font-size:.875rem;margin:0}.eval-form{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:8px;padding:24px;box-shadow:0 2px 12px #0000000a;border:1px solid #f1f5f9;position:relative;overflow:hidden}.eval-form:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#eccd8f,#d4a438)}.form-group label{display:block;font-weight:600;font-size:.875rem;color:#374151;margin-bottom:8px}.eval-input,.eval-select{width:100%;padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;transition:all .2s ease;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.eval-input:focus,.eval-select:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 2px #e8ba4e1a;background:#fff}.eval-input:hover,.eval-select:hover{border-color:#cbd5e0;transform:translateY(-1px)}.form-help{font-size:.75rem;color:#64748b;margin:2px 0 0}.checkbox-group{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 12px;border-radius:4px;transition:all .15s ease;border:none;background:transparent;position:relative;font-size:.875rem;color:#64748b;font-weight:500}.checkbox-label:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#eccd8f,#d4a438);opacity:0;transition:opacity .15s ease;border-radius:4px;z-index:-1}.checkbox-label:hover{background:#e8ba4e14;color:#8b6914}.checkbox-label:has(input:checked){color:#fff;font-weight:600}.checkbox-label:has(input:checked):before{opacity:1}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#eccd8f;border-radius:3px;border:1.5px solid #d1d5db;background:#fff;cursor:pointer;transition:all .15s ease}.checkbox-label input[type=checkbox]:hover{border-color:#eccd8f}.checkbox-label input[type=checkbox]:checked{border-color:#eccd8f;background:#eccd8f}.checkbox-label input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 2px #e8ba4e33}.checkbox-text{font-weight:inherit;color:inherit;font-size:inherit;-webkit-user-select:none;user-select:none;margin:5px;padding:5px}.form-actions{text-align:center;margin-top:16px}.eval-run-btn{background:linear-gradient(135deg,#eccd8f,#d4a438);color:#fff;border:none;padding:12px 28px;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #e8ba4e26;position:relative;overflow:hidden;min-width:160px;display:flex;align-items:center;justify-content:center;gap:8px}.eval-run-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.eval-run-btn:hover:before{left:100%}.eval-run-btn:hover:not(:disabled){transform:translateY(-4px) scale(1.03);box-shadow:0 20px 50px #e8ba4e80;background:linear-gradient(135deg,#f2be6e,#c49232);filter:brightness(1.1)}.eval-run-btn:active:not(:disabled){transform:translateY(-2px) scale(.99);box-shadow:0 8px 25px #e8ba4e66}.eval-run-btn:disabled{background:#f3d9b7!important;color:#8b6914!important;opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 4px 16px #e9ba4f33}.eval-estimate{margin-top:16px;padding:16px;background:linear-gradient(135deg,#fefaf4,#f9f6f0);border-radius:6px;border-left:3px solid #eccd8f;border:1px solid #f3f1ed}.eval-estimate p{margin:4px 0;font-size:.85rem;color:#6b7280;display:flex;align-items:center;gap:6px}.eval-estimate p:first-child{font-weight:500;color:#8b6914}.eval-warning{margin-top:12px;padding:12px;background:linear-gradient(135deg,#fff7ed,#fed7aa);border-radius:6px;border:1px solid #eccd8f;border-left:3px solid #f2be6e}.eval-warning p{margin:0;font-size:.85rem;color:#9a3412;line-height:1.4}.eval-error{margin-top:1rem;padding:1rem;background:#fef2f2;border-radius:8px;border-left:4px solid #f2be6e;color:#eccd8f}.eval-results-section{max-width:1000px;margin:0 auto}.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.results-header h3{font-size:1.125rem;font-weight:600;margin:0;color:#1e293b}.status-badge{padding:4px 8px;border-radius:12px;color:#fff;font-weight:500;font-size:.75rem}.no-results{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000014;border:1px solid #e2e8f0}.no-results p{color:#64748b;font-size:1.1rem;margin:0}.eval-progress{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 12px #0000000f;border:1px solid #e2e8f0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.progress-header h4{margin:0;font-size:1rem;font-weight:600;color:#1e293b}.cancel-btn{background:#f2be6e;color:#fff;border:none;padding:6px 12px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.8rem}.cancel-btn:hover{background:#eccd8f;transform:translateY(-1px)}.progress-info p{color:#64748b;margin:0 0 1rem}.progress-spinner{display:flex;align-items:center;gap:1rem}.spinner{width:24px;height:24px;border:3px solid #e2e8f0;border-top:3px solid #6B7280;border-radius:50%;animation:spin 1s linear infinite}.eval-completed{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 12px #0000000f;border:1px solid #e2e8f0}.results-summary{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.results-summary h4{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#eccd8f}.results-summary p{margin:0;color:#64748b}.best-performer{margin-top:1.5rem}.best-performer h5{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#1e293b}.performer-card{background:linear-gradient(135deg,#fefaf4,#f9f6f0);border:2px solid #eccd8f;border-radius:12px;padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.performer-info{display:flex;flex-direction:column;gap:.25rem}.performer-label{font-size:.875rem;font-weight:500;color:#8b6914}.performer-value{font-size:1.1rem;font-weight:600;color:#1e293b}.performer-accuracy{font-size:1.5rem;font-weight:700;color:#f2be6e}.results-table-container{margin:2rem 0}.results-table-container h5{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#1e293b}.results-table{background:#fff;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0}.table-header{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr 1fr;background:#f8fafc;border-bottom:2px solid #e2e8f0}.table-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr 1fr;border-bottom:1px solid #f1f5f9}.table-cell{padding:1rem .75rem;font-size:.9rem;display:flex;align-items:center}.table-header .table-cell{font-weight:600;color:#374151}.accuracy-badge{padding:.25rem .75rem;border-radius:12px;color:#fff;font-weight:600;font-size:.8rem}.recommendations{margin-top:2rem;padding:1.5rem;background:#fefaf4;border-radius:12px;border-left:4px solid #eccd8f}.recommendations h5{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#1e293b}.recommendations-list{margin:0;padding-left:1.5rem}.recommendations-list li{margin:.5rem 0;color:#374151;line-height:1.5}.eval-history-section{max-width:1000px;margin:0 auto}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.history-header h3{font-size:1.5rem;font-weight:700;margin:0;color:#1e293b}.refresh-btn{background:#eccd8f;color:#8b6914;border:none;padding:.5rem 1rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.refresh-btn:hover{background:#f2be6e;transform:translateY(-1px)}.history-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 4px 16px #00000014;border:1px solid #e2e8f0}.stat-value{display:block;font-size:2rem;font-weight:700;color:#eccd8f}.stat-label{font-size:.875rem;font-weight:500;color:#64748b;margin-top:.5rem}.history-list{display:flex;flex-direction:column;gap:1rem}.no-history{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000014;border:1px solid #e2e8f0}.no-history p{color:#64748b;font-size:1.1rem;margin:0}.history-item{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 16px #00000014;border:1px solid #e2e8f0;transition:all .2s ease}.history-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.history-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.history-info{display:flex;flex-direction:column;gap:.25rem}.history-name{font-weight:600;color:#1e293b}.history-date{font-size:.875rem;color:#64748b}.history-status{font-weight:600;font-size:.875rem}.history-results{margin-top:.5rem;font-size:.9rem;color:#64748b}@media (max-width: 768px){.dashboard-content{padding:1rem}.dashboard-tabs{padding:0 1rem;gap:.5rem}.tab{padding:1rem;font-size:.9rem}.eval-form{padding:1.5rem}.table-header,.table-row{grid-template-columns:1fr;gap:.5rem}.table-cell{padding:.5rem;border-bottom:1px solid #f1f5f9}.table-header .table-cell:before,.table-row .table-cell:before{content:attr(data-label);font-weight:600;color:#64748b;display:block;font-size:.8rem}.performer-card{grid-template-columns:1fr}.history-header-row{flex-direction:column;align-items:flex-start;gap:.5rem}}.delete-btn{background:#f1f5f9;color:#64748b;border:1px solid #e2e8f0;border-radius:6px;padding:.375rem .5rem;font-size:.875rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.delete-btn:hover{background:#fee2e2;color:#eccd8f;border-color:#fecaca;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.delete-btn:active{transform:translateY(0)}.history-actions{display:flex;align-items:center;gap:1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 20px 40px #00000026}.modal-content h3{font-size:1.25rem;font-weight:600;color:#1e293b;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.modal-body{margin-bottom:1.5rem}.modal-body p{color:#64748b;line-height:1.5;margin-bottom:.5rem}.modal-body strong{color:#f2be6e}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.cancel-btn{background:#f1f5f9;color:#64748b;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#e2e8f0;color:#475569}.delete-btn-confirm{background:#f2be6e;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:all .2s}.delete-btn-confirm:hover:not(:disabled){background:#eccd8f;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.delete-btn-confirm:disabled{background:#94a3b8;cursor:not-allowed;transform:none}.table-cell:last-child{text-align:center;padding-left:.5rem;padding-right:.5rem}.progress-section{margin:1rem 1.5rem 2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 2px 10px #00000014;border:1px solid #e2e8f0}.progress-section h4{margin:0 0 1rem;color:#1e293b;font-size:1.1rem;font-weight:600}.progress-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:1rem}.progress-card:last-child{margin-bottom:0}.progress-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.progress-title strong{display:block;color:#1e293b;font-weight:600;margin-bottom:.25rem}.progress-model{color:#64748b;font-size:.85rem}.progress-status{color:#6b7280;font-weight:500;font-size:.9rem;white-space:nowrap}.progress-bar-container{position:relative;background:#e2e8f0;border-radius:8px;height:24px;margin-bottom:.75rem;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#eccd8f,#f2be6e);border-radius:8px;transition:width .5s ease-in-out;position:relative}.progress-bar:after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(255,255,255,.2) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.2) 50%,rgba(255,255,255,.2) 75%,transparent 75%);background-size:20px 20px;animation:progress-stripes 1s linear infinite}@keyframes progress-stripes{0%{background-position:0 0}to{background-position:20px 0}}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#1e293b;font-weight:600;font-size:.8rem;text-shadow:0 1px 2px rgba(255,255,255,.8)}.progress-details{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.progress-eta,.progress-accuracy{color:#64748b;font-size:.85rem;font-weight:500;padding:.25rem .5rem;background:#fff;border-radius:6px;border:1px solid #e2e8f0}.progress-error{margin-top:.5rem;padding:.75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#eccd8f;font-size:.9rem}.table-row-expandable{border-bottom:1px solid #f1f5f9}.table-row-expandable:last-child{border-bottom:none}.category-metrics-row{background:#f8fafc;border-top:1px solid #e2e8f0;padding:1rem;margin:0}.category-metrics-header{font-weight:600;color:#374151;margin-bottom:.75rem;font-size:.9rem}.category-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;align-items:start}.category-metric{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.category-name{font-weight:600;color:#1e293b;font-size:.85rem;line-height:1.2}.category-accuracy{display:flex;align-items:center;gap:.5rem}.category-accuracy-badge{padding:.2rem .5rem;border-radius:8px;color:#fff;font-weight:600;font-size:.75rem;min-width:45px;text-align:center}.category-count{color:#64748b;font-size:.75rem;font-weight:500}.category-metrics-section{background:#f8fafc;border-top:1px solid #e2e8f0;padding:1.5rem;margin:0}.category-detailed-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000000a}.category-detailed-card:last-child{margin-bottom:0}.category-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.category-name-large{font-weight:700;color:#1e293b;font-size:1.1rem}.category-main-metrics{display:flex;gap:1rem;align-items:center}.metric-badge{padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.85rem;color:#fff;min-width:80px;text-align:center}.metric-badge.support{background-color:#6b7280}.category-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:start}.metrics-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.metrics-group.full-width{grid-column:1 / -1}.metrics-group h4{margin:0 0 1rem;color:#374151;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.metrics-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #e5e7eb}.metrics-row:last-child{border-bottom:none}.metric-label{color:#6b7280;font-size:.85rem;font-weight:500}.metric-value{color:#1e293b;font-size:.85rem;font-weight:600}.metric-value.positive{color:#eccd8f}.metric-value.negative{color:#f2be6e}.metric-value.confused-category{background:#fef3c7;color:#d97706;padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.misclassifications-list{display:flex;flex-direction:column;gap:.5rem}.misclassification-item{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:.75rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.misclass-category{font-weight:600;color:#1e293b;flex:1}.misclass-count{color:#f2be6e;font-weight:600;font-size:.85rem}.misclass-percentage{color:#6b7280;font-size:.8rem;font-style:italic}.results-container{max-width:1200px;margin:0 auto;padding:0 1rem}.results-container h5{margin:0 0 1.5rem;font-size:1.25rem;font-weight:700;color:#1e293b;text-align:center}.evaluation-cards{display:flex;flex-direction:column;gap:2rem}.evaluation-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;border:1px solid #e2e8f0;overflow:hidden;transition:all .3s ease;position:relative}.evaluation-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#eccd8f,#d4a438)}.evaluation-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 1.5rem 1rem;background:linear-gradient(135deg,#fefcf8,#faf8f4);border-bottom:1px solid #f1f5f9}.header-left{flex:1}.test-name{font-size:1.25rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;line-height:1.3}.test-meta{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.instruction-tag,.model-tag,.date-tag{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.instruction-tag{background:linear-gradient(135deg,#e0f2fe,#b3e5fc);color:#0277bd;border:1px solid #81d4fa}.model-tag{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);color:#7c3aed;border:1px solid #c4b5fd}.date-tag{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#f2be6e;border:1px solid #86efac}.header-right{display:flex;gap:1rem;align-items:center}.accuracy-display{text-align:center}.accuracy-score{font-size:2rem;font-weight:800;line-height:1;margin-bottom:.25rem;background:linear-gradient(135deg,#eccd8f,#f2be6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.accuracy-score.excellent{background:linear-gradient(135deg,#eccd8f,#f2be6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.accuracy-score.good{background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.accuracy-score.fair{background:linear-gradient(135deg,#eccd8f,#f2be6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.accuracy-score.poor{background:linear-gradient(135deg,#f2be6e,#eccd8f);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.accuracy-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.delete-btn-modern{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem;color:#64748b;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.delete-btn-modern:hover{background:#fee2e2;border-color:#fecaca;color:#eccd8f;transform:scale(1.05)}.card-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:#e2e8f0;margin:0}.stat-item{background:#fff;padding:1.25rem 1rem;text-align:center;transition:all .2s ease}.stat-item:hover{background:#f8fafc;transform:translateY(-2px)}.stat-value{font-size:1.5rem;font-weight:700;color:#1e293b;line-height:1;margin-bottom:.25rem}.stat-value.success{color:#eccd8f}.stat-value.error{color:#f2be6e}.stat-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.category-overview{padding:1.5rem;background:#fafcff;border-top:1px solid #e2e8f0}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.overview-header h4{margin:0;font-size:1.1rem;font-weight:700;color:#1e293b}.performance-legend{display:flex;gap:.75rem;flex-wrap:wrap}.legend-item{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:8px;text-transform:uppercase;letter-spacing:.05em}.legend-item.excellent{background:#dcfce7;color:#166534}.legend-item.good{background:#fef3c7;color:#92400e}.legend-item.fair{background:#fed7aa;color:#9a3412}.legend-item.poor{background:#fecaca;color:#991b1b}.categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.category-performance-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;transition:all .2s ease}.category-performance-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.category-name{font-weight:700;color:#1e293b;font-size:.9rem}.category-accuracy{font-weight:800;font-size:1rem}.category-accuracy.excellent{color:#eccd8f}.category-accuracy.good{color:#f59e0b}.category-accuracy.fair{color:#eccd8f}.category-accuracy.poor{color:#f2be6e}.performance-bar{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:.75rem}.bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.bar-fill.excellent{background:linear-gradient(90deg,#eccd8f,#f2be6e)}.bar-fill.good{background:linear-gradient(90deg,#f59e0b,#d97706)}.bar-fill.fair{background:linear-gradient(90deg,#eccd8f,#f2be6e)}.bar-fill.poor{background:linear-gradient(90deg,#f2be6e,#eccd8f)}.category-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#64748b;font-weight:500}.confusion-indicator{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#eccd8f;background:#fff7ed;padding:.5rem;border-radius:6px;border:1px solid #fed7aa}.confusion-icon{font-size:.8rem}.detailed-metrics{border-top:1px solid #e2e8f0;background:#f8fafc}.detailed-metrics summary{padding:1rem 1.5rem;cursor:pointer;font-weight:600;color:#374151;background:#f1f5f9;border:none;-webkit-user-select:none;user-select:none;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.detailed-metrics summary:hover{background:#e2e8f0;color:#1e293b}.detailed-metrics summary::marker{display:none}.detailed-metrics summary:before{content:"▶";transition:transform .2s ease;font-size:.8rem}.detailed-metrics[open] summary:before{transform:rotate(90deg)}.detailed-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.detailed-category-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;box-shadow:0 2px 4px #0000000a}.detailed-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.detailed-header h5{margin:0;font-size:1.1rem;font-weight:700;color:#1e293b}.performance-indicators{display:flex;gap:1rem}.indicator{text-align:center}.indicator-label{display:block;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.indicator-value{display:block;font-size:1.1rem;font-weight:700;color:#1e293b}.indicator-value.excellent{color:#eccd8f}.indicator-value.good{color:#f59e0b}.indicator-value.fair{color:#eccd8f}.indicator-value.poor{color:#f2be6e}.detailed-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.metric-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.metric-group h6{margin:0 0 1rem;font-size:.85rem;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.05em}.confusion-matrix{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.matrix-item{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.75rem;text-align:center;transition:all .2s ease}.matrix-item:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.matrix-item.positive{border-color:#eccd8f;background:#ecfdf5}.matrix-item.negative{border-color:#f2be6e;background:#fef2f2}.matrix-item.neutral{border-color:#6b7280;background:#f9fafb}.matrix-value{display:block;font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.matrix-item.positive .matrix-value{color:#eccd8f}.matrix-item.negative .matrix-value{color:#f2be6e}.matrix-item.neutral .matrix-value{color:#6b7280}.matrix-label{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.misclassification-chart{display:flex;flex-direction:column;gap:.5rem}.misclass-item{display:flex;align-items:center;gap:.75rem}.misclass-bar{flex:1;height:20px;background:#f1f5f9;border-radius:4px;overflow:hidden;position:relative}.misclass-fill{height:100%;border-radius:4px;transition:width .3s ease}.misclass-info{display:flex;flex-direction:column;min-width:100px}.misclass-category{font-weight:600;font-size:.8rem;color:#1e293b}.misclass-count{font-size:.7rem;color:#64748b;font-weight:500}@media (max-width: 768px){.card-header{flex-direction:column;gap:1rem;align-items:stretch}.header-right{flex-direction:row;justify-content:space-between}.card-stats{grid-template-columns:repeat(2,1fr)}.test-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.overview-header{flex-direction:column;align-items:flex-start}.performance-legend{justify-content:flex-start}.categories-grid,.detailed-metrics-grid,.confusion-matrix{grid-template-columns:1fr}.performance-indicators{flex-direction:column;gap:.5rem}}.card-actions{display:flex;gap:8px;align-items:center}.misclassified-btn-modern{position:relative;background:linear-gradient(135deg,#f2be6e,#eccd8f);color:#fff;border:none;border-radius:8px;padding:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.misclassified-btn-modern:hover:not(:disabled){background:linear-gradient(135deg,#eccd8f,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.misclassified-btn-modern:disabled{background:#f3d9b7;cursor:not-allowed;opacity:.6}.error-count{position:absolute;top:-4px;right:-4px;background:#fbbf24;color:#1f2937;border-radius:10px;padding:2px 6px;font-size:10px;font-weight:600;min-width:16px;text-align:center}.modal-large{max-width:90vw;max-height:90vh;width:1200px;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.modal-close-btn{background:none;border:none;font-size:20px;cursor:pointer;color:#6b7280;padding:4px;border-radius:4px;transition:all .2s ease}.modal-close-btn:hover{background:#e5e7eb;color:#374151}.modal-body{flex:1;overflow-y:auto;padding:24px}.misclassified-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin-bottom:24px}.summary-header h4{margin:0 0 8px;color:#1e293b;font-size:1.25rem;font-weight:600}.summary-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}.summary-meta span{background:#e2e8f0;padding:4px 8px;border-radius:6px;font-size:.875rem;color:#475569}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.stat-box{background:#fff;border-radius:8px;padding:16px;text-align:center;border:1px solid #e5e7eb}.stat-box.error{border-color:#fecaca;background:#fef2f2}.stat-box.total{border-color:#dbeafe;background:#eff6ff}.stat-box.rate{border-color:#fed7aa;background:#fff7ed}.stat-box .stat-value{font-size:1.5rem;font-weight:700;margin-bottom:4px}.stat-box.error .stat-value,.stat-box.total .stat-value{color:#eccd8f}.stat-box.rate .stat-value{color:#f2be6e}.stat-box .stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.no-misclassifications{text-align:center;padding:40px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;color:#166534}.misclassified-content{display:flex;flex-direction:column;gap:32px}.misclassified-by-category h5{margin:0 0 20px;color:#1e293b;font-size:1.125rem;font-weight:600}.category-errors{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:16px}.category-header h6{margin:0 0 16px;color:#1e293b;font-size:1rem;font-weight:600}.prediction-group{margin-bottom:20px}.prediction-header{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;margin-bottom:12px}.confusion-indicator{font-size:.875rem;color:#eccd8f;font-weight:500}.files-list{display:flex;flex-direction:column;gap:8px}.file-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s ease}.file-item:hover{background:#f3f4f6;border-color:#d1d5db}.file-icon{font-size:1.25rem;flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{font-weight:500;color:#1e293b;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{display:flex;gap:12px;font-size:.75rem;color:#6b7280}.file-meta span{background:#e5e7eb;padding:2px 6px;border-radius:4px}.error-indicator{display:flex;align-items:center;gap:8px;color:#eccd8f;font-size:.875rem;font-weight:500}.error-arrow{font-size:1rem}.predicted-category{background:#fef2f2;padding:4px 8px;border-radius:6px;border:1px solid #fecaca}.all-misclassified-files h5{margin:0 0 16px;color:#1e293b;font-size:1.125rem;font-weight:600}.files-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.table-header{display:grid;grid-template-columns:2fr .8fr 1.2fr 1.2fr .8fr;gap:16px;padding:12px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:.875rem;color:#374151}.table-body{max-height:400px;overflow-y:auto}.table-row{display:grid;grid-template-columns:2fr .8fr 1.2fr 1.2fr .8fr;gap:16px;padding:12px 16px;border-bottom:1px solid #f3f4f6;align-items:center;transition:background-color .2s ease}.table-row:hover{background:#f9fafb}.table-row:last-child{border-bottom:none}.col-filename{display:flex;align-items:center;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.file-icon-small{font-size:1rem;flex-shrink:0}.col-type{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase}.col-correct{color:#f2be6e;font-weight:500}.col-predicted.error{color:#eccd8f;font-weight:500}.col-confidence{font-size:.875rem;color:#6b7280}@media (max-width: 768px){.modal-large{width:95vw;max-height:95vh}.summary-stats{grid-template-columns:1fr}.summary-meta{flex-direction:column;gap:8px}.file-item{flex-direction:column;align-items:flex-start;gap:8px}.file-meta{flex-wrap:wrap}.table-header,.table-row{grid-template-columns:1fr;gap:8px}.table-header{display:none}.table-row{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:8px;padding:16px}.table-row>div:before{content:attr(data-label) ": ";font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.col-filename:before{content:"File: "}.col-type:before{content:"Tipo: "}.col-correct:before{content:"Corretta: "}.col-predicted:before{content:"Predetta: "}.col-confidence:before{content:"Confidenza: "}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:#6b7280}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.empty-state h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:500;color:#374151}.empty-state p{margin:0;font-size:.875rem;color:#6b7280;max-width:400px;line-height:1.5}.fine-tuning-dashboard{padding:20px;min-height:100vh}.modern-card{border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease;border:1px solid #e1e5e9}.modern-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.job-title-with-icon{display:flex;align-items:center;gap:8px}.status-icon{font-size:16px;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.spinning{animation:spin 2s linear infinite}.modern-status{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.modern-status.training{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.modern-status.completed{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.modern-status.failed{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.modern-status.pending{background:#e2e3e5;color:#383d41;border:1px solid #d6d8db}.modern-status.uploading{background:#cce5ff;color:#004085;border:1px solid #b3d7ff}.progress-section{margin:16px 0;padding:16px;background:#f8f9fa;border-radius:10px;border-left:4px solid #e9ba4f;box-shadow:0 1px 3px #0000000d;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.progress-bar-container{margin-bottom:8px}.progress-label{font-size:14px;font-weight:500;color:#495057;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;gap:8px}.progress-percentage{font-size:13px;font-weight:600;color:#e9ba4f;min-width:45px;text-align:right}.progress-bar{width:100%;height:10px;background:#e9ecef;border-radius:6px;overflow:hidden;position:relative;box-shadow:inset 0 1px 3px #0000001a}.progress-fill{height:100%;background:linear-gradient(90deg,#e9ba4f,#d4a63a);border-radius:6px;transition:width .4s ease;position:relative;box-shadow:0 1px 2px #007bff4d}.progress-fill.training{background:linear-gradient(90deg,#ffc107,#e0a800);animation:pulse 2s ease-in-out infinite alternate}.progress-fill.uploading{background:linear-gradient(90deg,#6b7280,#4b5563);animation:pulse 2s ease-in-out infinite alternate}@keyframes pulse{0%{opacity:.8}to{opacity:1}}.time-estimate{font-size:12px;color:#f3d9b7;font-weight:500;text-align:center;margin-top:6px;padding:4px 8px;background:#6c757d1a;border-radius:12px;display:inline-block}.modern-btn{position:relative;overflow:hidden;transition:all .3s ease;border-radius:8px;font-weight:600;text-transform:none;padding:12px 24px;min-height:48px;display:flex;align-items:center;justify-content:center}.modern-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #e9ba4f4d}.modern-btn:disabled{background:#f3d9b7!important;color:#8b6914!important;opacity:.7;cursor:not-allowed;transform:none}.modern-btn.loading{background:linear-gradient(45deg,#e9ba4f,#d4a63a);background-size:200% 200%;animation:gradientShift 2s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.btn-content{display:flex;align-items:center;gap:8px;justify-content:center}.btn-icon{font-size:16px;transition:transform .3s ease}.modern-btn:hover .btn-icon{transform:scale(1.1)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}.job-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.job-header h5{margin:0;font-size:16px;font-weight:600;color:#2c3e50;flex:1}.jobs-list{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.job-card.modern-card{margin-bottom:20px;padding:24px;background:#fff;border-left:4px solid #e1e5e9}.job-details{margin:16px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.job-details p{margin:0;font-size:14px;color:#495057;padding:8px 12px;background:#f8f9fa;border-radius:6px;border-left:3px solid #dee2e6}.job-details p strong{color:#2c3e50;font-weight:600}.job-actions{margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.btn-delete{background:#f8f9fa!important;color:#f3d9b7!important;border:1px solid #dee2e6!important;font-size:13px;padding:6px 12px;transition:all .2s ease}.btn-delete:hover{background:#e74c3c!important;color:#fff!important;border-color:#c0392b!important;transform:translateY(-1px)}.error-section{grid-column:1 / -1}.error-summary{background:#fff5f5!important;border-left-color:#ef4444!important;color:#991b1b!important;margin:0;font-size:14px;padding:12px;border-radius:6px;border-left:3px solid #ef4444}.error-details{margin-top:8px}.error-details summary{cursor:pointer;font-size:13px;color:#f3d9b7;padding:4px 8px;background:#f8f9fa;border-radius:4px;border:1px solid #dee2e6;-webkit-user-select:none;user-select:none}.error-details summary:hover{background:#e9ecef}.error-message-full{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:12px;margin-top:8px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;color:#495057;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.model-id{font-size:13px;color:#059669;background:#ecfdf5;padding:6px 12px;border-radius:16px;font-weight:500;border:1px solid #a7f3d0}.job-card.modern-card.training{border-left-color:#ffc107;background:linear-gradient(135deg,#fff,#fffbf0)}.job-card.modern-card.completed{border-left-color:#28a745;background:linear-gradient(135deg,#fff,#f0fff4)}.job-card.modern-card.failed{border-left-color:#dc3545;background:linear-gradient(135deg,#fff,#fff5f5)}.job-card.modern-card.pending{border-left-color:#f3d9b7;background:linear-gradient(135deg,#fff,#f8f9fa)}.job-card.modern-card.uploading{border-left-color:#6b7280;background:linear-gradient(135deg,#fff,#f0fcff)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#eccd8f0a,#f2be6e12);border:1px solid rgba(236,205,143,.1);border-left:4px solid var(--brand-primary);border-radius:12px;position:relative;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1)}.dashboard-header:hover{background:linear-gradient(135deg,#eccd8f0f,#f2be6e1a);border-color:#eccd8f26;border-left-color:var(--brand-accent);transform:translate(2px);box-shadow:0 4px 16px #eccd8f1a,0 2px 6px #eccd8f0f}.dashboard-header h2{margin:0;color:#1e293b}.classification-type-indicator{background:#e9ba4f;color:#fff;padding:8px 16px;border-radius:20px;font-weight:700;font-size:14px}.error-banner{background:#e74c3c;color:#fff;padding:12px;border-radius:5px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:#fff;font-size:18px;font-weight:700;cursor:pointer}.dashboard-tabs{display:flex;margin-bottom:30px;border-bottom:1px solid #ddd}.tab-button{background:none;border:none;padding:12px 24px;cursor:pointer;font-size:16px;color:#666;transition:all .3s ease;border-bottom:3px solid transparent}.tab-button:hover{background:#f8f9fa;color:#2c3e50}.tab-button.active{color:#e9ba4f;border-bottom-color:#e9ba4f;font-weight:700}.fine-tuning-section h3{color:#2c3e50;margin-bottom:20px;font-size:24px}.datasets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:30px}.dataset-card{background:#fff;border:1px solid #ddd;border-radius:10px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.dataset-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.dataset-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.dataset-header h4{margin:0;color:#2c3e50;font-size:18px}.dataset-type{font-size:20px}.dataset-stats{margin-bottom:15px}.dataset-stats p{margin:5px 0;color:#666;font-size:14px}.dataset-categories{margin-bottom:15px}.category-tag{display:inline-block;background:#ecf0f1;color:#2c3e50;padding:4px 8px;margin:2px 4px 2px 0;border-radius:12px;font-size:12px}.dataset-actions{display:flex;gap:10px}.training-form{background:#f8f9fa;border:1px solid #ddd;border-radius:10px;padding:20px;margin-bottom:30px}.training-form h4{margin-top:0;color:#2c3e50}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:15px;align-items:end}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:700;margin-bottom:5px;color:#2c3e50}.form-group input,.form-group select{padding:8px 12px;border:1px solid #ddd;border-radius:5px;font-size:14px}.jobs-list h4{color:#2c3e50;margin-bottom:15px}.job-card{background:#fff;border:1px solid #ddd;border-radius:10px;padding:20px;margin-bottom:15px;box-shadow:0 2px 4px #0000000d}.job-card.training{border-left:4px solid #f39c12}.job-card.completed{border-left:4px solid #27ae60}.job-card.failed{border-left:4px solid #e74c3c}.job-card.cancelled{border-left:4px solid #95a5a6}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.job-header h5{margin:0;color:#2c3e50;font-size:18px}.job-status{background:#ecf0f1;color:#2c3e50;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.job-details p{margin:5px 0;color:#666;font-size:14px}.error-message{color:#e74c3c!important;font-weight:700}.job-actions{display:flex;gap:10px;align-items:center;margin-top:15px}.model-id{background:#e9ba4f;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700}.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:30px}.model-card{background:#fff;border:1px solid #ddd;border-radius:10px;padding:20px;box-shadow:0 2px 4px #0000001a;border-left:4px solid #27ae60}.model-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.model-header h4{margin:0;color:#2c3e50;font-size:16px}.model-details p{margin:5px 0;color:#666;font-size:14px}.model-id{background:#ecf0f1;padding:8px;border-radius:5px;margin:10px 0;font-family:monospace;font-size:12px;word-break:break-all;color:#666}.system-status{background:#f8f9fa;border:1px solid #ddd;border-radius:10px;padding:20px;margin-top:30px}.system-status h4{margin-top:0;color:#2c3e50}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.status-item{display:flex;justify-content:space-between;padding:10px;background:#fff;border-radius:5px;border:1px solid #eee}.status-item span:first-child{color:#666;font-weight:700}.status-item span:last-child{color:#2c3e50}.empty-state{text-align:center;padding:40px;color:#666}.empty-state p{margin:10px 0}.btn{padding:8px 16px;border:none;border-radius:5px;cursor:pointer;font-size:14px;font-weight:700;transition:all .3s ease;text-decoration:none;display:inline-block}.btn-primary{background:#e9ba4f;color:#fff}.btn-primary:hover:not(:disabled){background:#d4a63a}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover:not(:disabled){background:#7f8c8d}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}@media (max-width: 768px){.fine-tuning-dashboard{padding:10px}.dashboard-header{flex-direction:column;gap:15px;text-align:center;padding:1rem 1.25rem;border-left-width:3px}.datasets-grid,.models-grid,.form-row{grid-template-columns:1fr}.dashboard-tabs{flex-wrap:wrap}.tab-button{flex:1;min-width:120px}}.token-statistics{margin-top:16px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #6b7280}.token-statistics h6{margin:0 0 12px;color:#495057;font-size:.95rem;font-weight:600}.token-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.token-stat{display:flex;flex-direction:column;align-items:center;padding:8px;background:#fff;border-radius:6px;border:1px solid #e9ecef}.stat-label{font-size:.8rem;color:#f3d9b7;margin-bottom:4px}.stat-value{font-size:.9rem;font-weight:600;color:#495057}.model-compatibility h6{margin:16px 0 12px;color:#495057;font-size:.95rem;font-weight:600}.compatibility-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.compatibility-item{padding:12px;background:#fff;border-radius:6px;border:1px solid #e9ecef}.compatibility-item.compatible{border-left:4px solid #28a745}.compatibility-item.has-issues{border-left:4px solid #ffc107;background:#fff3cd}.model-name{font-weight:600;font-size:.9rem;color:#495057;margin-bottom:6px}.compatibility-stats{display:flex;flex-direction:column;gap:2px;font-size:.85rem;color:#f3d9b7}.percentage{font-weight:500;color:#495057}.warning-text{font-size:.8rem;color:#856404;margin-top:6px;font-style:italic}@media (max-width: 768px){.token-stats-grid,.compatibility-grid{grid-template-columns:1fr;gap:8px}.token-stat{flex-direction:row;justify-content:space-between;align-items:center}}.annotation-dashboard{max-width:1400px;margin:0 auto;padding:12px;background:linear-gradient(135deg,#fefaf4,#f9f6f0);min-height:calc(100vh - 60px);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.dashboard-header{text-align:center;margin-bottom:12px;padding:1.5rem 2rem;background:linear-gradient(135deg,#eccd8f0a,#f2be6e14);border:1px solid rgba(236,205,143,.12);border-top:3px solid var(--brand-primary);border-radius:16px;color:#1e293b;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1)}.dashboard-header:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--brand-primary) 0%,var(--brand-accent) 100%);border-radius:0 0 8px 8px}.dashboard-header:hover{background:linear-gradient(135deg,#eccd8f0f,#f2be6e1f);border-color:#eccd8f2e;border-top-color:var(--brand-accent);transform:translateY(-1px);box-shadow:0 8px 25px #eccd8f26,0 3px 10px #eccd8f14}@media (max-width: 768px){.dashboard-header{padding:1.25rem 1.5rem;border-top-width:2px}.dashboard-header:before{width:40px;height:2px}.dashboard-header h2{font-size:1.5rem}.dashboard-header p{font-size:.875rem}}.dashboard-header h2{color:#1e293b;margin-bottom:6px;font-size:1.75rem;font-weight:600;letter-spacing:-.02em;position:relative}.dashboard-header p{color:#1e293b;font-size:.95rem;font-weight:400;position:relative;margin:0;opacity:.8}.dashboard-tabs{display:flex;justify-content:center;margin-bottom:8px;background:#fff;border-radius:10px;padding:3px;box-shadow:0 2px 12px #00000014;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.dashboard-content{margin-top:8px;min-height:400px}.tab-btn{background:none;border:none;padding:8px 20px;margin:0 1px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;color:#64748b;position:relative;overflow:hidden}.tab-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#eccd8f,#f2be6e);opacity:0;transition:opacity .3s ease;border-radius:16px;z-index:-1}.tab-btn:hover{color:#475569;transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.tab-btn.active{color:#fff;transform:translateY(-2px);box-shadow:0 8px 25px #e8ba4e66}.tab-btn.active:before{opacity:1}.tab-content{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;padding:20px;box-shadow:0 4px 20px #0000000f;border:1px solid rgba(255,255,255,.2);min-height:auto;position:relative;overflow:hidden}.tab-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#eccd8f,#f2be6e)}.upload-section{text-align:center;max-width:500px;margin:0 auto}.upload-section h3{color:#2d3748;margin-bottom:4px;font-size:1.1rem;font-weight:600}.upload-section p{color:#718096;margin-bottom:16px;font-size:.875rem}.file-upload-area{margin-bottom:20px}.upload-btn{background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border:none;padding:10px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #e8ba4e33;position:relative;overflow:hidden;min-width:120px}.upload-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.upload-btn:hover:before{left:100%}.upload-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 40px #e8ba4e66;background:linear-gradient(135deg,#f2be6e,#eccd8f)}.upload-btn:active{transform:translateY(-1px) scale(.98)}.upload-btn:disabled{background:#cbd5e0;cursor:not-allowed;transform:none;box-shadow:none}.upload-btn:disabled:before{display:none}.upload-status{margin-top:15px;padding:12px;background:#fef9f3;border:1px solid #e9ba4f;border-radius:8px;color:#8b6914;font-weight:500}.upload-info{margin-top:30px;padding:20px;background:#f7fafc;border-radius:10px;text-align:left}.upload-info p{margin:8px 0;color:#4a5568}.annotate-section{display:flex;gap:20px;height:calc(100vh - 200px);min-height:600px}.documents-list{flex:1;min-width:400px;max-width:50%}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.list-header h3{color:#2d3748;margin:0;font-size:1.1rem;font-weight:600}.filter-controls{display:flex;gap:8px}.filter-controls button{background:#eccd8f;border:1px solid #e9ba4f;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.filter-controls button:hover{background:#f2be6e}.loading{text-align:center;color:#718096;padding:40px;font-style:italic}.documents-grid{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 300px);min-height:500px;overflow-y:auto;border:1px solid rgba(232,186,78,.2);border-radius:8px;padding:16px;background:#ffffff80}.documents-grid::-webkit-scrollbar{width:8px}.documents-grid::-webkit-scrollbar-track{background:#e8ba4e1a;border-radius:4px}.documents-grid::-webkit-scrollbar-thumb{background:#e8ba4e66;border-radius:4px}.documents-grid::-webkit-scrollbar-thumb:hover{background:#e8ba4e99}.document-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(232,186,78,.3);border-radius:10px;padding:16px;transition:all .2s ease;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014;min-height:120px}.document-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#eccd8f,#f2be6e);transform:scaleX(0);transition:transform .3s ease}.document-card:hover:before{transform:scaleX(1)}.document-card:hover{background:#fff;border-color:#e8ba4e80;box-shadow:0 8px 25px #e8ba4e26;transform:translateY(-2px)}.doc-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:8px;gap:8px;flex-wrap:nowrap}.doc-type{background:#f3d9b7;color:#fff;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600;flex-shrink:0}.doc-status{padding:5px 10px;border-radius:14px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 1px 3px #0000001a;flex-shrink:0;margin-left:auto;margin-right:4px}.doc-status.pending{background:linear-gradient(135deg,#f3d9b7,#eccd8f);color:#fff;border:1px solid #e9ba4f}.doc-status.annotated{background:linear-gradient(135deg,#fef3c7,#e9ba4f);color:#8b6914;border:1px solid #f2be6e}.doc-status.reviewed{background:linear-gradient(135deg,#bee3f8,#90cdf4);color:#2a69ac;border:1px solid #63b3ed}.doc-title{font-weight:600;color:#1a202c;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem;line-height:1.3}.doc-date{font-size:.875rem;color:#718096;margin-bottom:10px;font-weight:500}.doc-preview{font-size:.9rem;color:#4a5568;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.annotation-panel{flex:1;background:#f7fafc;border-radius:8px;padding:16px;max-height:500px;overflow-y:auto}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.panel-header h4{color:#2d3748;margin:0;font-size:1rem;font-weight:600}.panel-header button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#a0aec0;transition:color .2s ease}.panel-header button:hover{color:#718096}.document-info{margin-bottom:20px;padding:15px;background:#fff;border-radius:8px}.document-info h5{color:#2d3748;margin:0 0 5px}.document-info p{color:#718096;margin:0;font-size:.9rem}.document-text{margin-bottom:20px}.document-text h6{color:#2d3748;margin-bottom:10px}.text-content{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:15px;max-height:200px;overflow-y:auto;line-height:1.6;color:#4a5568;font-size:.9rem}.text-content.csv-content{max-height:400px;font-family:Consolas,Monaco,Courier New,monospace}.csv-data{margin:0;font-family:inherit;font-size:.85rem;line-height:1.4;white-space:pre;overflow-x:auto;color:#2d3748;background:none}.annotation-form{background:#fff;border-radius:8px;padding:20px}.form-group{margin-bottom:20px;position:relative}.modal-body .form-group:last-child{margin-bottom:0}.modal-content .form-group{display:block!important;visibility:visible!important;opacity:1!important}.modal-content .form-group label{display:block!important;visibility:visible!important}.modal-content .form-group input,.modal-content .form-group textarea{display:block!important;visibility:visible!important;width:100%!important}.form-group label{display:block;margin-bottom:6px;color:#1a202c;font-weight:600;font-size:.95rem;letter-spacing:-.01em}.form-group select,.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #0000001a}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 2px #e8ba4e1a;background:#fff}.form-group select:hover,.form-group input:hover,.form-group textarea:hover{border-color:#cbd5e0;transform:translateY(-1px)}.annotate-btn{background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;font-size:.875rem}.annotate-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px #4299e14d}.annotate-btn:disabled{background:#cbd5e0;cursor:not-allowed;transform:none;box-shadow:none}.current-annotation{margin-top:20px;padding:15px;background:#fef9f3;border:1px solid #e9ba4f;border-radius:8px}.current-annotation h6{color:#8b6914;margin:0 0 10px}.current-annotation p{margin:5px 0;color:#8b6914;font-size:.9rem}.datasets-section{width:100%}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.section-header h3{color:#2d3748;margin:0}.create-btn{background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #e8ba4e4d;position:relative;overflow:hidden;font-size:.95rem;text-shadow:0 1px 2px rgba(0,0,0,.1)}.create-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.create-btn:hover:before{left:100%}.create-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 8px 25px #e8ba4e66;background:linear-gradient(135deg,#f2be6e,#eccd8f)}.datasets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:12px}.dataset-card{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:16px;transition:all .2s ease;position:relative;overflow:hidden}.dataset-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#eccd8f,#f2be6e);transform:scaleX(0);transition:transform .3s ease}.dataset-card:hover:before{transform:scaleX(1)}.dataset-card:hover{box-shadow:0 12px 40px #e8ba4e1f;transform:translateY(-6px);border-color:#e8ba4e4d}.dataset-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.dataset-header h4{color:#2d3748;margin:0}.dataset-id{background:#e2e8f0;color:#4a5568;padding:2px 8px;border-radius:4px;font-size:.75rem;font-family:monospace}.dataset-description{color:#718096;margin-bottom:15px;line-height:1.4}.dataset-stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:15px}.stat{background:#fff;padding:4px 10px;border-radius:6px;font-size:.85rem;color:#4a5568;border:1px solid #e2e8f0}.categories-breakdown{display:flex;flex-wrap:wrap;gap:8px}.category-count{background:#f3d9b7;color:#fff;padding:3px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.evaluate-section{width:100%}.evaluation-form{background:linear-gradient(135deg,#fffffff2,#f8fafce6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;padding:20px;margin-bottom:20px;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 20px #0000000f;position:relative;overflow:hidden}.evaluation-form:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#eccd8f,#f2be6e)}.evaluation-form h3{color:#1e293b;margin-bottom:8px;font-size:1.25rem;font-weight:600;background:linear-gradient(135deg,#eccd8f,#f2be6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;letter-spacing:-.02em}.evaluation-form p{color:#64748b;margin-bottom:16px;font-size:.9rem;line-height:1.5;font-weight:400}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;position:relative}.form-row:after{content:"";position:absolute;bottom:-16px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(232,186,78,.2) 50%,transparent 100%)}.evaluate-btn{background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin:20px auto 0;box-shadow:0 2px 8px #e8ba4e33;position:relative;overflow:hidden;min-width:140px;display:block;text-align:center}.evaluate-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.evaluate-btn:hover:before{left:100%}.evaluate-btn:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 20px 50px #e8ba4e80;background:linear-gradient(135deg,#f2be6e,#eccd8f);filter:brightness(1.1)}.evaluate-btn:active{transform:translateY(-2px) scale(.99);box-shadow:0 8px 25px #e8ba4e66}.evaluate-btn:disabled{background:#cbd5e0;cursor:not-allowed;transform:none;box-shadow:none}.evaluate-btn:disabled:before{display:none}.evaluation-results{margin-top:24px;position:relative}.evaluation-results:before{content:"";position:absolute;top:-24px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(232,186,78,.3) 50%,transparent 100%)}.evaluation-results h3{color:#1e293b;margin-bottom:16px;font-size:1.25rem;font-weight:600;background:linear-gradient(135deg,#eccd8f,#f2be6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;text-align:center}.results-table{display:grid;gap:8px;padding:0 4px}.result-row{background:#fffffff2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000a}.result-row:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#eccd8f,#f2be6e);transform:scaleX(0);transition:transform .3s ease}.result-row:hover:before{transform:scaleX(1)}.result-row:hover{transform:translateY(-6px);box-shadow:0 20px 60px #e8ba4e26;border-color:#e8ba4e4d;background:#fff}.result-info h4{color:#1e293b;margin:0 0 8px;font-weight:700;font-size:1.1rem}.result-info p{color:#64748b;margin:4px 0;font-size:.9rem;line-height:1.4}.result-stats{text-align:right;display:flex;flex-direction:column;align-items:flex-end}.accuracy{font-size:2.25rem;font-weight:900;background:linear-gradient(135deg,#e9ba4f,#d4a63a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px;line-height:1;position:relative;letter-spacing:-.02em}.accuracy:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:30px;height:2px;background:linear-gradient(90deg,#e9ba4f,#d4a63a);border-radius:1px}.test-count{color:#64748b;font-size:.85rem;font-weight:500;background:#f1f5f9;padding:4px 12px;border-radius:20px}.empty-state{text-align:center;padding:60px 20px;background:#fff9;border:2px dashed rgba(232,186,78,.3);border-radius:12px;margin:20px 0}.empty-icon{font-size:3rem;margin-bottom:16px;opacity:.7}.empty-state h4{color:#2d3748;margin-bottom:8px;font-size:1.2rem}.empty-state p{color:#718096;margin-bottom:20px;font-size:.95rem}.annotation-dashboard .modal-overlay{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;background:#000000d9!important;display:flex!important;justify-content:center!important;align-items:flex-start!important;z-index:2000!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;animation:fadeIn .2s ease-out!important;padding:40px 20px 20px!important;box-sizing:border-box!important;overflow-y:auto!important}.dataset-creation-modal{position:fixed;inset:0;background:#000c;display:flex;justify-content:center;align-items:flex-start;z-index:1500;padding:60px 20px 20px;overflow-y:auto}body:has(.dataset-creation-modal) .app-container{overflow:visible!important}body:has(.dataset-creation-modal) .main-content{overflow:visible!important}body:has(.dataset-creation-modal) .content-body{overflow:visible!important}.app-container:has(.dataset-creation-modal){overflow:visible!important}.main-content:has(.dataset-creation-modal){overflow:visible!important}.content-body:has(.dataset-creation-modal){overflow:visible!important}.modal-open .app-container,.modal-open .main-content,.modal-open .content-body{overflow:visible!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dataset-creation-modal .modal-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:80vh;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dataset-creation-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.modal-content h3{color:#1a202c;margin:0;font-size:1.5rem;font-weight:600;background:linear-gradient(135deg,#eccd8f,#f2be6e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#718096;padding:4px 8px;border-radius:4px;transition:all .2s ease;line-height:1}.modal-close-btn:hover{background:#e8ba4e1a;color:#eccd8f;transform:scale(1.1)}.dataset-creation-modal .modal-body{padding:20px 24px;flex:1;overflow:auto}.dataset-creation-modal .modal-actions{display:flex;gap:12px;justify-content:center;padding:20px 24px;border-top:1px solid #e2e8f0;flex-shrink:0}.dataset-creation-modal .modal-actions button{padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;font-size:.9rem}.cancel-btn{background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.95rem}.cancel-btn:hover{background:#edf2f7;border-color:#cbd5e0;transform:translateY(-1px)}@media (max-width: 768px){.annotation-dashboard{padding:15px}.dashboard-tabs{flex-wrap:wrap;gap:8px}.tab-btn{flex:1;min-width:120px}.annotate-section{flex-direction:column;height:auto;min-height:auto}.documents-list{min-width:unset;max-width:unset}.documents-grid{min-height:300px;max-height:50vh}.form-row,.datasets-grid{grid-template-columns:1fr}.result-row{flex-direction:column;text-align:center;gap:15px}.result-stats{text-align:center}}.delete-doc-btn,.delete-dataset-btn{background:#ff00000d;border:1px solid rgba(255,0,0,.2);font-size:1.2rem;cursor:pointer;padding:6px 8px;border-radius:6px;transition:all .2s ease;opacity:.9;color:#d32f2f;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;min-width:34px;height:34px}.delete-doc-btn:hover,.delete-dataset-btn:hover{opacity:1;background:#ff000026;border-color:#f006;transform:scale(1.15);box-shadow:0 2px 6px #f003}.delete-doc-btn:active,.delete-dataset-btn:active{transform:scale(1.05)}.export-jsonl-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:4px 6px;border-radius:4px;transition:all .2s ease;opacity:.7;margin-right:8px}.export-jsonl-btn:hover{opacity:1;background:#3498db1a;transform:scale(1.1)}.doc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.doc-content{cursor:pointer;flex:1}.dataset-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.dataset-actions{display:flex;align-items:center;gap:8px}.delete-confirmation{max-width:500px}.delete-confirmation .modal-body{margin:16px 0}.delete-confirmation .modal-body p{margin-bottom:8px;line-height:1.5}.delete-confirmation .modal-body strong{color:#f2be6e}.delete-confirm-btn{background:linear-gradient(135deg,#f2be6e,#eccd8f);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-right:8px}.delete-confirm-btn:hover:not(:disabled){background:linear-gradient(135deg,#eccd8f,#8b0000);transform:translateY(-1px);box-shadow:0 4px 12px #d32f2f4d}.delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.cancel-btn{background:#f5f5f5;color:#333;border:1px solid #ddd;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background:#e0e0e0;border-color:#bbb}.modal-content *{box-sizing:border-box}.modal-content>*{display:block!important}@media (max-width: 768px){.annotation-dashboard .modal-overlay{align-items:flex-start!important;padding:10px!important}.annotation-dashboard .modal-content{width:100%!important;max-width:none!important;max-height:calc(100vh - 20px)!important;margin-top:10px!important;margin-bottom:10px!important}.annotation-dashboard .modal-header{padding:16px 20px 12px!important}.annotation-dashboard .modal-body{padding:16px 20px!important}.annotation-dashboard .modal-actions{padding:16px 20px 20px!important;flex-direction:column!important;gap:12px!important}.annotation-dashboard .modal-actions button{width:100%!important}}@media (max-height: 700px){.annotation-dashboard .modal-overlay{align-items:flex-start!important;padding:10px!important}.annotation-dashboard .modal-content{max-height:calc(100vh - 20px)!important;margin:0!important}.annotation-dashboard .modal-body{max-height:calc(100vh - 180px)!important;overflow-y:auto!important}}@media (max-height: 500px){.annotation-dashboard .modal-overlay{align-items:flex-start!important;padding:5px!important}.annotation-dashboard .modal-content{max-height:calc(100vh - 10px)!important;margin:0!important}.annotation-dashboard .modal-body{max-height:calc(100vh - 150px)!important;overflow-y:auto!important}.annotation-dashboard .modal-header{padding:12px 20px 8px!important}.annotation-dashboard .modal-actions{padding:12px 20px!important}}.token-info{margin:15px 0;padding:12px;background:#f8f9fa;border-radius:8px;border-left:4px solid #28a745}.token-info.has-warnings{background:#fff3cd;border-left-color:#ffc107}.token-stats{margin-bottom:8px}.token-count{font-weight:500;color:#495057;font-size:.9rem}.token-warnings{margin-top:12px}.warning-header{color:#856404;font-size:.95rem;margin-bottom:8px}.token-warnings p{color:#856404;font-size:.85rem;margin:8px 0;line-height:1.4}.token-warnings ul{margin:8px 0;padding-left:20px;color:#856404}.token-warnings li{font-size:.85rem;margin-bottom:4px;line-height:1.3}.warning-note{background:#ffc1071a;padding:8px;border-radius:4px;border-left:3px solid #ffc107;font-style:italic;margin-top:12px!important}.token-ok{margin-top:8px}.success-text{color:#28a745;font-size:.9rem;font-weight:500}.bulk-actions-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px 16px;margin-bottom:16px;box-shadow:0 2px 8px #0000000d}.bulk-selection-controls{display:flex;align-items:center;gap:12px;margin-bottom:12px}.checkbox-container{display:flex;align-items:center;cursor:pointer;position:relative}.checkbox-container input[type=checkbox]{margin:0 8px 0 0;transform:scale(1.1);cursor:pointer}.selection-label{font-size:.9rem;color:#495057;font-weight:500}.bulk-actions-buttons{display:flex;gap:8px;align-items:center}.bulk-delete-btn{background:#f2be6e;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.bulk-delete-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}.bulk-delete-btn:disabled{background:#f3d9b7;cursor:not-allowed;transform:none;box-shadow:none}.clear-selection-btn{background:#f3d9b7;color:#fff;border:none;padding:8px 12px;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.clear-selection-btn:hover{background:#5a6268;transform:translateY(-1px)}.document-card.selected{border-color:#e9ba4f;background:#fef9f3;box-shadow:0 4px 16px #e9ba4f26}.document-card .doc-header .checkbox-container{margin-right:0;flex-shrink:0}.documents-to-delete{margin-top:16px;padding:12px;background:#f8f9fa;border-radius:6px;border-left:3px solid #f2be6e}.documents-to-delete h4{margin:0 0 8px;font-size:.9rem;color:#495057}.documents-to-delete ul{margin:0;padding-left:20px;max-height:120px;overflow-y:auto}.documents-to-delete li{font-size:.85rem;color:#f3d9b7;margin-bottom:4px;line-height:1.3}body:has(.dataset-wizard-overlay){overflow:hidden!important;margin:0!important;padding:0!important}html:has(.dataset-wizard-overlay),html:has(.dataset-wizard-overlay) body{height:100%!important;overflow:hidden!important;margin:0!important;padding:0!important}body:has(.dataset-wizard-overlay) .app-container{overflow:visible!important;height:100vh!important}body:has(.dataset-wizard-overlay) .main-content{overflow:visible!important}body:has(.dataset-wizard-overlay) .content-body{overflow:visible!important}.dataset-wizard-overlay{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;min-height:100vh!important;background:#000000b3!important;z-index:2000!important;overflow-y:auto!important;overflow-x:hidden!important;padding:20px 0!important;margin:0!important;box-sizing:border-box!important;display:flex!important;align-items:flex-start!important;justify-content:center!important}.dataset-wizard-modal{background:#fff!important;border-radius:12px!important;box-shadow:0 20px 60px #0000004d!important;width:calc(100% - 40px)!important;max-width:1300px!important;height:auto!important;min-height:calc(100vh - 40px)!important;max-height:none!important;margin:20px auto!important;display:flex!important;flex-direction:column!important;position:relative!important;overflow:visible!important}.wizard-header{padding:24px 32px 20px;border-bottom:2px solid #f0f4f8;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#e8ba4e,#d4a438);color:#fff}.wizard-header h2{margin:0;font-size:1.5rem;font-weight:600}.close-btn{background:none;border:none;font-size:24px;color:#fffc;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.close-btn:hover{color:#fff;background:#ffffff1a}.wizard-steps{display:flex;padding:24px 32px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.step{flex:1;display:flex;align-items:center;position:relative}.step:not(:last-child):after{content:"";position:absolute;right:-50%;top:20px;width:100%;height:2px;background:#cbd5e0;z-index:1}.step.completed:not(:last-child):after{background:#48bb78}.step-number{width:40px;height:40px;border-radius:50%;background:#cbd5e0;color:#4a5568;display:flex;align-items:center;justify-content:center;font-weight:600;margin-right:12px;z-index:2;position:relative;transition:all .3s ease}.step.active .step-number{background:#e8ba4e;color:#fff}.step.completed .step-number{background:#10b981;color:#fff}.step-content{flex:1}.step-title{font-weight:600;color:#2d3748;margin-bottom:2px}.step-description{font-size:.875rem;color:#718096}.step.active .step-title{color:#e8ba4e}.wizard-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:32px;min-height:500px;max-height:none}.step-panel{max-width:100%}.step-panel h3{margin:0 0 24px;color:#2d3748;font-size:1.25rem;font-weight:600}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151}.form-group input,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#e8ba4e;box-shadow:0 0 0 3px #e8ba4e1a}.dataset-info{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;margin-top:20px}.dataset-info p{margin:0;color:#4a5568}.dataset-review{space-y:24px}.review-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-bottom:20px}.review-section h4{margin:0 0 16px;color:#2d3748;font-size:1.1rem;font-weight:600}.info-grid{display:grid;gap:12px}.info-item{display:flex;align-items:flex-start}.info-item .label{font-weight:500;color:#4a5568;min-width:100px;margin-right:12px}.info-item .value{color:#2d3748;flex:1}.wizard-error{background:#fed7d7;border:1px solid #fc8181;color:#c53030;padding:12px 16px;margin:0 32px;border-radius:8px;font-weight:500}.wizard-footer{padding:20px 32px;border-top:1px solid #e2e8f0;background:#f8fafc;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;margin-top:auto}.footer-left,.footer-right{display:flex;gap:12px}.btn{padding:12px 24px;border-radius:8px;font-weight:500;font-size:1rem;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary:hover:not(:disabled){background:#d4a438;transform:translateY(-1px);box-shadow:0 4px 12px #e8ba4e4d}.btn-secondary:hover:not(:disabled){background:#cbd5e0;transform:translateY(-1px)}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.dataset-wizard-overlay{padding:10px 0;align-items:flex-start}.dataset-wizard-modal{width:95%;margin:10px auto;min-height:auto}.wizard-header,.wizard-content,.wizard-footer{padding-left:20px;padding-right:20px}.wizard-content{min-height:300px}.wizard-steps{flex-direction:column;gap:16px;padding:20px}.step{flex-direction:row}.step:not(:last-child):after{display:none}.step-number{margin-right:12px;flex-shrink:0}.wizard-footer{flex-direction:column;gap:12px}.footer-left,.footer-right{width:100%;justify-content:center}}@media (max-width: 480px){.step{align-items:flex-start}.step-number{width:32px;height:32px;font-size:.875rem}.step-title{font-size:.875rem}.step-description{font-size:.75rem}}.document-selector{display:flex;flex-direction:column;height:600px;min-height:600px;max-height:600px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;overflow:hidden}.selection-summary{padding:16px 20px;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.summary-stats{display:flex;gap:20px;flex-wrap:wrap}.summary-stats .stat{color:#4a5568;font-size:.9rem}.summary-stats .stat strong{color:#2d3748}.error-message{padding:16px 20px;background:#fed7d7;border-bottom:1px solid #fc8181;color:#c53030;display:flex;align-items:center;justify-content:space-between}.retry-btn{background:#c53030;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.retry-btn:hover{background:#9b2c2c}.load-more-section{padding:20px;display:flex;justify-content:center;border-top:1px solid #e2e8f0}.load-more-btn{background:#eccd8f;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.load-more-btn:hover:not(:disabled){background:#434190;transform:translateY(-1px)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.document-selector{height:auto;min-height:500px}.selection-summary{padding:12px 16px}.summary-stats{flex-direction:column;gap:8px}.summary-stats .stat{font-size:.85rem}}.selection-filters{border-bottom:1px solid #e2e8f0;background:#fff}.primary-filters{display:flex;align-items:center;padding:16px 20px;gap:16px;flex-wrap:wrap}.search-container{flex:1;min-width:300px;display:flex;align-items:center;gap:12px}.search-input-wrapper{position:relative;flex:1;max-width:400px}.search-input{width:100%;padding:12px 16px 12px 44px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fff}.search-input:focus{outline:none;border-color:#e8ba4e;box-shadow:0 0 0 3px #4c51bf1a}.search-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#a0aec0;font-size:1.1rem}.clear-search-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:4px;font-size:1rem;transition:all .2s ease}.clear-search-btn:hover{color:#718096;background:#f7fafc}.search-loading{color:#e8ba4e;font-size:1.2rem;animation:spin 1s linear infinite}.filter-actions{display:flex;align-items:center;gap:12px}.expand-filters-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-weight:500;color:#4a5568;transition:all .2s ease;position:relative}.expand-filters-btn:hover{background:#edf2f7;border-color:#cbd5e0}.expand-filters-btn.active{background:#e8ba4e;color:#fff;border-color:#e8ba4e}.filter-icon{font-size:1rem}.active-indicator{color:#f56565;font-size:.6rem;position:absolute;top:6px;right:6px}.expand-filters-btn.active .active-indicator{color:#fed7d7}.chevron{font-size:.8rem;transition:transform .2s ease}.chevron.up,.chevron.down{transform:rotate(0)}.clear-filters-btn{padding:12px 16px;background:#fed7d7;border:2px solid #fc8181;color:#c53030;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.clear-filters-btn:hover{background:#fbb6ce;border-color:#f56565}.advanced-filters{padding:20px;background:#f8fafc;border-top:1px solid #e2e8f0;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:20px}.filter-group{display:flex;flex-direction:column}.filter-group label{font-weight:500;color:#374151;margin-bottom:6px;font-size:.9rem}.filter-group select,.filter-group input[type=date]{padding:10px 12px;border:2px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#fff;transition:all .2s ease}.filter-group select:focus,.filter-group input[type=date]:focus{outline:none;border-color:#e8ba4e;box-shadow:0 0 0 3px #4c51bf1a}.filter-group select:disabled,.filter-group input[type=date]:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.confidence-slider{width:100%;height:6px;border-radius:3px;background:#e2e8f0;outline:none;-webkit-appearance:none}.confidence-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#e8ba4e;cursor:pointer;box-shadow:0 2px 6px #4c51bf4d}.confidence-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#e8ba4e;cursor:pointer;border:none;box-shadow:0 2px 6px #4c51bf4d}.confidence-labels{display:flex;justify-content:space-between;margin-top:6px;font-size:.8rem;color:#718096}.quick-filters{margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}.quick-filters-label{font-weight:500;color:#374151;margin-right:12px;font-size:.9rem}.quick-filter-buttons{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.quick-filter-btn{padding:8px 14px;background:#fff;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:.85rem;color:#4a5568;transition:all .2s ease}.quick-filter-btn:hover:not(:disabled){background:#e8ba4e;color:#fff;border-color:#e8ba4e}.quick-filter-btn:disabled{opacity:.6;cursor:not-allowed}.active-filters{padding:12px 20px;background:#edf2f7;border-top:1px solid #e2e8f0}.active-filters-label{font-weight:500;color:#2d3748;font-size:.9rem;margin-right:12px}.filter-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.filter-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#e8ba4e;color:#fff;border-radius:16px;font-size:.8rem;font-weight:500}.filter-tag button{background:none;border:none;color:#fff;cursor:pointer;padding:0;font-size:.9rem;opacity:.8;transition:opacity .2s ease}.filter-tag button:hover{opacity:1}@media (max-width: 768px){.primary-filters{flex-direction:column;align-items:stretch;gap:12px}.search-container{min-width:unset}.filter-actions{justify-content:space-between}.filters-grid{grid-template-columns:1fr;gap:16px}.quick-filter-buttons{flex-direction:column}.filter-tags{flex-direction:column;align-items:flex-start}}.bulk-actions{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 20px}.bulk-actions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.selection-controls{display:flex;align-items:center;gap:16px}.master-checkbox{display:flex;align-items:center;gap:8px}.checkbox-container:hover .checkmark{border-color:#e8ba4e}.checkbox-container input:checked+.checkmark{background:#e8ba4e;border-color:#e8ba4e}.checkbox-container input:indeterminate+.checkmark{background:#e8ba4e;border-color:#e8ba4e}.checkbox-container input:checked+.checkmark:after,.checkbox-container input:indeterminate+.checkmark:after{content:"";position:absolute;display:block}.checkbox-container input:checked+.checkmark:after{left:6px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-container input:indeterminate+.checkmark:after{left:4px;top:8px;width:10px;height:2px;background:#fff}.selection-label{font-weight:500;color:#2d3748;font-size:.9rem}.refresh-selection-btn{padding:8px 16px;background:#e6fffa;border:2px solid #38b2ac;color:#285e61;border-radius:6px;cursor:pointer;font-weight:500;font-size:.85rem;transition:all .2s ease}.refresh-selection-btn:hover:not(:disabled){background:#b2f5ea;border-color:#319795}.refresh-selection-btn:disabled{opacity:.6;cursor:not-allowed}.clear-selection-btn{padding:8px 16px;background:#fed7d7;border:2px solid #fc8181;color:#c53030;border-radius:6px;cursor:pointer;font-weight:500;font-size:.85rem;transition:all .2s ease}.clear-selection-btn:hover:not(:disabled){background:#fbb6ce;border-color:#f56565}.global-selection-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.select-all-matching-btn{padding:10px 16px;background:#e8ba4e;border:2px solid #E8BA4E;color:#fff;border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s ease;display:flex;align-items:center;gap:6px}.select-all-matching-btn:hover:not(:disabled){background:#434190;border-color:#434190;transform:translateY(-1px);box-shadow:0 4px 12px #e8ba4e4d}.select-all-matching-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.keyboard-shortcuts{color:#718096;font-size:.8rem}.keyboard-shortcuts kbd{background:#edf2f7;border:1px solid #cbd5e0;border-radius:4px;padding:2px 6px;font-size:.75rem;margin:0 2px}.bulk-actions-toolbar{display:flex;flex-direction:column;gap:16px}.action-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.group-label{font-weight:500;color:#4a5568;font-size:.9rem;min-width:120px}.category-buttons,.confidence-buttons,.quick-actions{display:flex;gap:8px;flex-wrap:wrap}.category-select-btn,.confidence-select-btn,.quick-action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:2px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:.85rem;color:#4a5568;transition:all .2s ease;font-weight:500}.category-select-btn:hover:not(:disabled),.confidence-select-btn:hover:not(:disabled),.quick-action-btn:hover:not(:disabled){background:#e8ba4e;color:#fff;border-color:#e8ba4e;transform:translateY(-1px)}.category-select-btn.selected{background:#48bb78;color:#fff;border-color:#48bb78}.category-select-btn.disabled,.category-select-btn:disabled{background:#f7fafc!important;color:#2d3748!important;border-color:#cbd5e0!important;cursor:not-allowed!important;opacity:1!important}.category-select-btn.disabled:hover,.category-select-btn:disabled:hover{background:#edf2f7!important;color:#2d3748!important;border-color:#cbd5e0!important;transform:none!important}.category-select-btn.disabled .category-count,.category-select-btn:disabled .category-count{background:#2d37481a!important;color:#4a5568!important}.category-count{background:#fff3;padding:2px 6px;border-radius:10px;font-size:.75rem;font-weight:600}.category-select-btn.selected .category-count{background:#ffffff4d}.check-icon{font-size:.8rem}.selection-summary-bar{margin-top:16px;padding:16px;background:#edf2f7;border-radius:8px;border:1px solid #cbd5e0}.summary-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.summary-text{color:#2d3748;font-size:.95rem}.category-breakdown{display:flex;gap:8px;flex-wrap:wrap}.category-chip{background:#e8ba4e;color:#fff;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.quality-info .quality-stat{color:#4a5568;font-size:.9rem}@media (max-width: 768px){.bulk-actions{padding:12px 16px}.bulk-actions-header{flex-direction:column;align-items:stretch}.selection-controls{justify-content:space-between}.keyboard-shortcuts{text-align:center}.bulk-actions-toolbar{gap:12px}.action-group{flex-direction:column;align-items:stretch;gap:8px}.group-label{min-width:unset;text-align:center}.category-buttons,.confidence-buttons,.quick-actions{justify-content:center}.summary-content{flex-direction:column;align-items:stretch;text-align:center}}.document-grid-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.grid-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#718096}.loading-spinner-large{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #E8BA4E;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.grid-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#718096;text-align:center}.empty-icon{font-size:4rem;margin-bottom:16px;opacity:.6}.grid-empty h3{color:#2d3748;margin-bottom:8px}.document-grid{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;align-content:start;min-height:500px;max-height:80vh}.document-grid.loading{opacity:.7;pointer-events:none}.document-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease;position:relative;outline:none;min-height:280px;max-height:300px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 8px #0000000d}.document-card:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.document-card:focus{border-color:#e8ba4e;box-shadow:0 0 0 3px #4c51bf1a}.document-card.focused{border-color:#e8ba4e;box-shadow:0 0 0 3px #4c51bf1a}.document-card.selected{border-color:#48bb78;background:#f0fff4;box-shadow:0 4px 12px #48bb7833}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.checkbox-container{position:relative;cursor:pointer}.checkbox-container input{opacity:0;width:20px;height:20px;cursor:pointer}.checkmark{position:absolute;top:0;left:0;width:20px;height:20px;background:#fff;border:2px solid #cbd5e0;border-radius:4px;transition:all .2s ease}.document-card.selected .checkmark{background:#48bb78;border-color:#48bb78}.document-card.selected .checkmark:after{content:"";position:absolute;display:block;left:6px;top:2px;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.file-type-icon{font-size:1.5rem}.preview-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:4px;border-radius:4px;opacity:.6;transition:all .2s ease}.preview-btn:hover{opacity:1;background:#f7fafc}.card-content{flex:1}.filename{font-size:1rem;font-weight:600;color:#2d3748;margin:0 0 12px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.6rem}.document-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.category-tag{background:#edf2f7;color:#4a5568;padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:500;flex-shrink:0}.confidence-badge{padding:4px 8px;border-radius:6px;font-size:.8rem;font-weight:600;color:#fff;flex-shrink:0}.confidence-excellent{background:#48bb78}.confidence-high{background:#6b7280}.confidence-medium{background:#ed8936}.confidence-low{background:#f56565}.document-details{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;font-size:.85rem}.detail-item{display:flex;flex-direction:column;gap:2px}.detail-label{color:#718096;font-weight:500}.detail-value{color:#2d3748}.content-preview{margin-top:12px}.content-preview p{font-size:.9rem;color:#4a5568;line-height:1.5;margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;min-height:5.4rem}.selection-indicator{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:#48bb78;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #48bb784d}.check-icon{color:#fff;font-size:.9rem;font-weight:700}.pagination-controls{padding:20px;border-top:1px solid #e2e8f0;background:#f8fafc;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.pagination-info{color:#4a5568;font-size:.9rem}.pagination-buttons{display:flex;align-items:center;gap:8px}.pagination-btn{background:#fff;border:2px solid #e2e8f0;color:#4a5568;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#e8ba4e;color:#fff;border-color:#e8ba4e}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{color:#2d3748;font-weight:500;padding:0 12px}.page-size-selector{display:flex;align-items:center;gap:8px;color:#4a5568;font-size:.9rem}.page-size-selector select{padding:6px 10px;border:2px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer}.preview-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1600;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.preview-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.preview-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.preview-title{display:flex;align-items:center;gap:12px;flex:1}.file-icon{font-size:1.5rem}.preview-title h3{margin:0;color:#2d3748;font-size:1.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-close{background:none;border:none;font-size:1.5rem;color:#718096;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.preview-close:hover{color:#2d3748;background:#f7fafc}.preview-content{flex:1;overflow-y:auto;padding:24px}.preview-metadata{margin-bottom:24px}.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-item strong{color:#4a5568;font-size:.85rem;font-weight:600}.preview-text h4{color:#2d3748;margin:0 0 12px;font-size:1rem}.content-text{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;font-size:.9rem;line-height:1.6;color:#2d3748;white-space:pre-wrap;max-height:300px;overflow-y:auto}.preview-actions{padding:20px 24px;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end}.btn{padding:12px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:#e8ba4e;color:#fff}.btn-primary:hover{background:#434190}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover{background:#cbd5e0}@media (max-width: 768px){.document-grid{grid-template-columns:1fr;padding:16px;gap:16px}.pagination-controls{flex-direction:column;text-align:center}.pagination-buttons{order:2}.page-size-selector{order:3;justify-content:center}.preview-modal{width:95%;max-height:90vh}.preview-header,.preview-content,.preview-actions{padding:16px 20px}.meta-grid{grid-template-columns:1fr}}.selection-summary{max-height:400px;overflow-y:auto}.selection-summary.empty{display:flex;align-items:center;justify-content:center;padding:40px 20px}.empty-selection{text-align:center;color:#718096}.empty-icon{font-size:3rem;margin-bottom:12px;opacity:.6}.empty-selection p{margin:0;font-size:1rem}.summary-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.summary-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.section-title{margin:0 0 16px;color:#2d3748;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}.stat-card{text-align:center;padding:16px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s ease}.stat-card:hover{background:#edf2f7;border-color:#cbd5e0}.stat-number{font-size:1.5rem;font-weight:700;color:#e8ba4e;margin-bottom:4px}.stat-label{font-size:.8rem;color:#718096;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.category-breakdown{space-y:12px}.category-item{margin-bottom:12px}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:16px}.category-name{font-weight:500;color:#2d3748;font-size:.9rem;flex:1;min-width:0}.category-stats{font-size:.85rem;color:#4a5568;white-space:nowrap;margin-left:auto}.category-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.category-fill{height:100%;background:linear-gradient(90deg,#e8ba4e 0% 100%);border-radius:3px;transition:width .3s ease}.quality-breakdown{display:grid;gap:8px}.quality-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:6px;font-size:.85rem}.quality-item.excellent{background:#48bb781a;border:1px solid rgba(72,187,120,.2);color:#2f855a}.quality-item.high{background:#4299e11a;border:1px solid rgba(66,153,225,.2);color:#2b77cb}.quality-item.medium{background:#ed89361a;border:1px solid rgba(237,137,54,.2);color:#c05621}.quality-item.low{background:#f565651a;border:1px solid rgba(245,101,101,.2);color:#c53030}.quality-label{font-weight:500}.quality-count{font-weight:600;padding:2px 8px;border-radius:12px;background:#ffffffb3}.type-breakdown{display:flex;flex-wrap:wrap;gap:8px}.type-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem}.type-icon{font-size:1rem}.type-name{font-weight:500;color:#2d3748}.type-count{background:#e8ba4e;color:#fff;padding:2px 6px;border-radius:8px;font-size:.75rem;font-weight:600}.annotator-breakdown{display:grid;gap:8px}.annotator-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem}.annotator-name{font-weight:500;color:#2d3748}.annotator-stats{color:#4a5568}.recent-list{space-y:8px}.recent-item{padding:10px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:8px}.recent-filename{font-weight:500;color:#2d3748;font-size:.85rem;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-meta{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#718096}.recent-category{background:#edf2f7;color:#4a5568;padding:2px 6px;border-radius:4px;font-weight:500}.more-indicator{text-align:center;color:#718096;font-size:.8rem;font-style:italic;padding:8px}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:12px 8px}.stat-number{font-size:1.25rem}.stat-label{font-size:.75rem}.category-header,.annotator-item{flex-direction:column;align-items:flex-start;gap:4px}.type-breakdown{flex-direction:column}.type-item{justify-content:space-between}.recent-meta{flex-direction:column;align-items:flex-start;gap:4px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.section-title{font-size:.9rem}.summary-section{margin-bottom:20px;padding-bottom:16px}}.classification-landing{min-height:100vh;background:#f9fafb;padding:2rem;overflow-x:hidden;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1f2937}.classification-landing .app-logo{position:fixed;top:.75rem;left:.75rem;height:32px;width:auto;object-fit:contain;z-index:100;opacity:.9}.landing-container{max-width:1400px;margin:0 auto;position:relative;z-index:1}.landing-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-left:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.header-navigation{display:flex;justify-content:flex-start;margin-bottom:2rem}.back-to-main-btn{background:linear-gradient(135deg,#e9ba4f 0% 100%);color:#fff;border:1px solid #e9ba4f;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #e9ba4f4d}.back-to-main-btn:hover{background:linear-gradient(135deg,#d4a63a 0% 100%);transform:translateY(-2px);box-shadow:0 6px 20px #e9ba4f66;border-color:#d4a63a}.landing-header{text-align:center;margin-bottom:4rem;color:#1a1a1a}.landing-title{font-size:2.5rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:1rem;color:#1a1a1a}.title-icon{font-size:2.5rem}.landing-subtitle{font-size:1.1rem;color:#666;max-width:600px;margin:0 auto;line-height:1.6}.classification-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:2rem;margin-bottom:4rem}.classification-card{background:#fff;border-radius:16px;padding:2rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;border:1px solid #e2e8f0;min-height:400px;box-shadow:0 1px 3px #0000000d}.classification-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-gradient);transform:scaleX(0);transition:transform .3s ease;border-radius:16px 16px 0 0}.classification-card:hover:before{transform:scaleX(1)}.classification-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #e8ba4e26;border-color:#e9ba4f}.card-background{position:absolute;top:1rem;right:1rem;opacity:.1;transition:opacity .3s ease;color:#e9ba4f}.classification-card:hover .card-background{opacity:.2;color:#d4a63a}.card-icon{font-size:4rem;line-height:1;filter:hue-rotate(0deg) saturate(1.2) brightness(1.1)}.card-content{position:relative;z-index:2}.card-title{font-size:1.75rem;font-weight:600;color:#1f2937;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.card-description{color:#6b7280;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.card-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.feature-item{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:#4b5563;margin-bottom:.75rem}.feature-icon{font-size:1.1rem;background:linear-gradient(135deg,#e9ba4f 0% 100%);color:#fff;padding:.5rem;border-radius:8px;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 4px #e8ba4e33}.card-categories{margin-bottom:2rem}.card-categories h4{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:.75rem}.categories-grid{display:flex;flex-wrap:wrap;gap:.5rem}.category-tag{background:#fef9f3;color:#92400e;padding:.25rem .75rem;border-radius:8px;font-size:.75rem;font-weight:500;border:1px solid #fed7aa;transition:all .2s ease}.classification-card:hover .category-tag{background:#fef3c7;color:#78350f;border-color:#fbbf24}.card-action{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-top:1px solid #f3f4f6;margin-top:auto}.action-text{font-weight:500;color:#6b7280;transition:color .2s ease}.action-arrow{font-size:1.25rem;color:#e9ba4f;transition:all .2s ease}.classification-card:hover .action-text{color:#374151}.classification-card:hover .action-arrow{color:#e9ba4f;transform:translate(4px)}.landing-features{background:#fff;border-radius:16px;padding:3rem;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.feature-highlight{text-align:center;color:#1a1a1a}.highlight-icon{font-size:2.5rem;margin-bottom:1rem;display:block}.feature-highlight h3{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.feature-highlight p{color:#666;line-height:1.5;font-size:.95rem}@media (max-width: 768px){.classification-landing{padding:1rem}.landing-title{font-size:2rem;flex-direction:column;gap:.5rem}.title-icon{font-size:2.5rem}.classification-grid{grid-template-columns:1fr;gap:1.5rem}.classification-card{padding:1.5rem;min-height:auto}.features-grid{grid-template-columns:1fr;gap:1.5rem}.landing-features{padding:2rem}}@media (max-width: 480px){.landing-title{font-size:1.5rem}.classification-card{padding:1rem}.card-title{font-size:1.5rem}.landing-features{padding:1.5rem}}.classification-card{animation:fadeInUp .4s ease-out}.classification-card:nth-child(1){animation-delay:.1s}.classification-card:nth-child(2){animation-delay:.15s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.main-landing{min-height:100vh;background:#fafafa;display:flex;flex-direction:column;align-items:center;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.main-landing .app-logo{width:180px!important;height:auto!important;margin:3rem 0;cursor:pointer;transition:opacity .2s ease;opacity:.9;max-width:none;margin-right:0!important}.main-landing .app-logo:hover{opacity:1}.landing-container{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.sections-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:2rem;margin-bottom:4rem;align-items:start}.section-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:none;min-height:500px;display:flex;flex-direction:column}.section-card:hover:not(.coming-soon){transform:translateY(-2px);box-shadow:0 10px 25px #00000026}.section-card.coming-soon{opacity:.7;cursor:not-allowed}.section-card.coming-soon:hover{transform:none}.card-background{height:120px;background:linear-gradient(180deg,#fafbfc,#fff);position:relative;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #f1f3f4}.card-icon{font-size:3rem;opacity:.8}.coming-soon-badge{position:absolute;top:1rem;right:1rem;background:#f9fafb;color:#6b7280;padding:.5rem .75rem;border-radius:8px;font-size:.8rem;font-weight:500;border:1px solid #e5e7eb}.card-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.card-title{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin-bottom:.75rem;line-height:1.3}.card-description{font-size:1rem;color:#6b7280;line-height:1.5;margin-bottom:1.25rem}.card-features{margin-bottom:1.5rem;flex:1}.card-features h4{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.features-list{list-style:none;padding:0;margin:0}.feature-item{display:flex;align-items:flex-start;margin-bottom:.5rem;padding-left:0}.feature-bullet{color:#eccd8f;font-weight:700;margin-right:.75rem;font-size:.75rem;line-height:1.5;flex-shrink:0;margin-top:.125rem}.feature-text{color:#4b5563;line-height:1.4;font-size:.9rem}.card-action{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid #f1f3f4;margin-top:auto}.action-text{font-weight:500;color:#374151;font-size:.9rem}.coming-soon-text{color:#f3d9b7}.action-arrow{font-size:1rem;color:#eccd8f;transition:transform .2s ease}.section-card:hover:not(.coming-soon) .action-arrow{transform:translate(2px)}@media (max-width: 768px){.landing-container{padding:0 1rem}.landing-title{font-size:2.5rem;flex-direction:column;gap:.5rem}.title-icon{font-size:2.5rem}.landing-subtitle{font-size:1.2rem}.sections-grid{grid-template-columns:1fr;gap:2rem}.section-card{min-height:auto}.card-background{height:150px}.card-icon{font-size:3rem}.card-content{padding:1.5rem}.card-title{font-size:1.5rem}.features-grid{grid-template-columns:1fr;gap:1.5rem}.feature-highlight{padding:1.5rem}.highlight-icon{font-size:2.5rem}}@media (max-width: 480px){.app-logo{width:100px;margin:1rem 0}.landing-title,.title-icon{font-size:2rem}.landing-subtitle{font-size:1.1rem}.card-content{padding:1rem}.card-title{font-size:1.3rem}.card-description{font-size:1rem}}.extract-content{padding:24px;max-width:1200px;margin:0 auto}.section-header{text-align:center;margin-bottom:32px;padding:1.5rem 2rem;background:linear-gradient(135deg,#eccd8f0f,#f2be6e17);border:1px solid rgba(236,205,143,.15);border-top:3px solid var(--brand-primary);border-radius:12px;color:var(--text-primary);position:relative;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1)}.section-header:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--brand-primary) 0%,var(--brand-accent) 100%);border-radius:0 0 8px 8px}.section-header:hover{background:linear-gradient(135deg,#eccd8f14,#f2be6e1f);border-color:#eccd8f40;transform:translateY(-2px);box-shadow:0 4px 20px #eccd8f1f,0 2px 8px #eccd8f14}.section-header h2{margin:0 0 8px;font-size:2rem;font-weight:700}.section-header p{margin:0;font-size:1.1rem;opacity:.9}.config-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.config-section h3{margin:0 0 20px;color:#374151;font-size:1.25rem;font-weight:600}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.config-item{display:flex;flex-direction:column;gap:8px}.config-item label{font-weight:500;color:#374151;font-size:.95rem}.config-select{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;background:#fff;transition:all .2s ease}.config-select:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 3px #eccd8f1a}.input-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.input-section h3{margin:0 0 20px;color:#374151;font-size:1.25rem;font-weight:600}.input-method-selection{display:flex;gap:16px;margin-bottom:24px;padding:8px;background:#f9fafb;border-radius:12px}.input-method{flex:1;display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:500;color:#6b7280;border:2px solid transparent}.input-method:hover{background:#f3f4f6}.input-method.active{background:#fff;color:#eccd8f;border-color:#eccd8f;box-shadow:0 2px 8px #eccd8f26}.input-method input[type=radio]{display:none}.file-upload-area{border:3px dashed #d1d5db;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafbfc;margin-bottom:24px}.file-upload-area:hover{border-color:#eccd8f;background:#f8faff}.file-upload-area.drag-over{border-color:#eccd8f;background:#f0f4ff;transform:scale(1.02)}.file-upload-area.has-file{border-color:#10b981;background:#f0fdf4}.file-input{display:none}.file-upload-prompt{display:flex;flex-direction:column;align-items:center;gap:12px}.upload-icon{font-size:3rem;color:#6b7280}.upload-text{font-size:1.1rem;color:#374151}.upload-formats{font-size:.9rem;color:#6b7280}.file-selected{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.file-icon{font-size:2rem;color:#10b981}.file-info{text-align:left}.file-name{font-weight:600;color:#374151;margin-bottom:4px}.file-size{font-size:.9rem;color:#6b7280}.text-input{width:100%;padding:16px;border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;resize:vertical;margin-bottom:24px;transition:border-color .2s ease}.text-input:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 3px #eccd8f1a}.extract-btn{width:100%;padding:16px 24px;background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #6366f14d}.extract-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.extract-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.results-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.results-section h3{margin:0 0 20px;color:#374151;font-size:1.25rem;font-weight:600}.extraction-results{display:flex;flex-direction:column;gap:24px}.result-metadata{display:flex;gap:24px;padding:16px;background:#f9fafb;border-radius:8px;flex-wrap:wrap}.metadata-item{display:flex;flex-direction:column;gap:4px;min-width:120px}.metadata-item strong{font-size:.85rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.extracted-data{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.extracted-data h4{margin:0;padding:12px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-size:1rem;font-weight:600;color:#374151}.json-output{margin:0;padding:16px;background:#1f2937;color:#f9fafb;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;line-height:1.5;overflow-x:auto;white-space:pre-wrap;max-height:400px;overflow-y:auto}.result-actions{display:flex;gap:12px;flex-wrap:wrap}.result-actions button{padding:10px 16px;border:1px solid #e5e7eb;background:#fff;color:#374151;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.result-actions button:hover{background:#f9fafb;border-color:#eccd8f;color:#eccd8f}.placeholder-content{padding:48px 24px;text-align:center}.coming-soon{max-width:400px;margin:0 auto}.coming-soon-icon{font-size:4rem;margin-bottom:24px}.coming-soon h3{color:#374151;margin-bottom:12px;font-size:1.5rem}.coming-soon p{color:#6b7280;line-height:1.6}.dataset-creation-section{display:flex;flex-direction:column;gap:24px}.dataset-creator-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.dataset-creator-card h3{margin:0 0 12px;color:#374151;font-size:1.25rem;font-weight:600}.dataset-creator-card .description{margin-bottom:24px;color:#6b7280;font-size:.95rem}.dataset-info-box{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:16px}.dataset-info-box p{margin:8px 0;color:#374151;font-size:.95rem}.annotated-documents-list{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb}.documents-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.documents-list-header h4{margin:0;color:#374151;font-size:1.1rem;font-weight:600}.selection-actions{display:flex;align-items:center;gap:8px}.selection-actions .btn-link{background:none;border:none;color:#eccd8f;font-size:.9rem;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.selection-actions .btn-link:hover:not(:disabled){background:#eccd8f1a;color:#f2be6e}.selection-actions .btn-link:disabled{opacity:.5;cursor:not-allowed}.selection-actions .separator{color:#d1d5db;-webkit-user-select:none;user-select:none}.document-card.selectable{cursor:pointer;-webkit-user-select:none;user-select:none}.document-card.selectable .document-header{display:flex;align-items:center;gap:12px}.document-card.selectable .document-header input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#eccd8f;flex-shrink:0}.document-card.selectable.selected{background:#eccd8f14;border-color:#eccd8f80}.document-card.selectable.selected:before{transform:scaleX(1)}.document-card.selectable .filename{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.warning-box{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:12px 16px;margin-top:16px;color:#92400e;font-size:.95rem}@media (max-width: 768px){.extract-content{padding:16px}.section-header{padding:20px}.section-header h2{font-size:1.5rem}.config-grid{grid-template-columns:1fr}.input-method-selection{flex-direction:column}.result-metadata{flex-direction:column;gap:12px}.result-actions{flex-direction:column}.result-actions button{width:100%}}.token-usage-info{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;border:2px solid #e5e7eb;transition:all .3s ease}.token-usage-info.token-normal{border-color:#10b981;background:linear-gradient(135deg,#10b98108,#10b9810f)}.token-usage-info.token-warning{border-color:#f59e0b;background:linear-gradient(135deg,#f59e0b08,#f59e0b0f)}.token-usage-info.token-exceeded{border-color:#ef4444;background:linear-gradient(135deg,#ef444408,#ef44440f)}.token-usage-info h4{margin:0 0 16px;color:#374151;font-size:1.1rem;font-weight:600}.token-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.token-stat{padding:12px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;font-size:.95rem}.token-stat strong{color:#6b7280;margin-right:8px;font-weight:600}.token-alert{padding:12px 16px;border-radius:8px;margin-top:12px;font-size:.95rem;line-height:1.5}.token-alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.token-alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #f87171}.token-alert strong{font-weight:600}@media (max-width: 768px){.token-stats{grid-template-columns:1fr}}.datasets-view-section{display:grid;grid-template-columns:350px 1fr;gap:24px;height:calc(100vh - 200px)}.datasets-list-panel{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb;overflow-y:auto}.datasets-list-panel h3{margin:0 0 20px;color:#374151;font-size:1.25rem;font-weight:600;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.empty-state{text-align:center;padding:48px 16px;color:#6b7280}.empty-state p{margin:8px 0}.datasets-list{display:flex;flex-direction:column;gap:12px}.dataset-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease}.dataset-card:hover{background:#fff;border-color:#eccd8f;transform:translate(4px);box-shadow:0 4px 12px #eccd8f26}.dataset-card.selected{background:#fff;border-color:#eccd8f;box-shadow:0 4px 12px #eccd8f33}.dataset-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.dataset-header h4{margin:0;color:#374151;font-size:1rem;font-weight:600;flex:1}.dataset-badge{background:#eccd8f;color:#fff;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.dataset-description{color:#6b7280;font-size:.9rem;margin:8px 0;line-height:1.4}.dataset-meta{display:flex;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.dataset-meta small{color:#9ca3af;font-size:.85rem}.dataset-details-panel{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb;overflow-y:auto;max-height:calc(100vh - 200px)}.dataset-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.dataset-details-header h3{margin:0;color:#374151;font-size:1.5rem;font-weight:700}.btn-close{background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;padding:8px 12px;cursor:pointer;color:#6b7280;font-size:1.2rem;transition:all .2s ease}.btn-close:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}.dataset-info-section{background:#f9fafb;border-radius:8px;padding:20px;margin-bottom:24px}.info-row{display:flex;padding:10px 0;border-bottom:1px solid #e5e7eb}.info-row:last-child{border-bottom:none}.info-row .label{font-weight:600;color:#6b7280;min-width:180px}.info-row .value{color:#374151;flex:1}.annotations-section{margin-top:24px}.annotations-section h4{margin:0 0 16px;color:#374151;font-size:1.25rem;font-weight:600}.annotations-list{display:flex;flex-direction:column;gap:12px}.annotation-item{background:#fff;border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .2s ease}.annotation-item.expanded{border-color:#eccd8f;box-shadow:0 4px 16px #eccd8f26}.annotation-header{display:flex;align-items:center;gap:12px;padding:16px;background:#f9fafb;border-bottom:1px solid #e5e7eb;transition:background .2s ease}.annotation-header:hover{background:#f3f4f6}.annotation-item.expanded .annotation-header{background:linear-gradient(135deg,#eccd8f14,#f2be6e1f)}.expand-icon{color:#9ca3af;font-size:.75rem;width:16px;transition:transform .2s ease}.annotation-number{font-weight:700;color:#6b7280;font-size:.9rem;min-width:40px}.filename{flex:1;color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.confidence-badge{font-size:.85rem;font-weight:600;padding:4px 10px;border-radius:12px}.annotation-metadata{padding:20px;background:#fafbfc;border-bottom:1px solid #e5e7eb}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.metadata-item{display:flex;flex-direction:column;gap:4px}.metadata-label{font-size:.8rem;color:#9ca3af;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.metadata-value{font-size:.95rem;color:#374151;font-weight:500}.annotation-notes{padding:16px 20px;background:#fef3c7;border-bottom:1px solid #fbbf24;color:#92400e;font-size:.9rem;line-height:1.5}.annotation-notes strong{font-weight:600}.annotation-content{padding:20px}.json-header{margin-bottom:12px;color:#374151;font-size:.95rem}.json-display{background:#1f2937;border-radius:8px;padding:16px;overflow-x:auto}.json-display pre{margin:0;color:#f9fafb;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}@media (max-width: 1024px){.datasets-view-section{grid-template-columns:1fr;height:auto}.datasets-list-panel{max-height:400px}.dataset-details-panel{max-height:none}.metadata-grid{grid-template-columns:1fr}}.annotation-detail{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;border:1px solid #e5e7eb;margin-top:20px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #eccd8f}.detail-header h3{margin:0;color:#374151;font-size:1.25rem}.close-detail-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:4px 8px;border-radius:4px;transition:all .2s ease}.close-detail-btn:hover{background:#ef44441a;color:#ef4444}.detail-content{display:flex;flex-direction:column;gap:24px}.document-text-section{flex:1}.document-text-section h4{margin:0 0 12px;color:#374151;font-size:1rem;font-weight:600}.document-text-box{max-height:300px;overflow-y:auto;padding:16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:.9rem;line-height:1.6;color:#374151;white-space:pre-wrap}.annotation-form-section{flex:1}.annotation-form-section h4{margin:0 0 12px;color:#374151;font-size:1rem;font-weight:600}.json-input-options{display:flex;align-items:center;gap:12px;margin-bottom:12px}.upload-json-btn{display:inline-block;padding:10px 20px;background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;box-shadow:0 2px 8px #eccd8f4d}.upload-json-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #eccd8f66}.or-separator{color:#6b7280;font-size:.9rem;font-style:italic}.json-textarea{width:100%;min-height:250px;padding:16px;border:2px solid #e5e7eb;border-radius:8px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;line-height:1.5;resize:vertical;background:#1f2937;color:#f9fafb;transition:border-color .2s ease}.json-textarea:focus{outline:none;border-color:#eccd8f;box-shadow:0 0 0 3px #eccd8f1a}.json-textarea::placeholder{color:#6b7280}.form-help{margin-top:8px;font-size:.85rem;color:#6b7280}.form-row{margin:16px 0}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:.9rem}.confidence-input{width:100%;max-width:200px;padding:8px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem}.save-annotation-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:16px}.save-annotation-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #eccd8f66}.save-annotation-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.current-annotation-box{margin-top:24px;padding:16px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px}.current-annotation-box h5{margin:0 0 12px;color:#166534;font-size:1rem}.json-preview{background:#1f2937;color:#f9fafb;padding:12px;border-radius:6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8rem;line-height:1.4;overflow-x:auto;max-height:200px;overflow-y:auto}.annotation-meta{margin-top:12px;display:flex;gap:16px;flex-wrap:wrap}.annotation-meta p{margin:0;font-size:.85rem;color:#166534}.user-profile-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.user-profile-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:400px;width:90vw;max-height:80vh;overflow:hidden}.user-profile-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:linear-gradient(135deg,#eccd8f,#f2be6e);color:#fff}.user-profile-header h3{margin:0;font-size:1.25rem;font-weight:600}.close-btn{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background-color:#fff3}.user-profile-content{padding:20px}.user-info-section{display:flex;align-items:center;gap:16px;margin-bottom:24px}.user-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#eccd8f,#f2be6e);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:700}.user-details{flex:1}.user-name{margin:0 0 4px;font-size:1.1rem;font-weight:600;color:#2c3e50}.user-email{margin:0 0 8px;color:#7f8c8d;font-size:.9rem}.user-role-badge{display:inline-block;padding:4px 12px;border-radius:16px;color:#fff;font-size:.8rem;font-weight:500}.user-stats{margin-bottom:24px;padding:16px;background:#f8f9fa;border-radius:8px}.stat-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.stat-item:last-child{margin-bottom:0}.stat-label{color:#7f8c8d;font-size:.9rem}.stat-value{font-weight:500;color:#2c3e50}.permissions-section{margin-bottom:24px}.permissions-section h5{margin:0 0 12px;color:#2c3e50;font-size:1rem;font-weight:600}.permissions-grid{display:flex;flex-direction:column;gap:8px}.permission-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:6px;transition:all .2s}.permission-item.enabled{background:#d4edda;border:1px solid #c3e6cb}.permission-item.disabled{background:#f8f9fa;border:1px solid #e9ecef;opacity:.6}.permission-icon{font-size:16px}.permission-text{font-size:.9rem;color:#2c3e50;font-weight:500}.user-profile-actions{display:flex;justify-content:center;padding-top:16px;border-top:1px solid #e9ecef}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:10px 24px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:8px}.logout-btn:hover:not(:disabled){background:#c0392b;transform:translateY(-1px)}.logout-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}
