/* ============================================================
   Unifin design system — neubrutalism on warm paper.
   Fonts (Archivo / Public Sans / IBM Plex Mono) load from Google
   Fonts in base.html. Tokens + components below are the design
   system; the tail restyles the HTMX result/job fragments to match.
   ============================================================ */
:root {
  /* Ink (text + borders) */
  --ink-900:#121212; --ink-700:#2E2E2C; --ink-500:#5C5C57; --ink-300:#9A9A92; --ink-100:#D9D7CC;
  /* Paper / surfaces */
  --paper:#FBF8EF; --paper-deep:#F3EEDF; --surface:#FFFFFF;
  /* Primary blue */
  --blue-bright:#3B8AFF; --blue:#1D6AE5; --blue-deep:#1148A8; --blue-tint:#E6EFFF;
  /* Success green */
  --green-bright:#2BD974; --green:#16A34A; --green-deep:#0E7A37; --green-tint:#E3F7EA;
  /* Secondary accents */
  --lemon:#FFD93D; --lemon-tint:#FFF6D1; --sky:#4DA3FF; --sky-tint:#E2F0FF;
  --coral:#FF6B5C; --coral-tint:#FFE6E2;
  /* Semantic */
  --text-strong:var(--ink-900); --text-body:var(--ink-700); --text-muted:var(--ink-500);
  --text-disabled:var(--ink-300); --text-inverse:#FBF8EF; --text-link:var(--blue-deep);
  --surface-page:var(--paper); --surface-alt:var(--paper-deep); --surface-card:var(--surface);
  --border-color:var(--ink-900); --border-hairline:var(--ink-100);
  --accent:var(--blue); --accent-bright:var(--blue-bright); --accent-strong:var(--blue-deep);
  --success:var(--green); --success-bg:var(--green-tint);
  --warning:#E0930B; --warning-bg:var(--lemon-tint);
  --danger:#D8453B; --danger-bg:var(--coral-tint);
  --info:var(--blue); --info-bg:var(--blue-tint);
  --focus-ring:var(--blue-deep);

  /* Type */
  --font-display:"Archivo","Arial Black",system-ui,sans-serif;
  --font-sans:"Public Sans",system-ui,-apple-system,sans-serif;
  --font-mono:"IBM Plex Mono","SF Mono",ui-monospace,monospace;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700; --fw-black:900;
  --fs-display:4.5rem; --fs-h1:3rem; --fs-h2:2.25rem; --fs-h3:1.5rem; --fs-h4:1.25rem;
  --fs-lg:1.125rem; --fs-body:1rem; --fs-sm:.875rem; --fs-xs:.75rem;
  --lh-tight:1.02; --lh-snug:1.15; --lh-normal:1.5; --lh-relaxed:1.65;
  --ls-tight:-0.02em; --ls-normal:0; --ls-wide:.04em; --ls-caps:.08em;

  /* Spacing (4px grid) */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
  --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px; --space-10:128px;
  --container-max:1200px; --container-pad:24px; --section-y:96px;

  /* Effects */
  --bw-thin:1.5px; --bw:2px; --bw-thick:3px;
  --radius-sm:4px; --radius:8px; --radius-lg:12px; --radius-xl:18px; --radius-pill:999px;
  --shadow-xs:1px 1px 0 var(--ink-900); --shadow-sm:2px 2px 0 var(--ink-900);
  --shadow:4px 4px 0 var(--ink-900); --shadow-lg:6px 6px 0 var(--ink-900); --shadow-xl:8px 8px 0 var(--ink-900);
  --ease-snap:cubic-bezier(0.2,0.8,0.2,1); --dur-fast:120ms; --dur:180ms;
}

