/* Testing new container ideas */

body {
  background: #f9f8f4;
}

section[data-kc-fullwidth].kc_row {
  border-radius: 24px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  width: 95% !important;
  margin: 0 auto !important;
  margin-top: 40px !important;
  margin-bottom: 28px !important;
  left: initial !important;
  float: none !important;
  overflow: hidden;
}

body.page section[data-kc-parallax].kc_row {
  background-position: 50% 60px;
}

.entry-content {
  padding-bottom: 24px;
}

/* ---------------------------------------------------------------------- */
/*	Global/General
/* ---------------------------------------------------------------------- */

@font-face {
  font-family: 'fontello';
  src: url('../font/fontello.eot');
  src: url('../font/fontello.eot') format('embedded-opentype'),
       url('../font/fontello.woff2') format('woff2'),
       url('../font/fontello.woff') format('woff'),
       url('../font/fontello.ttf') format('truetype'),
       url('../font/fontello.svg') format('svg');
  font-weight: normal;
  font-style: normal;
}
/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */
/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */
/*
@media screen and (-webkit-min-device-pixel-ratio:0) {
  @font-face {
    font-family: 'fontello';
    src: url('../font/fontello.svg?37943176#fontello') format('svg');
  }
}
*/
 
 [class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: "fontello";
  font-style: normal;
  font-weight: normal;
  speak: never;
 
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: .2em;
  text-align: center;
  /* opacity: .8; */
 
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
 
  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;
 
  /* Animation center compensation - margins should be symmetric */
  /* remove if not needed */
  margin-left: .2em;
 
  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */
 
  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
 
  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}
 
.icon-down-open-big:before { content: '\e800'; } /* '' */
.icon-up-open-big:before { content: '\e801'; } /* '' */
.icon-search:before { content: '\e802'; } /* '' */
.icon-heart-empty:before { content: '\e803'; } /* '' */
.icon-heart:before { content: '\e804'; } /* '' */


/* =WordPress Core
-------------------------------------------------------------- */
.alignnone {
    margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}

.alignright {
    float:right;
    margin: 5px 0 20px 20px;
}

.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

a img.alignnone {
    margin: 5px 20px 20px 0;
}

a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption {
    max-width: 96%; /* Image does not overflow the content area */
    padding: 5px 3px 10px;
    text-align: center;
    font-size: 14px;
    font-style: italic;
}

.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}

.wp-caption img {
    border: 0 none;
    height: auto;
    margin: 0;
    max-width: 98.5%;
    padding: 0;
    width: auto;
}

.wp-caption .wp-caption-text {
    margin: 0;
    padding: 0 4px 5px;
    margin-top: 10px;
}

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	-webkit-clip-path: inset(50%);
	        clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important; /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

.screen-reader-text:focus {
	background-color: #eee;
	clip: auto !important;
	-webkit-clip-path: none;
	        clip-path: none;
	color: #444;
	display: block;
	font-size: 1em;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
	/* Above WP toolbar. */
}

/* ---------------------------------------------------------------------- */
/*	Global
/* ---------------------------------------------------------------------- */
/* html, body {
    height: 100%;
} */

body, h1, h2, h3, h4, h5, h6, p, span {
  -webkit-font-smoothing: antialiased; }

h1 {
  font-family: 'Raleway';
  font-weight: 500;
  color: white;
  font-size: 57px; }

h2 {
  font-size: 34px;
  font-family: 'Raleway';
  color: #a62d2c;
  font-weight: 500;
  margin-bottom: 25px; }

h3 {
  font-family: 'Raleway';
  color: #333;
  font-weight: 500;
  font-size: 28px;
  line-height: normal; }

h5 {
  color: #a62d2c;
}

strong {
  font-weight: 700;
}

body, p {
  font-family: 'Raleway';
  color: #333;
  font-size: 18px; }

a {
  color: #a62d2c;
  -o-transition: color .15s ease-in;
  transition: color .15s ease-in;
  -webkit-transition: color .15s ease-in; }

a:hover {
  color: #a62d2c;
  -o-transition: color .15s ease-in;
  transition: color .15s ease-in;
  -webkit-transition: color .15s ease-in; }

.single-post .entry-content a:not(.kc_button), body.home .entry-content p a, .page-id-43669 .entry-content p a {
  color: #333;
  border-bottom: 3px solid #a8ced4;
  -webkit-box-shadow: inset 0 -4px 0 #a8ced4;
  box-shadow: inset 0 -4px 0 #51a8ced49da8;
  -webkit-transition: background 0.15s cubic-bezier(0.33, 0.66, 0.66, 1);
  -o-transition: background 0.15s cubic-bezier(0.33, 0.66, 0.66, 1);
  transition: background 0.15s cubic-bezier(0.33, 0.66, 0.66, 1); }

