/* css color variables
	green - #80bc00 / rgba(128,188,0,1)
	grey - #414042 / rgba(65,64,66,1)
	black - #000000 / rgba(0,0,0,1)
	cool-grey - #939598 / rgba(147,149,152,1)
	white - #ffffff / rgba(255,255,255,1)
*/


/* general */

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
textarea {
    resize: none;
}
html {
	position: relative;
}
body {
	font-family: 'Roboto', sans-serif;
	font-size: 15px;
	font-weight: 400;
	font-style: normal;
	color: #414042;
	position: relative;
	word-wrap: normal !important;
	
}
html,
body {
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-smoothing: antialiased;
    -webkit-font-smoothing: antialiased;
    text-shadow: rgba(0, 0, 0, .01) 0 0 1px;
}
#page {
	word-wrap: normal !important;
}
/* custom flex grid */
.container {
	max-width: 1110px;
	width: 100%;
    margin-right: auto;
    margin-left: auto;
}
.container-fluid {
	width: 100%;
    margin-right: auto;
    margin-left: auto;
}
.row {
	max-width: 100%;
	margin-right: auto;
	margin-left: auto;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-flow: row wrap;
    flex-flow: row wrap;
}
.col-10 {
	-ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}
.col-5 {
	-ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
	padding-left: 15px;
}
.col-5:first-child,
.col-5:nth-child(2n + 1) {
	padding-left: 0px;
	padding-right: 15px;
}
.col-6-left {
	-ms-flex: 0 0 60%;
    flex: 0 0 60%;
    max-width: 60%;
	padding-right: 15px;
}
.col-4-right {
	-ms-flex: 0 0 40%;
    flex: 0 0 40%;
    max-width: 40%;
	padding-left: 15px;
}
.col-6-right {
	-ms-flex: 0 0 60%;
    flex: 0 0 60%;
    max-width: 60%;
	padding-left: 15px;
}
.col-4-left {
	-ms-flex: 0 0 40%;
    flex: 0 0 40%;
    max-width: 40%;
	padding-right: 15px;
}
.col-2-left {
	-ms-flex: 0 0 20%;
    flex: 0 0 20%;
    max-width: 20%;
	padding-right: 15px;
}
.col-3-left {
	-ms-flex: 0 0 30%;
    flex: 0 0 30%;
    max-width: 30%;
	padding-right: 15px;
}
/* typography */
h1 {
    font-family: 'Roboto', sans-serif;
    font-size: 40px;
    font-weight: 900;
    font-style: normal;
    font-stretch: normal;
    line-height: 44px;
    letter-spacing: 2.4px;
}
h2 {
    font-family: 'Roboto', sans-serif;
    font-size: 24px;
    font-weight: 700;
    font-style: normal;
    font-stretch: normal;
    line-height: 35px;
    letter-spacing: normal;
}
h3 {
	font-family: 'Roboto', sans-serif;
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 35px;
	letter-spacing: normal;
}
h4 {
	font-family: 'Roboto', sans-serif;
	font-size: 20px;
	font-weight: 900;
	font-style: normal;
	font-stretch: normal;
	line-height: 26px;
	letter-spacing: 1.2px;
}
  
