/*
Theme Name: CBT
Theme URI: https://c-b-t.co.uk/
Description: Custom theme for Connect - Managed Print Services, Office Printers, Copiers & Print Support
Version: 1.0.1.2
Author: Connect
Author URI: https://c-b-t.co.uk/
Text Domain: cbt
Update URI: false
*/

/* Reset Styles */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, font, img, ins, kbd, q, s, samp, small, strike, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline; }

:focus {
  outline: 0; }

ol, ul {
  list-style: none; }

table {
  border-collapse: separate;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal; }

blockquote:before, blockquote:after, q:before, q:after {
  content: ""; }

blockquote, q {
  quotes: "" ""; }

div, nav, header, footer, aside {
  display: block; }

/* Variables */
/* General Structure */
body {
  background: #FFFFFF;
  text-align: center;
  font-family: 'Inter', Helvetica, Arial, sans-serif;
  font-size: 14px;
  color: #5b5b5b;
  padding: 40px 0 0 0; padding: 127px 0 0 0; }

h1, h2, h3, h4, h5 {
  font-family: 'Manrope', sans-serif;
}
h1 { font-weight: 600; }
h2 { font-weight: 600; }
p  { font-weight: 400; }

input,
button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-border-radius: 0px;
  -moz-border-radius: 0px;
  border-radius: 0px; }

.container {
  display: block;
  margin: auto;
  text-align: left;
  width: 1110px;
  position: relative;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box; }

a {
  color: #5b5b5b;
  text-decoration: none; }

a:hover {
  color: #333; }

.clearfix {
  display: block;
  clear: both; }

/* Top Bar */
#top-bar {
  background: #2e3a48;
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 300; }
  #top-bar .top-bar-left {
    float: left; }
    #top-bar .top-bar-left a {
      line-height: 40px;
      display: block;
      font-size: 13px;
      color: #FFF;
      padding: 0 16px 0 40px;
      border-left: 1px solid rgba(255, 255, 255, 0.2);
      border-right: 1px solid rgba(255, 255, 255, 0.2);
      background: url(./images/icon-cart.svg) no-repeat 16px center; }
    #top-bar .top-bar-left:hover {
      background-color: #E5007D; }
  #top-bar .top-bar-right {
    float: right; }
    #top-bar .top-bar-right span,
    #top-bar .top-bar-right a {
      color: #FFF;
      line-height: 40px;
      display: block;
      float: left; }
    #top-bar .top-bar-right .top-bar-phone {
      padding: 0 32px 0 24px;
      background: url(./images/call.svg) no-repeat left center; 
      background-size: 16px auto;
    }
    #top-bar .top-bar-right .top-bar-email {
      padding: 0 32px 0 24px;
      background: url(./images/email.svg) no-repeat left center;
      background-size: 16px auto;
      border-right: 1px solid rgba(255, 255, 255, 0.2);
      margin: 0 16px 0 0; }
      #top-bar .top-bar-right .top-bar-email:hover {
        color: #E5007D;
        background-image: url(./images/email-hover.svg); }
    #top-bar .top-bar-right .top-bar-twitter {
      background: url(./images/icon-twitter.svg) no-repeat center center;
      text-indent: -9999px;
      width: 32px; }
      #top-bar .top-bar-right .top-bar-twitter:hover {
        color: #E5007D;
        background-image: url(./images/icon-twitter-hover.svg); }
    #top-bar .top-bar-right .top-bar-facebook {
      background: url(./images/icon-facebook.svg) no-repeat center center;
      text-indent: -9999px;
      width: 32px; }
      #top-bar .top-bar-right .top-bar-facebook:hover {
        color: #E5007D;
        background-image: url(./images/icon-facebook-hover.svg); }
    #top-bar .top-bar-right .top-bar-googleplus {
      background: url(./images/icon-googleplus.svg) no-repeat center center;
      text-indent: -9999px;
      width: 32px;
      margin: 0 -9px 0 0; }
      #top-bar .top-bar-right .top-bar-googleplus:hover {
        color: #E5007D;
        background-image: url(./images/icon-googleplus-hover.svg); }

