.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

.row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}

.no-gutters {
  margin-right: 0;
  margin-left: 0;
}

.no-gutters > .col,
.no-gutters > [class*=col-] {
  padding-right: 0;
  padding-left: 0;
}

.col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-2-4, .col-lg-3, .col-lg-4, .col-lg-4-8, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-7-2, .col-lg-8, .col-lg-9, .col-lg-9-6, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-2-4, .col-md-3, .col-md-4, .col-md-4-8, .col-md-5, .col-md-6, .col-md-7, .col-md-7-2, .col-md-8, .col-md-9, .col-md-9-6, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-2-4, .col-sm-3, .col-sm-4, .col-sm-4-8, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-7-2, .col-sm-8, .col-sm-9, .col-sm-9-6, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-2-4, .col-xl-3, .col-xl-4, .col-xl-4-8, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-7-2, .col-xl-8, .col-xl-9, .col-xl-9-6, .col-xl-auto, .col-xs-2-4, .col-xs-4-8, .col-xs-7-2, .col-xs-9-6 {
  position: relative;
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
}
.pb-row::before, .pb-row::after {
  content:  unset;
}
.row .col {
  -ms-flex-preferred-size: 0;
  flex-basis: 0;
  -ms-flex-positive: 1;
  flex-grow: 1;
  max-width: 100%;
}

.col-auto {
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}

.col-1 {
  -ms-flex: 0 0 8.333333%;
  flex: 0 0 8.333333%;
  max-width: 8.333333%;
}

.col-2 {
  -ms-flex: 0 0 16.666667%;
  flex: 0 0 16.666667%;
  max-width: 16.666667%;
}

.col-3 {
  -ms-flex: 0 0 25%;
  flex: 0 0 25%;
  max-width: 25%;
}

.col-4 {
  -ms-flex: 0 0 33.333333%;
  flex: 0 0 33.333333%;
  max-width: 33.333333%;
}

.col-5 {
  -ms-flex: 0 0 41.666667%;
  flex: 0 0 41.666667%;
  max-width: 41.666667%;
}

.col-6 {
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%;
}

.col-7 {
  -ms-flex: 0 0 58.333333%;
  flex: 0 0 58.333333%;
  max-width: 58.333333%;
}

.col-8 {
  -ms-flex: 0 0 66.666667%;
  flex: 0 0 66.666667%;
  max-width: 66.666667%;
}

.col-9 {
  -ms-flex: 0 0 75%;
  flex: 0 0 75%;
  max-width: 75%;
}

.col-10 {
  -ms-flex: 0 0 83.333333%;
  flex: 0 0 83.333333%;
  max-width: 83.333333%;
}

.col-11 {
  -ms-flex: 0 0 91.666667%;
  flex: 0 0 91.666667%;
  max-width: 91.666667%;
}

.col-12 {
  -ms-flex: 0 0 100%;
  flex: 0 0 100%;
  max-width: 100%;
}

.col-2-4 {
  -ms-flex: 0 0 20%;
  flex: 0 0 20%;
  max-width: 20%;
}

.col-4-8 {
  -ms-flex: 0 0 40%;
  flex: 0 0 40%;
  max-width: 40%;
}

.col-7-2 {
  -ms-flex: 0 0 60%;
  flex: 0 0 60%;
  max-width: 60%;
}

.col-9-6 {
  -ms-flex: 0 0 80%;
  flex: 0 0 80%;
  max-width: 80%;
}

.ml-auto {
  margin-left: auto !important;
}

.mr-auto {
  margin-right: auto !important;
}

img {
  display: block;
  width: 100%;
}

body {
  background-color: #C9003A;
}

.frame {
  max-width: 1400px;
  margin: 0 auto;
}

.frame .frame {
  width: 92%;
}

.header {
  padding: 40px 0;
  background-color: #FFF;
}

.header .row {
  align-items: center;
}

.header .logo {
  height: 40px;
}

.header .cta-wrapper a {
  font-size: 24px;
}


/*---------- CUSTOM OVERRIDES -----------*/

