.block-video .video-holder {
  position: relative;
}
.block-video .video-holder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transform-origin: center;
  transition: transform 1s cubic-bezier(0.15, 0.65, 0.25, 1);
}
.block-video .video-holder a {
  display: block;
  box-sizing: border-box;
  aspect-ratio: 5/8;
  outline: 1px solid transparent;
  outline-offset: -1px;
  transition: all 1s cubic-bezier(0.15, 0.65, 0.25, 1);
}
@media (min-width: 40rem) {
  .block-video .video-holder a {
    aspect-ratio: 2/1;
  }
}
@media (hover: hover) and (pointer: fine) {
  .block-video .video-holder a:hover {
    padding: 1rem;
    outline-color: var(--color-grey-2);
  }
  .block-video .video-holder a:hover .play:before {
    animation: pulse-border 2500ms ease-out infinite;
  }
  .block-video .video-holder a:hover img {
    transform: scale(1.1);
  }
}
.block-video .video-holder .play {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--color-white);
  border-radius: 50%;
  height: 65px;
  width: 65px;
}
.block-video .video-holder .play:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--color-white);
  border-radius: 50%;
  height: 60px;
  width: 60px;
}
.block-video .video-holder .play svg {
  position: relative;
  z-index: 15;
  display: block;
  height: 35px;
  width: auto;
}
.block-video .video-holder .play svg path {
  fill: var(--color-yellow);
}

@keyframes pulse-border {
  0% {
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    opacity: 1;
  }
  20% {
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    opacity: 1;
  }
  100% {
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
    opacity: 0;
  }
}