*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:2.5rem;width:100%}.login-box h1{color:#333;font-size:1.8rem;margin:0 0 .5rem;text-align:center}.login-box h2{color:#666;font-size:1.2rem;font-weight:400;margin:0 0 2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.form-group input{border:2px solid #e0e0e0;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.error-message{background-color:#fee;border-radius:5px;color:#c33;font-size:.9rem;margin-bottom:1rem;padding:.75rem;text-align:center}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem;transition:transform .2s,box-shadow .2s;width:100%}.login-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.jobs-list{padding:1rem}.jobs-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.jobs-header h1{color:#2c3e50}.pagination-controls{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1rem}.pagination-left{align-items:center;display:flex;gap:.5rem}.pagination-left .total-count{border-right:1px solid #dcdde1;color:#2c3e50;font-size:.9rem;margin-right:1rem;padding-right:1rem}.pagination-left .total-count strong{color:#3498db;font-weight:600}.pagination-left label{color:#2c3e50;font-size:.9rem;font-weight:500}.pagination-select{background:#fff;border:1px solid #dcdde1;border-radius:4px;cursor:pointer;font-size:.9rem;padding:.4rem .8rem;transition:border-color .2s}.pagination-select:hover{border-color:#3498db}.pagination-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.pagination-right{align-items:center;display:flex;gap:.75rem}.page-info{color:#2c3e50;font-size:.9rem;font-weight:500;min-width:60px;text-align:center}.jobs-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.job-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:1.5rem;transition:transform .2s,box-shadow .2s}.job-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-4px)}.job-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.job-filename{color:#2c3e50;flex:1 1;font-size:1.1rem;margin:0;word-break:break-word}.job-status-badge{border-radius:12px;color:#fff;font-size:.875rem;font-weight:600;margin-left:.5rem;padding:.25rem .75rem;text-transform:uppercase}.job-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.job-info-item{display:flex;font-size:.9rem;justify-content:space-between}.job-info-item .label{color:#7f8c8d;font-weight:500}.job-info-item .value{color:#2c3e50;font-weight:600}.error-text{color:#e74c3c!important}.job-progress{background-color:#ecf0f1;border-radius:3px;height:6px;margin-bottom:1rem;overflow:hidden}.progress-bar{height:100%;transition:width .3s ease}.job-footer{align-items:center;border-top:1px solid #ecf0f1;display:flex;justify-content:space-between;padding-top:1rem}.job-date{color:#95a5a6}.empty-state{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:4rem 2rem;text-align:center}.empty-state h2{color:#2c3e50;margin-bottom:1rem}.empty-state p{color:#7f8c8d;margin-bottom:2rem}.error,.loading{color:#7f8c8d;font-size:1.1rem;padding:2rem;text-align:center}.btn-sm{font-size:.85rem;padding:.375rem .75rem}.page-viewer{display:flex;flex-direction:column;gap:1rem;height:100%}.page-image-container{align-items:flex-start;background:#f5f5f5;border-radius:8px;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:1rem;position:relative}.page-canvas,.page-image{cursor:crosshair;display:block;height:auto;max-width:100%}.cell-tooltip{background:#fff;border:2px solid #3498db;border-radius:6px;box-shadow:0 4px 12px #00000026;max-width:400px;min-width:200px;padding:.75rem;pointer-events:none;position:fixed;z-index:1000}.tooltip-header{align-items:center;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.5rem}.tooltip-badge{border-radius:4px;font-size:.75rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.tooltip-badge.header{background:#3498db;color:#fff}.tooltip-badge.cell{background:#27ae60;color:#fff}.tooltip-position{color:#7f8c8d;font-size:.85rem;font-weight:500}.tooltip-text{word-wrap:break-word;background:#f8f9fa;border-radius:4px;color:#2c3e50;font-size:.95rem;line-height:1.4;margin-bottom:.5rem;max-height:200px;overflow-y:auto;padding:.5rem}.tooltip-confidence{color:#7f8c8d;font-size:.85rem;margin-bottom:.25rem}.tooltip-method{color:#7f8c8d;font-size:.85rem;font-style:italic}.page-viewer-stats{background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#2c3e50;display:flex;font-size:.9rem;gap:2rem;padding:.75rem 1rem}.page-viewer-stats span{font-weight:500}.page-viewer-error,.page-viewer-loading{align-items:center;color:#7f8c8d;display:flex;font-size:1.1rem;height:100%;justify-content:center}.page-viewer-error{color:#e74c3c}.job-detail{padding:1rem}.job-detail-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.job-detail-header h1{color:#2c3e50;margin-top:1rem;word-break:break-word}.header-actions{display:flex;gap:1rem}.job-status-card{grid-gap:1.5rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem;padding:1.5rem}.status-item{display:flex;flex-direction:column;gap:.5rem}.status-item .label{color:#7f8c8d;font-size:.9rem;font-weight:500}.status-item .value{color:#2c3e50;font-size:1.5rem;font-weight:600}.status-item .value.error{color:#e74c3c}.status-badge{border-radius:4px;color:#fff;display:inline-block;font-size:.9rem;font-weight:600;padding:.5rem 1rem;text-transform:uppercase}.status-completed{background-color:#27ae60}.status-processing{background-color:#f39c12}.status-failed{background-color:#e74c3c}.status-pending{background-color:#95a5a6}.results-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:250px 1fr;margin-top:2rem}.pages-sidebar{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;height:-webkit-fit-content;height:fit-content;padding:1.5rem}.pages-sidebar h3{color:#2c3e50;margin-bottom:1rem}.pages-list{display:flex;flex-direction:column;gap:.5rem}.page-item{align-items:center;border:1px solid #ecf0f1;border-radius:4px;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem;transition:all .2s}.page-item:hover{background-color:#f8f9fa}.page-item.active{background-color:#3498db;border-color:#3498db;color:#fff}.page-number{font-weight:600}.page-status{border-radius:3px;font-size:.75rem;padding:.25rem .5rem;text-transform:uppercase}.page-item.active .page-status{background-color:#fff3}.page-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.page-header{border-bottom:2px solid #ecf0f1;margin-bottom:2rem;padding-bottom:1rem}.page-header h2{color:#2c3e50}.page-stats{color:#7f8c8d;display:flex;gap:1.5rem}.page-stats span{font-size:.9rem}.visualization-container{background-color:#f8f9fa;border-radius:8px;margin-bottom:2rem;padding:1rem;text-align:center}.visualization-image{border:1px solid #ecf0f1;border-radius:4px;height:auto;max-width:100%}.cells-section h3{color:#2c3e50;margin-bottom:1.5rem}.cells-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.cell-card{background-color:#f8f9fa;border:1px solid #ecf0f1;border-radius:6px;padding:1rem;transition:box-shadow .2s}.cell-card:hover{box-shadow:0 2px 8px #0000001a}.cell-header{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem}.cell-index{color:#2c3e50;font-weight:600}.cell-position{color:#7f8c8d;font-size:.85rem}.cell-content{margin-bottom:.75rem}.cell-text{word-wrap:break-word;color:#2c3e50;direction:rtl;line-height:1.5;text-align:right}.no-text{color:#95a5a6;font-style:italic}.cell-meta{display:flex;gap:1rem;margin-top:.5rem}.meta-item{background-color:#fff;border-radius:3px;color:#7f8c8d;font-size:.75rem;padding:.25rem .5rem}.cell-dimensions{color:#95a5a6;font-size:.75rem;text-align:right}.modal-overlay{background-color:#00000080}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;max-width:500px;padding:2rem;width:90%}.modal h2{color:#2c3e50;margin-bottom:1rem}.modal p{color:#7f8c8d;margin-bottom:1.5rem}.modal-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.modal-options label{color:#2c3e50;display:flex;flex-direction:column;font-weight:600;gap:.5rem}.modal-options input[type=number]{border:1px solid #bdc3c7;border-radius:4px;font-size:1rem;padding:.5rem}.loading{color:#7f8c8d}.error,.loading{font-size:1.1rem;padding:2rem;text-align:center}.error{color:#e74c3c}.btn{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:background-color .2s}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.btn:disabled{cursor:not-allowed;opacity:.6}.document-detail{display:flex;flex-direction:column;height:100vh;padding:1rem}.document-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.document-header h1{color:#2c3e50;flex:1 1;margin:0}.document-content{display:flex;flex:1 1;gap:1.5rem;overflow:hidden}.jobs-sidebar{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden;padding:1.5rem;width:300px}.sidebar-header{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.sidebar-header h2{color:#2c3e50;font-size:1.1rem;margin:0}.job-count{background:#ecf0f1;border-radius:12px;color:#7f8c8d;font-size:.9rem;padding:.25rem .5rem}.pagination-mini{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem;padding-bottom:1rem}.pagination-mini span{color:#2c3e50;font-size:.9rem;min-width:40px;text-align:center}.jobs-list-sidebar{display:flex;flex:1 1;flex-direction:column;gap:.75rem;overflow-y:auto}.job-item{border:2px solid #ecf0f1;border-radius:6px;cursor:pointer;padding:1rem;position:relative;transition:all .2s}.job-item:hover{background:#f8f9fa;border-color:#3498db}.job-item.selected{background:#e3f2fd;border-color:#3498db}.job-item-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.status-dot{border-radius:50%;height:10px;width:10px}.job-date{color:#7f8c8d;font-size:.85rem}.job-item-info{color:#2c3e50;display:flex;font-size:.85rem;justify-content:space-between}.btn-icon-delete{background:none;border:none;cursor:pointer;font-size:1rem;opacity:0;position:absolute;right:.5rem;top:.5rem;transition:opacity .2s}.job-item:hover .btn-icon-delete{opacity:1}.btn-icon-delete:hover{transform:scale(1.2)}.results-viewer{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;flex:1 1;overflow-y:auto;padding:1.5rem}.results-content{display:flex;flex-direction:column;height:100%}.results-header{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.results-header h3{color:#2c3e50;margin:0}.status-badge-large{border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;padding:.5rem 1rem;text-transform:uppercase}.results-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:2rem}.stat{background:#f8f9fa;border-radius:8px;padding:1rem;text-align:center}.stat-label{color:#7f8c8d;display:block;font-size:.85rem;margin-bottom:.5rem}.stat-value{color:#2c3e50;display:block;font-size:1.5rem;font-weight:600}.pages-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.page-card{border:2px solid #ecf0f1;border-radius:8px;cursor:pointer;padding:1rem;transition:all .2s}.page-card:hover{border-color:#3498db;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.page-header h4{color:#2c3e50;margin:0}.cell-count{color:#7f8c8d;font-size:.85rem}.page-status{align-items:center;color:#2c3e50;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:.75rem}.error-message{background:#fee;color:#e74c3c;font-size:.85rem;margin-bottom:.75rem;padding:.5rem}.btn-view{margin-top:.5rem;width:100%}.error-state,.no-pages,.no-selection{align-items:center;color:#7f8c8d;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.error-state h2{color:#2c3e50;margin-bottom:1rem}.job-hash{background:#ecf0f1;border-radius:4px;color:#95a5a6;font-family:monospace;font-size:.85rem;padding:.25rem .5rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-width:500px;padding:2rem;width:90%}.modal-content h2{color:#2c3e50;margin-top:0}.modal-content p{color:#555;line-height:1.6}.modal-info{background:#f8f9fa;border-radius:4px;color:#2c3e50;font-size:.9rem;margin:1rem 0;padding:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.upload-container{margin:0 auto;max-width:800px}.upload-container h1{color:#2c3e50;margin-bottom:2rem}.upload-section{margin-bottom:3rem}.dropzone{background-color:#fff;border:3px dashed #bdc3c7;border-radius:8px;cursor:pointer;padding:3rem;text-align:center;transition:all .3s ease}.dropzone:hover:not(.disabled){background-color:#f8f9fa;border-color:#3498db}.dropzone.active{background-color:#e3f2fd;border-color:#3498db}.dropzone.disabled{cursor:not-allowed;opacity:.7}.dropzone-content{align-items:center;display:flex;flex-direction:column;gap:1rem}.upload-icon{color:#95a5a6;height:64px;width:64px}.dropzone p{color:#2c3e50;font-size:1.1rem;margin:0}.file-types{color:#7f8c8d!important;font-size:.9rem!important}.uploading{align-items:center;display:flex;flex-direction:column;gap:1rem}.spinner{animation:spin 1s linear infinite;border:4px solid #ecf0f1;border-radius:50%;border-top-color:#3498db;height:48px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{background-color:#fadbd8;border:1px solid #e74c3c;border-radius:4px;color:#c0392b;margin-top:1rem;padding:1rem}.options-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.options-section h2{color:#2c3e50;margin-bottom:1.5rem}.options-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.option-group,.option-group label{display:flex;flex-direction:column}.option-group label{color:#2c3e50;font-weight:600;gap:.5rem}.option-group input[type=number]{border:1px solid #bdc3c7;border-radius:4px;font-size:1rem;padding:.5rem}.option-group input[type=number]:focus{border-color:#3498db;outline:none}.checkbox-label{align-items:center;cursor:pointer;flex-direction:row!important}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;margin-right:.75rem;width:20px}.hint{color:#7f8c8d;font-size:.85rem;font-weight:400}.App{display:flex;flex-direction:column;min-height:100vh}.navbar{background-color:#2c3e50;box-shadow:0 2px 4px #0000001a;padding:1rem 0}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.nav-logo{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none}.nav-menu{display:flex;gap:2rem;list-style:none}.nav-link{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s}.nav-link:hover{background-color:#ffffff1a}.nav-username{color:#fffc;padding:.5rem 1rem}.logout-button{color:#fff;cursor:pointer}.logout-button:hover{background-color:#ff4d4d4d}.main-content{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}
/*# sourceMappingURL=main.84636828.css.map*/