
.status-msg {
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  margin-top: 12px; /* 👈 muda de margin-bottom para margin-top */
  opacity: 0;
  transition: opacity 0.4s ease, transform 0.3s ease;
  transform: translateY(-5px); /* 👈 dá um efeito de deslizar de baixo pra cima */
}

.status-msg.show {
  opacity: 1;
  transform: translateY(0); /* 👈 aparece suavemente */
}

.status-msg.success {
  color: #4caf50; /* verde */
}

.status-msg.error {
  color: #f44336; /* vermelho */
}

  .contato-form button:hover {
    background-color: #d4d4d4;
  }

  /* Spinner de carregamento */
  .spinner {
    display: none;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
  }

  @keyframes spin {
    to {
      transform: rotate(360deg);
    }
  }

  .loading .texto-botao {
    display: none;
  }

  .loading .spinner {
    display: inline-block;
  }