h5 {
	font-family: 'Roboto', sans-serif;
	font-size: 14px;
	font-weight: 900;
	font-style: normal;
	font-stretch: normal;
	line-height: 28px;
	letter-spacing: 0.9px;
}
h6 {
	font-family: 'Roboto', sans-serif;
	font-size: 14px;
	font-weight: normal;
	font-style: normal;
	font-stretch: normal;
	line-height: 20px;
	letter-spacing: 2.5px;
}
p,
.paragraph {
	font-family: 'Roboto', sans-serif;
	font-size: 15px;
	font-weight: 400;
	font-style: normal;
	font-stretch: normal;
	line-height: 22px;
	letter-spacing: normal;
	/* margin-bottom: 20px; */
}
.paragraph2 {
	font-family: 'Roboto', sans-serif;
	font-size: 15px;
	font-weight: 400;
	font-style: normal;
	font-stretch: normal;
	line-height: 24px;
	letter-spacing: normal;
}
.paragraph-bold {
	font-family: 'Roboto', sans-serif;
	font-size: 15px;
	font-weight: 700;
	font-style: normal;
	font-stretch: normal;
	line-height: 22px;
	letter-spacing: normal;
}
.text-banner {
	font-family: 'Roboto', sans-serif;
	font-size: 130px;
	font-weight: 700;
	font-style: normal;
	font-stretch: normal;
	line-height: 120px;
	letter-spacing: 7.8px;
	text-align: center;
}
.text-banner-alternate {
	font-family: 'Roboto', sans-serif;
	font-size: 66px;
	font-weight: 700;
	font-style: normal;
	font-stretch: normal;
	line-height: 80px;
	letter-spacing: 3.9px;
	text-align: center;
}
.text-menu {
	font-family: 'Roboto', sans-serif;
	font-size: 14px;
	font-weight: 700;
	font-style: normal;
	font-stretch: normal;
	line-height: 20px;
	letter-spacing: normal;
	text-align: center;
}
.text-submenu {
	font-family: 'Roboto', sans-serif;
	font-size: 13px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 3.08;
	letter-spacing: normal;
	text-align: center;
}
.text-link {
	font-family: 'Roboto', sans-serif;
	font-size: 11px;
	font-weight: 700;
	font-style: normal;
	font-stretch: normal;
	line-height: 16px;
	letter-spacing: 0.7px;
	text-align: center;
}
.text-link-footer {
	font-family: 'Roboto', sans-serif;
	font-size: 11px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 16px;
	letter-spacing: 0.7px;
	text-align: center;
}
.number-text {
	font-family: 'Roboto', sans-serif;
	font-size: 50px;
	font-weight: 900;
	font-style: normal;
	font-stretch: normal;
	/* line-height: 28px; */
	line-height: 52px;
	letter-spacing: normal;
	text-align: left;
	color: #80bc00;
}
.bold,
strong {
	font-weight: 700 !important;
}
h3 p {
	font-family: 'Roboto', sans-serif;
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 35px;
	letter-spacing: normal;
}
a {
	color: #414042;
}
a:hover,
a:active {
	text-decoration: underline;
	color: #80bc00;
}
a:focus {
	outline: none;
}
a[href^=tel] {
	text-decoration:inherit;
	color: inherit;
}
.clear-both {
	clear: both;
	display: table;
}
.hide, div.hide, .button.hide {
	display: none;
}
.button,
.button-filled {
	width: 160px;
	height: 44px;
	border-radius: 22px;
	border: solid 2px #80bc00;
	font-family: 'Roboto', sans-serif;
	font-size: 11px;
	font-style: normal;
  	font-stretch: normal;
	font-weight: 700;
	text-transform: uppercase;
	line-height: 20px;
	text-align: center;
	letter-spacing: 0.7px;
	padding: 1em 2em;
	text-shadow: none;
	cursor: pointer;
	display: inline-block;
	min-width: 170px;
}
.button {
	background-color: transparent;
	color: #80bc00;
}
.button-filled {
	background-color: #80bc00;
	color: #ffffff;
}
.button:hover,
.button-filled:hover {
	background-color: #80bc00;
	border: solid 2px #80bc00;
	color: #ffffff;
	box-shadow: 0px 10px 20px 0 rgba(44, 44, 41, 0.35);
	text-decoration: none;
}
#button-filters {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#button-filters .button-filter {
	display: flex;
	flex-flow: column nowrap;
	justify-content: center;
	height: 35px;
    background-color: rgba(147, 149, 152, 0.4);
    border-radius: 25px;
    /* min-width: 132px; */
    color: #000000;
    background-image: url(../images/svg/close_small.svg);
    background-repeat: no-repeat;
    background-position-y: center;
    background-position-x: 10px;
    font-size: 13px;
    font-weight: 300;
    text-transform: uppercase;
    padding: 0;
    padding-left: 40px;
    padding-right: 25px;
	width: auto;
	margin-right: 20px;
	margin-bottom: 10px;
	cursor: pointer;
}
#button-filters .button-filter:hover {
	background-color: rgba(147, 149, 152, 0.3);
	background-image: url(../images/svg/close_small.svg);
	background-repeat: no-repeat;
	background-position-y: center;
	background-position-x: 10px;
}
#button-filters .button-filter .parent-category-name {
	opacity: 0.6;
	font-size: 10px;
	font-weight: bold;
	color: rgba(65, 64, 66, 0.6);
	display: none;
}
#button-filters .button-filter .parent-category-name.show {
	display: block;
}
.treehouse-body-frame {
	/* display: none; */
    position: fixed;
    z-index: 300;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border: 35px solid #fff;
    pointer-events: none;
}
.image-label {
	background-color: rgba(0,0,0,0.8);
	-webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    -o-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
	transform: rotate(-90deg);
	width: 235px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding-left: 25px;
	-webkit-transform-origin: 50% 51%;
    transform-origin: 50% 51%;
}
.image-label span {
	font-size: 14px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: normal;
	letter-spacing: normal;
	text-align: left;
	color: #ffffff;
	text-transform: uppercase;
}
/* select2 overrides */
.select2-container--default .select2-selection--single {
	border: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
	text-transform: uppercase;
	font-size: 14px;
	font-weight: 700;
	line-height: 20px;
	color: #414042;
}
.select2-container--default .select2-selection--single .select2-selection__rendered:hover {
	color: #80bc00;
}
.select2-dropdown {
	border: 0px !important;
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
	background-color: #ffffff !important;
	color: #80bc00 !important;
}
.select2-results__option {
	text-transform: uppercase !important;
	font-size: 13px;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
	border-color: #80bc00 transparent transparent transparent !important;
	border-width: 7px 6px 0 6px !important;
	margin-top: -4px !important;
}
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
	border-color: transparent transparent #80bc00 transparent !important;
    border-width: 0 6px 7px 6px !important;
}
/* shadow */
.img-shadow {
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
}
/* green absolute grid */
.green-grid {
	width: 188px;
	height: 83px;
	background-image: url('../images/svg/pattern.svg');
	background-repeat: repeat;
	position: absolute;
	z-index: 10;
}
/* slick carrousel overrides */
.slick-slider .slick-dots {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 30px;
}
.slick-slider .slick-dots li {
	list-style: none;
    display: flex;
	margin-right: 10px;
}
.slick-slider .slick-dots li:last-child {
	margin-right: 0px;
}
.slick-slider .slick-dots li button {
	font-size: 0;
	line-height: 0;
	outline: none;
	border-radius: 50%;
	background-color: rgba(65, 64, 66, 0.3);
	height: 8px;
	width: 8px;
	padding: 0;
}
.slick-slider .slick-dots li.slick-active button {
	background-color: rgba(65, 64, 66, 1);
	height: 8px;
	width: 8px;
    margin: 0;
}
/* video */
.video iframe {
	width: 100%;
	height: 100%;
	position: relative;
	display: none;
}
.video iframe.show {
	display: block;
}
.video {
	/* width: 100%;
	height: 100%;
	position: relative;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat; */
	width: calc(100% - 70px);
    height: calc(100vh - 80px);
    position: relative;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    margin: 0 auto;
}
.portfolio-modal-slider .video {
	width: 100%;
}
.play,
.play svg {
	cursor: pointer;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 999;
	opacity: 0.8;
	transition: opacity 0.4s ease-in-out;
	display: none;
}
.play.show,
.play.show svg  {
	display: block;
}
.play svg path {
    cursor: pointer;
	position: absolute;
}
.play:hover,
.play svg path:hover {
	opacity: 1;
	transition: opacity 0.4s ease-in-out;
}
/* footer */
#backToTop {
	display: flex;
	justify-content: flex-end;
	flex-direction: column;
    align-items: center;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transition: all 0.2s ease-in-out;
	position: fixed;
    bottom: 80px;
    z-index: 999;
	right: 100px;
}
.backToTop-text {
	color: #80bc00;
	font-size: 11px;
	font-weight: 700;
	margin-top: -5px;
}
#backToTop.visible {
	opacity: 1;
	visibility: visible;
	transition: all 0.2s ease-in-out;
	opacity: 1;
    visibility: visible;
    transition: all 0.2s ease-in-out;
    display: flex;
    flex-direction: column;
    align-items: center;
}
#footer {
	padding-bottom: 45px;
}
.site-footer {
	border-top: none;
}
#footer .site-links {
	display: flex;
    align-items: center;
	justify-content: center;
	margin-bottom: 48px;
}
#footer .site-links ul {
	display: flex;
	flex: row nowrap;
}
#footer .site-links ul li {
	list-style: none;
	font-size: 11px;
}
#footer .site-links ul > li:not(:last-child):after {
	content: '|';
	margin: 0 5px;
}
#footer .site-links ul li a {
	text-transform: uppercase;
}
#footer .site-copyright {
	display: flex;
	justify-content: flex-start;
}
#footer .site-copyright span {
	font-size: 11px;
	line-height: 16px;
	letter-spacing: 0.7px;
}
#footer .site-copyright .bold {
	margin: 0 3px;
}
#footer .site-social {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
#footer .site-social span {
	font-size: 11px;
	line-height: 16px;
	letter-spacing: 0.7px;
	text-transform: uppercase;
	color: #80bc00;
	font-weight: 700;
}
#footer .site-social .social-instagram {
	margin-left: 20px;
	margin-right: 10px;
}
#footer .site-social .social-facebook {
	margin-right: 10px;
}
#footer .site-social::before {
	content: '';
	width: 18px;
	height: 3px;
	background-color: #80bc00;
	display: inline-block;
	margin-right: 5px;
	margin-bottom: 3px;
}
/* home blocks */
.number-text:after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 0px;
    margin-bottom: 15px;
    margin-left: 28px;
}
.block-lead {
	margin-bottom: 28px;
}
.block-lead h1 {}
.block-lead h1 span {
	text-transform: uppercase;
	background-color: #000000;
	padding: 3px 10px;
	line-height: 1.3;
	display: inline;
	color: #ffffff;
	box-decoration-break: clone;
  	-webkit-box-decoration-break: clone;
}
.block-text {}
.block-text p {
	margin-bottom: 20px;
}
.block-lead-small {
	margin-bottom: 40px;
}
.block-lead-small h4 {
	color: #ffffff;
}
.block-lead-small h4 span {
	text-transform: uppercase;
	background-color: #000000;
	padding: 3px 10px;
}
/* scroll down btn */
.scroll-down {
	-webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
	transform: rotate(90deg);
	position: absolute;
	bottom: 70px;
    left: 20px;
}
.scroll-down span {
	color: rgba(255, 255, 255, 0.6);
	text-transform: uppercase;
	font-size: 11px;
	font-weight: 300;
	cursor: pointer;
}
.scroll-down span::before {
	-webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
	transform: rotate(90deg);
	content: '';
	width: 2px;
	height: 17px;
	display: inline-block;
	vertical-align: middle;
	margin-right: 14px;
	background-color: #ffffff;

}
.site-content {
	padding: 0;
	margin-top: 80px;
}
/* 00 - top menu bar */
.site-branding {
	padding: 0;
}
#treehouse-menu-bar {
	background-color: #ffffff;
    width: 100%;
    height: 80px;
    display: flex;
	align-items: center;
	justify-content: center;
	position: fixed;
	top: 0;
	z-index: 999;
}
.treehouse-menu-bar-branding .site-branding svg {
	width: 173px;
	height: 55px;
}
.treehouse-menu-button {
	display: flex;
	align-items: center;
	cursor: pointer;
	justify-content: flex-start;
	position: absolute;
	top: 13px;
	left: 40px;
}
.treehouse-menu-button svg {
	width: 53px;
	height: 53px;
	transition: opacity 0.3s ease-in-out;
}
.treehouse-menu-button svg:hover {
	opacity: 0.7;
	transition: opacity 0.3s ease-in-out;
}
.treehouse-menu-button span {
	margin-left: 7px;
	text-transform: uppercase;
	color: #80bc00;
	font-size: 11px;
	line-height: 16px;
	font-weight: 700;
	letter-spacing: 0.7px;
}
.social-lat {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	-webkit-transform:  rotate(90deg) translateX(-50%);
    -moz-transform:  rotate(90deg) translateX(-50%);
    -o-transform:  rotate(90deg) translateX(-50%);
    -ms-transform: rotate(90deg) translateX(-50%);
	transform: rotate(90deg) translateX(-50%);
	-webkit-transform-origin: 50% 51%;
	transform-origin: 50% 51%;
	position: fixed;
	top: 50%;
	right: -48px;
	z-index: 999;
	opacity: 0;
	transition: all 0.3s ease-in-out;
}
.social-lat::before {
	content: '';
	width: 18px;
	height: 2px;
	background-color: #80bc00;
	display: inline-block;
	margin-right: 5px;
}
.social-lat span {
	font-size: 11px;
	font-weight: 700;
	color: #80bc00;
	text-transform: uppercase;
}
.social-lat .social-instagram {
	margin-left: 20px;
    margin-right: 10px;
	-webkit-transform:  rotate(-90deg);
    -moz-transform:  rotate(-90deg);
    -o-transform:  rotate(-90deg);
    -ms-transform: rotate(-90deg);
	transform: rotate(-90deg);
}
.social-lat .social-facebook {
	margin-left: 10px;
	-webkit-transform:  rotate(-90deg);
    -moz-transform:  rotate(-90deg);
    -o-transform:  rotate(-90deg);
    -ms-transform: rotate(-90deg);
	transform: rotate(-90deg);
}
.social-lat.visible {
	opacity: 1;
	transition: all 0.3s ease-in-out;
}
/* 00 - HEADER */
#frontpage-header,
.block-banner {
	margin-bottom: 80px;
	height: calc(100vh - 80px);
}
.banner-slider-wrapper,
.block-banner-slider-wrapper,
.portfolio-modal-slider-wrapper {
	position: relative;
}

.frontpage-header-slider,
.block-banner-header-slider {
	visibility:hidden;
	opacity:0;	 
	transition: opacity 1s;
}

.frontpage-header-slider.slick-initialized,
.block-banner-header-slider.slick-initialized {
   visibility:visible;
   opacity:1;
}

.frontpage-header-slider .slide,
.block-banner-header-slider .slide {
   display:none ;
}

