@import url('https://fonts.googleapis.com/css?family=Encode+Sans+Semi+Expanded:300,700');

body{
	font-family: 'Encode Sans Semi Expanded', sans-serif;
}

strong {
	font-weight: bold;
}

i {
	transform: skew(4deg);
}

p {
	font-size: 18px;
}

.upcase {
	text-transform: uppercase;
}

.header {
	position: relative;
	width: 100%;
	top: 0;
	background-color: #fff;
	z-index: 9999;
}

.header__topbar {
	position: relative;
	display: block;
	width: 100%;
	background-color: #fafafa;
}

.header__topbar__inner {
	width: 100%;
	max-width: 1230px;
	padding: 5px 15px;
	margin: 0 auto;
	text-align: right;
}

.header__topbar__inner__text {
	font-size: 12px;
	margin: 0px;
	padding: 0px;
}

.phone {
	font-size: 16px;
	padding-right: 10px;
}

@media screen and (max-width: 768px) {
	.phone {
		display: none;
	}
}

.email {
	margin: 0px 20px 0px 0px;
}

.navbar {
	width: 100%;
	max-width: 1230px;
	padding: 12px 15px;
	margin: 0 auto;
}

.brand {
	width: 268px;
	display: inline-block;
}

@media screen and (max-width: 996px) {
	.brand {
		width: 150px;
	}
}

.brand img {
	position: relative;
	width: 100%;
}

.nav {
	display: inline-block;
	width:100%;
	margin: 0 auto;
	-webkit-box-shadow: inset 0px 0px 9px -1px rgba(0,0,0,0.75);
	-moz-box-shadow: inset 0px 0px 9px -1px rgba(0,0,0,0.75);
	box-shadow: inset 0px 13px 19px -23px rgba(0,0,0,0.75);
}

@media screen and (max-width: 996px) {
	.nav {
		display: none;
	}
}

.main {
	display: block;
	margin: 0px;
	padding: 0px;
}

.main > li {
	display: inline-block;
}

.main > li > a {
	display: block;
	padding: 10px 7px;
	font-size: 12px;
	font-weight: bold;
	color: #111;
}

.main > li > a:hover {
	text-decoration: none;
}

.sub-menu {
	visibility: hidden;
	opacity: 0;
	margin: 0px;
	padding: 0px;
	list-style: none;
	position: absolute;
	-webkit-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
}

.main > li:hover > .sub-menu {
	visibility: visible;
	opacity: 1;
	transition: all .2s;
}

.sub-menu > li {
	background-color: #fff;
	border-bottom: 1px solid #eaeaea;
	width: 225px;
}

.sub-menu > li:hover {
	background-color: #fafafa;
}

.sub-menu > li:last-child {
	border-bottom: none;
}

.sub-menu > li > a {
	display: block;
	padding: 10px 20px;
	font-size: 12px;
	font-weight: bold;
	color: #111;
}

.sub-menu > li > a:hover {
	text-decoration: none;
}

.main-about > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/about.svg) no-repeat center center;
	background-size: contain;
}

.main-services > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/services.svg) no-repeat center center;
	background-size: contain;
}

.main-casestudies > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/case-study.svg) no-repeat center center;
	background-size: contain;
}

.main-contact > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/contact.svg) no-repeat center center;
	background-size: contain;
}

.main-group > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/group.svg) no-repeat center center;
	background-size: contain;
}


.main-email:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/email.svg) no-repeat center center;
	background-size: contain;
}

@media screen and (max-width: 996px) {
	.main-about > a:before,
	.main-services > a:before,
	.main-casestudies > a:before,
	.main-contact > a:before,
	.main-group > a:before {
		width: 35px !important;
	}
}

.shadow {
    -webkit-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
}

.icon-xs {
	display: inline-block;
	max-width: 13px;
	max-height: 13px;
	vertical-align: middle;
	margin: 0px 5px 0px 0px;
}

#home-slider {
	margin-top: 0px;
}

@media screen and (max-width: 996px) {
	#home-slider {
	margin-top: 0px;
}
}

.carousel-content {
	position: absolute;
	display: block;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
	width: 100%;
	max-width: 768px;
	padding: 0 15px;
	margin: 0 auto;
	text-align: center;
	z-index: 10;
}

