/*
* Prefixed by https://autoprefixer.github.io
* PostCSS: v7.0.29,
* Autoprefixer: v9.7.6
* Browsers: last 4 version
*/
/*------------------------------------------------------------
## Default
------------------------------------------------------------*/
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.suspension-contain {
  max-height: 980px;
  overflow: hidden;
  position: relative;
}
html.suspended {
  background: rgba(0, 0, 0, 0.6);
}
body {
  color: #000000;
  font-size: 16px;
  font-family: "Roboto", Arial, Helvetica, sans-serif;
  max-width: 100%;
  min-width: 1200px;
  margin: 0 auto;
}
a {
  color: inherit;
  text-decoration: none;
}
a:hover {
  text-decoration: none;
  color: inherit;
}
ul,
h1,
h2,
h3,
h4,
h5 {
  padding: 0;
  margin: 0;
}
h1,
h2,
h3,
h4,
h5 {
  font-family: "Josefin Sans", sans-serif;
  font-weight: bold;
  line-height: 92%;
}
h1 {
  font-size: 70px;
}
h2 {
  color: #000000;
  font-size: 60px;
}
h2 span {
  color: #FFFFFF;
  display: contents;
}
li {
  list-style: none;
}
img {
  max-width: 100%;
}
p,
dl,
dd {
  margin: 0;
}
dt,
.site-logo {
  line-height: 0;
}
.row {
  max-width: 1299px;
  margin: 0 auto;
  padding: 0 15px;
}
.site-logo {
  display: inline-block;
}
/*------------------------------------------------------------
## Floats
------------------------------------------------------------*/
.fl {
  float: left;
}
.fr {
  float: right;
}
/*------------------------------------------------------------
## Typography
------------------------------------------------------------*/
.text-primary {
  color: #b11414;
}
.text-bold {
  font-weight: 700;
}
.text-uppercase {
  text-transform: uppercase;
}
.text-center {
  text-align: center !important;
}
.text-left {
  text-align: left;
}
/*------------------------------------------------------------
## Clearfix
------------------------------------------------------------*/
.clear {
  clear: both;
}
.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  font-size: 0;
}
.clearfix {
  display: block;
}
/*------------------------------------------------------------
## Cookies
------------------------------------------------------------*/
.cc-animate.cc-revoke.cc-bottom {
  font-size: 14px;
  padding: 5px 10px;
  position: fixed;
  display: block !important;
  -webkit-transform: none !important;
      -ms-transform: none !important;
          transform: none !important;
  bottom: 0 !important;
  left: 20px !important;
}
/*------------------------------------------------------------
## Call-To-Action
------------------------------------------------------------*/
.destroy-on-load,
.cta {
  display: none;
}
/* .cta {
  font-size: 0;
  background-color: #000000;
  background-image: url(../images/common/phonecall.png);
  background-size: 75%;
  background-position: center;
  background-repeat: no-repeat;
  border-top-left-radius: 70px;
  border-bottom-left-radius: 70px;
  display: block;
  width: 70px;
  height: 70px;
  position: fixed;
  right: 0;
  bottom: 50px;
  transform: translateX(110%);
  transition: all 0.3s;
  box-shadow: 0 0 5px 0 rgba(0,0,0,0.5);
} */
/*------------------------------------------------------------
## Gallery
------------------------------------------------------------*/
#content .gallery-container {
  text-align: center;
}
#content .gallery {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
#content .gallery li {
  display: inline-block;
  width: 33%;
}
#content .thumbnail {
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 4px;
  display: block;
  line-height: 0.42857;
  margin-bottom: 20px;
  padding: 4px;
  -webkit-transition: border 0.5s ease-in-out 0s;
  -o-transition: border 0.5s ease-in-out 0s;
  transition: border 0.5s ease-in-out 0s;
}