/* Site Header */
#site-header .btn-quote {
  background-color: #009EE3;
}
#site-header {
  background: #FFF;
  height: 96px;
  position: relative;
  width: 100%;
  position: fixed;
  top: 40px;
  z-index: 10;
  border-bottom: 1px solid #e5e5e5; }
  #site-header .mobile-call {
    display: none; }
  #site-header .mobile-logo {
    display: none; }
  #site-header .logo {
    display: block;
    float: left;
    margin: 16px 0 0 0;
    position: relative;
    width: 160px;
    height: 97px;
    background: url(./images/logo-full.svg); }
    /*#site-header .logo img {
      position: absolute;
      top: 34px;
      left: 6px;
      z-index: 1; }
    #site-header .logo span.strand-yellow {
      position: absolute;
      top: 11px;
      left: 3px;
      background: url(./images/logo-yellow.svg);
      width: 30px;
      height: 32px;
      transition: all .5s ease-in-out;
      -moz-transition: all .5s ease-in-out;
      -webkit-transition: all .5s ease-in-out; }
    #site-header .logo:hover span.strand-yellow {
      -moz-transform: rotate(10deg);
      transform: rotate(10deg);
      left: 5px; }
    #site-header .logo span.strand-pink {
      position: absolute;
      top: 2px;
      left: 42px;
      background: url(./images/logo-pink.svg);
      width: 38px;
      height: 43px;
      transition: all .5s ease-in-out;
      -moz-transition: all .5s ease-in-out;
      -webkit-transition: all .5s ease-in-out; }
    #site-header .logo:hover span.strand-pink {
      -moz-transform: rotate(-10deg);
      transform: rotate(-10deg);
      top: 0px; }
    #site-header .logo span.strand-blue {
      position: absolute;
      bottom: 0px;
      left: 38px;
      background: url(./images/logo-blue.svg);
      width: 17px;
      height: 36px;
      transition: all .5s ease-in-out;
      -moz-transition: all .5s ease-in-out;
      -webkit-transition: all .5s ease-in-out; }
    #site-header .logo:hover span.strand-blue {
      -moz-transform: rotate(10deg);
      transform: rotate(10deg);
      left: 35px; }
    #site-header .logo span.strand-black {
      position: absolute;
      bottom: 12px;
      left: 0px;
      background: url(./images/logo-black.svg);
      width: 35px;
      height: 25px;
      transition: all .5s ease-in-out;
      -moz-transition: all .5s ease-in-out;
      -webkit-transition: all .5s ease-in-out; }
    #site-header .logo:hover span.strand-black {
      -moz-transform: rotate(10deg);
      transform: rotate(10deg);
      bottom: 15px; }*/
  @media all and (min-width: 1141px) {
    #site-header .header-cta {
      float: right;
      margin: 25px 0 0 32px;
    
    }

    #site-header nav {
      padding: 30px 0 0 0;
      float: right; }
      #site-header nav li {
        padding: 0 0 0 32px;
        float: left;
        display: block;
        position: relative; }
        #site-header nav li.has-border {
          border-right: 1px solid #e5e5e5;
          padding: 0 32px; }
        #site-header nav li a {
          line-height: 40px;
          font-size: 16px;
          display: block;
          float: left;
          color: #5b5b5b;
          position: relative; }
          #site-header nav li a:hover:after {
            position: absolute;
            bottom: 0px;
            left: 0px;
            width: 100%;
            height: 2px;
            background: #E5007D;
            content: '';
            display: block; }
        #site-header nav li.current-menu-item a:after {
          position: absolute;
          bottom: 0px;
          left: 0px;
          width: 100%;
          height: 2px;
          background: #E5007D;
          content: '';
          display: block; }
       /* #site-header nav li.current-menu-item li a:hover:after { display: none!important; }*/
        #site-header nav li.has-dropdown:before {
          position: absolute;
          top: 16px;
          right: 32px;
          width: 10px;
          height: 8px;
          background: url(./images/dropdown-arrow.svg) no-repeat;
          content: '';
          display: block; }
        #site-header nav li.has-dropdown a {
          padding: 0 18px 0 0;
          font-size: 16px; }
        #site-header nav li ul,
        #site-header nav li.has-dropdown ul {
          position: absolute;
          top: 40px;
          right: -1px;
          width: 350px;
          background: #FFF;
          display: none;
          border: 1px solid #e5e5e5;
          border-bottom: none; }
          #site-header nav li ul li,
          #site-header nav li.has-dropdown ul li {
            float: none;
            display: block;
            padding: 0px;
            border-bottom: 1px solid #e5e5e5; }
            #site-header nav li ul li a,
            #site-header nav li.has-dropdown ul li a {
              display: block;
              float: none;
              padding: 10px 32px;
              text-align: right;
              line-height: 20px; }
              #site-header nav li ul li a:hover,
              #site-header nav li.has-dropdown ul li a:hover {
                background: #E5007D;
                color: #FFF; } }
              #site-header nav li.has-dropdown ul li a:after { display: none!important; }

/* Button */
.btn {
  display: inline-block;
  padding: 12px 32px;
  line-height: 24px;
  font-size: 14px;
  color: #FFF;
  background: url(./images/btn-hover.png) no-repeat right top #E5007D;
  background-size: auto 100%;
  transition: background .5s ease-in-out;
  -moz-transition: background .5s ease-in-out;
  -webkit-transition: background .5s ease-in-out;
  position: relative;
  font-weight: 500;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  cursor: pointer;
  border: none; }
  .btn:hover, .btn.btn-outline:hover {
    background-position: left top;
    color: #FFF; }
  .btn.btn-outline {
    background-color: transparent;
    border: 1px solid #FFF;
    color: #FFF; }

/* Home Hero */
.home-hero {
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 560px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.home-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: 1;
  pointer-events: none;
}

.home-hero .container {
  position: relative;
  z-index: 2;
}

.home-hero-content {
  max-width: 560px;
  color: #FFFFFF;
  padding: 80px 0;
}

.home-hero h1 {
  font-size: 40px;
  line-height: 50px;
  margin: 0 0 24px 0;
  color: #FFFFFF;
  font-weight: bold;
}

.home-hero p {
  font-size: 18px;
}

.home-hero-text {
  margin-bottom: 30px;
  font-size: 18px;
  line-height: 1.6;
}

.home-hero-text p {
  margin: 0;
  color: #FFFFFF;
}

.home-hero-buttons {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
}

.home-hero-buttons .btn {
  min-width: 180px;
  text-align: center;
}

.home-hero-buttons .btn-secondary {
  background: transparent;
  border: 2px solid #fff;
  color: #fff;
}

.home-hero-buttons .btn-secondary:hover,
.home-hero-buttons .btn-secondary:focus {
  background: #fff;
  color: #000;
}

/* Tablet */
@media (max-width: 991px) {
  .home-hero {
    min-height: 520px;
  }

  .home-hero-content {
    max-width: 100%;
    padding: 70px 0;
  }

  .home-hero-text {
    font-size: 17px;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .home-hero {
    min-height: auto;
    padding: 110px 0 60px;
    align-items: center;
    background-position: center;
  }

  .home-hero-content {
    padding: 0;
    max-width: 100%;
  }

  .home-hero h1 {
    font-size: 30px;
    line-height: 38px;
    margin-bottom: 20px;
  }

  .home-hero-text,
  .home-hero-text p {
    font-size: 16px;
    line-height: 1.6;
  }

  .home-hero-text {
    margin-bottom: 25px;
  }

  #banner .banner-split {
    display: block;
    padding-left: 0;
    padding-right: 0;
  }

  #banner .banner-content-col,
  #banner .banner-media-col {
    width: 100%;
    padding: 0;
  }

  #banner .banner-content-col {
    display: block;
  }

  #banner .banner-content-inner {
    padding: 48px 32px;
  }

  #banner .banner-content-copy {
    max-width: none;
  }

  #banner .banner-content-copy h2 {
    font-size: 34px;
    line-height: 42px;
  }

  #banner .banner-media-col {
    height: 320px;
  }

  #banner .video-text {
    height: 320px;
  }

  #banner .next-section {
    display: none;
  }
}

