.slick-slider{position:relative;display:block;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-khtml-user-select:none;-ms-touch-action:pan-y;touch-action:pan-y;-webkit-tap-highlight-color:transparent}.slick-list{position:relative;display:block;overflow:hidden;margin:0;padding:0}.slick-list:focus{outline:0}.slick-list.dragging{cursor:pointer;cursor:hand}.slick-slider .slick-list,.slick-slider .slick-track{-webkit-transform:translate3d(0,0,0);-moz-transform:translate3d(0,0,0);-ms-transform:translate3d(0,0,0);-o-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.slick-track{position:relative;top:0;left:0;display:block;margin-left:auto;margin-right:auto}.slick-track:after,.slick-track:before{display:table;content:''}.slick-track:after{clear:both}.slick-loading .slick-track{visibility:hidden}.slick-slide{display:none;float:left;height:100%;min-height:1px}[dir=rtl] .slick-slide{float:right}.slick-slide img{display:block}.slick-slide.slick-loading img{display:none}.slick-slide.dragging img{pointer-events:none}.slick-initialized .slick-slide{display:block}.slick-loading .slick-slide{visibility:hidden}.slick-vertical .slick-slide{display:block;height:auto;border:1px solid transparent}.slick-arrow.slick-hidden{display:none}

.icon-email-blue { background-image: url(../i/icon-email-blue.svg); width: 22px; height: 20px; }
.icon-phone-blue { background-image: url(../i/icon-phone-blue.svg); width: 21px; height: 21px; }
.icon-phone { background-image: url(../i/icon-phone.svg?v=2); width: 37px; height: 37px; }
.icon-pillar-1 { background-image: url(../i/icon-pillar-1.svg); width: 64px; height: 45px; }
.icon-pillar-2 { background-image: url(../i/icon-pillar-2.svg); width: 62px; height: 62px; }
.icon-pillar-3 { background-image: url(../i/icon-pillar-3.svg); width: 44px; height: 61px; }
.icon-pillar-4 { background-image: url(../i/icon-pillar-4.svg); width: 59px; height: 59px; }
.icon-arrow-right { background-image: url(../i/icon-arrow-right.svg); width: 19px; height: 9px; }
.pg-grey { background-color: #F9F9F9 ;}

footer {
  background-color: var(--dark);
  border-top: 7px solid var(--primary);
  color: #fff;
}

footer .brand {
  margin: 0 0 28px;
}

footer ul {
  margin: 0 0 70px;
}

footer ul li a i {
  margin: 0 12px 0 0;
}

footer ul li:first-child {
  margin: 0 30px 0 0;
}

footer ul li a {
  color: #fff;
  font-size: 2.1rem;
}


footer p:not(.brand) {
  font-size: 1.3rem;
}

footer p:not(.brand) em {
  color: #ccc;
}

footer p:not(.brand) a {
  color: #fff;
  text-decoration: underline;
}

footer ul li a:hover,
footer ul li a:focus,
footer p:not(.brand) a:hover,
footer p:not(.brand) a:focus {
  color: #999;
}

header {
  background-color: var(--grey);
  padding: 5px 0;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 1000;
}

header .navigation ul {
  height: 100%;
}

header .navigation ul li:last-child a i {
  margin: 0 15px 0 0;
}

.header .navigation ul li a {
  color: #fff;
  font-size: 3.3rem;
  font-family: var(--heading);
  font-weight: 300;
  letter-spacing: 0.25px;
  position: relative;
  display: block;
  padding: 0 29px;
  margin: 0;
}

.header .navigation ul li:first-child a {
  padding-left: 0;
}

header .navigation ul li:last-child a {
  display: -webkit-flex;
  display: -ms-flex;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: flex-end;
  -moz-justify-content: flex-end;
  -ms-justify-content: flex-end;
  -o-justify-content: flex-end;
  justify-content: flex-end;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding-right: 0;
  margin-right: 0;
  border-left: 1px solid #5f5e5c;
}

.header .navigation ul li a:hover,
.header .navigation ul li a:focus {
  color: #ccc;
}

.header .navigation ul li:not(:last-child):first-child a:after {
  left: 0;
}

.header .navigation ul li:not(:last-child) a:after {
  position: absolute;
  bottom: -21px;
  left: 29px;
  right: 29px;
  height: 0px;
  margin: auto;
  content: '';
  display: block;
  background-color: var(--primary);
  transition: all 0.3s;
}

.header .navigation ul li:not(:last-child) a:hover:after,
.header .navigation ul li:not(:last-child) a:focus:after,
.header .navigation ul li:not(:last-child) a.nav-selected:after {
  height: 7px;
}

.pillars ul {
  display: -webkit-flex;
  display: -ms-flex;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}

.pillars ul li {
  -webkit-flex: 0 0 32%;
  -ms-flex: 0 0 32%;
  flex: 0 0 32%;
  max-width: 32%;
}

.pillars ul li a {
  display: block;
  overflow: hidden;
  height: 525px;
  border-radius: var(--radius);
  position: relative;
  background-color: var(--primary);
}

.pillars ul li:first-child a { border-radius: 0 var(--radius) var(--radius) 0; }
.pillars ul li:last-child a { border-radius: var(--radius) 0 0 var(--radius); }

.pillars ul li a img {
  transition: all 0.3s;
  z-index: 1;
  position: absolute;
  top: -50%;
  left: -50%;
  right: -50%;
  bottom: -50%;
  margin: auto;
  transform-origin: center;
  transform: scale(1);
  opacity: 1;
}

.pillars ul li a:hover img,
.pillars ul li a:focus img {
  opacity: 0.17;
  transform: scale(1.05);
}

.pillars ul li a strong {
  position: absolute;
  left: 78px;
  bottom: 68px;
  transition: all 0.3s;
  opacity: 0;
  color: #fff;
  z-index: 3;
  font-family: var(--heading);
  font-weight: 300;
  font-size: 6.9rem;
  line-height: 0.8;
  display: inline-block;
}

.pillars ul li a strong em {
  font-weight: 400;
  font-size: 8.3rem;
  display: block;
  font-style: normal;
}

.pillars ul li a strong small {
  display: block;
  font-family: var(--font);
  font-size: 1.5rem;
  color: #c3fffd;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin: 20px 0 0;
}

.pillars ul li a:hover strong,
.pillars ul li a:focus strong {
  bottom: 78px;
  opacity: 1;
}

.why-choose {
  color: #fff;
  font-weight: 300;
  font-size: 1.6rem;
  background: #1e5799;
  background: -moz-linear-gradient(left,  var(--grey) 0%, var(--grey) 49%, var(--grey4) 51%, var(--grey4) 100%);
  background: -webkit-linear-gradient(left,  var(--grey) 0%,var(--grey) 49%,var(--grey4) 51%,var(--grey4) 100%);
  background: linear-gradient(to right,  var(--grey) 0%,var(--grey) 49%,var(--grey4) 51%,var(--grey4) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='var(--grey)', endColorstr='var(--grey4)',GradientType=1 );
}

.why-choose .grey1 { background-color: var(--grey); }
.why-choose .grey2 { background-color: var(--grey2); }
.why-choose .grey3 { background-color: var(--grey3); }
.why-choose .grey4 { background-color: var(--grey4); }

.why-choose h2 {
  font-size: 4.4rem;
  line-height: 0.9;
  font-weight: 300;
  margin: 0 0 15px;
}

.why-choose i[class^="icon-"] {
  height: 75px;
  margin: 0 0 20px;
}

.home-content h1,
.home-content h2 {
  color: var(--primary);
  font-size: 6.9rem;
  font-weight: 300;
  line-height: 0.8;
  margin: 0 0 20px;
}

.home-content h1 strong,
.home-content h2 strong {
  font-weight: 600;
  color: var(--dark);
  display: block;
  font-size: 8.3rem;
}

.home-content p { margin: 0 0 55px; }
.home-content p:last-child { margin: 0; }

.home-content a.inline-phone {
  color: var(--text);
}

.home-content a.inline-phone:hover,
.home-content a.inline-phone:hover {
  opacity: 0.5;
}

.request-quote {
  background-color: #000;
  background-image: url(../i/webp/roofing-quote-barrie-ontario.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  -webkit-background-size: cover;
  background-size: cover;
  color: #e5e5e5;
}

.request-quote h2 {
  color: #fff;
  font-size: 6.3rem;
  font-weight: 300;
}

.request-quote p {
  padding: 0 30px 0 0;
}

.form fieldset .mb-3 {
  margin: 0 0 15px;
  width: 49%;
  float: left;
}

.form fieldset .mb-3:nth-child(2n+2) {
  float: right;
}

.form fieldset .mb-3:nth-child(5) {
  float: none;
  width: 100%;
  clear: both;
}

.form fieldset .mb-3 .form-control {
  border-radius: 7px;
  width: 100%;
  padding: 15px;
  border: 1px solid #FFF !important;
  font-style: normal;
}

.form.contact-form fieldset .mb-3 .form-control {
  background-color: #f9f9f9;
}

.form-group.captcha {
  margin: 0;
}

.form.dark .form-control::placeholder { color: #000; opacity: 1; font-style: normal; }
.form.dark .form-control:-ms-input-placeholder { color: #000; }
.form.dark .form-control::-ms-input-placeholder { color: #000; }
.form.light .form-control::placeholder { color: var(--text); opacity: 1; font-style: normal; }
.form.light .form-control:-ms-input-placeholder { color: var(--text); }
.form.light .form-control::-ms-input-placeholder { color: var(--text); }

#testimonials {
  position: relative;
}

#testimonials ul li section {
  padding: 140px 50px;
  display: -webkit-flex;
  display: -ms-flex;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -ms-align-items: flex-start;
  align-items: flex-start;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}

#testimonials ul li section h2 {
  position: relative;
  max-width: 26%;
  flex: 0 0 26%;
  font-size: 6.3rem;
  line-height: 0.8;
  font-weight: 300;
}

#testimonials ul li section h2:before {
  z-index: -1;
  position: absolute;
  -webkit-background-size: contain;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
  content: '';
}

#testimonials ul li section h2:before {
  background-image: url(../i/icon-quote-left.svg);
  width: 99px;
  height: 88px;
  top: -35px;
  left: -35px;
}


#testimonials ul li section blockquote {
  max-width: 72%;
  flex: 0 0 72%;
}