.single-post .entry-content a:not(.kc_button):hover, body.home .entry-content p a:hover, .page-id-43669 .entry-content p a:hover {
  background: #a8ced4;
  text-decoration: none;
  color: #333; }

body.home h2 a {
  text-decoration: none; }

.kc-row-container .kc-wrap-columns, .kc_row_inner {
     display:-ms-flexbox;
     display:-webkit-box;
     display:flex;
     width:100%;
     -ms-flex-wrap:wrap;
         flex-wrap:wrap;
}

img {
  max-width: 100%;
  height: auto; }

.row {
    display: -webkit-flex;
}

.container .kc-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.kc-container {
  padding-right: 30px !important;
  padding-left: 30px !important; }

body section[data-kc-equalheight=true]>.kc-container .kc-wrap-columns {
  margin-left: -15px;
  margin-right: -15px;
}

@media (min-width: 576px) {
  .kc-container {
    max-width: 640px !important; } }

@media (min-width: 768px) {
  .kc-container {
    max-width: 820px !important; } }

@media (min-width: 992px) {
  .kc-container {
    max-width: 1030px !important; } }

@media (min-width: 1250px) {
  .kc-container {
    max-width: 1170px !important; } }

@media (max-width: 767px) {
  .kc-row-container.kc-container .kc-wrap-columns {
    margin-left: 0 !important;
    margin-right: 0 !important; } }

.wrapper {
  padding: 30px 0; }

.rt-diagonal-section {
  display: block;
  width: 100%;
  height: 100px;
  left: 0;
  position: absolute;
  top: -76px; }

.rt-diagonal-section-cta {
  position: absolute;
  width: 70px;
  height: 100%;
  top: 0;
  left: initial;
  right: -70px;
  display: block;
  z-index: 3; }

.noselect {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

.container {
  padding: 0 30px; }

.container-half .kc_column_inner {
  padding: 0 30px; }

@media (min-width: 576px) {
  .container {
    max-width: 640px; }
  .container-half .kc_column_inner {
    width: 640px !important;
    float: none;
    margin: 0 auto; } }

@media (min-width: 768px) {
  .container {
    max-width: 820px; }
    .container-half .kc_column_inner {
      width: auto !important;
      width: initial !important;
      padding: 0 30px; }
    .container-half {
      width: 100% !important;
      padding-left: calc((100vw - 820px) / 2); } }

@media (min-width: 992px) {
  .container {
    max-width: 1030px; }
    .container-half {
      width: 100% !important;
      padding-left: calc((100vw - 1030px) / 2); } }

@media (min-width: 1250px) {
  .container {
    max-width: 1170px; }
  .container-half {
    width: 100% !important;
    padding-left: calc((100vw - 1170px) / 2); } }

/* Page Banner */
.page-banner {
  height: 60vh !important;
}

@media (min-width: 768px) {
  .kc_col-sm-6 {
    width: 50%;
  }
}


/* ---------------------------------------------------------------------- */
/*	Buttons
/* ---------------------------------------------------------------------- */
.btn, .wpcf7 input[type=submit], .kc_button {
  display: inline-block;
  font-weight: normal;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  border: 1px solid transparent;
  border-radius: 50px;
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  line-height: 1.25;
  -webkit-transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;
  -o-transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out; }

.btn:focus, .wpcf7 input[type=submit]:focus, .btn:hover, .wpcf7 input[type=submit]:hover, .kc_button:hover, .kc_button:focus {
  outline: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  text-decoration: none; }

.btn.disabled, .wpcf7 input.disabled[type=submit], .btn:disabled, .wpcf7 input[type=submit]:disabled {
  opacity: .65; }

.btn:active, .wpcf7 input[type=submit]:active, .btn.active, .wpcf7 input.active[type=submit] {
  background-image: none; }

.btn, .kc_button {
  background: #a62d2c;
  padding: 12px 16px;
  font-weight: 500;
  border-radius: 8px;
  color: white;
  transition: all .4s; }

.btn:hover, .kc_button:hover {
  transition: all .4s;
  background: #c04240;
  color: #fff; }

.btn-inverse {
  background: transparent;
  color: #a62d2c; }

.btn-inverse:hover {
  background: #a62d2c;
  color: white; }

a.kc_button:hover {
  text-decoration: none;
}

.btn-arrow, .kc_button.btn-arrow {
  background: transparent;
  display: block;
  padding: 0;
  color: #a62d2c;
  font-size: 18px;
  -webkit-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out; }

.btn-arrow:after {
  content: url("../image/btn-arrow.png"); }

.btn-arrow:hover {
  text-decoration: none;
  -webkit-transform: translateX(10px);
  -ms-transform: translateX(10px);
      transform: translateX(10px);
  -webkit-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out; }

  .cli-plugin-button {
    border-radius: 8px;
  }

/* ---------------------------------------------------------------------- */
/*	Header and Navigation
/* ---------------------------------------------------------------------- */

.navbar>.container {
    -webkit-justify-content: space-between;
    display: -webkit-flex;
}
.wrapper-navbar {
  font-family: 'Raleway';
  font-weight: 500;
  font-size: 16px;
  padding-top: 20px;
  padding-bottom: 20px;
  background: #f9f8f4; }

.wrapper-navbar .nav-link {
  text-transform: lowercase;
  color: #333; }

.wrapper-navbar .nav-link:hover, .wrapper-navbar.rt-header-transparent #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:hover {
  color: #a62d2c;
  -webkit-transition: color .2s;
  -o-transition: color .2s;
  transition: color .2s; }

.wrapper-navbar.rt-header-transparent #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link {
  color: white; }

.wrapper-navbar.rt-header-transparent .dropdown-menu .nav-link {
  color: #333; }

.wrapper-navbar.rt-header-transparent {
  position: absolute;
  width: 100%;
  background-color: transparent;
  z-index: 99; }

.wrapper-navbar .btn-cta {
  color: #fff;
  background: #a62d2c;
  font-family: 'Raleway';
  font-weight: 500;
  text-transform: lowercase;
  border: none;
  border-radius: 8px;
  margin-left: auto;
  padding: 12px 16px; }

.wrapper-navbar .btn-cta:hover {
  background: #85bac2;
  -webkit-transition: all .2s;
  -o-transition: all .2s;
  transition: all .2s; }

.navbar-collapse {
    position: relative;
}

.wrapper-navbar .sticky-btn-container {
    position: absolute;
    top: 18px;
    right: 12px;
    z-index: 999;
    width: 100px;
}

.wrapper-navbar .sticky-btn-contact {
position: fixed;
display: none;
background: #a62d2c;
color: #fff;
font-family: 'Raleway';
font-weight: 500;
text-transform: lowercase;
border-radius: 8px;
margin-left: auto;
padding: 12px 16px; }

.wrapper-navbar .sticky-btn-contact:hover {
    background: #519da8;
    border-color: #519da8;
    -o-transition: background .2s, border-color .2s;
    transition: background .2s, border-color .2s;
    -webkit-transition: background .2s, border-color .2s;
}

.navbar {
  padding: 0 30px; }

.wrapper-navbar .navbar-toggler {
    font-family: 'Raleway';
    border-radius: 0;
    cursor: pointer;
    width: auto;
    height: auto;
    padding: 10px;
    color: #fff;
    border: none;
    z-index: 10000;
    outline: none; }

.wrapper-navbar .navbar-toggler.collapsed {
  color: #a62d2c;
  border-color: #a62d2c;
  border: 1px solid #a62d2c;
}

.wrapper-navbar.rt-header-transparent .navbar-toggler {
  color: white; }

.wrapper-navbar.rt-header-transparent .navbar-toggler.collapsed {
    border: 1px solid #fff;
}

.wrapper-navbar .navbar-toggler span::after {
    content: url("../image/close.png");
}

.wrapper-navbar .navbar-toggler.collapsed span::after {
    content: 'MENU';
}

.custom-logo-link img {
  max-width: none;
  width: 150px; }

@media (min-width: 767px) {
  .navbar {
    padding: 0 15px; }
  .wrapper-navbar .navbar-brand {
    margin-right: 25px; }
  .wrapper-navbar .navbar-nav li {
    padding: 0 20px; }}

@media screen and (max-width: 767px) {
  body.menu-open {
    overflow-y: hidden;
  }
  .site {
    position: relative;
    overflow: hidden;
  }
  .wrapper-navbar .navbar {
    position: inherit;
  }
  .wrapper-navbar .navbar-nav li {
    padding: calc(.01*100vw); }
  .navbar-collapse.collapse {
    background: #519ca8;
    position: fixed;
    bottom: 0;
    top: 0;
    width: 100%;
    padding-top: 75px;
    padding-bottom: 32px;
    text-align: center;
    right: -100%;
    z-index: 9999;
    overflow-y: scroll;
    display: block; }
  .navbar-collapse.navbar-opening {
    right: 0;
    -webkit-transition: right .2s;
    -o-transition: right .2s;
    transition: right .2s;
    position: fixed;
    bottom: 0;
    top: 0;
    width: 100%;
    padding-top: 75px;
    text-align: center;
    z-index: 98;
    height: auto !important; }
  .navbar-collapse.navbar-closing {
    z-index: 98;
    right: -100%;
    -webkit-transition: right .2s;
    -o-transition: right .2s;
    transition: right .2s; }
  .navbar-collapse.collapse.show {
    right: 0; }
  .navbar-collapse.collapsing {
    background: #519ca8;
    position: fixed;
    bottom: 0;
    top: 0;
    width: 100%;
    padding-top: 75px;
    text-align: center;
    height: auto !important; }
  .menu-main-menu-container {
    margin-bottom: 25px; } }

@media screen and (max-width: 767px) {
    .wrapper-navbar .btn-cta {
      color: white;
      border-color: white;
      margin-top: 20px; }

    .navbar-collapse.collapse ul li a {
        color: white;
    }
    .navbar-collapse.navbar-opening ul li a {
        color: white;
    }
}

/* ---------------------------------------------------------------------- */
/*	Page
/* ---------------------------------------------------------------------- */
#page-wrapper {
  background: #f9f8f4;
  padding: 0;
  overflow: hidden; }

/*
/* Simple Page Template
/* ---------------------------------------------------------------------- */
.page-template-default #page-wrapper:not(.kingcomposer), .page-template-simple-page #page-wrapper, #page-wrapper:not(.kingcomposer) {
  background: #f4f2ec;
  padding-top: 0;
  padding-bottom: 75px;
}

.page-template-default .wrapper:not(.kingcomposer) .page-header, .page-template-simple-page .page-header, body:not(.error404) .page-header {
  background: #f9f8f4;
  padding-top: 50px;
  padding-bottom: 50px;
}

.page-template-default .wrapper:not(.kingcomposer) h1.title, .page-template-simple-page h1.title, h1.title {
  color: #a62d2c;
  font-size: 48px;
  font-family: 'Raleway';
  font-weight: 700;
  margin: 0;
}

.page-template-default .wrapper:not(.kingcomposer) #content {
  padding-top: 50px;
}

.page-template-default .wrapper:not(.kingcomposer) h4, .page-template-simple-page h4 {
  margin-bottom: 20px;
}

.page-template-default .wrapper:not(.kingcomposer) .rt-diagonal-section, .page-template-simple-page .rt-diagonal-section, body:not(.kingcomposer) .rt-diagonal-section {
  margin-bottom: 20px;
  height: 50px;
  background: #f9f8f4;
}

@media (max-width: 767px) {
  .page-template-default .wrapper:not(.kingcomposer) h1.title, .page-template-simple-page h1.title {
    font-size: 28px;
  }
}

/* ---------------------------------------------------------------------- */
/*	Section Background Text
/* ---------------------------------------------------------------------- */
.rt-background-text {
  text-transform: lowercase;
  position: absolute;
  font-weight: 700;
  color: #f4f2ec;
  right: -20px;
  font-size: 75px;
  text-indent: -75px;
  line-height: 70px;
  height: 500px;
  top: 0; }

@media (min-width: 500px) {
  .rt-background-text {
    font-size: 150px;
    text-indent: -150px;
    line-height: 150px;
    top: 75px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
         align-items: center; } }

#awards .rt-background-text {
    color: #952928;
    right: auto;
    top: 25px;
    left: 65px;
}

@media (min-width: 500px) {
    #awards .rt-background-text {
        font-size: 120px;
        line-height: 100px;
        left: 125px;
        top: 25px;
    }
}