.carousel-img {
	position: relative;
	width: 100%;
	height: 500px;
	background: no-repeat center center;
	background-size: cover;
	z-index: 1;
}

@media screen and (max-width: 768px) {
	.carousel-img {
		height: 350px;
	}
}

.carousel-img:after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,.45);
	z-index: 5
}

.carousel-content__headline {
	font-weight: bold;
	color: #fff;
}

@media screen and (max-width: 768px) {
	.carousel-content__headline {
		font-size: 24px;
	}
}

.carousel-content__subheadline {
	font-size: 18px;
	color: #fff;
}

.carousel-content > a {
	display: inline-block;
	margin-top: 15px;
}

.section-sm {
	padding-top: 35px;
	padding-bottom: 35px;
}

.section__content__wrap {
	width: 100%;
	max-width: 992px;
	margin: 0 auto;
	padding: 0 15px;
}

.trust-icon {
	width: 100%;
	max-width: 350px;
	padding: 5px 15px;
}

.trust-icon:hover {
	opacity: .7;
	transition: all .2s;
}

.end {
	margin-bottom: 0px;
	padding-bottom: 0px;
}

.bg-gray {
	background-color: #f3f3f3;
}

.section {
	padding-top: 20px;
	padding-bottom: 65px;
}

@media screen and (max-width: 768px) {
	.section {
		padding-top: 35px;
		padding-bottom: 35px;
	}
}

.service-box {
	width: 100%;
	padding: 40px;
	text-align: center;
	border-bottom: 3px solid #28a745;
	background-color: #fff;
}

.service-box:hover {
	-webkit-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    transition: all .2s;
}


@media screen and (max-width: 996px) {
	.service-box {
		padding: 25px;
	}
}

@media screen and (max-width: 768px) {
	.service-box {
		margin-bottom: 1.5rem;
	}
}

@media screen and (min-width: 1200px) {
	.service-box {
		min-height: 493px;
	}
}

@media screen and (max-width: 1200px) {
	.service-box {
		min-height: 575px;
	}
}

@media screen and (max-width: 996px) {
	.service-box {
		min-height: 628px;
	}
}

@media screen and (max-width: 768px) {
	.service-box {
		min-height: auto;
	}
}

.service-box > h6 {
	font-weight: bold;
}

.service-box >  ul {
	position: relative;
	display: block;
	padding: 0px 0px 0px 10px;
	margin: 0px 0px 1rem 0px;
	width: 100%;
	max-width: 240px;
	left: 50%;
	transform: translateX(-50%);
	text-align: left;
}

.service-box > ul > li {
	list-style-image: url('/wp-content/themes/csl/img/greendot.svg');
	font-size: 14px;
	padding: 0px;
	margin-bottom: .75rem;
}

.service-box > a {
	color: #fff !important;
}
.icon-lg {
	max-width: 75px;
	margin: 0 auto 1.5rem;

}

.section__title {
	margin-bottom: 1rem;
}

.section__title:after {
	content: '';
	position: relative;
	display: block;
	width: 100px;
	height: 5px;
	background-color: green;
	margin: 1rem auto;
}

.section__title-white {
	margin-bottom: 1rem;
	color: white;
}

.section__title-white:after {
	content: '';
	position: relative;
	display: block;
	width: 100px;
	height: 5px;
	background-color: white;
	margin: 1rem auto;
}

.bot-rem-sm {
	margin-bottom: 2rem;
}

.bg-green {
	background-color: #218838;
}

.white {
	color: #fff;
}

.img100 {
	position: relative;
	width: 100%;
}

.testi-box {
	width: 100%;
	text-align: center;
	border-bottom: 3px solid green;
	background-color: #fafafa;
}

@media screen and (min-width: 1200px) {
	.testi-box {
		min-height: 622px;
	}
}

@media screen and (max-width: 1200px) {
	.testi-box {
		min-height: 660px;
	}
}

@media screen and (max-width: 996px) {
	.testi-box {
		min-height: 660px;
	}
}

@media screen and (max-width: 768px) {
	.testi-box {
		margin-bottom: 1.5rem;
		min-height: auto;
	}
}


.testi-box:hover {
	-webkit-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    transition: all .2s;
}