/* Banner */
#banner {
  background: #f5f5f5;
  position: relative;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
}

#banner .banner-split {
  display: flex;
  align-items: stretch;
}

#banner .banner-content-col,
#banner .banner-media-col {
  width: 50%;
  position: relative;
}

#banner .banner-content-col {
  display: flex;
  align-items: center;
  padding-right: 32px;
  box-sizing: border-box;
}

#banner .banner-media-col {
  padding-left: 32px;
  box-sizing: border-box;
}

#banner .banner-content-inner {
  width: 100%;
  padding: 96px 0;
}

#banner .banner-content-copy {
  max-width: 460px;
}

#banner .banner-content-copy h2 {
  font-size: 44px;
  line-height: 56px;
  margin: 0 0 24px 0;
  color: #000;
}

#banner .banner-content-text p {
  line-height: 21px;
  margin: 0 0 24px 0;
}

#banner .banner-content-buttons {
  display: flex;
  gap: 15px;
  flex-wrap: wrap;
  padding-top: 16px;
}

#banner .banner-content-buttons .btn-secondary {
  background: transparent;
  border: 1px solid #E5007D;
  color: #E5007D;
}

#banner .banner-content-buttons .btn-secondary:hover {
  color: #FFF;
}

#banner .video-text {
  position: relative;
  height: 100%;
}

#banner .video-text .video-text-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#banner .video-text .video-text-video img,
#banner .video-text .video-text-video video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

#banner .video-text .video-text-overlay {
  background: none no-repeat center center;
  background-size: 210% auto;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}
#banner .video-text .video-text-video {
    z-index: 1;
}

#banner .next-section {
  display: block;
  width: 24px;
  height: 24px;
  background: url(./images/next-section.svg) no-repeat center center;
  position: absolute;
  bottom: 32px;
  left: 50%;
  margin: 0 0 0 -16px;
  z-index: 5;
}

@media all and (max-width: 767px) and (min-width: 0px) {
  #banner .banner-split {
    display: block;
    padding-left: 0;
    padding-right: 0;
  }

  #banner .banner-content-col,
  #banner .banner-media-col {
    width: 100%;
    padding: 0;
  }

  #banner .banner-content-col {
    display: block;
  }

  #banner .banner-content-inner {
    padding: 48px 32px;
  }

  #banner .banner-content-copy {
    max-width: none;
  }

  #banner .banner-content-copy h2 {
    font-size: 34px;
    line-height: 42px;
  }

  #banner .banner-media-col {
    height: 320px;
  }

  #banner .video-text {
    height: 320px;
  }

  #banner .next-section {
    display: none;
  }

  #banner .banner-content-col,
  #banner .banner-media-col,
  #banner .banner-content-inner,
  #banner .banner-content-copy {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
  }

  #banner .banner-content-inner {
    padding: 48px 32px;
    overflow: hidden;
  }

  #banner .banner-content-text p,
  #banner .banner-content-text {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  #banner .video-text,
  #banner .video-text-video,
  #banner .video-text-video video,
  #banner .video-text-video img {
    width: 100%;
    max-width: 100%;
  }
}

/* Section Header */
.section-header {
  background: #2e3a48;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); }
  .section-header h2 {
    font-size: 24px;
    line-height: 32px;
    padding: 16px 0;
    font-style: italic;
    color: #FFF;
    text-align: center; }

/* Services */
.service-section {
  background: none no-repeat right center transparent;
  background-size: auto 120%;
  position: relative;
  z-index: 5;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); }
  .service-section .service-text {
    float: left;
    width: 50%;
    padding: 64px 0; }
    .service-section .service-text .service-text-inner h2 {
      font-size: 44px;
      line-height: 56px;
      margin: 0 0 64px 0;
      margin: 0 0 52px 0;
      color: #000; }
    .service-section .service-text .service-text-inner p {
      line-height: 21px;
      margin: 0 0 24px 0;
      }
    .service-section .service-text .service-text-inner .service-button {
      padding: 40px 0 0 0; }
  .service-section .service-icon {
    position: absolute;
    top: 50%;
    right: 0px;
    float: right;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%); }
  .service-section.service-section.resized .service-text {
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    position: relative;
    top: 50%;
    left: 0px; }
  .service-section.service-section-alt {
    /*background-color: #FFF;*/
    background-position: left center; }
    .service-section.service-section-alt .service-text {
      float: right; }
    .service-section.service-section-alt .service-icon {
      right: auto;
      left: 0px; 
    }
    .service-section .service-icon img {
      width: auto;
      height: 256px;
    }