.frontpage-header-slider .slide:first-child,
.block-banner-header-slider .slide:first-child {
   display:block;
   visibility:hidden;
} 

.frontpage-header-slider.slick-initialized .slide,
.block-banner-header-slider.slick-initialized .slide {
   display:block;
   visibility:visible!important;
}


.frontpage-header-slider,
.block-banner-header-slider {
	max-width: 100%;
	position: relative;
}
.frontpage-header-slider {
    width: 100%;
    height: 100%;
}
.frontpage-header-slider .slide,
.block-banner-slider-wrapper .slide {
	width: 100%;
	height: 700px;
	background-image: url('../images/temp_images/banner_homepage.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
	height: calc(100vh - 120px);
	min-height: 500px;
}
.frontpage-header-slider-arrows,
.block-banner-header-slider-arrows {
	position: absolute;
    display: flex;
    justify-content: space-between;
    align-items: center;
	top: 50%;
	width: 100%;
	transform: translateY(-50%);
}
.frontpage-header-slider-arrows .slider-prev,
.block-banner-header-slider-arrows .slider-prev {
	/* background-image: url('../images/svg/big_arrow_left.svg');
	background-repeat: no-repeat; */
	width: 30px;
	height: 48px;
	background-color: transparent;
	cursor: pointer;
	background-size: contain;
	margin-left: 70px;
}
.frontpage-header-slider-arrows .slider-next,
.block-banner-header-slider-arrows .slider-next {
	/* background-image: url('../images/svg/big_arrow_right.svg');
	background-repeat: no-repeat; */
	width: 30px;
	height: 48px;
	background-color: transparent;
	cursor: pointer;
	background-size: contain;
	margin-right: 70px;
}
.frontpage-header-slider-arrows .slider-prev svg path,
.block-banner-header-slider-arrows .slider-prev svg path,
.frontpage-header-slider-arrows .slider-next svg path,
.block-banner-header-slider-arrows .slider-next svg path {
	fill: rgba(255,255,255,0.2);
} 
.frontpage-header-slider-arrows .slider-prev:hover svg path,
.block-banner-header-slider-arrows .slider-prev:hover svg path,
.frontpage-header-slider-arrows .slider-next:hover svg path,
.block-banner-header-slider-arrows .slider-next:hover svg path {
	fill: #80bc00;
}
#frontpage-header .frontpage-header-slider .slider-arrows,
.block-banner-header-slider .slider-arrows,
.portfolio-modal-slider .slider-arrows {
	position: absolute;
    width: 30px;
    height: 48px;
	top: 50%;
	transform: translateY(-50%);
    background-color: transparent;
    background-size: contain;
    cursor: pointer;
    margin-left: 70px;
    z-index: 10;
}
#frontpage-header .frontpage-header-slider .slider-prev,
.block-banner-header-slider .slider-prev,
.portfolio-modal-slider .slider-prev {
	left: 0;
    margin-left: 70px;
}
#frontpage-header .frontpage-header-slider .slider-next,
.block-banner-header-slider .slider-next,
.portfolio-modal-slider .slider-next {
	right: 0;
    margin-right: 70px;
}
#frontpage-header .frontpage-header-slider .slider-arrows:hover svg path,
.block-banner-header-slider .slider-arrows:hover svg path,
.portfolio-modal-slider .slider-arrows:hover svg path {
	fill: #80bc00;
}
.frontpage-header-slider.slick-slider .slick-dots,
.block-banner-header-slider.slick-slider .slick-dots {
	display: flex;
    flex-wrap: wrap;
    justify-content: center;
    position: absolute;
    bottom: 50px;
    left: 50%;
    transform: translate(-50%, -50%);
}
.frontpage-header-slider.slick-slider .slick-dots li,
.block-banner-header-slider.slick-slider .slick-dots li,
.portfolio-modal-slider.slick-slider .slick-dots li {
	list-style: none;
    display: flex;
	margin-right: 10px;
}
.frontpage-header-slider.slick-slider .slick-dots li:last-child,
.block-banner-header-slider.slick-slider .slick-dots li:last-child,
.portfolio-modal-slider.slick-slider .slick-dots li:last-child {
	margin-right: 0px;
}
.frontpage-header-slider.slick-slider .slick-dots li button,
.block-banner-header-slider.slick-slider .slick-dots li button,
.portfolio-modal-slider.slick-slider .slick-dots li button {
	font-size: 0;
	line-height: 0;
	outline: none;
	border-radius: 50%;
	background-color: rgba(128, 188, 0, 0.3);
	height: 8px;
	width: 8px;
	padding: 0;
}
.frontpage-header-slider.slick-slider .slick-dots li.slick-active button,
.block-banner-header-slider.slick-slider .slick-dots li.slick-active button,
.portfolio-modal-slider.slick-slider .slick-dots li.slick-active button {
	background-color: rgba(128, 188, 0, 1);
	height: 8px;
	width: 8px;
    margin: 0;
}
.frontpage-header-custom-nav {
	display: none;
	flex-direction: column;
	position: absolute;
	top: 60px;
	right: 150px;
}
.frontpage-header-custom-nav.show {
    display: flex;
}
.frontpage-header-custom-nav span {
	font-size: 14px;
	line-height: 20px;
	letter-spacing: 0.9px;
	font-weight: 900;
	color: #ffffff;
	text-transform: uppercase;
	opacity: 0.6;
	margin-bottom: 15px;
}
.frontpage-header-custom-nav span::before {
	content: '';
	display: inline-block;
	vertical-align: middle;
	width: 17px;
	height: 2px;
	background-color: transparent;
	margin-right: 10px;
}
.frontpage-header-custom-nav span:hover,
.frontpage-header-custom-nav span.activeSlide {
    opacity: 1;
    cursor: pointer;
}
.frontpage-header-custom-nav span:hover::before,
.frontpage-header-custom-nav span.activeSlide::before {
    background-color: #ffffff;
    margin-bottom: 2px;
}
.banner-black-overlay {
	width: 100%;
	height: 100%;
	display: block;
	background-color: rgba(0,0,0,0.2);
}
.blur-frame-wrapper {
	width: 250px;
	height: 376px;
	position: absolute;
    top: 50%;
    left: 50%;
	transform: translate(-50%, -50%);
	overflow: hidden;
}
.blur-frame {
	/* background-color: #80bc00; */
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 100vw;
    height: calc(100vh - 120px);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    filter: blur(13px);
    -webkit-filter: blur(13px);
}
.frontpage-title-subtitle-wrapper {
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
}
.page-title-subtitle-wrapper {
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
}
.frontpage-header-slider-sub-title,
.block-banner-header-slider-sub-title {
	margin-bottom: 50px;
    /* position: absolute; */
    /* top: 32%; */
    /* left: 50%; */
    /* transform: translate(-50%, -32%); */
    text-align: center;
    text-transform: uppercase;
    /* width: 60%; */
}
.frontpage-header-slider-sub-title h6,
.block-banner-header-slider-sub-title h6 {
	text-transform: uppercase;
	font-size: 14px;
	line-height: 20px;
	letter-spacing: 2.5px;
	color: #ffffff;
}
.frontpage-header-slider-title {
	/* position: absolute; */
    /* top: 56%; */
    /* left: 50%; */
    /* transform: translate(-50%, -56%); */
    text-align: center;
    text-transform: uppercase;
    /* width: 60%; */
}
.block-banner-header-slider-title {
	/* position: absolute; */
    /* top: 56%; */
    /* left: 50%; */
    /* transform: translate(-50%, -56%); */
    text-align: center;
    text-transform: uppercase;
    /* width: 80%; */
}
.frontpage-header-slider-title h1 {
	font-size: 66px;
	color: #ffffff;
	font-weight: 700;
	line-height: 80px;
	letter-spacing: 3.9px;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
	display: flex;
	justify-content: center;
}
.block-banner-header-slider-title h1 {
	font-weight: 700;
	font-size: 120px;
	line-height: 120px;
	letter-spacing: 7.8px;
	color: #ffffff;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
	display: flex;
	justify-content: center;
}
.banner-slider-wrapper a.button {
	position: absolute;
    bottom: 86px;
	right: 150px;
	background-color: rgba(0, 0, 0, 0.6);
}
.banner-slider-wrapper a.button:hover {
	background-color: #80bc00;
    border: solid 2px #80bc00;
    color: #ffffff;
    box-shadow: 0px 10px 20px 0 rgba(44, 44, 41, 0.35);
    text-decoration: none;
}

/* 01 block - o que é*/
#whatis-wrapper {
	margin-bottom: 140px;
}
#whatis-wrapper .home-what-is {}
#whatis-wrapper .home-what-is .whatis-left {}
#whatis-wrapper .home-what-is .whatis-right {
	position: relative;
}
#whatis-wrapper .whatis-img {
	width: 432px;
	max-width: 100%;
	height: 504px;
	background-image: url('../images/temp_images/treehouse_a.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#whatis-wrapper .whatis-slider .slide {
	width: 432px;
	max-width: 100%;
	height: 504px;
	background-image: url('../images/temp_images/treehouse_a.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#whatis-wrapper .whatis-slider .slick-list {
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
}
#whatis-wrapper .whatis-slider-two {
	margin-top: 115px;
}
#whatis-wrapper .whatis-slider-two .slide {
	width: 648px;
	max-width: 100%;
	height: 432px;
	background-image: url('../images/temp_images/treehouse_b.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#whatis-wrapper .custom-slide-arrows {
	display: flex;
	flex-direction: column;
	/* position: absolute;
	bottom: 0; */
}
.whatis-slider-two-prev {
	background-image: url('../images/svg/mini_arrow_left.svg');
	background-repeat: no-repeat;
	width: 10px;
	height: 16px;
	background-color: transparent;
	cursor: pointer;
}
.whatis-slider-two-next {
	background-image: url('../images/svg/mini_arrow_right.svg');
	background-repeat: no-repeat;
	width: 10px;
	height: 16px;
	background-color: transparent;
	cursor: pointer;
	display: block;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-next-wrapper {
	width: 30px;
	height: 30px;
	display: flex;
    align-items: center;
	justify-content: center;
	margin-top: 5px;
	cursor: pointer;
	border-radius: 50%;
	position: relative;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-prev-wrapper {
	width: 30px;
	height: 30px;
	display: flex;
    align-items: center;
	justify-content: center;
	cursor: pointer;
	border-radius: 50%;
	position: relative;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-next-wrapper:hover,
#whatis-wrapper .custom-slide-arrows .slide-arrow-prev-wrapper:hover {
	background-color: #80bc00;
	border-radius: 50%;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-next-wrapper:hover .whatis-slider-two-next {
	background-image: url('../images/svg/mini_arrow_right_w.svg');
	background-repeat: no-repeat;
	width: 10px;
	height: 16px;
	background-color: transparent;
	cursor: pointer;
	display: block;
	margin-left: 2px;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-prev-wrapper:hover .whatis-slider-two-prev {
	background-image: url('../images/svg/mini_arrow_left_w.svg');
	background-repeat: no-repeat;
	width: 10px;
	height: 16px;
	background-color: transparent;
	cursor: pointer;
	display: block;
	margin-right: 2px;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-prev-wrapper > div,
#whatis-wrapper .custom-slide-arrows .slide-arrow-next-wrapper > div  {
	position: absolute;
	left: 40px;
	min-width: 100px;
	font-size: 11px;
	letter-spacing: 0.7px;
	font-weight: 700;
	color: #80bc00;
	text-transform: uppercase;
	opacity: 0;
}
#whatis-wrapper .custom-slide-arrows .slide-arrow-prev-wrapper:hover > div,
#whatis-wrapper .custom-slide-arrows .slide-arrow-next-wrapper:hover > div  {
	opacity: 1;
}
#whatis-wrapper .left-lead-text {
	width: 284px;
    margin-bottom: 60px;
    min-height: 175px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-end;
}
#whatis-wrapper .slider-pieces {
	margin-top: 70px;
	position: relative;
}
#whatis-wrapper .slider-pieces .block-text p {
	font-weight: 300;
}
#whatis-wrapper .info-wrapper {
	display: flex;
	flex-direction: column;
}
#whatis-wrapper .info-wrapper .block-text {
	min-height: 186px;
}
#whatis-wrapper .slider-counter-wrapper {
	position: absolute;
    top: 64%;
	transform: translateY(-64%);
	right: -100px;
}
#whatis-wrapper .slider-counter-wrapper::after {
	content: '';
    display: block;
    width: 45px;
    height: 2px;
	background-color:	#80bc00;
	margin-top: 2px;
}
#whatis-wrapper .slider-counter-wrapper .slider-counter .curr-slide {
	font-size: 20px;
	letter-spacing: 1.2px;
	color: #80bc00;
	font-weight: 700;
	margin-left: 5px;
}
#whatis-wrapper .slider-counter-wrapper .slider-counter .separator,
#whatis-wrapper .slider-counter-wrapper .slider-counter .total-slide {
	font-size: 11px;
	font-weight: 300;
	letter-spacing: 0.7px;
	color: #414042;
}
/* 02 block - construção modular*/
#modconstruction-wrapper {
	margin-bottom: 140px;
}
#modconstruction-wrapper .home-modconstruction {}
#modconstruction-wrapper a.button {
	margin-top: 55px;
}
#modconstruction-wrapper .modconst-right {
	position: relative;
}
#modconstruction-wrapper .modconst-img {
	width: 668px;
	max-width: 100%;
	height: 376px;
	background-image: url('../images/temp_images/construcao_modular.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: absolute;
	top: 290px;
	left: 15px;
	z-index: 1;
}

