/* Container com transição suave (0.5s) */
.ao-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition: opacity .5s ease, visibility .5s ease;
}

/* Quando aberto */
.ao-modal[aria-hidden="false"] {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

/* Backdrop com fade-in */
.ao-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.5);
  opacity: 0;
  transition: opacity .5s ease;
}
.ao-modal[aria-hidden="false"] .ao-modal__backdrop {
  opacity: 1;
}

/* Conteúdo: mais retangular, centrado; anima leve subida/scale */
.ao-modal__content {
  position: relative;
  margin: 6vh auto;
  width: 92%;
  max-width: 560px;
  background: #fff;
  border-radius: 10px; /* mais retangular que antes */
  padding: 20px 20px 16px;
  box-shadow: 0 22px 70px rgba(0,0,0,.25);
  transform: translateY(10px) scale(.98);
  opacity: 0;
  transition: transform .5s ease, opacity .5s ease;
}
.ao-modal[aria-hidden="false"] .ao-modal__content {
  transform: translateY(0) scale(1);
  opacity: 1;
}

/* Fechar */
.ao-modal__close {
  position: absolute;
  right: 12px;
  top: 10px;
  border: 0;
  background: transparent;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

/* Título */
.ao-modal__title {
  margin: 0 0 12px;
  font-size: 1.25rem;
  font-weight: 800;
}

/* Formulário: stack vertical */
.ao-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ao-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 600;
}

.ao-form input,
.ao-form select,
.ao-form textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #d9d9d9;
  border-radius: 8px;
  font: inherit;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}

.ao-form input:focus,
.ao-form select:focus,
.ao-form textarea:focus {
  border-color: var(--ao-primary, #006eff);
  box-shadow: 0 0 0 3px rgba(0,110,255,.12);
}

/* Consentimento */
.ao-consent {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-weight: 400;
}

/* Botão full width */
.ao-btn {
  width: 100%;
  margin-top: 4px;
  padding: 12px 16px;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 700;
  background: var(--ao-primary, #006eff);
  color: #fff;
  transition: filter .2s ease, transform .03s ease;
}
.ao-btn:hover { filter: brightness(1.05); }
.ao-btn:active { transform: translateY(1px); }

/* Feedback */
.ao-feedback {
  margin-top: 6px;
  font-size: .95rem;
  min-height: 1.1em;
}

.ao-trigger {
	visibility: hidden;
}

/* Responsivo */
@media (max-width: 420px) {
  .ao-modal__content {
    margin: 4vh auto;
    padding: 16px 14px 12px;
    border-radius: 8px;
  }
  .ao-modal__title { font-size: 1.15rem; }
	
  .ao-form {
    gap: 0;
  }
}
