
*, *:after, *:before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
	background:white;
	font-family: 'Prompt', sans-serif;
  font-weight: 400;
	font-size: 16px;
	margin:0;
	color: #1d1d1d;
  position: relative;
  letter-spacing: .05em;
  line-height: 1.2;
  padding-top: 125px;
	-moz-osx-font-smoothing:grayscale;
	-webkit-font-smoothing:antialiased;
}

.cf:after { 
	content:"";
	display:table;
	clear:both;
}

.wc{
	width:100%;
	max-width: 1070px;
	min-width:320px;
  padding: 0 40px;
	margin:0 auto;
	box-sizing:border-box;
	-moz-box-sizing:border-box;
	-webkit-box-sizing:border-box;
}


.wc > :not(.btn):last-child {
  margin-bottom: 0;
}

.block {
  padding-top: 90px;
  padding-bottom: 90px;
}


.center{
  text-align: center;
}

p, h1, h2, h3, h4, h5, ul{
	margin:0;
}

h1, h2, h3, h4, h5 {
  color: #602224;
}

h1 {
  font-size: 16px;
  padding-bottom: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .2em;
}

h3{
  font-size: 16px;
  line-height: 1.5;
  padding-bottom:14px;
  font-weight: 600;
  letter-spacing: normal;
}


p{
	line-height: 1.5;
	padding-bottom:18px;
  font-weight: 400;
  letter-spacing: normal;
}

.dotted-list {
  list-style-type: none;
  padding-left: 0;
  padding-bottom:18px;
}

.dotted-list li{
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: normal;
  position: relative;
  padding-left: 10px;
}

.dotted-list li:before {
  content: '';
  position: absolute;
  top:50%;
  left: 0;
  margin-top: -1px;
  width: 2px;
  height: 2px;
  background: black;
  border-radius: 50%;
}

b {
  font-weight: 600;
}

a, a:focus{
   outline: 0;
}

a{
  color: #ef4656;
  text-decoration: none;
	transition:.3s color, .3s background;
	-webkit-transition:.3s color, .3s background;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
    -webkit-tap-highlight-color: transparent; /* For some Androids */
}

a:hover {
  color:#f46775;
}

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

input{
  outline:none;
}

.btn {
  display: inline-block;
  background: #ef4656;
  color: #602224;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 17px 35px;
  font-weight: 600;
}

.btn .fa {
  font-size: .7em;
  position: relative;
  top: -2px;
  font-weight: 400;
}

.btn:hover {
  background: #f46775;
  color: #602224;
}

.page-wrapper {
  overflow-x: hidden;
}

/*header styles*/


.main-header {
  background: white;
  padding: 35px 0;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99;
 /* box-shadow: 0 2px 3px rgba(0,0,0,0.1);*/
}

.main-header .wc {
  max-width: 1600px;
  position: relative;
}

.main-header .logo {
  float: left;
  display: block;
  font-size: 27px;
  color: #602224;
  font-weight: 500;
  border-bottom: 3px solid #602224;
  padding-right: 12px;
  padding-bottom: 1px;
  letter-spacing: .1em;
}

.main-header .logo img {
    display: block;
}

.main-nav{
  padding-top: 2px;
  position: absolute;
  top: 5px;
  left: 50%;
  transform: translateX(-50%);
  margin-right: -50%;
  margin-top: 3px;
}

.main-nav ul{
  padding: 0;
  list-style-type: none;
}

.main-nav li {
  display: inline-block;
  padding-left: 0;
  padding-right: 25px;
  position: relative;
}

.main-nav li:last-of-type {
  padding-right: 0;
}


.main-nav li a{
  color: #602224;
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 600;
}


.main-nav li a:hover, .main-nav li.current-menu-item > a{
  color: #5b5b5b;
}

.social-menu {
  list-style-type: none;
  padding-left: 0;
  float: right;
  margin-top: 10px;
}

.social-menu li {
  display: inline-block;
  padding-right: 15px;
}

.social-menu li:last-of-type {
  padding-right: 0;
}

.social-menu li a {
  color: #ef4656;
  font-size: 15px;
}