#testimonials ul li section blockquote cite {
  font-weight: 600;
  font-style: normal;
  line-height: 1;
}

#testimonials ul li section blockquote cite em {
    font-style: normal;
    font-weight: 400;
    font-size: 80%;
    display: block;
}

#testimonials .slick-arrow {
  text-indent: -9999px;
  border: none;
  outline: 0;
  opacity: 1;
  transition: all 0.3s;
  width: 30px;
  height: 58px;
  -webkit-background-size: contain;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  background-color: transparent;
  z-index: 80;
  cursor: pointer;
}

#testimonials .slick-arrow.slick-prev {
  background-image: url(../i/icon-prev.svg);
  left: -50px;
}

#testimonials .slick-arrow.slick-next {
  background-image: url(../i/icon-next.svg);
  right: -50px;
}

#testimonials .slick-arrow:hover,
#testimonials .slick-arrow:focus {
  opacity: 0.6;
}

.slideshow {
  overflow: hidden;
  width: 57%;
  z-index: 999;
}
.slideshow img {
  border-radius: 0 0 100px 0;

}

.hero,
.home-about.image-section.image-section-bottom-right {
  position: relative;
}


.pg-content figure,
.home-about figure {
  width: 57%;
  overflow: hidden;
  text-align: right;
  height: 720px;
  margin-left: auto;
  border-radius: calc(var(--radius) * 2) 0 0 0;
  z-index: 999;
}

