*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--blue-800: #1e40af;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--green-100: #dcfce7;--green-600: #16a34a;--green-700: #15803d;--amber-100: #fef3c7;--amber-600: #d97706;--amber-700: #b45309;--red-100: #fee2e2;--red-600: #dc2626;--red-700: #b91c1c;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5;color:var(--gray-800);background-color:var(--gray-50)}body{min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:linear-gradient(135deg,var(--blue-700),var(--blue-800));color:#fff;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}.app-header h1{font-size:20px;font-weight:600;letter-spacing:-.01em}.app-version{font-size:12px;font-weight:400;opacity:.6}.header-actions{display:flex;gap:8px}.app-main{flex:1;padding:24px;max-width:1400px;width:100%;margin:0 auto}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s,box-shadow .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background-color:#fff;color:var(--blue-700);box-shadow:var(--shadow-sm)}.btn-primary:hover{background-color:var(--blue-50);box-shadow:var(--shadow-md)}.btn-secondary{background-color:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-secondary:hover{background-color:#ffffff40}.btn-success{background-color:#16a34a;color:#fff;border:1px solid #15803d}.btn-success:hover{background-color:#15803d}.drop-zone{border:2px dashed var(--gray-300);border-radius:var(--radius-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background-color .2s,box-shadow .2s;background-color:#fff;margin-bottom:24px}.drop-zone:hover{border-color:var(--blue-400, #60a5fa);background-color:var(--blue-50)}.drop-zone.drag-over{border-color:var(--blue-500);background-color:var(--blue-100);box-shadow:0 0 0 4px #3b82f626}.drop-zone.disabled{opacity:.5;cursor:not-allowed;border-color:var(--gray-200);background-color:var(--gray-50)}.drop-zone.disabled:hover{border-color:var(--gray-200);background-color:var(--gray-50)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--gray-400)}.drop-zone.drag-over .drop-zone-content{color:var(--blue-600)}.drop-zone:hover .drop-zone-content{color:var(--blue-500)}.drop-zone-title{font-size:16px;font-weight:600;color:var(--gray-700)}.drop-zone.drag-over .drop-zone-title{color:var(--blue-700)}.drop-zone-subtitle{font-size:13px;color:var(--gray-400)}.progress-container{background:#fff;border-radius:var(--radius-md);padding:16px 20px;margin-bottom:24px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-file{font-weight:600;font-size:13px;color:var(--gray-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:50%}.progress-detail{font-size:12px;color:var(--gray-500)}.progress-bar-track{width:100%;height:8px;background-color:var(--gray-100);border-radius:4px;overflow:hidden;margin-bottom:4px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue-500),var(--blue-600));border-radius:4px;transition:width .3s ease;min-width:0}.progress-percent{text-align:right;font-size:12px;font-weight:600;color:var(--blue-600)}.results-table-wrapper{background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);overflow-x:auto}.results-table{width:100%;border-collapse:collapse;font-size:13px}.results-table thead{position:sticky;top:0;z-index:10}.results-table th{background:var(--gray-50);color:var(--gray-600);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:10px 12px;text-align:left;border-bottom:2px solid var(--gray-200);white-space:nowrap}.results-table td{padding:8px 12px;border-bottom:1px solid var(--gray-100);vertical-align:middle}.results-table tbody tr:nth-child(2n){background-color:var(--gray-50)}.results-table tbody tr:hover{background-color:var(--blue-50)}.results-empty{text-align:center;padding:40px;color:var(--gray-400);font-size:15px}.cell-editable{cursor:pointer;border-radius:var(--radius-sm);transition:background-color .15s;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-editable:hover{background-color:var(--blue-100);outline:1px solid var(--blue-300, #93c5fd)}.cell-empty{color:var(--gray-300);font-style:italic}.cell-editing{padding:4px 6px}.cell-input{width:100%;padding:4px 8px;font-size:13px;font-family:inherit;border:2px solid var(--blue-500);border-radius:var(--radius-sm);outline:none;background:#fff;box-shadow:0 0 0 3px #3b82f626}.source-cell{font-size:12px;color:var(--gray-500);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-button{background:none;border:1px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;padding:2px 6px;font-size:14px;line-height:1;transition:background-color .15s,border-color .15s}.preview-button:hover{background-color:var(--blue-50);border-color:var(--blue-300, #93c5fd)}.delete-button{background:none;border:1px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;padding:2px 6px;font-size:14px;line-height:1;transition:background-color .15s,border-color .15s}.delete-button:hover{background-color:var(--red-100);border-color:var(--red-600)}.confidence-cell{text-align:center}.confidence-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.confidence-badge.high{background-color:var(--green-100);color:var(--green-700)}.confidence-badge.medium{background-color:var(--amber-100);color:var(--amber-700)}.confidence-badge.low{background-color:var(--red-100);color:var(--red-700)}.extraction-method-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.3px;vertical-align:middle}.extraction-method-badge.vision{background-color:var(--blue-100);color:var(--blue-700)}.extraction-method-badge.regex{background-color:var(--gray-100);color:var(--gray-600)}.preview-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.preview-modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:900px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.preview-header h3{font-size:15px;font-weight:600;color:var(--gray-800)}.preview-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--gray-400);padding:4px 8px;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.preview-close:hover{color:var(--gray-700);background-color:var(--gray-200)}.preview-body{display:flex;gap:16px;padding:16px 20px;overflow-y:auto;flex:1;min-height:0}.preview-image-container{flex:0 0 250px;display:flex;align-items:flex-start;justify-content:center;background:var(--gray-100);border-radius:var(--radius-md);padding:8px}.preview-image{max-width:100%;height:auto;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.preview-no-image{display:flex;align-items:center;justify-content:center;width:100%;min-height:200px;color:var(--gray-400);font-size:13px}.preview-ocr-text{flex:1;min-width:0}.preview-ocr-text h4{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);margin-bottom:8px}.preview-ocr-text pre{font-size:11px;line-height:1.6;color:var(--gray-600);background:var(--gray-50);padding:12px;border-radius:var(--radius-md);border:1px solid var(--gray-200);overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:350px;overflow-y:auto;font-family:SF Mono,Cascadia Code,Fira Code,Consolas,monospace}.preview-fields{padding:12px 20px 16px;border-top:1px solid var(--gray-200);background:var(--gray-50)}.preview-fields h4{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);margin-bottom:8px}.preview-fields dl{display:grid;grid-template-columns:auto 1fr auto 1fr auto 1fr;gap:4px 12px;font-size:13px}.preview-fields dt{font-weight:600;color:var(--gray-600);white-space:nowrap}.preview-fields dd{color:var(--gray-800);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.error-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-bottom:16px;background-color:var(--red-100);color:var(--red-700);border-radius:var(--radius-md);border:1px solid #fca5a5;font-size:13px;font-weight:500}.error-banner button{background:none;border:none;color:var(--red-600);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:var(--radius-sm);transition:background-color .15s}.error-banner button:hover{background-color:#dc26261a}.settings-modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:520px;width:100%;overflow:hidden}.settings-body{padding:20px;display:flex;flex-direction:column;gap:16px}.settings-presets{display:flex;align-items:center;gap:8px}.btn-preset{padding:4px 12px;font-size:12px;background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer}.btn-preset:hover{background:var(--blue-50);border-color:var(--blue-300, #93c5fd);color:var(--blue-700)}.settings-field{display:flex;flex-direction:column;gap:4px}.settings-label{font-size:12px;font-weight:600;color:var(--gray-600)}.settings-input{padding:8px 12px;font-size:13px;font-family:inherit;border:1px solid var(--gray-300);border-radius:var(--radius-sm);outline:none;transition:border-color .15s,box-shadow .15s}.settings-input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f61a}.settings-test-result{padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:500}.settings-test-result.success{background:var(--green-100);color:var(--green-700)}.settings-test-result.error{background:var(--red-100);color:var(--red-700)}.settings-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:4px}.settings-actions-right{display:flex;gap:8px}.btn-test{padding:6px 14px;font-size:12px;background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-sm);cursor:pointer}.btn-test:hover:not(:disabled){background:var(--gray-200)}.btn-test:disabled{opacity:.5;cursor:not-allowed}.btn-save{padding:6px 20px;font-size:13px;font-weight:600;background:var(--blue-600);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer}.btn-save:hover:not(:disabled){background:var(--blue-700)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-danger{padding:6px 14px;font-size:12px;background:var(--red-100);color:var(--red-700);border:1px solid #fca5a5;border-radius:var(--radius-sm);cursor:pointer}.btn-danger:hover{background:#fecaca}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.update-banner{display:flex;align-items:center;gap:12px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:500}.update-banner .btn-update{padding:4px 16px;background:#fff;color:#667eea;border:none;border-radius:4px;font-weight:600;cursor:pointer;font-size:13px}.update-banner .btn-update:hover{background:#f0f0f0}.update-banner .btn-dismiss{margin-left:auto;background:none;border:none;color:#fffc;cursor:pointer;font-size:16px;padding:4px 8px}.update-banner .btn-dismiss:hover{color:#fff}.update-progress-track{flex:1;height:6px;background:#ffffff4d;border-radius:3px;overflow:hidden}.update-progress-fill{height:100%;background:#fff;border-radius:3px;transition:width .3s ease}
