/* ============================================================
   Vila Rica · Financeiro — design system (Moderno claro / SaaS)
   ============================================================ */
:root {
  --bg:#f4f6fa; --surface:#fff; --surface-2:#f7f9fc;
  --ink:#172033; --muted:#697287; --faint:#9aa3b5; --line:#e7ebf2;
  --brand:#2f6bff; --brand-weak:#eaf1ff; --brand-ink:#1e4fd0;
  --green:#13a05a; --green-weak:#e7f7ee; --red:#e0463c; --red-weak:#fdeceb;
  --amber:#c47d12; --amber-weak:#fdf3e3;
  --radius:14px; --radius-sm:10px;
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 6px 20px rgba(16,24,40,.06);
  --sidebar:236px;
}
* { box-sizing:border-box; }
html, body { margin:0; }
body {
  background:var(--bg); color:var(--ink);
  font:14.5px/1.5 "Inter", -apple-system, "Segoe UI", Roboto, system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
}
a { color:var(--brand); text-decoration:none; }
b { font-weight:600; }

/* ---------- layout ---------- */
.app { display:grid; grid-template-columns:var(--sidebar) 1fr; min-height:100vh; }
.sidebar {
  position:sticky; top:0; height:100vh; background:var(--surface);
  border-right:1px solid var(--line); display:flex; flex-direction:column;
  padding:16px 14px; gap:4px;
}
.brand { display:flex; align-items:center; gap:10px; padding:6px 8px 14px;
  color:var(--ink); font-weight:700; font-size:16px; }
.brand small { display:block; font-weight:500; font-size:11px; color:var(--faint);
  letter-spacing:.06em; text-transform:uppercase; }
