.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:slideUp .6s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:450px;padding:40px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin:0 0 10px}.login-header p{color:#7f8c8d;font-size:1.1rem;margin:0}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group label{color:#2c3e50;font-size:.9rem;font-weight:600;margin-bottom:8px}.form-group input{background:#f8f9fa;border:2px solid #e1e8ed;border-radius:10px;font-size:1rem;padding:14px 16px;transition:all .3s ease}.form-group input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#fee;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-size:.9rem;padding:12px;text-align:center}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;overflow:hidden;padding:16px 20px;position:relative;transition:all .3s ease}.login-button:hover:not(:disabled){box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.login-footer{border-top:1px solid #e1e8ed;margin-top:30px;padding-top:20px;text-align:center}.login-footer p{color:#7f8c8d;font-size:.9rem;margin:0 0 20px}@media (max-width:480px){.login-container{padding:10px}.login-card{padding:30px 20px}.login-header h1{font-size:2rem}}.user-header{align-items:center;background:#2c3e50;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-left{align-items:center;flex:0 0 auto}.header-left h1{color:#fff;font-size:1.5rem;font-weight:600;margin:0}.header-right{position:relative}.user-info{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;transition:background-color .2s ease}.user-info:hover{background-color:#ffffff1a}.user-icon{font-size:1.5rem}.user-details{align-items:flex-start;display:flex;flex-direction:column;gap:.25rem}.user-name{font-size:.9rem;font-weight:600}.user-role{background:#3498db;border-radius:12px;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.2rem .5rem;text-transform:uppercase}.dropdown-arrow{font-size:.8rem;transition:transform .2s ease}.dropdown-arrow.rotated{transform:rotate(180deg)}.user-menu{animation:slideDown .2s ease-out;background:#fff;border:1px solid #e1e8ed;border-radius:12px;box-shadow:0 8px 25px #00000026;min-width:280px;position:absolute;right:0;top:100%;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{background:#f8f9fa;border-radius:12px 12px 0 0;gap:1rem;padding:1.5rem}.user-avatar,.user-menu-header{align-items:center;display:flex}.user-avatar{background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000001a;font-size:2rem;height:50px;justify-content:center;width:50px}.user-info-details{display:flex;flex-direction:column;gap:.25rem}.user-info-details strong{color:#2c3e50;font-size:1rem;margin-bottom:.25rem}.user-info-details small{color:#6c757d;font-size:.8rem}.role-badge{align-self:flex-start;border-radius:12px;color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.5px;margin-top:.5rem;padding:.25rem .5rem}.user-menu-item{align-items:center;background:none;border:none;color:#2c3e50;cursor:pointer;display:flex;font-size:.9rem;padding:.75rem 1.5rem;text-align:left;transition:background-color .2s ease;width:100%}.user-menu-item:hover{background-color:#f8f9fa}.admin-item{color:#e74c3c;font-weight:600}.admin-item:hover{background-color:#fee}.logout-button{border-radius:0 0 12px 12px;color:#e74c3c;font-weight:600}.logout-button:hover{background-color:#fee}.user-menu-divider{background:#e1e8ed;height:1px;margin:.5rem 0}@media (max-width:768px){.user-header{padding:1rem}.header-left h1{font-size:1.2rem}.user-menu{min-width:250px;right:-1rem}.user-details{display:none}}@media (max-width:480px){.header-left h1{font-size:1rem}.user-menu{min-width:220px;right:-2rem}}.loading-container{background:#f8f9fa;justify-content:center;min-height:100vh}.loading-spinner{border:4px solid #e1e8ed;height:40px;margin-bottom:1rem;width:40px}.loading-container p{color:#6c757d;font-size:1.1rem;margin:0}.unauthorized-container{align-items:center;background:#f8f9fa;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.unauthorized-container h2{color:#e74c3c;font-size:2rem;margin-bottom:1rem}.unauthorized-container p{color:#6c757d;font-size:1.1rem;margin-bottom:1rem}.permission-details{background:#fff;border:1px solid #dee2e6;border-radius:8px;margin-top:1rem;max-width:400px;padding:1.5rem;text-align:left}.permission-details p{font-size:.9rem;margin:.5rem 0}.permission-details strong{color:#2c3e50}*{box-sizing:border-box;margin:0;padding:0}.form-analysis-content,.image-container,.justoza-table-container,.llm-analysis-content,.table-container{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-behavior:smooth}.form-analysis-content::-webkit-scrollbar,.image-container::-webkit-scrollbar,.justoza-table-container::-webkit-scrollbar,.llm-analysis-content::-webkit-scrollbar,.table-container::-webkit-scrollbar{height:8px;width:8px}.form-analysis-content::-webkit-scrollbar-track,.image-container::-webkit-scrollbar-track,.justoza-table-container::-webkit-scrollbar-track,.llm-analysis-content::-webkit-scrollbar-track,.table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.form-analysis-content::-webkit-scrollbar-thumb,.image-container::-webkit-scrollbar-thumb,.justoza-table-container::-webkit-scrollbar-thumb,.llm-analysis-content::-webkit-scrollbar-thumb,.table-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.form-analysis-content::-webkit-scrollbar-thumb:hover,.image-container::-webkit-scrollbar-thumb:hover,.justoza-table-container::-webkit-scrollbar-thumb:hover,.llm-analysis-content::-webkit-scrollbar-thumb:hover,.table-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}body{background:linear-gradient(135deg,#e3f2fd,#f5f5f5);color:#333;font-family:Arial,sans-serif;line-height:1.5}.App,body{min-height:100vh}.App{display:flex;flex-direction:column}.App-header{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;gap:2rem;justify-content:center;padding:.75rem 1rem}.App-header h1{font-size:1.8rem;margin:0;text-shadow:1px 1px 2px #0000004d}.header-status{align-items:center;display:flex}.status-indicator{animation:pulse 2s infinite;display:inline-block;font-size:.9rem}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.App-main{flex:1 1;margin:0;max-width:100%;padding:1rem .5rem .25rem;width:100%}.upload-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1rem;padding:1.5rem}.upload-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1rem}.file-input{display:none}.file-input-label{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:700;padding:.75rem 1.5rem;transition:all .3s ease}.file-input-label:hover{box-shadow:0 3px 6px #0000004d;transform:translateY(-1px)}.file-info{background:#f8f9fa;border-left:3px solid #2196f3;border-radius:6px;margin-bottom:1rem;padding:.75rem;text-align:center}.file-info p{font-size:.9rem;font-weight:500;margin:0}.file-info-inline{align-items:center;background:#e3f2fd;border:1px solid #2196f3;border-radius:6px;display:flex;max-width:250px;overflow:hidden;padding:.75rem 1rem}.file-info-inline span{color:#1976d2;font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clear-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:.4rem .8rem;transition:background .3s ease}.clear-btn:hover{background:#d32f2f}.submit-btn{background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:6px;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem 1.5rem;transition:all .3s ease}.submit-btn:hover:not(:disabled){box-shadow:0 3px 6px #0000004d;transform:translateY(-1px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.preview-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1rem;padding:1.5rem}.preview-section h3{color:#2196f3;font-size:1.3rem;margin-bottom:.75rem}.preview-container{text-align:center}.preview-image{border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 2px 6px #0003;max-height:500px;max-width:100%}.error-section{background:#ffebee;border:1px solid #f44336;border-radius:12px;margin-bottom:2rem;padding:2rem;text-align:center}.error-section h3{color:#f44336;font-size:1.5rem;margin-bottom:1rem}.error-message{color:#d32f2f;font-size:1.1rem;margin:0}.results-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1rem;padding:1.5rem}.results-section h3{color:#2196f3;font-size:1.4rem;margin-bottom:1rem;text-align:center}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem}.stat-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:6px;padding:1rem;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h4{color:#495057;font-size:.85rem;margin-bottom:.4rem}.stat-value{color:#2196f3;font-size:1.6rem;margin:0}.text-results{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:1.5rem}.text-section{background:#f8f9fa;border-left:3px solid #2196f3;border-radius:6px;padding:1rem}.text-section h4{color:#2196f3;font-size:1.1rem;margin-bottom:.75rem}.text-content{background:#fff;border:1px solid #dee2e6;border-radius:4px;color:#333;font-family:Courier New,monospace;font-size:.9rem;line-height:1.4;max-height:180px;overflow-y:auto;padding:.75rem;white-space:pre-wrap}.detailed-results{border-top:1px solid #e0e0e0;padding-top:1.5rem}.detailed-results h4{color:#2196f3;font-size:1.2rem;margin-bottom:.75rem}.filter-controls{margin-bottom:1rem}.filter-buttons{display:flex;flex-wrap:wrap;gap:.4rem}.filter-btn{background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#666;cursor:pointer;font-size:.8rem;font-weight:500;padding:.4rem .8rem;transition:all .3s ease}.filter-btn:hover{background:#f5f5f5;border-color:#2196f3}.filter-btn.active{background:#2196f3;border-color:#2196f3;color:#fff}.table-container{border:1px solid #e0e0e0;border-radius:6px;max-height:400px;overflow:hidden;overflow-y:auto}.analysis-table{background:#fff;border-collapse:collapse;font-size:.85rem;width:100%}.analysis-table th{background:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#495057;font-weight:600;padding:.75rem;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.analysis-table th:first-child{width:100px}.analysis-table th:last-child{width:120px}.table-row{transition:background-color .2s ease}.table-row:hover{background:#f8f9fa}.table-row.printed{border-left:3px solid #4caf50}.table-row.handwritten{border-left:3px solid #ff9800}.type-cell{padding:.6rem;vertical-align:top}.type-badge{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:500;padding:.3rem .6rem;text-transform:uppercase}.type-badge.printed{background:#e8f5e8;color:#2e7d32}.type-badge.handwritten{background:#fff3e0;color:#f57c00}.text-cell{padding:.8rem;vertical-align:top}.text-content-cell{word-wrap:break-word;color:#333;font-family:Courier New,monospace;line-height:1.4;max-width:400px}.confidence-cell{padding:.8rem;vertical-align:top}.confidence-bar{background:#f0f0f0;border-radius:4px;height:20px;overflow:hidden;position:relative}.confidence-fill{background:linear-gradient(90deg,#f44336,#ff9800 30%,#4caf50 70%,#2196f3);height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.confidence-text{color:#333;font-size:.8rem;font-weight:500;left:50%;position:absolute;text-shadow:1px 1px 2px #fffc;top:50%;transform:translate(-50%,-50%)}.text-regions{grid-gap:1rem;display:grid;gap:1rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.text-region{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:1rem;transition:transform .2s ease}.text-region:hover{transform:translateX(5px)}.text-region.printed{border-left:4px solid #4caf50}.text-region.handwritten{border-left:4px solid #ff9800}.region-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem}.region-type{color:#666;font-size:.9rem;font-weight:700;text-transform:uppercase}.region-confidence{background:#e3f2fd;border-radius:4px;color:#1976d2;font-size:.8rem;font-weight:700;padding:.2rem .5rem}.region-text{word-wrap:break-word;color:#333;font-family:Courier New,monospace;font-size:.95rem;line-height:1.4}.App-footer{background:#37474f;color:#b0bec5;margin-top:auto;padding:2rem;text-align:center}.App-footer p{margin:.5rem 0}@media (max-width:768px){.App-header{flex-direction:column;gap:.5rem;text-align:center}.App-header h1{font-size:1.5rem}.upload-controls{flex-direction:column;gap:.75rem}.file-info-inline{max-width:100%;order:2}.App-main{padding:.5rem .25rem}.preview-section,.results-section,.upload-section{padding:1rem}.stats-grid{gap:.75rem;grid-template-columns:1fr 1fr}.file-input-label,.submit-btn{font-size:.9rem;padding:.6rem 1.2rem}.filter-buttons{flex-direction:column;gap:.25rem}.filter-btn{font-size:.75rem;padding:.35rem .7rem;text-align:center}.table-container{max-height:300px}.analysis-table{font-size:.75rem}.analysis-table th,.confidence-cell,.text-cell,.type-cell{padding:.5rem}.text-content-cell{font-size:.75rem;max-width:180px}.confidence-bar{height:12px}.confidence-text{font-size:.65rem}}.llm-start-section{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:2rem;text-align:center}.llm-analyze-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin:1rem 0;padding:1rem 2rem;transition:all .3s ease}.llm-analyze-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.llm-analyze-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.llm-requirements{background:#fff;border-left:4px solid #667eea;border-radius:6px;margin-top:1rem;padding:1rem}.llm-requirements h4{color:#667eea;margin-bottom:.5rem}.llm-requirements ul{list-style:none;margin:0;padding:0}.llm-requirements li{color:#28a745;font-weight:500;padding:.3rem 0}.llm-loading{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:3rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 1rem;width:50px}.llm-error{background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;margin-bottom:2rem;padding:1.5rem}.llm-error h4{color:#c53030;margin-bottom:1rem}.retry-btn{background:#e53e3e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:1rem;padding:.5rem 1rem;transition:background .3s ease}.retry-btn:hover{background:#c53030}.llm-results{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem;overflow:hidden;padding:0}.llm-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1.5rem}.llm-header h4{font-size:1.3rem;margin:0}.copy-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.copy-btn:hover{background:#ffffff4d}.llm-content{max-height:600px;overflow-y:auto;padding:1.5rem}.llm-content pre{word-wrap:break-word;color:#333;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.95rem;line-height:1.6;margin:0;white-space:pre-wrap}.llm-actions{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:1rem 1.5rem;text-align:center}.rerun-btn{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.7rem 1.5rem;transition:background .3s ease}.rerun-btn:hover{background:#218838}.handwritten-summary{background:#f8f9fa;border-left:4px solid #ed8936;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.handwritten-summary h4{color:#d69e2e;margin-bottom:1rem}.summary-stats{display:flex;gap:2rem;margin-bottom:1.5rem}.stat-item{align-items:center;display:flex;flex-direction:column}.stat-label{font-size:.9rem;margin-bottom:.25rem}.stat-value{color:#d69e2e;font-size:1.5rem}.handwritten-preview{background:#fff;border-radius:6px;padding:1rem}.handwritten-preview h5{color:#333;margin-bottom:.5rem}.text-preview{background:#f7fafc;border-left:3px solid #ed8936;border-radius:4px;color:#666;font-family:monospace;font-size:.9rem;padding:1rem}.extraction-start-section{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:2rem;text-align:center}.analysis-buttons{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin:2rem 0}.analysis-option{max-width:300px;text-align:center}.extraction-btn{align-items:center;border:none;border-radius:8px;box-shadow:0 4px 15px #0000004d;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;justify-content:center;margin:0 auto 1rem;min-width:280px;padding:15px 30px;transition:all .3s ease}.standard-btn{background:linear-gradient(135deg,#2196f3,#1976d2);box-shadow:0 4px 15px #2196f34d}.standard-btn:hover:not(:disabled){background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 6px 20px #2196f366;transform:translateY(-2px)}.two-step-btn{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 4px 15px #ff98004d}.two-step-btn:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#ef6c00);box-shadow:0 6px 20px #ff980066;transform:translateY(-2px)}.extraction-btn:disabled{background:#ccc!important;box-shadow:none!important;cursor:not-allowed;transform:none}.btn-description{color:#666;font-size:.9rem;font-style:italic;margin:0}.disabled-message{color:#666;font-style:italic;margin-top:1rem}.extraction-loading{background:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:3rem}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1rem}.extraction-loading .loading-spinner{animation:spin 1s linear infinite;border:5px solid #f3f3f3;border-radius:50%;border-top-color:#ed8936;height:50px;width:50px}.loading-text{text-align:center}.loading-text h4{color:#d69e2e;margin-bottom:.5rem}.loading-text p{color:#666;margin:.25rem 0}.progress-text{background:#2196f31a;border-left:3px solid #2196f3;border-radius:4px;color:#2196f3!important;font-size:1rem!important;margin:1rem 0!important;padding:.5rem}.extraction-loading-compact{align-items:center;background:linear-gradient(135deg,#f0f8ff,#e3f2fd);border:1px solid #bbdefb;border-radius:6px;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem}.loading-spinner-small{animation:spin 1s linear infinite;border:2px solid #e3f2fd;border-radius:50%;border-top-color:#2196f3;flex-shrink:0;height:16px;width:16px}.loading-text-compact{color:#1565c0;font-weight:500;line-height:1.2}.loading-text-compact strong{color:#0d47a1;font-weight:600}.loading-text-compact small{color:#666;font-weight:400}.placeholder-image{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #dee2e6;border-radius:8px;display:flex;flex:1 1;justify-content:center;text-align:center}.placeholder-content{color:#6c757d;max-width:300px}.placeholder-content h4{color:#495057;font-size:1.1rem;margin-bottom:.5rem}.placeholder-content p{font-size:.9rem;line-height:1.4;margin:0}.placeholder-text{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:6px;color:#6c757d;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:2rem}.placeholder-text h4{color:#495057;font-size:1.1rem;margin-bottom:.75rem}.placeholder-text p{font-size:.9rem;line-height:1.4;margin:.25rem 0}.placeholder-text small{color:#868e96}.url-input-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;border-radius:8px 8px 0 0;padding:10px}.url-input-container{align-items:center;display:flex;gap:8px}.url-input{background:#fff;border:1px solid #ced4da;border-radius:4px;flex:1 1;font-size:.85rem;padding:8px 12px;transition:border-color .3s ease,box-shadow .3s ease}.url-input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333;outline:none}.url-input:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.url-load-btn{background:linear-gradient(135deg,#2196f3,#1976d2);border:none;border-radius:4px;box-shadow:0 2px 4px #2196f34d;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.url-load-btn:hover:not(:disabled){background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 8px #2196f366;transform:translateY(-1px)}.url-load-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.extraction-error{background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;margin-bottom:.5rem;padding:1rem}.extraction-error h4{color:#e53e3e;margin-bottom:1rem}.extraction-error p{color:#666;margin-bottom:1.5rem}.extraction-results{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:.5rem;overflow:hidden}.results-header{align-items:center;background:linear-gradient(135deg,#ed8936,#d69e2e);color:#fff;display:flex;justify-content:space-between;padding:1rem 1.5rem}.results-header h4{font-size:1.3rem;margin:0}.header-actions{display:flex;gap:1rem}.results-content{max-height:none;overflow-y:visible;padding:1rem}.side-by-side-container{display:flex;gap:1rem;height:calc(100vh - 150px);margin-top:.5rem;min-height:600px}.analysis-section,.image-preview-section{display:flex;flex:1 1;flex-direction:column;height:100%;min-width:0}.analysis-section h5,.image-preview-section h5{border-bottom:1px solid #e3f2fd;color:#2196f3;font-size:1.1rem;font-weight:600;margin-bottom:.75rem;padding-bottom:.4rem}.image-preview-section .image-container{flex:1 1;overflow-y:auto;padding:10px;text-align:center}.image-preview-section .image-container::-webkit-scrollbar{width:8px}.image-preview-section .image-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.image-preview-section .image-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.image-preview-section .image-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.image-preview-section .step-image{border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 2px 4px #00000026;display:block;height:auto;margin:0 auto;max-height:none;max-width:100%;object-fit:contain;vertical-align:top;width:auto}.analysis-tabs{border:1px solid #e0e0e0;border-radius:8px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.tab-headers{background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex}.tab-button{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border:none;box-shadow:0 2px 4px #0000001a;color:#1565c0;cursor:pointer;flex:1 1;font-size:.75rem;font-weight:600;padding:6px 10px;position:relative;text-shadow:0 1px 2px #0000001a;transition:all .3s ease}.tab-button:hover{background:linear-gradient(135deg,#bbdefb,#e1bee7);box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.tab-button.active{background:linear-gradient(135deg,#fff,#f8f9fa);box-shadow:0 3px 6px #0003,inset 0 1px 0 #ffffff80;color:#0d47a1;font-weight:700;text-shadow:0 1px 3px #0003;transform:translateY(-2px)}.tab-button.active:after{background:linear-gradient(90deg,#2196f3,#9c27b0);bottom:0;box-shadow:0 2px 4px #2196f380;content:"";height:3px;left:0;position:absolute;right:0}.tab-content{background:#fff;display:flex;flex:1 1;flex-direction:column}.form-analysis-content{background-color:#f8f9fa;border-radius:0 0 8px 8px;flex:1 1;max-height:80vh;overflow-y:auto;padding:15px}.form-analysis-content::-webkit-scrollbar,.llm-analysis-content::-webkit-scrollbar{width:8px}.form-analysis-content::-webkit-scrollbar-track,.llm-analysis-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.form-analysis-content::-webkit-scrollbar-thumb,.llm-analysis-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.form-analysis-content::-webkit-scrollbar-thumb:hover,.llm-analysis-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.medical-form{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.medical-form h5{border-bottom:2px solid #e3f2fd;color:#2196f3;font-size:1.2rem;margin-bottom:20px;padding-bottom:10px;text-align:center}.form-section{background:#f8f9fa;border-left:4px solid #2196f3;border-radius:6px;margin-bottom:25px;padding:15px}.form-section h6{color:#1976d2;font-size:1rem;font-weight:600;margin-bottom:15px}.form-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-field{display:flex;flex-direction:column}.form-field label{color:#333;font-size:.9rem;font-weight:500;margin-bottom:5px}.form-input,.form-textarea{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:10px 12px;transition:border-color .3s ease}.form-input:focus,.form-textarea:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a;outline:none}.form-textarea{font-family:inherit;min-height:80px;resize:vertical}.form-actions{border-top:1px solid #e0e0e0;display:flex;gap:15px;justify-content:center;margin-top:25px;padding-top:20px}.form-actions .clear-btn,.form-actions .copy-btn,.form-actions .populate-btn,.form-actions .save-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .3s ease}.form-actions .copy-btn{background:#2196f3;color:#fff}.form-actions .copy-btn:hover{background:#1976d2;transform:translateY(-1px)}.form-actions .clear-btn{background:#f44336;color:#fff}.form-actions .clear-btn:hover{background:#d32f2f;transform:translateY(-1px)}.form-actions .populate-btn{background:#9c27b0;color:#fff}.form-actions .populate-btn:hover{background:#7b1fa2;transform:translateY(-1px)}.form-actions .save-btn{background:#4caf50;color:#fff}.form-actions .save-btn:hover{background:#388e3c;transform:translateY(-1px)}.justoza-table-container{background:#fff;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.justoza-table{background:#fff;border-collapse:collapse;font-size:.75rem;table-layout:fixed;width:100%}.justoza-table th{background:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#495057;font-size:.7rem;font-weight:600;overflow:hidden;padding:10px 6px;position:-webkit-sticky;position:sticky;text-align:left;text-overflow:ellipsis;top:0;white-space:nowrap;z-index:10}.justoza-table td:first-child,.justoza-table th:first-child{width:20%}.justoza-table td:nth-child(2),.justoza-table th:nth-child(2){width:25%}.justoza-table td:nth-child(3),.justoza-table th:nth-child(3){width:12%}.justoza-table td:nth-child(4),.justoza-table th:nth-child(4){width:15%}.justoza-table td:nth-child(5),.justoza-table th:nth-child(5){width:18%}.justoza-table td:nth-child(6),.justoza-table th:nth-child(6){width:10%}.justoza-table td{border-bottom:1px solid #f0f0f0;overflow:hidden;padding:6px 4px;text-overflow:ellipsis;vertical-align:middle}.justoza-table tr:hover{background:#f8f9fa}.table-input{background:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:.7rem;min-width:0;padding:6px 8px;transition:border-color .3s ease;width:100%}.table-input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f31a;outline:none}.justoza-table select.table-input{background-color:#f8f9fa;border:1px solid #ced4da;border-radius:4px;cursor:pointer;transition:all .2s ease}.justoza-table select.table-input:focus,.justoza-table select.table-input:hover{background-color:#fff;border-color:#2196f3}.justoza-table select.table-input:focus{box-shadow:0 0 0 2px #2196f333}.justoza-table select.table-input option{font-size:12px;padding:8px}.justoza-table select.table-input option:hover{background-color:#e3f2fd}.remove-row-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.7rem;min-width:40px;padding:6px 10px;transition:all .3s ease}.remove-row-btn:hover:not(:disabled){background:#d32f2f;transform:translateY(-1px)}.remove-row-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.table-actions{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:12px;text-align:center}.add-row-btn{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.add-row-btn:hover{background:#45a049;transform:translateY(-1px)}.json-analysis-content{background-color:#f8f9fa;border-radius:0 0 8px 8px;max-height:500px;overflow-y:auto;padding:15px}.json-text{word-wrap:break-word;background:#0000;color:#2c3e50;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85em;line-height:1.4;margin:0;padding:0;white-space:pre-wrap}.json-analysis-content{position:relative}.json-analysis-content:before{background:#2196f3;border-radius:4px;color:#fff;content:"📊 Dynamic JSON Structure";font-size:.75em;font-weight:500;padding:4px 8px;position:absolute;right:10px;top:-5px}.json-stats{background:#e3f2fd;border:1px solid #2196f3;border-radius:6px;font-size:.85em;margin-bottom:15px;padding:12px}.json-stats h5{color:#1976d2;font-size:.9em;margin:0 0 8px}.json-stats-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));max-width:100%}.stat-badge{background:#fff;border:1px solid #bbdefb;border-radius:4px;padding:6px 10px;text-align:center}.stat-label{color:#666;font-size:.75em;margin-bottom:2px}.stat-value{color:#1976d2;font-weight:700}.formatted-analysis{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6}.section-header{border-bottom:2px solid #fed7d7;color:#d69e2e;font-size:1.2rem;margin:1.5rem 0 1rem;padding-bottom:.5rem}.analysis-item{color:#4a5568;list-style:none;margin:.5rem 0;padding-left:1rem;position:relative}.analysis-item:before{color:#ed8936;content:"•";font-weight:700;left:0;position:absolute}.analysis-text{color:#2d3748;margin:.75rem 0}@media (max-width:768px){.side-by-side-container{flex-direction:column;gap:1rem}.analysis-section,.image-preview-section{flex:1 1}.image-preview-section .step-image{max-height:300px}.llm-start-section{padding:1.5rem}.llm-analyze-btn{font-size:1rem;padding:.8rem 1.5rem}.llm-header{flex-direction:column;gap:1rem;text-align:center}.llm-content{padding:1rem}.llm-content pre{font-size:.85rem}.form-grid{gap:12px;grid-template-columns:1fr}.form-section{margin-bottom:20px;padding:12px}.medical-form{padding:15px}.form-actions{flex-direction:column;gap:10px}.form-actions .clear-btn,.form-actions .copy-btn,.form-actions .populate-btn,.form-actions .save-btn{width:100%}.justoza-table{font-size:.65rem}.justoza-table td,.justoza-table th{padding:4px 2px}.table-input{font-size:.65rem;padding:4px 6px}.remove-row-btn{font-size:.65rem;min-width:30px;padding:3px 6px}.add-row-btn{font-size:.75rem;padding:4px 8px}}@media (max-width:480px){.App-header{padding:1rem}.App-header h1{font-size:1.8rem}.api-status,.file-info{flex-direction:column;gap:.5rem}.file-info{text-align:center}.text-regions{max-height:300px}}.llm-analysis-content::-webkit-scrollbar,.text-content::-webkit-scrollbar,.text-regions::-webkit-scrollbar{width:8px}.llm-analysis-content::-webkit-scrollbar-track,.text-content::-webkit-scrollbar-track,.text-regions::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.llm-analysis-content::-webkit-scrollbar-thumb,.text-content::-webkit-scrollbar-thumb,.text-regions::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.llm-analysis-content::-webkit-scrollbar-thumb:hover,.text-content::-webkit-scrollbar-thumb:hover,.text-regions::-webkit-scrollbar-thumb:hover{background:#555}.processing-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:.25rem;padding:.75rem}.step-navigator{border-bottom:1px solid #e0e0e0;margin-bottom:1rem;padding-bottom:.75rem}.step-indicators{align-items:center;display:flex;gap:.5rem;justify-content:space-between;overflow-x:auto;padding:.25rem 0}.step-indicator{align-items:center;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;min-width:90px;padding:.4rem;text-align:center;transition:all .3s ease}.step-indicator:hover{background:#f8f9fa}.step-indicator.active{background:#e3f2fd;color:#1976d2}.step-indicator.completed{opacity:1}.step-indicator:not(.completed):not(.active){cursor:not-allowed;opacity:.5}.step-number{align-items:center;background:#e0e0e0;border-radius:50%;display:flex;font-size:.9rem;font-weight:700;height:32px;justify-content:center;margin-bottom:.3rem;transition:all .3s ease;width:32px}.step-indicator.active .step-number{background:#2196f3;color:#fff}.step-indicator.completed .step-number{background:#4caf50;color:#fff}.step-title{font-size:.8rem;font-weight:500;line-height:1.2}.step-viewer{margin-bottom:0;min-height:200px}.step-content{text-align:center}.step-content h3{color:#2196f3;font-size:1.4rem;margin-bottom:.5rem}.step-content p{color:#666;font-size:.95rem;margin-bottom:1rem}.image-container{align-items:center;display:flex;flex-direction:column;gap:.75rem}.step-image{border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 2px 6px #0003;max-height:600px;max-width:100%}.legend{display:flex;gap:2rem;justify-content:center;margin-top:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border:2px solid;border-radius:4px;height:20px;width:20px}.legend-color.printed{background:#4caf504d;border-color:#4caf50}.legend-color.handwritten{background:#f443364d;border-color:#f44336}.extracted-text{margin-left:auto;margin-right:auto;margin-top:2rem;max-width:800px;text-align:left}.extracted-text h4{color:#2196f3;font-size:1.4rem;margin-bottom:1rem}.step-controls{align-items:center;background:#f8f9fa;border-radius:8px;border-top:2px solid #e0e0e0;display:flex;justify-content:space-between;padding:1rem}.nav-button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;padding:.8rem 1.5rem;transition:all .3s ease}.nav-button:disabled{cursor:not-allowed;opacity:.5}.prev-button{background:#6c757d;color:#fff}.prev-button:hover:not(:disabled){background:#5a6268}.next-button{background:#2196f3;color:#fff}.next-button:hover:not(:disabled){background:#1976d2}.step-info{color:#666;font-size:1rem;font-weight:500}@media (max-width:768px){.step-indicators{flex-direction:column;gap:.5rem}.step-indicator{flex-direction:row;gap:1rem;min-width:100%;text-align:left}.step-number{height:30px;margin-bottom:0;width:30px}.legend,.step-controls{flex-direction:column;gap:1rem}.nav-button{width:100%}}@media (max-width:480px){.processing-section{padding:1rem}.step-content h3{font-size:1.5rem}.step-content p{font-size:1rem}.step-image{max-height:400px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}}.submit-btn:disabled{position:relative}.submit-btn:disabled:before{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.image-list-section{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;margin-bottom:1rem;padding:.5rem}.compact-header{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:.75rem .5rem}.header-left{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;min-width:0}.header-left h2{color:#2196f3;font-size:1.3rem;font-weight:600;margin:0;white-space:nowrap}.header-subtitle{color:#666;font-size:.85rem;margin-top:.25rem;white-space:nowrap}.header-center{align-items:center;display:flex;flex:1 1;justify-content:center;min-width:0}.source-info{background:#fff;border:1px solid #d0d0d0;border-radius:6px;color:#555;font-size:.9rem;font-weight:500;padding:.5rem 1rem;white-space:nowrap}.header-right{align-items:center;display:flex;flex:1 1;gap:.5rem;justify-content:flex-end;min-width:0}.compact-btn{border:2px solid #0000;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:700;padding:.65rem 1.1rem;transition:all .3s ease;white-space:nowrap}.compact-btn.active{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 16px #1d4ed840;color:#fff}.compact-btn:hover{box-shadow:0 8px 18px #00000014;transform:translateY(-1px)}.home-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#334155;cursor:pointer;font-size:1.05rem;font-weight:700;padding:.25rem 0}.home-tab.selected{border-bottom-color:#2563eb;color:#111827}.home-tab:hover{color:#111827}.folder-btn{background:#2196f3;color:#fff;display:inline-block;text-decoration:none}.folder-btn:hover{background:#1976d2;transform:translateY(-1px)}.clear-btn,.refresh-btn{background:#f44336;border:none;color:#fff}.clear-btn:hover,.refresh-btn:hover{background:#d32f2f;transform:translateY(-1px)}.refresh-btn{background:#4caf50}.refresh-btn:hover{background:#45a049}.list-header{border-bottom:2px solid #e3f2fd;margin-bottom:2rem;padding-bottom:1rem;text-align:center}.list-header h2{color:#2196f3;font-size:1.8rem;margin-bottom:.5rem}.list-header p{color:#666;font-size:1.1rem;margin:0 0 1.5rem}.folder-picker-section{background:#f8f9fa;border:2px dashed #e0e0e0;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;transition:border-color .3s ease}.folder-picker-section:hover{border-color:#2196f3}.folder-picker-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1rem}.folder-picker-btn{align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);border:none;border-radius:8px;box-shadow:0 2px 4px #2196f34d;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.folder-picker-btn:hover{background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 8px #2196f366;transform:translateY(-2px)}.clear-folder-btn{background:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 18px;transition:all .3s ease}.clear-folder-btn:hover{background:#d32f2f;transform:translateY(-1px)}.refresh-server-btn{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 18px;transition:all .3s ease}.refresh-server-btn:hover{background:#45a049;transform:translateY(-1px)}.current-source-info{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;gap:2rem;justify-content:center;padding:1rem}.source-indicator{color:#1976d2;font-size:.95rem;font-weight:600}.image-count,.source-indicator{align-items:center;display:flex;gap:5px}.image-count{color:#666;font-size:.9rem;font-weight:500}.images-table-container{border:1px solid #e0e0e0;border-radius:8px;overflow-x:auto}.images-table{background:#fff;border-collapse:collapse;font-size:.85rem;width:100%}.images-table th{background:linear-gradient(135deg,#2196f3,#1976d2);border:none;color:#fff;font-weight:600;padding:8px 10px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.images-table th:first-child{text-align:center;width:80px}.images-table th:last-child{text-align:center;width:180px}.image-row{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.image-row:hover{background:#f8f9fa}.images-table td{border:none;padding:8px 10px;vertical-align:middle}.serial-number{color:#666;font-size:.9rem;font-weight:600;text-align:center}.filename{max-width:300px}.file-info{align-items:center;display:flex;gap:6px}.file-name{color:#333;font-weight:500;word-break:break-word}.file-ext{background:#e3f2fd;border-radius:4px;color:#1976d2;font-size:.75rem;font-weight:600;padding:2px 6px;text-transform:uppercase}.file-path{color:#666;font-family:monospace;font-size:.85rem;max-width:200px;word-break:break-all}.file-size{color:#888;font-weight:500;text-align:right}.actions{text-align:center}.open-btn,.view-btn{border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:500;margin:0 3px;padding:6px 10px;transition:all .3s ease}.view-btn{background:#4caf50;color:#fff}.view-btn:hover{background:#45a049;transform:translateY(-1px)}.open-btn{background:#ff9800;color:#fff}.open-btn:hover{background:#f57c00;transform:translateY(-1px)}.no-images{color:#666;padding:3rem;text-align:center}.no-images p{font-size:1.1rem;margin-bottom:1rem}.refresh-btn{background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:background .3s ease}.refresh-btn:hover{background:#1976d2}.header-buttons-container,.header-nav{flex-wrap:wrap;gap:1rem}.back-btn,.header-buttons-container,.header-nav{align-items:center;display:flex;justify-content:center}.back-btn{background:#ff9800cc;border:1px solid #ff980099;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;gap:.5rem;min-width:140px;padding:8px 16px;transition:all .3s ease}.back-btn:hover{background:#ff9800;border-color:#ff9800cc;box-shadow:0 2px 8px #ff98004d;transform:translateY(-1px)}.header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.header-url-section{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:6px;display:flex;gap:.5rem;padding:.5rem}.header-url-input{background:#ffffffe6;border:1px solid #ffffff4d;border-radius:4px;font-size:.85rem;padding:.5rem .75rem;transition:all .3s ease;width:300px}.header-url-input:focus{background:#fff;border-color:#fffc;box-shadow:0 0 0 2px #fff3;outline:none}.header-url-input:disabled{background:#ffffff80;color:#666;cursor:not-allowed}.header-url-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .3s ease;white-space:nowrap}.header-url-btn:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.header-url-btn:disabled{background:#ffffff1a;color:#ffffff80;cursor:not-allowed;transform:none}.header-ai-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.header-ai-btn{align-items:center;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:.5rem;justify-content:center;min-width:140px;padding:8px 16px;transition:all .3s ease}.standard-header-btn{background:#2196f3cc;border-color:#2196f399}.standard-header-btn:hover:not(:disabled){background:#2196f3;border-color:#2196f3cc;box-shadow:0 2px 8px #2196f34d;transform:translateY(-1px)}.two-step-header-btn{background:#ff9800cc;border-color:#ff980099}.two-step-header-btn:hover:not(:disabled){background:#ff9800;border-color:#ff9800cc;box-shadow:0 2px 8px #ff98004d;transform:translateY(-1px)}.header-ai-btn:disabled{background:#ffffff1a!important;border-color:#fff3!important;box-shadow:none!important;color:#ffffff80!important;cursor:not-allowed;transform:none!important}.modal-overlay{align-items:center;background:#000c;bottom:0;cursor:pointer;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;cursor:default;max-height:90vh;max-width:90vw;overflow:hidden}.modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.modal-header h3{color:#333;font-size:1.2rem;margin:0}.close-btn{align-items:center;background:#f44336;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:30px;justify-content:center;transition:background .3s ease;width:30px}.close-btn:hover{background:#d32f2f}.modal-body{padding:1rem;text-align:center}.modal-image{border-radius:6px;box-shadow:0 2px 8px #0000001a;max-height:70vh;max-width:100%}@media (max-width:1024px){.header-ai-btn{font-size:.8rem;min-width:120px;padding:6px 12px}}@media (max-width:768px){.header-buttons-container,.header-nav{align-items:center;flex-direction:column;gap:.5rem}.header-ai-buttons{gap:.5rem;justify-content:center}.header-ai-btn{flex:1 1;font-size:.75rem;max-width:150px;min-width:110px;padding:6px 10px}.back-btn{align-self:flex-start;margin-bottom:.25rem}}@media (max-width:1024px){.compact-header{align-items:stretch;flex-direction:column;gap:.75rem}.header-center,.header-left,.header-right{align-items:center;flex:none;justify-content:center}.header-left{text-align:center}.header-right{justify-content:center}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}}@media (max-width:768px){.compact-header{padding:.5rem}.header-left h2{font-size:1.1rem}.header-subtitle{font-size:.8rem}.compact-btn,.source-info{font-size:.8rem;padding:.4rem .8rem}.image-list-section{margin:.5rem;padding:.5rem}.list-header h2{font-size:1.5rem}.list-header p{font-size:1rem}.images-table{font-size:.8rem}.images-table td,.images-table th{padding:10px 8px}.file-info{align-items:flex-start}.actions,.file-info{flex-direction:column;gap:5px}.actions{display:flex}.open-btn,.view-btn{margin:0;width:100%}.modal-content{margin:1rem;max-height:calc(100vh - 2rem);max-width:calc(100vw - 2rem)}.header-buttons-container,.header-nav{align-items:center;flex-direction:column;gap:.5rem}.folder-picker-section{padding:1rem}.folder-picker-controls{flex-direction:column;gap:.8rem}.clear-folder-btn,.folder-picker-btn,.refresh-server-btn{text-align:center;width:100%}.current-source-info{flex-direction:column;gap:.8rem;text-align:center}}.structured-prescription-data{max-height:80vh;overflow-y:auto;padding:16px}.data-section{background:#fff;border-left:4px solid #007bff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px;padding:16px}.data-section h4{border-bottom:1px solid #eee;color:#2c3e50;font-size:1.1rem;font-weight:600;margin-bottom:12px;padding-bottom:8px}.data-content{color:#495057;font-size:14px;line-height:1.6}.demo-item,.lab-item,.medical-item,.treatment-item{margin-bottom:8px;padding:6px 0}.adverse-event-item,.therapy-item{background:#f8f9fa;border-left:3px solid #28a745;border-radius:6px;margin-bottom:8px;padding:12px}.adverse-event-item{border-left-color:#ffc107}.adverse-events-list,.therapies-list{margin-top:8px}.lab-values{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.lab-item{background:#e8f4f8;border-left:3px solid #17a2b8;border-radius:6px;margin-bottom:8px;padding:12px}.lab-item:last-child{margin-bottom:0}.lab-test-value{background:#f8f9fa;border-left:2px solid #28a745;border-radius:4px;font-size:13px;margin:4px 0;padding:6px 8px}.condition-tag{background:#007bff;border-radius:12px;color:#fff;display:inline-block;font-size:12px;margin-bottom:4px;margin-right:6px;padding:4px 8px}.raw-ocr-content{max-height:80vh;overflow-y:auto;padding:16px}.raw-text-display{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;max-height:70vh;overflow-y:auto;padding:16px}.raw-ocr-text{word-wrap:break-word;background:#0000;border:none;color:#2c3e50;font-family:Courier New,monospace;font-size:14px;line-height:1.5;margin:0;padding:0;white-space:pre-wrap}.raw-text-display::-webkit-scrollbar{width:8px}.raw-text-display::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.raw-text-display::-webkit-scrollbar-thumb{background:#007bff;border-radius:4px}.raw-text-display::-webkit-scrollbar-thumb:hover{background:#0056b3}.score-content{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:8px 0;max-height:80vh;overflow-y:auto;padding:12px}.score-summary{animation:fadeInUp .6s ease-out;overflow:hidden;position:relative}.score-summary:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{left:-100%}to{left:100%}}.score-content h5{border-bottom:3px solid #3498db;color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:24px;padding-bottom:12px;text-align:center}.score-display{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:10px;padding:8px}.score-metrics{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:12px}.score-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:8px;transition:transform .2s ease,box-shadow .2s ease}.score-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.score-card h6{color:#495057;font-size:.9rem;font-weight:600}.score-card h6,.score-value{margin-bottom:6px;text-align:center}.score-value{color:#2c3e50;font-size:1.4rem;font-weight:700}.score-bar{background:#e9ecef;height:12px;overflow:hidden}.score-bar,.score-fill{border-radius:10px;position:relative}.score-fill{height:100%;transition:width .8s ease}.score-card:first-child .score-fill{background:linear-gradient(90deg,#28a745,#20c997)}.score-card:nth-child(2) .score-fill{background:linear-gradient(90deg,#ffc107,#fd7e14)}.score-card:nth-child(3) .score-fill{background:linear-gradient(90deg,#007bff,#6610f2)}.score-details{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:8px}.score-details h6{border-bottom:2px solid #dee2e6;color:#495057;font-size:1rem;font-weight:600;margin-bottom:8px;padding-bottom:4px;text-align:center}.score-details ul{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));list-style:none;margin:0;padding:0}.score-details li{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:2px solid #007bff;border-radius:4px;font-size:11px;font-weight:500;padding:6px 8px;transition:transform .2s ease}.score-details li:hover{transform:translateX(4px)}.detailed-confidence{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:10px;margin-top:16px;padding:12px}.detailed-confidence h6{color:#495057;font-size:1.1rem;font-weight:600;margin-bottom:16px;text-align:center}.confidence-breakdown{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.confidence-section{background:#fff;border-left:3px solid #007bff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:10px}.confidence-section h7{color:#495057;display:block;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.confidence-list{display:flex;flex-wrap:wrap;gap:8px}.low-confidence-word{background:linear-gradient(135deg,#ffe6e6,#fcc);border:1px solid #f5c6cb;border-radius:20px;color:#d63384;font-size:12px;font-weight:500;padding:6px 12px;transition:transform .2s ease}.low-confidence-word:hover{transform:scale(1.05)}.high-confidence-word{background:linear-gradient(135deg,#e6ffe6,#cfc);border:1px solid #c3e6cb;border-radius:20px;color:#198754;font-size:12px;font-weight:500;padding:6px 12px;transition:transform .2s ease}.high-confidence-word:hover{transform:scale(1.05)}.no-high-confidence,.no-low-confidence{background:#f8f9fa;border-radius:6px;color:#6c757d;font-size:12px;font-style:italic;padding:8px;text-align:center;width:100%}.quality-excellent{color:#198754;font-weight:700}.quality-good{color:#0d6efd;font-weight:700}.quality-fair{color:#fd7e14;font-weight:700}.quality-poor{color:#dc3545;font-weight:700}@media (max-width:768px){.score-metrics{gap:16px}.confidence-breakdown,.score-details ul,.score-metrics{grid-template-columns:1fr}.score-card,.score-content{padding:16px}.score-value{font-size:1.8rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}}.llm-analysis-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-height:80vh;overflow-y:auto;padding:20px}.placeholder-text{color:#6b7280;padding:40px 20px;text-align:center}.placeholder-text h4{color:#374151;margin-bottom:16px}.placeholder-text p{line-height:1.6;margin-bottom:12px}.placeholder-text small{font-size:.9em;opacity:.7}.llm-analysis-content .analysis-text{color:#2d3748;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:14px;line-height:1.6}.llm-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;overflow:hidden}.llm-section h6{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0;padding:16px 20px;text-transform:uppercase}.llm-data{padding:0}.llm-status{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d;margin-bottom:20px}.llm-error,.llm-status{border-radius:12px;color:#fff;padding:16px;text-align:center}.llm-error{background:linear-gradient(135deg,#f56565,#e53e3e);box-shadow:0 4px 12px #f565654d}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.4822ee71.css.map*/