/* History */
#history {
  background: #ebebeb; }
  #history .container {
    padding: 192px 0 192px 0; }
  #history .history-line {
    position: absolute;
    top: 0px;
    left: 50%;
    width: 2px;
    height: 100%;
    background: #95989f; }
  #history .history-item {
    width: 50%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    padding: 0 64px 0 0;
    text-align: right;
    position: relative; }
    #history .history-item h3 {
      font-size: 44px;
      line-height: 56px;
      margin: 0 0 24px 0;
      color: #000; }
      #history .history-item h3 sup {
        position: relative;
        top: -0.3em;
        vertical-align: top;
        padding-left: 5px;
        font-size: 50%; }
    #history .history-item p {
      line-height: 21px;
      max-width: 350px;
      float: right; }
  #history .history-item-right {
    padding: 0 0 0 64px;
    text-align: left;
    float: right; }
    #history .history-item-right p {
      float: none; }
  #history .history-item-style-a {
    margin-top: -32px; }
    #history .history-item-style-a .history-item-image img {
      border: 1px solid #E5007D;
      border-radius: 100%;
      -moz-border-radius: 100%;
      -webkit-border-radius: 100%;
      margin: 0 0 32px 0; }
  #history .history-item-style-b {
    margin-top: -64px; }
    #history .history-item-style-b .history-item-image {
      float: right;
      width: 38%; }
      #history .history-item-style-b .history-item-image img {
        display: block;
        width: 100%;
        height: auto; }
    #history .history-item-style-b .history-item-text {
      background: #FFF;
      float: left;
      width: 62%;
      padding: 30px;
      box-sizing: border-box;
      -moz-box-sizing: border-box;
      -webkit-box-sizing: border-box;
      text-align: left; }
      #history .history-item-style-b .history-item-text h3 {
        font-size: 32px;
        line-height: 40px; }
    #history .history-item-style-b.history-item-right .history-item-image {
      float: left; }
    #history .history-item-style-b.history-item-right .history-item-text {
      float: right; }
  #history .history-item-date {
    position: absolute;
    top: 0px;
    right: 0px; }
    #history .history-item-date .dot {
      display: block;
      width: 12px;
      height: 12px;
      border-radius: 100%;
      -moz-border-radius: 100%;
      -webkit-border-radius: 100%;
      border: 2px solid #E5007D;
      margin: -8px -8px 0 0;
      background: #FFF;
      z-index: 20;
      position: relative;
      cursor: pointer; }
    #history .history-item-date .date {
      opacity: 0;
      display: block;
      position: absolute;
      top: -16px;
      left: 8px;
      padding: 0 32px;
      line-height: 32px;
      color: #FFF;
      background: #E5007D;
      min-width: 120px;
      text-align: center;
      transition: opacity .5s ease-in-out;
      -moz-transition: opacity .5s ease-in-out;
      -webkit-transition: opacity .5s ease-in-out; }
  #history .history-item:hover .history-item-date .date {
    opacity: 1; }
  #history .history-item-right .history-item-date {
    right: auto;
    left: 0px; }
    #history .history-item-right .history-item-date .dot {
      margin-left: -8px;
      margin-right: 0px; }
    #history .history-item-right .history-item-date .date {
      left: auto;
      right: 6px; }
  #history .history-item-style-a .history-item-date {
    top: 32px; }
  #history .history-item-style-b .history-item-date {
    top: 80px; }
  #history .history-item-style-c .history-item-date {
    top: 128px; }
  #history .todays-date {
    position: absolute;
    bottom: 0px;
    left: 50%;
    width: 350px;
    margin: 0 0 0 -175px;
    text-align: center;
    background: #E5007D;
    color: #FFF;
    line-height: 32px;
    display: block; }

/* About */
#about .container {
  padding: 64px 0 192px 0; }

#about .about-quote {
  float: left;
  width: 445px; }
  #about .about-quote blockquote {
    position: relative; }
    #about .about-quote blockquote p {
      font-size: 32px;
      line-height: 40px;
      position: relative;
      margin: 0 0 16px 0;
      color: #000; }
      #about .about-quote blockquote p span {
        position: absolute;
        top: 0px;
        left: -16px;
        display: block; }
    #about .about-quote blockquote cite {
      display: block;
      padding: 21px 0 0 0;
      line-height: 21px;
      color: #000;
      position: relative; }
      #about .about-quote blockquote cite:before {
        width: 6px;
        height: 1px;
        display: block;
        position: absolute;
        top: 0px;
        left: 0px;
        background: #000;
        content: ''; }
      #about .about-quote blockquote cite em {
        font-style: italic;
        color: #5c5c5c; }

#about .about-content {
  float: right;
  width: 350px; }
  #about .about-content h3 {
    font-size: 32px;
    line-height: 40px;
    color: #000;
    margin: 0 0 24px 0; }
  #about .about-content p {
    line-height: 21px;
    margin: 0 0 32px 0; }

/* Page Content */
#page-content {
  padding: 64px 0;
}
  #page-content h1,
  #page-content h2,
  #page-content h3 {
    font-size: 36px;
    line-height: 40px;
    margin: 0 0 24px 0;
  }
  #page-content p { line-height: 21px; margin: 0 0 24px 0; }

/* 404 */
#page-content.four-oh-four .container { text-align: center; }

/* Contact Banner */
#contact-banner {
  width: 100%;
  overflow: hidden;
  position: relative;
}

#contact-banner .contact-banner-map {
  position: relative;
  width: 100%;
  height: 450px;
  overflow: hidden;
}

