body.page-template-page-visionzero,
body.page-template-page-visionzerofocus,
body.page-template-page-visionzerobeyond,
body.page-template-page-visionzerochild {
  color: #221E1F;
  font-family: myriad-pro, sans-serif;
}
body.page-template-page-visionzero h1,
body.page-template-page-visionzerofocus h1,
body.page-template-page-visionzerobeyond h1,
body.page-template-page-visionzerochild h1 {
  font-family: museo-sans, sans-serif;
  font-weight: 700;
}
body.page-template-page-visionzero h2,
body.page-template-page-visionzero h3,
body.page-template-page-visionzero h4,
body.page-template-page-visionzero h5,
body.page-template-page-visionzerofocus h2,
body.page-template-page-visionzerofocus h3,
body.page-template-page-visionzerofocus h4,
body.page-template-page-visionzerofocus h5,
body.page-template-page-visionzerobeyond h2,
body.page-template-page-visionzerobeyond h3,
body.page-template-page-visionzerobeyond h4,
body.page-template-page-visionzerobeyond h5,
body.page-template-page-visionzerochild h2,
body.page-template-page-visionzerochild h3,
body.page-template-page-visionzerochild h4,
body.page-template-page-visionzerochild h5 {
  font-family: myriad-pro, sans-serif;
  font-weight: bold;
}
body.page-template-page-visionzero #site-wrapper,
body.page-template-page-visionzerofocus #site-wrapper,
body.page-template-page-visionzerobeyond #site-wrapper,
body.page-template-page-visionzerochild #site-wrapper {
  padding-top: 0px;
}
body.page-template-page-visionzero .container,
body.page-template-page-visionzerofocus .container,
body.page-template-page-visionzerobeyond .container,
body.page-template-page-visionzerochild .container {
  width: 1246px;
}
body.page-template-page-visionzero a,
body.page-template-page-visionzerofocus a,
body.page-template-page-visionzerobeyond a,
body.page-template-page-visionzerochild a {
  transition: 0.3s ease-in-out;
}

@media all and (max-width: 1280px) and (min-width: 0px) {
  body.page-template-page-visionzero .container,
body.page-template-page-visionzerofocus .container,
body.page-template-page-visionzerobeyond .container,
body.page-template-page-visionzerochild .container {
    width: auto;
    margin: 0 40px;
  }
}
@media all and (max-width: 1280px) and (min-width: 0px) {
  body.page-template-page-visionzero .container,
body.page-template-page-visionzerofocus .container,
body.page-template-page-visionzerobeyond .container,
body.page-template-page-visionzerochild .container {
    width: auto;
    margin: 0 32px;
  }
}
@media all and (max-width: 1023px) and (min-width: 0px) {
  body.page-template-page-visionzero .container,
body.page-template-page-visionzerofocus .container,
body.page-template-page-visionzerobeyond .container,
body.page-template-page-visionzerochild .container {
    width: auto;
    margin: 0 20px;
  }
}
.vz-button {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  border: none;
  font-family: myriad-pro, sans-serif;
  font-weight: 600;
  background: #E5272B;
  box-shadow: none;
  color: #FFF;
  border-radius: 4px;
  padding: 13px 14px 14px 14px;
  height: 53px;
  font-size: 20px;
  line-height: 26px;
  position: relative;
  display: inline-block;
  overflow: hidden;
  text-align: center;
}
.vz-button span {
  position: relative;
  z-index: 1;
}
.vz-button.vz-button-download {
  padding-right: 24px;
  padding-left: 55px;
}
.vz-button.vz-button-download svg {
  position: absolute;
  top: 50%;
  margin: -10px 0 0 0;
  left: 20px;
  display: block;
}
.vz-button:hover, .vz-button:active, .vz-button:focus {
  color: #FFF;
  background: #EA5255;
}
.vz-button.vz-button-outline {
  background: transparent;
  border: 2px solid #E5272B;
  box-shadow: none;
  padding: 11px 12px 12px 12px;
  color: #E5272B;
}
.vz-button.vz-button-outline.vz-button-download {
  padding-right: 22px;
  padding-left: 53px;
}
.vz-button.vz-button-outline.vz-button-download svg {
  left: 18px;
}
.vz-button.vz-button-outline:hover, .vz-button.vz-button-outline:active, .vz-button.vz-button-outline:focus {
  color: #FFF;
  background: #E5272B;
  border-color: #E5272B;
}

@media all and (max-width: 767px) and (min-width: 0px) {
  .vz-button {
    font-size: 16px;
  }

  .vz-button.vz-button-download {
    padding-left: 35px;
    padding-right: 12px;
    text-align: left;
  }
  .vz-button.vz-button-download svg {
    left: 12px;
    width: 16px;
  }

  .vz-button.vz-button-outline.vz-button-download {
    padding-left: 33px;
    padding-right: 10px;
  }
  .vz-button.vz-button-outline.vz-button-download svg {
    left: 10px;
  }
}
.vz-toggle-nav {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 64px;
  height: 64px;
  margin: 0px;
  border-radius: 100%;
  z-index: 1000;
  background: #FFF;
  display: none;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}
