/* 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: 1fr 1fr;
  grid-gap: 0 80px;
}
.vertical-center .container {
  align-items: center;
}
.light-colors * {
  color: var(--white);
}
.fixed-bg .bg-image {
  background-attachment: fixed;
}
.title-above {
  grid-column: 1 / -1;
  margin: 0 0 50px;
}
.title-above.highlight {
  font-weight: 700;
  font-size: 44px;
  padding-left: 5px;
  padding-right: 5px;
}
  .title-above.highlight:before,
  .title-above.highlight:after {
    left: -5px;
    width: calc(100% + 10px);
  }
  /* 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;
  }
  .column h2 {
    font-size: 36px;
    margin: 0 0 40px;
  }
  .column h3 {
    color: var(--green);
  }
  .column img {
    max-width: 100%;
  }
@media screen and (max-width: 1024px) {
  .column-count-2 .container .column .figure {
    flex-direction: column;
  }
}
@media screen and (max-width: 768px) {
  /* column widths */
  .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 {
    grid-template-columns: 1fr;
  }
  .column-count-2 .container .column:last-of-type {
    margin: 60px 0 0;
  }
}

/* background colors */

.blue-bg {
  background-color: var(--darkblue);
}
.grey-bg {
  background-color: var(--lightgrey);
}
.white-bg,
.blue-bg,
.grey-bg {
  padding-left: 40px;
  padding-right: 40px;
}
.white-bg + .white-bg {
  padding-top: 0;
}
.grey-bg + .grey-bg {
  padding-top: 0;
}
.blue-bg + .blue-bg {
  padding-top: 0;
}
.column.blue-bg,
.column.grey-bg {
  padding: 1.5em;
}
.blue-bg * {
  color: var(--white);
}
@media screen and (max-width: 580px) {
  .white-bg,
  .blue-bg,
  .grey-bg {
    padding-left: 0;
    padding-right: 0;
  }
}

/* cta blocks */

.cta-blocks {
  display: grid;
  padding: 50px 0 10px;
}
h3 + .cta-blocks {
  padding: 50px 0 90px;
}
.cta-blocks.col-02 {
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 60px;
}
.cta-blocks.col-03 {
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 50px;
}
.cta-blocks.col-04,
.cta-blocks.col-06,
.cta-blocks.col-08 {
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 40px;
}
.cta-blocks.col-05,
.cta-blocks.col-07 {
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 40px;
}
  .cta-blocks aside {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .cta-blocks .icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 200px;
    height: 160px;
    margin: 0 0 30px;
    font-size: 68px;
    color: var(--white);
    background: var(--darkblue);
    border-radius: 80px 0 80px 0;
    line-height: 122px;
    text-align: center;
  }
  .blue-bg .cta-blocks .icon {
    color: var(--darkblue);
    background: var(--white);
  }
    .cta-blocks .icon img {
      margin: 0 auto;
    }
  .cta-blocks .image {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 30px;
    text-align: center;
  }
  .cta-blocks h3 {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 20px;
  }
    .blue-bg .cta-blocks h3 {
      color: var(--green);
    }
  .cta-blocks p {
    font-size: 18px;
    margin: 0 0 15px;
  }
  .cta-blocks .button {
    margin: 20px 0 0;
  }
  .blue-bg .cta-blocks .button:hover {
    background: var(--lightblue);
  }
.main .content-after {
  display: flex;
  flex-direction: column;
  align-items: start;
  padding: 50px 0 0;
}
.content-before .button,
.content-after .button {
  margin-top: 0;
}
.parent-pageid-74 .cta-blocks aside,
.parent-pageid-1594 .cta-blocks aside {
  padding: 30px;
  background: #f6f6f6;
}
@media screen and (max-width: 768px) {
  .cta-blocks.col-02,
  .cta-blocks.col-03 {
    grid-template-columns: 1fr;
  }
  .cta-blocks h3 {
    font-size: 30px;
  }
}
@media screen and (max-width: 580px) {
  .cta-blocks.col-02,
  .cta-blocks.col-03,
  .cta-blocks.col-04,
  .cta-blocks.col-05,
  .cta-blocks.col-06,
  .cta-blocks.col-07 {
    grid-template-columns: 1fr;
  }
}

