:root {
  --bg: #f7f7f5;
  --fg: #222;
  --muted: #777;
  --accent: #2d6a4f;
  --border: #ddd;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--fg);
}
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.25rem;
  background: #fff;
  border-bottom: 1px solid var(--border);
}
.brand { font-weight: 700; color: var(--accent); }
.topbar nav a { color: var(--accent); text-decoration: none; margin-left: 1rem; }
.container { max-width: 920px; margin: 2rem auto; padding: 0 1.25rem; }
.btn {
  display: inline-block;
  padding: 0.55rem 1.1rem;
  background: var(--accent);
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
}
.muted { color: var(--muted); }

.topbar nav { display: flex; align-items: center; gap: 1rem; }
.who { color: var(--muted); font-size: 0.9rem; }
.who em { font-style: normal; color: var(--accent); }

.alert {
  background: #fdecea;
  color: #8a1c1c;
  border: 1px solid #f5c2c0;
  padding: 0.6rem 0.9rem;
  border-radius: 6px;
}

.card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  margin: 1.25rem 0;
}
.card h2 { margin-top: 0; font-size: 1.05rem; }
.row { display: flex; gap: 0.6rem; flex-wrap: wrap; align-items: center; }
.row input[type="email"] { flex: 1; min-width: 220px; }
input, select {
  padding: 0.45rem 0.55rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  font: inherit;
}

.grid { width: 100%; border-collapse: collapse; background: #fff; }
.grid th, .grid td {
  text-align: left;
  padding: 0.55rem 0.7rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.92rem;
}
.grid thead th { background: #f0f0ee; }
.grid tr.inactive { color: var(--muted); background: #fafafa; }
.grid .inline { display: inline; }
.actions { white-space: nowrap; }
.tag {
  background: var(--accent); color: #fff; border-radius: 4px;
  font-size: 0.7rem; padding: 0.05rem 0.35rem; vertical-align: middle;
}
button.link {
  background: none; border: none; color: var(--accent);
  cursor: pointer; padding: 0; font: inherit; margin-right: 0.5rem;
}
button.link.danger { color: #b42318; }
ul.links { line-height: 1.8; }

.ok {
  background: #e7f6ec;
  color: #1b5e34;
  border: 1px solid #b6e0c4;
  padding: 0.6rem 0.9rem;
  border-radius: 6px;
}
.card label { display: block; margin: 0.75rem 0; }
.card label > select,
.card label > input[type="text"],
.card label > input[type="file"],
.card label > input[type="date"],
.card label > textarea { display: block; width: 100%; margin-top: 0.25rem; }
fieldset.subtle {
  border: 1px dashed var(--border);
  border-radius: 6px;
  padding: 0.5rem 0.9rem 0.9rem;
  margin: 0.75rem 0;
}
fieldset.subtle legend { color: var(--muted); font-size: 0.85rem; padding: 0 0.4rem; }

.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; align-items: start; }
@media (max-width: 720px) { .two-col { grid-template-columns: 1fr; } }
iframe.pdf, object.pdf {
  display: block; width: 100%; height: 70vh;
  border: 1px solid var(--border); border-radius: 8px; background: #fff;
}
.actions a { margin-right: 0.5rem; }

.cards-row { display: flex; gap: 1rem; flex-wrap: wrap; margin: 1rem 0; }
.stat {
  background: #fff; border: 1px solid var(--border); border-radius: 8px;
  padding: 0.8rem 1.1rem; min-width: 160px;
}
.stat span { display: block; color: var(--muted); font-size: 0.8rem; }
.stat strong { font-size: 1.25rem; color: var(--accent); }

/* Avulsos — linking PIX/boletos to expenses */
.btn-sm { padding: 0.3rem 0.7rem; font-size: 0.85rem; }
.candidates { list-style: none; padding: 0; margin: 0.5rem 0; }
.candidates li {
  border-top: 1px solid var(--border); padding: 0.5rem 0;
  display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap;
}
.candidates form { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; margin: 0; }
.inline-link { margin-top: 0.75rem; display: flex; align-items: flex-end; gap: 0.6rem; flex-wrap: wrap; }
.inline-link label { flex: 1; min-width: 240px; margin: 0; }
.badge {
  display: inline-block; padding: 0.1rem 0.45rem; border-radius: 4px;
  font-size: 0.72rem; font-weight: 700; color: #fff;
}
.badge-high { background: #2d6a4f; }
.badge-medium { background: #b08900; }
.badge-low { background: #999; }

/* Painel — dashboard */
a.stat.action { text-decoration: none; color: inherit; transition: border-color 0.15s; }
a.stat.action:hover { border-color: var(--accent); }
a.stat.action.has-items strong { color: #b08900; }
a.stat.action strong { color: var(--muted); }
.bar {
  display: inline-block; width: 120px; height: 8px; background: #eee;
  border-radius: 4px; overflow: hidden; vertical-align: middle;
}
.bar-fill { height: 100%; background: var(--accent); }
.bar-fill.over { background: #b3261e; }
.pill {
  display: inline-block; min-width: 1.4em; padding: 0.05rem 0.4rem; text-align: center;
  background: #b08900; color: #fff; border-radius: 10px; font-size: 0.8rem; font-weight: 700;
}
.alert-text { color: #b3261e; font-weight: 700; }

/* Projeção — chart */
svg.chart {
  display: block; width: 100%; max-width: 720px; height: auto;
  background: #fff; border: 1px solid var(--border); border-radius: 8px;
  margin: 1rem 0; padding: 0.5rem;
}
tr.future-row td { color: var(--muted); font-style: italic; }

/* Extratos — reconciliation */
.ok-box {
  background: #e7f4ec; color: #1b4332; border: 1px solid #b7dfc6;
  padding: 0.6rem 0.9rem; border-radius: 6px;
}
.badge-status {
  display: inline-block; padding: 0.1rem 0.5rem; border-radius: 10px;
  font-size: 0.75rem; font-weight: 600; white-space: nowrap;
}
.badge-status.ok { background: #e7f4ec; color: #1b4332; }
.badge-status.warn { background: #fff3cd; color: #7a5b00; }
.badge-status.muted { background: #eee; color: #777; }