.vz-toggle-nav svg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
}
.vz-toggle-nav svg.svg-close {
  display: none;
}

body.vz-nav-active .vz-toggle-nav svg.svg-open {
  display: none;
}
body.vz-nav-active .vz-toggle-nav svg.svg-close {
  display: block;
}

#vz-header {
  background: url(../images/vz-banner-back.png) no-repeat right top #E5272B;
  padding: 40px 0 0 0;
}
#vz-header .container {
  text-align: center;
  width: auto;
  padding: 0 40px;
}
#vz-header .vz-header-top .vz-logo {
  float: left;
}
#vz-header .vz-header-top .kcc-nav {
  position: absolute;
  left: 0px;
  top: 15px;
  width: 100%;
  padding: 0 235px 0 326px;
  text-align: center;
}
#vz-header .vz-header-top .kcc-nav ul li {
  display: inline-block;
  padding: 0 16px;
}
#vz-header .vz-header-top .kcc-nav ul li a {
  font-size: 20px;
  line-height: 26px;
  color: #FFF;
}
#vz-header .vz-header-top .kcc-nav ul li a:hover, #vz-header .vz-header-top .kcc-nav ul li a:active, #vz-header .vz-header-top .kcc-nav ul li a:focus {
  text-decoration: underline;
}
#vz-header .vz-header-top .kcc-logo {
  float: right;
}
#vz-header .small-banner-text {
  padding: 115px 0 131px 56px;
  text-align: left;
}
#vz-header .small-banner-text h1 {
  font-size: 32px;
  line-height: 54px;
  margin: 0 0 6px 0;
  font-weight: bold;
  color: #FFF;
}
#vz-header .small-banner-text h2 {
  font-size: 64px;
  line-height: 70px;
  margin: 0 0 0 0;
  color: #FFF;
}
#vz-header .banner-text {
  margin: 0 auto;
  max-width: 825px;
  padding: 79px 0 136px 0;
}
#vz-header .banner-text h1 {
  font-size: 32px;
  line-height: 54px;
  margin: 0 0 6px 0;
  font-weight: bold;
  color: #FFF;
}
#vz-header .banner-text h2 {
  font-size: 64px;
  line-height: 70px;
  color: #FFF;
}
#vz-header .banner-text .vz-button-outline {
  border-color: #FFF;
  color: #FFF;
  padding-left: 23px;
  padding-right: 50px;
}
#vz-header .banner-text .vz-button-outline svg {
  position: absolute;
  top: 50%;
  right: 25px;
  margin: -7px 0 0 0;
  display: block;
}
#vz-header .banner-text .vz-button-outline:hover, #vz-header .banner-text .vz-button-outline:active, #vz-header .banner-text .vz-button-outline:focus {
  color: #E5272B;
  background: #FFF;
  border-color: #FFF;
}

@media all and (max-width: 1280px) and (min-width: 0px) {
  #vz-header .container {
    padding: 0px;
  }
}
@media all and (max-width: 1023px) and (min-width: 0px) {
  #vz-header {
    background-size: 330px auto;
    padding: 20px 0 0 0;
  }
  #vz-header .vz-header-top .vz-logo {
    width: 200px;
  }
  #vz-header .vz-header-top .kcc-nav {
    padding: 0 100px 0 200px;
  }
  #vz-header .vz-header-top .kcc-logo img {
    width: 80px;
  }
  #vz-header .banner-text {
    padding: 200px 0 136px 0;
  }
  #vz-header .banner-text h1 {
    font-size: 24px;
    line-height: 54px;
  }
  #vz-header .banner-text h2 {
    font-size: 36px;
    line-height: 51px;
  }
  #vz-header .small-banner-text {
    padding: 100px 0 100px 0;
    text-align: center;
  }
  #vz-header .small-banner-text h1 {
    font-size: 24px;
    line-height: 54px;
  }
  #vz-header .small-banner-text h2 {
    font-size: 36px;
    line-height: 51px;
    margin: 0px;
  }
}
@media all and (max-width: 767px) and (min-width: 0px) {
  #vz-header {
    background-size: 230px auto;
  }
  #vz-header .vz-header-top .vz-logo {
    width: 190px;
  }
  #vz-header .vz-header-top .kcc-nav {
    padding: 0px;
    top: 80px;
    display: none;
  }
  #vz-header .vz-header-top .kcc-logo img {
    width: 50px;
  }
  #vz-header .banner-text {
    padding: 64px 0 64px 0;
  }
  #vz-header .banner-text h1 {
    margin: 0px;
  }
  #vz-header .small-banner-text {
    padding: 80px 0 64px 0;
  }
  #vz-header .small-banner-text h1 {
    margin: 0px;
  }

  .vz-toggle-nav {
    display: block;
  }

  body.vz-nav-active #vz-header .vz-header-top {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100vh;
    background: #E5272B;
    padding: 20px 20px;
    z-index: 999;
  }
  body.vz-nav-active #vz-header .vz-header-top .kcc-logo {
    display: none;
  }
  body.vz-nav-active #vz-header .vz-header-top .kcc-nav {
    padding: 24px 0 0 0;
    text-align: left;
    display: block;
  }
  body.vz-nav-active #vz-header .vz-header-top .kcc-nav ul li {
    display: block;
  }
  body.vz-nav-active #vz-header .vz-header-top .kcc-nav ul li a {
    font-size: 24px;
    display: block;
    padding: 10px 0;
  }
}
.vz-intro {
  padding: 97px 0;
}
.vz-intro .vz-intro-wrapper {
  display: flex;
  align-items: center;
}
.vz-intro .vz-intro-wrapper .vz-intro-content {
  width: calc(100% - 393px);
  padding: 0 55px 0 0;
}
.vz-intro .vz-intro-wrapper .vz-intro-content h3 {
  font-size: 40px;
  line-height: 58px;
  margin: 0 0 28px 0;
  color: #221E1F;
  font-weight: 400;
  font-family: myriad-pro, sans-serif;
}
.vz-intro .vz-intro-wrapper .vz-intro-content h3 strong {
  font-weight: bold;
}
.vz-intro .vz-intro-wrapper .vz-intro-content p {
  font-size: 24px;
  line-height: 40px;
  color: #585858;
}
.vz-intro .vz-intro-wrapper .vz-intro-stat {
  width: 393px;
  border-radius: 100%;
  height: 393px;
  border: 2px solid #E5272B;
  text-align: center;
  padding: 113px 0 0 0;
}
.vz-intro .vz-intro-wrapper .vz-intro-stat img {
  margin: 0 auto 26px auto;
}
.vz-intro .vz-intro-wrapper .vz-intro-stat p {
  font-size: 24px;
  line-height: 32px;
  color: #221E1F;
}

