.login-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.login-modal{animation:slideUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:420px;overflow:hidden;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{background:linear-gradient(135deg,#06c,#0052a3);color:#fff;padding:2.5rem 2rem 2rem;text-align:center}.login-icon{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:50%;display:flex;height:64px;justify-content:center;margin:0 auto 1rem;width:64px}.login-header h2{font-size:1.5rem;font-weight:700;letter-spacing:-.025em;margin:0 0 .5rem}.login-subtitle{font-size:.9375rem;margin:0;opacity:.9}.login-form{padding:2rem}.login-error{align-items:center;animation:shake .4s ease-out;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;font-size:.875rem;gap:.5rem;margin-bottom:1.5rem;padding:.875rem 1rem}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.form-group{margin-bottom:1.5rem}.form-group label{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.form-group input{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.form-group input:focus{border-color:#06c;box-shadow:0 0 0 3px #0066cc1a;outline:none}.form-group input:disabled{background:#f9fafb;cursor:not-allowed}.form-group input::placeholder{color:#9ca3af}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:3rem}.password-toggle{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .2s ease}.password-toggle:hover{color:#06c}.login-button{align-items:center;background:linear-gradient(135deg,#06c,#0052a3);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:2rem;padding:1rem;transition:all .2s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 8px 16px #0066cc4d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.login-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:1.5rem 2rem;text-align:center}.login-footer p{align-items:center;color:#6b7280;display:flex;font-size:.8125rem;gap:.25rem;justify-content:center;margin:0}.login-footer p:before{content:"🔒";font-size:1rem}@media (max-width:480px){.login-modal{border-radius:0;max-width:100%;min-height:100vh;width:100%}.login-header{padding:3rem 1.5rem 2rem}.login-footer,.login-form{padding:1.5rem}}:root{--medical-primary:#06c;--medical-primary-light:#3385db;--medical-primary-dark:#004c99;--medical-secondary:#00a896;--medical-accent:#f0f4f8;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--error:#ef4444;--error-light:#fee2e2;--white:#fff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--font-primary:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Courier New",monospace;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--transition-fast:150ms ease-in-out;--transition-base:200ms ease-in-out;--transition-slow:300ms ease-in-out}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f9fafb;background:var(--gray-50);color:#111827;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-primary);line-height:1.6}.app{background:linear-gradient(180deg,#f9fafb 0,#fff);background:linear-gradient(to bottom,var(--gray-50) 0,var(--white) 100%);display:flex;flex-direction:column;min-height:100vh}.app-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff;background:var(--white);background:#fffffff2;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);padding:1.25rem 1rem;padding:1.25rem var(--spacing-md);position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{margin:0 auto;max-width:1200px}.header-main{justify-content:space-between;margin-bottom:.5rem}.header-main,.header-right{align-items:center;display:flex}.header-right{gap:1rem;gap:var(--spacing-md)}.app-header h1{align-items:center;color:#111827;color:var(--gray-900);display:flex;font-size:1.75rem;font-weight:700;gap:.5rem;gap:var(--spacing-sm);letter-spacing:-.025em;margin:0}.icon{color:#06c;color:var(--medical-primary)}.icon,.logout-button{align-items:center;display:flex;justify-content:center}.logout-button{background:#fff;background:var(--white);border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-md);color:#374151;color:var(--gray-700);cursor:pointer;height:36px;transition:all .2s ease-in-out;transition:all var(--transition-base);width:36px}.logout-button:hover{background:#fee2e2;background:var(--error-light);border-color:#ef4444;border-color:var(--error);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#ef4444;color:var(--error);transform:translateY(-1px)}.subtitle{color:#4b5563;color:var(--gray-600);font-size:.9375rem;font-weight:400;margin:0}.server-status{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:.8125rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);padding:.375rem .75rem;transition:all .2s ease-in-out;transition:all var(--transition-base);white-space:nowrap}.server-status.checking{background:#f3f4f6;background:var(--gray-100);color:#374151;color:var(--gray-700)}.server-status.online{background:#d1fae5;background:var(--success-light);color:#10b981;color:var(--success)}.server-status.offline{background:#fee2e2;background:var(--error-light);color:#ef4444;color:var(--error)}.status-indicator{height:16px;width:16px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.server-status.checking .status-indicator{animation:spin 1s linear infinite}.app-main{flex:1 1;padding:3rem 1rem;padding:var(--spacing-2xl) var(--spacing-md)}.container{margin:0 auto;max-width:1200px}.upload-zone{background:#fff;background:var(--white);border:2px dashed #d1d5db;border:2px dashed var(--gray-300);border-radius:1rem;border-radius:var(--radius-xl);cursor:pointer;padding:4rem 2rem;padding:var(--spacing-3xl) var(--spacing-xl);position:relative;text-align:center;transition:all .2s ease-in-out;transition:all var(--transition-base)}.upload-zone:hover:not(.disabled){border-color:#06c;border-color:var(--medical-primary);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.upload-zone.dragging{background:#0066cc0d;border-color:#06c;border-color:var(--medical-primary);transform:scale(1.01)}.upload-zone.disabled{cursor:not-allowed;opacity:.5}.upload-icon{color:#06c;color:var(--medical-primary);filter:drop-shadow(0 2px 4px rgba(0,102,204,.1));margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.upload-icon svg{stroke-width:1.5;height:64px;width:64px}.upload-zone h3{color:#111827;color:var(--gray-900);font-size:1.5rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.upload-zone p{color:#4b5563;color:var(--gray-600);font-size:.9375rem;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.upload-button{align-items:center;background:#06c;background:var(--medical-primary);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#fff;color:var(--white);cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);justify-content:center;padding:.875rem 2rem;transition:all .2s ease-in-out;transition:all var(--transition-base)}.upload-button:hover:not(.disabled){background:#004c99;background:var(--medical-primary-dark);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.upload-button:active:not(.disabled){transform:translateY(0)}.upload-button.disabled{cursor:not-allowed;opacity:.5}.upload-hint{color:#6b7280;color:var(--gray-500);font-size:.8125rem;line-height:1.5;margin-top:1.5rem;margin-top:var(--spacing-lg)}.preview-section{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}.image-preview{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:1.5rem;padding:var(--spacing-lg);transition:all .2s ease-in-out;transition:all var(--transition-base)}.image-preview:hover{box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.preview-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--spacing-md);padding-bottom:1rem;padding-bottom:var(--spacing-md)}.preview-header h3{color:#111827;color:var(--gray-900);font-size:1.125rem;font-weight:600}.remove-button{align-items:center;background:#ef4444;background:var(--error);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--white);cursor:pointer;display:flex;font-size:1.25rem;height:36px;justify-content:center;transition:all .2s ease-in-out;transition:all var(--transition-base);width:36px}.remove-button:hover{background:#dc2626;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:scale(1.05)}.preview-container{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);margin-bottom:1rem;margin-bottom:var(--spacing-md);max-height:500px;overflow:hidden}.preview-container img{display:block;height:auto;width:100%}.file-info{grid-gap:.5rem;grid-gap:var(--spacing-sm);background:#f9fafb;background:var(--gray-50);border-radius:.5rem;border-radius:var(--radius-md);color:#4b5563;color:var(--gray-600);display:grid;font-size:.875rem;gap:.5rem;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:1rem;padding:var(--spacing-md)}.file-info p{margin:0}.file-info strong{color:#374151;color:var(--gray-700);font-weight:600}.analyze-button{align-items:center;background:#00a896;background:var(--medical-secondary);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#fff;color:var(--white);cursor:pointer;display:flex;font-size:1.0625rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);justify-content:center;padding:1.125rem 2rem;transition:all .2s ease-in-out;transition:all var(--transition-base);width:100%}.analyze-button:hover:not(:disabled){background:#008f7a;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.analyze-button:disabled{cursor:not-allowed;opacity:.5}.analyzing-section{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:4rem;padding:var(--spacing-3xl)}.loading-spinner{text-align:center}.spinner{color:#06c;color:var(--medical-primary);height:64px;margin:0 auto 2rem;margin:0 auto var(--spacing-xl);width:64px}.spinner svg{animation:spin 1s linear infinite;height:100%;width:100%}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.loading-message{color:#374151;color:var(--gray-700);font-size:1.125rem;font-weight:500;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.progress-bar{background:#e5e7eb;background:var(--gray-200);height:12px;margin:1.5rem 0;margin:var(--spacing-lg) 0;overflow:hidden;position:relative;width:100%}.progress-bar,.progress-fill{border-radius:9999px;border-radius:var(--radius-full)}.progress-fill{background:linear-gradient(90deg,#06c,#00a896);background:linear-gradient(90deg,var(--medical-primary) 0,var(--medical-secondary) 100%);height:100%;transition:width .3s ease-in-out;transition:width var(--transition-slow)}.progress-text{color:#374151;color:var(--gray-700);font-size:.75rem;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.analysis-steps{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(4,1fr);margin-top:3rem;margin-top:var(--spacing-2xl)}.step{align-items:center;background:#f3f4f6;background:var(--gray-100);border-radius:.75rem;border-radius:var(--radius-lg);color:#9ca3af;color:var(--gray-400);display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);padding:1.5rem 1rem;padding:var(--spacing-lg) var(--spacing-md);position:relative;text-align:center;transition:all .2s ease-in-out;transition:all var(--transition-base)}.step span:last-child{font-size:.875rem;font-weight:500}.step.active{background:#0066cc1a;box-shadow:0 0 0 2px #06c;box-shadow:0 0 0 2px var(--medical-primary);color:#06c;color:var(--medical-primary)}.step.completed{background:#d1fae5;background:var(--success-light);color:#10b981;color:var(--success)}.step-number{align-items:center;background:currentColor;border-radius:9999px;border-radius:var(--radius-full);display:flex;font-size:1rem;font-weight:700;height:48px;justify-content:center;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);width:48px}.step-number,.step-number svg{color:#fff;color:var(--white)}.checkmark{color:#10b981;color:var(--success);position:absolute;right:.25rem;right:var(--spacing-xs);top:.25rem;top:var(--spacing-xs)}.result-display{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:3rem;padding:var(--spacing-2xl)}.result-header{align-items:center;border-bottom:2px solid #f3f4f6;border-bottom:2px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);justify-content:space-between;margin-bottom:3rem;margin-bottom:var(--spacing-2xl);padding-bottom:2rem;padding-bottom:var(--spacing-xl)}.result-header h2{align-items:center;color:#111827;color:var(--gray-900);display:flex;font-size:1.5rem;font-weight:700;gap:.5rem;gap:var(--spacing-sm);letter-spacing:-.025em;margin:0}.confidence-badge{border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--white);font-size:.9375rem;font-weight:700;letter-spacing:.025em;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg)}.result-info-compact{grid-gap:1rem;grid-gap:var(--spacing-md);background:#f9fafb;background:var(--gray-50);border-radius:.75rem;border-radius:var(--radius-lg);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr);margin-bottom:2rem;margin-bottom:var(--spacing-xl);padding:1.5rem;padding:var(--spacing-lg)}.info-row{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);padding:1rem;padding:var(--spacing-md);transition:all .2s ease-in-out;transition:all var(--transition-base)}.info-row:hover{border-color:#06c;border-color:var(--medical-primary);box-shadow:0 2px 4px #0066cc1a;transform:translateY(-1px)}.info-label{align-items:center;color:#6b7280;color:var(--gray-500);display:flex;font-size:.75rem;font-weight:600;gap:.25rem;gap:var(--spacing-xs);letter-spacing:.05em;text-transform:uppercase}.info-value{color:#111827;color:var(--gray-900);font-size:1rem;font-weight:600;word-break:break-word}.result-sections{display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-xl);margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.result-section{background:#f9fafb;background:var(--gray-50);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);padding:2rem;padding:var(--spacing-xl);transition:all .2s ease-in-out;transition:all var(--transition-base)}.result-section:hover{box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md)}.result-section h3{align-items:center;color:#111827;color:var(--gray-900);display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.result-section h3 svg{stroke-width:2;height:1.5rem;width:1.5rem}.info-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);padding:1rem;padding:var(--spacing-md)}.label{color:#6b7280;color:var(--gray-500);font-size:.8125rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.value{color:#111827;color:var(--gray-900);font-size:1rem;font-weight:500}.medications-list{flex-direction:column}.medication-card,.medications-list{display:flex;gap:1rem;gap:var(--spacing-md)}.medication-card{background:#fff;background:var(--white);border:1px solid #e5e7eb;border-left:4px solid #06c;border:1px solid var(--gray-200);border-left:4px solid var(--medical-primary);border-radius:.75rem;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--spacing-lg);transition:all .2s ease-in-out;transition:all var(--transition-base)}.medication-card:hover{box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateX(4px)}.med-number{align-items:center;background:#06c;background:var(--medical-primary);border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--white);display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;width:40px}.med-details{flex:1 1}.med-name{color:#111827;color:var(--gray-900);font-size:1.0625rem;font-weight:600;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.med-info{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm)}.med-tag{background:#f3f4f6;background:var(--gray-100);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-md);color:#374151;color:var(--gray-700);font-size:.8125rem;font-weight:500;padding:.375rem .875rem}.no-data{background:#fff;background:var(--white);border-radius:.5rem;border-radius:var(--radius-md);color:#9ca3af;color:var(--gray-400);font-style:italic;padding:1.5rem;padding:var(--spacing-lg);text-align:center}.result-actions{display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md)}.analyze-button,.download-button,.retry-button,.secondary-button{svg{stroke-width:2;height:1.25rem;width:1.25rem}}.download-button{align-items:center;background:#06c;background:var(--medical-primary);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#fff;color:var(--white);cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:.5rem;gap:var(--spacing-sm);justify-content:center;min-width:200px;padding:1.125rem 2rem;transition:all .2s ease-in-out;transition:all var(--transition-base)}.download-button:hover{background:#004c99;background:var(--medical-primary-dark);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.secondary-button{background:#fff;background:var(--white);border:2px solid #06c;border:2px solid var(--medical-primary);border-radius:.75rem;border-radius:var(--radius-lg);color:#06c;color:var(--medical-primary);cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;min-width:200px;padding:1.125rem 2rem;transition:all .2s ease-in-out;transition:all var(--transition-base)}.secondary-button:hover{background:#f9fafb;background:var(--gray-50);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.multi-preview-grid{-webkit-overflow-scrolling:touch;display:flex;gap:1rem;gap:var(--spacing-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);overflow-x:auto;padding-bottom:1rem;padding-bottom:var(--spacing-md);scroll-snap-type:x mandatory}.multi-preview-grid::-webkit-scrollbar{height:8px}.multi-preview-grid::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100);border-radius:9999px;border-radius:var(--radius-full)}.multi-preview-grid::-webkit-scrollbar-thumb{background:#9ca3af;background:var(--gray-400);border-radius:9999px;border-radius:var(--radius-full)}.multi-preview-grid::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--gray-500)}.multi-preview-grid .image-preview{flex:0 0 calc(33.333% - 1rem);flex:0 0 calc(33.333% - var(--spacing-md));margin:0;max-width:400px;min-width:280px;scroll-snap-align:start}.multi-preview-grid .preview-container{max-height:250px}.preview-actions{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md)}.file-count{background:#f3f4f6;background:var(--gray-100);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);color:#374151;color:var(--gray-700);font-size:1.125rem;font-weight:600;padding:1rem;padding:var(--spacing-md);text-align:center}.summary-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.summary-card,.summary-grid{gap:1rem;gap:var(--spacing-md)}.summary-card{align-items:center;background:#fff;background:var(--white);border:1px solid #e5e7eb;border-left:4px solid #06c;border:1px solid var(--gray-200);border-left:4px solid var(--medical-primary);border-radius:.75rem;border-radius:var(--radius-lg);display:flex;padding:2rem;padding:var(--spacing-xl);transition:all .2s ease-in-out;transition:all var(--transition-base)}.summary-card:hover{box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.summary-card.success{background:#d1fae5;background:var(--success-light);border-left-color:#10b981;border-left-color:var(--success)}.summary-card.error{background:#fee2e2;background:var(--error-light);border-left-color:#ef4444;border-left-color:var(--error)}.summary-icon{flex-shrink:0;font-size:2rem}.summary-content{flex:1 1}.summary-value{color:#111827;color:var(--gray-900);font-size:2rem;font-weight:700;line-height:1}.summary-label{color:#4b5563;color:var(--gray-600);font-size:.8125rem;font-weight:500;margin-top:.25rem;margin-top:var(--spacing-xs)}.file-list{flex-direction:column}.file-item,.file-list{display:flex;gap:1rem;gap:var(--spacing-md)}.file-item{align-items:flex-start;background:#fff;background:var(--white);border:1px solid #e5e7eb;border-left:4px solid #d1d5db;border:1px solid var(--gray-200);border-left:4px solid var(--gray-300);border-radius:.75rem;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--spacing-lg);transition:all .2s ease-in-out;transition:all var(--transition-base)}.file-item:hover{box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md)}.file-item.success{background:#d1fae5;background:var(--success-light);border-left-color:#10b981;border-left-color:var(--success)}.file-item.error{background:#fee2e2;background:var(--error-light);border-left-color:#ef4444;border-left-color:var(--error)}.file-item-icon{align-items:center;background:#fff;background:var(--white);border:2px solid;border-radius:9999px;border-radius:var(--radius-full);display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;width:40px}.file-item.success .file-item-icon{background:#fff;background:var(--white);color:#10b981;color:var(--success)}.file-item.error .file-item-icon{background:#fff;background:var(--white);color:#ef4444;color:var(--error)}.file-item-content{flex:1 1}.file-item-name{color:#111827;color:var(--gray-900);font-size:1rem;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.file-item-details{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm);margin-top:.5rem;margin-top:var(--spacing-sm)}.file-detail{background:#fff;background:var(--white);border-radius:.375rem;border-radius:var(--radius-sm);color:#4b5563;color:var(--gray-600);padding:.25rem .625rem}.file-detail,.file-item-error{font-size:.8125rem;font-weight:500}.file-item-error{color:#ef4444;color:var(--error);margin-top:.25rem;margin-top:var(--spacing-xs)}.error-section{background:#fff;background:var(--white);border:1px solid #fee2e2;border:1px solid var(--error-light);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:4rem;padding:var(--spacing-3xl);text-align:center}.error-icon{color:#ef4444;color:var(--error);filter:drop-shadow(0 2px 4px rgba(239,68,68,.2));height:4rem;margin:0 auto 1.5rem;margin:0 auto var(--spacing-lg);width:4rem}.error-icon svg{stroke-width:1.5;height:100%;width:100%}.error-section h2{color:#ef4444;color:var(--error);font-weight:600;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.error-message{color:#4b5563;color:var(--gray-600);font-size:1.0625rem;line-height:1.6;margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.retry-button{background:#06c;background:var(--medical-primary);border:none;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#fff;color:var(--white);cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .2s ease-in-out;transition:all var(--transition-base)}.retry-button:hover{background:#004c99;background:var(--medical-primary-dark);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.app-footer{background:#fff;background:var(--white);border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);color:#6b7280;color:var(--gray-500);font-size:.875rem;padding:2rem;padding:var(--spacing-xl);text-align:center}@media (max-width:768px){.app-header h1{font-size:1.25rem}.icon svg{height:24px;width:24px}.subtitle{font-size:.8125rem}.header-main{align-items:flex-start;flex-direction:column;gap:.75rem}.header-right{align-self:flex-end}.result-info-compact{grid-template-columns:repeat(2,1fr)}.upload-zone{padding:3rem 1rem;padding:var(--spacing-2xl) var(--spacing-md)}.analysis-steps{gap:.5rem;gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr)}.step{padding:1rem .5rem;padding:var(--spacing-md) var(--spacing-sm)}.step-number{height:40px;width:40px}.result-header{align-items:flex-start}.result-actions,.result-header{flex-direction:column}.download-button,.secondary-button{width:100%}.multi-preview-grid .image-preview{flex:0 0 calc(50% - 0.5rem);flex:0 0 calc(50% - var(--spacing-sm));min-width:250px}.summary-grid{grid-template-columns:repeat(2,1fr)}.file-item{flex-direction:column}.info-grid{grid-template-columns:1fr}}@media (max-width:480px){.app-header h1{font-size:1.25rem}.result-info-compact{grid-template-columns:1fr}.multi-preview-grid .image-preview{flex:0 0 calc(80% - 0.5rem);flex:0 0 calc(80% - var(--spacing-sm));min-width:240px}.analysis-steps{gap:.5rem;gap:var(--spacing-sm)}.step{flex-direction:row;justify-content:flex-start;padding:1rem;padding:var(--spacing-md);text-align:left}.step-number{flex-shrink:0;height:36px;width:36px}.analysis-steps,.summary-grid{grid-template-columns:1fr}}.text-center{text-align:center}.hidden{display:none}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.icon-inline{display:inline-block;margin-right:4px;vertical-align:middle}.icon-success{color:#10b981;color:var(--success)}.icon-error{color:#ef4444;color:var(--error)}.icon-warning{color:#f59e0b;color:var(--warning)}.icon-primary{color:#06c;color:var(--medical-primary)}
/*# sourceMappingURL=main.d6c6b2c0.css.map*/