/* cta blocks - feature blocks */

.feature-blocks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 60px;
  padding: 10px 0;
}
.feature-blocks.cta-blocks.col-01 {
  grid-template-columns: 1fr;
}
	.feature-blocks h3 {
    grid-column: 1 / -1;
    margin: 0 0 15px;
    flex: 1;
	}
  .feature-blocks .highlight:nth-of-type(2) {
    margin: 40px 0 0;
	}
	.main .feature-blocks aside .image {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 35px;
    width: 100%;
    height: 220px;
	}
		.feature-blocks aside .image i {
      position: absolute;
      bottom: -30px;
      left: 50%;
      transform: translateX(-50%);
      display: block;
      width: 60px;
      height: 60px;
      border-radius: 50%;
      font-size: 26px;
      color: var(--darkblue);
      line-height: 60px;
      background: var(--white);
		}
    .grey-bg .feature-blocks aside .image i {
      background: var(--lightgrey);
    }
    .feature-blocks aside .image img {
      display: block;
      width: 100%;
      height: 100%;
      margin: 0 auto;
      object-fit: cover;
      border-radius: 60px 0 60px 0;
		}
      .feature-blocks.cta-blocks.col-01 aside .image img {
        width: auto;
      }
	.feature-blocks aside h5 {
	  font-size: 22px;
    margin: 0;
	}
	.main .feature-blocks a:not(.button):not(.img-wrap) {
    display: block;
    text-decoration: none;
	}
  .feature-blocks ul,
  .feature-blocks ol {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
	.feature-blocks .description {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px 0 15px;
    margin: 10px 0 0;
    border-top: 1px solid #cecece;
	}
		.feature-blocks .description p {
      font-size: 14px;
      padding: 10px 0;
      margin: 0;
		}
@media screen and (max-width:  1024px)  {
	.feature-blocks {
	  grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (max-width:  580px)  {
	.feature-blocks {
    grid-template-columns: 1fr;
    grid-gap: 40px;
	}
}

/* banner block */

.banner-block {
  position: relative;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}
.banner-block + .banner-block {
  border-top: 50px solid var(--white);
}
/* .banner-block > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
} */
.banner-block .container {
  position: relative;
  display: grid;
  padding-top: 100px;
  padding-bottom: 100px;
}
.banner-block.single-left .container {
  grid-template-columns: 1fr 1fr;
  grid-template-areas: 'text .';
}
.banner-block.single-right .container {
  grid-template-columns: 1fr 1fr;
  grid-template-areas: '. text';
}
  .banner-block.single-left .block,
  .banner-block.single-right .block {
    grid-area: text;
  }
.banner-block.two-col .container {
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 100px;
}
.banner-block.three-col .container {
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 60px;
}
.banner-block.four-col .container {
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 40px;
}
.banner-block.five-col .container {
  grid-template-columns: repeat(5, 1fr);
  grid-gap: 30px;
}
.banner-block .block {
  padding: 60px;
  background: var(--white);
}
  .banner-block .block ul {
    list-style: outside disc;
    margin: 0 0 30px 20px;
  }
  .banner-block .block ul li::marker {
    color: var(--darkblue);
  }
@media screen and (max-width: 1024px)  {
	.banner-block.three-col .container,
  .banner-block.five-col .container {
    grid-template-columns: 1fr;
    grid-gap: 40px;
  }
  .banner-block.four-col .container {
    grid-template-columns: 1fr 1fr;
    grid-gap: 40px;
  }
  .banner-block .block {
    padding: 40px 20px;
  }
  .banner-block .block h2 {
    font-size: 40px;
  }
}
@media screen and (max-width: 768px)  {
	.banner-block.four-col .container {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 580px)  {
	.banner-block.single-left .container,
  .banner-block.single-right .container {
    grid-template-columns: 1fr;
    grid-template-areas: 'text';
  }
}