.testi-box p {
	font-size: 14px;
	padding: 35px 35px 0px 35px;
	text-align: left;
}

.testi-box p:last-child {
	padding-top: 0px;
	padding-bottom: 35px;
	margin-bottom: 0px;
}

.post-box {
	width: 100%;
	text-align: left;
	border-bottom: 3px solid green;
	background-color: #fafafa;
	padding: 35px;
	margin-bottom: 1.5rem;
}

.post-box:hover {
	-webkit-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    transition: all .2s;
}

a:hover {
	text-decoration: none !important;
}

.bg-dark-gray {
	background-color: #333;
}

.content-hero {
	margin-top: 0px;
}

@media screen and (max-width: 996px) {
	.content-hero {
		margin-top: 0px;
	}
}

.contact-box {
	width: 100%;
	text-align: left;
	border-bottom: 3px solid green;
	background-color: #fafafa;
	padding: 35px 35px 5px 35px;
}

.contact-box:hover {
	-webkit-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    -moz-box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
    box-shadow: 0 5px 15px 0 rgba(0,0,0,0.2);
}

.contact-box .wpcf7 input,
.contact-box .wpcf7 textarea {
	width: 100%;
	font-size: 14px;
	padding: 5px;
	margin-bottom: 10px;
	border: 1px solid #eaeaea !important;
	max-height: 100px
}

.wpcf7-form > p {
	margin-bottom: 0px;
}

.wpcf7-submit {
	margin-bottom: 0px;
}

.steve {
	width: 150px;
	float: left;
	padding: 0px 20px 20px 0px;
}

@media screen and (max-width: 768px) {
	.steve {
		padding: 0px 20px 0px 0px;
	}
}

.contact-mobile {
	display: none;
}

@media screen and (max-width: 768px) {
	.contact-mobile {
		display: inline-block;
	}
}

.contact-desktop {
	display: inline-block;
}

@media screen and (max-width: 768px) {
.contact-desktop {
	display: none;
	}
}

.nav-mobile {
	display: none;
}

@media screen and (max-width: 996px) {
	.nav-mobile {
		display: inline-block;
	}
}

.footer-nav__headline {
	color: #fff;
	border-bottom: 1px solid #fff;
	padding-bottom: 10px;
}

.footer-nav__headline a {
	color: #fff;
}

.footer-nav {
	margin: 0px 0px 0px 25px;
	padding: 0px;
}

.footer-nav > li {
	color: #fff;
	margin-bottom: 10px;
}

.footer-nav > li > a {
	color: #fff;
	font-size: 14px;
}

.footer-nav > li > a:hover {
	text-decoration: underline !important;
}

.main-about-white > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/about.svg) no-repeat center center;
	background-size: contain;
}

.main-services-white > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/services.svg) no-repeat center center;
	background-size: contain;
}

.main-casestudies-white > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/case-study.svg) no-repeat center center;
	background-size: contain;
}

.main-contact-white > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/contact.svg) no-repeat center center;
	background-size: contain;
}

.main-group-white > a:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/group.svg) no-repeat center center;
	background-size: contain;
}


.main-email-white:before {
	content: '';
	position: relative;
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	margin: -2px 5px 0px 0px;
	background: url(/wp-content/themes/csl/img/email.svg) no-repeat center center;
	background-size: contain;
}

.copy {
	color: #fff;
	font-size: 12px;
	border-top: 1px solid #fff;
	padding-top: 15px;
	margin-top: 15px;
	margin-bottom: 0px;
	padding-bottom: 0px;
}

#about,
#services,
#leadership,
#testimonials {
  margin-top: -69px;
  padding-bottom: 69px; 
  display: block; 
}

.responsive-menu-pro-item-link {
	font-weight: bold !important;
	padding-left: 15px !important;
	text-align:center;
}


#responsive-menu-pro-container {margin: 0 auto !important; max-width: 1230px !important;}


@media screen and (max-width: 996px) {

#responsive-menu-pro-container {
	margin-top: 51.83px !important;
}
}
#responsive-menu-pro > li > .responsive-menu-pro-submenu > li > a {
	padding-left: 16px !important;
}

 .carousel-content__headline {font-size: 44px;
}

.bg-green { background-color: #fff !important}
.white { color: #000000 !important;
	text-align: left;
}