:root{--brand-50: #e8f4ee;--brand-100: #c5e3d1;--brand-200: #9ed0b2;--brand-300: #6fbb8e;--brand-400: #3fa570;--brand-500: #1a7a4a;--brand-600: #156440;--brand-700: #104f33;--brand-800: #0c3a25;--brand-900: #082617}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#1a1a2e}code{font-family:JetBrains Mono,Courier New,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f3f5}::-webkit-scrollbar-thumb{background:#ced4da;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#adb5bd}.App{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.App-header{background:#fff;padding:1.5rem 2rem;text-align:center;border-bottom:1px solid #e9ecef;box-shadow:0 1px 3px #0000000f}.App-header-inner{max-width:1800px;margin:0 auto;display:flex;align-items:center;justify-content:center;position:relative}.App-header h1{color:#1a1a2e;font-size:2rem;margin-bottom:0;font-weight:700;letter-spacing:-.02em}.help-btn{position:absolute;right:0;display:flex;align-items:center;gap:.4rem;background:#f1f3f5;border:1px solid #dee2e6;border-radius:10px;padding:.5rem 1rem;font-size:.88rem;font-weight:600;color:#495057;cursor:pointer;transition:all .2s ease}.help-btn:hover{background:#e7f5ff;border-color:#228be6;color:#228be6;box-shadow:0 2px 8px #228be61f}.help-btn svg{flex-shrink:0}.back-btn{position:absolute;left:0;display:flex;align-items:center;gap:.4rem;background:#f1f3f5;border:1px solid #dee2e6;border-radius:10px;padding:.5rem 1rem;font-size:.88rem;font-weight:600;color:#495057;cursor:pointer;transition:all .2s ease}.back-btn:hover{background:#fff3e0;border-color:#f57c00;color:#e65100;box-shadow:0 2px 8px #f57c001f}.back-btn svg{flex-shrink:0}.App-header p{color:#6c757d;font-size:1rem}.App-main{flex:1;padding:2rem;max-width:1800px;width:100%;margin:0 auto}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#495057}.spinner{width:48px;height:48px;border:3px solid #e9ecef;border-top-color:#228be6;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{font-size:1.2rem;margin-bottom:.5rem;color:#343a40}.loading-subtext{color:#868e96;font-size:.95rem!important}.error-container{background-color:#fff5f5;border:1px solid #ffc9c9;border-radius:12px;padding:2rem;text-align:center;max-width:600px;margin:2rem auto}.error-container h2{color:#e03131;margin-bottom:1rem}.error-container p{color:#c92a2a;margin-bottom:1.5rem;font-size:1.05rem}.result-container{animation:fadeIn .4s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e9ecef}.result-header h2{color:#1a1a2e;font-size:1.75rem;font-weight:700}.reset-btn{background-color:#fff;color:#495057;border:1px solid #dee2e6;padding:.65rem 1.25rem;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:600}.reset-btn:hover{background-color:#f8f9fa;border-color:#228be6;color:#228be6;box-shadow:0 2px 8px #228be61f}.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;min-height:600px}@media (max-width: 1200px){.result-grid{grid-template-columns:1fr}}.settings-panel{max-width:800px;margin:2rem auto;background-color:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e9ecef;box-shadow:0 1px 3px #0000000a}.settings-panel h3{color:#1a1a2e;margin-bottom:1rem;font-size:1.1rem}.setting-item{margin:1rem 0;display:flex;align-items:center;gap:1rem}.setting-item label{display:flex;align-items:center;gap:.5rem;color:#495057;cursor:pointer;font-size:.95rem}.setting-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#228be6}.bbox-select{background-color:#fff;color:#495057;border:1px solid #dee2e6;padding:.5rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer;min-width:200px}.bbox-select:focus{outline:none;border-color:#228be6;box-shadow:0 0 0 3px #228be61f}.folder-results{width:100%}.folder-summary{background-color:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border-left:4px solid #228be6;box-shadow:0 1px 3px #0000000a}.folder-summary h3{color:#1a1a2e;margin-bottom:1rem}.folder-summary p{color:#495057;margin:.5rem 0;font-size:1.05rem}.folder-summary .success{color:#2b8a3e;font-weight:700}.folder-summary .error{color:#e03131;font-weight:700}.file-selector{background-color:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border-left:4px solid #228be6;box-shadow:0 1px 3px #0000000a}.file-selector label{color:#1a1a2e;font-size:1.05rem;font-weight:600;display:block;margin-bottom:.8rem}.file-select-dropdown{width:100%;padding:.8rem 1rem;background-color:#fff;color:#495057;border:1px solid #dee2e6;border-radius:8px;font-size:.95rem;cursor:pointer;transition:all .2s ease}.file-select-dropdown:hover{border-color:#228be6}.file-select-dropdown:focus{outline:none;border-color:#228be6;box-shadow:0 0 0 3px #228be61f}.folder-files-list{display:flex;flex-direction:column;gap:1.5rem}.file-result-item{background-color:#fff;border-radius:12px;padding:1.5rem;border-left:4px solid #dee2e6;box-shadow:0 1px 3px #0000000a}.file-result-item.success{border-left-color:#2b8a3e}.file-result-item.failed{border-left-color:#e03131}.file-result-header{margin-bottom:1rem}.file-result-header h4{color:#1a1a2e;margin-bottom:.5rem;font-size:1.2rem}.file-path{color:#868e96;font-size:.9rem;font-style:italic}.error-message{background-color:#fff5f5;border:1px solid #ffc9c9;border-radius:8px;padding:1rem;color:#c92a2a}.extracted-data-section{background-color:#fff;border-radius:12px;padding:1.5rem;margin-top:1.5rem;margin-bottom:1.5rem;border-left:4px solid #228be6;box-shadow:0 1px 3px #0000000a}.extracted-data-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.extracted-data-header h3{color:#1a1a2e;margin:0;font-weight:700}.export-excel-btn{background-color:#228be6;color:#fff;border:none;padding:.7rem 1.4rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.data-table-container{overflow-x:auto;margin-top:1rem}.data-table{width:100%;border-collapse:collapse;background-color:#fff;border-radius:8px;overflow:hidden}.data-table thead{background-color:#f1f3f5}.data-table th{padding:.85rem 1rem;text-align:left;color:#495057;font-weight:700;border-bottom:2px solid #dee2e6;white-space:nowrap;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}.data-table td{padding:.75rem 1rem;color:#343a40;border-bottom:1px solid #f1f3f5;font-size:.95rem}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table tbody tr:last-child td{border-bottom:none}.App-footer{background-color:#fff;padding:1.25rem;text-align:center;color:#868e96;border-top:1px solid #e9ecef;margin-top:auto;font-size:.9rem}.ocr-engine-selector{background:#fff;border:1px solid #e9ecef;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000000a;animation:fadeIn .4s ease-in}.ocr-engine-selector h3{color:#1a1a2e;text-align:center;margin-bottom:1.5rem;font-size:1.3rem;font-weight:700}.engine-options{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.engine-option{flex:1;min-width:250px;max-width:350px;background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:1rem}.engine-option:hover{border-color:#228be6;background:#f0f7ff;box-shadow:0 4px 12px #228be61a}.engine-option.selected{border-color:#228be6;background:#e7f5ff;box-shadow:0 0 0 3px #228be61f}.engine-option input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:#228be6}.engine-name{display:flex;flex-direction:column;gap:.3rem;flex:1}.engine-name strong{color:#1a1a2e;font-size:1.05rem;font-weight:700}.engine-name small{color:#868e96;font-size:.9rem}.engine-option.selected .engine-name strong{color:#1864ab}@media (max-width: 768px){.engine-options{flex-direction:column}.engine-option{max-width:100%}}.file-upload-container{max-width:800px;margin:2rem auto}.upload-mode-toggle{display:flex;gap:.75rem;margin-bottom:2rem;justify-content:center}.mode-btn{background-color:#fff;color:#6c757d;border:1px solid #dee2e6;padding:.7rem 1.75rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.mode-btn:hover{border-color:#228be6;color:#228be6;background:#f0f7ff}.mode-btn.active{background-color:#228be6;color:#fff;border-color:#228be6}.dropzone{border:2px dashed #ced4da;border-radius:16px;padding:3rem;text-align:center;cursor:pointer;transition:all .2s ease;background-color:#fff;min-height:300px;display:flex;align-items:center;justify-content:center}.dropzone:hover{border-color:#228be6;background-color:#f0f7ff}.dropzone-active{border-color:#228be6;background-color:#e7f5ff;transform:scale(1.01)}.dropzone-content{width:100%}.upload-icon{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.dropzone-text{font-size:1.35rem;color:#343a40;margin-bottom:.5rem;font-weight:600}.dropzone-subtext{color:#868e96;margin:1rem 0;font-size:1rem}.browse-btn{background-color:#228be6;color:#fff;border:none;padding:.85rem 1.75rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;margin:1rem .5rem}.browse-btn:hover{background-color:#1c7ed6;box-shadow:0 4px 12px #228be640}.export-excel-btn{background-color:#228be6;color:#fff;border:none;padding:.85rem 1.75rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;margin:1rem .5rem}.export-excel-btn:hover{background-color:#1c7ed6;box-shadow:0 4px 12px #228be640}.dropzone-formats{color:#adb5bd;font-size:.85rem;margin-top:1rem}.upload-info{background-color:#fff;border-radius:12px;padding:1.75rem;margin-top:2rem;border-left:4px solid #228be6;box-shadow:0 1px 3px #0000000a}.upload-info h3{color:#1a1a2e;margin-bottom:1rem;font-size:1.15rem;font-weight:700}.upload-info ul{list-style:none;padding:0}.upload-info li{color:#495057;padding:.5rem 0 .5rem 1.5rem;position:relative;font-size:.95rem;line-height:1.6}.upload-info li:before{content:"✓";position:absolute;left:0;color:#2b8a3e;font-weight:700}.preview-panel{background-color:#fff;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;height:100%;border:1px solid #e9ecef;box-shadow:0 1px 3px #0000000a}.panel-header h3{color:#1a1a2e;margin:0 0 .4rem;font-size:1.15rem;font-weight:700}.bbox-toggle{display:flex;align-items:center}.bbox-toggle label{display:flex;align-items:center;gap:.5rem;color:#495057;cursor:pointer;font-size:.9rem}.bbox-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#228be6}.filename{color:#868e96;font-size:.85rem;word-break:break-word}.preview-content{flex:1;overflow:auto;background-color:#f1f3f5;display:flex;align-items:center;justify-content:center;min-height:500px}.pdf-preview{width:100%;height:100%;min-height:500px}.image-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:1rem}.preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 2px 8px #0000001a}.preview-footer{background-color:#f8f9fa;padding:.85rem 1.25rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #e9ecef;flex-wrap:wrap;gap:.5rem}.page-indicator,.token-count,.bbox-stats{color:#868e96;font-size:.85rem}.bbox-stats,.token-count{color:#228be6;font-weight:600}.result-panel{background-color:#fff;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;height:100%;border:1px solid #e9ecef;box-shadow:0 1px 3px #0000000a}.panel-header{background-color:#f8f9fa;padding:1rem 1.25rem;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.panel-header h3{color:#1a1a2e;margin:0;font-size:1.15rem;font-weight:700}.header-actions{display:flex;gap:.5rem}.action-btn{background-color:#f1f3f5;border:1px solid #dee2e6;padding:.4rem .85rem;border-radius:6px;cursor:pointer;font-size:1.1rem;transition:all .2s ease}.action-btn:hover{background-color:#e9ecef;border-color:#228be6}.tabs{display:flex;background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.tab{flex:1;background:none;border:none;padding:.85rem;color:#868e96;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease;border-bottom:2px solid transparent}.tab:hover{background-color:#fff;color:#495057}.tab-active{color:#228be6!important;border-bottom-color:#228be6!important;background-color:#fff}.result-content{flex:1;overflow:auto;background-color:#fff;padding:1.5rem}.text-content{color:#343a40;line-height:1.8}.text-preview{font-family:Times New Roman,Times,serif;font-size:1rem;line-height:1.6;color:#212529;background-color:#fff;padding:2rem 2.25rem;border-radius:10px;border:1px solid #dee2e6;overflow-x:auto;word-wrap:break-word}.text-preview .md-para{margin:0 0 .25rem;line-height:1.6;color:#212529;font-family:Times New Roman,Times,serif;letter-spacing:normal}.text-preview .md-para:last-child{margin-bottom:0}.text-preview .md-para+.md-table-wrap{margin-top:0}.text-preview .md-table-wrap+.md-para{margin-top:.25rem}.text-preview .md-para strong{font-weight:700;color:#1a1a2e}.text-preview .md-para em{font-style:italic;color:#495057}.text-preview .md-code{font-family:JetBrains Mono,Courier New,monospace;font-size:.85em;background:#f1f3f5;border:1px solid #dee2e6;border-radius:3px;padding:.1em .4em}.text-preview .md-table-wrap{overflow-x:auto;margin:0;border-radius:8px;box-shadow:0 1px 4px #00000014}.text-preview .md-table{width:100%;border-collapse:collapse;font-size:.9rem;font-family:Times New Roman,Times,serif;background:#fff;table-layout:auto}.text-preview .md-table td,.text-preview .md-table th{font-family:Times New Roman,Times,serif}.text-preview .md-table tr:first-child td,.text-preview .md-table thead th{background-color:#e9ecef;font-weight:700;color:#343a40;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;padding:.6rem .875rem;border:1px solid #ced4da;white-space:nowrap}.text-preview .md-table td{padding:.5rem .875rem;border:1px solid #dee2e6;vertical-align:top;color:#212529}.text-preview .md-table tbody tr:nth-child(2n) td{background-color:#f8f9fa}.text-preview .md-table tbody tr:hover td{background-color:#e7f5ff}.text-preview .md-annotation{display:flex;align-items:flex-start;gap:.6rem;margin:.5rem 0;padding:.5rem .875rem;border-radius:6px;font-size:.875rem;line-height:1.5}.text-preview .md-ann-label{flex-shrink:0;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .5rem;border-radius:4px;margin-top:.1rem}.text-preview .md-ann-body{white-space:pre-wrap;color:#495057;font-size:.875rem}.text-preview .md-annotation-logo{background:#fff9db;border-left:3px solid #fab005}.text-preview .md-annotation-logo .md-ann-label{background:#fab005;color:#fff}.text-preview .md-annotation-attestation{background:#e7f5ff;border-left:3px solid #339af0}.text-preview .md-annotation-attestation .md-ann-label{background:#339af0;color:#fff}.text-preview .md-annotation-figure,.text-preview .md-annotation-scancode,.text-preview .md-annotation-marginalia{background:#f8f9fa;border-left:3px solid #adb5bd}.text-preview .md-annotation-figure .md-ann-label,.text-preview .md-annotation-scancode .md-ann-label,.text-preview .md-annotation-marginalia .md-ann-label{background:#adb5bd;color:#fff}.text-preview .ocr-table,.text-preview table:not(.md-table){width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem;background:#fff}.text-preview .ocr-table th,.text-preview table:not(.md-table) th{background:#e9ecef;font-weight:700;font-size:.82rem;padding:.55rem .875rem;border:1px solid #ced4da;text-align:left}.text-preview .ocr-table td,.text-preview table:not(.md-table) td{padding:.5rem .875rem;border:1px solid #dee2e6;vertical-align:top}.text-preview .ocr-table tbody tr:nth-child(2n) td,.text-preview table:not(.md-table) tbody tr:nth-child(2n) td{background:#f8f9fa}.text-preview .ocr-table tbody tr:hover td,.text-preview table:not(.md-table) tbody tr:hover td{background:#e7f5ff}.markdown-preview{font-family:Georgia,Times New Roman,Times,serif;font-size:1.05rem;line-height:1.7;color:#1a1a2e;background-color:#f8f9fa;padding:1.5rem;border-radius:8px;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;margin:0;border:1px solid #e9ecef;max-width:100%}.markdown-preview p{margin:.75rem 0;line-height:1.7}.markdown-preview table{width:100%;border-collapse:collapse;margin:1.5rem 0;background-color:#fff;border-radius:8px;overflow:hidden;font-size:.95rem}.markdown-preview thead{background-color:#f1f3f5}.markdown-preview th,.markdown-preview td{padding:.7rem 1rem;border:1px solid #e9ecef;text-align:left;vertical-align:middle}.markdown-preview th{background-color:#f1f3f5;color:#495057;font-weight:700;text-transform:uppercase;font-size:.8rem;letter-spacing:.04em}.markdown-preview tbody tr{transition:background-color .15s ease}.markdown-preview tbody tr:nth-child(2n){background-color:#f8f9fa}.markdown-preview tbody tr:hover{background-color:#e7f5ff}.markdown-preview tbody tr.total-row td{font-weight:700;background-color:#e7f5ff;color:#1864ab}.markdown-preview td:has(>*:only-child):not(:has(>table)){text-align:right}.markdown-preview .header{background-color:#e7f5ff;color:#1864ab;font-weight:600}.markdown-preview h1,.markdown-preview h2,.markdown-preview h3{color:#1a1a2e;margin-top:1.5rem;margin-bottom:.75rem}.markdown-preview strong{color:#1a1a2e;font-weight:700}.metadata-content{padding:1rem}.metadata-grid{display:grid;gap:.75rem}.metadata-item{background-color:#f8f9fa;padding:1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center;border-left:4px solid #e9ecef}.metadata-label{color:#868e96;font-weight:600;font-size:.9rem}.metadata-value{color:#343a40;font-weight:600}.metadata-badge{padding:.35rem .75rem;border-radius:6px;font-weight:600;font-size:.85rem}.badge-success{background-color:#d3f9d8;color:#2b8a3e}.badge-warning{background-color:#fff3bf;color:#e67700}.badge-info{background-color:#d0ebff;color:#1864ab}.badge-default{background-color:#f1f3f5;color:#868e96}.raw-content{padding:0}.json-code{background-color:#212529;color:#51cf66;padding:1.5rem;border-radius:8px;overflow-x:auto;font-family:JetBrains Mono,Courier New,monospace;font-size:.85rem;line-height:1.6;margin:0}.chunk-anchor{border:none;border-top:1px dashed #dee2e6;margin:.5rem 0}.fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0009;display:flex;align-items:center;justify-content:center;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fullscreen-modal{background:#fff;border-radius:12px;width:95vw;height:92vh;max-width:1400px;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.fullscreen-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;background:#f8f9fa;border-bottom:1px solid #e9ecef;flex-shrink:0}.fullscreen-header h3{margin:0;font-size:1.05rem;font-weight:600;color:#343a40}.fullscreen-actions{display:flex;gap:.4rem}.fullscreen-actions .close-btn{font-size:1.15rem;font-weight:700;color:#868e96;line-height:1}.fullscreen-actions .close-btn:hover{color:#e03131;background:#fff5f5;border-color:#e03131}.fullscreen-body{flex:1;overflow:auto;padding:2rem 2.5rem}.fullscreen-body .text-preview{border:none;border-radius:0;padding:0;max-width:100%}.fullscreen-body .md-table-wrap{overflow-x:auto}.fullscreen-body .md-table{min-width:600px}.landing-annotation{display:flex;align-items:baseline;gap:.5rem;margin:.4rem 0;padding:.4rem .75rem;border-radius:6px;font-size:.875rem;line-height:1.5}.annotation-label{flex-shrink:0;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .45rem;border-radius:4px}.annotation-body{white-space:pre-wrap;color:#495057}.landing-annotation-logo{background:#fff3cd;border-left:3px solid #ffc107}.landing-annotation-logo .annotation-label{background:#ffc107;color:#212529}.landing-annotation-attestation{background:#e8f4fd;border-left:3px solid #339af0}.landing-annotation-attestation .annotation-label{background:#339af0;color:#fff}.landing-annotation-figure,.landing-annotation-scancode,.landing-annotation-marginalia{background:#f8f9fa;border-left:3px solid #adb5bd}.landing-annotation-figure .annotation-label,.landing-annotation-scancode .annotation-label,.landing-annotation-marginalia .annotation-label{background:#adb5bd;color:#fff}.table-wrapper{overflow-x:auto;margin:.5rem 0}.table-wrapper table{border-collapse:collapse;width:100%;font-size:.875rem}.table-wrapper td,.table-wrapper th{border:1px solid #dee2e6;padding:.35rem .6rem;vertical-align:top}.layout-viewer{background-color:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000000a}.layout-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-left h3{color:#1a1a2e;margin:0 0 .5rem;font-size:1.3rem;font-weight:700}.layout-source{display:inline-block;background:#f1f3f5;color:#868e96;padding:.3rem .8rem;border-radius:6px;font-size:.85rem;border:1px solid #e9ecef}.layout-controls{display:flex;gap:1rem;align-items:center}.bbox-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#495057;font-size:.95rem}.bbox-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#228be6}.type-filter{background:#fff;color:#343a40;border:1px solid #dee2e6;border-radius:8px;padding:.5rem 1rem;font-size:.95rem;cursor:pointer;transition:all .2s}.type-filter:hover{border-color:#228be6}.type-filter:focus{outline:none;border-color:#228be6;box-shadow:0 0 0 3px #228be61a}.layout-content{position:relative;background:#f1f3f5;border-radius:8px;overflow:hidden;min-height:400px;display:flex;justify-content:center;align-items:center;border:1px solid #e9ecef}.image-container{position:relative;width:100%;display:flex;justify-content:center;align-items:center}.document-image{max-width:100%;max-height:70vh;width:auto;height:auto;display:block;object-fit:contain}.bbox-canvas{position:absolute;top:0;left:0;pointer-events:none;z-index:10}.layout-stats{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.stats-title{color:#1a1a2e;font-weight:700;margin-right:.5rem;font-size:1rem}.stat-badge{display:inline-flex;align-items:center;gap:.4rem;background:#f1f3f5;color:#495057;padding:.4rem .8rem;border-radius:6px;font-size:.9rem;border:1px solid #dee2e6;transition:all .2s}.stat-badge:hover{transform:translateY(-2px);box-shadow:0 2px 6px #00000014}.stat-dot{width:8px;height:8px;border-radius:50%}.stat-badge.total{background:#d0ebff;border-color:#228be6;color:#1864ab;font-weight:600}.no-layout-message{text-align:center;color:#868e96;padding:2rem;background:#f8f9fa;border-radius:8px;margin:1rem 0;border:1px solid #e9ecef}.no-layout-message p{margin:0;font-size:1rem}@media (max-width: 768px){.layout-header{flex-direction:column;align-items:flex-start}.layout-controls{width:100%;justify-content:space-between}.type-filter{flex:1}.layout-stats{justify-content:center}}.ob-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0f172a99;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;animation:obFadeIn .35s ease;padding:1rem}.ob-overlay--exit{animation:obFadeOut .35s ease forwards}@keyframes obFadeIn{0%{opacity:0}to{opacity:1}}@keyframes obFadeOut{0%{opacity:1}to{opacity:0}}.ob-modal{background:#fff;border-radius:20px;width:100%;max-width:560px;box-shadow:0 25px 60px #00000040;overflow:hidden;animation:obSlideUp .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}.ob-modal--exit{animation:obSlideDown .35s ease forwards}@keyframes obSlideUp{0%{opacity:0;transform:translateY(40px) scale(.96)}}@keyframes obSlideDown{to{opacity:0;transform:translateY(40px) scale(.96)}}.ob-progress{height:4px;background:#e9ecef}.ob-progress-fill{height:100%;background:linear-gradient(90deg,#228be6,#6366f1);border-radius:0 2px 2px 0;transition:width .4s ease}.ob-steps-indicator{display:flex;justify-content:center;gap:8px;padding:1.25rem 0 0}.ob-dot{width:10px;height:10px;border-radius:50%;border:2px solid #dee2e6;background:#fff;cursor:pointer;transition:all .25s ease;padding:0}.ob-dot--active{border-color:#228be6;background:#228be6;transform:scale(1.2)}.ob-dot--done{border-color:#228be6;background:#dbe4ff}.ob-content{padding:1.5rem 2rem 1rem;text-align:center;animation:obContentIn .35s ease}@keyframes obContentIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.ob-icon-badge{font-size:2.5rem;margin-bottom:.5rem;line-height:1}.ob-title{font-size:1.5rem;font-weight:800;color:#1a1a2e;margin:0 0 .25rem;letter-spacing:-.02em}.ob-subtitle{font-size:1rem;color:#228be6;font-weight:600;margin:0 0 1rem}.ob-desc{font-size:.95rem;color:#495057;line-height:1.6;margin:1rem 0 0}.ob-actions{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem 1.5rem;gap:.75rem}.ob-actions-right{display:flex;gap:.5rem}.ob-btn{border:none;border-radius:10px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.ob-btn--skip{background:none;color:#868e96}.ob-btn--skip:hover{color:#495057}.ob-btn--prev{background:#f1f3f5;color:#495057}.ob-btn--prev:hover{background:#e9ecef}.ob-btn--next{background:linear-gradient(135deg,#228be6,#6366f1);color:#fff;box-shadow:0 4px 12px #228be64d}.ob-btn--next:hover{box-shadow:0 6px 20px #228be666;transform:translateY(-1px)}.ob-visual{margin:.75rem auto;max-width:420px}.ob-app-frame{border-radius:12px;overflow:hidden;border:1px solid #e0e0e0;box-shadow:0 4px 20px #00000014}.ob-app-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f0f0f0;border-bottom:1px solid #e0e0e0}.ob-app-bar-dot{width:10px;height:10px;border-radius:50%}.ob-app-bar-dot:nth-child(1){background:#ff5f57}.ob-app-bar-dot:nth-child(2){background:#febc2e}.ob-app-bar-dot:nth-child(3){background:#28c840}.ob-app-bar-url{margin-left:auto;font-size:.7rem;color:#888;background:#fff;padding:2px 10px;border-radius:4px;font-family:monospace}.ob-app-body{position:relative;height:160px;overflow:hidden;background:#fafafa}.ob-sample-img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:brightness(.92)}.ob-app-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#228be6bf,#6366f1bf);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.ob-app-badge{background:#fff;color:#228be6;font-weight:900;font-size:1.6rem;padding:6px 20px;border-radius:10px;letter-spacing:.05em;box-shadow:0 4px 12px #00000026}.ob-app-tagline{color:#fff;font-size:.85rem;font-weight:600;letter-spacing:.02em}.ob-upload-demo{display:flex;flex-direction:column;gap:.75rem}.ob-upload-zone{border:2px dashed #228be6;border-radius:14px;padding:1.25rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;background:#f0f7ff}.ob-upload-icon{animation:obBounce 2s ease infinite}@keyframes obBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.ob-upload-label{font-weight:700;color:#228be6;font-size:.9rem}.ob-upload-formats{display:flex;gap:.4rem}.ob-upload-formats span{background:#dbe4ff;color:#364fc7;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:5px}.ob-upload-file-preview{display:flex;align-items:center;gap:.75rem;background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:.5rem .75rem}.ob-upload-thumb{width:48px;height:36px;object-fit:cover;border-radius:6px;border:1px solid #e9ecef}.ob-upload-file-info{flex:1;display:flex;flex-direction:column}.ob-upload-file-info strong{font-size:.8rem;color:#1a1a2e}.ob-upload-file-info span{font-size:.7rem;color:#868e96}.ob-upload-check{color:#51cf66;font-weight:900;font-size:1.1rem;background:#ebfbee;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}.ob-result-demo{display:flex;gap:.75rem}.ob-result-left{flex:1;min-width:0}.ob-result-img-wrap{position:relative;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0}.ob-result-doc-img{width:100%;display:block;max-height:180px;object-fit:cover;object-position:top}.ob-bbox{position:absolute;border:2px solid;border-radius:2px;pointer-events:none;animation:obPulse 2.5s ease infinite}@keyframes obPulse{0%,to{opacity:.6}50%{opacity:1}}.ob-bbox--header{top:2%;left:5%;width:90%;height:22%;border-color:#ff6b6b}.ob-bbox--table{top:30%;left:3%;width:94%;height:30%;border-color:#228be6}.ob-bbox--notes{top:65%;left:3%;width:80%;height:28%;border-color:#51cf66}.ob-result-right{flex:1;min-width:0;display:flex;flex-direction:column;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0;overflow:hidden}.ob-result-tabs{display:flex;border-bottom:1px solid #e9ecef}.ob-result-tab{padding:6px 10px;font-size:.7rem;font-weight:600;color:#868e96;cursor:default;border-bottom:2px solid transparent}.ob-result-tab.active{color:#228be6;border-bottom-color:#228be6}.ob-result-text{padding:.5rem .65rem;flex:1}.ob-text-line{font-size:.65rem;color:#495057;margin:0 0 3px;line-height:1.4}.ob-text-bold{font-weight:700;color:#1a1a2e;font-size:.7rem}.ob-text-dim{color:#adb5bd}.ob-export-demo{display:flex;flex-direction:column;gap:.75rem;align-items:center}.ob-export-table{width:100%;background:#fff;border-radius:10px;border:1px solid #e0e0e0;overflow:hidden}.ob-export-row{display:flex}.ob-export-row span{flex:1;padding:.45rem .5rem;font-size:.72rem;color:#495057;border-bottom:1px solid #f1f3f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ob-export-row span:first-child{flex:2}.ob-export-header{background:#f1f3f5}.ob-export-header span{font-weight:700;color:#1a1a2e;text-transform:uppercase;letter-spacing:.03em;font-size:.65rem}.ob-export-actions{display:flex;gap:.5rem}.ob-export-btn{display:flex;align-items:center;gap:5px;border:none;border-radius:8px;padding:.45rem 1rem;font-size:.78rem;font-weight:700;cursor:default}.ob-export-btn--copy{background:#f1f3f5;color:#495057}.ob-export-btn--excel{background:linear-gradient(135deg,#228be6,#1c7ed6);color:#fff;box-shadow:0 3px 10px #228be64d}@media (max-width: 600px){.ob-modal{max-width:100%;border-radius:16px}.ob-content{padding:1rem 1.25rem .75rem}.ob-title{font-size:1.2rem}.ob-result-demo{flex-direction:column}.ob-actions{flex-direction:column;gap:.5rem}.ob-actions-right{width:100%;justify-content:center}}.hg-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;background:#0f172a66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:hgFadeIn .25s ease}@keyframes hgFadeIn{0%{opacity:0}to{opacity:1}}.hg-panel{position:fixed;top:0;right:0;z-index:8001;width:min(820px,92vw);height:100vh;background:#fff;box-shadow:-8px 0 30px #0000001f;display:flex;flex-direction:column;animation:hgSlideIn .35s cubic-bezier(.16,1,.3,1)}@keyframes hgSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.hg-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#f8f9fa,#fff)}.hg-header h2{font-size:1.2rem;font-weight:800;color:#1a1a2e;margin:0}.hg-close{width:36px;height:36px;border:none;background:#f1f3f5;border-radius:10px;font-size:1rem;cursor:pointer;color:#495057;transition:all .2s;display:flex;align-items:center;justify-content:center}.hg-close:hover{background:#e9ecef;color:#1a1a2e}.hg-body{flex:1;display:flex;overflow:hidden}.hg-nav{width:200px;min-width:200px;border-right:1px solid #e9ecef;padding:.75rem 0;overflow-y:auto;background:#f8f9fa}.hg-nav-item{width:100%;display:flex;align-items:center;gap:.6rem;padding:.7rem 1.25rem;border:none;background:none;cursor:pointer;font-size:.88rem;font-weight:600;color:#495057;text-align:left;transition:all .15s;border-left:3px solid transparent}.hg-nav-item:hover{background:#e9ecef;color:#1a1a2e}.hg-nav-item--active{background:#e7f5ff;color:#228be6;border-left-color:#228be6}.hg-nav-icon{font-size:1.1rem}.hg-nav-label{flex:1}.hg-nav-item--onboarding{margin-top:.75rem;border-top:1px solid #e9ecef;padding-top:.75rem;background:linear-gradient(135deg,#e7f5ff,#f3f0ff);color:#228be6;font-weight:600}.hg-nav-item--onboarding:hover{background:linear-gradient(135deg,#d0ebff,#e5dbff);color:#1971c2}.hg-content{flex:1;padding:1.75rem 2rem;overflow-y:auto;animation:hgContentIn .3s ease}@keyframes hgContentIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hg-section-title{font-size:1.35rem;font-weight:800;color:#1a1a2e;margin:0 0 1.25rem;display:flex;align-items:center;gap:.5rem}.hg-text{font-size:.95rem;line-height:1.7;color:#495057;margin:0 0 1.25rem}.hg-features{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.hg-feature{display:flex;align-items:flex-start;gap:.6rem;background:#f8f9fa;border-radius:10px;padding:.85rem;border:1px solid #e9ecef}.hg-feature-icon{font-size:1.4rem;flex-shrink:0}.hg-feature div{display:flex;flex-direction:column;gap:.15rem}.hg-feature strong{font-size:.9rem;color:#1a1a2e}.hg-feature span{font-size:.82rem;color:#868e96}.hg-compare{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.hg-compare-card{background:#fff;border-radius:12px;padding:1rem;border:2px solid #e9ecef;transition:border-color .2s}.hg-compare-card:hover{border-color:var(--accent)}.hg-compare-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.hg-compare-header strong{font-size:1.05rem;color:#1a1a2e}.hg-compare-badge{font-size:.7rem;color:#fff;padding:.2rem .6rem;border-radius:6px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.hg-compare-item{font-size:.85rem;padding:.35rem 0;display:flex;gap:.4rem;align-items:flex-start;color:#495057}.hg-compare-item--pro span{color:#2b8a3e;font-weight:700}.hg-compare-item--con span{color:#e8590c;font-weight:700}.hg-compare-cons{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #f1f3f5}.hg-steps{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.hg-step{display:flex;gap:1rem;align-items:flex-start}.hg-step-num{width:36px;height:36px;min-width:36px;border-radius:10px;background:linear-gradient(135deg,#228be6,#6366f1);color:#fff;font-weight:800;font-size:.95rem;display:flex;align-items:center;justify-content:center}.hg-step-body strong{display:block;font-size:.95rem;color:#1a1a2e;margin-bottom:.2rem}.hg-step-body p{font-size:.88rem;color:#495057;line-height:1.6;margin:0}.hg-info-box{background:#e7f5ff;border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.25rem;border-left:4px solid #228be6}.hg-info-header{font-weight:700;color:#1a1a2e;margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem}.hg-info-box ul{margin:0;padding-left:1.25rem}.hg-info-box li{font-size:.88rem;color:#495057;line-height:1.7}.hg-areas{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.hg-area{background:#f8f9fa;border-radius:10px;padding:1rem;border:1px solid #e9ecef}.hg-area-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.6rem}.hg-area-header span{font-size:1.2rem}.hg-area-header strong{font-size:.9rem;color:#1a1a2e}.hg-area ul{margin:0;padding-left:1.1rem}.hg-area li{font-size:.85rem;color:#495057;line-height:1.65}.hg-tips{display:flex;flex-direction:column;gap:.75rem}.hg-tip{display:flex;gap:.75rem;align-items:flex-start;background:#fffbeb;border-radius:10px;padding:.85rem 1rem;border:1px solid #fef3c7}.hg-tip-icon{font-size:1.3rem;flex-shrink:0}.hg-tip strong{display:block;font-size:.9rem;color:#1a1a2e;margin-bottom:.15rem}.hg-tip p{font-size:.85rem;color:#495057;line-height:1.55;margin:0}@media (max-width: 700px){.hg-panel{width:100vw}.hg-nav{width:56px;min-width:56px}.hg-nav-label{display:none}.hg-nav-item{justify-content:center;padding:.7rem}.hg-content{padding:1.25rem}.hg-features,.hg-compare,.hg-areas{grid-template-columns:1fr}}
