.flytrap-work-gallery {
  --ft-gap: 16px;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
  grid-auto-rows: 72px;
  gap: var(--ft-gap);
}

.flytrap-work-gallery__item {
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  background: #e9e9e9;
  min-height: 220px;
  grid-column: span 4;
  grid-row: span 4;
}

.flytrap-work-gallery__item--small {
  grid-column: span 4;
  grid-row: span 4;
}

.flytrap-work-gallery__item--wide {
  grid-column: span 8;
  grid-row: span 4;
}

.flytrap-work-gallery__item--tall {
  grid-column: span 4;
  grid-row: span 6;
}

.flytrap-work-gallery__item--feature {
  grid-column: span 8;
  grid-row: span 6;
}

.flytrap-work-gallery__link {
  color: inherit;
  text-decoration: none;
}

.flytrap-work-gallery__media,
.flytrap-work-gallery__link {
  display: block;
  width: 100%;
  height: 100%;
}

.flytrap-work-gallery__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}

.flytrap-work-gallery__item:hover .flytrap-work-gallery__media img,
.flytrap-work-gallery__item:focus-within .flytrap-work-gallery__media img {
  transform: scale(1.03);
}

.flytrap-work-gallery__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 18px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.68), rgba(0, 0, 0, 0.15), transparent);
  color: #fff;
  pointer-events: none;
}

.flytrap-work-gallery__overlay h3 {
  margin: 0 0 6px;
  font-size: 1rem;
  line-height: 1.2;
}

.flytrap-work-gallery__overlay p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.4;
  opacity: 0.94;
}

@media (max-width: 991px) {
  .flytrap-work-gallery {
    grid-template-columns: repeat(8, minmax(0, 1fr));
  }

  .flytrap-work-gallery__item--small,
  .flytrap-work-gallery__item--tall {
    grid-column: span 4;
  }

  .flytrap-work-gallery__item--wide,
  .flytrap-work-gallery__item--feature {
    grid-column: span 8;
  }
}

@media (max-width: 767px) {
  .flytrap-work-gallery {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .flytrap-work-gallery::-webkit-scrollbar {
    height: 8px;
  }

  .flytrap-work-gallery__item,
  .flytrap-work-gallery__item--small,
  .flytrap-work-gallery__item--wide,
  .flytrap-work-gallery__item--tall,
  .flytrap-work-gallery__item--feature {
    flex: 0 0 82vw;
    width: 82vw;
    min-height: 300px;
    scroll-snap-align: start;
  }
}
