.hide {
  position: absolute !important;
  top: -9999px !important;
  left: -9999px !important; }

* {
  box-sizing: border-box; }

body {
  position: relative;
  margin: 0;
  padding: 0;
  color: #444444;
  font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif;
  font-size: 18px;
  font-weight: 300; }

p {
  margin-top: 0; }

a {
  color: #32026D; }
  a:hover {
    color: #D22A29; }

hr {
  width: 200px;
  height: 1px;
  background-color: #ededed;
  border: 0;
  margin: 0 auto; }

.full-img {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 200px; }
  .full-img img {
    display: block;
    max-width: 100%; }
  .full-img.scaffold {
    background-image: url(/assets/img/scaffold.jpg); }
  .full-img.building {
    background-image: url(/assets/img/building.jpg); }
  @media screen and (min-width: 500px) {
    .full-img {
      height: 300px; } }
  @media screen and (min-width: 600px) {
    .full-img {
      height: 350px; } }

.section {
  display: block;
  position: relative;
  width: 100%; }
  .section.section--offwhite {
    background: #f7f7f7;
    color: #444444; }
  .section .section_wrap {
    padding: 35px;
    margin: 0 auto;
    max-width: 800px; }
    @media screen and (min-width: 600px) {
      .section .section_wrap {
        padding: 45px 35px; } }
  .section .section_label {
    color: #999999;
    font-size: 60%;
    padding-bottom: 15px;
    text-transform: uppercase;
    letter-spacing: .2em; }
  .section .section_row {
    margin-right: -35px;
    margin-bottom: -30px;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between; }
    .section .section_row:after {
      content: "";
      display: table;
      clear: both; }
    @media screen and (min-width: 600px) {
      .section .section_row {
        margin-bottom: -45px; } }
  .section .section_column {
    float: left;
    width: 100%;
    padding-right: 35px;
    padding-bottom: 30px; }
    .section .section_column > *:first-child {
      margin-top: 0; }
      .section .section_column > *:first-child > *:first-child {
        margin-top: 0; }
    .section .section_column > *:last-child {
      margin-bottom: 0; }
      .section .section_column > *:last-child > *:last-child {
        margin-bottom: 0; }
    .section .section_column p {
      max-width: 350px; }
    @media screen and (min-width: 600px) {
      .section .section_column {
        padding-bottom: 45px; }
        .section .section_column.col-half {
          width: 50%; }
        .section .section_column.col-third {
          width: 33.3333333333%; }
        .section .section_column.col-quater {
          width: 25%; } }

.section--logo .section_wrap {
  padding: 20px 35px; }
.section--logo .site-logo {
  display: block;
  max-width: 350px;
  width: 100%;
  margin: 0 auto; }
  @media screen and (min-width: 600px) {
    .section--logo .site-logo {
      margin: 0; } }
.section--logo .contact {
  margin: 0 auto;
  width: 100%;
  padding-left: 35px;
  padding-bottom: 0;
  text-align: center; }
  @media screen and (min-width: 600px) {
    .section--logo .contact {
      margin: 0;
      float: right;
      text-align: left;
      width: auto;
      padding-left: 0;
      padding-right: 0;
      margin-top: 7px !important; } }

.site-contact {
  margin-right: -30px !important;
  margin-bottom: -30px !important; }
  .site-contact:after {
    content: "";
    display: table;
    clear: both; }

.contact {
  display: block;
  float: left;
  padding: 0 30px 30px 0; }
  .contact .label {
    display: block;
    line-height: 1em;
    color: #999999;
    font-size: 70%;
    margin-bottom: 3px;
    font-weight: 400; }
  .contact .info {
    line-height: 1.25em;
    color: #32026D;
    font-weight: 400; }

.section--about .section_wrap {
  margin-top: -45px;
  background-color: #ffffff; }

.key {
  font-size: 25px;
  font-weight: 500; }

.service-list {
  list-style: none;
  margin: 0;
  padding: 0; }
  .service-list li {
    padding-left: 30px;
    font-weight: 600;
    margin-bottom: 10px;
    position: relative; }
    .service-list li:last-child {
      margin-bottom: 0; }
    .service-list li:before {
      content: '';
      display: block;
      position: absolute;
      left: 0;
      top: 0px;
      height: 20px;
      width: 20px;
      background-repeat: no-repeat;
      background-position: center center;
      background-size: contain;
      background-image: url(/assets/img/check.svg); }

.section .accred-list {
  justify-content: flex-start; }
  .section .accred-list li.section_column {
    width: 170px;
    display: flex;
    align-items: center; }
    .section .accred-list li.section_column img {
      max-width: 100px; }

.accred-list {
  list-style: none;
  margin: 0;
  padding: 0; }
