/* Importa uma fonte moderna do Google Fonts (Opcional, mas recomendado) */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');

/* Variáveis de Cor (facilita manutenção) */
:root {
  --cor-primaria: #0BA132; /* Verde Principal */
  --cor-primaria-hover: #098a2a; /* Verde mais escuro para hover */
  --cor-texto: #475151; /* Cinza Escuro para texto */
  --cor-fundo-body: #F8F8F7; /* Off-white/Cinza claro para fundo geral */
  --cor-fundo-container: #ffffff; /* Branco para o container do formulário */
  --cor-borda-input: #ced4da; /* Cinza claro para bordas (padrão Bootstrap) */
  --cor-fundo-input: #F8F8F7; /* Fundo levemente cinza para inputs */
  --cor-sucesso: #198754; /* Verde Bootstrap para sucesso */
  --cor-erro: #dc3545; /* Vermelho Bootstrap para erro */
  --cor-info: #0dcaf0; /* Azul Bootstrap para info */
}

body {
  font-family: 'Poppins', sans-serif; /* Aplica a fonte importada */
  background-color: var(--cor-fundo-body);
  color: var(--cor-texto);
  padding-top: 40px; /* Mais espaço no topo */
  padding-bottom: 60px; /* Mais espaço embaixo */
  line-height: 1.6;
}

.container {
  max-width: 750px; /* Um pouco mais largo */
  background-color: var(--cor-fundo-container);
  padding: 40px; /* Mais padding interno */
  border-radius: 12px; /* Bordas mais arredondadas */
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1); /* Sombra mais pronunciada */
  margin-top: 20px;
  border: 1px solid #eee; /* Borda sutil */
}

/* Títulos */
h2.mb-4 {
  color: var(--cor-primaria); /* Título principal em verde */
  font-weight: 600;
  margin-bottom: 2rem !important; /* Mais espaço abaixo do título principal */
}

h5.mt-4 {
  color: var(--cor-texto);
  font-weight: 600;
  border-bottom: 2px solid var(--cor-primaria); /* Linha verde abaixo dos subtítulos */
  padding-bottom: 8px;
  margin-bottom: 1.8rem !important; /* Mais espaço abaixo dos subtítulos */
}

/* Labels */
.form-label {
  font-weight: 500;
  color: var(--cor-texto);
  margin-bottom: 0.5rem;
}

/* Inputs, Selects, Textareas */
.form-control,
.form-select {
  border-radius: 8px; /* Bordas arredondadas */
  border: 1px solid var(--cor-borda-input);
  padding: 0.75rem 1rem; /* Padding interno maior */
  background-color: var(--cor-fundo-input); /* Fundo levemente cinza */
  color: var(--cor-texto);
  transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out; /* Transição suave */
}

.form-control::placeholder {
  color: #999; /* Cor do placeholder */
  opacity: 1;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--cor-primaria); /* Borda verde ao focar */
  box-shadow: 0 0 0 0.25rem rgba(11, 161, 50, 0.2); /* Sombra verde suave ao focar */
  background-color: #fff; /* Fundo branco ao focar */
}

/* Botão Primário (Salvar) */
#submitBtn {
  background-color: var(--cor-primaria);
  border-color: var(--cor-primaria);
  color: #ffffff;
  padding: 0.8rem 1.5rem; /* Botão maior */
  font-weight: 500;
  border-radius: 8px;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, transform 0.1s ease; /* Transição suave */
  text-transform: uppercase; /* Texto em maiúsculas */
  letter-spacing: 0.5px; /* Espaçamento entre letras */
}

#submitBtn:hover {
  background-color: var(--cor-primaria-hover);
  border-color: var(--cor-primaria-hover);
  transform: translateY(-2px); /* Efeito sutil de levantar ao passar o mouse */
  box-shadow: 0 4px 10px rgba(11, 161, 50, 0.2);
}

#submitBtn:focus {
   box-shadow: 0 0 0 0.25rem rgba(11, 161, 50, 0.5); /* Sombra de foco mais forte */
}

#submitBtn:disabled {
  background-color: #a3d9b1; /* Cor mais clara quando desabilitado */
  border-color: #a3d9b1;
  cursor: not-allowed;
}

/* Mensagens de Status e Erro */
#status {
  border-radius: 8px;
  padding: 1rem;
  font-weight: 500;
}
#status .spinner-border {
    color: inherit; /* Usa a cor do texto do alerta */
}

/* Ajustes específicos para classes de alerta Bootstrap (se usadas) */
.alert-success {
    background-color: #d1e7dd;
    border-color: #badbcc;
    color: #0f5132;
}
.alert-danger {
    background-color: #f8d7da;
    border-color: #f5c2c7;
    color: #842029;
}
.alert-info {
    background-color: #cff4fc;
    border-color: #b6effb;
    color: #055160;
}


#cep-error {
  color: var(--cor-erro);
  font-size: 0.875em;
  margin-top: 0.25rem;
}

/* Ajuste para o spinner dentro do botão (se você adicionar) */
#submitBtn .spinner-border {
  width: 1rem;
  height: 1rem;
  margin-right: 8px;
  vertical-align: text-bottom;
}
