.image-card-group-block {
  padding: 0;
}
.image-card-group-block .image-card-group-divider {
  height: 2px;
  background-color: #2d2926;
  margin-top: 0;
  margin-bottom: var(--divider-to-heading-spacing-default);
}
.image-card-group-block .title { 
  font-family: "masqualero", serif;
  font-size: var(--h2-font-size-default);
  margin-bottom: var(--section-heading-margin-bottom-default);
  margin-top: 0;
  line-height: var(--h2-line-height-default);
}
.image-card-group-block .image-card-group-teaser-text p,
.image-card-group-block .image-card-group-teaser-text h2,
.image-card-group-block .image-card-group-teaser-text h3,
.image-card-group-block .image-card-group-teaser-text h4 {
  font-family: "sofia-pro", sans-serif;
  font-weight: 300;
}
.image-card-group-block .image-card-group-teaser-text p {
  font-size: 18px;
}
.image-card-group-block .icon {
  overflow: hidden;
  width: 32px;
  height: 32px;
  border: 2px solid #fff;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-grid-column-align: center;
      justify-self: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.image-card-group-block .icon svg {
  width: 100%;
  color: #fff;
}
@-webkit-keyframes toright {
  0% {
    -webkit-transform: translateX(-30px);
            transform: translateX(-30px);
  }
  100% {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
@keyframes toright {
  0% {
    -webkit-transform: translateX(-30px);
            transform: translateX(-30px);
  }
  100% {
    -webkit-transform: translateX(0px);
            transform: translateX(0px);
  }
}
.image-card-group-block .image-card-group-gallery .blocks-gallery-grid {
  display: grid;
  gap: 25px;
  grid-template-columns: repeat(4, 1fr);
  padding: 0;
  margin: 0;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item {
  padding: 0;
  margin-bottom: 0px;
  list-style: none;
  /* max-width: 270px; */
  height: 270px;
  
}

*:is(.page-template-interior, .single-program) .image-card-group-block .image-card-group-gallery ul li.image-card-group-item {
  height: auto;
  object-fit: contain;
}

.image-card-group-block .image-card-group-gallery ul li.image-card-group-item svg {
  -webkit-transition: all 0.5s cubic-bezier(0.345, 0, 0.145, 0.995);
  transition: all 0.5s cubic-bezier(0.345, 0, 0.145, 0.995);
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item img {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  height: 100%;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item:hover svg {
  -webkit-animation: toright 0.5s 0.2s;
          animation: toright 0.5s 0.2s;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item:hover img {
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item a {
  height: 100%;
  overflow: hidden;
  display: inline-block;
  position: relative;
  width: 100%;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item a img {
  height: 100%;
  -webkit-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item a .overlay {
  position: absolute;
  bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(25, 25, 25, 0.0001)), color-stop(41.19%, rgba(5, 5, 5, 0.6)), color-stop(89.08%, rgba(1, 1, 1, 0.8)));
  background: linear-gradient(180deg, rgba(25, 25, 25, 0.0001) 0%, rgba(5, 5, 5, 0.6) 41.19%, rgba(1, 1, 1, 0.8) 89.08%);
  width: 100%;
  -webkit-transition: 0.5s ease;
  transition: 0.5s ease;
  height: 50%;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item a .title {
  position: absolute;
  bottom: 26px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  padding: 0px 15px;
  margin-bottom:  0;
}
.image-card-group-block .image-card-group-gallery ul li.image-card-group-item a .title .card-title {
  color: #fff;
  font-family: "sofia-pro-condensed", sans-serif;
  text-transform: uppercase;
  font-size: 19px;
  margin: 0px;
  letter-spacing: 2px;
  font-weight: 700;
  padding: 0px 2px 0px 0px;
}

/*.page-template-landing .image-card-group-block ul li.image-card-group-item {
  width: calc(100% / 4);
}*/

@media screen and (min-width: 1500px) {

  .image-card-group-block .image-card-group-gallery .blocks-gallery-grid {
    grid-template-columns: repeat(4, 1fr);    
  }
}


body.narrow-content-well .image-card-group-block .image-card-group-gallery .blocks-gallery-grid {
  grid-template-columns: repeat(4, 1fr);
  @media screen and (max-width: 1280px) {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (max-width: 991px) {
  .image-card-group-block .title {
    font-size: 30px;
  }

  .image-card-group-block .image-card-group-gallery ul li.image-card-group-item a .title {
    bottom: 16px;
  }
  .image-card-group-block .image-card-group-gallery ul li.image-card-group-item a .title .card-title {
    font-size: 16px;
    line-height: 20px;
  }

  .the_content_interior.havetemplate-interior .image-card-group-block .image-card-group-gallery ul li.image-card-group-item,
  .image-card-group-block .image-card-group-gallery ul li.image-card-group-item {
    min-height: 190px;
  }

}
@media screen and (max-width: 575px) {
  .image-card-group-block .icon {
    width: 20px;
    height: 20px;
    border: 1px solid #fff;
  }
  .image-card-group-block .icon svg {
    width: 70%;
    margin: 0px auto;
  }
  .image-card-group-block .image-card-group-gallery ul {
    margin: 0 -8px;
  }

  .image-card-group-block .image-card-group-gallery .blocks-gallery-grid {
    grid-template-columns: repeat(2, 1fr);    
    gap: 15px;
  }

  .image-card-group-block .image-card-group-gallery ul li.image-card-group-item {
    height: 160px;
  }
  .the_content_interior.havetemplate-interior .image-card-group-block .image-card-group-gallery ul li.image-card-group-item {
    
  }
  .image-card-group-block .image-card-group-gallery ul li.image-card-group-item a .title .card-title {
    font-size: 13px;
    line-height: 16px;
  }
}