#contact-banner .contact-banner-map iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120%;   /* slightly larger so edges crop */
  height: 120%;
  transform: translate(-50%, -50%);
  border: 0;
}

/* Responsive heights */
@media (max-width: 1024px) {
  #contact-banner .contact-banner-map {
    height: 380px;
  }
}

@media (max-width: 767px) {
  #contact-banner .contact-banner-map {
    height: 300px;
  }
}
/* Contact */
#contact {
  padding: 64px 0;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); }
  #contact .contact-form {
    float: left;
    width: 540px; }
    #contact .contact-form h6 {
      font-style: italic;
      font-size: 14px;
      line-height: 21px;
      margin: 0 0 12px 0; }
    #contact .contact-form .field-name,
    #contact .contact-form .field-phone {
      padding: 0 16px 0 0;
      width: 50%;
      float: left;
      box-sizing: border-box;
      -moz-box-sizing: border-box;
      -webkit-box-sizing: border-box; }
    #contact .contact-form .field-phone {
      padding: 0 0 0 16px; }
    #contact .contact-form input[type="text"],
    #contact .contact-form input[type="email"],
    #contact .contact-form textarea {
       font-family: 'Inter', Helvetica, Arial, sans-serif;
      line-height: 48px;
      color: #000;
      font-size: 22px;
      border: none;
      background: none transparent;
      width: 100%;
      border-bottom: 1px solid #e5e5e5; }
      #contact .contact-form input[type="text"]:focus,
      #contact .contact-form input[type="email"]:focus,
      #contact .contact-form textarea:focus {
        border-color: #000; }
    #contact .contact-form textarea {
      height: 144px;
      border: none;
      resize: none;
      background: url(./images/textarea.png) repeat left top scroll; }
      #contact .contact-form textarea:focus {
        background-image: url(./images/textarea-focused.png); }
    #contact .contact-form ::-webkit-input-placeholder {
      color: #000; }
    #contact .contact-form :-moz-placeholder {
      /* Firefox 18- */
      color: #000; }
    #contact .contact-form ::-moz-placeholder {
      /* Firefox 19+ */
      color: #000; }
    #contact .contact-form :-ms-input-placeholder {
      color: #000; }
    #contact .contact-form .field-submit {
      padding: 24px 0; }
    #contact .contact-form .required-fields {
      font-style: italic;
      color: #b9b9b9; }
    #contact .contact-form span.wpcf7-not-valid-tip {
      padding: 10px 0 0 0;
    }
    #contact .contact-form div.wpcf7-validation-errors {
      border: none;
      margin: 0px;
      padding: 16px 0 0 0;
      color: red;
    }
    #contact .contact-form div.wpcf7-mail-sent-ok {
      border: none;
      margin: 0px;
      padding: 16px 0 0 0;
    }
  #contact .contact-details {
    float: right;
    width: 350px;
    text-align: right; }
    #contact .contact-details ul li {
      display: block;
      padding: 0 0 0 95px;
      position: relative;
      margin: 0 0 24px 0; }
      #contact .contact-details ul li h5 {
        position: absolute;
        top: 16px;
        left: 0px;
        font-style: italic;
        text-align: left;
        line-height: 14px;
        font-size: 14px;
         font-family: 'Inter', Helvetica, Arial, sans-serif;}
      #contact .contact-details ul li p {
        font-size: 24px;
        line-height: 34px;
        color: #000;
        text-align: right; }
        #contact .contact-details ul li p a {
          color: #000; }

/* Newsletter */
#newsletter-signup {
  background: #edbc33;
  padding: 64px 0;
  position: relative;
  z-index: 4;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); }
  #newsletter-signup .container {
    text-align: center; }
  #newsletter-signup input[type="email"] {
    width: 730px;
    border: none;
    border-bottom: 1px solid #FFF;
    height: 64px;
    margin: 0 auto 32px auto;
    max-width: 100%;
    text-align: center;
    font-family: 'Inter', Helvetica, Arial, sans-serif;
    font-size: 44px;
    line-height: 44px;
    padding: 0 0 20px 0;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    background: none transparent;
    color: #FFF; }
  #newsletter-signup ::-webkit-input-placeholder {
    color: #FFF; }
  #newsletter-signup :-moz-placeholder {
    /* Firefox 18- */
    color: #FFF; }
  #newsletter-signup ::-moz-placeholder {
    /* Firefox 19+ */
    color: #FFF; }
  #newsletter-signup :-ms-input-placeholder {
    color: #FFF; }
  #newsletter-signup .newsletter-message {
    margin: 0 0 32px 0;
    font-size: 16px;
    line-height: 20px;
    color: #FFF;
    display: none; }
    #newsletter-signup .newsletter-message span {
      opacity: 1;
      position: relative;
      line-height: 20px;
      top: -20px; }
  #newsletter-signup div.wpcf7-mail-sent-ok,
  #newsletter-signup div.wpcf7-validation-errors {
    margin: 0;
    padding: 32px 0 0 0;
    font-size: 16px;
    line-height: 20px;
    border: none;
    color: #FFF;
  }
  #newsletter-signup span.wpcf7-not-valid-tip { margin: 0 0 32px 0; }