.social-menu li a:hover {
  color: #e57983;
}

.nav-icon {
  float: right;
  width: 28px;
  height: 20px;
  position: relative;
  transform: rotate(0deg);
  transition: .5s ease-in-out;
  cursor: pointer;
  z-index: 10;
  margin-top: 10px;
  display: none;
}

.nav-icon span {
  display: block;
  position: absolute;
  height: 2px;
  width: 100%;
  background: #ef4656;
  opacity: 1;
  left: 0;
  transform: rotate(0deg);
  transition: .3s ease-in-out; 
}
    
.nav-icon span:nth-child(1) {
  top: 0px;
  transform-origin: left center; 
}

.nav-icon span:nth-child(2) {
  top: 7px;
  transform-origin: left center;
}

.nav-icon span:nth-child(3) {
  top: 14px;
  transform-origin: left center; 
}

.nav-icon.open span:nth-child(1) {
  transform: rotate(45deg);
  top: -2px;
  left: 5px; 
}

.nav-icon.open span:nth-child(2) {
  width: 0%;
  opacity: 0;
}

.nav-icon.open span:nth-child(3) {
  transform: rotate(-45deg);
  top: 18px;
  left: 5px;
}


/* Banner section*/

.banner-block {

}


.banner-block h1 {
  font-size: 40px;
  color: #602224;
  line-height: 1.1;
  text-align: left;
  letter-spacing: normal;
  position: relative;
  z-index: 5;
}


/* About styles*/


.about-block {
  margin-top: -230px;
  position: relative;
   padding-top: 575px;
}

.about-block:after {
  content: '';
  position: absolute;
  z-index: 1;
  background: url('imgs/about-bg.jpg') no-repeat center center;
  top: 132px;
  right: 50%;
  margin-right: -767px;
  height: 627px;
  width: 1275px;
}

.about-block .wc  {
  position: relative;
}

.about-block .wc:before {
  content: '';
  position: absolute;
  z-index: 1;
  background: #f1f1f1;
  top: -580px;
  right: 40px;
  height: 317px;
  width: 2000px;

}

.about-block:after {
  content: '';
  position: absolute;
  z-index: 2;
}

.about-content {
  background: white;
  max-width: 500px;
  padding: 60px 60px 70px;
  float: right;
  position: relative;
  z-index: 3;
}



/* Approach styles*/


.approach-overview {
  background: url('imgs/approach-bg.jpg') center center / cover;
  padding: 122px 0;
  margin-bottom: 50px;
}

.approach-overview-content {
  margin: 0 auto;
  background: white;
  max-width: 500px;
  padding: 60px;
}

.approach-overview-content h1 {
  text-align: center;
}

.approach-overview-content :last-child {
  padding-bottom: 0;
}

.approach-info {
  max-width: 500px;
  margin: 0 auto;
  padding-bottom: 27px;
}

/* Services styles*/

.services-block > .wc {
  position: relative;
  padding-top: 47px;
}

.services-block > .wc:before {
  content: '';
  position: absolute;
  top: 0;
  left: 40px;
  right: 40px;
  height: 1px;
  background: #d5d5d5;
}

.service-col {
  float: left;
  width: calc((99.99% - 100px) / 3);
  margin-right: 50px;
}

.service-col:nth-of-type(3n) {
  margin-right: 0;
}

.services-block .btn {
  margin: 35px 0 50px;
}

.limitless-col {
  float: left;
  width: calc(((99.99% - 50px) / 3) * 2);
  margin-right: 50px;
}

.programs-col {
  float: left;
  width: calc((99.99% - 100px) / 3);
}

.programs-col ul li {
  float: left;
  width: calc((99.99% - 20px) / 2);
  margin-right: 20px;
}

.programs-col ul li:nth-of-type(2n) {
  margin-right: 0;
}

.programs-col ul li:nth-of-type(2n + 1) {
  clear: left;
}


.program-logos {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 40px 0 50px !important;
}

.program-logo {
  margin-right: 15px;
  padding: 0 20px;
}

