:root{
  --azul:#1f4e79; --azul-claro:#2e6da4; --verde:#1f8a4c; --vermelho:#c0392b;
  --cinza:#f4f6f9; --cinza-borda:#e2e6ec; --texto:#27313d; --suave:#6b7785;
  --radius:10px; --sombra:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',system-ui,-apple-system,Arial,sans-serif;background:var(--cinza);color:var(--texto);font-size:15px;line-height:1.5}
a{color:var(--azul-claro);text-decoration:none}

/* Login */
.tela-login{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1f4e79,#2e6da4)}
.card-login{background:#fff;padding:36px 32px;border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.2);width:340px;max-width:92vw}
.login-marca{text-align:center;margin-bottom:22px}
.login-icone{font-size:34px}
.login-marca h1{font-size:20px;margin:8px 0 2px}
.login-marca p{color:var(--suave);font-size:13px;margin:0}
.card-login label{display:block;font-size:13px;color:var(--suave);margin-bottom:14px}
.card-login input{width:100%;margin-top:5px;padding:11px 12px;border:1px solid var(--cinza-borda);border-radius:8px;font-size:15px}

/* Layout */
.topo{display:flex;align-items:center;gap:16px;background:var(--azul);color:#fff;padding:0 20px;height:56px;position:sticky;top:0;z-index:20}
.topo-marca{display:flex;align-items:center;gap:8px;font-size:16px}
.topo-usuario{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:14px}
.topo-usuario small{color:#cfe0f0}
.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:22px;cursor:pointer}
.layout{display:flex;min-height:calc(100vh - 56px)}
.menu{width:210px;background:#fff;border-right:1px solid var(--cinza-borda);padding:14px 0;flex-shrink:0}
.menu a{display:block;padding:11px 22px;color:var(--texto);font-size:14px;border-left:3px solid transparent}
.menu a:hover{background:var(--cinza)}
.menu a.ativo{border-left-color:var(--azul);background:#eef4fa;color:var(--azul);font-weight:600}
.conteudo{flex:1;padding:24px;max-width:1100px}
.rodape{text-align:center;color:var(--suave);padding:16px}

/* Cabeçalho de página */
.pagina-cabecalho{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.pagina-cabecalho h2{margin:0;font-size:22px}
.filtro-mes input{padding:8px 10px;border:1px solid var(--cinza-borda);border-radius:8px}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.card{background:#fff;border:1px solid var(--cinza-borda);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--sombra)}
.card-saldo{background:var(--azul);color:#fff;border:0}
.card-saldo .card-rotulo{color:#cfe0f0}
.card-rotulo{display:block;font-size:12px;color:var(--suave);text-transform:uppercase;letter-spacing:.04em}
.card-valor{display:block;font-size:22px;font-weight:700;margin-top:6px}
.positivo{color:var(--verde)} .card-saldo .positivo{color:#fff}
.negativo{color:var(--vermelho)}

/* Blocos */
.bloco{background:#fff;border:1px solid var(--cinza-borda);border-radius:var(--radius);padding:18px 20px;margin-bottom:18px;box-shadow:var(--sombra)}
.bloco h3{margin:0 0 14px;font-size:16px;color:var(--azul)}

/* Formulários */
.form-linha{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.form-linha label,.card-login label{font-size:13px;color:var(--suave)}
.form-linha label{display:flex;flex-direction:column;gap:5px}
.form-linha input,.form-linha select{padding:9px 11px;border:1px solid var(--cinza-borda);border-radius:8px;font-size:14px;min-width:140px}
.check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--texto)}
.inline{display:inline}

/* Botões */
.btn{display:inline-block;border:0;border-radius:8px;padding:10px 16px;font-size:14px;cursor:pointer;font-weight:600}
.btn-primario{background:var(--azul);color:#fff}
.btn-primario:hover{background:var(--azul-claro)}
.btn-sec{background:#e9eef4;color:var(--azul)}
.btn-perigo{background:#fdecea;color:var(--vermelho)}
.btn-perigo:hover{background:#f9d7d3}
.btn-pequeno{padding:6px 10px;font-size:12px}
.btn-bloco{width:100%;margin-top:6px}
.acoes-linha{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}

/* Tabelas */
.tabela{width:100%;border-collapse:collapse;font-size:14px}
.tabela th,.tabela td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--cinza-borda)}
.tabela th{font-size:12px;text-transform:uppercase;color:var(--suave);letter-spacing:.03em}
.tabela .dir{text-align:right}
.vazio{color:var(--suave);text-align:center;padding:18px}
.lista-simples{margin:8px 0 0;padding-left:18px}

/* Badges e alertas */
.badge{font-size:12px;padding:3px 9px;border-radius:20px;font-weight:600}
.badge-ok{background:#e6f4ec;color:var(--verde)}
.badge-pendente{background:#fdecea;color:var(--vermelho)}
.alerta{padding:11px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}
.alerta-sucesso{background:#e6f4ec;color:var(--verde)}
.alerta-erro{background:#fdecea;color:var(--vermelho)}
.texto-aviso{margin:0 0 10px}
.texto-discreto{color:var(--suave);font-size:13px}

/* Água */
.agua-resumo{display:flex;flex-wrap:wrap;gap:28px;margin-bottom:14px}
.agua-resumo strong{display:block;font-size:19px;margin-top:4px}
.barra-progresso{height:22px;background:#eef1f5;border-radius:20px;overflow:hidden;margin:6px 0}
.barra-preenchida{height:100%;background:linear-gradient(90deg,#1f8a4c,#27ae60);transition:width .4s}
.agua-falta{font-size:15px;margin:10px 0 18px}

/* Responsivo */
@media(max-width:760px){
  .menu-toggle{display:block}
  .menu{position:fixed;left:-220px;top:56px;bottom:0;transition:left .25s;z-index:30}
  body.menu-aberto .menu{left:0}
  .conteudo{padding:16px}
  .topo-usuario span{display:none}
}