#modconstruction-wrapper .green-card {
	width: 294px;
	background-color: #80bc00;
	padding: 44px 45px 50px 30px;
	position: absolute;
	top: 160px;
	left: 120px;
	z-index: 2;
}
#modconstruction-wrapper .green-card h3 {
	color: #ffffff;
}
#modconstruction-wrapper .green-grid {
    top: 633px;
    right: 83px;
}
/* 03 block - estruturas */
#structures-wrapper {
	margin-bottom: 140px;
}
#structures-wrapper .home-structures {}
#structures-wrapper .home-structures .left-lead-text span {
	color: #414042;
}
#structures-wrapper .home-structures a.button-filled,
#structures-wrapper .home-structures a.button {
	margin-top: 55px;
}
#structures-wrapper .structures-img {
	width: 402px;
	max-width: 100%;
	height: 850px;
	background-image: url('../images/temp_images/estruturas.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	z-index: 1;
}
#structures-wrapper .number-text {
	margin-top: 220px;
}
#structures-wrapper .structures-center {
	position: relative;
}
#structures-wrapper .green-grid {
	top: 42px;
    right: -65px;
}
#structures-wrapper ul li {
	list-style-position: inside;
}
/* 04 block - reabilitação */
#rehabilitation-wrapper {
	margin-bottom: 140px;
	margin-top: 240px;
}
#rehabilitation-wrapper .grey-bg-wrapper {
	background: linear-gradient(to right, rgba(147, 149, 152, 0.3) 0%, rgba(147, 149, 152, 0.3) 72%, #ffffff 72%, #ffffff 100%);
	padding-top: 80px;
	padding-bottom: 60px;
}
#rehabilitation-wrapper .block-text {
	width: 444px;
}
#rehabilitation-wrapper a.button {
	margin-top: 55px;
}
#rehabilitation-wrapper .rehabilitation-right {
	position: relative;
}
#rehabilitation-wrapper .rehabilitation-img {
	width: 540px;
	max-width: 100%;
	height: 540px;
	background-image: url('../images/temp_images/reabilitacao.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	z-index: 2;
	position: absolute;
	top: -200px;
}