@media (min-width: 992px) {
    #awards .rt-background-text {
        top: 130px;
        left: 130px;
      }
}

#process .rt-background-text {
    color: #952928;
}

@media (max-width: 768px) {
    #process .rt-background-text {
        font-size: 120px;
        line-height: 100px;
        top: -250px;
    }
}

@media (max-width: 500px) {
    #process .rt-background-text {
        color: #952928;
        top: 25px;
        font-size: 75px;
        line-height: 65px;
        left: 70px;
    }
}

#process .rt-arrow { margin-left: -50px; }



/* ---------------------------------------------------------------------- */
/*	Home: Our Process
/* ---------------------------------------------------------------------- */
.rt-slider {
  clear: both; }

#our_process {
  font-family: 'Raleway';
  font-size: 18px; }

.process-callout {
  color: #a62d2c; }

/* ---------------------------------------------------------------------- */
/*	Home: Our Work
/* ---------------------------------------------------------------------- */
.our-work-block {
  position: relative;
  height: 150px;
  width: 100%;
  margin: 25px 0; }

.our-work-block a {
  opacity: 0;
  z-index: 0;
  position: absolute;
  -webkit-transition: opacity .5s ease-in;
  -o-transition: opacity .5s ease-in;
  transition: opacity .5s ease-in;
  width: 100%; }

.our-work-block a.active {
  opacity: 1;
  z-index: 1; }

  .our-work-image {
      height: 150px;
      border-radius: 24px;
  }

@media (min-width: 430px) {
    .our-work-block {
        height: 280px;
    }

    .our-work-image {
        height: 280px;
    }
}

@media (min-width: 767px) {
  .our-work {
    position: relative;
    top: -220px;
    height: 500px; }
  .our-work-image {
      height: 180px;
  }
  .our-work-block {
    /* First 3 are for IE11 */
    position: relative;
    height: auto;
    width: auto;
    /* For everything else */
    position: initial;
    height: initial;
    width: initial; }
  .our-work-block a {
    width: 38%; }
  .our-work-block-01 a {
    height: 180px;
    overflow: hidden;
    position: absolute;
    right: 0; }
  .our-work-block-02 a {
    margin-top: 50px;
    height: 180px;
    position: absolute;
    overflow: hidden;
    right: 0;
    top: 180px; }
  .our-work-block-03 a {
    position: absolute;
    top: 180px;
    left: 0;
    margin-top: 50px;
    height: 180px;
    overflow: hidden;
    width: 58%; } }

@media (min-width: 992px) {
    .our-work {
        height: 600px;
        top: -300px; }
    .our-work-image {
        height: 280px;
    }
    .our-work-block {
        margin: initial; }
    .our-work-block-01 a {
        height: 280px;
    }
    .our-work-block-02 a {
        height: 280px;
        top: 280px;
    }
    .our-work-block-03 a {
        height: 280px;
        top: 280px;
    }
}


/* ---------------------------------------------------------------------- */
/*	Contact Form
/* ---------------------------------------------------------------------- */
.form-control, .wpcf7 input[type=text],
.wpcf7 input[type=search],
.wpcf7 input[type=url],
.wpcf7 input[type=tel],
.wpcf7 input[type=number],
.wpcf7 input[type=range],
.wpcf7 input[type=date],
.wpcf7 input[type=month],
.wpcf7 input[type=week],
.wpcf7 input[type=time],
.wpcf7 input[type=datetime],
.wpcf7 input[type=datetime-local],
.wpcf7 input[type=color],
.wpcf7 input[type=email],
.wpcf7 input[type=file],
.wpcf7 input[type=submit],
.wpcf7 select,
.wpcf7 textarea, .wpcf7 .wpcf7-validation-errors {
  -webkit-appearance: none;
  display: block;
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: 20px;
  line-height: 1.25;
  color: #495057;
  background-color: #fff;
  background-image: none;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 0.25rem;
  -webkit-transition: border-color ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;
  transition: border-color ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s;
  -o-transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
  transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
  transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s, -webkit-box-shadow ease-in-out 0.15s; }

.wpcf7 input:not(:placeholder-shown), .wpcf7 textarea:not(:placeholder-shown) {
    border-color: #495057 !important;
}

.white-form .wpcf7 input:not(:placeholder-shown):not([type=submit]), .white-form .wpcf7 textarea:not(:placeholder-shown):not([type=submit]) {
  border-color: #fff !important;
}

/* WHITE FORM placeholder */

.white-form .wpcf7 input::-webkit-input-placeholder {
  color: #fff !important;
  opacity: 1; }

.white-form .wpcf7 input::-moz-placeholder {
  color: #fff !important;
  opacity: 1; }

.white-form .wpcf7 input:-ms-input-placeholder {
  color: #fff !important;
  opacity: 1; }

.white-form .wpcf7 input::-ms-input-placeholder {
  color: #fff !important;
  opacity: 1; }

.white-form .wpcf7 input::placeholder {
  color: #fff !important;
  opacity: 1; }

/* END White Form placeholder */
.form-control, .wpcf7 .wpcf7-validation-errors, .wpcf7 input[type=color], .wpcf7 input[type=date], .wpcf7 input[type=datetime-local], .wpcf7 input[type=datetime], .wpcf7 input[type=email], .wpcf7 input[type=file], .wpcf7 input[type=month], .wpcf7 input[type=number], .wpcf7 input[type=range], .wpcf7 input[type=search], .wpcf7 input[type=submit], .wpcf7 input[type=tel], .wpcf7 input[type=text], .wpcf7 input[type=time], .wpcf7 input[type=url], .wpcf7 input[type=week], .wpcf7 select, .wpcf7 textarea {
  border-radius: 0;
  border: 2px solid #a62d2c;
  background: transparent; }

.wpcf7-form label {
  display: none; }

.wpcf7 input[type=tel]::-webkit-input-placeholder, .wpcf7 input[type=email]::-webkit-input-placeholder, .wpcf7 input[type=text]::-webkit-input-placeholder, .wpcf7 textarea::-webkit-input-placeholder {
  color: #a62d2c; }

.wpcf7 input[type=tel]:-ms-input-placeholder, .wpcf7 input[type=email]:-ms-input-placeholder, .wpcf7 input[type=text]:-ms-input-placeholder, .wpcf7 textarea:-ms-input-placeholder {
  color: #a62d2c; }

.wpcf7 input[type=tel]::-ms-input-placeholder, .wpcf7 input[type=email]::-ms-input-placeholder, .wpcf7 input[type=text]::-ms-input-placeholder, .wpcf7 textarea::-ms-input-placeholder {
  color: #a62d2c; }

.wpcf7 input[type=tel]::-moz-placeholder, .wpcf7 input[type=email]::-moz-placeholder, .wpcf7 input[type=text]::-moz-placeholder, .wpcf7 textarea::-moz-placeholder {
  color: #a62d2c; }

.wpcf7 input[type=tel]::placeholder, .wpcf7 input[type=email]::placeholder, .wpcf7 input[type=text]::placeholder, .wpcf7 textarea::placeholder {
  color: #a62d2c; }

.wpcf7 input[type=tel]:focus, .wpcf7 input[type=text]:focus, .wpcf7 input[type=email]:focus, .wpcf7 textarea:focus {
  background: transparent;
  border-color: #495057; }

.wpcf7 input[type=submit] {
  max-width: 150px;
  margin-top: 20px;
  background: transparent;
  border-color: #cc3333 !important;
  color: #a62d2c;
  text-transform: lowercase; }

.wpcf7 input[type=submit]:hover, .wpcf7 input[type=submit]:focus {
  cursor: pointer;
  background: #a62d2c;
  border-color: #a62d2c;
  color: white;
  -webkit-transition: .2s color, .2s background;
  -o-transition: .2s color, .2s background;
  transition: .2s color, .2s background; }

.white-form .wpcf7 input[type=submit] {
  max-width: 150px;
  margin-top: 20px;
  background: transparent;
  border-color: #fff !important;
  color: #fff;
  text-transform: lowercase; }

.white-form .wpcf7 input[type=submit]:hover {
  cursor: pointer;
  background: #fff;
  border-color: #fff;
  color: #a62d2c;
  -webkit-transition: .2s color, .2s background;
  -o-transition: .2s color, .2s background;
  transition: .2s color, .2s background; }

div.wpcf7-mail-sent-ok {
    border-color: #a62d2c;
    margin: 0;
}

.wpcf7 .wpcf7-validation-errors {
    margin: 0;
}

/* Gravity Forms */
input[type=text], input[type=tel], input[type=email], textarea {
  border-radius: 0;
  border: 2px solid #a62d2c;
  background: 0 0;
  padding: .5rem .75rem !important;
}

input:focus, textarea:focus {
  border-color: black;
  outline: none;
}
::-webkit-input-placeholder {
  color: #a62d2c;
}
::-moz-placeholder {
  color: #a62d2c;
}
:-ms-input-placeholder {
  color: #a62d2c;
}
::-ms-input-placeholder {
  color: #a62d2c;
}
::placeholder {
  color: #a62d2c;
}

.gform_wrapper input[type=submit] {
  max-width: 150px;
  background: 0 0;
  border: 2px solid #a62d2c;
  color: #a62d2c;
  border-radius: 0;
  text-transform: lowercase;
  width: 100%;
  padding: .5rem .75rem;
  font-size: 20px;
  line-height: 1.25;
  cursor: pointer;
  min-width: 150px;
}

.gform_wrapper input[type=submit]:hover {
  background: #a62d2c;
  color: white;
  -webkit-transition: all .2s;
  -o-transition: all .2s;
  transition: all .2s;
}

body .gform_wrapper .gform_footer {
  margin-top: 0;
}

.gform_wrapper li.hidden_label textarea {
  margin-top: 8px;
}

body .gform_wrapper.gravity-theme .gform_footer, body .gform_wrapper.gravity-theme .gform_page_footer {
  margin: 0;
  padding: 0;
}

/* ---------------------------------------------------------------------- */
/*	Footer
/* ---------------------------------------------------------------------- */

@media (min-width: 992px) {
    footer {
        height: 490px;
        bottom: 0;
        width: 100%;
        z-index: -1;
        background-color: #333;
    }
}

#wrapper-footer {
  font-size: 16px;
  background: #333;
  padding-top: 100px;
  padding-bottom: 75px; }
  #wrapper-footer a {
    color: #c9c8c8; }
  #wrapper-footer a:hover {
      color: #85bac2;
      text-decoration: none;
  }
  #wrapper-footer .site-info {
    -webkit-box-align: end;
        -ms-flex-align: end;
         align-items: flex-end;
    margin-top: 45px;
    color: white; }
  #wrapper-footer p {
    font-size: 16px;
    color: #c9c8c8; }
  #wrapper-footer .footer-widget .title {
    color: #f9f8f4;
    font-weight: bold;
    font-family: 'Raleway';
    font-size: 16px;
    margin-bottom: 20px; }

.footer-col {
  margin-bottom: 50px; }

.footer-col:first-child {
margin-bottom: 0; }

 .footer-col ul {
     margin: 0;
     padding: 0; }

 .footer-col ul li {
     padding: 5px 0; }

 .website-by {
     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-box-orient: vertical;
     -webkit-box-direction: normal;
         -ms-flex-direction: column;
          flex-direction: column;
     margin-bottom: 15px;
 }

 .website-by img {
     width: 150px;
 }

 .copyright {
     text-align: center;
 }

 .copyright p {
     margin-bottom: 0;
 }

 .social_widget h5 {
     display: none;
 }

 .social-widget-icons-container {
     margin-left: 5px;
     margin-top: 15px;
 }

 .social-widget-icons-container i {
     color: white;
     font-size: 22px;
     margin-left: 15px;
 }

 .social-widget-icons-container i:hover {
     color: #519ca8;
     -o-transition: color .2s;
     transition: color .2s;
     -webkit-transition: color .2s;
 }

@media (min-width: 767px) {
    .copyright {
        text-align: left;
    }

    .website-by {
        margin-bottom: 0;
        -webkit-box-pack: end;
            -ms-flex-pack: end;
             justify-content: flex-end;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
            -ms-flex-direction: row;
             flex-direction: row;
    }

    .social-widget-icons-container {
        margin-top: 0;
    }

    .social-widget-icons-container i {
        margin-left: 5px;
    }

    .footer-col:nth-child(2) {
        padding-top: 0px;
    }

    .footer-col:first-child {
        margin-bottom: 50px; }
}

@media (min-width: 992px) {
  .footer-col {
    margin-bottom: 0; }

.social-widget-icons-container i {
    margin-left: 15px;
} }

/* ---------------------------------------------------------------------- */
/*	404 page
/* ---------------------------------------------------------------------- */
#wrapper-404 {
  background-image: url("../image/redtree-bg.jpg");
  background-color: #cdc8ba;
  background-size: cover;
  padding-top: 200px;
  padding-bottom: 200px; }

#wrapper-404 h2, #wrapper-404 p {
  color: white; }

#wrapper-404 #menu-main-nav {
  list-style: none;
  padding: 0; }

