.masonry-grid {
  padding: 40px 0 80px;
}
@media (max-width: 767.98px) {
  .masonry-grid {
    padding: 40px 0;
  }
}
.masonry-grid .container {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.masonry-grid .heading-block__text {
  max-width: 100%;
}
.masonry-grid__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 276px;
  gap: 40px;
}
@media (max-width: 991.98px) {
  .masonry-grid__grid {
    display: flex;
    overflow: hidden;
    position: relative;
    padding: 0;
  }
}
.masonry-grid__grid > :first-child {
  grid-column: span 2;
}
@media (max-width: 991.98px) {
  .masonry-grid__grid > :first-child {
    grid-column: span 1;
  }
}
.masonry-grid__grid > :nth-child(2) {
  grid-row: 1/span 2;
  grid-column: 3;
}
@media (max-width: 991.98px) {
  .masonry-grid__grid > :nth-child(2) {
    grid-row: auto;
    grid-column: auto;
  }
}
@media (max-width: 991.98px) {
  .masonry-grid__grid-wrapper {
    display: flex;
    gap: 40px;
    transition: transform 0.3s ease-in-out;
    cursor: grab;
  }
}
@media (max-width: 991.98px) and (max-width: 767.98px) {
  .masonry-grid__grid-wrapper {
    gap: 20px;
  }
}
@media (max-width: 991.98px) {
  .masonry-grid__grid-wrapper:active {
    cursor: grabbing;
  }
}
.masonry-grid__item {
  position: relative;
  border-radius: 8px;
  background: #ffffff;
  overflow: hidden;
  height: 100%;
}
@media (max-width: 991.98px) {
  .masonry-grid__item {
    width: 300px;
    height: auto;
    min-height: 400px;
    border-radius: 8px 8px 0 0;
    flex: 0 0 300px;
  }
  .masonry-grid__item .masonry-grid__content {
    transform: translateY(0);
  }
  .masonry-grid__item .masonry-grid__button-wrapper {
    border-left: 1px solid #dddddd;
    border-right: 1px solid #dddddd;
    border-top: 1px solid #dddddd;
  }
  .masonry-grid__item .masonry-grid__button-wrapper .btn.btn--link {
    background: #33b5dd;
    color: #ffffff;
  }
  .masonry-grid__item .masonry-grid__button-wrapper .btn.btn--link .btn__arrow {
    filter: brightness(0) invert(1);
  }
  .masonry-grid__item .masonry-grid__description {
    border-left: 1px solid #dddddd;
    border-right: 1px solid #dddddd;
    border-bottom: 1px solid #dddddd;
  }
  .masonry-grid__item .masonry-grid__image img {
    transform: scale(1.1);
  }
}
.masonry-grid__item:hover .masonry-grid__content {
  transform: translateY(0);
}
.masonry-grid__item:hover .masonry-grid__button-wrapper {
  border-left: 1px solid #dddddd;
  border-right: 1px solid #dddddd;
  border-top: 1px solid #dddddd;
}
.masonry-grid__item:hover .masonry-grid__button-wrapper .btn.btn--link {
  background: #33b5dd;
  color: #ffffff;
}
.masonry-grid__item:hover .masonry-grid__button-wrapper .btn.btn--link .btn__arrow {
  filter: brightness(0) invert(1);
}
.masonry-grid__item:hover .masonry-grid__description {
  border-left: 1px solid #dddddd;
  border-right: 1px solid #dddddd;
  border-bottom: 1px solid #dddddd;
}
.masonry-grid__item:hover .masonry-grid__image img {
  transform: scale(1.1);
}
.masonry-grid__image {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.masonry-grid__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  transition: transform 0.5s linear;
}
@media (max-width: 991.98px) {
  .masonry-grid__image img {
    aspect-ratio: 16/9;
    height: auto;
    min-height: 200px;
    -o-object-fit: cover;
    object-fit: cover;
  }
}
.masonry-grid__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  transform: translateY(calc(100% - 48px));
  transition: transform 0.3s linear;
}
.masonry-grid__button-wrapper {
  background: #ffffff;
  padding: 8px;
  padding-bottom: 0;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 0px 8px 0px 0px;
}
.masonry-grid .btn--link {
  color: #222;
  gap: 16px;
  padding: 8px;
  border-radius: 8px;
  transition: all 0.3s linear;
  background: #ffffff;
}
.masonry-grid__description {
  padding: 16px 16px 24px 16px;
  background: #ffffff;
}
.masonry-grid__navigation {
  display: none;
  width: 100%;
}
@media (max-width: 991.98px) {
  .masonry-grid__navigation {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: -16px;
  }
}
.masonry-grid__dots {
  display: flex;
  gap: 8px;
}
.masonry-grid__dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  cursor: pointer;
  border: none;
  padding: 0;
  background-color: var(--Neutrals-Light-black, #515151);
  border: 1px solid var(--Neutrals-Mid-black, #2c2c2c);
  transition: all 0.3s ease;
}
.masonry-grid__dot.active {
  background-color: var(--Primary-Colours-Primary-Blue, #33b5dd);
  border-color: var(--Primary-Colours-Primary-Blue, #33b5dd);
}
.masonry-grid__arrows {
  display: flex;
  gap: 8px;
}
.masonry-grid__arrow {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: 1px solid var(--Neutrals-Mid-black, #2c2c2c);
  border-radius: 4px;
  background: #fff;
  padding: 0;
}
.masonry-grid__arrow--prev svg {
  transform: rotate(180deg);
}
.masonry-grid__arrow:hover {
  background: var(--Primary-Colours-Primary-Blue, #33b5dd);
  border-color: var(--Primary-Colours-Primary-Blue, #33b5dd);
}
.masonry-grid__arrow:hover svg path {
  stroke: #fff;
}
.masonry-grid__arrow:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}