/* ============================================================================
 * Avíos Estilo — popup de captura de email (cupón 10% OFF)
 * ----------------------------------------------------------------------------
 * Hereda --ae-* del :root del sitio (assets/css/styles.css). No redeclara
 * tokens: fallback inline `var(--ae-x, #hex)` por si algún día se carga sin
 * el styles.css principal.
 *
 * Reusa .btn .btn-primary del sitio para el CTA; lo demás prefijo `aep-`.
 * Sin emojis. Voz institucional. z-index alto para tapar el header sticky.
 * ========================================================================= */

/* ---------- Overlay (fixed full-screen, encima del header sticky) -------- */
.aep-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.2rem;
  background: rgba(23, 23, 23, .58);   /* --ae-ink con alpha */
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease;
}
.aep-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.aep-overlay[hidden] { display: none; }

/* ---------- Modal = imagen arriba + franja blanca abajo ------------------ */
/* Dos partes apiladas: .aep-hero (imagen) y .aep-card (franja blanca con el
 * contenido). overflow:hidden recorta ambas a las esquinas redondeadas. */
.aep-modal {
  position: relative;
  width: 100%;
  max-width: 480px;
  color: var(--ae-ink-soft, #2b2b2b);
  border-radius: 16px;
  overflow: hidden;
  background: var(--ae-white, #FFFFFF);
  box-shadow: 0 24px 56px rgba(23, 23, 23, .28),
              0 8px 18px rgba(23, 23, 23, .14);
  font-family: "Montserrat", sans-serif;
  transform: translateY(8px) scale(.985);
  opacity: 0;
  transition: transform .26s ease, opacity .22s ease;
}
.aep-overlay.is-open .aep-modal {
  transform: translateY(0) scale(1);
  opacity: 1;
}

/* ---------- Hero: imagen de la mitad superior --------------------------- */
/* La imagen se setea inline desde popup.js (ruta relativa al documento). El
 * color de marca es el fallback si la imagen falta. */
.aep-hero {
  height: 200px;
  background-color: var(--ae-purple, #7B2A80);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

/* ---------- Card = franja blanca con TODO el contenido ------------------ */
.aep-card {
  position: relative;
  background: var(--ae-white, #FFFFFF);
  color: var(--ae-ink-soft, #2b2b2b);
  padding: 1.8rem 1.7rem 1.5rem;
}

@media (max-width: 480px) {
  .aep-modal { border-radius: 13px; }
  .aep-hero  { height: 150px; }
  .aep-card  { padding: 1.5rem 1.2rem 1.2rem; }
}

/* ---------- Botón cerrar (esquina, sobre la imagen → con contraste) ------ */
.aep-close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;                          /* sobre la card y la imagen */
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .92); /* contraste sobre cualquier fondo */
  border: 0;
  border-radius: 999px;
  color: var(--ae-ink, #171717);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(23, 23, 23, .28);
  transition: background .15s ease, color .15s ease;
}
.aep-close:hover,
.aep-close:focus-visible {
  background: var(--ae-white, #FFFFFF);
  color: var(--ae-purple, #7B2A80);
  outline: none;
}

/* ---------- Tipografía interna ------------------------------------------ */
.aep-title {
  margin: 0 0 .9rem;
  font-size: 2rem;
  line-height: 1.15;
  text-align: center;
  font-weight: 800;
  color: var(--ae-purple, #7B2A80);
}
.aep-desc {
  margin: 0 0 1.4rem;
  font-size: 1rem;
  line-height: 1.5;
  text-align: center;
  color: var(--ae-ink-soft, #2b2b2b);
}

@media (max-width: 480px) {
  .aep-title { font-size: 1.6rem; }
}

/* ---------- Form --------------------------------------------------------- */
.aep-form {
  display: flex;
  flex-direction: column;
  gap: .7rem;
}
.aep-input {
  font-family: inherit;
  font-size: 1rem;
  padding: .85rem 1rem;
  min-height: 48px;
  border: 1.5px solid var(--ae-gray, #DDE2E4);
  border-radius: 999px;
  background: var(--ae-white, #FFFFFF);
  color: var(--ae-ink, #171717);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.aep-input::placeholder { color: var(--ae-gray-dark, #6D6D72); }
.aep-input:focus {
  outline: none;
  border-color: var(--ae-purple, #7B2A80);
  box-shadow: 0 0 0 3px rgba(123, 42, 128, .15);
}
.aep-input:disabled {
  background: var(--ae-textile, #F4F6F5);
  cursor: not-allowed;
}

/* CTA reusa .btn.btn-primary; acá lo pintamos del violeta de marca (el
 * .btn-primary del sitio es ink/negro → invisible sobre la card negra). */
.aep-submit { width: 100%; }
.aep-submit.btn-primary {
  background: var(--ae-purple, #7B2A80);
  border-color: var(--ae-purple, #7B2A80);
  color: var(--ae-white, #FFFFFF);
}
.aep-submit.btn-primary:hover,
.aep-submit.btn-primary:focus-visible {
  background: var(--ae-purple-bright, #B85BE7);
  border-color: var(--ae-purple-bright, #B85BE7);
  color: var(--ae-white, #FFFFFF);
}
.aep-submit:disabled {
  cursor: not-allowed;
  opacity: .65;
  transform: none;
}

/* Honeypot: invisible al usuario, accesible para bots simples */
.aep-hp {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ---------- Status (errores inline) ------------------------------------- */
.aep-status {
  margin: .6rem 0 0;
  min-height: 1.1em;
  font-size: .85rem;
  color: var(--ae-ink-soft, #2b2b2b);
}
.aep-status--err {
  color: var(--ae-error, #B3261E);
  font-weight: 600;
}

/* ---------- Texto chico (validez + política) --------------------------- */
.aep-consent {
  margin: 1rem 0 0;
  font-size: .78rem;
  line-height: 1.45;
  text-align: center;
  color: var(--ae-ink-soft, #2b2b2b);
}
.aep-link {
  color: var(--ae-purple, #7B2A80);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.aep-link:hover { color: var(--ae-purple-dark, #37283F); }

/* ---------- Panel de éxito --------------------------------------------- */
.aep-exito {
  margin-top: .4rem;
  text-align: center;
}
.aep-exito-eyebrow {
  margin: 0 0 .6rem;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 800;
  color: var(--ae-purple, #7B2A80);
}
.aep-exito-codigo {
  margin: 0 0 .8rem;
  padding: .75rem 1rem;
  font-size: 1.85rem;
  font-weight: 800;
  letter-spacing: .22em;
  color: var(--ae-white, #FFFFFF);
  background: var(--ae-purple, #7B2A80);
  border-radius: 10px;
}
.aep-exito-msg {
  margin: 0;
  font-size: .95rem;
  color: var(--ae-ink-soft, #2b2b2b);
  line-height: 1.45;
}

/* ---------- Reduced motion --------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .aep-overlay,
  .aep-modal { transition: none; }
  .aep-overlay.is-open .aep-modal { transform: none; }
}