/* 05 block - nossos projectos */
#ourprojects-wrapper {
	margin-bottom: 140px;
}
#ourprojects-wrapper .container-ourprojects {
	max-width: 1366px;
    padding-left: 125px;
}
#ourprojects-wrapper .home-ourprojects {
	position: relative;
}
#ourprojects-wrapper .ourprojects-left {
	position: relative;
}
#ourprojects-wrapper .home-ourprojects a.button {
	margin-top: 55px;
}
#ourprojects-wrapper .ourprojects-right {
	flex: 0 0 70%;
    max-width: 70%;
	height: auto;
	align-items: flex-start;
    justify-content: flex-start;
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel {
	height: 550px;
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .slick-list {
	height: 550px;
    padding-top: 25px;
}

#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .slide {
	width: 294px;
	height: 500px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	margin-right: 30px;
	margin-left: 0;
	position: relative;
	cursor: pointer;
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .slide a {
	width: 100%;
	height: 100%;
	display: block;
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .slide .black-overlay {
	width: 100%;
	height: 100%;
	z-index: 99;
	transition: all 0.2s ease-in-out;
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .slide a:hover .black-overlay {
	background-color: rgba(0,0,0,0.0);
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
	transition: all 0.3s ease-in-out;
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .sl-01 {
	background-image: url('../images/temp_images/portfolio_tb1.jpg');
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .sl-02 {
	background-image: url('../images/temp_images/portfolio_tb2.jpg');
}
#ourprojects-wrapper .ourprojects-right .ourprojects-carrousel .sl-03 {
	background-image: url('../images/temp_images/portfolio_tb3.jpg');
}
#ourprojects-wrapper .ourprojects-right .slide .linear-gradient {
	width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(to top, rgba(0,0,0,0.3) 12%,transparent 100%);
    position: absolute;
    top: 0;
    left: 0;
}
#ourprojects-wrapper .ourprojects-right .slide .info {
	position: absolute;
    bottom: 24px;
	left: 15px;
	max-width: 200px;
}
#ourprojects-wrapper .ourprojects-right .slide .info .category {
	font-size: 11px;
	line-height: 16px;
	letter-spacing: 2px;
	color: #80bc00;
	text-transform: uppercase;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
}
#ourprojects-wrapper .ourprojects-right .slide .info .title {
	color: #ffffff;
	/* font-size: 20px; */
	font-size: 18px;
	font-weight: 900;
	line-height: 26px;
	letter-spacing: 1.2px;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
	text-transform: uppercase;
} 
#ourprojects-wrapper .ourprojects-right .slide .image-label {
	position: absolute;
	bottom: 98px;
	right: -98px;
}
#ourprojects-wrapper .ourprojects-custom-controls {
	display: flex;
	flex-direction: column;
	position: absolute;
	bottom: 20px;
	right: 20px;
}
#ourprojects-wrapper .ourprojects-custom-controls .slide-arrow-prev-wrapper {
	width: 30px;
	height: 30px;
	display: flex;
    align-items: center;
	justify-content: center;
	cursor: pointer;
	border-radius: 50%;
	position: relative;
}
#ourprojects-wrapper .ourprojects-custom-controls .slide-arrow-next-wrapper {
	width: 30px;
	height: 30px;
	display: flex;
    align-items: center;
	justify-content: center;
	margin-top: 5px;
	cursor: pointer;
	border-radius: 50%;
	position: relative;
}
#ourprojects-wrapper .ourprojects-custom-controls .slide-arrow-prev-wrapper:hover,
#ourprojects-wrapper .ourprojects-custom-controls .slide-arrow-next-wrapper:hover {
	background-color: #80bc00;
	border-radius: 50%;
}
#ourprojects-wrapper .ourprojects-slider-two-prev {
	background-image: url('../images/svg/mini_arrow_left.svg');
	background-repeat: no-repeat;
	width: 10px;
	height: 16px;
	background-color: transparent;
	cursor: pointer;
	margin-right: 2px;
}
#ourprojects-wrapper .ourprojects-slider-two-next {
	background-image: url('../images/svg/mini_arrow_right.svg');
	background-repeat: no-repeat;
	width: 10px;
	height: 16px;
	background-color: transparent;
	cursor: pointer;
	margin-left: 2px;
}
#ourprojects-wrapper .ourprojects-custom-controls .slide-arrow-prev-wrapper:hover .ourprojects-slider-two-prev {
	background-image: url('../images/svg/mini_arrow_left_w.svg');
} 
#ourprojects-wrapper .ourprojects-custom-controls .slide-arrow-next-wrapper:hover .ourprojects-slider-two-next {
	background-image: url('../images/svg/mini_arrow_right_w.svg');
} 
/* 06 block - entre em contacto */
#contact-wrapper {
	margin-bottom: 140px;;
}
#contact-wrapper .home-contact {
	position: relative;
	min-height: 645px;
}
#contact-wrapper .home-contact .container {
    position: relative;
}
#contact-wrapper .home-contact a.button-filled {
	margin-top: 55px;
}
/* this will change with acf image field created */
#contact-wrapper .bg-image-wrapper {
	width: 75%;
    height: 100%;
    background-image: url(../images/temp_images/contacto.jpg);
    background-size: cover;
    background-position: center center;
    margin-left: auto;
    position: absolute;
    z-index: 0;
    right: 0;
    top: 0;
}
#contact-wrapper .left-white-card {
	width: 324px;
	max-width: 100%;
	background-color: #ffffff;
	margin-top: 40px;
	padding: 80px 32px 76px 32px;
}
#contact-wrapper .left-white-card .left-lead-text {
	padding-right: 50px;
}
#contact-wrapper .green-grid {
    bottom: -40px;
    right: 83px;
}
/* BLOCKS */
/* block-a */
.block-a {}
.block-a-right.col-4-right {
	position: relative;
}
.block-a .block-a-slider .slick-list {
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
}
.block-a .block-a-slider .slide {
	width: 432px;
	max-width: 100%;
	height: 504px;
	background-image: url('../images/temp_images/treehouse_a.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.block-a .block-lead {
	margin-bottom: 0;
}
.block-a .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
.block-a .block-text {
	display: flex;
	flex-direction: column;
}
.block-a .block-text .lead {
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 35px;
	letter-spacing: normal;
	text-align: left;
	color: #414042;
	text-transform: uppercase;
	margin-bottom: 15px;
}
.block-a .block-text .sub-lead {
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 26px;
	letter-spacing: normal;
	text-align: left;
	color: #414042;
	margin-bottom: 30px;
}
/* block-b */
.block-b {
	margin-top: 40px;
}
.block-b .image-wrapper {
	position: relative;
}
.block-b .block-b-slider .slide {
	width: 648px;
	max-width: 100%;
	height: 648px;
	/* background-image: url('../images/temp_images/modc_habitacao.jpg'); */
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.block-b .image-label {
	position: absolute;
    bottom: 98px;
    right: -94px;
}
.block-b .block-lead {
	margin-bottom: 0;
	margin-top: 60px;
}
.block-b .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
/* block-c */
#block-c-wrapper .grey-bg-wrapper {
	background: linear-gradient(to right, rgba(147, 149, 152, 0.3) 0%, rgba(147, 149, 152, 0.3) 72%, #ffffff 72%, #ffffff 100%);
	padding-bottom: 60px;
}
.block-c {
	margin-top: 150px;
}
.block-c .block-c-slider .slick-list {
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
}
.block-c .block-lead {
	margin-bottom: 0;
	margin-top: 60px;
}
.block-c .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
.block-c .block-text {
	width: 444px;
}
.block-c .block-c-right {
	position: relative;
}
.block-c .block-c-img {
	width: 540px;
	max-width: 100%;
	height: 540px;
	background-image: url('../images/temp_images/modc_restauracao.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	z-index: 2;
	position: absolute;
	top: -200px;
}
.block-c .block-c-slider {
	position: absolute;
    width: 540px;
    height: 540px;
    top: -110px;
}
.block-c .block-c-slider .slide {
	width: 540px;
	max-width: 100%;
	height: 540px;
	background-image: url('../images/temp_images/modc_restauracao.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
/* block-d */
#block-d-wrapper {
	position: relative;
	margin-top: 175px;
}
#block-d-wrapper .bg-image-wrapper {
	width: 80%;
    height: 100%;
    background-image: url(../images/temp_images/b-hotelaria.jpg);
    background-size: cover;
    background-position: center center;
    margin-left: auto;
    position: absolute;
    z-index: 0;
    right: 0;
    top: 0;
}
#block-d-wrapper .left-white-card {
	width: 492px;
	max-width: 100%;
	background-color: #ffffff;
	margin-top: 40px;
	padding: 80px 32px 76px 32px;
	z-index: 2;
}
#block-d-wrapper .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
#block-d-wrapper .left-white-card .left-lead-text {
	padding-right: 50px;
}
#block-d-wrapper .green-grid {
    top: 0px;
    right: 145px;
}
#block-d-wrapper .block-d-slider-wrapper {
	width: 70%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
}
#block-d-wrapper .block-d-slider {
	height: 538px;
}
#block-d-wrapper .block-d-slider .slide {
	width: 100%;
	max-width: 100%;
	height: 538px;
	background-image: url(../images/temp_images/b-hotelaria.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
/* block-e */
#block-e-wrapper {
	margin-top: 190px;
	margin-bottom: 240px;
}
#block-e-wrapper .grey-bg-wrapper {
	background: linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 22%, rgba(147, 149, 152, 0.3) 22%, rgba(147, 149, 152, 0.3) 100%);
	padding-top: 60px;
    padding-bottom: 195px;
}
#block-e-wrapper .block-e {}
#block-e-wrapper .block-e-left {
	position: relative;
}
#block-e-wrapper .block-e-left .left-lead-text {
	width: 256px;
    position: absolute;
    bottom: 170px;
	right: 0;
	bottom: -160px;
	margin-right: 30px;
}
#block-e-wrapper .img-left {
	width: 324px;
	height: 324px;
	background-image: url('../images/temp_images/b_outros_left.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	z-index: 2;
    position: absolute;
	top: 240px;
	left: -50px;
}
#block-e-wrapper .block-e-left .img-top {
	width: 540px;
	max-width: 100%;
	height: 540px;
	background-image: url('../images/temp_images/b_outros_top.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	z-index: 2;
	position: absolute;
	top: -200px;
	right: 0;
	margin-right: 15px;
}
#block-e-wrapper .block-e-right {}
#block-e-wrapper .block-e-right .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
#block-e-wrapper .block-e-right .block-text {}
#block-e-wrapper .block-e-right .img-right {
	width: 324px;
	height: 324px;
	background-image: url('../images/temp_images/b_outros_right.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	z-index: 2;
	position: absolute;
	margin-top: 70px;
}
/* block-f */
#block-f-wrapper {
	position: relative;
	min-height: 700px;
}
.block-f-slider-wrapper {
	width: 75%;
	max-width: 1300px;
    position: absolute;
    top: 0;
    right: 0;
}
.block-f-slider-wrapper .block-f-slider {
	position: relative;
}
.block-f-slider-wrapper .block-f-slider .slide {
	width: 100%;
	max-width: 100%;
	height: 645px;
	background-image: url(../images/temp_images/b_portfolio.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
}
.block-f-slider-wrapper .custom-slide-arrows {
	position: absolute;
    display: flex;
    justify-content: space-between;
    align-items: center;
    top: 50%;
    width: 100%;
}
.block-f-slider-wrapper .custom-slide-arrows .slider-prev {
	/* background-image: url(../images/svg/big_arrow_left.svg);
    background-repeat: no-repeat; */
    width: 30px;
    height: 48px;
    background-color: transparent;
    cursor: pointer;
    background-size: contain;
    margin-left: 70px;
}
.block-f-slider-wrapper .custom-slide-arrows .slider-next {
	/* background-image: url(../images/svg/big_arrow_right.svg);
    background-repeat: no-repeat; */
    width: 30px;
    height: 48px;
    background-color: transparent;
    cursor: pointer;
    background-size: contain;
    margin-right: 70px;
}
.block-f-slider-wrapper .custom-slide-arrows .slider-prev svg path,
.block-f-slider-wrapper .custom-slide-arrows .slider-next svg path {
	fill: rgba(255,255,255,0.2);
} 
.block-f-slider-wrapper .custom-slide-arrows .slider-next:hover svg path,
.block-f-slider-wrapper .custom-slide-arrows .slider-next:hover svg path {
	fill: #80bc00;
}
#block-f-wrapper .left-white-card {
	width: 325px;
	max-width: 100%;
	background-color: #ffffff;
	margin-top: 40px;
	padding: 80px 32px 76px 32px;
	z-index: 2;
}
#block-f-wrapper .green-grid {
	bottom: 10px;
    right: 124px;
}
#block-f-wrapper .left-white-card .block-lead-small {
	margin-bottom: 40px;
}
#block-f-wrapper .left-white-card a.button {
	margin-top: 55px;
}
.block-f .slick-track {
	height: 645px;
}
.block-f .image-label {
	position: absolute;
    bottom: 98px;
    right: -63px;
}
/* portfolio */
.page-portfolio-wrapper {
	margin-top: 25px;
}
.page-portfolio-wrapper .portfolio-top {}
.page-portfolio-wrapper .portfolio-top .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
.page-portfolio-wrapper .portfolio-top .block-text {
	display: flex;
	flex-direction: column;
}
.page-portfolio-wrapper .portfolio-top .block-text .lead {
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 35px;
	letter-spacing: normal;
	text-align: left;
	color: #414042;
	text-transform: uppercase;
	margin-bottom: 15px;
}
.page-portfolio-wrapper .portfolio-top .block-text .sub-lead {
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 26px;
	letter-spacing: normal;
	text-align: left;
	color: #414042;
	margin-bottom: 30px;
}
.page-portfolio-wrapper .row-special {
	justify-content: flex-end;
	margin-top: 35px;
}
.page-portfolio-wrapper .inner-wrapper {
	width: 100%;
    margin-left: 168px;
}
.page-portfolio-wrapper .portfolio-items {
	display: flex;
    flex-direction: row;
	flex-wrap: wrap;
	margin-top: 70px;
}
.page-portfolio-wrapper .portfolio-items #ajax-load-more {
	width: 100%;
}
.page-portfolio-wrapper .portfolio-items #ajax-load-more .alm-reveal {
	display: flex;
    flex-wrap: wrap;
}
.page-portfolio-wrapper .portfolio-items .item {
	max-width: 294px;
	width: 100%;
	height: 500px;
	margin-bottom: 30px;
	margin-right: 30px;
	overflow: hidden;
	position: relative;
	cursor: pointer;
	transition: box-shadow 0.3s ease-in-out;
}
.page-portfolio-wrapper .portfolio-items .item:hover {
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
	transition: box-shadow 0.3s ease-in-out;
}
.page-portfolio-wrapper .portfolio-items .item-child-wrapper {
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	margin-right: 30px;
	margin-left: 0;
	position: relative;
	transition: all 0.3s ease-in-out;
}
.page-portfolio-wrapper .portfolio-items .item:hover .item-child-wrapper {
	/* background-size: 110%; */
	transform: scale(1.2);
	transition: all 0.3s ease-in-out;
}
.page-portfolio-wrapper .portfolio-items .item:nth-child(3n+3) {
	margin-right: 0px;
}
.page-portfolio-wrapper .portfolio-items .linear-gradient {
	width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(to top, rgba(0,0,0,0.3) 12%,transparent 100%);
    position: absolute;
    top: 0;
    left: 0;
}

