/* Wrapper general */
.ebook-blog-slider {
  display: flex;
  justify-content: center;
  padding: 40px 0;
}

/* Contenedor del slider */
.ebook-slider {
  max-width: 460px; /* un margen extra al ancho del contenido */
  width: 100%;
}

/* Área donde se apilan los slides */
.ebook-slider-viewport {
  position: relative;
  width: 100%;
  height: 350px; /* altura fija según layout */
}

/* Slide base (fade) */
.ebook-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 320ms ease, transform 320ms ease;
  transform: translateX(8px);
}

.ebook-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

/* Card interior con 2 columnas */
.ebook-slide-inner {
  display: flex;
  gap: 16px;
  width: 416px;    /* ancho total exacto del layout */
  height: 350px;   /* alto exacto del layout */
  background-color: #ffffff;
  border-radius: 24px;
  box-sizing: border-box;
}

/* Columna de texto */
.ebook-slide-text {
  flex: 0 0 200px;      /* ancho fijo columna texto */
  display: flex;
  flex-direction: column;
}

/* Título */
.ebook-slide-title {
  margin: 0 0 24px 0;   /* 24px entre título y descripción */
  font-size: 24px;
  line-height: 1;
  font-weight: 700;
  color: #0050d8;
}

/* Descripción */
.ebook-slide-description {
  margin: 0 0 16px 0;   /* 16px entre descripción y botón */
  font-size: 18px;
  line-height: 1.1;
  color: #4b5563;
}

/* Botón */
.ebook-slide-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 200px;         /* ancho indicado en layout */
  height: 40px;         /* alto indicado en layout */
  margin-top: auto;     /* pega el botón al fondo de la columna */
  border-radius: 999px;
  background-color: #0064ff;
  color: #ffffff;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background-color 200ms ease, transform 120ms ease,
              box-shadow 200ms ease;
}

.ebook-slide-button:hover {
  background-color: #0050d0;
  box-shadow: 0 8px 18px rgba(0, 100, 255, 0.35);
  transform: translateY(-1px);
}

.ebook-slide-button:active {
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(0, 100, 255, 0.25);
}

/* Columna imagen */
.ebook-slide-media {
  flex: 0 0 200px;  /* ancho columna imagen */
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Card azul de la imagen */
.ebook-slide-media-card {
  width: 100%;
  height: 100%;
  background-color: #e9f3ff;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.ebook-slide-media-card img {
  max-width: 80%;
  height: auto;
  display: block;
}

/* Dots */
.ebook-slider-dots {
    position: absolute;
    right: 70px;
    bottom: 16px;
    display: flex;
    gap: 8px;
}

.ebook-slider-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: none;
  background-color: #d1d5db;
  cursor: pointer;
  padding: 0;
  transition: background-color 180ms ease, width 180ms ease;
}

.ebook-slider-dot.is-active {
  background-color: #0052CC;
}

/* Versión responsive (mobile) */
@media (max-width: 767px) {
  .ebook-blog-slider {
    padding: 24px 16px;
  }

  .ebook-slider {
    max-width: 100%;
  }

  .ebook-slider-viewport {
    height: auto; /* deja que la altura la defina el slide activo */
  }

  /* Los slides dejan de ser absolutos y solo se muestra el activo */
  .ebook-slide {
    position: relative;
    display: none;
    opacity: 0;
    pointer-events: none;
    transform: none;
  }

  .ebook-slide.is-active {
    display: block;
    opacity: 1;
    pointer-events: auto;
  }

  /* Card en columna para ocupar todo el ancho */
  .ebook-slide-inner {
    flex-direction: column;
    width: 100%;
    height: auto;
    border-radius: 20px;
  }

  .ebook-slide-text,
  .ebook-slide-media {
    flex: 0 0 auto;
  }

  .ebook-slide-media-card {
    margin-top: 16px;
    height: auto;
  }

  .ebook-slide-media-card img {
    max-width: 70%;
    height: auto;
  }

  /* Botón full-width en mobile */
  .ebook-slide-button {
    width: 100%;
  }

  /* Dots debajo del card, centrados */
  .ebook-slider-dots {
    position: static;
    margin-top: 12px;
    display: flex;
    justify-content: center;
    gap: 8px;
  }
}
}