@import url("https://use.typekit.net/ctw1wmo.css");

html, body, p, h1, h2, h3, h4, h5, h6{
  font-family: "miller-headline", serif;
  color: #193154;
  font-weight: 300;
}
h1, h2, h3, h4, h5, h6{

}
h1{
  font-size: 65px;
  font-weight: 300;
  margin-bottom: 85px;
}
h2{
  font-size: 60px;
  margin-bottom: 60px;
}
h3{
  font-size: 40px;
}
p{
  font-size: 18px;
}
a, a:hover, a:active{
  text-decoration: none;

}
a:hover{
  color: #0E1C2D;
}
span.blue{
  color: #193154!important;
}
blockquote{
  position: relative;
}
blockquote p{
  font-style: italic;
  font-size: 1.4rem;
  color: #6F9DD5;
  position: relative;
  z-index: 2;
}
blockquote:before{
  content: '"';
  position: absolute;
  top: -30%;
  left: -50px;
  font-size: 10rem;
  color: #DCE4EA;
}
blockquote:after{
  content: '"';
  position: absolute;
  bottom: -100%;
  right: -50px;
  font-size: 10rem;
  color: #DCE4EA;
}
@media screen and ( max-width: 992px ){
  h1{
    font-size: 35px;
  }
  h2{
    font-size: 30px;
  }
  h3{
    font-size: 20px;
  }
}
footer{
  background-image: url('../img/footer.png');
  color: white;
}
.footerLogo{
  max-height: 70px;
  width: auto;
}
footer a, footer p, footer a:hover{
  font-weight: 400;
  font-size: 1.5rem;
  color: white;
}
footer p.blueTxt{
  color: #7B9BCF;
}
footer .terms a, footer .terms a:hover{
  font-weight: 400;
  font-size: 0.95rem;
  color: white;
}
footer .terms li{
  display: inline-block;
  padding: 0 10px;
  border-right: 1px solid white;
}
footer .terms li:last-child{
  border-right: none;
}
footer .menu{
  margin: 0;
  padding: 0;
}
footer li{
  display: block;
  margin-left: 0;
}
.footLogo{
  width: 30px;
  margin-right: 10px;
}
footer .btn{
  border: none!important;
  color: #0E1C2D;
  background: white;
  padding: 10px 20px;
  margin: 10px 0;
  font-weight: 700;
}
footer .btn:hover{
  border: none!important;
  color: black;
  background: white;
}
.projectPosts,
.statPosts {
    min-height: 450px;
    position: relative;
    overflow: hidden;
}
.projectPosts ul,
.statPosts ul {
    padding: 0;
    margin: 120px 0
}

.projectPosts li,
.statPosts li {
    display: block;
    padding: 20px 0;
}

.projectPosts li a {
    color: #7B9BCF;
    margin-left: 0;
    font-size: 22px;
    transition: margin-left .4s;
    -moz-transition: margin-left .4s;
    -webkit-transition: margin-left .4s
}

.linkStart {
    display: inline-block;
    width: 50px
}
.line{
  border-top: solid 1px #7B9BCF;
}
.linkIndent {
    top: -8px;
    width: 0;
    display: inline-block;
    position: relative;
    overflow: hidden;
    transition: width .4s;
    -moz-transition: width .4s;
    -webkit-transition: width .4s
}

.projectPosts li:hover .linkIndent {
    width: 100%;
    transition: width .4s;
    -moz-transition: width .4s;
    -webkit-transition: width .4s
}

.projectPosts li:hover a,
.statPosts li:hover p {
    color: #7B9BCF;
    margin-left: 20px;
    transition: margin-left .4s;
    -moz-transition: margin-left .4s;
    -webkit-transition: margin-left .4s
}

.projectPosts li .img {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    opacity: 0;
    transition: opacity .4s;
    -moz-transition: opacity .4s;
    -webkit-transition: opacity .4s
}

.projectPosts li .imgOffice {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    opacity: 1
}