.page-portfolio-wrapper .item a {
	width: 100%;
	height: 100%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}
.page-portfolio-wrapper .item .black-overlay {
	width: 100%;
	height: 100%;
	z-index: 99;
}
.page-portfolio-wrapper .item a:hover .black-overlay {
	background-color: rgba(0,0,0,0.0);
}
.page-portfolio-wrapper .item.item-01 {
	background-image: url('../images/temp_images/portfolio_tb1.jpg');
}
.page-portfolio-wrapper .item .info {
	position: absolute;
    bottom: 24px;
	left: 15px;
	max-width: 220px;
}
.page-portfolio-wrapper .item .info .category {
	font-size: 11px;
	line-height: 16px;
	letter-spacing: 2px;
	color: #80bc00;
	text-transform: uppercase;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
}
.page-portfolio-wrapper .item .info .title {
	color: #ffffff;
	/* font-size: 20px; */
	font-size: 18px;
	font-weight: 900;
	line-height: 26px;
	letter-spacing: 1.2px;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
	text-transform: uppercase;
} 
.page-portfolio-wrapper .item .image-label {
	position: absolute;
	bottom: 98px;
	right: -97px;
}
.page-portfolio-wrapper .portfolio-filters .first-line {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 25px;
}
.page-portfolio-wrapper .first-line > div {
    margin-bottom: 10px;
}
.page-portfolio-wrapper .portfolio-filters .first-line .first-line-label {
	font-weight: 900;
	font-size: 20px;
	line-height: 26px;
	letter-spacing: 1.2px;
	color: #ffffff;
	text-transform: uppercase;
	background-color: #000000;
	padding: 3px 10px;
	display: inline;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	/*margin-right: 45px;*/
}
.page-portfolio-wrapper .portfolio-filters .first-line > div {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	position: relative;
}
.page-portfolio-wrapper .portfolio-filters .first-line > div:not(:last-child) {
	margin-right: 50px;
}
.page-portfolio-wrapper .portfolio-filters .first-line .filters-all label {
	text-transform: uppercase;
	font-weight: 700;
	font-size: 14px;
	line-height: 20px;
}
.page-portfolio-wrapper .js-modconst + .select2-container {
	min-width: 200px;
}
.page-portfolio-wrapper .js-structures + .select2-container  {}
.page-portfolio-wrapper .js-reab + .select2-container  {
	min-width: 130px;
}
.category-name-and-button {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;

}
.portfolio-filters .submenu-arrow {
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 7px solid #80bc00;
	cursor: pointer;
}
.subcategories-submenu,
.category-name {
	-webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
    -khtml-user-select: none; /* Konqueror HTML */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* Internet Explorer/Edge */
	user-select: none; /* Non-prefixed version, currently supported by Chrome and Opera */
}
.subcategories-submenu {
	display: flex;
	flex-flow: column nowrap;
	position: absolute;
	top: 28px;
	left: 0;
	background-color: #FFF;
	padding: 10px;
	width: 100%;
	z-index: 1;
	box-shadow: 2px 2px 15px 2px;
	transition: transform 0s;
	transform-origin: top;
	transform: scaleY(0);
}
.subcategories-submenu.open {
	transform: scaleY(1);
	transition: transform 0.1s;
}
.subcategories-submenu input[type="checkbox"] {
	display: none;
}
.subcategories-submenu label {
	cursor: pointer;
	color: #414042;
	text-transform: uppercase;
	font-size: 13px;
	font-weight: 300;
	line-height: 2;
	transition: color 0.2s;
}
.subcategories-submenu label:hover {
	color: #80bc00;
}
.subcategories-submenu input[type="checkbox"]:checked + label {
	color: #80bc00;
}
.hidden-project-data {
	display: none;
}
.no-results {
	color: #80bc00;
	width: 100%;
	text-align: center;
	text-transform: uppercase;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.45;
	letter-spacing: 0.7px;
	opacity: 0;
}
.no-results.show {
	transition: opacity 0.3s;
	opacity: 1;
}
.processing {
	color: #80bc00;
	width: 100%;
	text-align: center;
	text-transform: uppercase;
	font-size: 11px;
	font-weight: bold;
	line-height: 1.45;
	letter-spacing: 0.7px;
	transition: opacity 0.3s;
	opacity: 0;
}
.processing.show {
	opacity: 1;
}
.processing #loader-1 {
	animation: infinite-rotation 0.6s linear infinite;
}
@keyframes infinite-rotation {
    to {transform: rotate(1turn);}
}
.check-button {
    position: relative;
	display: flex;
	align-items: stretch;
	cursor: pointer;
}
.filters-all .check-button {
    align-items: center;
}
.check-button + label {
	color: #999;
	text-transform: uppercase;
	margin-left: 5px;
}
.check-button.on + label {
	color: #80bc00;
}
.check-button .check-button-wrapper {
    width: 28px;
    height: 28px;
    border: 2px solid #414042;
    display: inline-block;
    vertical-align: middle;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
	position: relative;
	cursor: pointer;
}
.check-button .check-button-wrapper::before {
    display: block;
    position: absolute;
    content: '';
    height: 18px;
    width: 18px;
    top: 0px;
    bottom: 0px;
    left: -1px;
    right: 0px;
    margin: auto;
    background: transparent;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
	box-sizing: border-box;
	cursor: pointer;
}
.check-button label {
	display: inline-block;
	vertical-align: middle;
	font-size: 14px;
	color: #414042;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	margin: 0px;
	margin-left: 5px;
	cursor: pointer;
	text-transform: uppercase;
	font-weight: 700;
	white-space: nowrap;
	margin-right: 5px;
}
.check-button label.active,
.check-button label:hover {
    color: #80bc00 !important;
}
.check-button input[type="checkbox"] {
    position: absolute;
    width: 26px;
    display: block;
    height: 26px;
    margin: 0px;
    opacity: 0;
    z-index: 1;
    cursor: pointer;
}
.check-button input[type="checkbox"]:checked + .check-button-wrapper {
    border: 2px solid #414042;
}
.check-button input[type="checkbox"]:checked + .check-button-wrapper::before {
    display: block;
    position: absolute;
    content: url('../images/svg/close_small_green.svg');
    height: 18px;
    width: 18px;
    top: 0px;
    bottom: 0px;
    left: -1px;
    right: 0px;
    margin: auto;
    background: transparent;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
	box-sizing: border-box;
	cursor: pointer;
}
.check-button input[type="checkbox"]:checked ~ .category-name-and-button label {
    color: #414042;
}
.check-button input[type="checkbox"]:disabled + .check-button-wrapper {
    border: 2px solid #414042;
}
.check-button input[type="checkbox"]:disabled ~ .category-name-and-button label {
    color: #414042;
}
/* portfolio modal */
#portfolio-modal {
	position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.65);
    z-index: -1;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease-in-out;
    border: 40px solid #ffffff;
}
#portfolio-modal.show {
	opacity: 1;
	visibility: visible;
	transition: all 0.2s ease-in-out;
	z-index: 999999;
}
.portfolio-modal-slider-wrapper {
	max-width: 100%;
	position: relative;
}
.portfolio-modal-slider-wrapper .slide {
	width: 100%;
	height: calc(100vh - 80px);
	background-image: url('../images/temp_images/banner_homepage.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
}
.portfolio-modal-slider-arrows {
	position: absolute;
    display: flex;
    justify-content: space-between;
    align-items: center;
	top: 50%;
	width: 100%;
	transform: translateY(-50%);
}
.portfolio-modal-slider-arrows .slider-prev {
	/* background-image: url('../images/svg/big_arrow_left.svg');
	background-repeat: no-repeat; */
	width: 30px;
	height: 48px;
	background-color: transparent;
	cursor: pointer;
	background-size: contain;
	margin-left: 20px;
}
.portfolio-modal-slider-arrows .slider-next {
	/* background-image: url('../images/svg/big_arrow_right.svg');
	background-repeat: no-repeat; */
	width: 30px;
	height: 48px;
	background-color: transparent;
	cursor: pointer;
	background-size: contain;
	margin-right: 20px;
}
.portfolio-modal-slider-arrows .slider-prev svg path,
.portfolio-modal-slider-arrows .slider-next svg path {
	fill: rgba(255,255,255,0.2);
}
.portfolio-modal-slider-arrows .slider-prev:hover svg path,
.portfolio-modal-slider-arrows .slider-next:hover svg path {
	fill: #80bc00;
}
.close-btn-modal {
	position: absolute;
	z-index: 10;
	right: 18px;
	top: 12px;
	cursor: pointer;
}
.close-btn-modal:hover svg path:first-of-type {
	fill: #80bc00;
	stroke: #80bc00;
}
.info-btn-modal {
	position: absolute;
    z-index: 10;
    top: 60px;
	left: 23px;
	cursor: pointer;
}
.info-btn-modal svg path:first-of-type {
	fill: #000000;
	stroke: #000000;
}
.info-btn-modal:hover svg path:first-of-type,
.info-btn-modal.active svg path:first-of-type {
	fill: #80bc00;
	stroke: #80bc00;
}
.info-card-modal {
	position: absolute;
	z-index: 10;
	top: 60px;
	left: 103px;
	width: 100%;
	max-width: 246px;
	min-height: 556px;
	background-color: rgba(0,0,0,0.8);
	display: flex;
	flex-direction: column;
	align-items: center;
	color: #ffffff;
	padding: 48px 13px 48px 13px;
	opacity: 0;
    visibility: hidden;
	transition: all 0.4s ease-in-out;
	min-height: 400px;
    overflow-y: auto;
}
.info-card-modal.show {
	opacity: 1;
	visibility: visible;
	transition: all 0.4s ease-in-out;
}
.info-card-modal span {
	width: 100%;
}
.info-card-modal .modal-category {
	color: #80bc00;
	font-size: 11px;
	font-weight: 400;
	line-height: 16px;
	letter-spacing: 2px;
	text-align: center;
	text-transform: uppercase;
}
.info-card-modal .modal-title {
	font-size: 14px;
	font-weight: 400;
	line-height: 20px;
	letter-spacing: 2.5px;
	text-align: center;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
	margin-top: 30px;
	padding: 0 25px;
	text-transform: uppercase;
}
.info-card-modal .modal-year {
	color: #80bc00;
	font-size: 11px;
	font-weight: 400;
	line-height: 16px;
	letter-spacing: 2px;
	text-align: center;
	margin-top: 50px;
	text-transform: uppercase;
}
.info-card-modal .modal-local {
	font-size: 14px;
	font-weight: 900;
	line-height: 28px;
	letter-spacing: 0.9px;
	text-align: center;
	margin-top: 5px;
	text-transform: uppercase;
}
.info-card-modal .modal-country {
	font-size: 14px;
	font-weight: 300;
	line-height: 20px;
	letter-spacing: 2.5px;
	text-align: center;
	text-shadow: 0px 2px 20px rgba(0, 0, 0, 0.6);
	text-transform: uppercase;
}
.info-card-modal .modal-text {
	font-size: 15px;
	font-weight: 400;
	line-height: 22px;
	margin-top: 30px;
}
.info-card-modal .modal-share {
	margin-top: 50px;
	text-align: center;
}
.info-card-modal .modal-share .share-btn {
	cursor: pointer;
}
.info-card-modal .modal-share .share-btn svg path {
	fill: #ffffff;
}
.info-card-modal .modal-share .share-btn:hover svg path {
	fill: #80bc00;
}
.portfolio-modal-photo-info {
	position: absolute;
    bottom: 45px;
    left: 50%;
    transform: translateX(-50%);
}
.portfolio-modal-photo-info span {
	font-size: 14px;
	line-height: 28px;
	letter-spacing: 0.9px;
	color: #ffffff;
	font-weight: 900;
	text-transform: uppercase;
}
#portfolio-modal .image-label {
	position: absolute;
	bottom: 98px;
	right: -97px;
	color: #ffffff;
    text-transform: uppercase;
}
.portfolio-modal-slider.slick-slider .slick-dots {
	display: flex;
    flex-wrap: wrap;
    justify-content: center;
    position: absolute;
    bottom: 25px;
	left: 50%;
	transform: translateX(-50%);
}
/* page contacts */
.page-contacts-wrapper {
	margin-top: 20px;
}
.block-contact-info-card {
	width: 432px;
	max-width: 100%;
	height: 504px;
	background-image: url('../images/temp_images/01_contactos.jpg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
	padding: 80px 40px 80px 40px;
	box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.45);
}
.block-contact-info-card span,
.block-contact-info-card p {
	color: #ffffff;
	position: relative;
	font-size: 24px;
	line-height: 31px;
}
.block-contact-info-card span {
	font-weight: 700;
}
.block-contact-info-card p {
	font-weight: 400;
	margin-bottom: 30px;
	color: #ffffff;
}
.block-contact-info-card a {
	color: inherit;
}
.green-overlay {
	width: 100%;
	height: 100%;
	background-color: rgba(128,188,0,0.65);
	position: absolute;
	top: 0;
	left:0;
	mix-blend-mode: multiply;
}
.linear-overlay {
	width: 100%;
    height: 100%;
    display: block;
    background: linear-gradient(to top, rgba(0,0,0,0.6) 12%,transparent 100%);
    position: absolute;
    top: 0;
    left: 0;
}
.block-contact-info .block-lead {
	margin-bottom: 0;
}
.block-contact-info .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
.block-contact-info .block-text {
	display: flex;
	flex-direction: column;
}
.block-contact-info .block-text .lead {
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 35px;
	letter-spacing: normal;
	text-align: left;
	color: #414042;
	text-transform: uppercase;
	margin-bottom: 15px;
}
.block-contact-info .block-text .sub-lead {
	font-size: 24px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 26px;
	letter-spacing: normal;
	text-align: left;
	color: #414042;
	margin-bottom: 30px;
}
.block-contact-info-right {
	margin-top: 145px;
}
#mapContact {
	width: 100%;
	height: 645px;
	background-color: #80bc00;
}
.block-contact-map {
	position: relative;
	height: 745px;
	padding-top: 140px;
}
.block-contact-map-wrapper {
	width: 73%;
    position: absolute;
    top: 0;
    right: 40px;
}
.block-contact-map-info {
	position: relative;
	/* padding-top: 140px; */
	pointer-events: none;
}
.block-contact-map-info .left-white-card {
	width: 324px;
	max-width: 100%;
	background-color: #ffffff;
	margin-top: 40px;
	padding: 80px 32px 76px 32px;
	pointer-events: all;
}
.block-contact-map-info .left-white-card .button {
	margin-top: 60px;
}
/* textpage template */
.page-text-template-wrapper {
	margin-top: 20px;
}
.page-text-template-wrapper .block-lead {
	margin-bottom: 0;
}
.page-text-template-wrapper .block-lead::after {
	content: '';
	width: 2px;
	background-color: #80bc00;
	height: 50px;
	display: block;
	margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
.page-text-template-wrapper .block-text {
	margin-bottom: 68px;
}
.page-text-template-wrapper .block-text h2 {
	margin-bottom: 30px;
	color: #000000;
	text-transform: uppercase;
}
.page-text-template-wrapper .block-text h2:not(:first-of-type) {
	margin-top: 60px;
}
.page-text-template-wrapper .block-text p {
	margin-bottom: 5px;
	color: #000000;
}
.page-text-template-wrapper .block-text ul {
	margin-bottom: 20px;
}
.page-text-template-wrapper .block-text ul li {
	list-style-position: inside;
	font-family: 'Roboto', sans-serif;
	font-size: 15px;
	font-weight: 300;
	font-style: normal;
	font-stretch: normal;
	line-height: 22px;
	letter-spacing: normal;
}
/* treehouse full menu - no header.php*/
.treehouse-full-menu {
	width: 100%;
	height: 100vh;
	background-color: #ffffff;
	position: fixed;
	top: -100vh;
	left: 0;
	padding: 0px 40px 0px 40px;
	z-index: 1000;
	background-image: url('../images/logo-menu-open.png');
	background-repeat: no-repeat;
	background-position-x: center;
	background-position-y: calc(100vh - 240px);
	/* opacity: 0;
	visibility: hidden; */
	margin-top: 0;
	transition: top 0.5s ease-in-out;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}
.treehouse-full-menu.open {
	/* opacity: 1;
	visibility: visible; */
	top: 0vh;
	transition: top 0.5s ease-in-out;
}
.treehouse-full-menu .full-menu-close-btn {
	cursor: pointer;
	width: 140px;
	position: absolute;
    top: 5px;
	left: 0px;
	display: flex;
	align-items: center;
}
.treehouse-full-menu .full-menu-close-btn svg {
    opacity: 1;
	transition: opacity 0.3s ease-in-out;
}
.treehouse-full-menu .full-menu-close-btn svg:hover {
	opacity: 0.7;
	transition: opacity 0.3s ease-in-out;
}
.treehouse-full-menu .full-menu-close-btn span {
	margin-left: 7px;
	text-transform: uppercase;
	color: #80bc00;
	font-size: 11px;
	line-height: 16px;
	font-weight: 700;
	letter-spacing: 0.7px;
}
.treehouse-full-menu .inner-menu-top-bar {
	margin-top: 14px;
    position: absolute;
    width: calc(100% - 80px);
    min-height: 53px;
    z-index: 1;
}
.treehouse-full-menu .inner-menu-top-bar .lang-choice {
	display: flex;
    align-items: center;
    justify-content: center;
}
.treehouse-full-menu .inner-menu-top-bar .lang-choice li {
	margin: 0 5px;
}
.treehouse-full-menu .inner-menu-top-bar .lang-choice li a {
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background-color: transparent;
	color: #414042;
	display: flex;
    justify-content: center;
	align-items: center;
	font-size: 13px;
	cursor: pointer;
	text-decoration: none;
	padding: 0;
}
.treehouse-full-menu .inner-menu-top-bar .lang-choice li a:hover,
.treehouse-full-menu .inner-menu-top-bar .lang-choice li a:active,
.treehouse-full-menu .inner-menu-top-bar .lang-choice li a:focus,
.treehouse-full-menu .inner-menu-top-bar .lang-choice li.wpml-ls-current-language a {
	color: #ffffff;
	background-color: #80bc00;
	text-decoration: none;
}
.treehouse-full-menu .inner-menu-body {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	height: 100vh;
}
.treehouse-full-menu .inner-menu-body > div {
	width: 100%;
}
.treehouse-full-menu .inner-menu-body ul.menu {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	height: 100vh;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item {
	-ms-flex: 0 0 16.6666666667%;
    flex: 0 0 16.6666666667%;
	max-width: 16.6666666667%;
	/* -ms-flex: 0 0 14.2857142857%;
    flex: 0 0 14.2857142857%;
	max-width: 14.2857142857%; */
	flex-direction: column;
	border-right: 1px solid rgba(147,149,152,0.2);
	text-align: center;
	padding-top: 110px;
	padding-left: 15px;
	padding-right: 15px;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item:last-of-type {
	border-right: 0;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item a {
	text-transform: uppercase;
	font-size: 14px;
	line-height: 20px;
	color: #414042;
	font-weight: 700;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item a svg.icon {
    display: none;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item a:hover,
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item a:active,
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item a:focus {
	color: #80bc00;
	text-decoration: none;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	/* display: none; */
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu li.menu-item {
	max-width: 100%;
	padding: 0px 0px 0px 0px;
	border: none;
	cursor: pointer;
	flex: none;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu li.menu-item:first-of-type {
	padding: 30px 0px 0px 0px;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu li.menu-item a {
	font-weight: 400;
	font-size: 13px;
	line-height: 40px;
	color: #414042;
}
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu li.menu-item a:hover,
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu li.menu-item a:active,
.treehouse-full-menu .inner-menu-body ul.menu li.menu-item ul.sub-menu li.menu-item a:focus {
	color: #80bc00;
	text-decoration: none;
}
/* breadcrumbs */
.breadcrumbs_wrapper {
	text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 0.7px;
    margin-bottom: 60px;
	/* margin-top: -70px; */
	color: #80bc00;
	font-weight: 700;
}
.breadcrumbs_wrapper a {
	text-decoration: none;
	font-weight: 300;
}
#breadcrumbs {
	display: inline-block;
}
#breadcrumbs li {
	display: inline-block;
	list-style: none;
}
#breadcrumbs .separator {
	padding: 0 5px;
}
/* portfolio loader */
.loader{
	margin: 0 0 2em;
	/* height: 100px; */
	width: 20%;
	text-align: center;
	padding: 1em;
	margin: 0 auto 1em;
	display: inline-block;
	vertical-align: top;
  }

.loader svg path,
.loader svg rect{
  fill: #80bc00;
}

/* new sitemap */
.page-sitemap-template-wrapper .menu-item {
	list-style: none;
	margin-bottom: 20px;
	font-family: 'Roboto', sans-serif;
    font-size: 24px;
    font-weight: 700;
    font-style: normal;
    font-stretch: normal;
    line-height: 35px;
    letter-spacing: normal;
}
.page-sitemap-template-wrapper .menu-item a {
	text-transform: uppercase;
}
.page-sitemap-template-wrapper .menu-item a:hover {
	text-decoration: none;
	color: #80bc00;
}
.page-sitemap-template-wrapper .menu-item .sub-menu {
	margin-bottom: 10px;
    margin-top: 10px;
}
.page-sitemap-template-wrapper .menu-item .sub-menu li {
	list-style: none;
}
.page-sitemap-template-wrapper .menu-item .sub-menu li a {
	background-color: #ffffff;
	color: #414042;
	padding: 0;
	text-transform: capitalize;
	font-size: 18px;
    font-weight: 400;
}
.page-sitemap-template-wrapper .menu-item .sub-menu li a:hover {
	color: #80bc00;
}
.page-sitemap-template-wrapper .menu-item .sub-menu .menu-item {
	margin-bottom: 10px;
}
.page-sitemap-template-wrapper .block-lead::after {
    content: '';
    width: 2px;
    background-color: #80bc00;
    height: 50px;
    display: block;
    margin-top: 30px;
    margin-bottom: 20px;
    margin-left: 28px;
}
/* share modal */
.apss-social-share {
	display: flex;
	opacity: 0;
	visibility: hidden;
	padding-top: 5px;
	transition: all .3s ease-in-out;
}
.apss-social-share.share-active {
	opacity: 1;
	visibility: visible;
	transition: all .3s ease-in-out;
}
.apss-facebook .apss-icon-block,
.apss-email .apss-icon-block,
.apss-pinterest .apss-icon-block,
.apss-linkedin .apss-icon-block {
	background-color: transparent;
}
.apss-social-share a:hover, .apss-social-share a:focus {
	color: #80bc00;
}
.apss-theme-4 .apss-facebook a:hover .fa,
.apss-theme-4 .apss-email a:hover .fa,
.apss-theme-4 .apss-pinterest a:hover .fa,
.apss-theme-4 .apss-linkedin a:hover .fa {
	color: #80bc00;
}
.apss-theme-4 .apss-single-icon a:hover .apss-icon-block:after {
	display: none;
}
.apss-theme-4 .apss-single-icon a {
	min-height: auto;
}
.page-construcao-modular-wrapper #block-f-wrapper {
    margin-top: 350px;
}
.page-estruturas-wrapper #block-f-wrapper {
    margin-top: 170px;
}
.page-reabilitacao-wrapper #block-f-wrapper {
    margin-top: 170px;
}
/* modal-share v1 vs v2 */
.info-card-modal .modal-share {
	display: none;
}