/* text area columns */

.main .bg-image {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.column-count-2 .container {
  display: grid;
  grid-template-columns: repeat(2, 47.5%);
  grid-gap: 0 5%;
}
.column-count-2 .container > h3 {
  grid-column: 1 / -1;
}
.vertical-center .container {
  align-items: center;
}
.light-colors * {
  color: var(--white);
}
.fixed-bg .bg-image {
  background-attachment: fixed;
}
  /* column widths */
  .column-count-2.twentyeighty .container {
    grid-template-columns: 1fr 4fr;
  }
  .column-count-2.thirtyseventy .container {
    grid-template-columns: 3fr 7fr;
  }
  .column-count-2.fourtysixty .container {
    grid-template-columns: 2fr 3fr;
  }
  .column-count-2.sixtyfourty .container {
    grid-template-columns: 3fr 2fr;
  }
  .column-count-2.seventythirty .container {
    grid-template-columns: 7fr 3fr;
  }
  .column-count-2.eightytwenty .container {
    grid-template-columns: 4fr 1fr;
  }
  .column-count-2 .container .column .figure {
    display: flex;
    align-items: center;
  }
.button-below {
  grid-column: 1 / -1;
  padding-top: 50px;
}
@media screen and (max-width: 1024px) {
  .column-count-2 .container .column .figure {
    flex-direction: column;
  }
}
@media screen and (max-width: 1200px) {
  .column-count-2 .container,
  .column-count-2.twentyeighty .container,
  .column-count-2.thirtyseventy .container,
  .column-count-2.fourtysixty .container,
  .column-count-2.sixtyfourty .container,
  .column-count-2.seventythirty .container,
  .column-count-2.eightytwenty .container,
  .column-count-3 .container {
    display: block;
  }
  .main .column:nth-child(2) ul {
    margin-bottom: 0;
  }
}

/* icons/text */

.icon-text {
  padding: 0 20px;
  margin: 0 0 60px;
  text-align: center;
}
  .icon-text .fas {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100px;
    height: 100px;
    margin-bottom: 20px;
    font-size: 46px;
    color: var(--white);
    line-height: 80px;
    background: var(--red);
  }
  .icon-text h2 {
    font-size: 32px;
  }
@media screen and (min-width: 1200px) {
  .icon-text {
    margin: 0 0 20px;
  }
}

/* image/content blocks */

.image-content {
  position: relative;
}
.image-content .container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-areas: 'image text';
}
.image-content.reversed .container {
  grid-template-areas: 'text image';
}
.image-content main {
  grid-area: text;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: baseline;
  padding: 100px 0 100px 50px;
}
.image-content.reversed main {
  padding: 100px 50px 100px 0;
}
  .image-content main h3 {
    font-size: 30px;
  }
  .image-content main h3 + h4 {
    position: relative;
    top: -15px;
    font-size: 20px;
    margin: 0 0 15px;
  }
  .image-content main p {
    margin: 0 0 40px;
  }
.image-content picture {
  grid-area: image;
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
}
.image-content.reversed picture {
  right: 0;
  left: auto;
}
  .image-content picture img {
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
@media screen and (max-width: 1024px) {
  .image-content .container,
  .image-content.reversed .container {
    grid-template-columns: 1fr;
    gap: 0;
    grid-template-areas: 'text'
    'image';
  }
  .image-content picture,
  .image-content.reversed picture {
    position: relative;
    top: auto;
    right: auto;
    width: calc(100% + 20px);
    height: auto;
  }
  .image-content main {
    padding: 80px 10px;
  }
  .image-content main p {
    margin: 0;
  }
  .image-content main p + .button {
    margin: 40px 0 0;
  }
}