.program-logo:last-of-type {
  margin-right: 0;
}

/* team styles */

.team-block {
  padding-top: 180px;
}

.team-block > .wc {
  position: relative;
}


.team-img {
  position: absolute;
  left: 510px;
  top: -150px;
}

.team-overview {
  max-width: 400px;
}

.team-members {
  background: #f1f1f1;
  padding: 270px 0 70px;
  margin-top: -114px;
}

.team-item {
  margin-bottom: 5px;
}


@media screen and (min-width: 960px)  {


  .team-item {
    float: left;
    width: calc((99.99% - 100px) / 3);
    margin-right: 50px;
    margin-bottom: 10px;
  }

  .team-item:nth-of-type(3n) {
    margin-right: 0;
  }

  .team-item:nth-of-type(3n + 1) {
    clear: left;
  }
  
}


@media screen and (max-width: 959px) and (min-width:600px) {

  .team-item {
    float: left;
    width: calc((99.99% - 50px) / 2);
    margin-right: 50px;
    margin-bottom: 10px;
  }

  .team-item:nth-of-type(2n) {
    margin-right: 0;
  }

  .team-item:nth-of-type(2n + 1) {
    clear: left;
  }

}


/* review styles */

.reviews-block {
  background: url('imgs/review-bg.png') no-repeat center center;
  position: relative;
  padding: 100px 0;
}

.reviews-block h1 {
  text-align: center;
  padding-bottom: 50px;
}

.reviews-block .bx-prev {
  position: absolute;
  left: 50px;
  top: 50%;
  margin-top: -34px;
}

.reviews-block .bx-next {
  position: absolute;
  right: 50px;
  top: 50%;
  margin-top: -34px;
}

.reviews-block .bx-prev, .reviews-block .bx-next {
  width: 67px;
  height: 67px;
  display: block;
  background:#fafafa;
  text-align: center;
  line-height: 67px;
  color: #602224;
}

.reviews-block .bx-prev:hover, .reviews-block .bx-next:hover {
  background: #ef4656;
  color: #602224;
}


.reviews-slider {
  list-style-type: none;
  padding-left: 0;
  text-align: center;
}

.reviews-slider .review-content p {
  font-family: 'Times', serif;
  font-style: italic;
  font-size: 32px;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.3;
}

.reviews-slider img {
  max-width: 74px;
  display: block;
  margin: 10px auto 15px;
}

.reviews-slider h3 {
  padding-bottom: 0;
}


.review-item :last-child {
  padding-bottom: 0;
}

/* industry styles */

.industries-block {
  position: relative;
  z-index: 2;
}

.industries-block .wc {
  position: relative;
}

.industries-block .wc:before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 40px;
  left: 300px;
  width: 3000px;
  background: #602224;
  z-index: 1;
}


.industries-content {
  padding: 100px 0 0;
  float: right;
  /*max-width: 400px;*/
    max-width: 520px !important;

  color: white;
  position: relative;
  z-index: 2;
}

.industries-content h1 {
  color: white;
}

.industries-content .dotted-list li:before {
  background: white;
}

.industries-content .dotted-list {
  float: left;
  width: calc((99.99% - 50px) / 2);
  margin-right: 50px;
}

.industries-content .dotted-list:nth-of-type(2n) {
  margin-right: 0;
}

.industries-large-img {
  position: absolute;
  right: calc(100% + 100px);
  top: 100px;
  width: 750px;
  max-width: 750px;

}

.industries-small-img {
  float: right;
  margin-top: 15px;
}

/* footer styles */

.main-footer {
  padding: 100px 0;
}

.main-footer a {
  text-decoration: underline;
}

.main-footer h3 {
  font-size: 16px;
  padding-bottom: 20px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .2em;
}

.footer-col {
  float: left;
  width: calc((99.99% - 150px) / 4);
  margin-right: 50px;
}

.footer-col:nth-of-type(4n) {
  margin-right: 0;
}

.footer-logo {
  float: right;
  display: inline-block;
  font-size: 27px;
  color: #602224;
  font-weight: 500;
  border-bottom: 3px solid #602224;
  padding-right: 12px;
  padding-bottom: 1px;
  letter-spacing: .1em;
  margin-top: 43px;
}

