:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;margin:0;padding:0;overflow-x:hidden}body{font-family:inherit;line-height:inherit;color:inherit}#root{width:100%;min-height:100vh;margin:0;padding:0}button{font-family:inherit}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}.login-container-cd{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5}.login-form-cd{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.logo-cd,.login-form-cd h2{text-align:center;margin-bottom:1.5rem;color:#333}.form-group-cd{margin-bottom:1rem}.form-group-cd label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group-cd input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s}.form-group-cd input:focus{outline:none;border-color:#007bff}.error-message-cd{color:#dc3545;font-size:.875rem;margin-bottom:1rem;text-align:center}.btn-login-cd{width:100%;padding:.75rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .3s}.btn-login-cd:hover:not(:disabled){background-color:#0056b3}.btn-login-cd:disabled{background-color:#6c757d;cursor:not-allowed}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#0f2794,#4d118a);color:#333;overflow-x:hidden;margin:0;padding:0}#root{min-height:100vh;width:100%;overflow-x:hidden}.app{min-height:100vh;width:100%;box-sizing:border-box}:root{--primary-color: #4f46e5;--primary-hover: #3730a3;--secondary-color: #6b7280;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--background-light: #ffffff;--background-gray: #f9fafb;--border-color: #e5e7eb;--text-primary: #111827;--text-secondary: #6b7280;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--border-radius: 8px;--border-radius-lg: 12px}.patient-list-container,.patient-detail-container,.biometric-capture-container{width:100%;max-width:1200px;margin:0 auto;background:var(--background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.page-header,.detail-header,.capture-header{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%);color:#fff;padding:20px;width:100%;box-sizing:border-box}.header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;flex-wrap:wrap;gap:15px;width:100%}.header-content h1{display:flex;align-items:center;gap:12px;font-size:1.8rem;font-weight:700;margin:0}.page-icon{opacity:.9;flex-shrink:0}.date-info{display:flex;align-items:center;gap:8px;font-size:.9rem;opacity:.9;white-space:nowrap}.stats{display:flex;gap:15px;flex-wrap:wrap}.stat-item{background:#ffffff26;padding:6px 12px;border-radius:var(--border-radius);font-size:.85rem;font-weight:500;white-space:nowrap}.page-content{width:100%;box-sizing:border-box}.datatable-container{padding:25px;width:100%}.datatable-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:15px;flex-wrap:wrap}.search-container{position:relative;flex:1;min-width:250px;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-input{width:100%;padding:12px 12px 12px 45px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;transition:all .2s ease}.refresh-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.refresh-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.refresh-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.datatable-wrapper{border:1px solid var(--border-color);border-radius:var(--border-radius);background:#fff;width:100%;overflow-x:auto}.datatable{width:100%;min-width:600px;border-collapse:collapse}.datatable thead{background:var(--background-gray)}.datatable th{text-align:left;padding:16px 20px;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.datatable-row:hover{background:var(--background-gray);transform:scale(1.01)}.datatable-row:active{transform:scale(.99)}.datatable td{padding:16px 20px;border-bottom:1px solid var(--border-color)}.status-badge{padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:500;text-transform:capitalize}.status-badge.completado{background:#dcfce7;color:#166534}.status-badge.pendiente{background:#fef3c7;color:#92400e}.loading-cell,.no-data-cell{text-align:center;padding:40px 20px;color:var(--text-secondary)}.loading-spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;display:inline-block;margin-right:10px}.datatable-footer{padding:15px 20px;background:var(--background-gray);border-top:1px solid var(--border-color);text-align:center}.records-count{color:var(--text-secondary);font-size:.9rem}.detail-header{display:flex;align-items:flex-start;gap:20px}.back-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;text-decoration:none;font-weight:500}.back-button:hover{background:#ffffff40;transform:translateY(-1px)}.patient-info{flex:1}.patient-basic-info{display:flex;align-items:center;gap:15px;margin-bottom:20px}.patient-icon{background:#ffffff26;padding:12px;border-radius:var(--border-radius)}.patient-details h1{font-size:1.8rem;margin-bottom:8px}.patient-meta{display:flex;gap:20px;opacity:.9}.completion-status{background:#ffffff26;padding:15px 20px;border-radius:var(--border-radius)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:500}.percentage{font-size:1.1rem}.progress-bar{height:8px;background:#fff3;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--success-color);transition:width .3s ease}.detail-content{padding:30px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid var(--border-color)}.header-actions{display:flex;gap:10px;align-items:center}.clear-all-button{background:var(--error-color);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500}.clear-all-button:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.clear-all-button:disabled{background:var(--secondary-color);cursor:not-allowed;transform:none}.section-header h2{font-size:1.5rem;color:var(--text-primary)}.edit-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease}.edit-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.biometric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px}.biometric-card{border:2px solid var(--border-color);border-radius:var(--border-radius-lg);padding:20px;background:#fff;transition:all .2s ease}.biometric-card.has-data{border-color:var(--success-color);background:linear-gradient(135deg,#f0fdf4,#fff)}.biometric-card.no-data{border-color:var(--border-color);background:var(--background-gray)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.card-title{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--text-primary)}.success-indicator{color:var(--success-color)}.card-content{margin-bottom:15px;min-height:120px;display:flex;align-items:center;justify-content:center}.biometric-display{text-align:center}.biometric-image{max-width:100%;max-height:100px;border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.no-data-display{text-align:center;color:var(--text-secondary)}.no-data-icon{margin-bottom:10px;opacity:.5}.card-description{color:var(--text-secondary);font-size:.9rem}.capture-container{max-width:800px;margin:0 auto;padding:30px}.capture-header{text-align:center;margin-bottom:30px}.capture-header h2{display:flex;align-items:center;justify-content:center;gap:12px;font-size:1.8rem;color:var(--text-primary);margin-bottom:10px}.capture-icon{color:var(--primary-color)}.capture-subtitle{color:var(--text-secondary);font-size:1.1rem}.capture-content{background:#fff;border-radius:var(--border-radius-lg);padding:30px;box-shadow:var(--shadow-md);margin-bottom:30px}.fingerprint-display{text-align:center;margin-bottom:25px}.fingerprint-image-container{position:relative;display:inline-block;background:var(--background-gray);border-radius:var(--border-radius);padding:20px;min-width:200px;min-height:200px;display:flex;align-items:center;justify-content:center}.fingerprint-image{max-width:100%;max-height:160px;border-radius:var(--border-radius)}.fingerprint-overlay{position:absolute;top:10px;right:10px;background:var(--success-color);color:#fff;padding:8px;border-radius:50%}.fingerprint-placeholder{background:var(--background-gray);border:2px dashed var(--border-color);border-radius:var(--border-radius);padding:40px;text-align:center;color:var(--text-secondary)}.placeholder-icon{margin-bottom:15px;opacity:.5}.signature-display{margin-bottom:25px}.signature-container{border:2px solid var(--border-color);border-radius:var(--border-radius);background:#fff;min-height:120px;display:flex;align-items:center;justify-content:center}.signature-canvas{border:none;background:#fff;border-radius:var(--border-radius)}.signature-image-container{padding:10px}.signature-image{max-width:100%;height:auto;border:1px solid var(--border-color);border-radius:var(--border-radius);background:#fff}.signature-image-container{padding:10px;display:flex;justify-content:center;align-items:center;min-height:120px}.device-selector{margin-bottom:20px}.device-selector label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.device-select{width:100%;padding:10px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem}.photo-display{margin-bottom:25px}.photo-container,.camera-container{border:2px solid var(--border-color);border-radius:var(--border-radius);background:var(--background-gray);min-height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden}.captured-photo,.camera-video{max-width:100%;max-height:100%;border-radius:var(--border-radius)}.camera-placeholder{text-align:center;color:var(--text-secondary)}.status-section{margin-bottom:25px}.status-indicator{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--border-radius);font-weight:500;margin-bottom:15px}.status-indicator.disconnected{background:#fef2f2;color:#991b1b}.status-indicator.connected{background:#f0fdf4;color:#166534}.status-indicator.capturing{background:#fef3c7;color:#92400e}.status-indicator.captured{background:#f0fdf4;color:#166534}.status-indicator.idle{background:var(--background-gray);color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.control-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.primary-button,.secondary-button{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;min-width:140px;justify-content:center}.primary-button{background:var(--primary-color);color:#fff}.primary-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.primary-button:disabled{background:var(--secondary-color);cursor:not-allowed;transform:none}.secondary-button{background:var(--background-gray);color:var(--text-primary);border:2px solid var(--border-color)}.secondary-button:hover{background:var(--border-color);transform:translateY(-1px)}.secondary-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.navigation-buttons{display:flex;justify-content:space-between;gap:20px}.next-button{background:var(--success-color);color:#fff;border:none;padding:12px 24px;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.next-button:hover{background:#059669;transform:translateY(-1px)}.next-button:disabled{background:var(--secondary-color);cursor:not-allowed;transform:none}.save-button{background:var(--success-color);color:#fff;border:none;padding:14px 28px;border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.save-button:hover{background:#059669;transform:translateY(-1px)}.save-button:disabled{background:var(--secondary-color);cursor:not-allowed;transform:none}.step-indicator{display:flex;justify-content:center;align-items:center;margin:30px 0;padding:20px;background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm)}.step-item{display:flex;flex-direction:column;align-items:center;position:relative}.step-circle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;margin-bottom:8px;transition:all .2s ease}.step-circle.active{background:var(--primary-color);color:#fff;transform:scale(1.1)}.step-circle.completed{background:var(--success-color);color:#fff}.step-circle:not(.active):not(.completed){background:var(--background-gray);border:2px solid var(--border-color);color:var(--text-secondary)}.step-name{font-size:.9rem;font-weight:500;text-align:center;color:var(--text-secondary)}.step-connector{position:absolute;top:20px;left:100%;width:60px;height:2px;background:var(--border-color);transition:all .2s ease}.step-connector.completed{background:var(--success-color)}.confirmation-container{max-width:900px;margin:0 auto;padding:30px}.confirmation-header{text-align:center;margin-bottom:30px}.confirmation-icon{color:var(--success-color)}.confirmation-content{background:#fff;border-radius:var(--border-radius-lg);padding:30px;box-shadow:var(--shadow-md);margin-bottom:30px}.patient-info h3{margin-bottom:15px;color:var(--text-primary)}.patient-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item label{font-weight:500;color:var(--text-secondary);font-size:.9rem}.detail-item span{font-weight:600;color:var(--text-primary)}.biometric-previews h3{margin-bottom:20px;color:var(--text-primary)}.previews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:25px}.biometric-preview{border:2px solid var(--border-color);border-radius:var(--border-radius);padding:15px;background:var(--background-gray)}.biometric-preview.captured{border-color:var(--success-color);background:linear-gradient(135deg,#f0fdf4,#fff)}.biometric-preview.missing{border-color:var(--error-color);background:#fef2f2}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-weight:500}.preview-header>div:first-child{display:flex;align-items:center;gap:8px}.success-icon{color:var(--success-color)}.preview-content{min-height:80px;display:flex;align-items:center;justify-content:center}.biometric-image{max-width:100%;max-height:70px;border-radius:var(--border-radius)}.missing-text{color:var(--error-color);font-style:italic}.confirmation-checkbox{margin:25px 0}.checkbox-container{display:flex;align-items:flex-start;gap:12px;cursor:pointer}.checkbox-container input[type=checkbox]{display:none}.checkmark{width:20px;height:20px;border:2px solid var(--border-color);border-radius:4px;background:#fff;position:relative;transition:all .2s ease;flex-shrink:0;margin-top:2px}.checkbox-container input[type=checkbox]:checked+.checkmark{background:var(--primary-color);border-color:var(--primary-color)}.checkbox-container input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:14px}.checkbox-text{line-height:1.5;color:var(--text-primary)}.error-message,.warning-message{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:var(--border-radius);margin-bottom:15px}.error-message{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.warning-message{background:#fffbeb;color:#92400e;border:1px solid #fed7aa}.error-banner{background:#fef2f2;color:#991b1b;padding:15px 20px;margin:0 30px 20px;border-radius:var(--border-radius);display:flex;justify-content:space-between;align-items:center}.retry-button{background:var(--error-color);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius);cursor:pointer;font-size:.9rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary)}.loading-container .loading-spinner{width:40px;height:40px;margin-bottom:20px}.error-container{display:flex;align-items:center;justify-content:center;min-height:400px;padding:40px}.error-content{text-align:center;max-width:500px}.error-content h2{color:var(--error-color);margin-bottom:15px;font-size:1.5rem}.error-content p{color:var(--text-secondary);margin-bottom:25px;line-height:1.6}.empty-state,.no-data-message{text-align:center;padding:60px 40px;color:var(--text-secondary)}.empty-icon,.message-icon{margin-bottom:20px;opacity:.5}.empty-state h3,.no-data-message h3{color:var(--text-primary);margin-bottom:10px;font-size:1.3rem}.empty-state p,.no-data-message p{margin-bottom:25px;line-height:1.6}.message-content{max-width:400px;margin:0 auto}@media (max-width: 1300px){.patient-list-container,.patient-detail-container,.biometric-capture-container{max-width:calc(100vw - 20px);margin:0 10px}}@media (max-width: 768px){.app{padding:5px}.patient-list-container,.patient-detail-container,.biometric-capture-container{max-width:calc(100vw - 10px);margin:0 5px}.page-header,.detail-header,.capture-header{padding:15px}.header-content{flex-direction:column;gap:10px;align-items:flex-start}.header-content h1{font-size:1.5rem}.date-info{align-self:flex-start}.stats{justify-content:flex-start;gap:10px}.datatable-container,.detail-content,.capture-container{padding:15px}.datatable-header{flex-direction:column;gap:15px;align-items:stretch}.search-container{max-width:none;min-width:auto}.refresh-button{align-self:center}.biometric-grid,.previews-grid{grid-template-columns:1fr}.detail-header{flex-direction:column;gap:15px}.patient-basic-info{flex-direction:column;text-align:center;gap:10px}.section-header{flex-direction:column;gap:15px;text-align:center}.control-buttons,.navigation-buttons{flex-direction:column}.step-indicator{padding:15px;overflow-x:auto}.step-connector{display:none}.patient-details{grid-template-columns:1fr}.datatable{min-width:500px}.datatable th,.datatable td{padding:10px 8px;font-size:.9rem}}@media (max-width: 480px){.app{padding:0}.patient-list-container,.patient-detail-container,.biometric-capture-container{margin:0;border-radius:0;max-width:100vw;width:100vw}.datatable-container{padding:10px}.datatable th,.datatable td{padding:8px 6px;font-size:.85rem}.capture-container,.capture-content{padding:15px}.header-content h1{font-size:1.3rem}.datatable{min-width:450px}.stats{flex-direction:column;gap:8px}.stat-item{text-align:center}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.patient-list-container,.patient-detail-container,.biometric-capture-container{animation:fadeIn .3s ease-out}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.refresh-icon.spinning{animation:none}}.capture-interface{padding:20px;background:var(--background-light);border-radius:var(--border-radius);margin-top:15px}.preview-container{display:flex;flex-direction:column;align-items:center;gap:15px}.capture-preview{max-width:100%;max-height:200px;border-radius:var(--border-radius);border:2px solid var(--border-color);object-fit:contain}.capture-controls{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap}.capture-btn{background:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;min-width:120px;justify-content:center}.capture-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.capture-btn:disabled{background:var(--secondary-color);cursor:not-allowed;transform:none}.restart-btn{background:var(--warning-color);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.restart-btn:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.save-btn{background:var(--success-color);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.save-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.save-btn:disabled,.restart-btn:disabled{background:var(--secondary-color);cursor:not-allowed;transform:none}.clear-btn{background:var(--error-color);color:#fff;border:none;padding:8px 16px;border-radius:var(--border-radius);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.clear-btn:hover{background:#dc2626;transform:translateY(-1px)}.status-text{text-align:center;margin-top:10px;color:var(--text-secondary);font-size:14px;font-style:italic}.signature-capture-container{display:flex;flex-direction:column;align-items:center;gap:15px}.signature-canvas{display:block;margin:0 auto;cursor:crosshair}.photo-capture-container{display:flex;flex-direction:column;gap:15px}.camera-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--background-light);color:var(--text-primary);font-size:14px}.camera-selector{margin-bottom:10px}.camera-error,.camera-loading{text-align:center;padding:10px;background:var(--background-gray);border-radius:var(--border-radius);margin-bottom:10px}.refresh-btn{background:var(--secondary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:12px;transition:background-color .2s}.refresh-btn:hover{background:#374151}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.camera-container{display:flex;justify-content:center;align-items:center;min-height:150px;background:var(--background-gray);border-radius:var(--border-radius);overflow:hidden}.camera-video{width:100%;height:auto;border-radius:var(--border-radius)}.camera-placeholder{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-secondary);text-align:center}.camera-placeholder svg{opacity:.5}@media (max-width: 480px){.capture-interface{padding:15px}.capture-controls{flex-direction:column;width:100%}.capture-btn,.restart-btn,.save-btn,.clear-btn{width:100%;justify-content:center}.signature-canvas{width:100%;max-width:280px;height:70px}.camera-container{min-height:120px}}.image-uploader{width:100%;margin:20px 0}.upload-zone{border:2px dashed var(--border-color);border-radius:var(--border-radius-lg);padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--background-light);min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.upload-zone:hover{border-color:var(--primary-color);background:#f8faff}.upload-zone.drag-over{border-color:var(--primary-color);background:#f0f9ff;transform:scale(1.02)}.upload-icon{color:var(--text-secondary);margin-bottom:12px}.upload-text{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.upload-subtitle{font-size:14px;color:var(--text-secondary)}.uploaded-image-container{position:relative;display:inline-block;border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-md);max-width:100%}.uploaded-image{max-width:400px;max-height:300px;width:auto;height:auto;display:block;border-radius:var(--border-radius-lg)}.remove-image-button{position:absolute;top:8px;right:8px;background:var(--error-color);color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.remove-image-button:hover{background:#dc2626;transform:scale(1.1)}.capture-mode-selector{display:flex;gap:12px;margin-bottom:24px;padding:4px;background:var(--background-gray);border-radius:var(--border-radius-lg);max-width:fit-content;margin-left:auto;margin-right:auto}.mode-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease;white-space:nowrap}.mode-button:hover{color:var(--text-primary);background:#ffffff80}.mode-button.active{background:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm)}.mode-button svg{flex-shrink:0}.upload-section{padding:20px;background:var(--background-light);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);margin:20px 0}@media (max-width: 768px){.capture-mode-selector{flex-direction:column;width:100%;max-width:none}.mode-button{justify-content:center;width:100%}.upload-zone{padding:30px 15px;min-height:150px}.uploaded-image{max-width:100%;max-height:200px}}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media print{.page-header,.navigation-buttons,.control-buttons{display:none!important}.patient-list-container,.patient-detail-container,.biometric-capture-container{box-shadow:none;border:1px solid #000}}.header-actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.history-button{background:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;font-size:.875rem;transition:background-color .2s ease}.history-button:hover{background:var(--primary-hover)}.date-range-picker{min-width:250px}.stats{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.stat-item{margin:.25rem 0}.empty-state{margin-top:1rem}.empty-icon{margin-bottom:1rem;opacity:.3}.date-range-controls{display:flex;align-items:end;gap:16px;margin:0 20px;flex-wrap:wrap;background:#f8fafc;padding:16px;border-radius:10px;border:1px solid #e2e8f0}.date-input-group{display:flex;flex-direction:column;gap:6px;min-width:160px}.date-input-group label{font-size:13px;font-weight:600;color:#374151;margin-bottom:2px}.date-input{padding:10px 14px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;background:#fff;transition:all .2s ease;color:#374151}.date-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;transform:translateY(-1px)}.date-input:hover{border-color:#9ca3af}.text-input{padding:10px 14px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;background:#fff;transition:all .2s ease;color:#374151;width:180px}.text-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;transform:translateY(-1px)}.text-input:hover{border-color:#9ca3af}.text-input::placeholder{color:#9ca3af;font-style:italic}.search-date-button{background:linear-gradient(135deg,var(--primary-color) 0%,#3730a3 100%);color:#fff;border:none;border-radius:8px;padding:12px 20px;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:600;height:fit-content;transition:all .2s ease;box-shadow:0 2px 4px #4f46e533}.search-date-button:hover:not(:disabled){background:linear-gradient(135deg,#3730a3,#312e81);transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.search-date-button:active:not(:disabled){transform:translateY(0)}.search-date-button:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;transform:none;box-shadow:none}.search-buttons{display:flex;gap:8px;align-items:center;height:fit-content}.clear-filters-button{background:#f3f4f6;color:#6b7280;border:2px solid #d1d5db;border-radius:8px;padding:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:700;transition:all .2s ease;width:44px;height:44px}.clear-filters-button:hover:not(:disabled){background:#ef4444;border-color:#dc2626;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #ef444433}.clear-filters-button:disabled{background:#f9fafb;border-color:#e5e7eb;color:#d1d5db;cursor:not-allowed}.home-button,.logout-button{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:8px;padding:10px 18px;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.home-button:hover,.logout-button:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e533}.logout-button{border-color:#dc2626;color:#dc2626}.logout-button:hover{background:#dc2626;color:#fff;box-shadow:0 4px 12px #dc262633}.error-banner{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;border-radius:10px;padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;color:#dc2626;box-shadow:0 2px 8px #dc26261a}.retry-button{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;border-radius:6px;padding:8px 16px;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.retry-button:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-1px)}.refresh-button{background:linear-gradient(135deg,var(--primary-color) 0%,#3730a3 100%);color:#fff;border:none;border-radius:8px;padding:12px 24px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #4f46e533}.refresh-button:hover{background:linear-gradient(135deg,#3730a3,#312e81);transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.datatable-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;margin-bottom:20px}.datatable-header{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:20px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.search-container{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none}.search-input{width:100%;padding:12px 16px 12px 46px;border:2px solid #d1d5db;border-radius:10px;font-size:14px;background:#fff;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.search-input::placeholder{color:#9ca3af}.datatable-header .refresh-button{padding:10px 20px;font-size:13px}.refresh-icon{transition:transform .3s ease}.refresh-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.datatable-wrapper{overflow-x:auto}.datatable{width:100%;border-collapse:collapse;font-size:14px}.datatable th{background:linear-gradient(135deg,#4f46e5,#3730a3);color:#fff;padding:16px 20px;text-align:left;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.datatable td{padding:16px 20px;border-bottom:1px solid #f1f5f9;color:#374151;font-weight:500}.datatable-row{cursor:pointer;transition:all .2s ease}.datatable-row:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);transform:scale(1.001)}.status-badge{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.completado{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border:1px solid #34d399}.status-badge.pendiente{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #f59e0b}.loading-cell,.no-data-cell{text-align:center;padding:40px 20px;color:#6b7280;font-style:italic}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid #f3f4f6;border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite;margin-right:10px}.pagination-container{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:20px;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.pagination-info{color:#6b7280;font-size:14px;font-weight:500}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-btn{background:#fff;border:2px solid #d1d5db;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px}.pagination-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e533}.pagination-btn:disabled{background:#f9fafb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.page-info{color:#374151;font-weight:600;font-size:14px;margin:0 16px;background:#fff;padding:8px 16px;border-radius:8px;border:2px solid #e5e7eb}.datatable-footer{background:#f8fafc;padding:12px 20px;border-top:1px solid #e2e8f0;text-align:center}.records-count{color:#6b7280;font-size:13px;font-weight:500}.stats .stat-item{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#374151;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;margin:0;display:inline-block;border:1px solid #d1d5db;transition:all .2s ease}.stats .stat-item:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.stats .stat-item.stat-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-color:#34d399}.stats .stat-item.stat-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#f59e0b}.empty-state{text-align:center;padding:60px 20px;color:#6b7280;margin-top:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.empty-state .empty-icon{color:#cbd5e0;margin-bottom:20px;opacity:1}.empty-state h3{margin:0 0 12px;color:#374151;font-size:18px;font-weight:600}.empty-state p{margin:0 0 24px;color:#6b7280;font-size:14px}.page-header{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:24px;padding:28px}.header-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}.header-content h1{display:flex;align-items:center;gap:12px;color:var(--text-primary);font-size:26px;font-weight:700;margin:0}.header-content .page-icon{color:var(--primary-color)}.header-actions{display:flex;gap:12px;align-items:center}.header-subtitle{margin-top:20px;padding-top:20px}@media (max-width: 768px){.header-content{flex-direction:column;align-items:stretch}.date-range-controls{margin:0;justify-content:center;flex-direction:column;align-items:stretch;gap:12px}.date-input,.text-input{width:100%}.search-buttons,.header-actions{justify-content:center}.datatable-header{flex-direction:column;align-items:stretch}.pagination-container{flex-direction:column;text-align:center}.pagination-controls{justify-content:center}}.date-info{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:14px;font-weight:500;background:#f8fafc;padding:8px 16px;border-radius:20px;border:1px solid #e2e8f0}.date-info .date-icon{color:var(--primary-color)}.history-button{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:8px;padding:10px 18px;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.history-button:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e533}
