/******************************
	RESPONSIVE STYLES 
******************************/
@media screen and (max-width: 1200px) {
	.vertical-text {
	    left: 10px;
        transform-origin: left top;
	}
	.about-wrapper .vertical-text {
	    top: 345px;
	}
	.logos-wrapper a {
		margin-right: 35px;
	}
	.footer-btm .cell:last-child {
    	width: 230px;
	}
	.content-table .cell:first-child .img-box{
		margin-left: -15px;
		width: calc(100% + 15px);
	}
	.content-table .cell:last-child .img-box{
		margin-right: -15px;
		width: calc(100% + 15px);
	}
}
@media screen and (max-width: 1100px) {
	.about-wrapper .container {
    	padding: 65px 15px;
	}
	.about-wrapper .cell:first-child {
	    padding: 70px 20px 0 35px;
	}
	.services-content:after {
    	margin: 0 auto;
	}
	.services-list .container {
		padding: 0 5px;
	}
	.services-list .cell {
		padding: 0 10px;
	}
	.services-item {
		margin-bottom: 20px;
	    padding: 30px 15px 25px;
	}
	.social-wrapper {
		padding: 80px 0 55px;
	}
	.logos-wrapper a{
		margin-bottom: 15px;
	}
	.footer-btm .cell:nth-child(2) {
    	width: 135px
	}
	.footer-btm .cell:last-child {
    	width: 215px;
	}
	.breadcrumbs{
		margin-bottom: 50px;
	}
	.main-content .vertical-text{
		display: none;
	}
	.attribute-list li{
		width: 115px;
	}
	.property-filter .cell:first-child{
		width: 45px;
		padding: 0;
	}
	.property-filter span{
		display: block;
		font-size: 0;
		height: 24px;
	}
	.property-filter .cell:last-child{
		width: 48%;
	}
	.main-content .sidebar{
		width: 340px;
	}
	.project-content .content {
	    padding-right: 0;
	}

}

@media screen and (max-width: 1000px) { /* Target Screen Width */
	.header-menu .cell:nth-child(2) {
    	padding-left: 25px;
	}
	.nav-menu li {
		margin-right: 20px;
	}
	.phone a:first-child {
    	margin-right: 10px;
	}
	.banner-text .logo {
		font-size: 54px;
	}
	.vertical-text {
		position: static;
		margin-bottom: 20px;
		-webkit-transform: none;
	    -moz-transform: none;
	    -ms-transform: none;
	    -o-transform: none;
	    transform: none;
	}
	.vertical-text:before {
	    position: static;
	    display: inline-block;
	    height: 1px;
	    margin: -2px 10px 0 0;
	    vertical-align: middle;
	}
	.about-wrapper .cell:first-child {
	    padding: 0;
	}
	.about-wrapper .cell:last-child {
		padding-left: 35px;
	}
	.info-banner {
		margin-left: 0;
	}
	.info-banner .img-box {
	    margin: 0 0 30px 0;
	}
	.info-banner-text {
	    max-width: 220px;
    	padding: 0 0 20px 20px;
	}
	.social-wrapper .container {
		padding: 0 15px;
	}
	.social-wrapper .soc-box {
		margin-top: 0;
	}
	.attribute-list{
		margin: 20px 10px 0 10px;
	}
	.attribute-list li {
	    width: 105px;
	}
	.breadcrumbs,
	.main-content h1,
	.main-content .content{
		padding-left: 0;
	}
	.project-content .services-content{
		padding-top: 50px;
	}
	
	.container .container {
		padding-left: 0;
		padding-right: 0;
	}
	
	.history-scale-box.part-first:before, 
	.history-scale-box.part-second:before{
		height: 1200px;
	}
	.history-scale-box.part-second article:nth-child(3):before{
		content: none;
	}
	.history-scale-box.part-second article:nth-child(3):after, 
	.history-scale-box.part-second article:nth-child(5):after, 
	.history-scale-box.part-second article:nth-child(7):after{
		width: 84px;
		right: -101px;
	}
	.history-scale-box.part-second:before{
		height: 1000px;
	}
	.history-scale-box .img-short{
		padding-right: 0;
	}
	.history-scale-box.part-first article:first-child h3{
		font-size: 58px;
	}
	.history-scale-box h3{
		font-size: 28px;
		line-height: 38px;
	}
	
	.testimonials-slider .slick-dots {
		bottom: 10px;
	}

}