.pg-content figure { border-radius: 0; }
.pg-content.image-radius-right figure { border-radius: 0 calc(var(--radius) * 2) calc(var(--radius) * 2) 0;  }
.pg-content.image-radius-left figure { border-radius: calc(var(--radius) * 2) 0 0 calc(var(--radius) * 2);  }
.pg-content.image-radius-right.image-radius-no-bottom figure { border-radius: 0 calc(var(--radius) * 2) 0 0;  }
.pg-content.image-radius-left.image-radius-no-bottom figure { border-radius: calc(var(--radius) * 2) 0 0 0;  }

.pg-title {
  background-image: url(../i/title.jpg);
  background-repeat: no-repeat;
  background-position: bottom center;
  background-color: #000;
  padding: calc(var(--spacing) * 1.625) 0 0;
}

.pg-title h1 {
  color: #FFF;
  font-weight: 600;
  letter-spacing: 3px;
  font-size: 9.3rem;
  line-height: 0.7125;
}

.list-check ul {
  column-count: 2;
}

.list-check li {
  background: url(../i/icon-list.png);
  background-position: 0% 5%;
  background-repeat: no-repeat;
  padding: 0 0 0 50px;
  margin: 0 0 40px 0;
}

.get-in-touch h2:after {
  content: '';
  width: 100px;
  height: 5px;
  background: var(--blue);
  display: block;
  margin: 10px 0 50px;
}

.get-in-touch a {
  color: var(--text);
  margin: 0 0 30px 0;
}

.get-in-touch a:hover,
.get-in-touch a:focus {
  opacity: 0.5;
}

.get-in-touch a i {
  margin: 0 12px 0 0;
}

.get-in-touch {
  padding: 30px;
}

.brand a img {
  position: relative;
  top: 4px;
}