.vz-intro-centered {
  padding: 34px 0 140px 0;
  padding: 108px 0 140px 0;
}
.vz-intro-centered .vz-intro-content {
  padding: 0 214px;
  text-align: center;
}
.vz-intro-centered .vz-intro-content h3 {
  font-size: 40px;
  line-height: 58px;
  margin: 0 0 28px 0;
  color: #221E1F;
  font-weight: 400;
  font-family: myriad-pro, sans-serif;
}
.vz-intro-centered .vz-intro-content h3 strong {
  font-weight: bold;
}
.vz-intro-centered .vz-intro-content p {
  font-size: 24px;
  line-height: 40px;
  color: #585858;
}

@media all and (max-width: 1280px) and (min-width: 0px) {
  .vz-intro-centered .vz-intro-content {
    padding: 0 114px;
  }
}
@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-intro {
    padding: 64px 0;
  }
  .vz-intro .vz-intro-wrapper {
    display: block;
  }
  .vz-intro .vz-intro-wrapper .vz-intro-content {
    width: auto;
    padding: 0 0 51px 0;
  }
  .vz-intro .vz-intro-wrapper .vz-intro-content h3 {
    font-size: 26px;
    line-height: 41px;
    margin: 0 0 37px 0;
  }
  .vz-intro .vz-intro-wrapper .vz-intro-content p {
    font-size: 20px;
    line-height: 33px;
  }
  .vz-intro .vz-intro-wrapper .vz-intro-stat {
    width: auto;
    border: none;
    height: auto;
    border-radius: 0px;
    padding: 0px;
    text-align: left;
  }
  .vz-intro .vz-intro-wrapper .vz-intro-stat img {
    height: 74px;
    margin: 0 0 5px 0;
  }
  .vz-intro .vz-intro-wrapper .vz-intro-stat p {
    font-size: 26px;
  }

  .vz-intro-centered {
    padding: 64px 0;
  }
  .vz-intro-centered .vz-intro-content {
    padding: 0px;
  }
  .vz-intro-centered .vz-intro-content h3 {
    font-size: 26px;
    line-height: 41px;
    margin: 0 0 37px 0;
  }
  .vz-intro-centered .vz-intro-content p {
    font-size: 20px;
    line-height: 33px;
  }
}
.vz-about-image img {
  display: block;
  width: 100%;
}