/* ---------- base ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--text-body);font-family:var(--font-sans);
  font-size:var(--fs-body);line-height:var(--lh-normal);-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink-900);margin:0;letter-spacing:var(--ls-tight);}
img{max-width:100%;}
.wrap{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad);}
.eye{font-family:var(--font-mono);font-size:13px;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--blue-deep);margin:0;}
.lead{font-size:19px;line-height:1.5;color:var(--text-body);}

/* ---------- buttons ---------- */
.btn{font-family:var(--font-sans);font-weight:700;border:var(--bw) solid var(--ink-900);
  border-radius:var(--radius);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  gap:8px;line-height:1;white-space:nowrap;font-size:16px;padding:13px 22px;
  transition:transform var(--dur) var(--ease-snap),box-shadow var(--dur) var(--ease-snap),background var(--dur);}
.btn svg{width:18px;height:18px;}
.btn--primary{background:var(--accent-bright);color:var(--ink-900);box-shadow:var(--shadow);}
.btn--primary:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-lg);}
.btn--primary:active{transform:translate(3px,3px);box-shadow:var(--shadow-xs);}
.btn--secondary{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow);}
.btn--secondary:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-lg);background:var(--paper-deep);}
.btn--secondary:active{transform:translate(3px,3px);box-shadow:var(--shadow-xs);}
.btn--dark{background:var(--ink-900);color:var(--paper);box-shadow:var(--shadow);}
.btn--dark:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-lg);}
.btn--dark:active{transform:translate(3px,3px);box-shadow:var(--shadow-xs);}
.btn--ghost{background:transparent;border-color:transparent;box-shadow:none;}
.btn--ghost:hover{background:var(--paper-deep);}
.btn--sm{font-size:14px;padding:9px 14px;}
.btn--lg{font-size:18px;padding:16px 28px;}

/* ---------- badge / card ---------- */
.badge{font-family:var(--font-mono);font-weight:600;font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;padding:5px 11px;
  border:var(--bw) solid var(--ink-900);border-radius:var(--radius-pill);line-height:1;background:var(--surface);}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--green);}
.badge--green{background:var(--green-bright);} .badge--lemon{background:var(--lemon);}
.badge--sky{background:var(--sky-tint);}
.card{background:var(--surface);border:var(--bw) solid var(--ink-900);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);}

/* ---------- nav ---------- */
nav.top{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:var(--bw) solid var(--ink-900);}
.nav-in{display:flex;align-items:center;gap:28px;height:70px;}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo .mark{height:34px;width:34px;display:block;flex:none;}
.nav-logo .word{font-family:var(--font-display);font-weight:900;font-size:22px;color:var(--ink-900);letter-spacing:-.02em;}
.nav-links{display:flex;gap:26px;margin-left:14px;}
.nav-links a{font-weight:600;font-size:15px;color:var(--ink-700);}
.nav-links a:hover{color:var(--ink-900);}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:12px;}
.lang-switch{display:inline-flex;border:var(--bw) solid var(--ink-900);border-radius:var(--radius);
  overflow:hidden;background:var(--surface);box-shadow:var(--shadow-xs);}
.lang-switch button{font-family:var(--font-mono);font-weight:700;font-size:12px;letter-spacing:.04em;
  border:none;background:transparent;color:var(--text-muted);padding:7px 11px;cursor:pointer;line-height:1;}
.lang-switch button + button{border-left:var(--bw) solid var(--ink-900);}
.lang-switch button.on{background:var(--ink-900);color:var(--paper);}

/* ---------- hero ---------- */
.hero{padding:84px 0 72px;}
.hero-grid{display:grid;grid-template-columns:1.12fr 0.88fr;gap:48px;align-items:center;}
.hero h1{font-size:46px;font-weight:900;line-height:1.14;}
.hero h1 .hl{background:var(--accent-bright);padding:0 6px;border:var(--bw) solid var(--ink-900);
  border-radius:6px;box-decoration-break:clone;-webkit-box-decoration-break:clone;}
.hero .lead{margin:22px 0 26px;max-width:520px;}
.hero-note{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);margin-top:16px;
  display:flex;align-items:center;gap:8px;}