.projectPosts .firstImg .img,
.statPosts .firstImg img {
    opacity: 1 !important
}

.projectPosts li:hover .img,
.statPosts li:hover img {
    opacity: 1;
    transition: opacity .4s;
    -moz-transition: opacity .4s;
    -webkit-transition: opacity .4s
}

.mobileLink {
    display: none
}

.statPosts li:hover p {
    color: #000;
    margin-left: 30px;
    transition: margin-left .4s;
    -moz-transition: margin-left .4s;
    -webkit-transition: margin-left .4s
}

.statPosts li p {
    display: inline-block;
    margin-bottom: 0
}

.statPosts li .statGraph {
    width: 33%
}

.statPosts li p {
    margin-left: 0;
    color: #a3a3a3;
    transition: margin-left .4s;
    -moz-transition: margin-left .4s;
    -webkit-transition: margin-left .4s
}

.statPosts li:hover .linkIndent {
    width: 100%;
    transition: width .4s;
    -moz-transition: width .4s;
    -webkit-transition: width .4s
}

.statPosts li img {
    position: absolute;
    top: 0;
    right: 0;
    opacity: 0;
    height: 100%;
    width: auto !important;
    transition: opacity .4s;
    -moz-transition: opacity .4s;
    -webkit-transition: opacity .4s
}

.statPosts li img.base {
    opacity: 1 !important
}

.btn {
  background-color: #193154;
  color: white;
  border: none;
  border-radius: 0;
  font-size: 22px;
  padding: 15px 30px;
}
.btn:hover{
  background-color: #0E1C2D;
  color: #6F9DD5;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
p a {
    position: relative;
    z-index: 2
}
p a{
  color: #193154;
}
p a:after,
p a:before {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 0;
    right: 0;
    height: 0;
    background-color: rgba(25, 49, 84, .7);
    opacity: 0;
    transform: translateY(-18px);
    transition: height .4s, cubic-bezier(.175, .885, .32, 1.275) .2s, opacity 0s;
    z-index: -1
}

p a:hover:after,
p a:hover:before,
p a:hover:focus {
    height: 7px;
    opacity: 1;
    transform: translateY(2px);
    transition: height .4s, cubic-bezier(.175, .885, .32, 1.275) .2s, opacity 0s
}

h1 a:after,
h1 a:before,
h2 a:after,
h2 a:before,
h3 a:after,
h3 a:before,
h4 a:after,
h4 a:before,
h5 a:after,
h5 a:before,
h6 a:after,
h6 a:before {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 0;
    right: 0;
    height: 0;
    background-color: rgba(225, 122, 162, .5);
    opacity: 0;
    transform: translateY(-18px);
    transition: height .4s, cubic-bezier(.175, .885, .32, 1.275) .2s, opacity 0s
}

h1 a:hover:after,
h1 a:hover:before,
h1 a:hover:focus,
h2 a:hover:after,
h2 a:hover:before,
h2 a:hover:focus,
h3 a:hover:after,
h3 a:hover:before,
h3 a:hover:focus,
h4 a:hover:after,
h4 a:hover:before,
h4 a:hover:focus,
h5 a:hover:after,
h5 a:hover:before,
h5 a:hover:focus,
h6 a:hover:after,
h6 a:hover:before,
h6 a:hover:focus {
    height: 7px;
    opacity: 1;
    transform: translateY(2px);
    transition: height .4s, cubic-bezier(.175, .885, .32, 1.275) .2s, opacity 0s
}

.circle {
    border: solid 4px #fff;
    border-radius: 50%;
    height: 250px;
    width: 250px;
    position: relative
}

.circleInner {
    width: 70%
}

.circleInner h3 {
    font-weight: 700;
}
.circleInner h3, .circleInner p {
    color: white;
}

.view {
    font-family: 'Playfair Display', serif;
    margin: 0 !important
}

@media(max-width:1200px) {

    .projectPosts,
    .statPosts {
        min-height: 0
    }

    .projectPosts li img {
        display: none
    }

    .projectPosts li a,
    .statPosts li p {
        margin: auto
    }

    .linkIndent {
        display: none
    }

    .mobileLink {
        display: block
    }

    .statPosts .mobileLink {
        padding: 20px 0
    }

    .statPosts .mobileLink img {
        position: static;
        opacity: 1;
        display: block;
        height: auto !important
    }

    .statPosts .mobileLink p {
        margin-left: 0;
        color: #a3a3a3
    }

    .projectPosts li a,
    .projectPosts li:hover a {
        color: #fff
    }

    .deskLink {
        display: none
    }

    .projectPosts li:hover a,
    .statPosts li:hover p {
        margin-left: 0
    }

    .greyBg {
        background: 0 0 !important
    }
}

@media screen and (max-width: 992px){
  .projectPosts li::after {
      display: none;
      bottom: 0;
      width: 0;
      border-top: none;
  }
  .projectPosts li, .statPosts li{
    padding: 0;
  }
  #caseFeed.carousel{
    height: 300px;
  }
}
.carousel video{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: cover;
}