@media screen and (max-width: 900px) {
	#header {
		height: 66px;
	}
	.header-menu {
    	position: fixed;
		bottom: auto;
		top: 0 !important;
		z-index: 11;
	}
	.header-menu .cell:nth-child(2){
		width: 0;
	}
	.header-menu .cell:last-child {
		width: auto;
		opacity: 1;
		visibility: visible;
	}
	.top-bar {
		display: none;
	}

	/*=== Navigation ===*/
	#nav-btn {
        display: inline-block;
	    margin: -3px 0 0 15px;
	    vertical-align: middle;
	}
	#nav-close-btn {
		position: absolute;
		top: 35px;
		right: 55px;
		display: block;
		z-index: 5;
	}
	.main-nav {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		max-width: 60%;
		width: 0;
		margin: 0;
		-webkit-transition: all 0.6s ease 0s;
	    -moz-transition: all 0.6s ease 0s;
		-ms-transition: all 0.6s ease 0s;
		-o-transition: all 0.6s ease 0s;
		transition: all 0.6s ease 0s;
		color: #fff;
		background-color: #051528;
		overflow: hidden;
		overflow-y: auto;
		z-index: 110;
	}
	.open .main-nav {
		width: 100%;
		-webkit-transition: all 0.8s ease 0s;
	    -moz-transition: all 0.8s ease 0s;
		-ms-transition: all 0.8s ease 0s;
		-o-transition: all 0.8s ease 0s;
		transition: all 0.8s ease 0s;
	}
	.main-nav nav {
		position: relative;
		min-width: 415px;
		padding: 80px 80px 40px 40px;
		text-align: left;
	}
	.header-menu .main-nav,
	.header-menu nav,
	.header-menu .nav-menu,
	.header-menu li,
	.header-menu li > a {
		height: auto;
	}
	.nav-menu li {
		display: block;
		margin-right: 0;
	}
	.nav-menu li.has-child {
		position: relative;
	}
	.nav-menu > li > a {
		display: block;
        padding: 13px 30px 10px 15px;
	    border-bottom: 1px solid #000;
	    font-size: 20px;
	    -webkit-box-shadow: 0px 1px rgba(255, 255, 255, 0.2);
    	-moz-box-shadow: 0px 1px rgba(255, 255, 255, 0.2);
	    box-shadow: 0px 1px rgba(255, 255, 255, 0.2);
	}
	.nav-menu li a:hover,
	li.has-child:hover > a {
		color: inherit;
	}
	.nav-menu li.active > a,.nav-menu li.active > a:hover{
		color: #d7df21;
	}
	.sub-ctrl {
	    position: absolute;
	    top: 7px;
	    right: 0;
	    width: 30px;
	    height: 40px;
	    text-align: center;
		cursor: pointer;
		z-index: 1;
	}
	.sub-ctrl:after {
	    content: "\f105";
	    font: 22px/40px Font Awesome\ 5 Pro;
	    font-weight: bold;
	}
	.sub-ctrl.show {
		-webkit-transform: rotate(90deg);
		-moz-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		-o-transform: rotate(90deg);
		transform: rotate(90deg);
	}
	.sub-menu {
		position: static;
		display: none;
	    width: 100%;
	    height: auto;
	    margin: 0 !important;
        padding: 6px 20px;
	    text-align: inherit;
		-webkit-transform: none;
		-moz-transform: none;
		-ms-transform:none;
		-o-transform: none;
		transform: none;
		-webkit-transition: none;
		-moz-transition: none;
	 	-ms-transition: none;
		-o-transition: none;
		transition: none;
		background-color: transparent;
		opacity: 1;
		visibility: visible;
	}
	.sub-menu li a {
		padding: 9px 10px;
		font-size: 15px;
	}

	.vertical-text:before {
		width: 50px;
	}
	.vertical-text:after {
	    content: "";
	    display: inline-block;
	    width: 50px;
	    height: 1px;
	    margin: -2px 0 0 10px;
	    vertical-align: middle;
	    background: #6d6e71;
	}
	.banner-text .large-text {
		line-height: 38px;
		font-size: 30px;
	}
	.about-wrapper .container {
		padding: 50px 15px 60px;
		text-align: center;
	}
	.about-wrapper .table,
	.about-wrapper .cell {
		display: block;
	}
	.about-wrapper .cell:last-child {
		width: 500px;
    	margin: 20px auto 0;
    	padding: 0;
	}
	.info-banner .btn{
		margin-left: 0;
	}
	.info-banner .img-box {
		margin: 0 auto 30px;
	}
	.services-wrapper h2 {
		line-height: 46px;
		font-size: 40px;
	}
	.services-list {
		padding: 50px 0;
	}
	.social-wrapper {
    	padding: 60px 0 55px;
	}
	.social-wrapper:after{
		width: 60%;
	}
	.main-content{
		padding-bottom: 70px;
	}
	.main-content:after,
	.main-content:before{
		content: none;
	}
	.main-content .col-left,
	.main-content .col-right{
    	display: block;
	}
	.main-content .col-right{
		width: 100%;
		padding: 30px 0 0 0;
	}
	.cta-banner{
		max-width: 350px;
		margin: 0 auto;
	}
	.filter-wrapper,
	.prop-listings{
		padding: 0;
	}
	.item-top-info{
		font-size: 16px;
		line-height: 22px; 
	}
	.item-info{
		padding: 10px 10px 25px;
	}
	.attribute-list{
	    margin: 20px 0 0;
	}
	.content-table .cell:first-child .content-table-info{
		margin-left: 0;
	}
	.content-table .cell:last-child .content-table-info{
		margin-right: 0;
	}
	
	.frame-contain.map-frame {
		padding-bottom: 40%;
	}
	.history-scale-box:before, 
	.history-scale-box article:after,
	.history-scale-box.part-first article:before{
		content: none !important;
	}
	.history-scale-box.part-first article:first-child{
		padding-right: 0;
	}
	.history-scale-box article{
	    width: calc(50% - 20px);
	}
	.history-scale-box article:nth-child(odd){
		margin-right: 40px;
	}
	.history-scale-box article.btm{
		margin-top: 40px;
	}
	.history-scale-box.part-first article:nth-child(7), 
	.history-scale-box.part-first article:nth-child(9){
		width: 48%;
	}
	.history-scale-box.part-first article:nth-child(8){
		width: 45%;
	}
	.history-scale-box.part-first{
		margin-top: 40px;
	}
	
	.staff-list.two-col > li {
		width: 46%
	}
}