#content .thumbnail img{
  height: 215px !important;
}
#content .thumbnail:hover {
  -webkit-transform: scale(1.02);
      -ms-transform: scale(1.02);
          transform: scale(1.02);
}
#content .page_navigation {
  display: inline-block;
}
#content .page_link,
#content .previous_link,
#content .next_link,
#content .first_link,
#content .last_link,
#content .ellipse {
  background-color: #fff;
  border: 1px solid #ddd;
  color: #0275d8;
  display: inline-block;
  line-height: 1.25;
  margin-left: -1px;
  padding: 0.5rem 0.75rem;
  position: relative;
}
#content .page_navigation > a:hover,
.page_navigation > a.active_page {
  background-color: #eceeef;
  border-color: #ddd;
  color: #014c8c;
  text-decoration: none;
}
/*------------------------------------------------------------
## Buttons
------------------------------------------------------------*/
button,
.btn {
  cursor: pointer;
}
button:disabled,
.btn:disabled {
  cursor: no-drop;
}
.btn {
  color: #fff;
  font-family: inherit;
  font-weight: bold;
  font-size: inherit;
  line-height: 60px;
  text-align: center;
  background: #519CD1;
  display: block;
  width: 200px;
  padding: 0 10px;
  position: relative;
}
.btn:before {
  content: '';
  position: absolute;
  top: -4px;
  left: -5px;
  bottom: 0;
  width: 102px;
  height: 60px;
  background-color: transparent;
  border-top: 4px solid #BD0202;
  border-left: 5px solid #BD0202;
}
.btn:after {
  content: '';
  position: absolute;
  right: -4px;
  bottom: -4px;
  width: 107px;
  height: 60px;
  background-color: transparent;
  border-right: 4px solid #BD0202;
  border-bottom: 4px solid #BD0202;
}
/*------------------------------------------------------------
## Header
------------------------------------------------------------*/
#header {
  padding-top: 3px;
}
#header .row {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr auto 1fr;
  grid-template-columns: 1fr auto 1fr;
  max-width: 1222px;
}
#header .site-logo {
  max-width: 204px;
  margin: 0 auto;
  -ms-grid-column: 2;
  grid-column: 2;
  -ms-grid-row: 1;
  grid-row: 1;
  z-index: 1;
}
#header nav {
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-column: 1/4;
  -ms-grid-row: 1;
  grid-row: 1;
  max-width: 1150px;
  width: 100%;
  margin-left: auto;
}
#header nav a#pull {
  display: none;
}
#header nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#header nav ul li.spacer {
  width: 204px;
  height: 95px;
}
#header nav ul li a {
  font-weight: bold;
  font-size: 17.46px;
  line-height: 120%;
  padding-bottom: 10px;
  position: relative;
}
#header nav ul li a:after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -56px;
  width: 16px;
  height: 0;
  background-color: #BD0101;
  margin: 0 auto;
  opacity: 0;
  -webkit-transition: height 0.3s ease, opacity 0.5s;
  -o-transition: height 0.3s ease, opacity 0.5s;
  transition: height 0.3s ease, opacity 0.5s;
}
#header nav ul li.active-menu a:after,
#header nav ul li a:hover:after {
  height: 56px;
  opacity: 1;
}
header {
    position: relative;
    z-index: 3;
}
/*------------------------------------------------------------
## Banner
------------------------------------------------------------*/
/*#banner {
  background: url(../images/common/banner.jpg) no-repeat top/auto #3D3D3D;
}*/
#banner .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 1325px;
  padding-bottom: 395px;
}
#banner .container {
  color: #FFFFFF;
  text-align: center;
}
#banner{position: relative;
  overflow: hidden;}
#banner h1 {
  font-size: 60px;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  position: absolute;
  color: #fff;
  text-align: center;
  left: 0;
  right: 0;

  bottom: 13%;  
  z-index: 3;
  text-shadow: 2px 2px 0 #000000, 2px -2px 0 #141312, -2px 2px 0 #060606, -2px -2px 0 #0e0d0b, 2px 0px 0 #000001, 0px 2px 0 #000000, -2px 0px 0 #0e0e0b, 0px -2px 0 #010102;
}

#slideshow {
    position: relative; 
    width: 100%; 
    min-height: 1325px;
}

#slideshow > div { 
    top: 10px; 
    left: 10px; 
    right: 10px; 
    bottom: 10px; 
}

#slideshow > div img{
  min-height: 1004px;
}
#banner .flexslider {
  margin: 0 !important;
  border: 0 solid #fff !important;
  max-width: 100% !important;
}