.visit-us-block {
  margin-top: -150px;
  height: 557px;
  background: url('imgs/visit-bg.jpg') center center / cover;
  position: relative;
  z-index: 1;
}

.visit-us-block .btn {
  position: absolute;
  top: calc(50% + 30px);
  left: 50%;
  transform: translate(-50%, -50%);
}

.visit-us-block .btn:after {
  content: '';
  position: absolute;
  top: calc(100% - 1px);
  left: 50%;
  margin-left: -10px;
  width: 0; 
  height: 0; 
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #ef4656;
  transition: .3s border;
}

.visit-us-block .btn:hover:after {
  border-top: 10px solid #f46775;
}


/* contact styles*/

.contact-content {
  background: white;
  float: left;
  max-width: 477px;
  padding: 60px 60px 0;
  margin-left: -60px;
  position: relative;
  z-index: 2;
  margin-top: -92px;
}

.contact-block h3 {
  font-size: 20px;
  font-weight: 500;
  text-transform: uppercase;
}

.cform {
  float: right;
  max-width: 730px;
  width: 100%;
}

.cform input[type="text"] {
  display: block;
  width: 100%;
  margin-bottom: 10px;
  background: #f1f1f1;
  padding: 10px 25px;
  border: 0;
}

.cform input[type="text"].is-error {
  background: red;
  color: white;
}

.cform textarea {
  display: block;
  width: 100%;
  margin-bottom: 10px;
  background: #f1f1f1;
  padding: 10px 25px;
  border: 0;
  height: 200px;
}

.cform textarea.is-error {
  background: red;
  color: white;
}

.cform input[type="submit"] {
  -webkit-appearance: none;
  border: 0;
  transition: .3s background;
  padding: 10px 25px;
  white-space: normal;
}

/*.cform input[type="submit"]:after {
  content: '\f054';
  font-family: 'FontAwesome';
  font-size: .7em;
  position: relative;
  top: -2px;
  font-weight: 400;
}*/


.cform input[type="submit"]:disabled {
  cursor: wait;
  opacity: .6; 
}

.status-msg {
  display: none;
}

/*form captcha*/

.status-msg {
  display: none;
  text-align: center;
  padding: 26px 0 0;
  float: right;
}