/* hero upload form */
.hero-form{display:flex;flex-direction:column;gap:14px;max-width:520px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field > .lbl{font-family:var(--font-mono);font-size:12px;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;color:var(--text-muted);}
.inp{font-family:var(--font-sans);font-size:16px;padding:14px 16px;border:var(--bw) solid var(--ink-900);
  border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);width:100%;color:var(--ink-900);}
.inp:focus{outline:none;transform:translate(-1px,-1px);box-shadow:var(--shadow);}
input[type=file].inp{padding:10px 12px;cursor:pointer;}
input[type=file].inp::file-selector-button{font-family:var(--font-sans);font-weight:700;font-size:14px;
  border:var(--bw) solid var(--ink-900);border-radius:var(--radius-sm);background:var(--paper-deep);
  color:var(--ink-900);padding:8px 14px;margin-right:14px;cursor:pointer;}
.hero-form .btn{align-self:flex-start;}

/* hero converter / sample-output visual */
.conv{display:grid;grid-template-columns:1fr;gap:14px;}
.conv-row{display:flex;align-items:center;gap:14px;}
.file-tile{flex:1;display:flex;align-items:center;gap:11px;background:var(--surface);
  border:var(--bw) solid var(--ink-900);border-radius:var(--radius);padding:12px 14px;
  box-shadow:var(--shadow-sm);font-weight:600;font-size:14px;color:var(--ink-900);}
.file-ic{width:34px;height:34px;border:var(--bw) solid var(--ink-900);border-radius:6px;display:flex;
  align-items:center;justify-content:center;flex:none;}
.file-ic svg{width:18px;height:18px;}
.tile-sub{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--text-muted);white-space:nowrap;}
.conv-divider{display:flex;justify-content:center;align-items:center;gap:12px;}
.conv-divider .line{height:2px;flex:1;background:var(--ink-900);}
.conv-divider .lbl{font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text-muted);}
.out-card{padding:18px;}
.out-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.out-title{font-family:var(--font-display);font-weight:800;font-size:17px;color:var(--ink-900);white-space:nowrap;}
.tabset{display:inline-flex;border:var(--bw) solid var(--ink-900);border-radius:var(--radius);
  background:var(--paper-deep);padding:3px;gap:2px;margin-bottom:14px;}
.tabset button{font-family:var(--font-sans);font-weight:600;font-size:12px;border:none;background:transparent;
  color:var(--text-muted);padding:6px 11px;border-radius:5px;cursor:pointer;}
.tabset button.on{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-xs);
  border:var(--bw) solid var(--ink-900);}
table.fin{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:13.5px;color:var(--ink-900);}
table.fin td{padding:7px 0;border-bottom:1px solid var(--ink-100);font-variant-numeric:tabular-nums;}
table.fin td.r{text-align:right;font-weight:600;}
table.fin tr:last-child td{border-bottom:none;font-weight:700;}
table.fin tr.total td{border-top:var(--bw) solid var(--ink-900);}

/* ---------- sections ---------- */
section{padding:var(--section-y) 0;}
.band{background:var(--paper-deep);border-top:var(--bw) solid var(--ink-900);border-bottom:var(--bw) solid var(--ink-900);}
.sec-head{max-width:640px;margin-bottom:48px;}
.sec-head h2{font-size:40px;font-weight:900;line-height:1.05;margin:14px 0 0;}
.sec-head p{font-size:18px;margin:16px 0 0;}

/* formats strip */
.formats{padding:34px 0;background:var(--ink-900);border-top:var(--bw) solid var(--ink-900);
  border-bottom:var(--bw) solid var(--ink-900);}
.formats-in{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;}
.formats-label{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;
  color:#FBF8EF;opacity:.7;}
.fmt{font-family:var(--font-mono);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--ink-900);background:var(--paper);border:var(--bw) solid var(--paper);border-radius:var(--radius-pill);
  padding:6px 14px;}