@media screen and (max-width: 770px) { /* Tablet View */
	body{
		cursor: pointer; /* iOS Clicking Fix */
	}
	h1{
		line-height: 38px;
		font-size: 28px;
	}
	h2,
	.services-wrapper h2{
	   line-height: 34px;
	   font-size: 26px;
	}
	h3,
	.main-content .content h3,
	.moto-banner h3{
		margin-bottom: 10px;
		font-size: 22px;
	}
	h2 span,
	h3 span{
		margin-top: 4px;
	}
	hr{
		margin: 30px 0;
	}

	#nav-close-btn {
    	top: 40px;
    	right: 40px;
    }
    .main-nav {
    	max-width: 60%;
    }
	.main-nav nav {
		min-width: 392px;
		padding: 80px 40px 40px;
	}
	.nav-menu > li > a{
	 	padding: 12px 30px 10px 15px;
		font-size: 18px;
	}
	.sub-ctrl{
		top: 6px;
	}
	.banner-text .logo{
		font-size: 48px;
	}
	.social-wrapper .container{
		padding: 0;
	}
	.about-wrapper .cell:last-child{
		width: 450px;
	}
	.services-list {
    	padding: 25px 0;
	}
	.services-list .table,
	.services-list .row,
	.services-list .row .cell, 
	.social-table,
	.social-table > .cell{
		display: block;
	}
	.services-item{
		margin-bottom: 0;
	}
	.services-item h3{
		line-height: 32px;
	}
	.social-table > .cell:first-child{
	    padding: 0 15px;
	}
	.social-table > .cell:last-child{
	    padding-left: 0;
	}
	.testimonials-box{
	    height: auto;
    	padding: 50px 15px;
	}
	.testimonials-box .slick-dots{
		bottom: -25px;
	}
	.testimonials-slide{
    	padding: 15px 0;
	}
	.testimonials-box:after, .content-table-info:after,
	.info-banner:after, .info-banner:before, 
	.soc-box:before, .cta-banner:before,
	.social-wrapper:after,
	.footer-btm:after{
		content: none;
	}
	.info-banner-text{
		line-height: 24px;
	}
	.soc-box{
		max-width: 450px;
		margin: 0 auto 50px;
	}
	.social-wrapper{
		margin-bottom: 0;
	    padding: 50px 0 35px;
	}
	.logos-wrapper{
		padding: 45px 15px 0;
	}
	.logos-wrapper h3:after{
		margin: 15px auto 0;
	}
	.footer-btm{
		text-align: center;
	}
	.footer-btm .table,
	.footer-btm .cell{
		display: block;
	}
	.footer-btm .cell:first-child{
		padding-bottom: 20px;
	}
	.footer-btm .cell:nth-child(2),
	.footer-btm .cell:last-child{
		display: inline-block;
		vertical-align: middle;
		width: auto;
	}
	.main-content{
    	padding-bottom: 40px;
	}
	.content-table{
		height: auto;
	}
	.content-table .img-box{
		height: 350px;
		margin-top: 0;
		background-position: center top;
	}
	.content-table,
	.content-table .cell{
		display: block;
	}
	.content-table .cell:last-child .img-box,
	.content-table .cell:first-child .img-box {
	    margin-right: -15px !important;
	    margin-left: -15px !important;
	    width: calc(100% + 30px);
	}
	.content-slider {
	    padding: 0 55px;
	}
	.cta-banner .large-text,
	.services-banner .large-text{
		font-size: 24px;
	}
	.cta-banner .large-text:after {
    	margin: 10px auto 20px;
	}
	.moto-banner p{
		line-height: 34px;
		font-size: 18px;
	}
	
	.logos-wrapper .slick-next:before {
	    color: #f4f4f4;
	}
	.history-scale-box.part-first article,
	.history-scale-box article{
		min-height: 50px;
		width: 100% !important;
		float: none;
		text-align: center !important;
	}
	.history-scale-box.part-first article:nth-child(5), 
	.history-scale-box.part-first article:nth-child(6),
	.history-scale-box li.btm{
		margin-top: 25px;
	}
	.history-scale-box.part-second{
		padding-top: 0;
	}
	.history-scale-box.part-first article:nth-child(8){
		padding: 0;
	}
	.history-scale-box h3 {
		margin-top: 20px;
	}
	
	/* property details */
	
	.project-detail {
		display: block;
	}
	
	.project-detail .main-col,
	.project-detail .side-col {
		display: block;
		width: 100%;
	}
	
	.project-detail .side-col {
		padding-left: 0;
		max-width: 90%;
		margin: 50px auto 0;
	}
	
	.staff-section br {
		display: block;
		line-height: 0;
	}
	
	.project-detail .side-col .flexbox {
		-webkit-flex-direction: column-reverse;
		flex-direction: column-reverse;
	}
	.project-detail .side-col .prop-map {
		margin-top: 35px;
	}
}