.homeCarousel{
  height: 95vh;
}

.cropcircle{
  width: 500px;
  height: 500px;
  border-radius: 100%;
  background-size: cover;
  position: absolute;
}
.cropcircleSm{
  width: 350px;
  height: 350px;
  border-radius: 100%;
  background-size: cover;
  position: absolute;
}
a.cropcircle:hover textPath{
  font-size: 20px;
  transition: all 0.3s;
}
a.cropcircle textPath{
  transition: all 0.3s;
}
a.cropcircle:hover .circletext{
  width: 430px;
  height: 430px;
  top: -65px;
  left: -65px;
  transition: all 0.3s;
}
.location1{
  left: -120px;
  top: 200px;
  border: solid 100px rgba(252,199,69,0.9);
}
.location2{
  right: -50px;
  top: 20px;
  border: solid 100px rgba(189,76,150,0.9);
}
.location3{
  left: 270px;
  top: 500px;
  border: solid 100px rgba(73,176,117,0.9);
}
.location4{
  left: -120px;
  top: 120px;
  border: solid 100px rgba(252,199,69,0.9);
}
.location5{
  right: -50px;
  top: 500px;
  border: solid 100px rgba(189,76,150,0.9);
}
.circletext{
  position: absolute;
  width: 400px;
  height: 400px;
  top: -50px;
  left: -50px;
  -webkit-animation-name: spin;
  -webkit-animation-duration: 10000ms;
  -webkit-animation-iteration-count: infinite;
  -webkit-animation-timing-function: linear;
  -moz-animation-name: spin;
  -moz-animation-duration: 10000ms;
  -moz-animation-iteration-count: infinite;
  -moz-animation-timing-function: linear;
  -ms-animation-name: spin;
  -ms-animation-duration: 10000ms;
  -ms-animation-iteration-count: infinite;
  -ms-animation-timing-function: linear;
  animation-name: spin;
  animation-duration: 10000ms;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  transition: all 0.3s;
}
@-ms-keyframes spin {
  from { -ms-transform: rotate(0deg); }
  to { -ms-transform: rotate(360deg); }
}
@-moz-keyframes spin {
  from { -moz-transform: rotate(0deg); }
  to { -moz-transform: rotate(360deg); }
}
@-webkit-keyframes spin {
  from { -webkit-transform: rotate(0deg); }
  to { -webkit-transform: rotate(360deg); }
}
@keyframes spin {
  from {
    transform:rotate(0deg);
  }
  to {
    transform:rotate(360deg);
  }
}
.baseBanner{
  min-height: 500px;
}
.baseBanner h1{
  color: white!important;
}
.headerOverlay{
  background: rgba(25,49,84,0.5);
}
@media screen and ( max-width: 1200px ){
  .homeCarousel{
    height: 75vh;
  }
}
@media screen and ( max-width: 992px ){
  .cropcircle{
    width: 200px;
    height: 200px;
    border-radius: 100%;
    background-size: cover;
    position: absolute;
  }
  .cropcircleSm{
    width: 150px;
    height: 150px;
    border-radius: 100%;
    background-size: cover;
    position: absolute;
  }
  a.cropcircle:hover textPath{
    font-size: 20px;
    transition: all 0.3s;
  }
  a.cropcircle textPath{
    transition: all 0.3s;
  }
  a.cropcircle:hover .circletext{
    width: 160px;
    height: 160px;
    top: -35px;
    left: -35px;
    transition: all 0.3s;
  }
  .circletext{
    position: absolute;
    width: 200px;
    height: 200px;
    top: -50px;
    left: -50px;
  }
  .location1{
    left: -50px;
    top: 200px;
    border: solid 50px rgba(252,199,69,0.9);
  }
  .location2{
    right: -50px;
    top: 20px;
    border: solid 50px rgba(189,76,150,0.9);
  }
  .location3{
    left: 270px;
    top: 300px;
    border: solid 50px rgba(73,176,117,0.9);
  }
  .location4{
    left: -20px;
    top: 10px;
    border: solid 50px rgba(252,199,69,0.9);
  }
  .location5{
    right: -50px;
    top: 500px;
    border: solid 50px rgba(189,76,150,0.9);
  }
  .homeCarousel{
    height: 45vh;
  }
}
/* ====== NAV BAR ====== */
.flag{
	width: 30px;
	height: auto;
}
#navbarNav{
	right: 0;
	top: 0;
	position: absolute;
}
.menu-header-menu-container{
	margin: 0;
	padding: 0;
	transform-origin: bottom right;
	right: 50px;
	top: 250px;
	position: absolute;
}
#bar{
	margin-right: 35px;
	z-index: 1505;
}
.est{
	margin: 0;
	padding: 0;
	transform-origin: center;
	right: 75px;
	top: 30%;
	position: absolute;
	color: white!important;
	width: 100px;
}
.est p{
	color: white!important;
}
#bar li{
	display: block;
	margin: 0 0 5px 0;
	text-align: right;
}
#bar li a, .est{
	color: white;
	font-size: 20px;
}
#bar .dropdown-menu li{
	display: block;
	margin: 0;
}
#bar .dropdown-menu{
	border: 0;
	border-radius: 0;
}
#bar .custom-logo{
	width: auto;
	max-height: 50px;
	margin: 35px;
}
.navbar-expand-lg .navbar-nav{
	flex-direction: column;
}
/* ====== NAV BAR END ====== */