.fmt.acc{background:var(--accent-bright);}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.step{padding:24px;position:relative;}
.step .n{font-family:var(--font-display);font-weight:900;font-size:34px;color:var(--ink-900);width:54px;
  height:54px;border:var(--bw) solid var(--ink-900);border-radius:var(--radius);display:flex;align-items:center;
  justify-content:center;background:var(--accent-bright);margin-bottom:18px;box-shadow:var(--shadow-sm);}
.step h3{font-size:20px;font-weight:800;margin-bottom:8px;}
.step p{font-size:15px;margin:0;}

/* features */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.feat{padding:26px;}
.feat .fic{width:50px;height:50px;border:var(--bw) solid var(--ink-900);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:var(--shadow-sm);}
.feat .fic svg{width:24px;height:24px;color:var(--ink-900);}
.feat h3{font-size:19px;font-weight:800;margin-bottom:8px;}
.feat p{font-size:15px;margin:0;line-height:1.55;}

/* cta */
.cta{background:var(--accent-bright);border-top:var(--bw) solid var(--ink-900);text-align:center;}
.cta h2{font-size:48px;font-weight:900;line-height:1.04;}
.cta p{font-size:19px;margin:18px auto 30px;max-width:520px;color:var(--ink-900);}

/* footer */
footer{background:var(--ink-900);color:var(--paper);border-top:var(--bw) solid var(--ink-900);padding:64px 0 40px;}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;margin-bottom:48px;}
.foot-logo{display:flex;align-items:center;gap:10px;}
.foot-logo .mark{height:30px;width:30px;display:block;flex:none;}
.foot-logo .word{font-family:var(--font-display);font-weight:900;font-size:22px;color:var(--paper);}
.foot-blurb{font-size:14px;color:#B8B8B0;margin-top:16px;max-width:280px;line-height:1.6;}
.foot-col h4{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  color:#8C8C84;margin-bottom:16px;font-weight:600;}
.foot-col a{display:block;font-size:14.5px;color:#D6D6CE;margin-bottom:11px;}
.foot-col a:hover{color:var(--accent-bright);}
.foot-bottom{border-top:1px solid #333;padding-top:24px;display:flex;justify-content:space-between;
  align-items:center;font-family:var(--font-mono);font-size:12px;color:#8C8C84;flex-wrap:wrap;gap:12px;}

/* ============================================================
   HTMX result / job fragments (#work) — restyled to the system.
   Fragments swap into #work; they use .card, table.num, status
   colors, td.badge, progress, .alert. Keep their markup, match look.
   ============================================================ */
#work{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad);scroll-margin-top:86px;}
#work:not(:empty){padding-top:40px;padding-bottom:72px;}
#work .card{padding:20px 22px;margin-bottom:20px;}
#work h2{font-size:24px;margin:0 0 6px;}
#work h3{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--ink-900);margin:0 0 12px;}

.results > p > a, a.backlink{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--blue-deep);}

/* tables */
table.num{width:100%;border-collapse:collapse;font-size:13px;}
table.num th,table.num td{text-align:left;padding:6px 9px;border-bottom:1px solid var(--ink-100);}
table.num th{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--text-muted);font-weight:600;}
table.num td{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink-900);}
table.num td:nth-child(n+4),table.num th:nth-child(n+4){text-align:right;}
tr.total td{font-weight:700;border-top:var(--bw) solid var(--ink-900);}
tr.subhead td{background:var(--paper-deep);font-weight:700;color:var(--ink-900);font-family:var(--font-display);}
.indent{padding-left:22px !important;}

/* status colors (also used by validation summary spans + statement badges) */
.ok{color:var(--green-deep);} .bad{color:var(--danger);} .warn{color:var(--warning);}
.derived{color:var(--blue-deep);} .muted{color:var(--text-muted);}
.meta-bar{display:flex;gap:18px;flex-wrap:wrap;color:var(--text-muted);font-size:14px;align-items:center;}
.meta-bar strong{color:var(--ink-900);}
.emailed{font-family:var(--font-mono);font-weight:600;color:var(--green-deep);background:var(--green-tint);
  border:var(--bw) solid var(--ink-900);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-sm);}