.vz-about-columns {
  background: #E5272B;
  padding: 105px 0 100px 0;
}
.vz-about-columns .vz-about-columns-wrapper {
  margin: 0 -18px;
}
.vz-about-columns .vz-about-columns-wrapper section {
  float: left;
  width: 33.33%;
  padding: 0 18px;
}
.vz-about-columns .vz-about-columns-wrapper section h4 {
  font-size: 24px;
  line-height: 58px;
  color: #FFF;
  margin: 0 0 6px 0;
}
.vz-about-columns .vz-about-columns-wrapper section p {
  font-size: 18px;
  line-height: 28px;
  color: #FFF;
}
.vz-about-columns.vz-about-columns-grey {
  background: #EDEDED;
  padding: 76px 0 52px 0;
}
.vz-about-columns.vz-about-columns-grey h2 {
  font-size: 40px;
  line-height: 58px;
  margin: 0 0 30px 0;
  font-weight: bold;
  color: #221E1F;
}
.vz-about-columns.vz-about-columns-grey .vz-about-columns-wrapper section h4 {
  color: #221E1F;
}
.vz-about-columns.vz-about-columns-grey .vz-about-columns-wrapper section p {
  color: #585858;
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-about-columns {
    padding: 64px 0 32px 0;
  }
  .vz-about-columns .vz-about-columns-wrapper {
    margin: 0px;
  }
  .vz-about-columns .vz-about-columns-wrapper section {
    float: none;
    width: auto;
    padding: 0 0 32px 0;
  }
  .vz-about-columns .vz-about-columns-wrapper section h4 {
    line-height: 36px;
    font-size: 22px;
  }
  .vz-about-columns .vz-about-columns-wrapper section p {
    font-size: 16px;
    line-height: 26px;
  }
}
.vz-image-and-text {
  padding: 64px 0;
}
.vz-image-and-text .vz-image-and-text-wrapper {
  display: flex;
  align-items: center;
}
.vz-image-and-text .vz-image-and-text-wrapper .image-holder {
  width: 51%;
  padding: 0 80px 0 0;
}
.vz-image-and-text .vz-image-and-text-wrapper .image-holder img {
  width: 100%;
  display: block;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder {
  width: 49%;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder h1,
.vz-image-and-text .vz-image-and-text-wrapper .content-holder h2,
.vz-image-and-text .vz-image-and-text-wrapper .content-holder h3 {
  font-size: 40px;
  line-height: 58px;
  color: #221E1F;
  margin: 0 0 10px 0;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder p {
  font-size: 20px;
  line-height: 32px;
  color: #585858;
  margin: 0 0 22px 0;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder h4 {
  font-size: 20px;
  line-height: 32px;
  color: #221E1F;
  font-weight: bold;
  margin: 0 0 6px 0;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder ul:not([class]) li {
  padding: 0 0 0 14px;
  font-size: 20px;
  line-height: 28px;
  color: #585858;
  display: block;
  position: relative;
  margin: 0 0 8px 0;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder ul:not([class]) li:before {
  width: 6px;
  height: 6px;
  content: "";
  display: block;
  border-radius: 100%;
  background: #E5272B;
  position: absolute;
  top: 11px;
  left: 0px;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder ul.link-list li {
  display: block;
  margin: 0 0 3px 0;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder ul.link-list li a {
  display: block;
  padding: 0 0 0 26px;
  color: #E5272B;
  font-size: 20px;
  line-height: 32px;
  position: relative;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder ul.link-list li a:hover, .vz-image-and-text .vz-image-and-text-wrapper .content-holder ul.link-list li a:active, .vz-image-and-text .vz-image-and-text-wrapper .content-holder ul.link-list li a:focus {
  text-decoration: underline;
}
.vz-image-and-text .vz-image-and-text-wrapper .content-holder ul.link-list li a:before {
  background: url('data:image/svg+xml,<svg width="20px" height="20px" viewBox="0 0 20 20" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><title>link</title><g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" stroke-linecap="round" stroke-linejoin="round"><g id="link" transform="translate(1.000000, 1.000000)" stroke="%23E5272B" stroke-width="2"><path d="M7,10.1403462 C7.80030663,11.21776 9.02585327,11.8920241 10.3585588,11.9881386 C11.6912643,12.0842531 12.9997206,11.5927408 13.9443281,10.64117 L16.7073234,7.85881561 C18.4524874,6.03925377 18.4275291,3.14696911 16.651228,1.35822225 C14.8749269,-0.430524601 12.0027662,-0.455657773 10.1958645,1.30173386 L8.61174724,2.88767584" id="Path"></path><path d="M11,7.85965382 C10.1996934,6.78224003 8.97414673,6.10797586 7.64144123,6.01186137 C6.30873573,5.91574687 5.00027938,6.40725916 4.0556719,7.35883003 L1.29267664,10.1411844 C-0.452487394,11.9607462 -0.427529093,14.8530309 1.348772,16.6417777 C3.1250731,18.4305246 5.9972338,18.4556578 7.80413548,16.6982661 L9.37904278,15.1123242" id="Path"></path></g></g></svg>') no-repeat;
  width: 20px;
  height: 20px;
  display: block;
  position: absolute;
  top: 7px;
  left: 0px;
  content: "";
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-image-and-text {
    padding: 64px 0;
  }
  .vz-image-and-text .vz-image-and-text-wrapper {
    display: block;
  }
  .vz-image-and-text .vz-image-and-text-wrapper .image-holder {
    width: auto;
    padding: 0 0 36px 0;
    max-width: 400px;
  }
  .vz-image-and-text .vz-image-and-text-wrapper .content-holder {
    width: auto;
    padding: 0px;
  }
  .vz-image-and-text .vz-image-and-text-wrapper .content-holder h1,
.vz-image-and-text .vz-image-and-text-wrapper .content-holder h2,
.vz-image-and-text .vz-image-and-text-wrapper .content-holder h3 {
    font-size: 32px;
    line-height: 40px;
  }
  .vz-image-and-text .vz-image-and-text-wrapper .content-holder p {
    font-size: 18px;
    line-height: 28px;
    margin: 0 0 30px 0;
  }
}
.vz-community {
  background: #EDEDED;
  padding: 76px 0 52px 0;
}
.vz-community h2 {
  font-size: 40px;
  line-height: 58px;
  font-weight: bold;
  color: #221E1F;
  margin: 0 0 10px 0;
  font-family: myriad-pro, sans-serif;
  font-weight: bold;
}
.vz-community p {
  font-size: 20px;
  line-height: 32px;
  max-width: 930px;
  margin: 0 0 47px 0;
  color: #221E1F;
}
.vz-community h3 {
  font-size: 24px;
  line-height: 32px;
  color: #221E1F;
  margin: 0 0 27px 0;
  font-family: myriad-pro, sans-serif;
  font-weight: bold;
}
.vz-community .vz-community-boxes {
  display: grid;
  column-gap: 36px;
  row-gap: 32px;
  grid-template-columns: 1fr 1fr 1fr;
}
.vz-community .vz-community-boxes section {
  background: #FFF;
  border-radius: 4px;
  padding: 30px 32px 81px 32px;
}
.vz-community .vz-community-boxes section .vz-community-box {
  min-height: 235px;
  position: relative;
}
.vz-community .vz-community-boxes section .vz-community-box h4 {
  font-size: 24px;
  line-height: 32px;
  font-family: myriad-pro, sans-serif;
  font-weight: bold;
  color: #221E1F;
  margin: 0 0 8px 0;
}
.vz-community .vz-community-boxes section .vz-community-box p {
  font-size: 18px;
  line-height: 28px;
  color: #585858;
  margin: 0px;
}
.vz-community .vz-community-boxes section .vz-community-box ul {
  margin: 0 0 -8px 0;
}
.vz-community .vz-community-boxes section .vz-community-box ul li {
  padding: 0 0 0 14px;
  font-size: 18px;
  line-height: 28px;
  color: #585858;
  display: block;
  position: relative;
  margin: 0 0 8px 0;
}
.vz-community .vz-community-boxes section .vz-community-box ul li:before {
  width: 6px;
  height: 6px;
  content: "";
  display: block;
  border-radius: 100%;
  background: #E5272B;
  position: absolute;
  top: 11px;
  left: 0px;
}
.vz-community .vz-community-boxes section .vz-community-box a {
  position: absolute;
  bottom: 32px;
  left: 32px;
  font-size: 20px;
  line-height: 32px;
  color: #585858;
  text-decoration: underline;
}
.vz-community .vz-community-boxes section .vz-community-box a:hover, .vz-community .vz-community-boxes section .vz-community-box a:active, .vz-community .vz-community-boxes section .vz-community-box a:focus {
  color: #E5272B;
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-community {
    padding: 64px 0;
  }
  .vz-community h2 {
    font-size: 36px;
    margin: 0 0 10px 0;
    line-height: 46px;
  }
  .vz-community p {
    font-size: 16px;
    line-height: 26px;
  }
  .vz-community h3 {
    font-size: 22px;
    line-height: 32px;
  }
  .vz-community .vz-community-boxes {
    margin: 0px;
    display: block;
  }
  .vz-community .vz-community-boxes section {
    width: auto;
    float: none;
    margin: 0 0 10px 0;
  }
  .vz-community .vz-community-boxes section .vz-community-box {
    min-height: 0px;
    padding: 20px 22px;
  }
  .vz-community .vz-community-boxes section .vz-community-box h4 {
    font-size: 22px;
    line-height: 32px;
  }
  .vz-community .vz-community-boxes section .vz-community-box a {
    position: relative;
    bottom: auto;
    left: auto;
    margin: 16px 0 0 0;
    font-size: 18px;
    display: inline-block;
  }
}
.vz-2050-vision {
  background: #EDEDED;
  padding: 80px 0 80px 0;
}
.vz-2050-vision .vz-2050-vision-wrapper {
  display: flex;
  align-items: center;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content {
  width: 51%;
  padding: 0 100px 0 0;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content h2 {
  font-size: 40px;
  line-height: 58px;
  color: #221E1F;
  margin: 0 0 28px 0;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content p {
  font-size: 20px;
  line-height: 32px;
  color: #585858;
  margin: 0px;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content .vz-2050-vision-buttons {
  display: block;
  padding: 57px 0 0 0;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content .vz-2050-vision-buttons a {
  margin: 0 24px 24px 0;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits {
  width: 49%;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section {
  background: #FFF;
  border-radius: 4px;
  border: 1px solid #EDEDED;
  margin: 0 0 16px 0;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper {
  height: 120px;
  display: flex;
  align-items: center;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper p {
  font-size: 20px;
  line-height: 26px;
  padding: 0 20px 0 32px;
  color: #221E1F;
  width: calc(100% - 155px);
  font-family: myriad-pro, sans-serif;
  font-weight: 600;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper.benefit-wrapper-left-icon p {
  padding-left: 0px;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper .benefit-icon {
  width: 155px;
  text-align: center;
  vertical-align: middle;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper .benefit-icon img {
  margin: 0 auto;
  display: inline-block;
  vertical-align: middle;
}
.vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-buttons-mobile {
  display: none;
}
.vz-2050-vision.vz-2050-vision-red {
  background: #E5272B;
}
.vz-2050-vision.vz-2050-vision-red .vz-2050-vision-wrapper .vz-2050-vision-content h2,
.vz-2050-vision.vz-2050-vision-red .vz-2050-vision-wrapper .vz-2050-vision-content p {
  color: #FFF;
}

@media all and (max-width: 1000px) and (min-width: 0px) {
  .vz-2050-vision {
    padding: 64px 0;
  }
  .vz-2050-vision .vz-2050-vision-wrapper {
    display: block;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content {
    width: auto;
    padding: 0 0 32px 0;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content h2 {
    font-size: 36px;
    line-height: 46px;
    margin: 0 0 10px 0;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content p {
    font-size: 18px;
    line-height: 28px;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-content .vz-2050-vision-buttons-desktop {
    display: none;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits {
    width: auto;
    padding: 0px;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper p {
    font-size: 18px;
    line-height: 24px;
    padding: 0 0 0 20px;
    width: calc(100% - 120px);
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-benefits section .benefit-wrapper .benefit-icon {
    width: 120px;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-buttons-mobile {
    padding: 20px 0 0 0;
    display: block;
    margin: 0 -10px 0 0;
  }
  .vz-2050-vision .vz-2050-vision-wrapper .vz-2050-vision-buttons-mobile a {
    margin: 0 0 10px 0;
  }
}
.vz-consultation-report {
  padding: 108px 0 153px 0;
}
.vz-consultation-report .container {
  max-width: 820px;
}
.vz-consultation-report h2 {
  margin: 0 0 20px 0;
  font-size: 40px;
  line-height: 58px;
  color: #221E1F;
}
.vz-consultation-report p {
  font-size: 20px;
  line-height: 32px;
  color: #585858;
}
.vz-consultation-report h3 {
  padding: 47px 0 0 0;
  font-size: 24px;
  line-height: 32px;
  color: #221E1F;
  margin: 0 0 27px 0;
}
.vz-consultation-report .vz-consultation-report-buttons a {
  margin: 0 20px 10px 0;
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-consultation-report {
    padding: 64px 0;
  }
  .vz-consultation-report h2 {
    font-size: 36px;
    line-height: 46px;
    margin: 0 0 10px 0;
  }
  .vz-consultation-report p {
    font-size: 18px;
    line-height: 28px;
  }
  .vz-consultation-report h3 {
    padding: 37px 0 0 0;
    font-size: 22px;
    line-height: 32px;
  }
  .vz-consultation-report .vz-consultation-report-buttons a {
    margin: 0 0 10px 0;
  }
}
.vz-event {
  background: #E5272B;
  padding: 128px 0 116px 0;
}
.vz-event .vz-event-wrapper {
  display: flex;
  align-items: center;
}
.vz-event .vz-event-wrapper .vz-event-content {
  width: 58%;
  padding: 0 104px 0 0;
}
.vz-event .vz-event-wrapper .vz-event-content h5 {
  font-weight: 600;
  color: #FFF;
  font-size: 20px;
  line-height: 24px;
  margin: 0 0 1px 0;
}
.vz-event .vz-event-wrapper .vz-event-content h2 {
  font-size: 40px;
  line-height: 58px;
  color: #FFF;
  margin: 0 0 18px 0;
}
.vz-event .vz-event-wrapper .vz-event-content p {
  font-size: 20px;
  line-height: 32px;
  color: #FFF;
  margin: 0 0 35px 0;
}
.vz-event .vz-event-wrapper .vz-event-content .vz-event-meta {
  margin: 0 0 12px 0;
  font-size: 20px;
  line-height: 32px;
  font-weight: 600;
  padding: 0 0 0 37px;
  color: #FFF;
}
.vz-event .vz-event-wrapper .vz-event-content .vz-event-meta.vz-event-meta-location {
  background: url(../images/vz-icon-location.svg) no-repeat left center;
}
.vz-event .vz-event-wrapper .vz-event-content .vz-event-meta.vz-event-meta-date {
  background: url(../images/vz-icon-date.svg) no-repeat left center;
  margin: 0 0 43px 0;
}
.vz-event .vz-event-wrapper .vz-event-content .vz-button-download-desktop {
  background: #FFF;
  color: #E5272B;
}
.vz-event .vz-event-wrapper .vz-event-content .vz-button-download-desktop:hover {
  background: #383943;
  color: #FFF;
}
.vz-event .vz-event-wrapper .vz-button-download-mobile {
  background: #FFF;
  color: #E5272B;
}
.vz-event .vz-event-wrapper .vz-button-download-mobile:hover {
  background: #383943;
  color: #FFF;
}
.vz-event .vz-event-wrapper .vz-event-programme {
  width: 42%;
  background: #EDEDED;
  border-radius: 4px;
  padding: 53px 64px 58px 64px;
}
.vz-event .vz-event-wrapper .vz-event-programme h4 {
  font-size: 24px;
  line-height: 32px;
  color: #221E1F;
  margin: 0 0 16px 0;
}
.vz-event .vz-event-wrapper .vz-event-programme ul li {
  margin: 0 0 6px 0;
  font-size: 20px;
  line-height: 32px;
  color: #221E1F;
  padding: 0 0 0 64px;
  position: relative;
}
.vz-event .vz-event-wrapper .vz-event-programme ul li strong {
  position: absolute;
  font-weight: 400;
  top: 0px;
  left: 0px;
  line-height: 32px;
  font-size: 20px;
  color: #E5272B;
  display: block;
}
.vz-event .vz-event-wrapper .vz-button-download-mobile {
  display: none;
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-event {
    padding: 64px 0;
  }
  .vz-event .vz-event-wrapper {
    display: block;
  }
  .vz-event .vz-event-wrapper .vz-event-content {
    width: auto;
    padding: 0px;
  }
  .vz-event .vz-event-wrapper .vz-event-content h2 {
    font-size: 36px;
    line-height: 42px;
  }
  .vz-event .vz-event-wrapper .vz-event-content p {
    font-size: 18px;
    line-height: 28px;
  }
  .vz-event .vz-event-wrapper .vz-event-content .vz-event-meta {
    background-position: left top !important;
    font-size: 18px;
    line-height: 28px;
  }
  .vz-event .vz-event-wrapper .vz-event-content .vz-button-download-desktop {
    display: none;
  }
  .vz-event .vz-event-wrapper .vz-event-programme {
    width: auto;
    margin: 0 0 32px 0;
    padding: 32px;
  }
  .vz-event .vz-event-wrapper .vz-button-download-mobile {
    display: inline-block;
  }
}
#vz-related h4 {
  font-size: 40px;
  line-height: 58px;
  font-weight: bold;
  color: #221E1F;
  margin: 0 0 36px 0;
}
#vz-related .vz-related-links {
  display: block;
}
#vz-related .vz-related-links section a {
  display: block;
  height: 0px;
  padding-top: 40%;
  position: relative;
  overflow: hidden;
}
#vz-related .vz-related-links section a .vz-related-link-image {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background: none no-repeat center center;
  background-size: cover;
  z-index: 1;
  transition: 0.3s;
}
#vz-related .vz-related-links section a .vz-related-link-gradient {
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  height: calc(100% - 32px);
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0) 1%, rgba(0, 0, 0, 0.5) 100%);
  z-index: 2;
}
#vz-related .vz-related-links section a .vz-related-link-text {
  position: absolute;
  bottom: 0px;
  left: 0px;
  padding: 37px 48px;
  font-size: 40px;
  line-height: 58px;
  color: #FFF;
  font-weight: bold;
  z-index: 3;
}
#vz-related .vz-related-links section a .vz-related-link-text .container span {
  display: block;
  font-size: 0.6em;
  padding: 0;
  font-weight: normal;
}
#vz-related .vz-related-links section a:hover .vz-related-link-image, #vz-related .vz-related-links section a:active .vz-related-link-image, #vz-related .vz-related-links section a:focus .vz-related-link-image {
  transform: scale(1.2);
}
#vz-related .vz-related-links section.vz-related-link-vision a .vz-related-link-image {
  background-image: url(../images/related-vision.jpg);
}
#vz-related .vz-related-links section.vz-related-link-focus a .vz-related-link-image {
  background-image: url(../images/related-focus.jpg);
}
#vz-related .vz-related-links section.vz-related-link-beyond a .vz-related-link-image {
  background-image: url(/wp-content/uploads/2024/05/Cars-on-road.png);
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  #vz-related h4 {
    font-size: 24px;
    margin: 0 0 16px 0;
  }
  #vz-related .vz-related-links {
    display: block;
    margin: 0;
  }
  #vz-related .vz-related-links section {
    padding: 0;
    float: none;
    width: auto;
  }
  #vz-related .vz-related-links section a .vz-related-link-text {
    font-size: 24px;
    line-height: 32px;
    padding: 24px;
  }
}
.vz-columns {
  padding: 108px 0 102px 0;
}
.vz-columns h2 {
  font-size: 40px;
  line-height: 58px;
  font-weight: bold;
  color: #221E1F;
  margin: 0 0 42px 0;
  font-family: myriad-pro, sans-serif;
  font-weight: bold;
}
.vz-columns .vz-columns {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  column-gap: 33px;
  padding: 0px;
}
.vz-columns .vz-columns section {
  padding: 0 0 20px 0;
}
.vz-columns .vz-columns section h4 {
  font-size: 24px;
  line-height: 32px;
  font-family: myriad-pro, sans-serif;
  font-weight: bold;
  color: #221E1F;
  margin: 0 0 8px 0;
}
.vz-columns .vz-columns section p {
  font-size: 18px;
  line-height: 28px;
  color: #585858;
  margin: 0px;
}

@media all and (max-width: 1023px) and (min-width: 0px) {
  .vz-columns {
    padding: 64px 0 44px 0;
  }
  .vz-columns h2 {
    font-size: 36px;
    margin: 0 0 32px 0;
    line-height: 46px;
  }
  .vz-columns .vz-columns {
    grid-template-columns: 1fr 1fr;
  }
  .vz-columns .vz-columns section h4 {
    font-size: 22px;
    line-height: 32px;
  }
}
@media all and (max-width: 767px) and (min-width: 0px) {
  .vz-columns .vz-columns {
    display: block;
  }
}
#vz-sub-footer {
  background: url(../images/vz-footer-back.svg) no-repeat right bottom #383943;
  padding: 83px 0 75px 0;
}
#vz-sub-footer aside {
  float: left;
  width: 25%;
}
#vz-sub-footer aside h5 {
  font-size: 20px;
  line-height: 32px;
  margin: 0 0 18px 0;
  color: #FFF;
}
#vz-sub-footer aside ul li {
  margin: 0 0 20px 0;
}
#vz-sub-footer aside ul li a {
  color: #FFF;
  display: block;
  padding: 0 0 0 34px;
  background: url(../images/vz-icon-download-white.svg) no-repeat left center;
  font-size: 16px;
  line-height: 26px;
}
#vz-sub-footer aside ul li a:hover, #vz-sub-footer aside ul li a:active, #vz-sub-footer aside ul li a:focus {
  opacity: 0.7;
}
#vz-sub-footer aside p {
  font-size: 16px;
  line-height: 26px;
  margin: 0 0 32px 0;
}
#vz-sub-footer aside p a {
  color: #FFF;
  text-decoration: underline;
}
#vz-sub-footer aside p a:hover, #vz-sub-footer aside p a:active, #vz-sub-footer aside p a:focus {
  opacity: 0.7;
}
#vz-sub-footer aside.vz-sub-footer-widget-a {
  padding: 13px 0 0 0;
  width: 31%;
}
#vz-sub-footer aside.vz-sub-footer-widget-a img {
  display: block;
  width: 255px;
  height: auto;
}
#vz-sub-footer aside.vz-sub-footer-widget-a h6 {
  padding: 37px 0 0 0;
  font-size: 16px;
  line-height: 26px;
  margin: 0 0 8px 0;
  color: #FFF;
}
#vz-sub-footer aside.vz-sub-footer-widget-a .kcc-logo img {
  width: 113px;
  height: auto;
}
#vz-sub-footer aside.vz-sub-footer-widget-b {
  width: 27%;
}
#vz-sub-footer aside.vz-sub-footer-widget-c {
  width: 25%;
}
#vz-sub-footer aside.vz-sub-footer-widget-d {
  width: 17%;
}
#vz-sub-footer aside.vz-sub-footer-widget-d h5 {
  margin: 0 0 3px 0;
}