#banner .flexslider .slides img {
  min-height: 350px;
  object-fit: cover;
}
/*------------------------------------------------------------
## About Section
------------------------------------------------------------*/
#about{position: relative;z-index: 2;}
#about .container {
  color: #FFFFFF;
  background-color: #519CD1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 88px 79px 60px 125px;
  margin-top: -110px;
}
#about .text {
  max-width: 488px;
  margin-right: 15px;
}
#about .subheading {
  font-weight: 500;
  font-size: 24px;
  line-height: 229%;
  display: block;
  margin: -17px 0 20px;
}
#about p,
#services p,
#testimonials p {
  font-weight: 700;
  font-size: 18px;
  line-height: 167%;
}
#about p {
  margin-bottom: 29px;
}
#about .btn {
  margin-top: 42px
}
#about .thumb {
  line-height: 0;
  position: relative;
}
#about .thumb:before {
  content: '';
  position: absolute;
  top: -13px;
  left: -13px;
  width: 68.46%;
  height: 70.55%;
  border-top: 13px solid #BD0202;
  border-left: 13px solid #BD0202;
}
#about .thumb:after {
  content: '';
  position: absolute;
  right: -13px;
  bottom: -13px;
  width: 68.46%;
  height: 70.55%;
  border-right: 13px solid #BD0202;
  border-bottom: 13px solid #BD0202;
}
/*------------------------------------------------------------
## Rating Section
------------------------------------------------------------*/
#rating {
  text-align: center;
  padding: 60px 0 61px;
}
#rating h2 {
  color: #519BD1;
  margin-bottom: 42px;
}
#rating .badges {
  line-height: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
}
/*------------------------------------------------------------
## Services Section
------------------------------------------------------------*/
#services {
  color: #FFFFFF;
  text-align: center;
  background-color: #519CD1;
  padding: 60px 0 233px;
}
#services h2,
#testimonials h2 {
  text-transform: uppercase;
}
#services p {
  text-transform: uppercase;
  max-width: 776px;
  margin: 20px auto 34px;
}
#services .btn {
  margin: 0 auto 65px;
}
#services .thumbs {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 15px auto 15px auto;
  grid-template-columns: auto auto auto;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 100%;
  padding: 0;
}
#services .thumbs img:nth-of-type(odd) {
  border-top: 44px solid #000000;
  margin-bottom: 4px;
}
#services .thumbs img:nth-of-type(even) {
  border-bottom: 4px solid #000000;
}
/*------------------------------------------------------------
## Testimonials Section
------------------------------------------------------------*/
#testimonials .row {
  max-width: 1297px;
}
#testimonials .container {
  background-color: #FFFFFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-top: -166px;
  position: relative;
  -webkit-box-shadow: 0 8px 4px -4px rgba(0,0,0,0.35);
          box-shadow: 0 8px 4px -4px rgba(0,0,0,0.35);
}
#testimonials .container:before {
  content: '';
  position: absolute;
  top: -12px;
  right: -14px;
  width: 24.15%;
  height: 44.19%;
  border-top: 12px solid #BD0202;
  border-right: 14px solid #BD0202;
}
#testimonials .container:after {
  content: '';
  position: absolute;
  left: -16px;
  bottom: -17px;
  width: 24.15%;
  height: 44.19%;
  border-left: 16px solid #BD0202;
  border-bottom: 17px solid #BD0202;
  z-index: -1;
}
#testimonials .left {
  max-width: 536px;
  margin-right: 59px;
  margin-left: 30px;
  padding: 68px 0 141px;
}
#testimonials .quote {
  display: block;
  margin: 0 auto 50px;
}
#testimonials .rating {
  margin: 16px 0 40px;
}
#testimonials .author {
  font-weight: bold;
  font-size: 24px;
  display: block;
}
#testimonials .right {
  text-align: right;
  background: url(../images/common/testimonials.jpg) no-repeat center/cover;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  max-width: 549px;
  width: 100%;
  padding: 0 69px 145px 56px;
}
#testimonials h2 {
  font-size: 55px;
  line-height: 100%;
}
#testimonials .btn {
  margin: 121px 4px 0 0;
}
/*------------------------------------------------------------
## Projects Section
------------------------------------------------------------*/
#projects {
  text-align: center;
  padding: 119px 0 84px;
}
#projects h2 span {
  color: #519BD1;
}
#projects .grid {
  line-height: 0;
  -webkit-columns: 3;
     -moz-columns: 3;
          columns: 3;
  -webkit-column-gap: 35px;
     -moz-column-gap: 35px;
          column-gap: 35px;
  -webkit-column-fill: balance;
     -moz-column-fill: balance;
          column-fill: balance;
  max-height: 870px;
  margin-top: 51px;
}
#projects .grid img {
  margin-bottom: 33px;
}
#projects a.btn {
  margin: 35px auto 0;
}
/*------------------------------------------------------------
## Contact Form Messages
------------------------------------------------------------*/
form .messages p {
  display: none;
  font-family: Arial !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  font-size: 16px !important;
}
form .loading {
  display: none;
}
form .alert {
  padding: 15px;
  margin-bottom: 20px;
  border: 1px solid transparent;
  border-radius: 4px;
}
form .alert-success {
  color: #3c763d;
  background-color: #dff0d8;
  border-color: #d6e9c6;
}
form .alert-danger {
  color: #a94442;
  background-color: #f2dede;
  border-color: #ebccd1;
}
form [type="submit"] {
  margin: 20px auto;
}
/*------------------------------------------------------------
## Contact Form
------------------------------------------------------------*/
.ctc-form {
  margin: 0 auto;
  text-align: center;
}
.ctc-form label {
  display: block;
  margin-bottom: 12px;
}
.ctc-form .thirds {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 22px 1fr 22px 1fr;
  grid-template-columns: 1fr 1fr 1fr;
  -webkit-column-gap: 22px;
     -moz-column-gap: 22px;
          column-gap: 22px;
}
.ctc-form ::-webkit-input-placeholder {
  color: #323232;
  font-family: inherit;
  font-size: 18px;
}
.ctc-form ::-moz-placeholder {
  color: #323232;
  font-family: inherit;
  font-size: 18px;
}
.ctc-form :-ms-input-placeholder {
  color: #323232;
  font-family: inherit;
  font-size: 18px;
}
.ctc-form ::-ms-input-placeholder {
  color: #323232;
  font-family: inherit;
  font-size: 18px;
}
.ctc-form input[type="text"],
.ctc-form textarea,
.ctc-form ::placeholder {
  color: #323232;
  font-family: inherit;
  font-size: 18px;
}
.ctc-form input[type="text"],
.ctc-form textarea {
  border: 1px solid #DDDDDD;
  border-radius: 0;
  display: block;
  width: 100%;
  padding: 5px 10px;
}
.ctc-form input[type="text"] {
  height: 45px;
}
.ctc-form textarea {
  line-height: 167%;
  height: 319px;
  padding-top: 10px;
  resize: none;
}
.ctc-form .recap {
  display: inline-block;
}
.ctc-form .g-recaptcha {
  margin-bottom: 12px;
}
.ctc-form .consent {
  font-size: 12px;
}
.ctc-form .consent input {
  vertical-align: middle;
  margin: 0 5px 0 0;
}
.ctc-form .g-recaptcha div {
  margin: 0 auto;
}
.ctc-form .ctcBtn {
  border: 0;
  margin: 32px auto 0;
}
.ctc-form .ctc-hide {
  display: none;
}
/*------------------------------------------------------------
## Footer
------------------------------------------------------------*/
/*Contact Form Section*/
#footer .contact-form {
  text-align: center;
  background: url(../images/common/contact.jpg) no-repeat center/cover;
  padding: 63px 0 36px;
}
#footer .contact-form h2 {
  margin-bottom: 37px;
}
#footer .contact-form .ctc-form input[type="text"],
#footer .contact-form .ctc-form textarea {
  border: 0;
}
#footer .contact-form .ctc-form .consent {
  color: #FFFFFF;
}
/*Contact Info Section*/
#footer .contact-info {
  font-weight: bold;
  font-size: 18px;
  text-align: center;
  padding: 34px 0 19px;
}
#footer .contact-info .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
#footer .contact-info span {
  display: block;
}
#footer .contact-info .phone a {
  font-size: 24px;
  margin-top: -3px;
}
#footer .contact-info .middle p {
  font-weight: 500;
  margin: 10px 0 5px;
}
#footer .contact-info .email p {
  margin: -1px 0 5px;
}
#footer .bottom-footer {
  color: #FFFFFF;
  background-color: #519CD1;
  padding: 14px 0 13px;
}
#footer .bottom-footer .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#footer .silver {
  margin-left: 15px;
}
#footer .silver img {
  display: inline-block;
  vertical-align: middle;
  max-width: 40px;
  margin-right: 5px;
}
/*------------------------------------------------------------
## Inner Pages
------------------------------------------------------------*/
.inner #banner {
  background-size: cover;
}
.inner #banner .row {
  min-height: 1070px;
  padding-bottom: 140px;
}
.inner #content {
  min-height: 400px;
  padding: 40px 0;
}
/*------------------------------------------------------------
## Privacy Plicy Page
------------------------------------------------------------*/
.inPrivacyBox {
  max-width: 850px;
  margin: 0 auto;
}
.inPrivacyBox p {
  text-align: justify !important;
  padding: 10px 0;
}
/*------------------------------------------------------------
## Media Queries
------------------------------------------------------------*/
@media screen and (max-width: 1199px){
  body{min-width: 320px;}
  h1{font-size: 40px !important; margin-bottom: 20px !important;}
  h2{font-size: 35px !important; margin-bottom: 20px !important;}
  h3{font-size: 30px !important;}
  #header {padding: 0}
  #header .row {width: 100%; display: block; padding: 0; text-align: center;}
  #header nav {display:block; height: auto; max-width: 100%;}
  #header nav ul { width: 100%; display: none; height: auto;border-bottom:5px solid #000; padding: 0 15px;}
  #header nav ul li { width: 100%;position: relative; }
  #header nav ul li.spacer{display: none;}
  #header nav ul li a { display: block; float:none; padding: 10px 0;}
  #header nav ul li a:after{display: none;}
  #header nav a {text-align: left; width: 100%;}
  #header nav a strong {position: absolute; top: 50%; transform: translateY(-50%); left: 15px;}
  #header nav a#pull {display: block; color: #fff; background-color: #000; height: 30px;padding: 10px 0; width: 100%; position: relative;}
  #header nav a#pull:after { content:""; background: url('../images/nav-icon.png') no-repeat; width: 20px; height: 20px; display: inline-block; position: absolute; right: 15px; top: 50%; transform: translateY(-50%);}
  .cta{background: #519CD1  url("../images/common/phonecall.png") no-repeat center center;border-bottom-left-radius: 40px;box-shadow: 0 0 5px black; border-top-left-radius: 40px;bottom: 1%;display: block;height: 80px;position: fixed;right: 0;text-decoration: none; text-indent: -9999em;width: 100px;z-index: 999;}
  #banner {position: relative;}
  #banner h1{left: 0; right: 0; margin: 0 auto; top: 50%; transform: translateY(-50%); bottom: initial; font-size: 20px !important;line-height: 180%;padding: 0 45px;}
  #banner #slideshow > div img{min-height: 350px; object-fit: cover;width: 100%;}
  #banner .flexslider .slides img {min-height: 230px;}
  #slideshow{min-height: auto; line-height: 0;}
  #about .container{margin-top: 0; padding: 40px 15px; flex-wrap: wrap; justify-content: center;}
  #about .row{padding: 0;}
  #about .text{margin: 0;}
  #about .btn {margin: 20px auto 50px;}
  #rating .badges{flex-wrap: wrap;}
  #services .btn {margin: 0 auto;}
  #services{padding: 40px 0;}
  #services .row>.row{padding: 30px 15px !important;}
  #services .row{    flex-wrap: wrap;columns: 1;padding: 0 15px;grid-template-columns: initial;text-align: center;justify-content: center;}
  #testimonials{padding: 55px 0;}
  #testimonials .container {margin-top: 0;padding: 0;flex-wrap: wrap;max-width: 549px; margin: 0 auto;}
  #testimonials .btn {margin: 20px 0 0;}
  #testimonials .right {padding: 30px 0;align-items: center; text-align: center;}
  #projects .grid{columns: 1; max-height: initial;}
  .ctc-form textarea{height: 100px;}
  #projects .grid{margin-top: 0;}
  #testimonials .left{padding: 30px 0;}
  #services .thumbs img{margin-bottom: 30px !important;}
  .ctc-form .thirds {grid-template-columns: 1fr;}
  #services .row>.row:nth-of-type(2){margin: 30px auto !important;}
  #footer .contact-form, #projects, #rating{padding: 40px 0;}
  #footer .contact-info{padding: 30px 0;}
  #footer .contact-info .row{    flex-wrap: wrap;justify-content: center;flex-direction: column;align-items: center;}
  #footer .middle {order: -1;}
  #footer .bottom-footer .row{justify-content: center;}
  #footer .bottom-footer {padding: 10px 0;text-align: center;}
}