#wrapper-404 #menu-main-nav .menu-item {
  font-weight: bold; }


/* ---------------------------------------------------------------------- */
/*	Animations
/* ---------------------------------------------------------------------- */

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

@-webkit-keyframes rtBounceInLeft {
    from,
    60%,
    75%,
    90%,
    to {
      -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
      animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    0% {
      opacity: 0;
      -webkit-transform: translate3d(-500px, 0, 0);
      transform: translate3d(-500px, 0, 0);
    }

    60% {
      opacity: 1;
      -webkit-transform: translate3d(25px, 0, 0);
      transform: translate3d(25px, 0, 0);
    }

    75% {
      -webkit-transform: translate3d(-10px, 0, 0);
      transform: translate3d(-10px, 0, 0);
    }

    90% {
      -webkit-transform: translate3d(5px, 0, 0);
      transform: translate3d(5px, 0, 0);
    }

    to {
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
    }
}

@keyframes rtBounceInLeft {
    from,
    60%,
    75%,
    90%,
    to {
      -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
      animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }

    0% {
      opacity: 0;
      -webkit-transform: translate3d(-500px, 0, 0);
      transform: translate3d(-500px, 0, 0);
    }

    60% {
      opacity: 1;
      -webkit-transform: translate3d(25px, 0, 0);
      transform: translate3d(25px, 0, 0);
    }

    75% {
      -webkit-transform: translate3d(-10px, 0, 0);
      transform: translate3d(-10px, 0, 0);
    }

    90% {
      -webkit-transform: translate3d(5px, 0, 0);
      transform: translate3d(5px, 0, 0);
    }

    to {
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
    }
}

.rtBounceInLeft {
    -webkit-animation-name: rtBounceInLeft;
    animation-name: rtBounceInLeft;
    visibility: visible !important;
}

  @-webkit-keyframes slideInUp {
    from {
      -webkit-transform: translate3d(0, 100%, 0);
      transform: translate3d(0, 100%, 0);
      visibility: visible;
    }

    to {
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
    }
  }

  @keyframes slideInUp {
    from {
      -webkit-transform: translate3d(0, 100%, 0);
      transform: translate3d(0, 100%, 0);
      visibility: hidden;
    }

    to {
      -webkit-transform: translate3d(0, 0, 0);
      transform: translate3d(0, 0, 0);
      visibility: visible;
    }
  }

  .slideInUp {
    -webkit-animation-name: slideInUp;
    animation-name: slideInUp;
    visibility: visible !important;
  }

  .blog-post-item {
      visibility: hidden;
  }

  @-webkit-keyframes rtFadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: hidden;
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    visibility: visible;
  }
}

