.slabs {
  display: grid;
  gap: 1.6rem;
  grid-template-columns: repeat(3, 1fr);
  margin: var(--xl-gap) auto;
  max-width: var(--xl-width);
  padding: 0 var(--xs-gap);

  @media (max-width: 1024px) {
    grid-template-columns: repeat(2, 1fr);
    margin: 4rem auto;
  }

  @media (max-width: 700px) {
    gap: 1rem;
    grid-template-columns: 1fr;
  }
}

.slabs__item {
  position: relative;
  border-radius: var(--border-r);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background-color: var(--ocean-very-light);
  transition: background-color 0.25s;
}

.slabs__item:hover {
  background-color: var(--ocean-light);
  .slabs__path {
    fill: var(--ocean-very-light);
  }
}

.slabs__media,
.slabs__content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.slabs__media {
  object-fit: cover;
}

.slabs__content {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 1.25rem 1.625rem 2rem;
  box-sizing: border-box;
}

.slabs__title {
  margin: 0;
  font: var(--venti);
  font-weight: 600;
}

.slabs__body {
  font-size: 1rem;
  line-height: 1.4rem;
}

.slabs__body p {
  margin: 0;
}

.slabs__link {
  margin: 2rem 1.625rem 0 auto;
  position: relative;
  display: inline-flex;
  align-items: center;

  @media (max-width: 360px) {
    margin-top: 0.75rem;
  }
}

.slabs__link:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: -1.65rem;
  transform: translateY(-50%);
  height: 0.75rem;
  width: 1.25rem;
  background-color: currentColor;
  transition: clip-path, width, 0.25s;
  clip-path: var(--short-arrow);
}

.slabs__item:hover .slabs__link:after {
  right: -2rem;
  width: 1.625rem;
  clip-path: var(--long-arrow);
}

.slabs__icon {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-end;

  &.slabs__icon--1 svg {
    height: 100%;
  }

  &.slabs__icon--2 {
    justify-content: flex-end;
  }
}

.slabs__path {
  fill: var(--ocean-light);
  transition: fill 0.25s;
}
