:root {
  --bg: #f5f4f0;
  --card: #ffffff;
  --text: #1a1a1a;
  --dim: #6b6b6b;
  --border: #e2e0da;
  --accent: #1a7f5a;
  --accent-soft: #e3f2ec;
  --danger: #b3372f;
  --warn: #9a6b00;
  --warn-soft: #fdf3d8;
  --radius: 10px;
}
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #16181a;
    --card: #1f2225;
    --text: #eceae6;
    --dim: #9b9b95;
    --border: #33363a;
    --accent: #3dbd8b;
    --accent-soft: #143126;
    --danger: #e5695f;
    --warn: #d9a93f;
    --warn-soft: #33290f;
  }
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font: 16px/1.45 system-ui, -apple-system, "Segoe UI", sans-serif;
}
main { max-width: 640px; margin: 0 auto; padding: 16px 12px 64px; }
h1 { font-size: 1.35rem; margin: 12px 4px; }
h2 { font-size: 1rem; margin: 0 0 10px; }
a { color: var(--accent); text-decoration: none; }
.dim { color: var(--dim); }
.small { font-size: .85rem; }
.backlink { display: inline-block; margin-top: 8px; }

.topnav {
  display: flex; gap: 16px; align-items: center;
  padding: 10px 16px;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 5;
}
.topnav .brand { font-weight: 700; margin-right: auto; }
.topnav a { color: var(--text); font-weight: 500; }

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  margin: 10px 0;
  display: block;
}
.card.empty { text-align: center; color: var(--dim); padding: 32px; }
a.row-card { color: var(--text); }
a.row-card:active { background: var(--accent-soft); }

.row-top { display: flex; justify-content: space-between; gap: 8px; align-items: baseline; }
.row-mid { margin: 4px 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.row-bot { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; font-size: .85rem; }
.amount { font-weight: 700; white-space: nowrap; }
.confidence { font-size: .8rem; }

.pill, .badge {
  display: inline-block;
  border-radius: 999px;
  padding: 1px 9px;
  font-size: .78rem;
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid transparent;
}
.badge-income { background: #e7edf9; color: #2d5fa8; }
.badge-report { background: var(--bg); color: var(--dim); border-color: var(--border); }
.small-h { font-size: 1.05rem; margin-top: 24px; }
.badge-excluded, .badge-warn { background: var(--warn-soft); color: var(--warn); }
@media (prefers-color-scheme: dark) { .badge-income { background: #17233a; color: #7ea9e8; } }

.flash { border-radius: var(--radius); padding: 10px 14px; margin: 10px 0; font-size: .92rem; }
.flash-ok { background: var(--accent-soft); color: var(--accent); }
.flash-warn { background: var(--warn-soft); color: var(--warn); }
.flash-error { background: #fbe6e4; color: var(--danger); }
@media (prefers-color-scheme: dark) { .flash-error { background: #3a1a17; } }

label { display: block; margin: 10px 0 4px; font-size: .9rem; font-weight: 500; }
input, select {
  width: 100%;
  font-size: 16px; /* prevents iOS zoom */
  padding: 10px;
  margin-top: 4px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg);
  color: var(--text);
}
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 10px; }
@media (max-width: 420px) { .grid2 { grid-template-columns: 1fr; } }

.kind-picker { border: 0; padding: 0; margin: 0 0 6px; display: flex; gap: 6px; }
.kind-picker label {
  flex: 1; text-align: center; margin: 0;
  border: 1px solid var(--border); border-radius: 8px;
  padding: 9px 4px; cursor: pointer; font-weight: 500;
}
.kind-picker label:has(input:checked) {
  background: var(--accent-soft); border-color: var(--accent); color: var(--accent);
}
.kind-picker input { display: none; }

.taxprompt { background: var(--warn-soft); border-radius: 8px; padding: 4px 10px 10px; margin-top: 8px; }
.req { font-weight: 400; font-size: .78rem; color: var(--warn); }

.candidates { margin: 6px 0; display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.chip {
  border: 1px solid var(--border); background: var(--bg); color: var(--text);
  border-radius: 999px; padding: 4px 12px; font-size: .85rem; cursor: pointer;
}
.chip:active { background: var(--accent-soft); }

.btn {
  display: inline-block; border: 0; border-radius: 8px; cursor: pointer;
  font-size: 16px; font-weight: 600; padding: 12px 18px;
}
.btn-primary { background: var(--accent); color: #fff; width: 100%; margin-top: 14px; }
.btn-big { padding: 15px; font-size: 17px; }
.btn-danger { background: transparent; color: var(--danger); border: 1px solid var(--danger); }
.reject-form { display: flex; gap: 8px; margin-top: 12px; align-items: center; }
.reject-form select { flex: 1; margin: 0; }
.reject-form .btn { white-space: nowrap; }

table { width: 100%; border-collapse: collapse; font-size: .92rem; }
th, td { text-align: left; padding: 6px 4px; border-bottom: 1px solid var(--border); }
tr:last-child td { border-bottom: 0; }
.num { text-align: right; white-space: nowrap; }
table.mini td { padding: 4px; border: 0; }
tr.total td { border-top: 1px solid var(--border); font-weight: 600; }

.deadlines { list-style: none; padding: 0; margin: 0; }
.deadlines li { padding: 6px 0; border-bottom: 1px solid var(--border); }
.deadlines li:last-child { border: 0; }
.date-chip {
  display: inline-block; min-width: 64px; text-align: center;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; padding: 2px 6px; font-size: .82rem; font-weight: 600;
  margin-right: 8px;
}
.date-chip.soon { background: var(--warn-soft); color: var(--warn); border-color: var(--warn); }

.contractor { margin: 12px 0; }
.bar { height: 8px; background: var(--bg); border-radius: 999px; overflow: hidden; margin-top: 6px; }
.bar-fill { height: 100%; background: var(--accent); border-radius: 999px; }
.bar-fill.near { background: var(--warn); }
.bar-fill.over { background: var(--danger); }
.warn-text { color: var(--warn); }

.notes { padding-left: 18px; }
.notes li { margin: 6px 0; }

.body-excerpt {
  white-space: pre-wrap; word-break: break-word;
  font-size: .8rem; background: var(--bg);
  border-radius: 8px; padding: 10px; max-height: 320px; overflow: auto;
}

.login-card { max-width: 360px; margin: 12vh auto; text-align: center; }
.login-card form { text-align: left; }
