/*

Theme Name: Cube

Theme URI: http://cubemedia.nz

Author: Hanyu Zhang

Description: Theme For Cube Media Company website

*/

@import url('https://fonts.googleapis.com/css?family=Raleway:300,400,500,600,700');

html, body{
	font-family: 'Raleway', sans-serif;
}
body{
	margin: 0 auto;
}
img{
	max-width: 100%;
	display: block;
	height: auto;
}
h1, h2, h3, h4, h5, h6, a{
	font-family: 'Raleway', sans-serif;
}
p, ul, li{
	font-family: 'Raleway', sans-serif;
}
h1{
	font-size: 57px;
	color: black;
	line-height: 67px;
	font-weight: 600;
	position: relative;
}
.site-header{
	background-color: #000;
	padding-top: 25px;
	padding-bottom: 25px;
}
.site-branding, .site-right{
	width: 50%;
	display: block;
	float: left;
}
.page-container{
	padding-left: 20px;
	padding-right: 20px;
	max-width: 1340px;
	display: table;
	margin: 0 auto;
	width: 100%;
}
ul#primary-menu li a{
	font-size: 18px;
	font-weight: 700;
	line-height: 25px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: #747474;
	padding: 10px 15px;
	text-decoration: none;
}
ul#primary-menu li.current_page_item a{
	color: white;
}
/*ul#primary-menu li:last-child a{
	padding-right: 0px;
}*/
ul#primary-menu li{
	float: left;
}
ul#primary-menu{
	list-style-type: none;
	margin: 0px;
	display: block;
	float: right;
}
#masthead .page-container{
	display: table;
}
#site-navigation{
	display: table-cell;
	vertical-align: middle;
	height: 56px;
}
#header-logo a{
	display: inline-block;
}
.site-right-inner{
	display: table;
	float: right;
}
footer{
	background-color: black;
	padding-top: 25px;
	padding-bottom: 25px;
	display: table;
	width: 100%;
}
.footer-left{
	width: 60%;
	display: block;
	float: left;
}
.footer-right{
	width: 40%;
	display: block;
	float: right;
	text-align: right;
}
.footer-left p, .footer-left a, .footer-right p, .footer-right a{
	font-size: 14px;
	font-weight: 500;
	line-height: 24px;
	color: white;
}
.footer-right p:last-child, .footer-left p:last-child{
	margin-bottom: 0px;
}
.footer-left a:hover, .footer-right a:hover{
	text-decoration: none;
}
.social-lists{
	margin-bottom: 10px;
	margin-top: 10px;
}
.social-lists i{
	text-align: right;
	font-size: 23px;
	width: 23px;
	height: 23px;
}
.carousel-fade .carousel-inner .item {
  	opacity: 0;
  	transition: opacity 0.5s;
}
.carousel-fade .carousel-inner .active {
 	opacity: 1;
}
.carousel-fade .carousel-inner .active.left,
.carousel-fade .carousel-inner .active.right {
  	left: 0;
  	opacity: 0;
  	z-index: 1;
}
.carousel-fade .carousel-inner .next.left,
.carousel-fade .carousel-inner .prev.right {
  	opacity: 1;
}
.carousel-fade .carousel-control {
  z-index: 2;
} 
@media all and (transform-3d), (-webkit-transform-3d) {
    .carousel-fade .carousel-inner > .item.next,
    .carousel-fade .carousel-inner > .item.active.right {
      	opacity: 0;
      	-webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
    .carousel-fade .carousel-inner > .item.prev,
    .carousel-fade .carousel-inner > .item.active.left {
     	opacity: 0;
      	-webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
    .carousel-fade .carousel-inner > .item.next.left,
    .carousel-fade .carousel-inner > .item.prev.right,
    .carousel-fade .carousel-inner > .item.active {
      	opacity: 1;
      	-webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
}
.carousel,
.carousel-inner,
.carousel-inner .item {
  	height: 100%;
}
html.home-html, .page-template-tpl-home #page{
	width: 100%;
	height: 100%;
}
body.page-template-tpl-home, .carousel-caption-outter, .home-banner, .carouselFade, .carousel-inner, .item{
	width: 100%;
	height: 100%;
}
.page-template-tpl-home main{
	width: 100%;
	height: calc(100% - 224px);
}
.carousel-caption h1{
	font-size: 57px;
	color: white;
	line-height: 67px;
	font-weight: 400;
	position: relative;
	text-align: center;
	margin-bottom: 30px;
}
.carousel-caption p{
	font-weight: 400;
	position: relative;
	font-size: 24px;
	line-height: 34px;
	color: white;
	text-align: center;
	max-width: 715px;
	margin: 0 auto;
}
.carousel-caption-outter {
	display: table;
}
.carousel-caption{
	display: table-cell;
	vertical-align: middle;
	position: relative;
	top: unset;
	right: unset;
	left: unset;
	bottom: unset;
	padding: 20px;
	margin: 0 auto;
}
.home-banner{
	background-color: black;
	position: relative;
}
.item:before{
	position: absolute;
	content: '';
	top: 0px;
	right: 0px;
	bottom: 0px;
	left: 0px;
	background-color: rgba(0, 0, 0, 0.2);
	z-index: 1;
}
.carousel-control.left, .carousel-control.right{
	background-image: unset !important; 
	width: 52px;
	height: 52px;
}
.carousel-control.left{
	left: 30px;
	top: 45%;
}
.carousel-control.right {
	right: 30px;
	top: 45%;
}
.content-container{
	max-width: 900px;
	display: block;
	margin: 0 auto;
	padding-left: 20px;
	padding-right: 20px;
	padding-top: 45px;
	padding-bottom: 45px;
}
.content-header .content-container{
	position: relative;	
	height: 100%;
}
.content-header .content-header-inner{
	height: 100%;
}
.content-header h1{
	color: white;
	font-size: 70px;
	font-weight: 200;
	line-height: 70px;
	margin-bottom: 0px;
	margin-top: 0px;
	position: absolute;
	text-shadow: 2px 2px 2px black;
	bottom: 35px;
}
.two-columns{
	width: 100%;
	display: table;
	padding-top: 25px;
	padding-bottom: 25px;
}
.column-left{
	width: 40%;
	display: block;
	float: left;
}
.column-right{
	width: 60%;
	display: block;
	float: left;
}
.column-left h2{
	max-width: 225px;
	font-size: 36px;
	font-weight: 600;
	line-height: 45px;
	color: black;
	margin-top: 0px;
}
.column-right h4{
	font-weight: 600;
	font-size: 24px;
	color: black;
	line-height: 28px;
	margin-top: 0px;
	margin-bottom: 5px;
}
.column-right ul{
	margin-top: 15px;
	padding-left: 15px;
}
.column-right ul li{
	padding-left: 15px;
	margin-bottom: 10px;
}
.column-right ul li:last-child{
	margin-bottom: 0px;
}
.column-right p:last-child{
	margin-bottom: 0px;
}
.column-right p, .column-right ul li, .column-right a{
	font-size: 18px;
	font-weight: 400;
	line-height: 27px;
	color: black;
}
.page-button{
	list-style-type: none;
	padding-left: 0px;
	margin-bottom: 25px;
	margin-top: 25px;
	display: table;
	width: 100%;
}
.project-category{
	list-style-type: none;
	padding-left: 0px;
	margin-bottom: 60px;
	margin-top: 25px;
	display: table;
	width: calc(100% + 20px);
}
.page-button li a{
	color: white;
	width: 90px;
	display: block;
}
.project-category li a{
	color: white;
	display: block;
	height: 100%;
}
.page-button li a:hover{
	text-decoration: none;
}
.project-category li a:hover{
	text-decoration: none;
}
.page-button li{
	padding: 10px;
	background-color: #A8A8A8;
	font-weight: 600;
	font-size: 19px;
	text-transform: uppercase;
	color: white;
	width: calc(20% - 20px);
	margin-right: 20px;
	float: left;
	display: inline-block;
}
.project-category li{
	padding: 10px;
	background-color: #A8A8A8;
	font-weight: 600;
	font-size: 19px;
	text-transform: uppercase;
	color: white;
	width: calc(25% - 20px);
	margin-right: 20px;
	float: left;
	display: inline-block;
	height: 70px;
}
.page-button li:hover{
	background-color: black;
}
.project-category li:hover{
	background-color: black;
}
.page-button li:last-child{
	margin-right: 0px;
}
.project-category li:last-child{
	margin-right: 0px;
}
.active-button, .active-cat{
	background-color: black !important;	
}
.stick{
	color: black;
	font-size: 30px; 
	line-height: 40px;
	font-weight: 300;
	margin-bottom: 30px;
	text-align: right;
}
.stick span{
	font-weight: 600;
}
.page-id-47 .column-left h2{
	max-width: 285px;
}
#gform_1 input{
	width: 100% !important;
	height: 55px !important;
	border-radius: 5px;
	border: 1px solid #A8A8A8;
}
#gform_1 textarea{
	width: 100% !important;
	border-radius: 5px;
	border: 1px solid #A8A8A8;
}
#gform_1 label{
	color: #A8A8A8;
	font-size: 19px;
	font-weight: 600;
	line-height: 25px;
}
.gfield_required{
	display: none !important;
}
.input-left, .input-right{
	width: 50% !important;
	float: left !important;
	clear: unset !important;
	display: block !important;
	margin-bottom: 25px !important;
}
#gform_1 ul li{
	margin-bottom: 25px !important;
	margin-top: 0px !important;
}
#gform_1{
	margin-top: 40px;
}
#gform_1 .gfield_error{
	padding-right: 16px !important;
}
#gform_1 input#gform_submit_button_1{
	background-color: black;
	color: white;
	font-size: 19px;
	line-height: 25px;
	font-weight: 600;
	border-radius: 5px;
	width: 215px !important;
	padding-top: 15px;
	padding-bottom: 15px;
	display: block;
	border: 1px solid black;
	text-transform: uppercase;
	letter-spacing: 1px;
}
#gform_1 input#gform_submit_button_1:hover{
	background-color: white;
	color: black;
}
ul#primary-menu.menu li{
	position: relative;
}
ul#primary-menu.menu li > ul.sub-menu{
	background-color: #333333;
	width: 180px;
	list-style-type: none;
	padding-left: 0px;
	/*border-top: 1px solid #ddd;*/
	position: absolute;
	z-index: 10;
	top: 33px;
	visibility: hidden;
	left: 0px;
}
ul#primary-menu.menu li:hover > ul.sub-menu{
	visibility: visible;
}
ul#primary-menu.menu li > ul.sub-menu li:last-child{
	border-bottom: 0px;
}
ul#primary-menu.menu li > ul.sub-menu li{
	display: block;
	clear: both;
    border-bottom: 1px solid #444444;
	width: 100%;
}
ul#primary-menu.menu li > ul.sub-menu li a{
	color: #888888;
	text-align: left;
	display: block;
	width: 100%;
    font-size: 15px;
    font-weight: 500;
    line-height: 20px;
    padding-bottom: 10px !important;
    padding-left: 15px;
    padding-right: 15px;
    padding-top: 10px !important;
    text-transform: uppercase;
    padding-top: 8px;
    padding-bottom: 8px;
}
ul#primary-menu.menu li > ul.sub-menu li a:hover{
	color: #fff;
}
.mobmenu_content #mobmenuright .sub-menu{
	padding-left: 0px !important;
}
.accordion{
	width: 100%;
	display: table;
}
.accordion-item{
	width: 33.3333%;
	display: block;
	float: left;
}
.accordion-item-inner{
	margin-left: 15px;
	margin-right: 15px;
	margin-top: 15px;
	margin-bottom: 15px;
}
.accordion-item:nth-of-type(3n+1) .accordion-item-inner{
	margin-left: 0px;
}
.accordion-item:nth-of-type(3n+1){
	clear: left;
}
.accordion-item:nth-of-type(3n) .accordion-item-inner{
	margin-right: 0px;
}
.accordion-item-heading{
	width: 100%;
	height: 180px;
}
.fa-minus{
	display: none;
}
.fa-plus{
	font-size: 22px;
	color: white;
	display: block;
	clear: both;
}
.accordion-item-heading h4{
	font-size: 17px;
	color: white;
	font-weight: 600;
	line-height: 25px;
	margin-bottom: 0px;
}
.accordion-item-heading{
	position: relative;
}
.accordion-item-heading:before{
	content: '';
	position: absolute;
	top: 0px;
	right: 0px;
	bottom: 0px;
	left: 0px;
	background-color: rgba(0, 0, 0, 0.7);
}
.accordion-item-heading-inner{
	position: relative;
	width: calc(100% - 30px);
	top: 85px;
	text-transform: uppercase;
	left: 15px;
	right: 15px;
}
.accordion-item-heading:hover{
	cursor: pointer;
}
.accordion-item-heading:hover:before{
	background-color: rgba(0, 0, 0, 0);
}
.accordion-item-heading:hover h4, .accordion-item-heading:hover i{
	visibility: hidden;
}
.accordion-item-content{
	display: none;
}
.accordion-item-content p{
    font-size: 18px;
    font-weight: 400;
    line-height: 27px;
    color: black;
}
.accordion-item-content h5{
	font-size: 20px;
	color: black;
	font-weight: 600;
	line-height: 25px;
	margin-bottom: 15px;
}
.component-projects .lightbox {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    height: 100%;
    z-index: 99999;
    margin: 0;
    background: rgba(0, 0, 0, 0.5); 
}
.component-projects .lightbox-wrapper {
	position: relative;
	width: 680px;
	height: 540px;
	margin: 0 auto;
	background: #fff; 
}
.component-projects .lightbox-wrapper .lightbox-container {
	position: absolute;
	width: 680px;
	height: 540px;
	left: 0;
	top: 0; 
}
.component-projects .lightbox-wrapper .lightbox-container .project-photo {
	position: relative;
	width: 680px;
	height: 380px;
	background-size: cover; 
}
.component-projects .lightbox-wrapper .lightbox-container .project-nav {
	position: absolute;
	width: 680px;
	height: 50px;
	top: 330px;
	text-align: left;
	background: rgba(0, 0, 0, 0.6); 
}
.component-projects .lightbox-wrapper .lightbox-container .project-nav i {
	position: absolute;
	font-style: normal;
	font-size: 24px;
	line-height: 24px;
	margin: -12px 0 0 0;
	color: #fff;
	cursor: pointer;
	user-select: none;
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none; 
}
.component-projects .lightbox-wrapper .lightbox-container .project-nav .fa-chevron-left {
	top: 50%;
	left: 20px; 
}
.component-projects .lightbox-wrapper .lightbox-container .project-nav .fa-chevron-right {
	top: 50%;
	right: 20px; 
}
.component-projects .lightbox-wrapper .lightbox-container .project-nav .fa-times-circle {
	right: 10px;
	top: -310px;
}
.component-projects .lightbox-wrapper .lightbox-container .project-nav h5 {
	padding: 0px 0 0 90px; 
	font-size: 19px;
	color: white;
	font-weight: 600;
	line-height: 25px;
	margin-bottom: 0px;
	margin-top: 12px;
}
.component-projects .lightbox-wrapper .lightbox-container .project-content {
	padding: 20px 90px;
	text-align: left;
	overflow-y: auto;
	position: relative;
	height: 160px; 
}
.component-projects .block:before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle;
    margin-right: -0.25em; 
}
  .component-projects .centered {
    display: inline-block;
    vertical-align: middle;
    width: 680px; 
}
.component-projects .block {
    text-align: center; 
}
.component-projects{
	margin-bottom: 100px;
}
.person-position{
	display: block;
	font-weight: 600;
	font-size: 16px;
	color: black;
	line-height: 25px;
	margin-top: 0px;
	margin-bottom: 20px;
}
ul.sub-menu li.current-menu-item a{
	color: white !important;
}
.news-inner{
	display: table;
	width: 100%;
}
.news-left{
	display: block;
	float: left;
	max-width: calc(40% - 20px);
	margin-right: 20px;
}
.news-right{
	display: block;
	float: left;
	width: calc(60% - 20px);
	margin-left: 20px;
	height: auto;
	min-height: 250px;
	position: relative;
}
h4.news-title{
	font-size: 24px;
	font-weight: 600;
	color: #000;
	line-height: 30px;
}
.news-description p{
	font-size: 18px;
	font-weight: 400;
	color: #000;
	line-height: 27px;
}
.bottom-line{
	position: absolute;
	display: table;
	bottom: 0px;
}
.news-source{
	font-size: 14px;
	font-weight: 400;
	color: #9F9F9F;
	line-height: 17px;
	float: left;
	position: relative;
	top: 7px;
}
.news-right a{
	background-color: black;
	border-radius: 11px;
	padding: 10px 35px;
	font-size: 20px;
	font-weight: 600;
	color: #fff;
	display: inline-block;
	line-height: 27px;
	float: left;
	margin-right: 20px;
	border: 1px solid black;
}
.news-right a:hover{
	text-decoration: none;
	color: black;
	background-color: white;
}
.news{
	display: inline-block;
	padding-top: 50px;
	border-bottom: 1px solid #A8A8A8;
	padding-bottom: 50px;
	width: 100% !important;
}
.news:last-child{
	border-bottom: 0px;
}
.footer-right p:last-child{
	margin-top: 35px;
}
@media(max-width: 1099px){
	ul#primary-menu li a{
		font-size: 18px;
		padding: 10px 10px;
	}
	#header-logo img{
		max-width: 475px;
	}
	#site-navigation{
		height: 43px;
	}
	.page-template-tpl-home main{
		width: 100%;
		height: calc(100% - 221px);
	}
}
@media(max-width: 991px){
	ul#primary-menu li a{
		font-size: 16px;
		padding: 10px 5px;
	}
	#header-logo img{
		max-width: 364px;
	}
	#site-navigation{
		height: 33px;
	}
	.page-template-tpl-home main{
		width: 100%;
		height: calc(100% - 210px);
	}
	.footer-left{
		margin-bottom: 15px;
		margin-top: 15px;		
	}
	.footer-right, .footer-left{
		width: 100%;
		display: block;
		float: none;
		text-align: center;
		clear: both;
	}
	.carousel-control.right, .carousel-control.left{
		display: none;
	}
}
@media(max-width: 900px){
	.accordion-item-heading-inner{
		top: 60px;
	}
	.news-left, .news-right{
		width: 100% !important;
		float: none;
		clear: both;
		display: block;
		max-width: 100% !important;
		margin-left: 0px;
		margin-right: 0px;
	}
	.news-inner{
		max-width: 500px;
		margin: 0 auto;
	}
	.news{
		display: block;
	}
	.news-right{
		min-height: auto;
	}
	.bottom-line {
	    position: relative;
	    top: 10px;
	}
}
@media(max-width: 768px){
	.mob-expand-submenu{
		margin-top: -40px !important;
	}
	.mobmenu .sub-menu li a{
		padding-left: 35px !important;
	}
}
@media(max-width: 767px){
	.page-template-tpl-home main{
		height: 550px;
	}
	body.page-template-tpl-home, .carousel-caption-outter, .home-banner, .carouselFade, .carousel-inner, .item{
		height: unset;
		min-height: 550px;
	}
	.accordion-item-heading-inner{
		top: 85px;
	}
/*	.carousel{
		min-height: 450px;
	}*/
	.accordion-item{
		width: 50%;
	}
	.accordion-item:nth-of-type(3n) .accordion-item-inner{
		margin-right: 15px;
	}
	.accordion-item:nth-of-type(3n+1) .accordion-item-inner{
		margin-left: 15px;
	}
	.accordion-item:nth-of-type(3n+1){
		clear: unset;
	}
	.accordion-item:nth-of-type(2n) .accordion-item-inner{
		margin-right: 0px;
	}
	.accordion-item:nth-of-type(2n+1) .accordion-item-inner{
		margin-left: 0px;
	}
	.project-category li{
		width: calc(50% - 20px);
		margin-bottom: 15px;
		margin-top: 15px;
	}
	.input-left, .input-right{
		width: 100% !important;
	}
	.page-button li{
		width: calc(33.3333% - 20px);
		margin-bottom: 20px;
	}
	.page-button li:last-child{
		margin-bottom: 0px;
	}
	.column-left, .column-right{
		width: 100%;
		display: block;
		float: none;
		clear: both;
	}
	.column-left h2{
		margin-bottom: 25px;
		max-width: 100%;
	}
	.column-right ul{
		padding-right: 20px;
	}
	.column-left, .column-right{
		margin-bottom: 15px;
		margin-top: 15px;
		display: inline-block;
	}
	.left-image{
		width: 305px !important;
	}
}
@media(max-width: 680px){
	.component-projects .lightbox{
		display: none;
	}
	.accordion-item{
		width: 100%;
	}
	.accordion-item-content{
		display: none;
	}
	.component-projects .accordion .accordion-item .show-sub .accordion-item-content{
		max-height: 2000px !important;
		display: block;
	}
	.component-projects .accordion .accordion-item .accordion-item-content {
	    position: relative;
	    max-height: 0;
	    overflow: hidden;
	    background: #fff;
	    -webkit-transition: max-height 800ms ease-in-out;
	    -moz-transition: max-height 800ms ease-in-out;
	    -ms-transition: max-height 800ms ease-in-out;
	    transition: max-height 800ms ease-in-out;
	}
	.accordion-item-heading-inner{
		max-width: calc(100% - 30px);
		top: 145px;
	}
	.fa-plus{
		clear: unset;
		float: right;
	}
	.accordion-item-heading:before{
		top: 135px;
	}
	.accordion-item-heading:hover:before{
		background-color: rgba(0, 0, 0, 0.7); 
	}
	.component-projects .accordion .accordion-item .show-sub .accordion-item-heading i.fa-plus{
		display: none;
	}
	.component-projects .accordion .accordion-item .show-sub .accordion-item-heading i.fa-minus{
		display: block;
		float: right;
		font-size: 22px;
		color: white;
	}
	.accordion-item-heading:hover h4, .accordion-item-heading:hover i{
		visibility: visible;
	}
	.accordion-item .accordion-item-inner{
		margin-left: 0px !important;
		margin-right: 0px !important;
	}
}
@media(max-width: 520px){
	.carousel-caption h1{
		font-size: 45px;
		line-height: 55px;
	}
	.page-button li{
		width: calc(50% - 20px);
		margin-bottom: 20px;
	}
	.accordion-item-heading-inner{
		top: 125px;
	}
	.accordion-item-heading:before{
		top: 120px;
	}
	.project-category li{
		width: calc(100% - 20px);
	}
	.bottom-line{
		display: block;
	}
	.bottom-line .news-source{
		float: none;
		text-align: center;
		top: 15px;
	}
	.news-right a{
		display: block;
		float: none;
		max-width: 223px;
		margin: 0 auto;
	}
}
@media(max-width: 350px){
	.left-image{
		width: 100% !important;
	}
}
body.page-template-tpl-home{
    height: calc(100% - 29px);    
}
}