body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:20px}.header{text-align:center;color:#fff;margin-bottom:40px}.header h1{font-size:36px;margin-bottom:10px}.header p{font-size:18px;opacity:.9}.upload-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 30px #0000001a;margin-bottom:30px}.upload-area{border:2px dashed #cbd5e0;border-radius:8px;padding:40px;text-align:center;transition:all .3s ease}.upload-label{cursor:pointer;display:block}.upload-label input[type=file]{display:none}.upload-icon{font-size:48px;margin-bottom:15px}.upload-text{font-size:18px;color:#4a5568;margin-bottom:8px}.upload-hint{font-size:14px;color:#718096}.file-info{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding:15px;background:#f7fafc;border-radius:8px}.file-size{font-size:14px;color:#718096;margin-top:4px}.action-buttons{display:flex;align-items:center;gap:15px;margin-top:20px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:#f56565;color:#fff;padding:8px 16px;font-size:14px}.btn-danger:hover{background:#e53e3e}.loading{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}.processing-time{color:#718096;font-size:14px}.error-message{margin-top:20px;padding:15px;background:#fed7d7;color:#c53030;border-radius:8px}.success-message{margin-top:20px;padding:15px;background:#c6f6d5;color:#22543d;border-radius:8px}.results-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 30px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.results-title{font-size:24px;font-weight:600;color:#2d3748}.results-count{background:#edf2f7;padding:6px 12px;border-radius:20px;font-size:14px;color:#4a5568}.image-card{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;transition:all .3s ease}.image-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #0000001a}.image-wrapper{aspect-ratio:4/3;background:#f7fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}.image-wrapper img{width:100%;height:100%;object-fit:contain}.image-meta{display:flex;gap:8px}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge-original{background:#e6fffa;color:#047481}.badge-annotated{background:#fef5e7;color:#8b6914}.editor-overlay[data-v-885cc024]{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000}.editor-container[data-v-885cc024]{background:#fff;border-radius:0;width:100vw;height:100vh;display:flex;flex-direction:column;box-shadow:none}.editor-header[data-v-885cc024]{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;border-bottom:1px solid #e5e7eb;background:#f8f9fa}.editor-header h3[data-v-885cc024]{margin:0;font-size:1rem;color:#2d3748}.close-btn[data-v-885cc024]{background:none;border:none;font-size:24px;cursor:pointer;color:#718096;padding:5px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:4px;transition:background .2s}.close-btn[data-v-885cc024]:hover{background:#f7fafc}.editor-toolbar[data-v-885cc024]{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid #e5e7eb;background:#fafafa;background:#f8fafc;flex-wrap:wrap}.tool-group[data-v-885cc024]{display:flex;align-items:center;gap:6px}.tool-label[data-v-885cc024]{font-size:12px;color:#4a5568;margin:0 4px;font-weight:500}.editor-toolbar button[data-v-885cc024]{width:28px;height:28px;border:1px solid #cbd5e0;background:#fff;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}.editor-toolbar button[data-v-885cc024]:hover:not(:disabled){background:#edf2f7;border-color:#a0aec0;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.editor-toolbar button.active[data-v-885cc024]{background:#667eea;color:#fff;border-color:#667eea}.editor-toolbar button[data-v-885cc024]:disabled{opacity:.4;cursor:not-allowed}.separator[data-v-885cc024]{width:1px;height:28px;background:#cbd5e0;margin:0 4px}.editor-toolbar input[type=color][data-v-885cc024]{width:32px;height:32px;border:1px solid #cbd5e0;border-radius:4px;cursor:pointer}.editor-toolbar input[type=range][data-v-885cc024]{width:80px;height:4px;outline:none;-webkit-appearance:none;background:#e2e8f0;border-radius:2px}.editor-toolbar input[type=range][data-v-885cc024]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#667eea;border-radius:50%;cursor:pointer}.editor-toolbar input[type=range][data-v-885cc024]::-moz-range-thumb{width:16px;height:16px;background:#667eea;border-radius:50%;cursor:pointer;border:none}.width-indicator[data-v-885cc024],.zoom-indicator[data-v-885cc024]{font-size:11px;color:#718096;min-width:40px;text-align:center}.zoom-controls[data-v-885cc024]{margin-left:auto}.canvas-container[data-v-885cc024]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f0f0f0;overflow:auto;padding:10px;position:relative}#fabric-canvas[data-v-885cc024]{box-shadow:0 4px 6px #0000001a;max-width:100%;max-height:calc(100% - 30px)}.canvas-help[data-v-885cc024]{position:absolute;bottom:10px;left:50%;transform:translate(-50%);background:#ffffffe6;padding:6px 12px;border-radius:6px;box-shadow:0 2px 8px #0000001a;color:#4a5568;font-size:12px;z-index:10}.editor-footer[data-v-885cc024]{padding:10px 15px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:10px;background:#f8f9fa}.btn[data-v-885cc024]{padding:8px 20px;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-save[data-v-885cc024]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-save[data-v-885cc024]:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-cancel[data-v-885cc024]{background:#e5e7eb;color:#4a5568}.btn-cancel[data-v-885cc024]:hover{background:#cbd5e0}.modal-overlay[data-v-148aa5dd]{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn-148aa5dd .3s ease}@keyframes fadeIn-148aa5dd{0%{opacity:0}to{opacity:1}}.modal-container[data-v-148aa5dd]{background:#fff;border-radius:16px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px #00000080;animation:slideUp-148aa5dd .3s ease;position:relative}@keyframes slideUp-148aa5dd{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close[data-v-148aa5dd]{position:absolute;top:15px;right:15px;background:#00000080;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10}.modal-close[data-v-148aa5dd]:hover{background:#000000b3;transform:scale(1.1)}.modal-image-wrapper[data-v-148aa5dd]{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto;background:#f8fafc;border-radius:16px 16px 0 0}.modal-image-wrapper img[data-v-148aa5dd]{max-width:100%;max-height:60vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 30px #0000001a}.modal-info[data-v-148aa5dd]{padding:20px 30px;border-bottom:1px solid #e5e7eb;background:#fff}.modal-info h3[data-v-148aa5dd]{font-size:1.5rem;color:#2d3748;margin-bottom:8px}.modal-info p[data-v-148aa5dd]{color:#718096;font-size:.95rem}.modal-actions[data-v-148aa5dd]{padding:20px 30px;background:#fff;border-radius:0 0 16px 16px;display:flex;justify-content:space-between;align-items:center;gap:20px}.format-selector[data-v-148aa5dd]{display:flex;align-items:center;gap:12px}.format-selector label[data-v-148aa5dd]{font-weight:600;color:#4a5568}.format-select[data-v-148aa5dd]{padding:8px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;color:#2d3748;background:#fff;cursor:pointer;transition:border-color .3s ease;min-width:150px}.format-select[data-v-148aa5dd]:focus{outline:none;border-color:#667eea}.action-buttons[data-v-148aa5dd]{display:flex;gap:12px}.btn[data-v-148aa5dd]{padding:10px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-download[data-v-148aa5dd]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-download[data-v-148aa5dd]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.btn-download[data-v-148aa5dd]:disabled{opacity:.5;cursor:not-allowed}.btn-secondary[data-v-148aa5dd]{background:#e5e7eb;color:#4a5568}.btn-secondary[data-v-148aa5dd]:hover{background:#cbd5e1}.btn-edit[data-v-148aa5dd]{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}.btn-edit[data-v-148aa5dd]:hover{transform:translateY(-2px);box-shadow:0 10px 20px #f59e0b66}.loading[data-v-148aa5dd]{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin-148aa5dd 1s ease-in-out infinite}@keyframes spin-148aa5dd{to{transform:rotate(360deg)}}@media (max-width: 768px){.modal-container[data-v-148aa5dd]{max-width:95vw;max-height:95vh}.modal-actions[data-v-148aa5dd]{flex-direction:column;gap:15px}.format-selector[data-v-148aa5dd]{width:100%;justify-content:space-between}.action-buttons[data-v-148aa5dd]{width:100%}.action-buttons .btn[data-v-148aa5dd]{flex:1}}.pdf-download-buttons{display:flex;gap:10px;margin-left:auto}.btn-pdf{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap;transition:background .3s}.btn-pdf:hover:not(:disabled){background:#45a049}.btn-pdf:disabled{background:#ccc;cursor:not-allowed}.btn-regenerate{padding:8px 16px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap;transition:all .3s;margin-right:10px}.btn-regenerate:hover:not(:disabled){background:linear-gradient(135deg,#f97316,#ea580c);transform:translateY(-1px)}.btn-regenerate:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.job-status{margin-top:20px}.status-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.QUEUED{background:#fef3c7;color:#92400e}.status-badge.PROCESSING{background:#dbeafe;color:#1e40af}.status-badge.COMPLETED{background:#d1fae5;color:#065f46}.status-badge.analysis-complete{background:#e0f2fe;color:#0369a1;font-weight:600}.status-badge.FAILED{background:#fee2e2;color:#991b1b}.status-badge.regenerating{background:#dbeafe;color:#1e40af;margin-left:8px;animation:pulse 1.5s infinite}.status-badge.regenerated{background:#d1fae5;color:#065f46;margin-left:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.status-badge.clickable{cursor:pointer;transition:all .2s ease}.status-badge.clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #00000026}.status-message{color:#64748b;font-size:14px;margin-bottom:12px}.progress-bar{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.annotated-section{margin-top:40px}.annotated-section h3{font-size:20px;font-weight:600;color:#2d3748;margin-bottom:20px}.history-button{position:absolute;right:20px;top:20px;padding:10px 20px;background:#fff3;color:#fff;border:2px solid white;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.history-button:hover{background:#ffffff4d;transform:translateY(-2px)}.result-link{margin-top:15px;text-align:center}.btn-link{display:inline-block;padding:8px 16px;background:#667eea;color:#fff;text-decoration:none;border-radius:6px;font-size:14px;transition:background .2s}.btn-link:hover{background:#5a67d8}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column}.modal-header{padding:20px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:20px;font-weight:600}.close-button{background:none;border:none;font-size:28px;cursor:pointer;color:#94a3b8}.modal-body{padding:20px;overflow-y:auto;flex:1}.empty-history{text-align:center;padding:40px;color:#94a3b8}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8fafc;border-radius:8px;transition:background .2s}.history-item:hover{background:#f1f5f9}.history-info{flex:1}.history-filename{font-weight:600;color:#1e293b;margin-bottom:4px}.history-date{font-size:13px;color:#64748b;margin-bottom:8px}.history-status .status-badge{font-size:11px}.view-button{padding:6px 14px;background:#667eea;color:#fff;text-decoration:none;border-radius:6px;font-size:13px;transition:background .2s;border:none;cursor:pointer}.view-button:hover{background:#5a67d8}.view-button.processing-button{background:#17a2b8}.view-button.processing-button:hover{background:#138496}.view-button.analysis-complete-button{background:#0369a1}.view-button.analysis-complete-button:hover{background:#075985}.view-button.completed-button{background:#28a745}.view-button.completed-button:hover{background:#218838}.completed-area{text-align:center;padding:60px 20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;border:2px dashed #28a745}.completion-icon{font-size:64px;margin-bottom:20px}.completion-text{font-size:24px;font-weight:600;color:#28a745;margin-bottom:10px}.completion-file{font-size:16px;color:#6c757d}.btn-success{background:#28a745;color:#fff;border:none;padding:12px 32px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s}.btn-success:hover{background:#218838;transform:translateY(-2px)}.header{position:relative}.mappings-section{margin-top:30px;background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.mappings-section h3{font-size:20px;font-weight:600;color:#2d3748;margin-bottom:15px}.mappings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px}.mapping-item{display:flex;align-items:center;padding:10px;background:#f8f9fa;border-radius:4px}.mapping-key{font-weight:700;color:#007bff}.mapping-arrow{margin:0 10px;color:#999}.mapping-value{flex:1}.file-info-compact{text-align:center;padding:10px;margin-bottom:10px;background:#f8f9fa;border-radius:8px}.file-info-compact .file-name{font-size:14px;color:#4a5568;font-weight:500}.mapping-section{margin-top:30px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.mapping-section h2{margin-bottom:20px;color:#1e293b}.mapping-info{margin-bottom:20px;padding:15px;background:#f8fafc;border-radius:6px;font-size:14px;color:#64748b}.mapping-table-container{display:flex;gap:20px;margin-bottom:30px}.mapping-table{overflow-x:auto}.mapping-table.two-column{flex:1}@media (max-width: 768px){.mapping-table-container{flex-direction:column;gap:10px}}.mapping-table table{width:100%;border-collapse:collapse;background:#fff}.mapping-table th{background:#f1f5f9;padding:6px 10px;text-align:left;font-weight:600;font-size:13px;color:#475569;border-bottom:2px solid #e2e8f0}.mapping-table td{padding:2px 8px;border-bottom:1px solid #e2e8f0;font-size:13px;vertical-align:middle}.mapping-table input[type=checkbox]{cursor:pointer;width:16px;height:16px}.mapping-table input[type=text]{width:100%;padding:3px 8px;border:1px solid #e2e8f0;border-radius:4px;font-size:13px;transition:border-color .2s}.mapping-table input[type=text]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-sm{padding:2px 6px;font-size:10px;line-height:1;min-height:20px;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center}.btn-sm.btn-icon{padding:1px;width:18px;height:18px;min-height:18px;font-size:16px;font-weight:700;border-radius:3px}.btn-sm.btn-danger{background:#ef4444;color:#fff;border:none;cursor:pointer}.btn-sm.btn-danger:hover{background:#dc2626}.add-mapping{margin-bottom:20px;padding:12px 15px;background:#f8fafc;border-radius:6px}.add-mapping-inline{display:flex;align-items:center;gap:15px}.add-mapping-inline h3{margin:0;font-size:14px;color:#334155;white-space:nowrap;min-width:fit-content}.add-mapping-form{display:flex;gap:10px;align-items:center;flex:1}.add-mapping-form .input-number{width:120px;padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;font-size:13px}.add-mapping-form .input-label{width:250px;padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;font-size:13px}.add-mapping-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.images-preview{margin-top:30px}.images-preview h3{margin-bottom:15px;font-size:18px;color:#334155}.images-preview .image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.images-preview .image-item{cursor:pointer;transition:transform .2s}.images-preview .image-item:hover{transform:scale(1.05)}.images-preview .image-item img{width:100%;height:150px;object-fit:contain;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;padding:5px}.images-preview .image-caption{margin-top:5px;font-size:12px;color:#64748b;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.annotated-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.annotated-header h3{margin:0;font-size:20px;color:#1f2937}.action-buttons{display:flex;gap:10px}.action-buttons .btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.action-buttons .btn-primary{background:#3b82f6;color:#fff}.action-buttons .btn-primary:hover{background:#2563eb}.action-buttons .btn-secondary{background:#6b7280;color:#fff}.action-buttons .btn-secondary:hover{background:#4b5563}.action-buttons-inline{display:inline-flex;gap:10px}.action-buttons-inline .btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.action-buttons-inline .btn-primary{background:#3b82f6;color:#fff}.action-buttons-inline .btn-primary:hover{background:#2563eb}.action-buttons-inline .btn-secondary{background:#6b7280;color:#fff}.action-buttons-inline .btn-secondary:hover{background:#4b5563}.previous-results{margin-bottom:30px;padding:20px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.previous-results h3{margin-bottom:15px;font-size:16px;color:#1f2937}.results-tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #e5e7eb}.results-tabs .tab{padding:10px 20px;background:none;border:none;color:#718096;font-weight:600;cursor:pointer;position:relative;transition:color .3s ease}.results-tabs .tab.active{color:#667eea}.results-tabs .tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#667eea}.home-button{position:absolute;left:20px;top:20px;background:#fff3;border:2px solid white;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home-button:hover{background:#ffffff4d;transform:translateY(-2px)}.job-result-container[data-v-11aba9b6]{max-width:1200px;margin:0 auto;padding:20px}.header[data-v-11aba9b6]{display:flex;align-items:center;gap:20px;margin-bottom:30px}.back-button[data-v-11aba9b6]{padding:8px 16px;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap}.back-button[data-v-11aba9b6]:hover{background:#5a6268}.loading[data-v-11aba9b6],.error[data-v-11aba9b6]{text-align:center;padding:40px}.spinner[data-v-11aba9b6]{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #007bff;border-radius:50%;animation:spin-11aba9b6 1s linear infinite;margin:0 auto 20px}@keyframes spin-11aba9b6{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-card[data-v-11aba9b6],.progress-card[data-v-11aba9b6]{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.status-info[data-v-11aba9b6]{display:grid;gap:10px;margin-top:15px}.status-item[data-v-11aba9b6]{display:flex;gap:10px}.label[data-v-11aba9b6]{font-weight:700;min-width:100px}.status-badge[data-v-11aba9b6]{padding:4px 12px;border-radius:4px;font-size:14px;font-weight:700}.status-pending[data-v-11aba9b6]{background:#ffc107;color:#000}.status-processing[data-v-11aba9b6]{background:#17a2b8;color:#fff}.status-completed[data-v-11aba9b6]{background:#28a745;color:#fff}.status-failed[data-v-11aba9b6]{background:#dc3545;color:#fff}.progress-bar[data-v-11aba9b6]{width:100%;height:30px;background:#f0f0f0;border-radius:15px;overflow:hidden;margin:15px 0}.progress-fill[data-v-11aba9b6]{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease}.results-section[data-v-11aba9b6]{margin-top:30px}.results-header[data-v-11aba9b6]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.results-title[data-v-11aba9b6]{font-size:24px;font-weight:600;color:#2d3748;margin:0}.results-count[data-v-11aba9b6]{background:#667eea;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600}.image-grid[data-v-11aba9b6]{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:24px;margin-bottom:30px}.image-card[data-v-11aba9b6]{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #00000012;transition:all .3s ease}.image-card[data-v-11aba9b6]:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.image-wrapper[data-v-11aba9b6]{position:relative;width:100%;height:200px;overflow:hidden}.image-wrapper img[data-v-11aba9b6]{width:100%;height:100%;object-fit:contain;background:#f8fafc;transition:transform .3s ease}.image-card:hover .image-wrapper img[data-v-11aba9b6]{transform:scale(1.05)}.image-info[data-v-11aba9b6]{padding:16px}.image-title[data-v-11aba9b6]{font-size:16px;font-weight:600;color:#2d3748;margin-bottom:8px}.image-meta[data-v-11aba9b6]{display:flex;gap:8px}.badge[data-v-11aba9b6]{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-original[data-v-11aba9b6]{background:#e0f2fe;color:#0277bd}.badge-annotated[data-v-11aba9b6]{background:#f3e5f5;color:#7b1fa2}.badge-edited[data-v-11aba9b6]{background:#fff3cd;color:#856404;border:1px solid #ffc107}.annotated-section[data-v-11aba9b6]{margin-top:40px}.annotated-section h3[data-v-11aba9b6]{font-size:20px;font-weight:600;color:#2d3748;margin:0}.section-header[data-v-11aba9b6]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.pdf-buttons[data-v-11aba9b6]{display:flex;gap:10px}.btn-pdf-original[data-v-11aba9b6]{padding:10px 20px;background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #6b72804d}.btn-pdf-original[data-v-11aba9b6]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6b728066}.btn-pdf-download[data-v-11aba9b6]{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.btn-pdf-download[data-v-11aba9b6]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-pdf-download[data-v-11aba9b6]:active,.btn-pdf-original[data-v-11aba9b6]:active{transform:translateY(0)}.btn-regenerate[data-v-11aba9b6]{padding:10px 20px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #f59e0b4d}.btn-regenerate[data-v-11aba9b6]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.btn-regenerate[data-v-11aba9b6]:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.loading[data-v-11aba9b6]{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin-11aba9b6 1s ease-in-out infinite}.regenerated-pdfs-section[data-v-11aba9b6]{margin-top:30px;background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.regenerated-pdfs-section h3[data-v-11aba9b6]{font-size:20px;font-weight:600;color:#2d3748;margin:0 0 20px}.pdf-list[data-v-11aba9b6]{display:flex;flex-direction:column;gap:12px}.pdf-item[data-v-11aba9b6]{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e2e8f0;transition:background .2s}.pdf-item[data-v-11aba9b6]:hover{background:#f1f5f9}.pdf-info[data-v-11aba9b6]{display:flex;align-items:center;gap:16px;flex:1}.pdf-filename[data-v-11aba9b6]{font-weight:600;color:#1f2937;flex:1}.pdf-date[data-v-11aba9b6]{color:#6b7280;font-size:14px}.edit-count[data-v-11aba9b6]{background:#fef3c7;color:#92400e;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.btn-download[data-v-11aba9b6]{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-download[data-v-11aba9b6]:hover{background:#2563eb;transform:translateY(-1px)}.mappings-section[data-v-11aba9b6]{margin-top:30px;background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.mappings-grid[data-v-11aba9b6]{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;margin-top:15px}.mapping-item[data-v-11aba9b6]{display:flex;align-items:center;padding:10px;background:#f8f9fa;border-radius:4px}.mapping-key[data-v-11aba9b6]{font-weight:700;color:#007bff}.mapping-arrow[data-v-11aba9b6]{margin:0 10px;color:#999}.mapping-value[data-v-11aba9b6]{flex:1}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.container{max-width:1200px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center}.header h1{font-size:2.5rem;margin-bottom:10px}.header p{font-size:1.1rem;opacity:.9}.upload-section{padding:40px;border-bottom:1px solid #e5e7eb}.upload-area{border:2px dashed #cbd5e1;border-radius:12px;padding:40px;text-align:center;transition:all .3s ease;background:#f8fafc}.upload-area.dragover{border-color:#667eea;background:#f0f4ff}.upload-area input[type=file]{display:none}.upload-label{cursor:pointer;display:inline-block}.upload-icon{font-size:3rem;color:#667eea;margin-bottom:20px}.upload-text{font-size:1.2rem;color:#4a5568;margin-bottom:10px}.upload-hint{font-size:.9rem;color:#718096}.file-info{margin-top:20px;padding:15px;background:#f0f4ff;border-radius:8px;display:flex;align-items:center;justify-content:space-between}.file-name{font-weight:600;color:#2d3748}.file-size{color:#718096;font-size:.9rem}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.action-buttons{margin-top:30px;display:flex;gap:15px;justify-content:center;align-items:center}.processing-time{color:#6b7280;font-size:14px;font-weight:500;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.results-section{padding:40px}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.results-title{font-size:1.8rem;color:#2d3748}.results-count{background:#667eea;color:#fff;padding:8px 16px;border-radius:20px;font-weight:600}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.image-card{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .3s ease;background:#fff}.image-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.image-wrapper{position:relative;padding-top:75%;background:#f8fafc}.image-wrapper img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain}.image-info{padding:15px}.image-title{font-weight:600;color:#2d3748;margin-bottom:8px}.image-meta{display:flex;justify-content:space-between;font-size:.9rem;color:#718096}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600}.badge-original{background:#dbeafe;color:#1e40af}.badge-annotated{background:#d1fae5;color:#065f46}.error-message{background:#fee2e2;color:#991b1b;padding:15px;border-radius:8px;margin-top:20px;display:flex;align-items:center;gap:10px}.success-message{background:#d1fae5;color:#065f46;padding:15px;border-radius:8px;margin-top:20px;display:flex;align-items:center;gap:10px}.tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #e5e7eb}.tab{padding:10px 20px;background:none;border:none;color:#718096;font-weight:600;cursor:pointer;position:relative;transition:color .3s ease}.tab.active{color:#667eea}.tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#667eea}