@media screen and (max-width: 670px) { /* Phone View */
	.main-nav{
		max-width: 80%;
	}
	.main-nav nav{
		min-width: 384px;
	}
	.banner > .relative:after{
		content: none;
	}
	.banner-text .ico-logo{
		width: 50px;
		height: 51px;
	}
	.banner .banner-text .ico-logo {
		display: block;
		margin: 0 auto 10px;
	}
	.banner-text .logo {
		margin-bottom: 35px;
		line-height: 50px;
    	font-size: 40px;
	}
	.banner-text .large-text {
	    line-height: 32px;
    	font-size: 24px;
	}
	.soc-box:after,
	.soc-box .text-box {
		opacity: 1;
		visibility: visible;
	}
	
	/*
	.prop-listings > .btn {
    	margin-top: 15px;
	}

	.prop-listing-items,
	.prop-listing-items > .row,
	.prop-listing-items > .row >.cell{
		display: block;
	}	.item-box{
		max-width: 470px;
		margin: 0 auto;
	}
	.prop-listing-items .row > .cell:first-child{
		padding-right: 0;
	}
	.prop-listing-items .row > .cell:last-child{
		padding-left: 0;
	}
	*/
	
	.item-top, .item-images,
	.item-box figure {
		height: 280px;
	}
	.property-filter .cell:first-child{
		display: none;
	}
	.property-filter .cell {
		display: block;
		width: 100%;
	}
	.property-filter .cell:last-child {
		width: 100%;
		padding: 20px 0 0;
	}
	.item-box,
	.item-box:nth-child(2n) {
		display: block;
		width: 100%;
		margin: 10px auto;
	}
	
	.moto-banner{
		height: 550px;
	}
	.moto-banner:after{
		content: none;
	}
	.moto-banner:before{
		left: 0;
	}
	
	.staff-list.two-col > li {
		width: 100%;
		max-width: 420px;
		margin: 20px auto;
	}
	.two-col > li:nth-child(2n) {
		margin-left: 0;
	}
	
	.staff-detail figure {
		display: block;
		width: 200px;
		height: 250px;
		margin-right: auto;
		margin-left: auto;
		
	}
	.staff-detail > div {
		width: 100%;
		margin-top: 20px;
		margin-left: 0;
		text-align: center;
	}
	.staff-detail .content {
		text-align: left;
	}
	
	.error-message header {
		font-size: 20px;
	}
	.error-message h1 {
		font-size: 36px;
	}
}
@media screen and (max-width: 480px) {
	.main-nav{
		max-width: 95%;
	}
	.main-nav nav{
	    min-width: 340px;
	    padding: 70px 30px 30px;
	}
	
	h1 {
    	line-height: 34px;
    	font-size: 24px;
	}
	h2,
	.services-wrapper h2 {
	    line-height: 32px;
	    font-size: 22px;
	}
	h3,
	.services-item h3,
	.main-content .content h3,
	.moto-banner h3{
		line-height: 30px;
		font-size: 20px;
	}
	.btn{
		min-width: 170px;
	}
	.banner-text .logo{
		margin-bottom: 15px;
		line-height: 46px;
		font-size: 36px;
	}
	.banner-text .large-text{
    	line-height: 30px;
    	font-size: 20px;
	}
	.about-wrapper .cell:last-child{
		width: 100%;
	}
	.info-banner-text{
	    max-width: 100%;
	    margin-bottom: 0;
    	padding: 0 15px 20px;
    	border: 0;
	}
	.info-banner-text:after{
		content: none;
	}
	.services-item{
	    padding: 25px 15px 20px;
	}
	.services-item i{
		margin-bottom: 20px;
	}
	.breadcrumbs{
		margin-bottom: 30px;
	}
	.content-slider{
		padding: 0;
	}
	.property-filter{
		padding: 30px 20px;
	}
	.item-top-info{
		padding: 10px;
	}
	.content-table .cell:first-child .content-table-info,
	.content-table .cell:last-child .content-table-info{
		padding: 30px 15px 30px;
	}
	.project-content .content .img-box {
	    height: 320px;
	}
	.moto-banner{
		height: 350px;
	}
	.moto-banner p{
		font-size: 16px;
		line-height: 28px;
	}
	
	.frame-contain.map-frame {
		padding-bottom: 65%;
	}
	.history-scale-box.part-first article:first-child h3{
		font-size: 52px;
	}
}

@media screen and (max-width: 380px) {
	.main-nav nav {
		min-width: 300px;
	}
	#nav-close-btn{
		top: 20px;
		right: 20px;
	}
	.banner-text .logo{
		line-height: 44px;
		font-size: 32px;
	}
	.sub-banner{
		height: 220px;
	}
	.header-menu .cell:nth-child(2) {
    	padding-left: 15px;
	}
	.vertical-text:before,
	.vertical-text:after{
		content: none;
	}
	.logos-wrapper a{
		display: block;
		margin-right: 0;
	}
	.logos-wrapper a:last-child{
		margin-bottom: 0;
	}
	.logos-wrapper a img:last-child{
		left: 50%;
		transform: translateX(-50%);
	}
	.breadcrumbs li{
		font-size: 12px;
	}
	.attribute-list span{
		font-size: 12px;
	}
	.attribute-list li{
		width: auto;
		padding: 0 10px;
	}
	.history-scale-box.part-first article:first-child h3{
		font-size: 48px;
	}
	
	.title-text, .staff-detail .title-text {
		font-size: 32px;
	}
	
	.staff-list .contact-link,
	.staff-list a.contact-link,
	.staff-detail .contact-link {
		font-size: 18px;
	}
}