@media all and (max-width: 1280px) and (min-width: 0px) {
  #vz-sub-footer aside.vz-sub-footer-widget-a {
    width: 24%;
  }
  #vz-sub-footer aside.vz-sub-footer-widget-a img {
    display: block;
    width: 200px;
    height: auto;
  }
  #vz-sub-footer aside.vz-sub-footer-widget-a .kcc-logo img {
    width: 80px;
    height: auto;
  }
  #vz-sub-footer aside.vz-sub-footer-widget-b {
    width: 28%;
  }
  #vz-sub-footer aside.vz-sub-footer-widget-c {
    width: 28%;
  }
  #vz-sub-footer aside.vz-sub-footer-widget-d {
    width: 20%;
  }
}
@media all and (max-width: 1023px) and (min-width: 0px) {
  #vz-sub-footer {
    padding: 64px 0 0 0;
    background-size: 300px auto;
  }
  #vz-sub-footer aside {
    width: auto !important;
    float: none !important;
    padding: 0 0 32px 0 !important;
  }
}
#vz-footer {
  background: #1F1F25;
  padding: 22px 0 16px 0;
}
#vz-footer p {
  font-size: 16px;
  line-height: 22px;
  margin: 0 0 10px 0;
  color: #FFF;
}
#vz-footer p a {
  color: #FFF;
  text-decoration: underline;
}
#vz-footer p a:hover, #vz-footer p a:active, #vz-footer p a:focus {
  opacity: 0.8;
}
#vz-footer p.vz-links a {
  margin: 0 30px 0 0;
}

@media all and (min-width: 1024px) {
  #vz-footer p {
    line-height: 26px;
    margin: 0px;
  }
  #vz-footer p.vz-credit {
    width: 200px;
    text-align: center;
    position: absolute;
    top: 0px;
    left: 50%;
    margin: 0 0 0 -100px;
  }
  #vz-footer p.vz-copyright {
    float: left;
  }
  #vz-footer p.vz-links {
    float: right;
  }
  #vz-footer p.vz-links a {
    margin: 0 0 0 30px;
  }
}

/*# sourceMappingURL=main.css.map */
