/* Image Grid */
.image-grid {
  padding: var(--section-padding) 0;
}

.image-grid .section__title {
  font-size: var(--h1-size);
  line-height: var(--h1-lh);
  font-weight: 600;
}

.image-grid__items > div {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--spacing-lg);
}

.image-grid__item {
  position: relative;
  border-radius: var(--radius-card-lg);
  overflow: hidden;
  text-decoration: none;
  display: block;
  background: var(--color-white);
}

.image-grid__image img {
  width: 100%;
  height: 360px;
  display: block;
  object-fit: cover;
}

/* Caption — hidden by default (plain style) */
.image-grid__caption {
  display: none;
}

/* Style: overlay — blue gradient over image bottom */
.image-grid--overlay .image-grid__caption {
  display: flex;
  align-items: flex-end;
  position: absolute;
  inset: 0;
  padding: var(--spacing-md);
  background: linear-gradient(180deg, rgba(17, 108, 166, 0) 63%, var(--color-blue-light) 100%);
}

.image-grid--overlay .image-grid__title {
  color: var(--color-white);
  font-size: var(--h5-size);
  line-height: var(--h5-lh);
  font-weight: 700;
  text-transform: uppercase;
}

/* Style: grey-panel — grey bar at bottom */
.image-grid--grey-panel .image-grid__caption {
  display: flex;
  align-items: flex-end;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--spacing-md);
  background: color-mix(in srgb, var(--color-dark-blue) 40%, transparent);
}

.image-grid--grey-panel .image-grid__title {
  color: var(--color-white);
  font-size: var(--h5-size);
  line-height: var(--h5-lh);
  font-weight: 700;
  text-transform: uppercase;
}

/* Style: rentals — 2 columns, no crop */
.image-grid--rentals .image-grid__items > div {
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-xl);
}

.image-grid--rentals .image-grid__item {
  border-radius: 0;
  background: transparent;
}

.image-grid--rentals .image-grid__image img {
  height: auto;
  object-fit: contain;
}

/* Hover */
a.image-grid__item:hover {
  opacity: 0.9;
}

@media (max-width: 1023px) {
  .image-grid__items > div {
    grid-template-columns: repeat(2, 1fr);
  }

  .image-grid__image img {
    height: 280px;
  }
}

@media (max-width: 767px) {
  .image-grid {
    padding: var(--spacing-xl) 0;
  }

  .image-grid .section__title {
    font-size: var(--h2-size);
    line-height: var(--h2-lh);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
  }

  .image-grid__items > div {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }

  /* Rentals style — vertical cards with title on top */
  .image-grid--rentals .image-grid__items > div {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .image-grid--rentals .image-grid__item {
    display: flex;
    flex-direction: column-reverse;
    border: none;
    border-radius: 0;
    background: none;
    padding: 0;
    text-align: center;
  }

  .image-grid--rentals .image-grid__caption {
    display: block;
    position: static;
    padding: 0;
    background: none;
    margin-bottom: var(--spacing-md);
  }

  .image-grid--rentals .image-grid__title {
    font-size: var(--h2-size);
    line-height: var(--h2-lh);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    text-transform: uppercase;
  }

  .image-grid--rentals .image-grid__image img {
    height: auto;
    object-fit: contain;
  }
}
