:root {
  --bg: #f3f4ef;
  --surface: #fff;
  --surface-muted: #f8f9f5;
  --ink: #19211d;
  --muted: #69736d;
  --faint: #929a95;
  --line: #e2e5df;
  --line-strong: #d3d8d1;
  --sidebar: #17221d;
  --sidebar-muted: #93a099;
  --accent: #4d765c;
  --accent-dark: #31513d;
  --accent-soft: #e8f0e9;
  --blue: #496b89;
  --blue-soft: #e8eff4;
  --amber: #9a6a2f;
  --amber-soft: #f6eedf;
  --red: #9b4e48;
  --red-soft: #f7e9e7;
  --radius: 14px;
  --radius-sm: 9px;
  --shadow: 0 1px 2px rgb(25 33 29 / 4%), 0 8px 28px rgb(25 33 29 / 4%);
  --ease-out: cubic-bezier(.23, 1, .32, 1);
  font-family: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
  font-synthesis: none;
}

* { box-sizing: border-box; }
html { min-width: 320px; background: var(--bg); }
body { margin: 0; min-height: 100vh; background: var(--bg); }
a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

.app-shell { display: grid; grid-template-columns: 238px minmax(0, 1fr); min-height: 100vh; }
.sidebar { position: fixed; inset: 0 auto 0 0; z-index: 10; width: 238px; display: flex; flex-direction: column; padding: 26px 18px 20px; color: #edf2ee; background: var(--sidebar); }
.brand { display: flex; align-items: center; gap: 11px; padding: 0 8px 28px; }
.brand-mark { display: grid; width: 34px; height: 34px; place-items: center; color: #dbe9dd; border: 1px solid rgb(255 255 255 / 14%); border-radius: 10px; background: rgb(255 255 255 / 6%); }
.brand-mark svg { width: 21px; height: 21px; }
.brand > span:last-child { display: flex; flex-direction: column; gap: 2px; }
.brand strong { font-size: 15px; letter-spacing: .02em; }
.brand small { color: var(--sidebar-muted); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; }
.primary-nav { display: grid; gap: 5px; }
.primary-nav a { display: flex; align-items: center; gap: 11px; min-height: 42px; padding: 0 12px; color: #abb6b0; border-radius: 9px; font-size: 13px; font-weight: 550; transition: color 150ms ease, background-color 150ms ease, transform 140ms var(--ease-out); }
.primary-nav a svg { width: 18px; height: 18px; }
.primary-nav a.is-active { color: #fff; background: rgb(255 255 255 / 9%); }
@media (hover: hover) and (pointer: fine) { .primary-nav a:hover { color: #fff; background: rgb(255 255 255 / 6%); } }
.primary-nav a:active { transform: scale(.98); }
.sidebar-note { display: flex; align-items: center; gap: 10px; margin-top: auto; padding: 13px 11px; border: 1px solid rgb(255 255 255 / 9%); border-radius: 10px; background: rgb(255 255 255 / 4%); }
.sidebar-note div { display: flex; min-width: 0; flex-direction: column; gap: 3px; }
.sidebar-note strong { font-size: 11px; }
.sidebar-note small { overflow: hidden; color: var(--sidebar-muted); font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }
.live-dot { width: 7px; height: 7px; flex: 0 0 auto; border-radius: 50%; background: #76a784; box-shadow: 0 0 0 4px rgb(118 167 132 / 12%); }
.sidebar-foot { display: flex; justify-content: space-between; margin-top: 14px; padding: 0 5px; color: var(--sidebar-muted); font-size: 9px; letter-spacing: .04em; text-transform: uppercase; }
.sidebar-foot strong { color: #bac9c0; font-weight: 600; }
.main-column { grid-column: 2; min-width: 0; }
.mobile-header { display: none; }
.page { width: min(1420px, 100%); margin: 0 auto; padding: 48px 48px 70px; }

.page-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 32px; margin-bottom: 30px; }
.page-header h1 { max-width: 760px; margin: 4px 0 10px; font-family: Georgia, "Times New Roman", serif; font-size: clamp(34px, 3.4vw, 52px); font-weight: 500; line-height: 1.04; letter-spacing: -.035em; }
.compact-header h1 { font-size: clamp(32px, 3vw, 46px); }
.page-header .button { margin-top: 10px; }
.eyebrow { margin: 0 0 5px; color: var(--accent); font-size: 10px; font-weight: 750; letter-spacing: .13em; text-transform: uppercase; }
.lede { max-width: 680px; margin: 0; color: var(--muted); font-size: 14px; line-height: 1.65; }
.back-link { display: inline-flex; margin-bottom: 20px; color: var(--muted); font-size: 12px; font-weight: 650; }
.title-row { display: flex; align-items: center; gap: 12px; }
.title-row .eyebrow { margin: 0; }
.header-actions { display: flex; gap: 8px; }

.button { display: inline-flex; min-height: 40px; align-items: center; justify-content: center; gap: 8px; padding: 0 15px; border: 1px solid transparent; border-radius: 9px; cursor: pointer; font-size: 12px; font-weight: 680; transition: transform 140ms var(--ease-out), background-color 150ms ease, border-color 150ms ease; }
.button svg { width: 16px; height: 16px; }
.button:active { transform: scale(.98); }
.button-primary { color: #fff; background: var(--accent-dark); }
.button-secondary { color: var(--ink); border-color: var(--line-strong); background: var(--surface); }
.button-danger { color: var(--red); border-color: #e7c8c4; background: var(--red-soft); }
@media (hover: hover) and (pointer: fine) {
  .button-primary:hover { background: #264332; }
  .button-secondary:hover { border-color: #bec6be; background: #fafbf8; }
}
.text-button { padding: 0; color: var(--accent-dark); border: 0; cursor: pointer; background: none; font-size: 11px; font-weight: 700; }
.text-button.danger { color: var(--red); }
.icon-button { display: grid; width: 30px; height: 30px; place-items: center; color: var(--faint); border: 1px solid var(--line); border-radius: 8px; cursor: pointer; background: var(--surface); font-size: 18px; transition: color 150ms ease, border-color 150ms ease, transform 140ms var(--ease-out); }
.icon-button:active { transform: scale(.95); }

.metrics-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 18px; }
.metric-card { display: flex; min-width: 0; align-items: center; gap: 13px; padding: 17px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); box-shadow: 0 1px 2px rgb(25 33 29 / 3%); }
.metric-card > div { display: flex; min-width: 0; flex-direction: column; gap: 2px; }
.metric-card strong { font-family: Georgia, serif; font-size: 24px; font-weight: 500; }
.metric-card span:last-child { overflow: hidden; color: var(--muted); font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }
.metric-icon { display: grid; width: 35px; height: 35px; flex: 0 0 auto; place-items: center; border-radius: 10px; }
.metric-icon svg { width: 17px; height: 17px; }
.metric-icon.green { color: var(--accent); background: var(--accent-soft); }
.metric-icon.amber { color: var(--amber); background: var(--amber-soft); }
.metric-icon.blue { color: var(--blue); background: var(--blue-soft); }
.metric-icon.neutral { color: #68716c; background: #eff1ed; }

.dashboard-grid, .import-layout { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(290px, .75fr); gap: 18px; margin-bottom: 18px; }
.panel { border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); box-shadow: var(--shadow); }
.panel-heading { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 22px 16px; }
.panel-heading h2 { margin: 0; font-family: Georgia, serif; font-size: 21px; font-weight: 500; letter-spacing: -.02em; }
.step-chip, .source-state { padding: 5px 8px; color: var(--muted); border: 1px solid var(--line); border-radius: 999px; background: var(--surface-muted); font-size: 9px; font-weight: 750; letter-spacing: .06em; text-transform: uppercase; }
.source-state.live { color: var(--accent-dark); border-color: #cdddcf; background: var(--accent-soft); }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 15px; padding: 4px 22px 22px; }
.field { display: flex; min-width: 0; flex-direction: column; gap: 7px; }
.field.full, .form-footer.full, .form-errors.full { grid-column: 1 / -1; }
.field label { font-size: 11px; font-weight: 680; }
.field input, .field select { width: 100%; height: 41px; padding: 0 12px; color: var(--ink); border: 1px solid var(--line-strong); border-radius: 8px; outline: none; background: #fbfcf9; font-size: 12px; transition: border-color 150ms ease, box-shadow 150ms ease, background-color 150ms ease; }
.field input:focus, .field select:focus { border-color: #749080; background: #fff; box-shadow: 0 0 0 3px rgb(77 118 92 / 10%); }
.field small { color: var(--faint); font-size: 9px; line-height: 1.45; }
.field .errorlist, .form-errors .errorlist { margin: 0; padding: 0; color: var(--red); list-style: none; font-size: 10px; }
.form-footer { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding-top: 5px; border-top: 1px solid var(--line); }
.form-footer p { display: flex; align-items: center; gap: 7px; margin: 0; color: var(--muted); font-size: 9px; }
.shield { display: inline-grid; width: 18px; height: 18px; place-items: center; color: var(--accent-dark); border-radius: 50%; background: var(--accent-soft); font-weight: 800; }
.file-field input { height: auto; padding: 12px; border-style: dashed; }
.check-field { display: grid; grid-template-columns: auto 1fr; align-items: start; gap: 9px; padding: 12px; border: 1px solid var(--line); border-radius: 9px; background: var(--surface-muted); }
.check-field input { width: 15px; height: 15px; margin: 1px 0 0; accent-color: var(--accent); }
.check-field label { color: var(--muted); font-weight: 520; line-height: 1.45; }
.check-field .errorlist { grid-column: 2; }

.source-list { display: grid; padding: 0 18px 12px; }
.source-list article { display: grid; grid-template-columns: 36px minmax(0, 1fr) auto; align-items: center; gap: 10px; padding: 13px 4px; border-bottom: 1px solid var(--line); }
.source-list article:last-child { border: 0; }
.source-list article > div { display: flex; min-width: 0; flex-direction: column; gap: 3px; }
.source-list strong { font-size: 11px; }
.source-list small { color: var(--faint); font-size: 9px; }
.source-monogram { display: grid; width: 34px; height: 34px; place-items: center; border-radius: 9px; font-size: 8px; font-weight: 800; letter-spacing: -.03em; }
.source-monogram.irs { color: #745d3d; background: #f1eade; }
.source-monogram.dnb { color: #385c77; background: #e5edf3; }
.source-monogram.buzz { color: #6e4d71; background: #efe7ef; font-size: 12px; }
.compliance-note { display: flex; gap: 10px; margin: 8px 18px 18px; padding: 13px; color: var(--accent-dark); border: 1px solid #d8e3d9; border-radius: 10px; background: #f1f6f1; }
.compliance-note svg { width: 18px; height: 18px; flex: 0 0 auto; }
.compliance-note div { display: flex; flex-direction: column; gap: 4px; }
.compliance-note strong { font-size: 10px; }
.compliance-note p { margin: 0; color: #607067; font-size: 9px; line-height: 1.55; }
.mapping-list { display: grid; gap: 8px; padding: 0 20px 16px; }
.mapping-list span { display: flex; justify-content: space-between; gap: 10px; padding: 10px 11px; color: var(--muted); border-radius: 8px; background: var(--surface-muted); font-size: 10px; }
.mapping-list b { color: var(--accent); }

.jobs-panel, .results-panel, .suppression-panel { overflow: hidden; }
.table-wrap { width: 100%; overflow-x: auto; border-top: 1px solid var(--line); }
table { width: 100%; border-collapse: collapse; font-size: 11px; }
th { padding: 10px 16px; color: var(--faint); background: var(--surface-muted); font-size: 8px; font-weight: 750; letter-spacing: .09em; text-align: left; text-transform: uppercase; white-space: nowrap; }
td { min-width: 80px; padding: 13px 16px; color: #444e48; border-top: 1px solid var(--line); vertical-align: middle; }
tbody tr:first-child td { border-top: 0; }
td strong, td > a { color: var(--ink); }
td small { display: block; margin-top: 3px; color: var(--faint); font-size: 9px; }
.company-link { font-weight: 700; }
.source-pill { display: inline-flex; padding: 5px 7px; color: #4f5d55; border: 1px solid var(--line); border-radius: 6px; background: var(--surface-muted); font-size: 8px; font-weight: 700; white-space: nowrap; }
.status { display: inline-flex; align-items: center; gap: 6px; padding: 5px 8px; border-radius: 999px; font-size: 8px; font-weight: 750; white-space: nowrap; }
.status i { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.status-completed { color: var(--accent-dark); background: var(--accent-soft); }
.status-running { color: var(--blue); background: var(--blue-soft); }
.status-queued { color: var(--amber); background: var(--amber-soft); }
.status-failed, .status-cancelled { color: var(--red); background: var(--red-soft); }
.icon-link { display: grid; width: 28px; height: 28px; place-items: center; color: var(--muted); border: 1px solid var(--line); border-radius: 7px; background: var(--surface); transition: transform 140ms var(--ease-out), border-color 150ms ease; }
.icon-link:active { transform: scale(.95); }
.empty-state { display: flex; min-height: 120px; align-items: center; justify-content: center; flex-direction: column; gap: 5px; color: var(--muted); text-align: center; }
.empty-state strong { color: var(--ink); font-family: Georgia, serif; font-size: 18px; font-weight: 500; }
.empty-state span { font-size: 10px; }
.quiet-alert { color: var(--red); font-size: 9px; font-weight: 650; }

.progress-panel { margin-bottom: 18px; padding: 20px 22px; }
.progress-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 13px; }
.progress-top > div { display: flex; align-items: baseline; gap: 10px; }
.progress-top span { color: var(--muted); font-size: 10px; }
.progress-top strong { font-size: 12px; }
.progress-track { height: 6px; overflow: hidden; border-radius: 999px; background: #e8ebe6; }
.progress-track span { display: block; height: 100%; border-radius: inherit; background: var(--accent); transition: width 180ms var(--ease-out); }
.is-indeterminate .progress-track span { min-width: 18%; }
.job-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; margin-top: 18px; border: 1px solid var(--line); border-radius: 9px; background: var(--line); overflow: hidden; }
.job-metrics div { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 11px 12px; background: var(--surface-muted); }
.job-metrics span { color: var(--muted); font-size: 9px; }
.job-metrics strong { font-size: 14px; }
.id-stack { display: flex; align-items: flex-start; flex-direction: column; gap: 3px; }
.id-stack span { color: var(--muted); font-size: 8px; }
.pagination { display: flex; align-items: center; justify-content: center; gap: 18px; padding: 15px; border-top: 1px solid var(--line); font-size: 10px; }
.pagination a { color: var(--accent-dark); font-weight: 700; }

.alert { display: flex; align-items: flex-start; flex-direction: column; gap: 4px; margin-bottom: 18px; padding: 13px 15px; border-radius: 10px; font-size: 10px; }
.alert-error { color: var(--red); border: 1px solid #ebd1ce; background: var(--red-soft); }
.alert span, .alert .errorlist { margin: 0; color: #7e5c58; }
.is-hidden { display: none !important; }
.identity-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 18px; }
.identity-grid article { display: flex; flex-direction: column; gap: 6px; padding: 15px; border: 1px solid var(--line); border-radius: 11px; background: var(--surface); }
.identity-grid span { color: var(--faint); font-size: 8px; font-weight: 750; letter-spacing: .1em; }
.identity-grid strong { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 13px; }
.source-detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.source-detail { overflow: hidden; }
.data-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); margin: 0; padding: 0 22px 18px; gap: 1px; background: var(--line); }
.data-list div { min-width: 0; padding: 10px; background: var(--surface-muted); }
.data-list dt { overflow: hidden; margin-bottom: 4px; color: var(--faint); font-size: 8px; font-weight: 700; text-overflow: ellipsis; text-transform: uppercase; white-space: nowrap; }
.data-list dd { overflow-wrap: anywhere; margin: 0; color: var(--ink); font-size: 10px; }
.source-footer { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 13px 22px; color: var(--faint); border-top: 1px solid var(--line); font-size: 9px; }
.source-footer a { color: var(--accent-dark); font-weight: 700; }
.toast-stack { position: fixed; top: 18px; right: 20px; z-index: 30; }
.toast { padding: 11px 14px; color: #fff; border: 1px solid rgb(255 255 255 / 10%); border-radius: 9px; background: var(--sidebar); box-shadow: 0 12px 40px rgb(0 0 0 / 18%); font-size: 10px; }

:focus-visible { outline: 2px solid #537764; outline-offset: 3px; }

@media (max-width: 1080px) {
  .page { padding: 38px 30px 60px; }
  .dashboard-grid, .import-layout { grid-template-columns: minmax(0, 1.25fr) minmax(260px, .75fr); }
  .metrics-grid { grid-template-columns: repeat(2, 1fr); }
  .source-detail-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .app-shell { display: block; }
  .sidebar { display: none; }
  .main-column { width: 100%; }
  .mobile-header { display: flex; height: 60px; align-items: center; justify-content: space-between; padding: 0 18px; color: #fff; background: var(--sidebar); }
  .mobile-header .brand { padding: 0; }
  .mobile-header .brand-mark { width: 30px; height: 30px; }
  .mobile-header nav { display: flex; gap: 14px; color: #bac4be; font-size: 10px; font-weight: 650; }
  .page { padding: 28px 17px 50px; }
  .page-header { align-items: stretch; flex-direction: column; gap: 16px; }
  .page-header h1 { font-size: 36px; }
  .page-header .button { margin: 0; }
  .header-actions { flex-wrap: wrap; }
  .dashboard-grid, .import-layout { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .field.full, .form-footer.full { grid-column: auto; }
  .form-footer { align-items: stretch; flex-direction: column; }
  .form-footer .button { width: 100%; }
  .job-metrics { grid-template-columns: repeat(2, 1fr); }
  .identity-grid { grid-template-columns: repeat(2, 1fr); }
  .data-list { grid-template-columns: 1fr; }
}

@media (max-width: 430px) {
  .metrics-grid { grid-template-columns: 1fr; }
  .metric-card { padding: 14px; }
  .panel-heading { padding-inline: 17px; }
  .form-grid { padding-inline: 17px; }
  .progress-panel { padding-inline: 17px; }
  .progress-top > div { align-items: flex-start; flex-direction: column; gap: 3px; }
  .identity-grid { grid-template-columns: 1fr 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
  .button:active, .icon-button:active, .primary-nav a:active { transform: none; }
}
