.login-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;background-color:var(--color-background);padding:20px}.login-header{width:100%;text-align:center;padding:40px 0 20px}.login-header h1{font-size:24px;margin:0;color:var(--color-abana-primary);font-weight:700}.login-box h2{text-align:center;margin-bottom:30px;color:var(--color-text-dark)}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#555}.form-group input{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:16px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background-color:#fff;padding:30px;border-radius:8px;width:90%;max-width:450px;box-shadow:0 5px 15px #0000004d;text-align:center}.modal-title{color:var(--color-abana-primary);border-bottom:1px solid #eee;padding-bottom:10px;margin-top:0}.modal-message{margin:20px 0 30px;color:#333}.modal-actions{display:flex;justify-content:flex-end;gap:15px}.modal-actions button{padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:600;transition:background-color .2s;border:1px solid transparent}.btn-cancel{background-color:#ccc;color:#333}.btn-cancel:hover{background-color:#bbb}.btn-confirm{background-color:#dc3545;color:#fff}.btn-confirm:hover{background-color:#c82333}.upload-container{max-width:600px;margin:50px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a}.upload-container h2{text-align:center;color:var(--color-abana-primary);margin-bottom:30px}.upload-form .form-group{margin-bottom:25px}.upload-form label{display:block;margin-bottom:8px;font-weight:600;color:var(--color-ui-text-dark)}.upload-form input[type=text],.upload-form input[type=file]{width:100%;padding:10px;border:1px solid var(--color-ui-border);border-radius:4px;box-sizing:border-box;font-size:16px}.file-info{margin-top:10px;color:green;font-size:.9em}.upload-container button{width:100%;padding:12px;background-color:var(--color-abana-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:18px;margin-top:20px;transition:background-color .3s}.upload-container button:hover:not(:disabled){background-color:var(--color-abana-hover)}.upload-container button:disabled{background-color:#ccc;cursor:not-allowed}.code-input-group{position:relative}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;z-index:10;background-color:#fff;border:1px solid var(--color-ui-border);border-top:none;border-radius:0 0 4px 4px;box-shadow:0 4px 6px #0000001a;max-height:200px;overflow-y:auto}.suggestion-item{padding:10px;cursor:pointer;font-size:14px;border-bottom:1px solid #eee}.suggestion-item:last-child{border-bottom:none}.loading-suggestion,.no-suggestion{padding:10px;font-style:italic;color:#666;text-align:center}.checkbox-group{margin-bottom:1rem}.checkbox-row{display:flex;align-items:flex-start;justify-content:center;gap:.75rem;margin-bottom:.25rem}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-abana-primary);cursor:pointer}.checkbox-label{font-weight:600;color:var(--color-ui-text-dark);cursor:pointer;-webkit-user-select:none;user-select:none;line-height:1.4}.checkbox-hint{display:block;margin-left:2rem;color:var(--color-ui-text-light);font-size:.875rem;line-height:1.4;max-width:600px}.checkbox-custom:disabled{opacity:.6;cursor:not-allowed}.results-container{max-width:1600px;margin:30px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a}.results-container h2{text-align:center;color:var(--color-abana-primary);margin-bottom:30px}.summary-info{border:1px solid #ccc;padding:15px;border-radius:4px;margin-bottom:25px;background-color:#f9f9f9}.summary-info p{margin:5px 0}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:30px}.metric-card{background-color:#fff;border:1px solid #ddd;border-radius:6px;padding:20px;text-align:center;box-shadow:0 2px 5px #0000000d}.metric-card h4{margin-top:0;font-size:1.1em;color:#555}.metric-card p{font-size:2.5em;font-weight:700;color:var(--color-abana-primary);margin:0}.error-card p{color:#c00}.action-section{text-align:center;padding-top:20px;border-top:1px dashed #ddd;display:flex;justify-content:center}.export-button{background-color:#28a745;color:#fff;border:none;padding:12px 25px;border-radius:4px;cursor:pointer;font-size:1em;transition:background-color .3s}.export-only-errors{margin-left:24px;background-color:#198754}.export-button:hover{background-color:#1e7e34}.processing-message{text-align:center;padding:50px;background-color:#eaf6ff;border:1px dashed #007bff;color:#007bff}.processing-message h2{color:#007bff}.spinner{border:4px solid rgba(0,0,0,.1);border-top:4px solid var(--color-abana-primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:20px auto 0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message h2{color:#c0392b}.error-message .export-button{background-color:#c0392b}.detailed-metrics-section h3{text-align:center;color:var(--abana-primary-dark);margin-top:30px;margin-bottom:15px;font-size:1.4em;font-weight:500}.detailed-results-table{width:100%;border-collapse:collapse;margin-top:15px;font-size:.85em}.detailed-results-table th,.detailed-results-table td{border:1px solid #e0e0e0;padding:8px 5px;text-align:center;vertical-align:middle}.detailed-results-table thead th{background-color:var(--abana-primary-dark);color:#fff;font-weight:600}.group-header-row-results{background-color:#e9e9e9!important;font-weight:700;color:var(--abana-primary-dark);border-top:2px solid var(--abana-primary-dark)}.cataloger-row-results{background-color:#fcfcfc;font-style:italic;color:#555}.separator-row-results{background-color:var(--abana-primary-dark)!important;color:#fff!important;font-weight:600;text-align:center!important;padding:5px 0;border:none!important;border-bottom:2px solid #555!important;text-transform:uppercase;letter-spacing:1px}.error-cell{color:var(--abana-error-red);font-weight:700}.zero-cell{color:#aaa}.detailed-results-table td:first-child{text-align:left;font-weight:500}.filter-bar{display:flex;gap:20px;align-items:flex-end;padding:15px;margin-bottom:25px;border:1px solid #ddd;border-radius:6px;background-color:#f9f9f9;flex-wrap:wrap;width:100%}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:.9em;font-weight:500;margin-bottom:5px;color:#555}.filter-bar input[type=date],.filter-bar input[type=text],.filter-bar select{padding:8px;border:1px solid #ccc;border-radius:4px;font-size:1em;width:150px}.filter-bar input#projectCode{width:160px}.filter-summary{text-align:right;font-size:.9em;color:#777;margin-top:-15px}.reset-button{background-color:gray;color:#fff;border:none;padding:8px 15px;border-radius:4px;cursor:pointer;font-size:.9em;transition:background-color .3s}.reset-button:hover{background-color:#555}.history-container h2{text-align:center;color:var(--color-abana-primary);margin-bottom:20px}.history-container p{text-align:center;color:var(--color-ui-text-light);margin-bottom:30px}.history-table{width:100%;border-collapse:collapse;margin-top:20px;font-size:.95em;table-layout:fixed}.history-table thead{background-color:#f4f4f4;border-bottom:2px solid var(--color-abana-primary)}.history-table th{padding:12px 15px;text-align:left;font-weight:600;color:var(--color-ui-text-dark)}.history-table tbody tr{border-bottom:1px solid #eee;transition:background-color .2s}.history-table tbody tr:hover{background-color:#fafafa}.history-table th:nth-child(1),.history-table td:nth-child(1){width:5%}.history-table th:nth-child(2),.history-table td:nth-child(2){width:20%;word-wrap:break-word}.history-table th:nth-child(3),.history-table td:nth-child(3){width:20%;word-wrap:break-word}.history-table th:nth-child(4),.history-table td:nth-child(4){width:10%}.history-table th:nth-child(5),.history-table td:nth-child(5){width:18%;word-wrap:break-word}.history-table th:nth-child(6),.history-table td:nth-child(6){width:10%;word-wrap:break-word}.history-table th:nth-child(7),.history-table td:nth-child(7){width:7%}.history-table th:nth-child(8),.history-table td:nth-child(8){width:7%}.history-table th:nth-child(9),.history-table td:nth-child(9){width:10%}.history-table td{padding:10px;vertical-align:middle}.history-table button{background-color:var(--color-abana-primary);color:#fff;border:none;padding:6px 10px;border-radius:4px;cursor:pointer;font-size:.85em;transition:background-color .3s}.history-table button:hover{background-color:var(--color-abana-hover)}.button-in-process{opacity:.5;cursor:"default"}.code-input-group-history,.code-input-group-reports{position:relative}.suggestions-dropdown-history,.suggestions-dropdown-reports{position:absolute;top:100%;left:0;right:0;z-index:20;background-color:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 4px 4px;box-shadow:0 4px 8px #0000001a;max-height:200px;overflow-y:auto}.suggestion-item{padding:8px 10px;cursor:pointer;font-size:.9em}.suggestion-item:hover{background-color:#f0f0f0;color:var(--color-abana-primary)}.loading-suggestion,.no-suggestion{padding:8px 10px;font-style:italic;color:#666}.reports-container{max-width:1600px;margin:30px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a}.reports-container h2{text-align:center;color:var(--abana-primary-dark);margin-bottom:25px;font-weight:300}.filter-bar{display:flex;flex-wrap:wrap;gap:15px;align-items:flex-end;padding:15px;margin-bottom:30px;border:1px solid #ddd;border-radius:6px;background-color:var(--abana-light-bg)}.summary-cards-section{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px;text-align:center}.summary-card{background-color:#fff;padding:20px;border-radius:6px;border:1px solid #ccc;box-shadow:0 2px 4px #0000000d;transition:box-shadow .2s}.summary-card:hover{box-shadow:0 4px 12px #0000001a}.summary-card h4{margin:0 0 15px;font-size:1.1em;color:var(--abana-primary-dark);font-weight:500;text-align:center}.card-metrics{display:flex;justify-content:space-around;gap:10px;padding-top:10px;border-top:1px dashed #eee}.card-metrics p{display:flex;flex-direction:column;text-align:center;margin:0}.card-metrics .doc-count,.card-metrics .error-count{color:var(--abana-secondary-gray);font-weight:400}.card-metrics strong{font-size:2.2em;display:block;font-weight:600;line-height:1.1}.doc-count strong{color:var(--abana-primary-dark)}.error-count strong{color:var(--abana-error-red)}.three-table-layout{display:flex;flex-direction:column;gap:40px}.pivot-table{width:100%;border-collapse:collapse;margin-top:15px;font-size:.8em}.pivot-table td{padding:6px 4px;vertical-align:top;border:1px solid #e0e0e0}.pivot-table th{background-color:var(--abana-primary-dark);color:#fff;font-weight:600;padding:6px 4px;vertical-align:top;border:1px solid var(--abana-primary-dark)}.group-header-row{background-color:#e9e9e9!important;font-weight:700;color:var(--abana-primary-dark);border-top:2px solid var(--abana-primary-dark)}.cataloger-row{background-color:#fcfcfc;font-style:italic;color:#555}.clickable-error{color:var(--abana-error-red);font-weight:700;cursor:pointer;transition:background-color .2s}.clickable-error:hover{background-color:#fce7e7}.zero-error{color:#aaa}.separator-row{background-color:var(--abana-secondary-gray)!important;color:#fff!important;font-weight:600;text-align:center!important;padding:5px 0;border:none!important;border:2px solid var(--abana-secondary-gray);text-transform:uppercase;letter-spacing:1px}.trazability-list-container{max-height:400px;overflow-y:auto;margin-top:15px}.trazability-list-container table{width:100%;font-size:.9em}.trazability-list-container th{background-color:#f0f0f0;position:sticky;top:0}.export-dropdown-container{position:relative;display:inline-block}.export-button{padding:10px 15px;background-color:var(--abana-primary-dark);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9em;min-width:150px}.export-button:disabled{background-color:#a0a0a0;cursor:not-allowed}.dropdown-arrow{margin-left:8px;transition:transform .2s}.export-dropdown-menu{position:absolute;top:100%;left:0;margin-top:2px;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 8px #0000001a;z-index:20;width:100%}.export-dropdown-menu button{display:block;width:100%;padding:10px 15px;text-align:left;background:none;border:none;cursor:pointer;font-size:.9em;color:var(--abana-primary-dark)}.export-dropdown-menu button:hover{background-color:var(--abana-light-bg)}.admin-container{max-width:1000px;margin:30px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a}.admin-container h2{text-align:center;color:var(--color-abana-primary);margin-bottom:30px}.admin-actions{margin-bottom:25px;text-align:right}.add-user-button{background-color:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:1em;transition:background-color .3s}.add-user-button:hover{background-color:#1e7e34}.user-table{width:100%;border-collapse:collapse;margin-top:15px;font-size:.95em}.user-table thead{background-color:#f4f4f4;border-bottom:2px solid var(--color-ui-border)}.user-table th{padding:12px 15px;text-align:left;font-weight:600;color:var(--color-ui-text-dark)}.user-table tbody tr{border-bottom:1px solid #eee;transition:background-color .2s}.user-table tbody tr:hover{background-color:#fafafa}.user-table td{padding:10px 15px;vertical-align:middle}.profile-administrador{font-weight:700;color:var(--color-abana-primary)}.profile-revisor{color:#007bff}.edit-button{background-color:#ffc107;color:#333;border:none;padding:6px 10px;border-radius:4px;cursor:pointer;font-size:.85em;transition:background-color .3s;margin-right:10px}.edit-button:hover{background-color:#e0a800}.edit-form{max-width:500px;margin:30px auto 0;padding:25px;border:1px solid #ddd;border-radius:6px}.edit-form .form-group{margin-bottom:15px}.edit-form label{display:block;font-weight:600;margin-bottom:8px}.edit-form select{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px}.edit-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:25px}.user-table th{padding:12px 15px;text-align:left;font-weight:600;color:var(--color-ui-text-dark);width:fit-content}.delete-button{background-color:#dc3545;color:#fff;border:none;padding:6px 10px;border-radius:4px;cursor:pointer;font-size:.85em;transition:background-color .3s}.delete-button:hover:not(:disabled){background-color:#c82333}.delete-button:disabled{background-color:#f0f0f0;color:#aaa;cursor:not-allowed}.change-password-container{max-width:500px;margin:30px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a}.change-password-container h2{text-align:center;color:var(--color-abana-primary);margin-bottom:30px}.password-form .form-group{margin-bottom:20px}.password-form label{display:block;font-weight:600;margin-bottom:8px;color:#555}.password-form input[type=password]{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:16px}.margin-bottom-10{margin-bottom:10px}.navbar{display:flex;justify-content:flex-start;align-items:center;position:fixed;top:30px;left:0;width:100%;z-index:999;box-sizing:border-box;background-color:#333;box-shadow:0 2px 4px #0003;height:50px;padding:0 30px}.navbar-links{display:flex;gap:20px}.navbar-links a{color:#fff;text-decoration:none;font-weight:500;line-height:50px;transition:color .3s}.navbar-links a:hover{color:var(--color-abana-primary)}.navbar-user{display:flex;align-items:center;color:#f0f0f0;font-size:.9em}.navbar-user span{margin-right:20px}.logout-btn{background-color:var(--color-abana-primary);color:#fff;border:none;padding:8px 15px;border-radius:4px;cursor:pointer;font-size:.9em;transition:background-color .3s}.top-bar-container{display:flex;justify-content:flex-end;height:30px;position:fixed;top:0;left:0;width:100%;box-sizing:border-box;z-index:1000;padding:8px 30px;background-color:#eee;border-bottom:1px solid #ccc}.navbar-user{display:flex;align-items:center;color:#555;font-size:.85em}.navbar-user span{margin-right:15px}.logout-btn{background-color:var(--color-abana-primary);color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.9em;transition:background-color .3s}.logout-btn:hover{background-color:var(--color-abana-hover)}.change-password-link{color:var(--color-abana-primary);text-decoration:none;font-weight:700;margin-left:5px}.change-password-link:hover{text-decoration:underline}.primary-button,.login-button,.save-button{width:100%;padding:12px;background-color:var(--color-abana-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:18px;margin-top:20px;transition:background-color .3s}.primary-button:hover:not(:disabled),.login-button:hover:not(:disabled),.save-button:hover:not(:disabled){background-color:var(--color-abana-hover)}.primary-button:disabled,.login-button:disabled,.save-button:disabled{background-color:#a0c3e6;cursor:not-allowed}.cancel-button{padding:10px 20px;border-radius:4px;cursor:pointer;font-size:1em;border:none;transition:background-color .3s;background-color:#6c757d;color:#fff}.cancel-button:hover{background-color:#5a6268}.status-message{padding:15px;border-radius:4px;margin-bottom:20px;text-align:center;font-weight:600;color:var(--color-ui-text-dark)}.status-message-success{background-color:#e6ffed;color:#00873c;border:1px solid #00873c}.status-message-error{background-color:#ffe6e6;color:#c00;border:1px solid #cc0000}.input-error{border-color:#c00!important}.validation-error{color:#c00;font-size:.85em;margin-top:5px}.page-container{margin:30px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a}.login-page{display:flex;flex-direction:column;align-items:center;min-height:100vh;background-color:var(--color-ui-background);padding:20px}.login-main{width:100%;display:flex;justify-content:center}.login-box{background-color:#fff;padding:40px;border-radius:8px;box-shadow:0 4px 10px #0000001a;max-width:450px;width:100%;margin-top:30px}.admin-container,.history-container,.reports-container{margin:30px auto;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a;display:flex;flex-direction:column}.admin-container,.history-container{max-width:1500px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:8px;color:var(--color-ui-text-light)}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid var(--color-ui-border);border-radius:4px;box-sizing:border-box;font-size:16px}.page-container h2{text-align:center;color:var(--color-abana-primary);margin-bottom:30px}:root{--color-abana-primary: #a21957;--color-abana-hover: #8c164d;--color-ui-background: #f4f7f9;--color-ui-text-dark: #333;--color-ui-text-light: #555;--color-ui-border: #ccc;--abana-primary-dark: #47545d;--abana-secondary-gray: #7a7a7a;--abana-error-red: #dc3545;--abana-light-bg: #f9f9f9}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}body{margin:0;font-family:Arial,sans-serif;background-color:var(--color-ui-background)}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.app-container{padding-top:80px;min-height:100vh;box-sizing:border-box}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.client-logo{width:120px;height:auto;margin-bottom:15px}.client-:hover{filter:drop-shadow(0 0 1.5em var(--color-abana-primary) aa);transition:filter .3s}.status-completado-correctamente{color:#1e8449;font-weight:700}.status-completado-con-errores{color:#1e8484;font-weight:700}.status-pendiente{color:#f39c12;font-weight:700}.status-error{color:#c0392b;font-weight:700}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.error-message{color:"red";text-align:"center"}.empty-result{text-align:"center";padding:"20px"}:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
