.vsm-player {
  position: relative;
  width: 100%;
}

.vsm-player__video {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
  background: #000;
}

/* Overlay que contiene los botones */
.vsm-overlay {
  position: absolute;
  inset: 0;
  border-radius: 14px;
  pointer-events: none; /* importante: el overlay no bloquea el click en el video */
  opacity: 0;
  transition: opacity .18s ease;
}

/* Mostrar controles solo al hover (y accesible con teclado) */
.vsm-player:hover .vsm-overlay {
  opacity: 1;
  pointer-events: none;
}

/* Botones: ahora sí reciben clicks */
.vsm-btn {
  pointer-events: auto;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(6px);

  cursor: pointer;
  font-size: 16px;
  line-height: 1;
}

.vsm-btn i { pointer-events: none; color: var(--paper);}

/* Centro del video */
.vsm-btn--play {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

/* Esquina inferior izquierda */
.vsm-btn--mute {
  position: absolute;
  left: 14px;
  bottom: 14px;
}
.vsm-btn--mute i{margin-bottom: 0.1em;}
/* Pequeña animación */
.vsm-player:hover .vsm-btn--play,
.vsm-player:focus-within .vsm-btn--play {
  transform: translate(-50%, -50%) scale(1);
}

.vsm-btn:hover { transform: scale(1.06); }
.vsm-btn:active { transform: scale(0.96); }
.hero-bg {
  position: relative;
  overflow: hidden;
}

.hero-bg .vsm-player__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.is-bg{
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: contain;
}
.is-bg .vsm-player__video{
    object-fit: cover;
    height: 100%;
    width: 100%;
    border-radius: 0;
}
/* === Carousel sin controles encima del video === */
.vsm-carousel {
  position: relative;
}

/* Controles fuera del video */
.vsm-carousel .carousel-control-prev,
.vsm-carousel .carousel-control-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;

  background: rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
  border-radius: 999px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 1;
}

/* Izquierda / derecha fuera del marco */
.vsm-carousel .carousel-control-prev {
  left: -56px;   /* ajusta según tu layout */
}

.vsm-carousel .carousel-control-next {
  right: -56px;
}

/* Iconos */
.vsm-carousel .carousel-control-prev-icon,
.vsm-carousel .carousel-control-next-icon {
  width: 18px;
  height: 18px;
  background-size: 18px 18px;
}

/* En móviles: acercar */
@media (max-width: 768px) {
  .vsm-carousel .carousel-control-prev {
    left: -40px;
  }
  .vsm-carousel .carousel-control-next {
    right: -40px;
  }
}