.vision {
  --title-size: 250px;
  --title-line-height: 1.3;
  --vision-opacity-when-inactive: 0.3;
  position: relative;
  transform: translateY(
    calc(var(--title-size) * var(--title-line-height) / 2 * -1)
  );
}

.vision-title {
  font-size: var(--title-size);
  font-weight: 300;
  line-height: var(--title-line-height);
  text-transform: uppercase;
  transform: translateY(calc(var(--title-size) * var(--title-line-height) / 2));
}

.vision-content {
  display: grid;
  grid-template-columns: repeat(12, minmax(auto, 1fr));
  grid-template-rows: repeat(2, auto);
  gap: var(--default-grid-gap);
  padding: 0 var(--default-grid-margin);
}

.vision-bg {
  width: calc(100% + var(--default-grid-margin));
  grid-column: 5 / span 8;
  aspect-ratio: 3 / 2;
  opacity: 1;
  z-index: -1;
}

.vision-copy {
  position: sticky;
  top: 50%;
  grid-column: 1 / span 4;
  font-size: 18px;
  line-height: 1.4;
  height: min-content;
  margin-top: 33%;
}

.vision-copy-secondary {
  opacity: var(--vision-opacity-when-inactive);
}

.vision-images {
  grid-column: 5 / 13;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  grid-template-rows: 1fr;
  gap: var(--default-grid-gap);
  opacity: var(--vision-opacity-when-inactive);
}

.vision-images-mobile {
  display: none;
}

.vision-image {
  aspect-ratio: 16 / 9;
}

.vision-image-mobile {
  aspect-ratio: 16 / 9;
}

.vision-image:nth-child(1n) {
  grid-column: 1 / 5;
}

.vision-image:nth-child(2n) {
  grid-column: 5 / 9;
}

@media only screen and (max-width: 1240px) {
  .vision {
    --title-size: 105px;
    display: flex;
    flex-direction: column;
    transform: none;
    margin-top: 10vh;
  }

  .vision-title {
    text-align: center;
    transform: none;
  }

  .vision-content {
    display: flex;
    flex-direction: column-reverse;
    padding: 0;
    gap: 5vh;
  }

  .vision-bg {
    width: 100%;
  }

  .vision-copy {
    position: static;
    font-size: 14px;
    line-height: 1.4;
    margin: 0;
    padding: 0 var(--default-grid-margin);
  }

  .vision-copy-secondary {
    opacity: unset;
  }

  .vision-images {
    display: none;
  }

  .vision-images-mobile {
    display: flex;
    flex-direction: column;
    gap: var(--default-grid-gap);
    overflow-x: clip;
  }

  .vision-image-mobile {
    will-change: transform;
  }

  .vision-image-mobile:nth-child(1) {
    margin-right: var(--default-grid-margin);
  }

  .vision-image-mobile:nth-child(2) {
    margin-left: var(--default-grid-margin);
  }
}