/* ====== NAV BURGER ====== */
#sideNavigation .dropdown-menu, #sideNavigation .dropdown-menu.show{
  position: static!important;
  transform: none!important;
  width: 100%;
  border: none!important;
  background-color: transparent!important;
  margin: 0;
  padding: 0;
}
.dropdown-menu{
  height: 0;
  max-height: 0;
  opacity: 0;
  transition: 0.8s;
}
.dropdown-menu.show{
  height: auto;
  opacity: 1;
  max-height: 1000px;
  transition: 0.8s;
}
.dropdown-item.active, .dropdown-item:active, .dropdown-item:focus, .dropdown-item:hover{
	background: none!important;
}
.navbar-toggle{
	z-index: 100000;
	display: inline;
  position: absolute;
	right: 0;
	top: 0;
}
.navbar-toggle{
	margin: 35px;
	background-color: #0E1C2D;
}
.hamburger {
  padding: 12px 12px;
  display: inline-block;
  cursor: pointer;
  transition-property: opacity, filter;
  transition-duration: 0.15s;
  transition-timing-function: linear;
  font: inherit;
  color: inherit;
  text-transform: none;
  background-color: transparent;
	border-radius: 50%;
  border: 0;
  overflow: visible;
	z-index: 30000;
}
.hamburger:hover {
  opacity: 0.7;
}
.hamburger.is-active:hover {
  opacity: 0.7;
}
.hamburger.is-active .hamburger-inner, .hamburger.is-active .hamburger-inner::before, .hamburger.is-active .hamburger-inner::after {
  background-color: white;
}
.hamburger-box {
  width: 35px;
  height: 18px;
  display: inline-block;
  position: relative;
  margin-top: 10px;
}
.hamburger-inner {
  display: block;
  top: 50%;
  margin-top: -2px;
}
.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
  width: 35px;
  height: 5px;
  background-color: white;
  border-radius: 0;
  position: absolute;
  transition-property: transform;
  transition-duration: 0.15s;
  transition-timing-function: ease;
}
.scrolled .hamburger-inner, .scrolled .hamburger-inner::before, .scrolled .hamburger-inner::after{
	background-color: #193154;
}
.hamburger-inner::before, .hamburger-inner::after {
  content: "";
  display: block;
}
.hamburger-inner::before {
  top: -10px;
}
.hamburger-inner::after {
  bottom: -10px;
}
.hamburger--spin .hamburger-inner {
  transition-duration: 0.5s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin .hamburger-inner::before {
  transition: top 0.3s 0.5s ease-in, opacity 0.1s ease-in;
}
.hamburger--spin .hamburger-inner::after {
  transition: bottom 0.3s 0.5s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spin.is-active .hamburger-inner {
  transform: rotate(225deg);
  transition-delay: 0.3s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger--spin.is-active .hamburger-inner::before {
  top: 0;
  opacity: 0;
  transition: top 0.3s ease-out, opacity 0.3s 0.3s ease-out;
}
.hamburger--spin.is-active .hamburger-inner::after {
  bottom: 0;
  transform: rotate(-90deg);
  transition: bottom 0.3s ease-out, transform 0.3s 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
#sideNavigation{
  color: white!important;
}
#sideNavigation p a{
  font-size: 1em!important;
  text-transform: lowercase;
}
#overlay{
  position: fixed;
  z-index: 1500;
  width: 100%;
  height: 100%;
  background: black;
  opacity: 0.7;
  transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    -webkit-transition: opacity 0.3s;
  display: none;
}
#sideNavigation #menu-header-menu, #socialNav{
  transition: opacity 0.3s;
    -moz-transition: opacity 0.3s;
    -webkit-transition: opacity 0.3s;
  opacity: 0;
}
#navLink{
  width: 40px;
  height: auto;
}
.sidenav {
    height: 100%;
    width: 0;
    position: fixed;
    z-index: 10000;
    top: 0;
    right: 0;
    background-color: #0E1C2D;
    overflow-x: hidden;
    padding-top: 60px;
    transition: 0.5s;
    text-align: right;
}
.sidenav a, .sidenav a:not([href]):not([tabindex]) {
    text-decoration: none;
    font-size: 20px;
    color: #fff;
    display: block;
    transition: 0.15s;
    margin-bottom: 15px;
}
.sidenav a.social{
  display: inline-block;
}
.sidenav #socialNav a, .sidenav #socialNav a:not([href]):not([tabindex]) {
    border-bottom: none;
}
.sidenav a:hover, .offcanvas a:focus{
    color: #f1f1f1;
}
.sidenav .closebtn {
    position: absolute;
    top: 0;
    right: 25px;
    font-size: 36px;
    margin-left: 50px;
}
.sidenav li{
  display: block;
}
#main {
    padding: 20px;
}
body {
  overflow-x: hidden;
}
.topnav {
    overflow: hidden;
    top: 0;
}
.topnav a {
    display: inline;
    padding: 0;
    text-decoration: none;
    position: relative;
    border: none;
}
.topnav p a {
    float: none;
    display: inline;
    text-align: left;
    padding: 0;
    text-decoration: none;
    width: auto;
}
.topnav>p{
    margin: 8px 15px;
}
.topnav a.active {
    background-color: #4CAF50;
    color: white;
}
a svg{
  transition:all .5s ease;
  &:hover{
    #transform:rotate(180deg);
  }
}
#ico{
  display: none;
}
#sideNavigation #socialNav, #sideNavigation #menu-header-menu{
  margin: 80px;
}
.menu{
  margin-top: 20px;
  margin-right: 50px;
  padding: 0 30px;
  @include border-radius(5px);
  #transition: all 0.5s ease;
  a{
    display: block;
    color: #fff;
    padding: 10px 2px;
    margin: 3px 0;
    text-decoration: none;
  }
}
@media(max-width: 992px){
  .sidenav ul{
    display: block;
  }
  .sidenav li{
    display: block;
    width: 100%;
    margin-bottom: 20px;
  }
  ul .sub-menu {
    padding-inline-start: 0;
  }
  .sub-menu li{
    display: block;
    width: 100%;
    margin-bottom: 5px;
  }
  .sub-menu li a{
    font-weight: 300;
  }
  .menu{
    margin-right: 0;
  }
	#bar .custom-logo{
		width: 100%;
		max-height: auto;
		margin: 40px 0;
	}
	#bar{
		margin-top: 0;
		margin-right: 0;
		z-index: 1505;
	}
	.hamburger{
		z-index: 30000;
	}
}
/* ====== NAV BURGER ====== */

