/* Modal oculto por padrão */
.modal-cadastro {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 99999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

/* Modal visível quando tem a classe 'mostrar' */
.modal-cadastro.mostrar {
  opacity: 1;
  visibility: visible;
}

/* Container do modal */
.modal-cadastro .modal {
  background: #1f1f1f;
  border-radius: 15px;
  padding: 25px;
  width: 90%;
  max-width: 380px;
  position: relative;
  border: 1px solid #303030;
  transform: scale(0.7);
  transition: transform 0.3s ease;
}

.modal-cadastro.mostrar .modal {
  transform: scale(1);
}

/* Botão X para fechar */
.modal-close {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 25px;
  height: 25px;
  cursor: pointer;
  opacity: 0.7;
}

.modal-close:hover {
  opacity: 1;
}

.modal-close::before,
.modal-close::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 2px;
  background: #fff;
  transform: translate(-50%, -50%) rotate(45deg);
}

.modal-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* Título */
.modal-title {
  font-size: 20px;
  color: #efefef;
  text-align: center;
  margin-bottom: 25px;
  background: linear-gradient(90deg, #ead4a0, #b48943);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Formulário */
.form_sql {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.form_sql label {
  font-size: 14px;
  color: #efefef;
  margin-bottom: 5px;
}

.form_sql input {
  padding: 12px;
  border: 1px solid #303030;
  border-radius: 8px;
  background: #0b0d0b;
  color: #efefef;
  font-size: 14px;
}

.form_sql input:focus {
  outline: none;
  border-color: #b48943;
}

.form_sql input::placeholder {
  color: #666;
}

/* Mensagens de resposta */
.modal-response {
  min-height: 20px;
  color: #ff222c;
  font-size: 14px;
  text-align: center;
}

/* Loading */
.loader {
  display: none;
  width: 20px;
  height: 20px;
  border: 2px solid transparent;
  border-top: 2px solid #0f110f;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

/* LOADER CENTRALIZADO NO BOTÃO DO MODAL */
.form_sql .loader {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 18px;
  height: 18px;
}

.form_sql .onm-btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 45px;
}

.form_sql .onm-btn.sended .loader {
  display: block;
}

.form_sql .onm-btn.sended .onm-btn-txt {
  opacity: 0;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Termos */
.modal-terms {
  font-size: 12px;
  color: #9d9e9d;
  text-align: center;
  margin-top: 15px;
}

.modal-terms a {
  color: #b48943;
  text-decoration: none;
}

.modal-terms a:hover {
  text-decoration: underline;
}