/*---------- VARIABLES -----------*/
:root {
  --frame-width: 1400px;

  --colour-primary: #00A69C;
  --colour-secondary: #5FC4BB;
  --colour-alternate: #285E5A;
  --colour-white: #ECECEC;
  --colour-black: #3A3F3D;

  --font-main: "Proxima-Nova";
}
h1, .h1 {
  font-family: var(--font-main);
  font-style: normal;
  font-weight: 800;
  font-size: 30px;
  line-height: 44px;
  color: var(--colour-primary);
}
p, .p, a, .a {
  font-family: var(--font-main);
  font-style: normal;
  font-weight: 500;
  font-size: 22px;
  line-height: 26.73px;
  color: var(--colour-alternate-1);
}
li, .li {
  font-family: var(--font-main);
  font-style: normal;
  font-weight: 400;
  font-size: 18px;
  line-height: 21.87px;
  color: var(--colour-alternate-1);
}
.row {
  margin: unset;
  padding: unset !important;
}
.post-builder .col-sm-12 {
  padding: unset;
}
.post-builder .pb-row {
  display: flex;
  flex-wrap: wrap;
  row-gap: 40px
}
/*---------------- CONTENT ----------------*/
.header .logo {
  height: 80px;
}
.header .coltable {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header .col {
  padding: unset;
}
.header .col.slogan {
  display: flex;
  width: unset;
  justify-content: flex-end;
  column-gap: 20px;
}
.header .email, .header .phone {
  background: #FFFFFF;
  box-shadow: 0px 0px 15px rgba(52, 68, 67, 0.12);
  border-radius: 56px;
  padding: 16px 30px;
}

.header .col.slogan a {
  flex 0 0 50%;
  display: flex;
  column-gap: 10px;
  font-weight: 500;
  font-size: 18px;
  line-height: 18px;
  color: var(--colour-alternate);
}
.header .email:hover, .header .phone:hover {
  text-decoration: none;
  color: white !important;
  background: var(--colour-primary);
}
.banner {
  background: white;
}
.banner .pb-column {
  display: flex;
  align-items: center;
  flex-direction: column;
  width: unset;
  flex: 1 1;
  padding: unset;
  row-gap: 20px;
}
.banner .pb-column:first-of-type {
  margin-left: calc((100vw - var(--frame-width)) / 2);
  padding: 80px 40px 80px 0px;
  max-width: fit-content;
}
.banner .pb-column:last-of-type {
  flex: 0 0 50%;
}
.banner .pb-block-type-image {
  position: relative;
  overflow: hidden;
  z-index: 1;
  height: 100%;
  width: 100%;
  min-height: 400px;
}
.banner .pb-block-type-image img {
  /* Background Img Content */
  object-fit: cover;
  font-family: "object-fit: cover";
  left: 50%;
  vertical-align: middle;
  max-height: 101%;
  max-width: none;
  min-height: 101%;
  min-width: 101%;
  position: absolute;
  top: 50%;
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  width: 101%;
  z-index: -1;
}
.banner ul {
  padding-top: 20px;
  display: flex;
  flex-direction: column;
  row-gap: 20px;
}
.banner li {
  display: flex;
  column-gap: 20px;
}
.banner li::before {
  content:'\f054';
  font-family: "Font Awesome 5 Pro";
  font-size: 28px;
  font-weight: 900;
  color: var(--colour-secondary);
}
.banner li:last-of-type::before {
  content: '\f3c5';
}
.services {
  background: var(--colour-white);
  padding: 80px 0px !important;
}
.services .pb-row::before, .services .pb-row::after {
  content: unset;
}
.services .pb-row {
  column-gap: 40px;
}
.services .col-sm-2 {
  width: unset;
  flex: 1 1 10%;
  background: white;
  padding: unset;
}

.services .col-sm-2 p {
  font-family: var(--font-main);
  font-style: normal;
  font-weight: 400;
  font-size: 16px;
  line-height: 19px;
  color: var(--colour-alternate);
  margin: unset;
}
.services .col-sm-2 em {
  font-weight: 400;
  font-size: 22px;
  line-height: 22px;
  color: var(--colour-primary);
}
.services .pb-row:last-of-type .pb-block-content {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  padding: 10px;
  padding-bottom: 25px;
}
.copyright {
  background:var(--colour-black);
  border-bottom: unset;
}

.copyright * {
  font-style: normal;
  font-weight: 500;
  font-size: 12px;
  line-height: 12px;
  text-align: center;
  color: #FFFFFF;
}
/*---------------- RESPONSIVE ----------------*/
@media screen and (max-width: 1500px){
  .frame {
      width: unset;
  }
}
@media screen and (max-width:1400px){
  .frame {
    max-width: unset;
    margin: unset;
    padding: 0px 15px !important;
  }
  .row {
    padding: unset;
  }
  .banner .pb-column:first-of-type {
    margin-left: 15px;
  }
}
@media screen and (max-width:800px){
  .header .coltable {
    flex-direction: column;
    row-gap: 20px;
  }
  .header .col.slogan {
    justify-content:center;
    flex-wrap: wrap;
    row-gap: 20px;
  }
  .banner .pb-column {
    flex: 0 0 100% !important;
    width: unset;
    max-width: unset;
  }
  .banner .pb-column:first-of-type {
    padding: unset;
    margin: 0px 15px;
  }
  .services .col-sm-2 {
    flex: 1 1 40%;
    width: unset;
  }
}
@media screen and (max-width:500px){
  .banner .pb-block-type-image {
    min-height: 250px;
  }
  .services .col-sm-2 {
    flex: 1 1 100%;
    width: unset;
  }
  .services .pb-row {
    row-gap: 25px;
  }
  .services .pb-row:last-of-type .pb-block-content {
    flex-direction: row;
    column-gap: 10px;
    align-items: center;
    padding: 0px 20px;
  }

}
