:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;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;background-color:#1a1a1a;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}}.doc-detail{max-width:1200px;margin:0 auto;padding:20px;box-sizing:border-box}.doc-detail__back{display:inline-block;margin-bottom:20px;color:#646cff;text-decoration:none;font-weight:500}.doc-detail__back:hover{text-decoration:underline}.doc-detail__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.doc-detail__title{margin:0;font-size:1.8rem;word-break:break-word}.doc-detail__actions{display:flex;gap:10px;flex-wrap:wrap}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.9em;font-weight:600;margin-top:5px}.status-badge--VALIDATED{background:#d4edda;color:#155724}.status-badge--PENDING_REVIEW{background:#fff3cd;color:#856404}.status-badge--PROCESSING_OCR{background:#cce5ff;color:#004085}.status-badge--REJECTED{background:#f8d7da;color:#721c24}.status-badge--UPLOADED{background:#e2e3e5;color:#383d41}.doc-detail__meta{background:#f8f9fa;padding:20px;border-radius:8px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;margin-bottom:30px}.doc-detail__meta-item{display:flex;flex-direction:column}.doc-detail__meta-item label{font-size:.85em;color:#6c757d;margin-bottom:4px;font-weight:600;text-transform:uppercase}.doc-detail__meta-item span{font-weight:500;word-break:break-word}.doc-detail__section{margin-bottom:40px}.doc-detail__section h2{border-bottom:2px solid #eee;padding-bottom:10px;margin-bottom:20px}.invoice-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:15px;margin-bottom:25px;background:#fff;border:1px solid #eee;padding:15px;border-radius:8px}.lines-table{width:100%;border-collapse:collapse;margin-top:10px}.lines-table th,.lines-table td{padding:12px;border-bottom:1px solid #eee;text-align:left}.lines-table th{background:#f8f9fa;font-weight:600;color:#495057}.lines-table .num{text-align:right;font-variant-numeric:tabular-nums}@media(max-width:768px){.doc-detail__header{flex-direction:column;align-items:flex-start}.doc-detail__actions{width:100%;justify-content:stretch}.doc-detail__actions .btn{flex:1;justify-content:center}.doc-detail__meta,.invoice-meta{grid-template-columns:1fr;gap:12px}.lines-table thead{display:none}.lines-table,.lines-table tbody,.lines-table tr,.lines-table td{display:block;width:100%}.lines-table tr{margin-bottom:15px;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 1px 3px #0000000d;background:#fff;padding:10px;box-sizing:border-box}.lines-table tr:last-child{margin-bottom:0}.lines-table td{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f0f0;text-align:right;font-size:.95em}.lines-table td:last-child{border-bottom:none}.lines-table td:before{content:attr(data-label);font-weight:600;color:#666;text-align:left;margin-right:15px;flex-shrink:0}.lines-table .num{text-align:right}}.doc-detail__toast{position:fixed;top:20px;right:20px;padding:15px 25px;border-radius:6px;color:#fff;font-weight:600;box-shadow:0 4px 12px #00000026;z-index:1000;animation:slideIn .3s ease-out}.doc-detail__toast--success{background:#28a745}.doc-detail__toast--error{background:#dc3545}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .2s;display:inline-flex;align-items:center;gap:6px}.btn--validate{background:#28a745;color:#fff}.btn--validate:hover{background:#218838}.btn--reopen{background:#ffc107;color:#212529}.btn--reopen:hover{background:#e0a800}.btn:disabled{opacity:.6;cursor:not-allowed}.upload-mode-toggle{display:flex;gap:0;margin-bottom:20px;border:1px solid #ddd;border-radius:6px;overflow:hidden;width:fit-content}.upload-mode-toggle__btn{padding:8px 20px;border:none;background:#f8f9fa;color:#555;font-size:.9em;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.upload-mode-toggle__btn--active{background:#646cff;color:#fff}.upload-mode-toggle__btn:hover:not(.upload-mode-toggle__btn--active){background:#e9ecef}.bulk-counter{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:10px 14px;background:#f0f4f8;border-radius:8px}.bulk-counter__text{font-weight:600;font-size:.95em;white-space:nowrap}.bulk-counter__bar-bg{flex:1;height:8px;background:#ddd;border-radius:4px;overflow:hidden}.bulk-counter__bar{height:100%;background:#646cff;border-radius:4px;transition:width .3s}.bulk-jobs{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;max-height:400px;overflow-y:auto}.bulk-job{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#f8f9fa;border-radius:6px;border-left:4px solid #ddd;transition:border-color .2s}.bulk-job--QUEUED{border-left-color:#adb5bd}.bulk-job--UPLOADING{border-left-color:#646cff}.bulk-job--PROCESSING_OCR{border-left-color:#ffc107}.bulk-job--DONE{border-left-color:#28a745}.bulk-job--FAILED{border-left-color:#dc3545}.bulk-job--DUPLICATE{border-left-color:#ff9800}.bulk-job--REJECTED{border-left-color:#e91e63}.bulk-job__icon{font-size:1.3em;width:28px;text-align:center;flex-shrink:0}.bulk-job__info{flex:1;min-width:0}.bulk-job__name{font-weight:500;font-size:.9em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bulk-job__detail{font-size:.78em;color:#888;margin-top:1px}.bulk-job__detail--error{color:#dc3545}.bulk-job__progress-bg{width:80px;height:5px;background:#e0e0e0;border-radius:3px;overflow:hidden;flex-shrink:0}.bulk-job__progress{height:100%;border-radius:3px;transition:width .3s;background:#646cff}.bulk-job__progress--done{background:#28a745}.bulk-job__progress--fail{background:#dc3545}.bulk-job__progress--dup{background:#ff9800}.bulk-job__action{padding:4px 10px;border-radius:4px;border:none;font-size:.8em;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0}.bulk-job__action--view{background:#e8eaf6;color:#646cff}.bulk-job__action--view:hover{background:#c5cae9}.bulk-job__action--retry{background:#fff3e0;color:#e65100}.bulk-job__action--retry:hover{background:#ffe0b2}.bulk-job__action--remove{background:none;color:#999;font-size:1em;padding:2px 6px}.bulk-job__action--remove:hover{color:#c00}.bulk-summary{padding:16px;background:#f0f4f8;border-radius:8px;margin-bottom:16px}.bulk-summary h3{margin:0 0 10px;font-size:1.05em}.bulk-summary__stats{display:flex;gap:20px;flex-wrap:wrap}.bulk-summary__stat{text-align:center}.bulk-summary__stat-num{font-size:1.5em;font-weight:700;line-height:1}.bulk-summary__stat-num--done{color:#28a745}.bulk-summary__stat-num--dup{color:#ff9800}.bulk-summary__stat-num--fail{color:#dc3545}.bulk-summary__stat-num--rejected{color:#e91e63}.bulk-summary__stat-label{font-size:.75em;color:#888;text-transform:uppercase;letter-spacing:.04em}.bulk-actions{display:flex;gap:10px;margin-bottom:16px}.bulk-actions .btn--upload{flex:1}@media(max-width:480px){.bulk-job{flex-wrap:wrap}.bulk-job__progress-bg{width:100%;order:10}.bulk-summary__stats{gap:12px}}.upload-hidden-input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.upload-page{padding:20px;max-width:640px;margin:0 auto}.upload-page__back{display:inline-flex;align-items:center;gap:6px;color:#646cff;text-decoration:none;font-size:.95em;margin-bottom:16px}.upload-page__back:hover{color:#535bf2}.upload-page h1{font-size:1.4em;margin-bottom:20px}.upload-zone{border:2px dashed #bbb;border-radius:10px;padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:20px}.upload-zone:hover,.upload-zone--drag{border-color:#646cff;background:#646cff0d}.upload-zone__icon{font-size:2.5em;margin-bottom:8px}.upload-zone__label{font-size:.95em;color:#666}.upload-zone__label strong{color:#646cff}.upload-zone__hint{font-size:.8em;color:#999;margin-top:6px}.upload-preview{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f0f4f8;border-radius:8px;margin-bottom:16px}.upload-preview__icon{font-size:1.6em}.upload-preview__info{flex:1}.upload-preview__name{font-weight:600;font-size:.95em;word-break:break-all}.upload-preview__size{font-size:.8em;color:#888}.upload-preview__remove{background:none;border:none;font-size:1.2em;cursor:pointer;color:#999;padding:4px 8px;border-radius:4px}.upload-preview__remove:hover{background:#eee;color:#c00}.upload-progress{margin-bottom:16px}.upload-progress__bar-bg{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.upload-progress__bar{height:100%;background:#646cff;border-radius:3px;transition:width .3s}.upload-progress__bar--full{width:100%}.upload-progress__text{font-size:.85em;color:#666;margin-top:6px;text-align:center}.upload-page .btn--upload{width:100%;padding:12px;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:opacity .15s}.upload-page .btn--upload:hover:not(:disabled){background:#535bf2}.upload-page .btn--upload:disabled{opacity:.5;cursor:not-allowed}.upload-page__toast{padding:10px 16px;border-radius:6px;margin-bottom:16px;font-size:.9em;animation:uploadFadeIn .2s ease-in}.upload-page__toast--error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.upload-page__toast--success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}@keyframes uploadFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:overlayFadeIn .15s ease-out;padding:20px}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#fff;border-radius:12px;padding:24px;max-width:480px;width:100%;box-shadow:0 8px 32px #0003;animation:modalSlideIn .2s ease-out;max-height:90vh;overflow-y:auto}@keyframes modalSlideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-box h2{font-size:1.2em;margin:0 0 16px}.modal-box p{margin:0 0 12px;font-size:.95em;color:#555}.modal-field{margin-bottom:16px}.modal-field label{display:block;font-size:.85em;font-weight:600;margin-bottom:6px;color:#333}.modal-field select,.modal-field input[type=text]{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:6px;font-size:.95em;box-sizing:border-box}.modal-field select:focus,.modal-field input:focus{border-color:#646cff;outline:none;box-shadow:0 0 0 2px #646cff26}.modal-radios{display:flex;gap:16px;margin-bottom:16px}.modal-radio{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.95em}.modal-radio input{accent-color:#646cff}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.modal-btn{padding:10px 20px;border-radius:6px;border:none;font-size:.9em;font-weight:600;cursor:pointer;min-height:40px;transition:opacity .15s}.modal-btn:disabled{opacity:.5;cursor:not-allowed}.modal-btn--primary{background:#646cff;color:#fff}.modal-btn--primary:hover:not(:disabled){background:#535bf2}.modal-btn--success{background:#28a745;color:#fff}.modal-btn--success:hover:not(:disabled){background:#218838}.modal-btn--cancel{background:#e2e3e5;color:#333}.modal-btn--cancel:hover:not(:disabled){background:#d6d8db}.modal-btn--outline{background:transparent;border:1px solid #646cff;color:#646cff}.modal-btn--outline:hover:not(:disabled){background:#646cff14}.dup-info{background:#fff3cd;border:1px solid #ffeeba;border-radius:8px;padding:14px;margin-bottom:16px}.dup-info__row{display:flex;justify-content:space-between;font-size:.9em;padding:3px 0}.dup-info__row span:first-child{color:#856404;font-weight:500}@media(max-width:480px){.upload-zone{padding:28px 16px}.modal-box{padding:18px}.modal-actions{flex-direction:column}.modal-btn{width:100%}}.settings-page{padding:20px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.settings-section{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a;margin-bottom:30px}.settings-title{font-size:1.2rem;color:#2c3e50;margin-bottom:15px;border-bottom:2px solid #eee;padding-bottom:10px}.settings-table-container{overflow-x:auto}.settings-table{width:100%;border-collapse:collapse}.settings-table th,.settings-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.settings-table th{background-color:#f8f9fa;color:#666;font-weight:600}.status-badge{padding:4px 8px;border-radius:4px;font-size:.85rem;font-weight:500}.status-active{background-color:#e6f4ea;color:#1e7e34}.status-inactive{background-color:#f8f9fa;color:#6c757d}.action-btn{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;margin-right:8px;transition:background .2s}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}.btn-edit{background-color:#f0f0f0;color:#333}.btn-edit:hover{background-color:#e0e0e0}.btn-delete{background-color:#fff0f0;color:#d32f2f}.btn-delete:hover{background-color:#ffe0e0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:25px;border-radius:8px;width:100%;max-width:400px;box-shadow:0 4px 6px #0000001a}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#444}.form-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@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}