.talkBtn{
	background: #7B9BCF;
	text-transform: uppercase;
	font-family: sans-serif;
	font-weight: 700;
	transform: rotate(90deg) translateX(-50%);
	right: 0;
	top: 50%;
	width: auto;
	z-index: 3;
}
.centerObject{
  top: 0;
}
.overlay{
  opacity: 0;
  background: rgba(0,0,0,0.8);
  color: white!important;
  transition: all .5s;
}
.overlay:hover{
  opacity: 1;
}
.postLink:before{
  content: "";
  display: block;
  padding-top: 90%;
}
.postLinkContent{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  height:100%;
}
.offerLinkContent{
  position: absolute;
  top: 30px;
  left: 30px;
  bottom: 30px;
  right: 30px;
}
.postLinkContent h2, .offerLinkContent h2{
  font-size: 45px;
  margin-bottom: 30px;
}

@media screen and ( max-width: 992px ){
  .offerLinkContent{
    position: relative;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
  }
  .postLink:before{
    padding-top: 0;
  }
}
.darkBg{
  background: #1E1E1C;
  color: white;
}
.lightBg{
  background: #EEEDED;
}
.greyBg{
  background: #F1F1F1;
}
.blueBg{
  background: #6F9DD5;
}
.darkBg a, .darkBg a:hover{
  color: white;
}
.marbleBg{
  background-image: url('../img/placeholder.jpg');
}
.carouselText{
  background-image: url('../img/blue.png');
}
.carouselText p, .carouselText h1, .carouselText h2, .carouselText h3, .carouselText h4, .carouselText h5, .carouselText h6{
  color: white;
}
@keyframes load {
	from {width: 0;}
	to {width: 100%;}
}
.loader{
	height: 10px;
	background: white;
	animation-name: load;
	animation-duration: 10s;
}
.loaderTrans{
	-webkit-animation-duration: 9s;
    animation-duration: 9s;
	-webkit-transform: width(100%);
    transform: width(100%);
}
.dropdown-menu{
  background: #1E1E1C;
  border: solid 1px white;
  border-radius: 0;
}
.dropdown .dropdown-menu{
  transition: none;
}
ul.dropdown-menu li{
  padding: 10px;
}
.centerDrop{
  margin: 0 -35%!important;
}
.btn.orange{
  background: #0E1C2D;
  color: white;
  padding: 10px 20px;
  border: none!important;
}
#cd-timeline{
  margin: 0!important;
  padding: 70px 0!important;
}
.timeline-date, .timeline-express-read-more-link{
  display: none!important;
}

@media screen and ( max-width: 992px ){
  .centerDrop{
    margin: 0 -48%!important;
  }
}
.strong-view.wpmtst-modern .wpmtst-testimonial-content p, .strong-view.wpmtst-modern .wpmtst-testimonial-field{
  font-size: 25px;
}