.brand .dot { width:14px; height:14px; border-radius:5px;
  background:linear-gradient(135deg, var(--brand), #6f9bff); flex:none; }

.menu { display:flex; flex-direction:column; gap:2px; flex:1; }
.menu-grupo { margin:14px 10px 4px; font-size:10.5px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; color:var(--faint); }
.nav-item { display:flex; align-items:center; gap:11px; padding:9px 11px;
  border-radius:var(--radius-sm); color:var(--muted); font-weight:500; font-size:14px; }
.nav-item:hover { background:var(--surface-2); color:var(--ink); }
.nav-item.ativo { background:var(--brand-weak); color:var(--brand-ink); font-weight:600; }
.nav-item .ico { display:inline-flex; }
.nav-item .ico svg { width:19px; height:19px; fill:none; stroke:currentColor;
  stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }

.user-box { display:flex; align-items:center; gap:10px; margin-top:6px;
  padding:9px 10px; border:1px solid var(--line); border-radius:var(--radius-sm);
  background:var(--surface-2); }
.avatar { width:30px; height:30px; border-radius:50%; flex:none; color:#fff; font-weight:700;
  display:grid; place-items:center; background:linear-gradient(135deg,var(--brand),#6f9bff); }
.user-nome { font-size:13px; font-weight:600; line-height:1.2; flex:1; min-width:0; }
.user-nome small { display:block; font-weight:500; color:var(--faint); text-transform:capitalize; }
.sair { background:transparent; color:var(--muted); border:0; cursor:pointer; font-size:17px;
  padding:4px 6px; border-radius:8px; }
.sair:hover { background:var(--red-weak); color:var(--red); }

.main { min-width:0; }
.content { padding:26px 30px 60px; max-width:1180px; }

/* ---------- títulos / cabeçalho ---------- */
.pagina { font-size:21px; font-weight:700; margin:0 0 4px; letter-spacing:-.01em; }
.cabecalho-linha { display:flex; align-items:center; justify-content:space-between;
  gap:14px; flex-wrap:wrap; margin-bottom:8px; }
.sub-secao { font-size:13px; font-weight:700; color:var(--muted); margin:26px 0 10px;
  text-transform:uppercase; letter-spacing:.04em; }
.ajuda { color:var(--muted); font-size:13.5px; margin:6px 0 18px; max-width:70ch; }
.ajuda em { color:var(--faint); }

/* ---------- botões ---------- */
button, a.botao { font:inherit; }
button { background:var(--brand); color:#fff; border:0; border-radius:10px;
  padding:9px 16px; font-weight:600; font-size:14px; cursor:pointer; transition:filter .12s; }
button:hover { filter:brightness(1.06); }
a.botao, a.botao:visited { display:inline-flex; align-items:center; gap:6px; background:var(--brand);
  color:#fff; padding:9px 16px; border-radius:10px; font-weight:600; }
a.botao:hover { filter:brightness(1.06); }

/* ---------- cards ---------- */
.cards { display:grid; grid-template-columns:repeat(auto-fit, minmax(176px,1fr));
  gap:14px; margin:6px 0 18px; }
.card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px 18px; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:3px; }
.card .rotulo { font-size:12px; color:var(--muted); font-weight:500; }
.card .numero { font-size:23px; font-weight:700; letter-spacing:-.02em;
  font-variant-numeric:tabular-nums; }
.card .sub { font-size:12px; color:var(--faint); }
.card.destaque { background:linear-gradient(180deg, #fff, var(--brand-weak)); border-color:#d4e1ff; }
.card.alerta { background:linear-gradient(180deg,#fff,var(--red-weak)); border-color:#f6cfcb; }
.verde { color:var(--green); } .vermelho { color:var(--red); }

/* ---------- chips / abas (vistas) ---------- */
.por-operacao { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:14px; }
.chip { background:var(--surface); border:1px solid var(--line); border-radius:999px;
  padding:5px 12px; font-size:12.5px; color:var(--muted); }
.chip b { color:var(--ink); }
.vistas { display:flex; flex-wrap:wrap; gap:7px; margin:2px 0 16px; }
.vista { font-size:13px; color:var(--muted); padding:7px 14px; border-radius:999px;
  border:1px solid var(--line); background:var(--surface); cursor:pointer; }
.vista:hover { border-color:var(--brand); color:var(--brand); }
.vista.ativa { background:var(--brand); border-color:var(--brand); color:#fff; font-weight:600; }

/* ---------- filtros / formulários ---------- */
.filtros { display:flex; flex-wrap:wrap; gap:12px; align-items:end;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:14px 16px; box-shadow:var(--shadow); margin-bottom:16px; }
label { font-size:12px; color:var(--muted); font-weight:500; }
.filtros label { display:flex; flex-direction:column; gap:5px; }
select, input[type=text], input[type=date], input[type=number], input[type=password], textarea {
  border:1px solid var(--line); border-radius:9px; padding:8px 10px; font:inherit;
  font-size:14px; color:var(--ink); background:var(--surface); outline:none; transition:border-color .12s, box-shadow .12s; }
select:focus, input:focus, textarea:focus { border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-weak); }
.upload, .upload-inline { display:flex; gap:10px; align-items:center; }
.upload { background:var(--surface); border:1px dashed #cdd6e6; border-radius:var(--radius);
  padding:16px; margin:14px 0; }
.upload-inline input[type=file] { font-size:12px; max-width:240px; }
input[type=file] { font-size:13px; }

.form-titulo { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:20px; max-width:660px; display:flex; flex-direction:column; gap:15px; box-shadow:var(--shadow); }
.form-titulo label { display:flex; flex-direction:column; gap:5px; }
.form-titulo input:disabled { background:var(--surface-2); color:var(--faint); }
.linha-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-acoes { display:flex; gap:14px; align-items:center; margin-top:4px; }
a.cancelar, a.cancelar:visited { color:var(--muted); }

/* ---------- tabelas ---------- */
.grade { width:100%; border-collapse:collapse; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); }
.grade th { text-align:left; font-size:11px; text-transform:uppercase; letter-spacing:.04em;
  color:var(--muted); font-weight:600; padding:11px 14px; background:var(--surface-2);
  border-bottom:1px solid var(--line); white-space:nowrap; }
.grade td { padding:11px 14px; border-bottom:1px solid var(--line);
  font-variant-numeric:tabular-nums; }
.grade tbody tr:last-child td { border-bottom:0; }
.grade tbody tr:hover { background:var(--surface-2); }
.grade .num { text-align:right; white-space:nowrap; }
.grade tfoot td { border-top:2px solid var(--line); background:var(--surface-2); font-weight:600; }
.grade .vazio { text-align:center; color:var(--faint); padding:26px; }
.rev { color:var(--amber); font-style:normal; font-size:12px; }
tr.st-cancelado { color:var(--faint); text-decoration:line-through; }
tr.st-pago td { color:var(--muted); }
tr.st-pendente { background:#fffaf2; }

/* ---------- badges ---------- */
.badge { display:inline-block; padding:3px 9px; border-radius:999px; font-size:11.5px;
  font-weight:600; text-transform:capitalize; }
.badge.aberto, .badge.pendente { background:var(--amber-weak); color:var(--amber); }
.badge.pago, .badge.classificado, .badge.score-exata { background:var(--green-weak); color:var(--green); }
.badge.cancelado { background:#eef0f4; color:var(--faint); }
.badge.score-provavel { background:var(--brand-weak); color:var(--brand-ink); }
.badge.score-possivel { background:var(--amber-weak); color:var(--amber); }

/* ---------- ações em tabela ---------- */
.acoes { display:flex; gap:6px; align-items:center; }
.inline { display:inline; }
.acoes button { padding:5px 11px; font-size:12.5px; }
button.ok { background:var(--green); }
button.no { background:var(--surface); color:var(--red); border:1px solid var(--line); }
button.no:hover { background:var(--red-weak); filter:none; }
a.mini, a.mini:visited { font-size:12.5px; padding:5px 11px; border:1px solid var(--line);
  border-radius:9px; color:var(--brand); }
a.mini:hover { border-color:var(--brand); background:var(--brand-weak); }

/* ---------- mensagens ---------- */
.flash { background:var(--brand-weak); border:1px solid #cfe0fb; color:var(--brand-ink);
  padding:11px 15px; border-radius:var(--radius-sm); margin:0 0 14px; }
.erro { color:var(--red); }
.erro.bloco { background:var(--red-weak); border:1px solid #f6cfcb; padding:11px 15px;
  border-radius:var(--radius-sm); margin:0 0 14px; }
.notas { color:var(--muted); font-size:13px; padding-left:18px; }
.notas li { margin:3px 0; }

/* ---------- DFC duas colunas ---------- */
.duas-colunas { display:grid; grid-template-columns:1fr 1fr; gap:22px; }

/* ---------- mini-gráfico (sparkbars) ---------- */
.spark { display:flex; align-items:flex-end; gap:3px; height:84px; padding:14px 16px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); margin:6px 0 18px; overflow:hidden; }
.spark .bar { flex:1; min-width:3px; border-radius:3px 3px 0 0; background:var(--brand);
  opacity:.85; align-self:flex-end; }
.spark .bar.neg { background:var(--red); }
.spark-leg { display:flex; justify-content:space-between; font-size:11px; color:var(--faint);
  margin:-12px 2px 18px; }

/* ---------- login ---------- */
.login-body { display:grid; place-items:center; min-height:100vh;
  background:radial-gradient(1200px 500px at 50% -10%, #e8efff, var(--bg)); }
.login-card { background:var(--surface); border:1px solid var(--line); border-radius:18px;
  padding:30px; width:min(370px,92vw); display:flex; flex-direction:column; gap:14px;
  box-shadow:0 10px 40px rgba(16,24,40,.12); }
.login-card h1 { font-size:19px; margin:0 0 6px; font-weight:700; }
.login-card label { display:flex; flex-direction:column; gap:5px; }
.login-card input { width:100%; }
.login-card button { width:100%; padding:11px; margin-top:4px; }

/* ---------- responsivo ---------- */
@media (max-width:860px) {
  .app { grid-template-columns:1fr; }
  .sidebar { position:static; height:auto; flex-direction:row; flex-wrap:wrap;
    align-items:center; gap:6px; overflow-x:auto; }
  .brand { padding:6px 8px; }
  .menu { flex-direction:row; flex-wrap:wrap; flex:1 0 100%; order:3; }
  .menu-grupo { display:none; }
  .nav-item { padding:7px 10px; }
  .user-box { margin:0; }
  .content { padding:18px; }
  .duas-colunas { grid-template-columns:1fr; }
  .grade { display:block; overflow-x:auto; white-space:nowrap; }
}