/* Clients Slider */
#clients-slider {
  background: #312b37;
  padding: 64px 0; }
  #clients-slider .client-logos {
    position: relative; }
    #clients-slider .client-logos:before {
      position: absolute;
      top: 0px;
      left: 0px;
      width: 3px;
      height: 100%;
      z-index: 10;
      content: '';
      display: block;
      background: #312b37; }
    #clients-slider .client-logos .slick-slide {
      height: 184px;
      padding: 0 64px;
      position: relative;
      text-align: center; }
      #clients-slider .client-logos .slick-slide:before {
        position: absolute;
        top: 0px;
        right: -1px;
        width: 1px;
        height: 100%;
        content: '';
        display: block;
        background: #4c4a4f; }
    #clients-slider .client-logos img {
      max-width: 100%;
      max-height: 104px;
      height: auto;
      position: relative;
      margin: auto;
      top: 50%;
      transform: translateY(-50%);
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      opacity: 0;
      margin-top: 30px;
      transition: all .5s ease-in-out;
      -moz-transition: all .5s ease-in-out;
      -webkit-transition: all .5s ease-in-out; }
    #clients-slider .client-logos .slick-active img,
    #clients-slider .client-logos .slick-current img {
      margin-top: 0px;
      opacity: 1; }
    #clients-slider .client-logos .slick-arrow {
      display: block;
      width: 24px;
      height: 24px;
      border: none;
      text-indent: -9999px;
      cursor: pointer;
      background: url(./images/slider-arrow-left.svg);
      position: absolute;
      top: 50%;
      left: -30px;
      margin-top: -12px; }
      #clients-slider .client-logos .slick-arrow.slick-next {
        background-image: url(./images/slider-arrow-right.svg);
        left: auto;
        right: -30px; }

/* Make Enquiry */
#make-enquiry {
  background: #009EE3;
  padding: 64px 0; }
  #make-enquiry .container {
    text-align: center; }
  #make-enquiry h3 {
    width: 730px;
    border: none;
    /*border-bottom: 1px solid #FFF;*/
    /*height: 64px;*/
    margin: 0 auto 16px auto;
    max-width: 100%;
    text-align: center;
     font-family: 'Inter', Helvetica, Arial, sans-serif;
    font-size: 44px;
    line-height: 44px;
    /*padding: 0 0 20px 0;*/
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    background: none transparent;
    color: #FFF; }

#make-an-enquiry {
  background: #FFF;
  text-align: center;
  max-width: 980px;
  height: 552px;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  margin: 40px auto;
  position: relative;
  border-radius: 8px;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); }
  #make-an-enquiry button.mfp-close {
    top: -40px;
    color: #FFF;
    border: 2px solid #FFF;
    border-radius: 100%;
    width: 24px;
    height: 24px;
    line-height: 21px;
    padding: 0px;
    font-size: 20px;
    opacity: 1; }
  #make-an-enquiry .enquiry-pane {
    display: none;
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    padding: 0 125px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; }
    #make-an-enquiry .enquiry-pane.active {
      display: block; }
    #make-an-enquiry .enquiry-pane .enquiry-pane-content {
      transform: translateY(-50%);
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      position: relative;
      top: 50%; }
      #make-an-enquiry .enquiry-pane .enquiry-pane-content .text-field {
        width: 100%;
        border: none;
        border-bottom: 1px solid #e5e5e5;
        height: 64px;
        margin: 0 auto 32px auto;
        max-width: 100%;
        text-align: center;
         font-family: 'Inter', Helvetica, Arial, sans-serif;
        font-size: 44px;
        line-height: 44px;
        padding: 0 0 20px 0;
        box-sizing: border-box;
        -moz-box-sizing: border-box;
        -webkit-box-sizing: border-box;
        background: none transparent;
        color: #000; }
      #make-an-enquiry .enquiry-pane .enquiry-pane-content textarea { resize: none; height: 140px!important; }
        #make-an-enquiry .enquiry-pane .enquiry-pane-content .text-field.error {
          border-color: #E5007D; }
      #make-an-enquiry .enquiry-pane .enquiry-pane-content h5 {
        font-size: 44px;
        line-height: 56px;
        margin: 0 0 48px 0; }
  #make-an-enquiry .enquiry-progress {
    position: absolute;
    bottom: 32px;
    left: 0px;
    width: 100%;
    z-index: 1;
    text-align: left;
    padding: 0 125px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; }
    #make-an-enquiry .enquiry-progress .enquiry-progress-inner {
      padding: 8px 0 8px 95px;
      position: relative; }
    #make-an-enquiry .enquiry-progress h6 {
      position: absolute;
      line-height: 24px;
      top: 0px;
      left: 0px;
      float: left;
      display: block; }
    #make-an-enquiry .enquiry-progress .progress-bar {
      display: block;
      height: 8px;
      border-radius: 8px;
      -moz-border-radius: 8px;
      -webkit-border-radius: 8px;
      background: #ebebeb;
      position: relative;
      overflow: hidden; }
      #make-an-enquiry .enquiry-progress .progress-bar span {
        width: 25%;
        position: absolute;
        top: 0px;
        left: 0px;
        height: 100%;
        background: #E5007D;
        border-radius: 8px;
        -moz-border-radius: 8px;
        -webkit-border-radius: 8px;
        display: block; }
  #make-an-enquiry .enquiry-progress-step-1 .progress-bar span {
    width: 25%; }
  #make-an-enquiry .enquiry-progress-step-2 .progress-bar span {
    width: 50%; }
  #make-an-enquiry .enquiry-progress-step-3 .progress-bar span {
    width: 75%; }
  #make-an-enquiry .enquiry-progress-step-4 .progress-bar span {
    width: 100%; }

    #make-an-enquiry div.wpcf7-mail-sent-ok {
      position: absolute;
      top: 50%;
      left: 0px;
      width: 100%;
      border: none;
      padding: 0px;
      background: #FFF;
      margin: 0px;
      border-radius: 8px;
      font-size: 36px;
      line-height: 40px;
      padding: 80px 0;
      transform: translateY(-50%);
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
       font-family: 'Inter', Helvetica, Arial, sans-serif;
    }