@keyframes rtFadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: hidden;
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    visibility: visible;
  }
}

.rtFadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
  visibility: visible;
}

/* Miscellaneous */
@media (min-width: 767px) {
    .mega-menu-item-1584 { display: none !important; }
    .btn-call { display: none; }
}

@media (max-width: 767px) {
    .btn-contact { display: none !important; }
}

.video-responsive {
    width: 100% !important;
    height: auto !important;
}

.full-name-fields span.first-name {
  margin-bottom: 16px;
  display: block;
}


@media (min-width: 768px) {
  .full-name-fields {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .full-name-fields span.first-name {
    margin-right: 16px;
    margin-bottom: 0;
  }
}

.rt-tooltip-wrapper {
  position: relative;
  display: inline;
}

.rt-tooltip-wrapper .fa {
  cursor: pointer;
  font-size: 12px;
  color: #aba8a0;
}

.rt-tooltip {
  position: absolute;
  z-index: 1070;
  visibility: hidden;
  opacity: 0;
  background: white;
  font-size: 14px;
  padding: 8px;
  -webkit-transition: opacity .3s;
  -o-transition: opacity .3s;
  transition: opacity .3s;
  min-width: 200px;
  top: 18px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  border: #e7e7e7;
  border-radius: 3px;
  -webkit-box-shadow: 1px 1px 5px 1px #88888812;
          box-shadow: 1px 1px 5px 1px #88888812;
}

@media (max-width: 500px) {
  .rt-tooltip {
    left: initial;
    -webkit-transform: none;
        -ms-transform: none;
            transform: none;
  }
}

.rt-tooltip-wrapper .fa:hover {
  color: #519da8;
}

.rt-tooltip-wrapper .fa:hover ~ .rt-tooltip {
  visibility: visible;
  opacity: 1;
  -webkit-transition: opacity .3s;
  -o-transition: opacity .3s;
  transition: opacity .3s;
}

h1, h2, h3, h4 {
  font-family: 'Raleway', sans-serif !important;
}

h1 {
  font-weight: 500 !important;
}

.single-job-listing .gform_wrapper {
  background: white;
  padding: 24px;
  border-radius: 16px;
}

.single-job-listing .gform_heading {
  margin-bottom: 16px;
}

.gform_required_legend {
  display: none !important;
}

/* Reverse column order on mobile */
@media (max-width: 767px) {
  .kc_row_inner.reverse-order-mobile {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
  }

  .kc_row_inner.reverse-order-mobile .kc_column_inner:first-child {
      -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
      order: 2;
  }

  .kc_row_inner.reverse-order-mobile .kc_column_inner:last-child {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
}

@media (max-width: 767px) {
  .kc_row.reverse-order-mobile {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
  }

  .kc_row.reverse-order-mobile .kc_column:first-child {
      -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
      order: 2;
  }

  .kc_row.reverse-order-mobile .kc_column:last-child {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
}

@media (max-width: 1024px) {
  .kc_row.reverse-order-mobile-1024px {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
  }

  .kc_row.reverse-order-mobile .kc_column:first-child {
      -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
      order: 2;
  }

  .kc_row.reverse-order-mobile .kc_column:last-child {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
}

@media (max-width: 999px) {
  .kc_row.collapse-999px .kc_column_inner {
    width: 100%;
    margin-bottom: 10px;
  }
}

img.square {
  aspect-ratio: 1;
  object-fit: cover;
}

/* Service page circles */
#circles {
  margin-top: -100px;
  padding-top: 0;
  padding-bottom: 32px;
}

#circles strong {
  color: #a62d2c;
}

#circles .kc_row_inner {
  background: #f2f1eb url('../image/lines_white_trans-1-1024x1002.png') center center/auto no-repeat scroll;
  box-shadow: 2px 2px 8px 2px rgba(0,0,0,.1);
  min-height: unset;
}

#circles .kc_column:nth-child(even) .kc_row { 
  margin-top: 0;
}

@media (min-width: 1201px) {
  #circles .kc_column:nth-child(even) .kc_row {
    margin-top: 100px;
  }
}

@media (min-width: 768px) and (max-width: 1200px) {

  #circles p {
    font-size: 24px;
  }

  #circles .kc_row {
    min-height: unset;
    float: none;
    max-width: 400px;
  }

  #circles .kc_column:nth-child(odd) .kc_row {
    margin-left: auto;
  }

  #circles .kc_column:nth-child(2) {
    margin-top: 25%;
  }

  #circles .kc_column:nth-child(3) {
    margin-top: -25%;
  }

  #circles .kc_column {
    width: 50%;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  #circles p {
    font-size: 20px;
  }

  #circles .kc_row {
    max-width: unset;
  }
}

@media (min-width: 1201px) and (max-width: 1400px) {
  #circles p {
    font-size: 18px;
  }
}

@media (min-width: 1401px) and (max-width: 1600px) {
  #circles p {
    font-size: 20px;
  }
}