.genisys {
  position: absolute !important;
  z-index: -1;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  word-wrap: normal;
  color: white;
  opacity: 0;
}





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


  .social-menu {
    float: left;
    margin-left: 20px;
  }

  .nav-icon {
    display: block;
  }

  .main-nav{
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: 71px;
    left: auto;
    right: 0;
    width: 200px;
    background: #f1f1f1;
    height: calc(100vh - 71px);
    transition: .3s height, .3s top, .3s opacity, .3s transform, 0s visibility .3s;
    transform: translateX(-15px);
    margin-right: 0;
    overflow-y: auto;
    margin-top: 0;
    padding-top: 0;
  }

  .mobile-nav-is-active .main-nav {
    opacity: 1;
    visibility: visible;
    transition-delay: 0s;
    transform: none;
  }

   .main-nav li {
    display: block;
    padding: 0;
  }

   .main-nav li:after {
    display: none;
  }

  .main-nav a {
    display: block;
    border-bottom: 1px solid rgba(0,0,0,.1);
    padding: 15px;
  }

  .main-nav .sub-menu > li:last-of-type a {
    border-bottom: 1px solid rgba(255,255,255,.1);
  }

  .main-nav .menu-item-has-children > a:after {
    display: none;
  }

  .main-nav .btn {
    text-align: center;
    margin-top: 10px;
  }

  .banner-block h1 {
    font-size: 45px;
  }

  .about-block {
    margin-top: -174px;
    padding-top: 375px;
  }

  .about-block::after {
    background-size: cover;
    background-position: top center;
    top: 98px;
    right: 0;
    margin-right: 0;
    height: 543px;
    width: auto;
    left: 0;
  }

  .about-block .wc::before { 
    right: 40px;
    top: -380px;
  }

}

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

  .footer-col {
    width: calc((99.99% - 50px) / 2);
  }

  .footer-col:nth-of-type(2n) {
    margin-right: 0;
  }

  .footer-col:nth-of-type(2n + 1) {
    clear: left;
  }

  .footer-logo {
    float: none;
    margin-top: 0;
  }

  .team-block {
    padding-top: 50px;
    background: #f1f1f1;
    margin-top: 0;
  }

  .team-overview {
    max-width: 100%;
    padding-bottom: 30px;
  }

  .team-img {
    position: static;
    margin-left: -40px;
    margin-right: -40px;
    width: calc(99.99% + 80px);
    max-width: calc(99.99% + 80px);
  }

  .team-members {
    padding-top: 35px;
    padding-bottom: 35px;
    margin-top: 0;
  }

   .reviews-block .bx-controls-direction {
    text-align: center;
    padding-top: 10px;
  }

  .reviews-block .bx-prev, .reviews-block .bx-next {
    position: static;
    display: inline-block;
    margin: 0 10px;
  }

  .limitless-col, .programs-col {
    float: left;
    width: calc((99.99% - 50px) / 2);
  }

}


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

  .industries-block {
    background: #602224
  }

  .industries-block .wc::before {
    display: none;
  }

  .industries-content {
    max-width: 100%;
    padding-top: 50px;
  }

  .industries-large-img {
    position: static;
    margin-left: -40px;
    margin-right: -40px;
    max-width: calc(100% + 80px);
    width: calc(100% + 80px);
    margin: 5px -40px 20px;
  }

  .industries-small-img {
    float: none;
    position: relative;
    top: 20px;
    margin: -5px auto 0;
    display: block;
  }


}


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

  body {
    padding-top: 80px;
  }

  .wc {
    padding-left: 30px;
    padding-right: 30px;
  }

  p {
    padding-bottom: 18px;
    font-size: 14px;
  }

  .main-header {
    padding: 15px 0;
  }

  .main-header .wc {
     padding-left: 20px;
    padding-right: 20px;
  }

  .main-nav {
    top: 51px;
    height: calc(100vh - 51px);
  }

  .banner-block h1 {
    font-size: 22px;
    line-height: 1.2;
  }

  .about-block {
  margin-top: -88px;
   float: none; 
  }

  .about-block::after { 
    top: 45px;
  }

  .about-block .wc::before { 
    top: -387px;
  }

  .about-content {
    padding: 10px 0 36px;

  }

  .about-block::after { 
    height: 298px;
  }

  .approach-overview .wc {
    padding-left: 20px;
    padding-right: 20px;
  }

  .approach-overview {
    padding: 58px 0;
  }

  .approach-overview-content {
    padding: 37px 28px;
  }

  .services-block > .wc::before { 
    left: 30px;
    right: 30px;
  }

  .service-col {
    width: 100%;
    margin-right: 0;
    margin-bottom: -18px;
  }

  .service-col:last-of-type {
    margin-bottom: 0;
  }

  .services-block .btn {
    margin: 19px 0 39px;
  }

  .main-footer {
    padding: 50px 0;
  }

  .footer-col {
    float: none;
    margin-right: 0;
    width: 100%;
  }

  .reviews-block {
    padding: 55px 0;
  }

  .reviews-block h1 {
    padding-bottom: 30px;
  }

  .reviews-slider .review-content p {
    font-size: 20px;
  }

  .reviews-block .bx-prev, .reviews-block .bx-next {
    width: 50px;
    height: 50px;
    line-height: 50px;
    font-size: 16px;
    margin: 0 5px;
  }

  .contact-content {
    padding: 40px 30px 10px;
    margin-left: -30px;
    margin-right: -30px;
    width: calc(100% + 60px);
    max-width: calc(100% + 60px);
    /*margin-top: 0;*/
  }

   .limitless-col, .programs-col {
    float: none;
    width: 100%;
    margin-right: 0;
  }

  .program-logos {
    margin: 20px 0 47px !important;
  }



}