/* Site Footer */
#site-footer {
  background: #FFF;
  padding: 10px 0; }
  #site-footer .container {
    text-align: center; }
  #site-footer p {
    line-height: 20px;
    color: #adadad; }
    #site-footer p a {
      color: #adadad; }
      #site-footer p a:hover {
        color: #5b5b5b; }

.back-to-top {
  position: fixed;
  bottom: -64px;
  right: 32px;
  background: url(./images/icon-back-to-top.svg) no-repeat center center #FFF;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
  width: 48px;
  height: 48px;
  border-radius: 100%;
  -moz-border-radius: 100%;
  -webkit-border-radius: 100%;
  z-index: 101;
  transition: bottom .5s ease-in-out;
  -moz-transition: bottom .5s ease-in-out;
  -webkit-transition: bottom .5s ease-in-out; }

@media all and (min-width: 1141px) {
  .service-section {
    background-color: transparent !important;
    background-image: none !important; } }

@media all and (max-width: 1140px) and (min-width: 0px) {
  #site-header .header-cta {
    display: none;
  }
  .container,
  #site-header .inner {
    width: 704px; }
  #site-header {
    z-index: 100; }
    #site-header .container {
      position: static; }
    #site-header .inner {
      margin: auto;
      position: relative;
      height: 96px; }
    #site-header .toggle-nav {
      position: absolute;
      bottom: 0px;
      right: -16px;
      width: 16px;
      height: 16px;
      border: 16px solid #FFF; }
    #site-header .toggle-nav span {
      display: block;
      height: 2px;
      width: 16px;
      margin: 1px 0 2px 0;
      background: #000;
      -webkit-transition: all ease 0.4s;
      -moz-transition: all ease 0.4s;
      transition: all ease 0.4s;
      position: absolute; }
    #site-header .toggle-nav span.line-a {
      top: 3px; }
    #site-header .toggle-nav span.line-b {
      top: 7px; }
    #site-header .toggle-nav span.line-c {
      top: 11px; }
    #site-header .toggle-nav.active span.line-b {
      opacity: 0; }
    #site-header .toggle-nav.active span.line-a {
      -webkit-transform: rotate(-45deg);
      -moz-transform: rotate(-45deg);
      -o-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
      transform: rotate(-45deg);
      top: 6px; }
    #site-header .toggle-nav.active span.line-c {
      -webkit-transform: rotate(45deg);
      -moz-transform: rotate(45deg);
      -o-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
      transform: rotate(45deg);
      top: 6px; }
    #site-header .logo {
      position: relative;
      z-index: 10; }
    #site-header nav {
      display: none;
      float: none;
      clear: both;
      background: #FFF;
      position: absolute;
      top: 96px;
      left: 0px;
      width: 100%;
      border-top: 1px solid #e5e5e5; }
      #site-header nav li {
        display: block; }
        #site-header nav li a {
          display: block;
          font-size: 24px;
          line-height: 48px;
          text-align: center;
          border-bottom: 1px solid #e5e5e5; }
          #site-header nav li a:hover {
            background: #E5007D;
            color: #FFF; }
          #site-header nav li a.dropdown-active {
            background: #e5e5e5;
            color: #5b5b5b; }
        #site-header nav li ul {
          display: none; }
          #site-header nav li ul li a {
            font-size: 16px; }
  #banner .video-text .video-text-overlay {
    background-size: 1800px auto; }
  .service-section {
    background-position: 70% top;
    background-size: auto 100%; }
  .service-section.service-section-alt {
    background-position: 56% top; }
  #service-section-3 {
    background-position: 20% top; }
  #service-section-5 {
    background-position: 80% top; }
  #clients-slider .container {
    padding-left: 64px;
    padding-right: 64px; }
  #clients-slider .client-logos:before {
    display: none; }
  #clients-slider .client-logos .slick-slide {
    border-left: 1px solid #4c4a4f; }
  #clients-slider .client-logos .slick-slide:before {
    right: 0px; }
  #clients-slider .client-logos .slick-arrow {
    left: -64px; }
    #clients-slider .client-logos .slick-arrow.slick-next {
      left: auto;
      right: -64px; }
  #make-an-enquiry {
    max-width: 600px; }
    #make-an-enquiry .enquiry-pane {
      padding: 0 64px; }
    #make-an-enquiry .enquiry-progress {
      padding: 0 64px; }
  #history .history-line {
    left: 15px; }
  #history .container {
    padding: 128px 64px 32px 0; }
  #history .history-item {
    width: auto;
    float: none;
    text-align: left; }
    #history .history-item p {
      max-width: none;
      float: none; }
    #history .history-item .history-item-date {
      left: 8px;
      right: auto;
      margin: 0px;
      top: 0px; }
      #history .history-item .history-item-date .dot {
        margin: 0px; }
      #history .history-item .history-item-date .date {
        opacity: 1;
        -ms-transform: rotate(90deg);
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
        position: absolute;
        top: 81px;
        left: -83px;
        width: 180px;
        padding: 0px; }
  #history .history-item-left,
  #history .history-item-right {
    padding: 0 0 0 128px; }
  #history .history-item-style-a {
    margin: 0 0 128px 0; }
    #history .history-item-style-a h3 {
      max-width: 470px; }
    #history .history-item-style-a p {
      max-width: 470px;
      float: none; }
  #history .history-item-style-b {
    margin: 0 0 128px 0; }
  #history .history-item-style-c {
    margin: 0 0 128px 0; }
  #about .container {
    padding-bottom: 96px; }
  #about .about-quote {
    width: 50%;
    padding: 0 16px 0 0;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; }
    #about .about-quote blockquote p {
      line-height: 40px;
      font-size: 36px; }
  #about .about-content {
    width: 50%;
    padding: 0 0 0 16px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; }
  #contact .contact-form {
    width: 50%;
    padding: 0 16px 0 0;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; }
    #contact .contact-form .field-name,
    #contact .contact-form .field-phone {
      float: none;
      padding: 0px;
      width: auto; }
  #contact .contact-details {
    width: 50%;
    padding: 0 0 0 16px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box; }
    #contact .contact-details ul li {
      padding: 0px; }
      #contact .contact-details ul li h5 {
        display: none; } }

