@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--fc-cyan: #00AEEF;--fc-red: #ED1C24;--fc-lime: #C8D400;--accent: var(--fc-cyan);--accent-dark: #0090c8;--muted: #6b7280;--border: #e5e7eb;--surface: #ffffff;--bg: #f3f4f6;--text: #111827;--text-secondary: #374151;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100vh}body{margin:0}a,button,label{-webkit-tap-highlight-color:transparent}.login-shell{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 24px #00000012;padding:40px 36px 36px;display:grid;gap:24px}.login-logo-wrap{display:flex;justify-content:center}.login-logo{height:36px;width:auto}.login-header{display:grid;gap:4px;text-align:center}.login-title{margin:0;font-size:1.3rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.login-subtitle{margin:0;font-size:.875rem;color:var(--muted)}.login-form{display:grid;gap:14px}.field{display:grid;gap:6px}.field-label-row{display:flex;align-items:center;justify-content:space-between}.field-label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.field-input{width:100%;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:7px;background:var(--surface);font-family:inherit;font-size:.9rem;color:var(--text);outline:none;transition:border-color .13s ease,box-shadow .13s ease}.field-input::placeholder{color:#9ca3af}.field-input:focus{border-color:var(--fc-cyan);box-shadow:0 0 0 3px #00aeef1f}.field-input:disabled{background:#f9fafb;color:var(--muted);cursor:not-allowed}.forgot-link{background:none;border:none;padding:0;font-family:inherit;font-size:.78rem;font-weight:500;color:var(--fc-cyan);cursor:pointer;text-decoration:underline;text-underline-offset:.15em}.forgot-link:hover{color:var(--accent-dark)}.login-error{margin:0;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;font-size:.84rem;font-weight:500;color:#991b1b}.login-helper{margin:-2px 0 0;font-size:.82rem;line-height:1.5;color:var(--muted)}.btn-primary{width:100%;height:42px;padding:0 16px;border:none;border-radius:7px;background:var(--fc-cyan);color:#fff;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .13s ease,opacity .13s ease}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{width:100%;height:40px;padding:0 16px;border:1px solid var(--border);border-radius:7px;background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .13s ease}.btn-ghost:hover:not(:disabled){background:var(--bg)}.btn-ghost:disabled{opacity:.55;cursor:not-allowed}.login-confirm{display:grid;gap:10px;text-align:center}.confirm-icon{font-size:2.2rem;line-height:1;margin-bottom:4px}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:var(--bg)}.app-sidebar{width:260px;min-height:100vh;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 18px 20px;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:100}.app-logo{height:auto;width:100%;max-width:160px;display:block;margin-bottom:20px;object-fit:contain}.header-icon{width:14px;height:14px;display:block;flex-shrink:0}.btn-upload-new{display:block;width:100%;padding:9px 14px;border:none;border-radius:8px;background:linear-gradient(135deg,var(--fc-cyan),#0284c7);box-shadow:0 4px 14px #00aeef38;color:#fff;font:inherit;font-size:.8rem;font-weight:700;letter-spacing:.01em;cursor:pointer;text-align:center;transition:background .15s,box-shadow .15s}.btn-upload-new:hover{background:linear-gradient(135deg,#009fe0,#0369a1);box-shadow:0 6px 18px #0284c747}.sidebar-nav{display:flex;flex-direction:column;gap:1px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.sidebar-step{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:7px;border:none;background:transparent;font:inherit;text-align:left;width:100%;cursor:pointer;transition:background .12s}.sidebar-step:hover:not(:disabled){background:var(--bg)}.sidebar-step:disabled{opacity:.35;cursor:default}.sidebar-step-badge{width:20px;height:20px;border-radius:50%;background:#f3f4f6;color:#9ca3af;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,color .12s}.sidebar-step.is-active .sidebar-step-badge{background:#2563eb;color:#fff}.sidebar-step.is-done .sidebar-step-badge{background:#10b981;color:#fff}.sidebar-step.is-error .sidebar-step-badge{background:#dc2626;color:#fff}.sidebar-step-label{font-size:.8rem;font-weight:500;color:#9ca3af;transition:color .12s}.sidebar-step.is-active .sidebar-step-label,.sidebar-step.is-done .sidebar-step-label,.sidebar-step.is-error .sidebar-step-label{color:var(--text-secondary)}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:1px;padding-top:16px;border-top:1px solid var(--border)}.sidebar-footer-btn{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:7px;border:none;background:transparent;font:inherit;font-size:.8rem;font-weight:500;color:var(--muted);cursor:pointer;width:100%;text-align:left;transition:background .12s,color .12s}.sidebar-footer-btn:hover{background:var(--bg);color:var(--text)}.app-body{padding:28px 20px 56px}.steps{width:min(760px,100%);margin:0 auto;display:grid;gap:12px}.step{border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 14px 40px #0f172a0a;overflow:hidden;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.step.is-active{border-color:#2563eb47;box-shadow:0 0 0 1px #2563eb14,0 18px 44px #2563eb14}.step.is-done{border-color:#d1fae5;box-shadow:0 16px 36px #0596690f}.step.is-error{border-color:#fecaca;box-shadow:0 0 0 1px #ef444414,0 18px 40px #ef444414}.step.is-locked{opacity:.48;pointer-events:none}.step-header{display:flex;align-items:stretch;gap:12px}.step-toggle{flex:1;min-width:0;padding:18px 20px;display:flex;align-items:center;gap:14px;border:0;background:transparent;color:inherit;cursor:pointer;text-align:left;font:inherit;transition:background .15s ease}.step-toggle:hover{background:#0f172a05}.step-toggle:focus-visible{outline:2px solid rgba(37,99,235,.45);outline-offset:-2px}.step-toggle:disabled{cursor:default}.step-hdr-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;padding:18px 20px 18px 0}.step-badge{width:30px;height:30px;border-radius:999px;background:#f3f4f6;color:#4b5563;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s ease,color .15s ease}.step.is-active .step-badge{background:#2563eb;color:#fff}.step.is-done .step-badge{background:#10b981;color:#fff}.step.is-error .step-badge{background:#dc2626;color:#fff}.step-title-block{flex:1;min-width:0}.step-num{margin:0;font-size:.62rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);line-height:1}.step-heading{margin:0;font-size:.92rem;font-weight:700;color:var(--text);line-height:1.3}.step-pill{font-size:.72rem;font-weight:500;padding:3px 8px;border-radius:20px;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.step-pill.is-ok{background:#ecfdf5;color:#065f46}.step-pill.is-warn{background:#fffbeb;color:#92400e}.step-pill.is-error{background:#fef2f2;color:#b91c1c}.step-chevron{display:inline-flex;align-items:center;justify-content:center;width:24px;color:var(--muted);font-size:1rem;line-height:1}.step-body{padding:0 20px 20px;display:grid;gap:16px;overflow:visible;opacity:1;max-height:none;transform:translateY(0);transition:max-height .22s ease,opacity .18s ease,transform .22s ease,padding .22s ease}.step-body.is-expanded{max-height:none}.step-body.is-collapsed{padding-top:0;padding-bottom:0;gap:0;opacity:0;max-height:0;overflow:hidden;transform:translateY(-6px)}.card{border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:0 1px 3px #0000000d}.batch-stats{display:flex;flex-wrap:wrap;gap:24px;padding:10px 0;border-top:1px solid var(--border)}.batch-stats>div{display:flex;flex-direction:column;gap:2px}.dropzone{min-height:180px;display:grid;place-items:center;gap:6px;padding:28px;border:1.5px dashed var(--border);border-radius:8px;background:#fafafa;text-align:center;cursor:pointer;transition:border-color .13s ease,background .13s ease}.dropzone:focus-visible{outline:2px solid var(--fc-cyan);outline-offset:2px}.dropzone.is-active{border-color:var(--fc-cyan);background:#f0faff}.dropzone--locked{cursor:not-allowed;opacity:.55;border-style:dashed;border-color:var(--border);background:var(--surface-2, #f8f9fa);pointer-events:none}.dropzone.is-busy{cursor:progress;border-color:#bfdbfe;background:#f8fbff}.dropzone-title{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.dropzone-copy{font-size:.85rem;color:var(--muted)}.inline-link{color:var(--fc-cyan);text-decoration:underline;text-underline-offset:.15em}.helper-text{margin:0;font-size:.8rem;color:var(--muted)}.action-row{display:flex;flex-wrap:wrap;gap:10px}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:8px;border:1px solid transparent;font:inherit;font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .12s ease,border-color .12s ease,color .12s ease}.primary-button{background:var(--accent);color:#fff}.primary-button:hover:not(:disabled){background:var(--accent-dark)}.secondary-button{background:#fff;color:var(--text-secondary);border-color:var(--border)}.secondary-button:hover:not(:disabled){background:#f9fafb}.primary-button:disabled,.secondary-button:disabled{opacity:.55;cursor:not-allowed}.summary-grid,.integration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}.summary-grid div,.integration-grid div{padding:12px 14px;display:grid;gap:4px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.summary-grid div.has-issue,.integration-grid div.has-issue{border-color:#fecaca;background:#fef2f2}.summary-label{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.summary-grid strong,.integration-grid strong{font-size:1.2rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.tenant-picker{display:grid;gap:6px}.tenant-picker select{min-height:40px;border:1px solid var(--border);border-radius:8px;padding:0 12px;font:inherit;color:var(--text-secondary);background:#fff}.meta-block{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.meta-block p{margin:0;font-size:.85rem;color:var(--text-secondary)}.meta-block p+p{margin-top:5px}.summary-note-card{padding:16px;display:grid;gap:12px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.processing-card{padding:24px 28px;display:grid;gap:16px}.processing-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.processing-percentage{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.progress-track{height:12px;overflow:hidden;border-radius:999px;background:#e5eef7}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#0ea5e9,#0284c7);transition:width .22s ease}.processing-meta{display:grid;gap:6px}.verification-summary-card{border-color:#c7e6ff;background:#f4faff}.summary-note-header{display:grid;gap:3px}.summary-note-header h3{margin:0;font-size:.875rem;font-weight:700;color:var(--text)}.summary-note-header p{margin:0;font-size:.8rem;color:var(--muted)}.summary-note-list{display:grid;gap:6px}.summary-note-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:7px;background:var(--surface)}.summary-note-item.is-issue{border-color:#fecaca;background:#fef2f2}.summary-note-number{margin:0 0 2px;font-size:.72rem;font-weight:600;color:var(--fc-cyan);letter-spacing:.02em}.summary-note-title{margin:0;font-size:.875rem;font-weight:600;color:var(--text)}.summary-note-amount{margin:0;font-size:.875rem;font-weight:700;color:var(--text-secondary);white-space:nowrap}.issues-card{border-color:#fecaca;background:#fff7f7}.issue-pill-list,.issue-tag-list{display:flex;flex-wrap:wrap;gap:6px}.issue-pill,.issue-tag{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:999px;font-size:.73rem;font-weight:600;letter-spacing:.01em;border:1px solid #fecaca;background:#fef2f2;color:#991b1b}.invoice-list-toolbar{display:flex;justify-content:flex-end}.invoice-list-toggle-all{appearance:none;border:none;background:none;padding:0;font:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s ease}.invoice-list-toggle-all:hover{color:var(--text)}.invoice-list{display:grid;gap:10px}.invoice-row-meta{margin:3px 0 0;font-size:.72rem;color:var(--muted)}.invoice-row{padding:16px;display:grid;gap:12px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.invoice-row.has-supplier-mismatch,.invoice-row.has-unresolved-fields,.invoice-row.has-review{border-color:#fde68a;background:#fffbeb}.invoice-row.has-issue{border-color:#fca5a5;background:#fff8f8}.credit-note-eyebrow{margin:0 0 3px;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#6d28d9}.invoice-main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.invoice-number{margin:0 0 2px;font-size:.72rem;font-weight:600;color:var(--fc-cyan);letter-spacing:.03em}.invoice-supplier{margin:0;font-size:.9rem;font-weight:600;color:var(--text);line-height:1.3}.status-badge{display:inline-flex;align-items:center;min-height:24px;padding:0 9px;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.status-ready{background:#e6f9ef;color:#166534}.status-individual{background:#e0f2fe;color:#0369a1}.status-review{background:#fffbeb;color:#92400e}.status-blocked,.status-missing,.status-missing_source_page{background:#fef2f2;color:#991b1b}.status-badge--credit-note{background:#ddd6fe;color:#5b21b6;border:1px solid #8b5cf6;font-weight:700}.invoice-meta{margin:0;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.invoice-meta dt{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.invoice-meta dd{margin:4px 0 0;font-size:.875rem;color:var(--text-secondary)}.amount-primary{font-weight:600}.amount-strong{font-weight:700}.validation-note{margin:0;font-size:.8rem;font-weight:600;color:#991b1b}.invoice-actions{display:flex;flex-wrap:wrap;gap:10px}.verification-banner{padding:12px 14px;border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:12px}.verification-banner.is-pass{background:#edfdf4;border:1px solid #bbf7d0}.verification-banner.is-fail{background:#fff7f7;border:1px solid #fecaca}.verification-banner p{margin:0;font-size:.85rem;color:var(--text-secondary)}.invoice-details{display:grid;gap:14px;padding:16px;border:1px solid var(--border);border-radius:8px;background:#fcfcfd}.invoice-action-bar{display:flex;align-items:center;gap:8px;padding-top:10px;border-top:1px solid var(--border)}.invoice-collapse-trigger{appearance:none;border:none;background:none;padding:0;font:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s ease}.invoice-collapse-trigger:hover{color:var(--text)}.invoice-collapse-trigger:not(:last-child):after{content:"·";margin-left:8px;color:var(--border)}.invoice-remove-trigger{appearance:none;border:none;background:none;padding:0;font:inherit;font-size:.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s ease}.invoice-remove-trigger:hover{color:#dc2626}.invoice-remove-prompt{font-size:.78rem;font-weight:600;color:var(--text)}.invoice-remove-confirm{appearance:none;border:1px solid #dc2626;border-radius:6px;background:#dc2626;color:#fff;padding:4px 12px;font:inherit;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .12s ease}.invoice-remove-confirm:hover{background:#b91c1c}.verification-columns{display:block}.verification-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.verification-card{padding:14px;border:1px solid var(--border);border-radius:8px;background:#fff}.verification-card h4{margin:0 0 10px;font-size:.85rem;color:var(--text)}.verification-card-heading h4{margin-bottom:0}.verification-detail-pair{display:contents}.verification-detail-cell{min-height:78px}.supplier-pick-cell{appearance:none;border:none;font:inherit;color:inherit;text-align:left;cursor:pointer;position:relative;transition:box-shadow .12s ease,border-color .12s ease}.supplier-pick-cell:hover{box-shadow:0 0 0 2px #22c55e59}.supplier-pick-cell:focus-visible{outline:2px solid #22c55e;outline-offset:2px}.supplier-pick-cell--selected{background:#f0fdf4!important;border:2px solid #22c55e!important}.supplier-pick-cell--unselected{background:#f9fafb!important;border-color:#e5e7eb!important;opacity:.65}.supplier-pick-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.supplier-pick-badge{display:inline-flex;align-items:center;padding:1px 7px;border-radius:999px;background:#16a34a;color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.supplier-pick-hint{font-size:.65rem;font-weight:600;color:#b45309;opacity:.7;white-space:nowrap;text-transform:none;letter-spacing:0}.supplier-pick-cell:hover .supplier-pick-hint{opacity:1}.supplier-xero-card{grid-column:1 / -1}.supplier-xero-card.is-loading{background:#f8fafc;border-color:#cbd5e1}.supplier-xero-card.is-found{background:#f0fdf4;border-color:#bbf7d0}.supplier-xero-card.is-mapped{background:#ecfdf5;border-color:#86efac}.supplier-xero-card.is-warning{background:#fffbeb;border-color:#fde68a}.supplier-xero-card.is-error{background:#fef2f2;border-color:#fecaca}.supplier-xero-row{display:block}.supplier-xero-info{display:grid;gap:10px;min-width:0}.supplier-xero-contact-row{display:flex;align-items:flex-start;justify-content:flex-start;gap:12px;flex-wrap:wrap}.supplier-xero-contact-copy{display:grid;gap:4px;min-width:0}.supplier-xero-contact-actions{margin-left:auto;display:flex;align-items:flex-start}.supplier-xero-label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.supplier-xero-value{font-size:.92rem;font-weight:700;line-height:1.4;color:var(--text)}.supplier-xero-note{margin:0;font-size:.74rem;line-height:1.45;color:#7c2d12}.supplier-contact-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.supplier-xero-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.supplier-xero-action{appearance:none;min-height:34px;padding:0 14px;border:1px solid #d7dee8;border-radius:999px;background:#fff;color:#0f172a;font:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:border-color .12s ease,background-color .12s ease,color .12s ease}.supplier-xero-action:hover{background:#f8fafc;border-color:#b8c4d6;color:#111827}.supplier-xero-action.is-selected{border-color:#0f766e;background:#ecfeff;color:#115e59}.supplier-contact-option{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:var(--text);font-size:.78rem;font-weight:600;line-height:1;padding:8px 12px;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease}.supplier-contact-option:hover{border-color:#60a5fa;color:#1d4ed8}.supplier-contact-option.is-selected{border-color:#15803d;background:#dcfce7;color:#166534}.supplier-department-editor{display:grid;gap:12px;margin-top:2px}.supplier-department-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.supplier-department-label{font-size:.68rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.supplier-department-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.supplier-department-input{width:100%;min-width:0;border:1px solid #c7d2e4;border-radius:12px;background:#fff;color:var(--text);font:inherit;font-size:.92rem;padding:12px 14px;box-sizing:border-box}.supplier-department-input:focus{outline:2px solid rgba(37,99,235,.12);border-color:#60a5fa}.supplier-xero-status{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:.72rem;font-weight:700;white-space:nowrap}.supplier-xero-status--loading{background:#e2e8f0;color:#475569}.supplier-xero-status--found{background:#bbf7d0;color:#166534}.supplier-xero-status--mapped{background:#86efac;color:#14532d}.supplier-xero-status--warning{background:#fde68a;color:#92400e}.supplier-xero-status--error{background:#fecaca;color:#991b1b}.detail-cell-pass{background:#f0fdf4;border-color:#bbf7d0}.detail-cell-warn{background:#fffbeb;border-color:#fde68a}.detail-cell-fail{background:#fef2f2;border-color:#fecaca}.detail-cell-unselected{background:#f9fafb;border-color:#e5e7eb;opacity:.65}.detail-list{margin:0;display:grid;gap:10px}.detail-list div{display:grid;gap:2px}.detail-list dt{font-size:.68rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}.detail-list dd{margin:0;font-size:.875rem;color:var(--text-secondary)}.detail-note{margin:4px 0 0;font-size:.72rem;color:#166534}.document-type-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.document-type-action{appearance:none;border:1px solid #d7dee8;border-radius:999px;background:#fff;color:#334155;font:inherit;font-size:.72rem;font-weight:700;line-height:1;padding:7px 10px;cursor:pointer;transition:border-color .12s ease,background-color .12s ease,color .12s ease}.document-type-action:hover{border-color:#94a3b8;background:#f8fafc}.document-type-action.is-active{border-color:#16a34a;background:#f0fdf4;color:#166534}.comparison-list{display:grid;gap:8px}.comparison-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:8px}.comparison-item.is-pass{background:#edfdf4;border:1px solid #bbf7d0}.comparison-item.is-fail{background:#fff7f7;border:1px solid #fecaca}.comparison-item p{margin:4px 0 0;font-size:.8rem;color:var(--text-secondary)}.comparison-label{display:block;font-size:.72rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.05em}.detail-alert,.detail-success{margin:0;padding:12px 14px;border-radius:8px;font-size:.82rem}.detail-alert{border:1px solid #fecaca;background:#fff7f7;color:#991b1b}.detail-alert.is-success,.detail-success{border:1px solid #bbf7d0;background:#edfdf4;color:#166534}.detail-alert p,.detail-success{margin:0}.detail-alert p+p{margin-top:6px}.gst-check-bar{margin-top:2px}.gst-check-alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #fecaca;border-radius:8px;background:#fef2f2;flex-wrap:wrap}.gst-check-alert p{margin:0;font-size:.8rem;color:#991b1b}.gst-check-acknowledged{margin:0;padding:10px 14px;border:1px solid #bbf7d0;border-radius:8px;background:#f0fdf4;font-size:.8rem;color:#166534}.gst-check-undo{appearance:none;border:none;background:none;padding:0;margin-left:8px;font:inherit;font-size:.75rem;font-weight:600;color:#166534;text-decoration:underline;cursor:pointer}.wrong-store-bar{margin-top:2px}.wrong-store-alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #fecaca;border-radius:8px;background:#fef2f2;flex-wrap:wrap}.wrong-store-alert p{margin:0;font-size:.8rem;color:#991b1b}.wrong-store-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.raw-response-panel{display:grid;gap:10px}.usage-card{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.usage-card div{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;display:grid;gap:4px}.usage-card strong{font-size:1rem;color:var(--text)}.prompt-card{display:grid;gap:8px}.prompt-pre{margin:0;padding:14px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text-secondary);font-size:.78rem;line-height:1.5;white-space:pre-wrap}.raw-response-pre{margin:0;padding:14px;border:1px solid var(--border);border-radius:8px;background:#0f172a;color:#e2e8f0;font-size:.75rem;line-height:1.5;overflow:auto;max-height:360px}.invoice-preview-modal{position:fixed;inset:0;z-index:220;display:grid;padding:24px;background:#0f172a80;overflow-y:auto}.invoice-preview-dialog{width:min(1180px,100%);height:min(92vh,940px);margin:auto;min-height:0;display:grid;grid-template-rows:auto 1fr;gap:16px;padding:18px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 18px 50px #0f172a2e}.invoice-preview-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.invoice-preview-heading{display:grid;gap:6px}.invoice-preview-eyebrow{margin:0;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fc-cyan)}.invoice-preview-heading h3{margin:0;font-size:1.05rem;font-weight:700;color:var(--text)}.invoice-preview-copy{margin:0;font-size:.82rem;color:var(--muted)}.invoice-preview-frame-shell{min-height:0;overflow:hidden;border:1px solid var(--border);border-radius:10px;background:#dbe3ec}.invoice-preview-frame{width:100%;height:100%;min-height:65vh;border:0;background:#fff}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:760px){.app-body{padding:16px 16px 40px}.step-header{flex-direction:column;gap:0}.step-hdr-actions{width:100%;justify-content:flex-start;padding:0 20px 18px}.upload-card,.preview-card,.integration-card,.processing-card{padding:16px}.dropzone{min-height:140px;padding:20px}.summary-grid,.integration-grid,.invoice-meta,.verification-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.invoice-main,.verification-banner,.comparison-item,.summary-note-item,.invoice-preview-header,.processing-header{flex-direction:column;align-items:flex-start}.invoice-preview-modal{padding:12px}.invoice-preview-dialog{width:100%;height:calc(100vh - 24px);padding:14px}.invoice-preview-frame{min-height:58vh}.notice{width:calc(100vw - 32px)}}@media(max-width:720px){.verification-detail-grid{grid-template-columns:1fr}.verification-detail-pair{display:block}.supplier-xero-contact-row{flex-direction:column;align-items:stretch}.supplier-xero-contact-actions{margin-left:0}.supplier-department-grid{grid-template-columns:1fr}}.individual-form{display:grid;gap:12px}.individual-field{display:grid;gap:5px}.individual-field-label{display:flex;align-items:center;gap:8px;font-size:.75rem;font-weight:600;color:var(--text-muted, #6b7280);letter-spacing:.04em;text-transform:uppercase}.individual-field-badge{font-size:.65rem;font-weight:600;color:#b45309;background:#fef3c7;border-radius:4px;padding:1px 6px;letter-spacing:0;text-transform:none}.individual-field-input{width:100%;font-size:.9rem;font-family:inherit;padding:9px 12px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--text, #111);outline:none;transition:border-color .15s;box-sizing:border-box}.individual-field--missing .individual-field-input{border-color:#fbbf24;background:#fffbeb}.individual-field-input:focus{border-color:var(--fc-cyan, #00aeef);box-shadow:0 0 0 3px #00aeef1f}.individual-field-note{margin:2px 0 0;font-size:.74rem;color:#166534}.individual-send-btn{margin-top:4px;width:100%;justify-content:center}.individual-dept-warning{font-size:.8rem;font-weight:500;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:7px 10px;margin-bottom:2px}.individual-send-result{font-size:.85rem;font-weight:500;padding:10px 14px;border-radius:7px;margin:0}.individual-send-result.is-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.individual-send-result.is-warn{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.individual-send-result.is-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.individual-dev-panel{margin-top:16px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.individual-dev-summary{cursor:pointer;padding:10px 14px;font-size:.72rem;font-weight:600;color:#6b7280;background:#f9fafb;-webkit-user-select:none;user-select:none;list-style:none}.individual-dev-summary::-webkit-details-marker{display:none}.individual-dev-panel[open] .individual-dev-summary{border-bottom:1px solid #e5e7eb}.individual-dev-body{padding:12px 14px;display:flex;flex-direction:column;gap:10px;background:#fff}.individual-dev-label{font-size:.65rem;font-weight:700;letter-spacing:.05em;color:#9ca3af;margin:0 0 4px}.individual-dev-pre{font-family:SF Mono,Fira Code,monospace;font-size:.72rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px 12px;margin:0;color:#111827}.individual-dev-meta{font-size:.68rem;color:#9ca3af;margin:0}.mapping-modal-backdrop{position:fixed;inset:0;z-index:230;display:grid;padding:24px;background:#0f172a80;overflow-y:auto}.mapping-modal-dialog{width:min(540px,100%);max-height:min(80vh,680px);margin:auto;display:flex;flex-direction:column;gap:14px;padding:20px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 18px 50px #0f172a2e;overflow:hidden}.mapping-modal-dialog--settings{width:min(760px,100%);max-height:min(92vh,900px)}.mapping-modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.mapping-modal-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--text)}.mapping-modal-sub{margin:8px 0 0;font-size:.84rem;line-height:1.5;color:var(--muted);max-width:40rem}.mapping-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;border-radius:6px;color:var(--muted);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s}.mapping-modal-close:hover{background:var(--bg);color:var(--text)}.settings-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-top:12px;padding-bottom:0}.settings-tab-btn{appearance:none;border:none;background:none;padding:8px 14px;font:inherit;font-size:.85rem;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:0;transition:color .12s,border-color .12s}.settings-tab-btn.is-active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.settings-tab-btn:hover:not(.is-active){color:var(--text)}.store-settings-form{padding:20px;display:flex;flex-direction:column;gap:18px}.store-settings-desc{margin:0;font-size:.83rem;color:var(--muted);line-height:1.5}.store-settings-field{display:flex;flex-direction:column;gap:6px}.store-settings-label{font-size:.83rem;font-weight:600;color:var(--text)}.store-settings-input{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font:inherit;font-size:.88rem;color:var(--text);background:var(--surface);outline:none;transition:border-color .12s}.store-settings-input:focus{border-color:var(--accent)}.store-settings-actions{display:flex;align-items:center;gap:12px}.store-settings-saved{font-size:.83rem;color:#166534;font-weight:500}.single-invoice-dev-panel{display:grid;gap:14px}.single-invoice-dev-toolbar{display:flex;flex-wrap:wrap;gap:10px}.single-invoice-dev-meta{margin:-4px 0 0;font-size:.78rem;color:var(--muted)}.single-invoice-dev-dropzone{min-height:160px}.dev-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.dev-result-card{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fff;display:grid;gap:4px}.dev-result-card strong{font-size:.98rem;color:var(--text)}.mapping-search{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:var(--surface);color:var(--text);outline:none;box-sizing:border-box}.mapping-search:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.mapping-contact-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;min-height:0}.mapping-contact-item{text-align:left;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text);font-size:.88rem;cursor:pointer;transition:background .1s,border-color .1s}.mapping-contact-item:hover{background:#f0f4ff;border-color:#2563eb;color:#1d4ed8}.mapping-contact-item.is-selected{background:#eff6ff;border-color:#2563eb;color:#1d4ed8}.mapping-loading,.mapping-empty{font-size:.85rem;color:var(--muted);text-align:center;padding:24px 0;margin:0}.mapping-settings-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px}.mapping-modal-content{flex:1;display:flex;flex-direction:column;gap:16px;min-height:0;overflow-y:auto}.mapping-settings-layout{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.15fr);gap:16px;min-height:0;overflow:hidden}.mapping-settings-panel{min-height:0;border:1px solid var(--border);border-radius:12px;background:#fafafa;display:flex;flex-direction:column;overflow:hidden}.mapping-settings-editor-shell{border:1px solid var(--border);border-radius:12px;background:#fff;display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:0 12px 30px #0f172a0f}.mapping-settings-editor-shell .mapping-settings-panel-header{border-bottom-color:#2563eb1f;background:linear-gradient(180deg,#f8fbff,#f3f8ff)}.mapping-settings-panel--editor{background:var(--surface)}.mapping-settings-panel-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.mapping-settings-panel-header h4{margin:0;font-size:.88rem;font-weight:600;color:var(--text)}.mapping-count{font-size:.78rem;font-weight:600;color:var(--muted);background:var(--bg);padding:2px 8px;border-radius:20px}.mapping-settings-search-wrap{padding:10px 10px 0}.mapping-settings-list{min-height:0;max-height:340px;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px}.mapping-settings-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.mapping-settings-item.is-active{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14}.mapping-settings-item-copy{min-width:0}.mapping-settings-supplier,.mapping-settings-contact{margin:0}.mapping-settings-supplier{font-size:.88rem;font-weight:700;color:var(--text)}.mapping-settings-contact{margin-top:4px;font-size:.78rem;color:var(--muted);overflow-wrap:anywhere}.mapping-settings-item-actions{flex-shrink:0}.mapping-editor{min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.mapping-editor-fields{flex:1;min-height:0;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.mapping-field{display:flex;flex-direction:column;gap:6px}.mapping-field-label{font-size:.8rem;font-weight:600;color:var(--text)}.mapping-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:var(--surface);color:var(--text);outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.mapping-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.mapping-input:disabled{background:#f8fafc;color:var(--muted);cursor:not-allowed}.mapping-field-hint{margin:0;font-size:.76rem;color:var(--muted)}.contact-selected-list{display:flex;flex-wrap:wrap;gap:8px}.contact-selected-chip{display:flex;align-items:center;gap:8px;padding:9px 12px;border:1.5px solid #86efac;border-radius:8px;background:#f0fdf4}.contact-selected-name{flex:1;font-size:.88rem;font-weight:500;color:#15803d;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-selected-clear{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#bbf7d0;color:#166534;font-size:1rem;line-height:1;cursor:pointer;padding:0;transition:background .1s}.contact-selected-clear:hover{background:#86efac}.contact-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;background:#fafafa;padding:4px}.contact-list-item{display:block;width:100%;text-align:left;padding:8px 10px;border:none;border-radius:6px;background:transparent;color:var(--text);font-size:.86rem;cursor:pointer;transition:background .1s}.contact-list-item:hover{background:#eff6ff;color:#1d4ed8}.contact-list-message{margin:0;padding:16px 10px;font-size:.84rem;color:var(--muted);text-align:center}.copy-from-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.copy-from-supplier{font-size:.86rem;font-weight:500;color:var(--text)}.copy-from-contacts{font-size:.76rem;color:var(--muted)}.contact-list-more{margin:2px 0 0;padding:6px 10px;font-size:.75rem;color:var(--muted);text-align:center;border-top:1px solid var(--border)}.mapping-contact-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.mapping-form-error{margin:0;font-size:.82rem;color:#b91c1c}.mapping-editor-actions{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface)}.mapping-editor-footer-note{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.78rem;color:var(--muted)}.mapping-inline-refresh{appearance:none;border:none;background:none;padding:0;color:#2563eb;font:inherit;font-weight:600;cursor:pointer}.mapping-inline-refresh:hover:not(:disabled){text-decoration:underline}.mapping-inline-refresh:disabled{color:#94a3b8;cursor:default}.mapping-editor-action-buttons{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.secondary-button--danger{color:#b91c1c;border-color:#fecaca;background:#fff}.secondary-button--danger:hover{color:#991b1b;border-color:#fca5a5;background:#fef2f2}@media(max-width:900px){.mapping-settings-layout{grid-template-columns:1fr;overflow:visible}.mapping-contact-list--editor{max-height:180px}}@media(max-width:640px){.mapping-settings-toolbar{flex-direction:column;align-items:stretch}.mapping-settings-item{flex-direction:column;align-items:flex-start}.mapping-settings-item-actions,.mapping-settings-item-actions .secondary-button{width:100%}.mapping-editor-actions{flex-direction:column;align-items:stretch}}.xero-send-progress{display:flex;flex-direction:column;gap:8px}.xero-send-progress__label{margin:0;font-size:.8rem;color:var(--muted)}.xero-send-progress__track{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.xero-send-progress__fill{height:100%;background:var(--fc-cyan);border-radius:99px;transition:width .35s ease}.send-result-summary{font-size:.85rem;font-weight:600;color:var(--text);margin:0 0 12px}.send-result-list{display:flex;flex-direction:column;gap:6px}.send-result-blocked-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.send-result-blocked-item{border:1px solid #fecaca;border-radius:8px;padding:10px 12px;background:#fff7ed}.send-result-blocked-heading{margin:0;font-size:.82rem;font-weight:700;color:#7c2d12}.send-result-blocked-message{margin:4px 0 0;font-size:.8rem;color:#9a3412}.send-result-row{border:1px solid var(--border);border-radius:8px;padding:10px 14px;background:var(--surface)}.send-result-row.is-created{border-color:#a7f3d0;background:#f0fdf9}.send-result-row.is-error{border-color:#fca5a5;background:#fef2f2}.send-result-row.is-skipped{border-color:var(--border);background:#f9fafb;opacity:.8}.send-result-row.is-pending{border-color:#cbd5e1;background:#f8fafc}.send-result-row.is-processing{border-color:#7dd3fc;background:#f0f9ff}.send-result-row-main{display:flex;align-items:center;gap:10px}.send-result-status-icon{font-size:.85rem;font-weight:700;width:18px;flex-shrink:0}.send-result-row.is-created .send-result-status-icon{color:#059669}.send-result-row.is-error .send-result-status-icon{color:#dc2626}.send-result-row.is-skipped .send-result-status-icon{color:#9ca3af}.send-result-row.is-pending .send-result-status-icon{color:#64748b}.send-result-row.is-processing .send-result-status-icon{width:28px;color:#0284c7}.animated-dots{display:inline-flex;align-items:center;gap:3px}.animated-dots__dot{width:4px;height:4px;border-radius:999px;background:currentColor;opacity:.28;animation:send-result-dot-pulse 1s ease-in-out infinite}.animated-dots__dot:nth-child(2){animation-delay:.16s}.animated-dots__dot:nth-child(3){animation-delay:.32s}@keyframes send-result-dot-pulse{0%,80%,to{opacity:.28;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}.send-result-row-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.send-result-row-heading{display:flex;align-items:center;gap:8px;min-width:0}.send-result-invoice-num{font-size:.8rem;font-weight:700;color:var(--fc-cyan, #0ea5e9)}.send-result-type-badge{min-height:18px;padding:0 6px;font-size:.64rem;letter-spacing:.04em}.send-result-supplier{font-size:.82rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.send-result-contact{font-size:.77rem;color:#475569}.send-result-row-right{flex-shrink:0;font-size:.8rem;display:flex;align-items:center;gap:8px}.send-result-xero-link{color:#2563eb;font-weight:600;text-decoration:none}.send-result-xero-link:hover{text-decoration:underline}.send-result-label-skipped{color:#9ca3af}.send-result-label-success{color:#065f46;font-weight:600}.send-result-label-pending{color:#475569;font-weight:500}.send-result-label-processing{display:inline-flex;align-items:center;gap:6px;color:#0369a1;font-weight:600}.send-result-label-dots{color:inherit}.send-result-label-error{color:#dc2626;font-weight:500}.send-result-dept-warn{margin:6px 0 0 28px;font-size:.78rem;color:#92400e}.send-result-summary-note{margin:6px 0 0 28px;font-size:.78rem;color:#475569}@media(max-width:760px){.primary-button,.secondary-button{min-height:44px;padding-top:10px;padding-bottom:10px}.step-toggle{min-height:56px}.btn-upload-new{padding:11px 18px}.dropzone{min-height:160px;padding:28px 20px;border-width:2px}.mapping-modal-backdrop{padding:0;align-items:flex-end}.mapping-modal-dialog{width:100%;max-height:92vh;border-radius:16px 16px 0 0;margin:0}.mapping-modal-dialog--settings{width:100%;max-height:96vh;border-radius:16px 16px 0 0;margin:0}.invoice-preview-modal{padding:0;align-items:flex-end}.invoice-preview-dialog{width:100%;height:96vh;border-radius:16px 16px 0 0;margin:0;padding:14px}.invoice-meta{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:420px){.invoice-meta{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.app-body{padding:12px 12px 40px}}
