.image-overlay {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}
.image-overlay__image img {
  display: block;
  width: 100%;
  height: auto;
  transition: transform 0.3s ease;
}
.image-overlay__overlay {
  position: absolute;
  inset: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
  transition: 0.3s ease;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
}
.image-overlay__text {
  color: white;
  font-size: 1.25rem;
  font-weight: 600;
  text-align: center;
  padding: 1rem;
}
.image-overlay__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.image-overlay__link:hover {
  text-decoration: none;
}
.image-overlay.bs-text-center .image-overlay__overlay {
  justify-content: center;
}
.image-overlay.bs-text-center .image-overlay__text {
  text-align: center;
}
.image-overlay.bs-text-left .image-overlay__overlay {
  justify-content: flex-start;
}
.image-overlay.bs-text-left .image-overlay__text {
  text-align: left;
}
.image-overlay.bs-text-right .image-overlay__overlay {
  justify-content: flex-end;
}
.image-overlay.bs-text-right .image-overlay__text {
  text-align: right;
}
.image-overlay.bs-text-justify .image-overlay__overlay {
  justify-content: space-between;
}
.image-overlay.bs-text-justify .image-overlay__text {
  text-align: justify;
}
.image-overlay--hover:hover .image-overlay__overlay {
  opacity: 1;
}
.image-overlay--no-hover .image-overlay__overlay {
  opacity: 1;
  background-color: rgba(0, 0, 0, 0.3);
}
@media (max-width: 767.98px) {
  .image-overlay__text {
    font-size: 1rem;
  }
}
@media (max-width: 575.98px) {
  .image-overlay__text {
    font-size: 0.875rem;
  }
}