@media all and (max-width: 767px) and (min-width: 0px) {
  .container,
  #site-header .inner {
    padding-left: 32px;
    padding-right: 32px;
    width: auto; }
  body {
    padding-top: 0px; }
  #top-bar {
    display: none; }
  #site-header {
    top: 0px;
    height: 64px; }
    #site-header .logo {
      display: none; }
    #site-header .container,
    #site-header .inner {
      height: 64px; }
    #site-header .inner {
      padding: 0px; }
    #site-header .mobile-logo {
      display: block;
      padding: 8px 0;
      float: left; }
      #site-header .mobile-logo img {
        height: 48px;
        width: auto; }
    #site-header .toggle-nav {
      right: -16px;
      bottom: 8px; }
    #site-header .mobile-call {
      display: block;
      width: 32px;
      height: 48px;
      background: url(./images/icon-phone-black.svg) no-repeat center center;
      right: 32px;
      bottom: 7px;
      position: absolute; }
    #site-header nav {
      top: 64px; }
  #banner .video-text .video-text-overlay {
    background-size: 230% auto; }
  #contact-banner .video-text .video-text-overlay {
    background-size: 460% auto; }
  .service-section {
    position: relative; }
    .service-section .container {
      padding: 320px 0 0 0; }
    .service-section .service-icon {
      position: absolute;
      top: 0px;
      left: 0px;
      width: 100%;
      height: 320px;
      float: none;
      transform: none;
      -webkit-transform: none;
      -ms-transform: none;
      text-align: center; }
      .service-section .service-icon img {
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        max-width: 104px;
        max-height: 104px;
        margin: auto;
        position: relative;
        top: 50%; }
    .service-section .service-text {
      float: none;
      background: #f5f5f5;
      box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
      padding: 32px;
      width: auto; }
      .service-section .service-text .service-text-inner h2 {
        margin: 0 0 24px 0;
        line-height: 40px;
        font-size: 36px; }
      .service-section .service-text .service-text-inner p {
        max-width: none; }
      .service-section .service-text .service-text-inner .service-button {
        padding: 0px; }
  #service-section-1 {
    background-size: 300% auto;
    background-position: right top; }
  #service-section-2 {
    background-size: 220% auto;
    background-position: left top; }
  #service-section-3 {
    background-size: 200% auto;
    background-position: 75% top; }
  #service-section-4 {
    background-size: 240% auto;
    background-position: left top; }
  #service-section-5 {
    background-size: 270% auto;
    background-position: right top; }
  #newsletter-signup input[type="email"] {
    font-size: 24px;
    line-height: 36px;
    height: 48px; }
  #clients-slider .container {
    padding-left: 96px;
    padding-right: 96px; }
  #clients-slider .client-logos .slick-arrow {
    left: -64px; }
    #clients-slider .client-logos .slick-arrow.slick-next {
      right: -64px; }
  #clients-slider .client-logos .slick-slide {
    padding-left: 16px;
    padding-right: 16px; }
  #make-enquiry h3 {
    font-size: 24px;
    line-height: 36px;
    height: 48px; }
  #make-an-enquiry .enquiry-pane .enquiry-pane-content .text-field {
    font-size: 24px;
    padding-bottom: 10px; }
  #make-an-enquiry .enquiry-pane .enquiry-pane-content h5 {
    font-size: 36px;
    line-height: 40px; }
  #history .container {
    padding: 64px 32px 32px 0; }
  #history .history-item-left,
  #history .history-item-right {
    padding: 0 0 0 63px; }
  #history .history-item-style-a {
    margin: 0 0 64px 0; }
  #history .history-item-style-b {
    margin: 0 0 64px 0; }
    #history .history-item-style-b .history-item-image {
      width: auto;
      float: none; }
      #history .history-item-style-b .history-item-image img {
        width: 100%;
        height: auto; }
    #history .history-item-style-b .history-item-text {
      margin: 0 -32px 0 0;
      float: none;
      width: auto; }
  #history .history-item-style-c {
    margin: 0 0 64px 0; }
  #history .todays-date {
    width: 100%;
    left: 0px;
    margin: 0px; }
  #about .container {
    padding: 64px 32px 40px 32px; }
  #about .about-quote {
    float: none;
    width: auto;
    padding: 0px;
    margin: 0 0 64px 0; }
  #about .about-content {
    float: none;
    width: auto;
    padding: 0px; }
  #contact {
    padding: 0px; }
    #contact .container {
      padding: 64px 32px 64px 32px; }
    #contact .contact-form {
      float: none;
      width: auto;
      padding: 0px;
      margin: 0 0 64px 0; }
    #contact .contact-details {
      text-align: left;
      float: none;
      width: auto;
      padding: 0px; }
      #contact .contact-details ul li p {
        text-align: left; }
  #make-an-enquiry .enquiry-pane,
  #make-an-enquiry .enquiry-progress {
    padding: 0 32px; }
  .back-to-top {
    display: none; } }

