/* ================================================================
   TRN Popup Ad Manager - Estilos del overlay
   IMPORTANTE: usamos opacity + visibility en vez de display:none.
   Muchas redes de anuncios usan "lazyload" (Intersection Observer)
   para detectar cuándo un bloque entra en el viewport y cargarlo.
   Si usáramos display:none, el bloque nunca tendría tamaño/posición
   y esas redes nunca lo detectarían como visible para cargar el anuncio.
   ================================================================ */

#trn-popup-backdrop {
  display: flex;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, var(--trn-bg-opacity, 0.6));
  z-index: 999998;
  justify-content: center;
  align-items: center;
  transition: opacity 0.25s ease;
}

#trn-popup-backdrop.trn-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Contenedor que agrupa la X + la tarjeta del anuncio.
   La X va DENTRO de este contenedor (no fija a la pantalla),
   así se mueve junto con la tarjeta y nunca queda tapada por
   otros anuncios fijos que tengas arriba (como un anuncio ancla). */
#trn-popup-inner {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  width: 90%;
  max-width: 380px;
}

#trn-popup-close {
  position: relative;
  margin-bottom: 8px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #222;
  color: #222;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  z-index: 2147483647;
  transition: opacity 0.2s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  flex-shrink: 0;
}

#trn-popup-close:hover {
  background: #222;
  color: #fff;
}

#trn-popup-box {
  position: relative;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
  width: 100%;
  padding: 20px;
  box-sizing: border-box;
  overflow-x: hidden;
  overflow-y: auto;
  max-height: 90vh;
}

/* Animación Fade */
.trn-anim-fade #trn-popup-box {
  opacity: 0;
  transition: opacity 0.3s ease;
}
.trn-anim-fade.trn-active #trn-popup-box {
  opacity: 1;
}

/* Animación Zoom */
.trn-anim-zoom #trn-popup-box {
  transform: scale(0.85);
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.trn-anim-zoom.trn-active #trn-popup-box {
  transform: scale(1);
  opacity: 1;
}

#trn-popup-content {
  min-height: 100px;
  width: 100%;
  max-width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

/* Contención responsive: sin importar qué tamaño traiga el anuncio de tu
   red (imagen, video, div interno), nunca debe salirse de la caja. */
#trn-popup-content img,
#trn-popup-content video,
#trn-popup-content > * {
  max-width: 100% !important;
  height: auto !important;
  box-sizing: border-box !important;
}

/* Los iframes de anuncios (AdSense, redes de terceros, etc.) casi siempre
   definen SU PROPIO alto vía JavaScript según el tamaño real de la
   creatividad que cargaron. Si le forzamos "height:auto", le ganamos a
   ese alto con !important y el iframe se colapsa, cortando el anuncio
   (esto era el problema: la creatividad se veía recortada).
   Por eso aquí solo limitamos el ANCHO y dejamos que la red de anuncios
   controle su propio alto libremente. */
#trn-popup-content iframe {
  max-width: 100% !important;
  width: 100% !important;
  border: none;
  box-sizing: border-box !important;
  display: block;
}

/* ================================================================
   Modo "Pantalla completa" (estilo viñeta) - fondo difuminado (blur)
   detrás del anuncio, y la tarjeta ocupa casi toda la pantalla.
   Aplica igual en computadora y en móvil: en pantallas angostas
   ocupa el 92% del ancho; en pantallas anchas se limita a 480px
   para que no se vea gigante y descentrado.
   ================================================================ */
.trn-fullscreen-mobile#trn-popup-backdrop {
  background: rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.trn-fullscreen-mobile #trn-popup-inner {
  width: 96%;
  max-width: 96%;
}

.trn-fullscreen-mobile #trn-popup-box {
  min-height: 70vh;
  max-height: 90vh;
  overflow-x: hidden;
  overflow-y: auto;
  border-radius: 16px;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
