/* Espacios publicitarios — portal */
.banner-slot-pro {
  position: relative;
  margin: 1rem 0;
  padding: 0;
}

.banner-slot-wrap {
  position: relative;
}

.banner-item-slot {
  display: none;
}

.banner-item-slot.active {
  display: block;
  animation: banner-fade-in 0.45s ease;
}

@keyframes banner-fade-in {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.banner-slot-pro__img {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.banner-link:hover .banner-slot-pro__img {
  transform: scale(1.01);
}

.banner-dots {
  display: flex;
  justify-content: center;
  gap: 0.35rem;
  margin-top: 0.5rem;
}

.banner-dot {
  width: 6px;
  height: 6px;
  border-radius: 9999px;
  border: none;
  background: #d6d3d1;
  padding: 0;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}

.banner-dot.active {
  background: #0d9488;
  transform: scale(1.15);
}

/* Banner superior (global-sobre-cabecera): ancho total, sin huecos, más bajo en PC */
.banner-slot-pro--cabecera-top,
.banner-slot-pro[data-banner-ubicacion="global-sobre-cabecera"] {
  width: 100vw;
  max-width: 100vw;
  margin: 0 calc(50% - 50vw) !important;
  padding: 0 !important;
  border: none;
  line-height: 0;
}

.banner-slot-pro--cabecera-top .banner-slot-wrap,
.banner-slot-pro--cabecera-top .banner-item-slot__frame,
.banner-slot-pro--cabecera-top .banner-slot-pro__frame-top {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  --tw-ring-shadow: 0 0 #0000 !important;
}

.banner-slot-pro--cabecera-top .banner-link,
.banner-slot-pro--cabecera-top .banner-slot-pro__frame-top {
  display: block;
  overflow: visible;
  line-height: 0;
}

.banner-slot-pro--cabecera-top .banner-slot-pro__img--cabecera-top {
  display: block;
  width: 100%;
  height: auto;
  max-height: 100px;
  object-fit: contain;
  object-position: center top;
  border-radius: 0;
  vertical-align: top;
}

@media (min-width: 768px) {
  .banner-slot-pro--cabecera-top .banner-slot-pro__img--cabecera-top {
    max-height: 72px;
  }
}

/* Segmentación por dispositivo */
.banner-slot-pro--targeted .banner-item-slot--mobile,
.banner-slot-pro--targeted .banner-item-slot--desktop {
  display: none !important;
}

html.banner-view-mobile .banner-slot-pro--targeted .banner-item-slot--mobile.active,
html.banner-view-desktop .banner-slot-pro--targeted .banner-item-slot--desktop.active {
  display: block !important;
}

@media (max-width: 767px) {
  .banner-item-slot--desktop {
    display: none !important;
  }
  .banner-item-slot--mobile.active {
    display: block !important;
  }
}

@media (min-width: 768px) {
  .banner-item-slot--mobile {
    display: none !important;
  }
  .banner-item-slot--desktop.active {
    display: block !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .banner-item-slot.active {
    animation: none;
  }
}