.pg-lg,
.home-about,
.hero {
  display: -webkit-flex;
  display: -ms-flex;
  -webkit-display: flex;
  -moz-display: flex;
  -ms-display: flex;
  -o-display: flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
}

.pg-lg figure,
.home-about figure,
.hero .slideshow {
  max-width: 57%;
  -webkit-flex: 0 0 57%;
  flex: 0 0 57%;
}

.pg-lg.pg-lg-reverse figure,
.home-about figure {
  order: 2;
}

.home-content {
    padding: 0 100px;
}

.pg-padding {
  padding: calc(var(--spacing) * 2) 0;
}

.contact-info {
  padding: var(--spacing);
  background-color: #f9f9f9;
  position: relative;
  border-radius: var(--radius);
}

.contact-info h2 {
  margin: 0 0 25px;
}

.contact-info h2:after {
  content: '';
  display: block;
  width: 75px;
  height: 3px;
  background-color: var(--blue);
  margin: 5px 0 0;
}

.contact-info ul li {
  margin: 0 0 10px;
}

.contact-info ul li:last-child {
  margin: 0;
}

.contact-info ul li i {
  margin: 0 10px 0 0;
}

.contact-info ul li a {
  color: var(--text);
}

.contact-info ul li a:hover,
.contact-info ul li a:focus {
  color: var(--blue);
}

.check-list ul {
  -webkit-display: flex;
  -webkit-align-items: flex-start;
  -webkit-justify-content: space-between;
  -webkit-flex-wrap: wrap;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}

.check-list ul li {
  position: relative;
  padding: 0 0 0 30px;
  -webkit-flex: 0 0 48%;
  flex: 0 0 48%;
  max-width: 48%;
  line-height: 1.25;
  margin: 0 0 23px;
}

.check-list ul li:before {
  width: 19px;
  height: 19px;
  content: '';
  display: block;
  -webkit-background-size: contain;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../i/icon-check.svg);
  position: absolute;
  top: 1px;
  left: 0;
}

.contact-form label + span,
.request-quote label + span {
    display: none;
}

.contact-form label,
.request-quote label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.pg-grey,
.ccm-page-id-203 .testimonials,
.page-template-about .testimonials {
    background-color: #f9f9f9;
}

.pg-privacy-policy p {
    margin: 0 0 40px;
}

.pg-privacy-policy p:last-child {
  margin: 0;
}


.pg-privacy-policy h4 {
    font-family: var(--font);
    font-weight: 700;
}

.pg-privacy-policy p a {
    color: var(--blue);
    text-decoration: underline;
}

.pg-privacy-policy p a:hover, .pg-privacy-policy p a:focus {
    color: var(--grey1);
}

.page-template-services .home-content p, .page-template-services .home-content ul {
    margin: 0 0 30px;
}

.gallery {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -5px 0;
}

.gallery a {
  -webkit-flex: 0 0 32%;
  -ms-flex: 0 0 32%;
  flex: 0 0 32%;
  max-width: 32%;
  margin: 5px 0.5%;
  position: relative;
  overflow: hidden;
  display: block;
  background-color: var(--blue);
  height: 285px;
}

.gallery a img {
  position: absolute;
  top: -50%;
  right: -50%;
  left: -50%;
  bottom: -50%;
  margin: auto;
  opacity: 1;
  transition: all 0.3s;
  transform-origin: center;
  transform: scale(1);
  filter: grayscale(0);
  z-index: 1;
}

.gallery a:hover img,
.gallery a:focus img {
  opacity: 0.2;
  transform: scale(1.2);
  filter: grayscale(1);
}

.gallery a:after {
  content: '';
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(../i/icon-expand.svg);
  display: block;
  width: 55px;
  height: 55px;
  transform-origin: center;
  transform: scale(1.2);
  transition: all 0.3s;
  opacity: 0;
}

.gallery a:before {
  content: '';
  z-index: 3;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  margin: auto;
  border: 1px solid #fff;
  transition: all 0.3s;
  opacity: 0;
}

.gallery a:hover:after,
.gallery a:focus:after {
  transform: scale(1);
  opacity: 1;
}

.gallery a:hover:before,
.gallery a:focus:before {
  border: 8px solid #fff;
  opacity: 0.3;
}

.lg-toolbar {
  background: none !important;
}

#lg-counter,
.lg-sub-html,
#lg-download {
  display: none !important;
}

.testimonials {
    display: none;
}

.why-choose {
    border-bottom: 3px solid #fff;
}

.request-quote.no-parallax {
  background-image: url(../i/jpg-png/roofing-quote-barrie-ontario.jpg);
}

.parallax-mirror.no-parallax {
  display: none !important;
}

.home-about figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