/* status badge cell in statement rows: override the .badge pill back to a plain cell */
td.badge{display:table-cell;border:none;border-radius:0;background:transparent;box-shadow:none;padding:6px 9px;
  font-family:var(--font-mono);font-weight:700;text-align:center;width:1%;text-transform:none;letter-spacing:0;}

/* progress + alert */
progress{width:100%;height:16px;-webkit-appearance:none;appearance:none;border:var(--bw) solid var(--ink-900);
  border-radius:var(--radius-pill);background:var(--surface);overflow:hidden;}
progress::-webkit-progress-bar{background:var(--surface);}
progress::-webkit-progress-value{background:var(--accent-bright);}
progress::-moz-progress-bar{background:var(--accent-bright);}
.alert{padding:14px 18px;border-radius:var(--radius);border:var(--bw) solid var(--ink-900);box-shadow:var(--shadow-sm);}
.alert.bad{background:var(--coral-tint);}

/* results tabbed viewer (segmented switcher) */
.result-viewer{padding:18px 20px;}
.rtabs-wrap{overflow-x:auto;margin-bottom:20px;}
.rtabs{display:inline-flex;gap:3px;border:var(--bw-thick) solid var(--ink-900);border-radius:var(--radius-lg);
  background:var(--paper-deep);padding:5px;white-space:nowrap;}
.rtab{font-family:var(--font-sans);font-weight:700;font-size:14px;border:var(--bw) solid transparent;
  background:transparent;color:var(--text-muted);padding:9px 16px;border-radius:var(--radius);cursor:pointer;
  line-height:1;white-space:nowrap;transition:background var(--dur),color var(--dur);}
.rtab:hover{color:var(--ink-900);}
.rtab.on{background:var(--surface);color:var(--ink-900);border-color:var(--ink-900);box-shadow:var(--shadow-xs);}
.rpanel{display:none;}
.rpanel.on{display:block;}
.tbl-scroll{overflow-x:auto;}

/* admin dashboard + compare diff */
.admin h3{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--ink-900);margin:0 0 12px;}
.admin .card{padding:20px 22px;}
.admin-list td .badge{font-size:11px;padding:3px 9px;text-transform:none;}
.admin-list input[type=radio]{width:16px;height:16px;cursor:pointer;}
.admin a.backlink{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--blue-deep);}
table.cmp{width:100%;border-collapse:collapse;font-size:13px;}
table.cmp th,table.cmp td{text-align:left;padding:6px 10px;border-bottom:1px solid var(--ink-100);}
table.cmp th{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--text-muted);font-weight:600;}
table.cmp td{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--ink-900);}
table.cmp th:nth-child(n+4),table.cmp td:nth-child(n+4){text-align:right;}
table.cmp td.lbl{font-family:var(--font-sans);font-weight:600;}
table.cmp tr.total td{font-weight:700;border-top:var(--bw) solid var(--ink-900);}
table.cmp tr.changed{background:var(--lemon-tint);}
table.cmp tr.changed td{font-weight:600;}
body.diffs-only table.cmp tr.same{display:none;}

/* download / nav buttons inside fragments */
#work a[role=button]{font-family:var(--font-sans);font-weight:700;font-size:15px;border:var(--bw) solid var(--ink-900);
  border-radius:var(--radius);padding:11px 18px;background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-sm);
  display:inline-flex;align-items:center;gap:8px;margin-right:10px;transition:transform var(--dur) var(--ease-snap),box-shadow var(--dur) var(--ease-snap);}
#work a[role=button]:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow);}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero-grid,.steps,.feat-grid,.foot-grid{grid-template-columns:1fr;}
  .hero{padding:48px 0 40px;}
  .hero h1{font-size:38px;}
  .sec-head h2{font-size:30px;}
  .cta h2{font-size:34px;}
  .nav-links{display:none;}
  section{padding:60px 0;}
  table.num{font-size:12px;}
  table.num th,table.num td{padding:5px 6px;}
}
