/* Painel de Controle Financeiro — Prefeitura de Mossâmedes
   Paleta: verde Cerrado + dourado Serra Dourada + azul gov. CSS puro, sem build. */
:root{
  --verde:#13533a; --verde-2:#1f7a51; --verde-3:#e7f1ea;
  --ouro:#b8862f; --ouro-2:#e0bd62; --ouro-soft:#f7eed6;
  --azul:#1d4e6f;
  --ink:#16211c; --muted:#5e6b63; --line:#e4e9e4;
  --bg:#f3f6f3; --card:#ffffff;
  --ok:#1f7a51; --warn:#b8862f; --danger:#b23b2c;
  --shadow:0 1px 2px rgba(20,40,30,.06), 0 6px 18px rgba(20,40,30,.05);
  --radius:14px;
  --font:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--azul)}
.hidden{display:none !important}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

/* ---------------- topo ---------------- */
.topbar{position:sticky;top:0;z-index:20;background:linear-gradient(100deg,var(--verde),var(--verde-2));
  color:#fff;display:flex;align-items:center;gap:14px;padding:12px 22px;box-shadow:var(--shadow)}
.brasao{width:42px;height:42px;border-radius:50%;background:var(--ouro-soft);display:grid;place-items:center;
  font-weight:800;color:var(--verde);font-size:18px;flex:none;border:2px solid var(--ouro-2)}
.topbar h1{font-size:1.06rem;margin:0;font-weight:700;letter-spacing:.2px}
.topbar .sub{font-size:.78rem;opacity:.85;margin-top:1px}
.topbar .spacer{flex:1}
.tag{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);padding:4px 10px;border-radius:999px;
  font-size:.74rem;font-weight:600}
.btn{cursor:pointer;border:0;border-radius:9px;font:inherit;font-weight:600;padding:9px 14px;transition:.15s}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.26)}
.btn-primary{background:var(--ouro);color:#3a2c08}
.btn-primary:hover{background:var(--ouro-2)}

/* ---------------- layout ---------------- */
.wrap{max-width:1280px;margin:0 auto;padding:20px 22px 60px}
.section-title{font-size:.82rem;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);
  font-weight:700;margin:26px 2px 12px;display:flex;align-items:center;gap:8px}
.section-title::before{content:"";width:14px;height:14px;border-radius:4px;background:var(--ouro);display:inline-block}

/* ---------------- KPIs ---------------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;
  box-shadow:var(--shadow);border-left:5px solid var(--verde-2);position:relative}
.kpi.k-ouro{border-left-color:var(--ouro)}
.kpi.k-azul{border-left-color:var(--azul)}
.kpi.k-danger{border-left-color:var(--danger)}
.kpi .label{font-size:.76rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi .value{font-size:1.5rem;font-weight:800;margin-top:6px;letter-spacing:-.4px}
.kpi .hint{font-size:.74rem;color:var(--muted);margin-top:4px}
.kpi .value.neg{color:var(--danger)}
.kpi .value.pos{color:var(--ok)}

/* ---------------- cards / gráficos ---------------- */
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:16px 18px;display:flex;flex-direction:column}
.card h3{margin:0 0 2px;font-size:.98rem;font-weight:700}
.card .cap{font-size:.76rem;color:var(--muted);margin:0 0 10px}
.card .chart-box{position:relative;flex:1;min-height:240px}
.card.tall .chart-box{min-height:330px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.toggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.toggle button{border:0;background:#fff;padding:6px 12px;font:inherit;font-size:.8rem;font-weight:600;color:var(--muted);cursor:pointer}
.toggle button.on{background:var(--verde);color:#fff}

/* ---------------- mínimos constitucionais ---------------- */
.minimos{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.gauge{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}
.gauge .top{display:flex;justify-content:space-between;align-items:baseline}
.gauge .pct{font-size:2rem;font-weight:800}
.gauge .meta{font-size:.8rem;color:var(--muted)}
.bar{height:16px;border-radius:9px;background:#eef2ee;margin:12px 0 6px;position:relative;overflow:hidden}
.bar > span{display:block;height:100%;border-radius:9px;background:linear-gradient(90deg,var(--verde-2),var(--verde))}
.bar .mark{position:absolute;top:-4px;bottom:-4px;width:2px;background:var(--danger)}
.gauge .legenda{font-size:.76rem;color:var(--muted)}
.pill{display:inline-block;font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:999px}
.pill.ok{background:var(--verde-3);color:var(--verde)}
.pill.no{background:#f6e3df;color:var(--danger)}

/* ---------------- tabela ---------------- */
.filtros{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:10px;margin-bottom:12px}
.filtros input,.filtros select{font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink);width:100%}
.filtros input:focus,.filtros select:focus{outline:2px solid var(--verde-3);border-color:var(--verde-2)}
.tablewrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
table{border-collapse:collapse;width:100%;font-size:.85rem}
thead th{position:sticky;top:0;background:#f0f4f0;text-align:left;padding:10px 12px;font-weight:700;color:var(--verde);
  white-space:nowrap;cursor:pointer;user-select:none;border-bottom:1px solid var(--line)}
thead th.r{text-align:right}
thead th .arrow{opacity:.4;font-size:.7rem}
tbody td{padding:9px 12px;border-bottom:1px solid #f0f2ef;vertical-align:top}
tbody td.r{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
tbody tr:hover{background:#f8faf8}
tbody td.obj{color:var(--muted);font-size:.8rem;max-width:360px}
.tablefoot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:12px}
.muted{color:var(--muted);font-size:.82rem}
.pager{display:flex;gap:6px;align-items:center}
.pager button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 11px;cursor:pointer;font:inherit;font-weight:600}
.pager button:disabled{opacity:.45;cursor:default}

/* rodapé */
.rodape{margin-top:34px;color:var(--muted);font-size:.78rem;text-align:center;line-height:1.6}

/* ---------------- login ---------------- */
.login{position:fixed;inset:0;z-index:50;background:linear-gradient(140deg,var(--verde),#0c3a28);
  display:grid;place-items:center;padding:20px}
.login .box{background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.35);padding:34px 30px;width:min(380px,94vw);text-align:center}
.login .brasao{width:62px;height:62px;font-size:26px;margin:0 auto 14px}
.login h2{margin:0 0 2px;color:var(--verde);font-size:1.25rem}
.login p{margin:0 0 20px;color:var(--muted);font-size:.86rem}
.login input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:1rem;text-align:center;letter-spacing:2px}
.login input:focus{outline:2px solid var(--verde-3);border-color:var(--verde-2)}
.login .btn-primary{width:100%;margin-top:14px;padding:12px}
.login .erro{color:var(--danger);font-size:.84rem;margin-top:12px;min-height:18px}

/* ---------------- responsivo ---------------- */
@media (max-width:980px){ .cols-3{grid-template-columns:1fr} .cols-2{grid-template-columns:1fr}
  .minimos{grid-template-columns:1fr} .filtros{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .filtros{grid-template-columns:1fr} .topbar h1{font-size:.95rem}
  .wrap{padding:14px} tbody td.obj{display:none} thead th.objh{display:none} }
