/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

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,
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;
	box-sizing: border-box;
	-webkit-transition: all 0.5s ease-in-out;
	-moz-transition: all 0.5s ease-in-out; 
	-o-transition: all 0.5s ease-in-out; 
	-ms-transition: all 0.5s ease-in-out;
	transition: all 0.5s ease-in-out;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
p + p { 
	margin-top: 0.5em;
}
strong {
font-weight: bold;
}

/*================================*/
/*          Colours               */
/*                                */
/*    Green:     #8cc541          */
/*    Black:     #282525          */
/*                                */
/*================================*/

/*===== Main Styles =====*/
body {
background-color: #ffffff;
font-family: 'Montserrat', sans-serif;
margin: 0;
padding: 0;
line-height: 1;
}

/*===== Divs =====*/
#top-bar {
position: fixed;
top: 0;
width: 100%;
height: 40px;
padding: 0;
margin: 0;
z-index: 9999;
background-color: #282525;
border-top: 3px solid #8cc541;
box-shadow: 0px 5px 11px 0px rgba(50, 50, 50, 0.3);
}

#header {
position: relative;
width: 100%;
margin: 40px 0 0;
}

#logo {
display: block;
float: left;
width: 350px;
margin: 0;
padding: 0;
}

#header-contact {
float: right;
display: block;
padding: 30px 0 0;
margin: 0;
text-align: right;
}

#menu {
position: relative;
background: none repeat scroll 0 0 #282525;
width: 100%;
height: 50px;
text-align: center;
z-index: 999;
}

#building-banner {
position: relative;
background:url('../images/banner-01.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
z-index: 50;
}

#office-banner {
position: relative;
background:url('../images/banner-02.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
z-index: 50;
}

#truestone-banner {
position: relative;
background:url('../images/banner-03.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
z-index: 50;
}

#kitchen-banner {
position: relative;
background:url('../images/banner-04.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
z-index: 50;
}

#banner-short {
position: relative;
background:url('../images/banner-short.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-landscaping {
position: relative;
background:url('../images/banner-landscape.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-surfacing {
position: relative;
background:url('../images/banner-surfacing.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-driveway {
position: relative;
background:url('../images/banner-driveway.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-patio {
position: relative;
background:url('../images/banner-patio.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-footpath {
position: relative;
background:url('../images/banner-footpath.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-swimming {
position: relative;
background:url('../images/banner-swimming.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

#banner-ecoflex {
position: relative;
background:url('../images/banner-ecoflex.jpg') center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
margin: 0;
padding: 0;
width: 100%;
height: 250px;
z-index: 50;
}

.truestone-logo {
position: absolute;
bottom: 30px;
right: 30px;
background:url('../images/truestone-logo.png') center center no-repeat;
width: 650px;
height: 150px;
}

.main-content {
width: 100%;
margin: 0;
padding: 0;
overflow: hidden;
}

.main-content.contact {
overflow: unset;
z-index: 10;	
}

.main-content.black {
background:url('../images/logo-icon.png') top right no-repeat #282525;
border-top: 3px solid #8cc541;
}

.main-content.truestone {
background:url('../images/logott-icon-small.png') center right no-repeat #282525;
border-top: 3px solid #8cc541;
}

.overlay {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
height: 100%;
width: 100%;
opacity: 0;
transition: .5s ease;
background-color: #282525;
background: url('../images/logo-icon.png') top right no-repeat rgba(40, 37, 37, 0.8);
}

.overlaytt {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
height: 100%;
width: 100%;
opacity: 0;
transition: .5s ease;
background-color: #282525;
background: url('../images/logott-icon.png') top right no-repeat rgba(40, 37, 37, 0.8);
}

.text {
position: absolute;
top: 50%;
left: 50%;
width: 70%;
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
text-align: center;
}

.image {
position: absolute;
top: 50%;
left: 50%;
width: 100%;
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
text-align: center;
}

.scroll-up {
background: #8cc541;
clip-path: polygon(100% 0%, 100% 100%, 50% 85%, 0 100%, 0% 50%, 0 0);
-webkit-clip-path: polygon(100% 0%, 100% 100%, 50% 85%, 0 100%, 0% 50%, 0 0);
-moz-clip-path: polygon(100% 0%, 100% 100%, 50% 85%, 0 100%, 0% 50%, 0 0);
-o-clip-path: polygon(100% 0%, 100% 100%, 50% 85%, 0 100%, 0% 50%, 0 0);
color: #282525;
text-align: center;
padding: 20px 30px 30px 30px;
position: absolute;
top: 0;
right: 100px;
line-height: 1;
cursor: pointer;
transition: all .3s ease 0s;
-webkit-transition: all .3s ease 0s;
-moz-transition: all .3s ease 0s;
-o-transition: all .3s ease 0s;
}

.container {
margin: 0;
padding: 0;
overflow: hidden;
}

.project-header {
padding: 20px 0;
margin: 0;
height: 85px;
}

#email-response {
display: inline-block;
margin: 10px 0;
padding: 0;
}

#footer {
position: relative;
background: none repeat scroll 0 0 #282525;
border-top: 3px solid #8cc541;
width: 100%;
padding: 60px 0;
margin: 0;
}

#baseline {
background: none repeat scroll 0 0 transparent;
width: 100%;
padding: 20px 0;
margin: 0;
}

/*===== Containers =====*/
#top-bar-wrapper {
width: 100%;
max-width: 1250px;
padding: 0 10px;
margin: 0 auto;
overflow: hidden;
}

#header-wrapper {
position: relative;
width: 100%;
max-width: 1250px;
padding: 20px 10px;
margin: 0 auto;
overflow: hidden;
}

#menu-wrapper {
position: relative;
width: 100%;
max-width: 1250px;
padding: 0 10px;
margin: 0 auto;
}

.banner-wrapper {
position: relative;
width: 100%;
max-width: 1250px;
height: 550px;
padding: 20px 10px;
margin: 0 auto;
overflow: hidden;
}

.banner-content {
position: absolute;
left: 10px;
bottom: 25%;
}

.main-content-wrapper {
width: 100%;
max-width: 1250px;
padding: 80px 10px;
margin: 0 auto;
overflow: hidden;
}

.main-content-wrapper.contact {
overflow: unset;
z-index: 10;	
}

.main-content-short-wrapper {
width: 100%;
max-width: 1250px;
padding: 40px 10px;
margin: 0 auto;
overflow: hidden;
}

.main-content-wide-wrapper {
width: 100%;
padding: 0;
margin: 0 auto;
overflow: hidden;
}

.two-column-flex-wrapper {
display: flex;
flex-direction: row;
flex-wrap: nowrap;
justify-content: flex-start;
background-color: #ffffff;
width: 100%;
max-width: 2000px;
padding: 0;
margin: 0;
overflow: hidden;
}

.quote-button-wrapper {
line-height: 70px;
font-size: 1.2em;
}

.testimonial-wrapper {
margin: 0;
padding: 0;
min-height: 150px;
}

.columns-wrapper {
width: 100%;
padding: 20px 0;
margin: 0;
overflow: hidden;
}

.news-image-wrapper {
position: relative;
background-position: center center;
background-repeat: no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
border-radius: 10px 10px 0 0;
width: 100%;
height: 250px;
padding: 0;
margin: 0;
}

#footer-wrapper {
width: 100%;
max-width: 1250px;
padding: 0 10px;
margin: 0 auto;
overflow: hidden;
}

#baseline-wrapper {
width: 100%;
max-width: 1250px;
padding: 0 10px;
margin: 0 auto;
overflow: hidden;
}

/*===== Columns =====*/
.top-column-left {
display: block;
float: left;
width: 30%;
padding: 0;
margin: 0;
overflow: hidden;
}

.top-column-right {
display: block;
float: right;
width: 70%;
padding: 0;
margin: 0;
overflow: hidden;
text-align: right;
}

.left-column {
display: block;
float: left;
padding: 10px 0 0;
margin: 0;
overflow: hidden;
}

.right-column {
display: block;
float: right;
padding: 0;
margin: 0;
overflow: hidden;
}

.three-column {
display: block;
float: left;
width: 33.333%;
padding: 10px;
margin: 0;
}

.column-inner {
background: #f5f5f5;
border-radius: 15px;
padding: 20px;
margin: 0;
}

.three-column.surfacing {
position: relative;
background: url("../images/surfacing-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.surfacing:hover .overlay {
opacity: 1;
}

.three-column.landscape {
position: relative;
background: url("../images/gilman-bg-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.three-column.patio {
position: relative;
background: url("../images/patio-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.patio:hover .overlay {
opacity: 1;
}

.three-column.swimming {
position: relative;
background: url("../images/swimming-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.swimming:hover .overlay {
opacity: 1;
}

.three-column.ecoflex {
position: relative;
background: url("../images/eco-flex-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.ecoflex:hover .overlay {
opacity: 1;
}

.three-column.paths {
position: relative;
background: url("../images/paths-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.paths:hover .overlay {
opacity: 1;
}

.three-column.driveway {
position: relative;
background: url("../images/driveway-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 450px;
}

.driveway:hover .overlay {
opacity: 1;
}

.four-column {
display: block;
float: left;
width: 25%;
padding: 0;
margin: 0;
}

.six-column {
display: block;
float: left;
width: 16.666%;
padding: 0;
margin: 0;
}

.six-column.res1 {
position: relative;
background: url("../images/resin-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res1:hover .overlay {
opacity: 1;
}

.six-column.res2 {
position: relative;
background: url("../images/resin-02.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res2:hover .overlay {
opacity: 1;
}

.six-column.res3 {
position: relative;
background: url("../images/resin-03.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res3:hover .overlay {
opacity: 1;
}

.six-column.res4 {
position: relative;
background: url("../images/resin-04.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res4:hover .overlay {
opacity: 1;
}

.six-column.res5 {
position: relative;
background: url("../images/resin-05.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res5:hover .overlay {
opacity: 1;
}

.six-column.res6 {
position: relative;
background: url("../images/resin-06.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res6:hover .overlay {
opacity: 1;
}

.six-column.res7 {
position: relative;
background: url("../images/resin-07.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res7:hover .overlay {
opacity: 1;
}

.six-column.res8 {
position: relative;
background: url("../images/resin-08.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res8:hover .overlay {
opacity: 1;
}

.six-column.res9 {
position: relative;
background: url("../images/resin-09.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res9:hover .overlay {
opacity: 1;
}

.six-column.res10 {
position: relative;
background: url("../images/resin-10.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res10:hover .overlay {
opacity: 1;
}

.six-column.res11 {
position: relative;
background: url("../images/resin-11.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res11:hover .overlay {
opacity: 1;
}

.six-column.res12 {
position: relative;
background: url("../images/resin-12.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res12:hover .overlay {
opacity: 1;
}

.six-column.res13 {
position: relative;
background: url("../images/resin-13.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res13:hover .overlay {
opacity: 1;
}

.six-column.res14 {
position: relative;
background: url("../images/resin-14.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res14:hover .overlay {
opacity: 1;
}

.six-column.res15 {
position: relative;
background: url("../images/resin-15.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res15:hover .overlay {
opacity: 1;
}

.six-column.res16 {
position: relative;
background: url("../images/resin-16.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res16:hover .overlay {
opacity: 1;
}

.six-column.res17 {
position: relative;
background: url("../images/resin-17.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res17:hover .overlay {
opacity: 1;
}

.six-column.res18 {
position: relative;
background: url("../images/resin-18.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res18:hover .overlay {
opacity: 1;
}

.six-column.res19 {
position: relative;
background: url("../images/resin-19.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res19:hover .overlay {
opacity: 1;
}

.six-column.res20 {
position: relative;
background: url("../images/resin-20.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res20:hover .overlay {
opacity: 1;
}

.six-column.res21 {
position: relative;
background: url("../images/resin-21.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res21:hover .overlay {
opacity: 1;
}

.six-column.res22 {
position: relative;
background: url("../images/resin-22.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res22:hover .overlay {
opacity: 1;
}

.six-column.res23 {
position: relative;
background: url("../images/resin-23.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res23:hover .overlay {
opacity: 1;
}

.six-column.res24 {
position: relative;
background: url("../images/resin-24.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res24:hover .overlay {
opacity: 1;
}

.six-column.res25 {
position: relative;
background: url("../images/resin-25.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res25:hover .overlay {
opacity: 1;
}

.six-column.res26 {
position: relative;
background: url("../images/resin-26.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res26:hover .overlay {
opacity: 1;
}

.six-column.res27 {
position: relative;
background: url("../images/resin-27.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res27:hover .overlay {
opacity: 1;
}

.six-column.res28 {
position: relative;
background: url("../images/resin-28.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res28:hover .overlay {
opacity: 1;
}

.six-column.res29 {
position: relative;
background: url("../images/resin-29.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res29:hover .overlay {
opacity: 1;
}

.six-column.res30 {
position: relative;
background: url("../images/resin-30.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res30:hover .overlay {
opacity: 1;
}

.six-column.res31 {
position: relative;
background: url("../images/resin-31.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res31:hover .overlay {
opacity: 1;
}

.six-column.res32 {
position: relative;
background: url("../images/resin-32.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res32:hover .overlay {
opacity: 1;
}

.six-column.res33 {
position: relative;
background: url("../images/resin-33.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res33:hover .overlay {
opacity: 1;
}

.six-column.res34 {
position: relative;
background: url("../images/resin-34.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res34:hover .overlay {
opacity: 1;
}

.six-column.res35 {
position: relative;
background: url("../images/resin-35.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res35:hover .overlay {
opacity: 1;
}

.six-column.res36 {
position: relative;
background: url("../images/resin-36.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res36:hover .overlay {
opacity: 1;
}

.six-column.res37 {
position: relative;
background: url("../images/resin-37.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res37:hover .overlay {
opacity: 1;
}

.six-column.res38 {
position: relative;
background: url("../images/resin-38.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res38:hover .overlay {
opacity: 1;
}

.six-column.res39 {
position: relative;
background: url("../images/resin-39.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res39:hover .overlay {
opacity: 1;
}

.six-column.res40 {
position: relative;
background: url("../images/resin-40.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res40:hover .overlay {
opacity: 1;
}

.six-column.res41 {
position: relative;
background: url("../images/resin-41.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res41:hover .overlay {
opacity: 1;
}

.six-column.res42 {
position: relative;
background: url("../images/resin-42.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res42:hover .overlay {
opacity: 1;
}

.six-column.res43 {
position: relative;
background: url("../images/resin-43.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res43:hover .overlay {
opacity: 1;
}

.six-column.res44 {
position: relative;
background: url("../images/resin-44.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res44:hover .overlay {
opacity: 1;
}

.six-column.res45 {
position: relative;
background: url("../images/resin-45.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res45:hover .overlay {
opacity: 1;
}

.six-column.res46 {
position: relative;
background: url("../images/resin-46.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res46:hover .overlay {
opacity: 1;
}

.six-column.res47 {
position: relative;
background: url("../images/resin-47.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res47:hover .overlay {
opacity: 1;
}

.six-column.res48 {
position: relative;
background: url("../images/resin-48.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 200px;
}

.res48:hover .overlay {
opacity: 1;
}

.left-column-50 {
display: block;
float: left;
width: 50%;
padding: 0 25px 0 0;
margin: 0;
overflow: hidden;
}

.right-column-50 {
display: block;
float: left;
width: 50%;
padding: 0 0 0 25px;
margin: 0;
overflow: hidden;
}

.left-column-60 {
display: block;
float: left;
width: 60%;
padding: 0 25px 0 0;
margin: 0;
overflow: hidden;
}

.right-column-40 {
display: block;
float: left;
width: 40%;
padding: 0 0 0 25px;
margin: 0;
overflow: hidden;
}

.left-column-flex-50 {
order: 1;
flex-grow: 0;
flex-basis: auto;
width: 50%;
padding: 9% 60px 0;
margin: 0;
}

.left-column-flex-50.dark {
Background-color: #3e3f3a;
}

.left-column-flex-50.landscape {
position: relative;
background: url("../images/gilman-bg-01.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.landscape:hover .overlay {
opacity: 1;
}

.left-column-flex-50.hut {
position: relative;
background: url("../images/gilman-bg-03.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.hut:hover .overlay {
opacity: 1;
}

.left-column-flex-50.surfacing {
position: relative;
background: url("../images/gilman-bg-05.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.surfacing:hover .overlaytt {
opacity: 1;
}

.left-column-flex-50.office {
position: relative;
background: url("../images/gilman-bg-02.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.office:hover .overlay {
opacity: 1;
}

.right-column-flex-50 {
order: 1;
flex-grow: 0;
flex-basis: auto;
width: 50%;
padding: 60px 60px;
margin: 0;
}

.right-column-flex-50.dark {
Background-color: #3e3f3a;
}

.right-column-flex-50.landscape {
position: relative;
background: url("../images/landscaping.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.landscape:hover .overlay {
opacity: 1;
}

.right-column-flex-50.office {
position: relative;
background: url("../images/gilman-bg-02.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.office:hover .overlay {
opacity: 1;
}

.right-column-flex-50.house {
position: relative;
background: url("../images/gilman-bg-04.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.house:hover .overlay {
opacity: 1;
}

.right-column-flex-50.building {
position: relative;
background: url("../images/gilman-bg-06.jpg") center center no-repeat;
-webkit-background-size: cover;
-moz-background-size: cover;
-o-background-size: cover;
background-size: cover;
height: 600px;
}

.building:hover .overlay {
opacity: 1;
}

.footer-column-01 {
display: block;
float: left;
width: 33.3%;
margin: 0;
padding: 0 40px 0 0;
overflow: hidden;
}

.footer-column-02 {
display: block;
float: left;
width: 46.3%;
margin: 0;
padding: 0 40px 0 0;
overflow: hidden;
}

.footer-column-03 {
display: block;
float: right;
width: 20.3%;
margin: 0;
padding: 0;
overflow: hidden;
}

/*===== Borders =====*/
.bordtop {
border-top: 4px solid #ffffff;
}

.bordbottom {
border-bottom: 4px solid #ffffff;
}

.bordleft {
border-left: 2px solid #ffffff;
}

.bordright {
border-right: 2px solid #ffffff;
}

.bordmid {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.bordleftfour {
border-left: 2px solid #ffffff;
}

.bordrightfour {
border-right: 2px solid #ffffff;
}

.bordleftsix {
border-left: 2px solid #ffffff;
}

.bordrightsix {
border-right: 2px solid #ffffff;
}

/*===== Sections =====*/
section {
padding: 40px 0 0;
margin: 0;
overflow: hidden;
}

section.short {
padding: 20px 0 0;
margin: 0;
overflow: hidden;
}

section.large {
padding: 80px 0 0;
margin: 0;
overflow: hidden;
}

section.lower {
padding: 0 0 40px 0;
margin: 0;
overflow: hidden;
}

section.sub {
padding: 0 0 20px 0;
margin: 0;
overflow: hidden;
}

/*===== Menus =====*/
.menu_title {
display: none;
position: relative;
float: right;
bottom: 0.6em;
margin-right: 3em;
color: #ffffff;
font-size: 1.1em;
font-weight: 600; 
}

nav a {
position: relative;
color: #ffffff; 
display: block; 
font-size: 1em;
font-weight: 600;
text-transform: uppercase;
line-height: 50px;
padding: 0 35px; 
text-decoration: none; 
}

nav a.active {
color: #8cc541;
}

nav a.first {
padding: 0 35px 0 0; 
}

nav a.last {
padding: 0 0 0 35px;
}

nav a:hover {
color: #8cc541;
}

nav a.nocursor {
cursor: context-menu;
}

nav a.nocursor:hover {
color: #ffffff;
}

nav ul,
nav ul li { 
height: 50px;
list-style-type: none; 
padding: 0; 
margin: 0; 
}

nav > ul { 
text-align: left; 
}

nav > ul > li { 
display: inline-block; 
}

nav > ul > li:first-child { 
border-left: none; 
}

.sub-menu-parent { 
position: relative;
background: url("../images/down.gif") no-repeat scroll right 15px center;
padding: 0 15px 0 0; 
}

.sub-menu {
visibility: hidden; /* hides sub-menu */
opacity: 0;
position: absolute;
top: 100%;
left: 0;
width: 100%;
transform: translateY(-2em);
z-index: -1;
transition: all 0.3s ease-in-out 0s, visibility 0s linear 0.3s, z-index 0s linear 0.01s;
}

.sub-menu-parent:hover .sub-menu {
visibility: visible; /* shows sub-menu */
opacity: 1;
z-index: 1;
transform: translateY(0%);
transition-delay: 0s, 0s, 0.3s; /* this removes the transition delay so the menu will be visible while the other styles transition */
}

.sub-menu li {
background: #282525;
width: 350px;
height: 50px;
line-height: 50px;
border-bottom: 1px solid #ececec;
box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.2);
text-align: left;
}

.sub-menu li a {
color: #ffffff;
font-size: 0.9em;
line-height: 50px;	
}

.sub-menu li a:hover {
color: #8cc541;
}

.sub-menu li a.active {
color: #8cc541;
}

/*===== General =====*/
.center {
text-align: center;
}

.left {
text-align: left;
}

.right {
text-align: right;
}

.light {
font-weight: 300;
}

.normal {
font-weight: 400;
}

.semibold {
font-weight: 600;
}

.bold {
font-weight: 700;
}

.extrabold {
font-weight: 900;
}

.italic {
font-style: italic;
}

.uppercase {
text-transform: uppercase;
}

.darkshadow {
text-shadow: 2px 2px 2px #000000;
}

.hidden {
opacity: 0;
}

.hide {
display: block;
}

.noover {
overflow: visible;
}

.clear {
clear: both;
}

/*===== Spans =====*/
span.green {
color: #8cc541;
}

span.header-light {
text-transform: none;
}

/*===== Headers =====*/
header.main {
padding: 0 0 40px 0;
margin: 0;
overflow: hidden;
}

header.sub {
padding: 0 0 20px 0;
margin: 0;
overflow: hidden;
}

header.mid {
padding: 20px 0;
margin: 0;
overflow: hidden;
}

h1 {
color: #282525;
font-size: 3em;
margin: 0;
padding: 0;
display: block;
line-height: 1.3em;
}

h1.white {
color: #ffffff;
}

h2 {
color: #282525;
font-size: 2.5em;
margin: 0;
padding: 0;
display: block;
line-height: 1.3em;
}

h2.white {
color: #ffffff;
}

h3 {
color: #282525;
font-size: 1.5em;
margin: 0;
padding: 0;
display: block;
line-height: 1.2em;
}

h3.white {
color: #ffffff;
}

h3.green {
color: #8cc541;
}

h4 {
color: #282525;
font-size: 1.2em;
margin: 0;
padding: 0;
display: block;
line-height: 1.3em;
}

h4.white {
color: #ffffff;
}

/*===== Paragraphs =====*/
p.main-text {       
color: #454545; 
font-size: 1em; 
padding: 0;
line-height: 1.7em;
}

p.main-text.white {       
color: #eeeeee; 
}

p.main-text.small {       
font-size: 0.875em; 
}

p.main-text.large {       
font-size: 1.2em; 
}

p.top-bar-text {       
color: #fafafa; 
font-size: 0.8em; 
padding: 0;
line-height: 40px;
}

p.header-text {      
color: #2e3838; 
font-size: 2.2em;
padding: 0;
margin: 0;
line-height: 1em;
}

p.header-text.small {
font-size: 0.875em;
line-height: 2em;
margin: 0;
}

p.banner-text {      
color: #ffffff; 
font-size: 3em;
padding: 0;
margin: 0;
line-height: 1.3em;
}

p.banner-text.small { 
font-size: 1.4em;
}

p.large-text {       
color: #ffffff; 
font-size: 2.5em;
padding: 0;
line-height: 1.3em;
}

p.error-text {       
color: #282525; 
font-size: 12em; 
font-weight: 700;
padding: 0;
line-height: 1em;
}

/*===== Form Fields =====*/
form#emailForm {
padding: 0;
margin: 0;
}

form.cmxform {
width: 100%;
color: #454545; 
font-family: 'Montserrat', sans-serif;
font-size: 1em;
padding: 10px 0 0;
}

form.cmxform legend {
padding-left: 0;
}

form.cmxform legend, form.cmxform label {
color: #454545;
}

form.cmxform fieldset {
border: none;
background: none repeat scroll 0 0 transparent;
background-color: #transparent;
margin: 0;
padding: 10px 0 0;
}

form.cmxform fieldset fieldset {
background: none;
}

form.cmxform fieldset p, form.cmxform fieldset fieldset {
padding: 0 0 20px;
background: none repeat scroll 0 0 transparent;
}

form.cmxform label.error, label.error {
color: #ffffff;
font-style: italic;
display: block !important;
margin: 0 0 10px 0;
}

div.error { 
display: none; 
}

form.cmxform .gray * { 
color: gray; 
}

#emailForm {
width: 100%;
}

#emailForm label.error {
width: auto;
display: none;
font-size: 0.85em;
margin: 0 0 20px 0;
}

.editor-label-buttons {
background: none repeat scroll 0 0 transparent;
border: 0 none;
display: inline-block;
float: right;
margin: 0 10px 0 0;
outline: 0 none;
padding: 0;
vertical-align: baseline;
}

.editor-field {
background: none repeat scroll 0 0 transparent;
border: 0 none;
display: inline-block;
width: 33%;
margin: 0;
outline: 0 none;
padding: 0;
vertical-align: baseline;
}

.editor-field-full {
background: none repeat scroll 0 0 transparent;
border: 0 none;
display: inline-block;
width: 100%;
margin: 0;
outline: 0 none;
padding: 0;
vertical-align: baseline;
}

.editor-field-short {
background: none repeat scroll 0 0 transparent;
border: 0 none;
display: inline-block;
width: 100px;
margin: 0;
outline: 0 none;
padding: 0;
vertical-align: top;
}

input.contact {
border: 1px solid #ffffff;
border-radius: 5px;
color: #454545;
font-family: 'Montserrat', sans-serif;
font-size: 1em;
font-weight: 300;
height: 35px;
line-height: 18px;
margin: 0 auto 15px;
padding: 5px;
width: 95%;
-webkit-transition: all 0.5s ease-in-out;
-moz-transition: all 0.5s ease-in-out; 
-o-transition: all 0.5s ease-in-out; 
-ms-transition: all 0.5s ease-in-out;
}

input.contact.question {
width: 75px;
text-align: center;
}

input.contact:focus {
border: 1px solid #3d2763;
}

input.contact.error {
border: 1px solid #ffffff;
}

textarea.contact {
border: 1px solid #ffffff;
border-radius: 5px;
color: #454545;
font-family: 'Montserrat', sans-serif;
font-size: 1em;
font-weight: 300;
height: 200px;
line-height: 18px;
margin: 0 auto 25px;
padding: 10px 5px;
width: 98%;
-webkit-transition: all 0.5s ease-in-out;
-moz-transition: all 0.5s ease-in-out; 
-o-transition: all 0.5s ease-in-out; 
-ms-transition: all 0.5s ease-in-out;
}

textarea.contact:focus {
border: 1px solid #3d2763;
}

textarea.contact.error {
border: 1px solid #ffffff;
}

span.requiredfield {
color: #3d2763;
}

input.submit {
background: #8cc541;
border: 2px solid #fff;
border-radius: 7px;
display: inline-block;
color: #282525;
cursor: pointer;
font-family: 'Montserrat', sans-serif;
font-size: 1em;
padding: 15px 25px;
margin: 0 10px 0 0;
text-align: center;
text-decoration: none;
text-transform: uppercase;
-webkit-transition: all 0.3s ease-in-out;
-moz-transition: all 0.3s ease-in-out; 
-o-transition: all 0.3s ease-in-out; 
-ms-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
}

input.submit:hover {
color: #ffffff;
background: #282525;
}

/*===== Buttons =====*/
a.button {
background: #282525;
border: 2px solid #fff;
border-radius: 7px;
display: inline-block;
color: #ffffff;
cursor: pointer;
font-family: 'Montserrat', sans-serif;
font-size: 1em;
font-weight: 600;
padding: 15px 25px;
margin: 0 10px 0 0;
text-align: center;
text-decoration: none;
text-transform: uppercase;
-webkit-transition: all 0.3s ease-in-out;
-moz-transition: all 0.3s ease-in-out; 
-o-transition: all 0.3s ease-in-out; 
-ms-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
}

a.button.green {
color: #282525;
background: #8cc541;
}

a.button:hover {
color: #282525;
background: #8cc541;
}

a.button.green:hover {
color: #ffffff;
background: #282525;
}

a.button.large {
font-size: 1.2em;
font-weight: 600;	
padding: 15px 40px;
margin: 0;
}

a.clear-button {
background: url("../images/right-arrow.png") no-repeat scroll right 10px center;
border: 0 none;
display: inline-block;
color: #ffffff;
cursor: pointer;
font-family: 'Montserrat', sans-serif;
font-size: 1em;
font-weight: 600;
padding: 0 45px 0 0;
margin: 0;
text-align: center;
text-decoration: none;
text-transform: uppercase;
-webkit-transition: all 0.2s ease-in-out;
-moz-transition: all 0.2s ease-in-out; 
-o-transition: all 0.2s ease-in-out; 
-ms-transition: all 0.2s ease-in-out;
transition: all 0.2s ease-in-out;
}

a.clear-button:hover {
background: url("../images/right-arrow.png") no-repeat scroll right center;
}

a.clear-button.black {
background: url("../images/right-arrow-black.png") no-repeat scroll right 10px center;
color: #282525;
}

a.clear-button.black:hover {
background: url("../images/right-arrow-black.png") no-repeat scroll right center;
}

/*===== Links =====*/
a.link:link, a.link:visited, a.link:active {
color: inherit;
font-size: inherit; 
text-decoration: none;
margin: 0;
-webkit-transition: all 0.5s ease-in-out;
-moz-transition: all 0.5s ease-in-out; 
-o-transition: all 0.5s ease-in-out; 
-ms-transition: all 0.5s ease-in-out;
transition: all 0.5s ease-in-out;
}

a.link.under:link, a.link.under:visited, a.link.under:active {
color: inherit;
font-size: inherit; 
text-decoration: underline;
margin: 0;
-webkit-transition: all 0.5s ease-in-out;
-moz-transition: all 0.5s ease-in-out; 
-o-transition: all 0.5s ease-in-out; 
-ms-transition: all 0.5s ease-in-out;
transition: all 0.5s ease-in-out;
}

a.link:hover {
color: #8cc541;
text-decoration: underline;
}

a.link.under:hover {
color: #8cc541;
}

a.blank:link, a.blank:visited, a.blank:active {
color: inherit;
text-decoration: none;
}

a.gallery:link, a.gallery:visited, a.gallery:active {
text-decoration: none;
}

/*===== Telephone Numbers =====*/
.tel,.tel:visited { /*for small screens */ 
color: inherit; 
padding: 0; 
text-decoration: none; 
cursor: default;
} 

.tel:hover,.tel:focus { 
color: inherit; 
}

/*===== Lists =====*/
/*===== Standard Bullets =====*/
ul.bullets {
list-style-type: disc;
list-style-position: inside;
margin: 10px 0 20px 0;
padding: 0;
}

ul.bullets li {
color: #8cc541; 
padding: 0;
margin-bottom: 5px;
margin-left: 2.0em;
text-indent: -1em;
}

span.bullets {
color: #454545; 
font-size: 1em; 
line-height: 1.7em;
}

/* Top Bar List */
ul.top-bar {
list-style-type: none;
display: inline-table;
padding: 0;
margin: 0;
}

ul.top-bar li {
float: left;
color: #fafafa; 
font-size: 0.8em; 
line-height: 40px;
margin: 0 10px 0 0;
}

ul.top-bar li.last {
background-color: #8cc541;
border-radius: 0 0px 5px 5px;
height: 48px;
line-height: 45px;
margin: 0;
padding: 0 30px;
color: #282525;
font-size: 1.1em;
font-weight: 600;
text-transform: uppercase;
}

/* dash List */
ul.dash {
list-style-type: none;
padding: 0;
margin: 0;
}

ul.dash li {
color: #eeeeee; 
font-size: 0.875em;
font-weight: 400;
line-height: 1.7em;
padding: 0;
margin-bottom: 10px;
margin-left: 2.0em;
}

ul.dash li:before {
content: '\2014';
position: absolute;
margin-left: -20px;
color: #8cc541;
}

ul.dash li a {
margin: 0 0 0 10px !important;	
}
	
/*===== Images =====*/
img {
border: 0;
height: auto;
max-width: 100%;
}

img.top {
border: 0;
height: auto;
max-width: 100%;
position: relative;
margin-right: 5px;
top: 3px;
}

img.border {
border: 1px solid #282525;
padding: 5px;
min-height: 280px;
}

img.rounded {
border-radius: 15px;
}

/*********************************************************************/
/*===== Media Queries for Mobile =====*/
@media screen and (max-width: 480.99px) 
			  and (min-width: 320px) {

#logo {
width: 250px;
float: none;
margin: 0 auto;
}

#header-contact {
float: none;
padding: 20px 0 0;
text-align: center;	
}
	  
.banner-wrapper {
height: 350px;
}

.banner-content {
bottom: 10%;
}

.menu_title {
display: block !important;
}

.sub-menu-parent { 
background: none;
padding: 0; 
}

.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}

.text {
width: 90%;
}

.main-content-wrapper {
padding: 60px 10px
}

.left-column {
width: 100%;
padding: 0;
text-align: center;
}

.right-column {
width: 100%;
padding: 40px 0 0;
text-align: center;
}

.left-column-50 {
width: 100%;
padding: 0;	
}

.right-column-50 {
width: 100%;
padding: 40px 0 0;	
}

.three-column {
width: 100%;
}

.four-column {
width: 100%;
}

.six-column {
width: 50%;
}

.bordleftfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.bordrightfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.left-column-60 {
width: 100%;
padding: 0;
}

.right-column-40 {
width: 100%;
padding: 40px 0 0 0;
}

.footer-column-01 {
width: 100%;
padding: 0;
text-align: center;	
}

.footer-column-02 {
width: 100%;
padding: 60px 0 0;
text-align: center;	
}

.footer-column-03 {
width: 100%;
padding: 60px 0 0;
text-align: center;	
}

.two-column-flex-wrapper {
flex-flow: column nowrap;
}

.left-column-flex-50.landscape {
width: 100%;
height: 400px;
order: 1;
}

.left-column-flex-50.hut {
width: 100%;
height: 400px;
order: 1;
}

.left-column-flex-50.surfacing {
width: 100%;
height: 400px;
order: 1;
}

.right-column-flex-50.office {
width: 100%;
height: 400px;
order: 2;
}

.right-column-flex-50.house {
width: 100%;
height: 400px;
order: 2;
}

.right-column-flex-50.building {
width: 100%;
height: 400px;
order: 2;
}

.right-column-flex-50.landscape {
width: 100%;
height: 400px;
order: 2;
}

.bordright {
border-right: none;
border-bottom: 4px solid #ffffff;
}

.bordleft {
border-left: none;
}

.editor-field {
width: 100%;
}

.editor-field-full {
width: 97%;
}

.editor-label-buttons {
float: none;
margin: 0 auto 0 0;
text-align: center;
}

h1 {
font-size: 1.8em;
}

h2 {
font-size: 1.6em;
}

h3 {
font-size: 1.3em;
}

p.header-text {
font-size: 1.6em;
}

p.header-text.small {
font-size: 0.75em;
}

p.banner-text {
font-size: 1.6em;
}

p.banner-text.small {
font-size: 1.1em;
}

p.large-text {
font-size: 1.8em;
}

a.button.large {
font-size: 1em;
padding: 0 30px;
}

a.button.green {
margin: 0 0 10px 0;
}

ul.top-bar li.last {
height: 45px;
font-size: 1em;
padding: 0 20px;
}	

}


/*********************************************************************/
/*===== Mobile Landscape =====*/
@media screen and (max-width: 600.99px) 
			  and (min-width: 481px) {
			  
#logo {
width: 250px;
float: none;
margin: 0 auto;
}

#header-contact {
float: none;
padding: 20px 0 0;
text-align: center;	
}
	  
.banner-wrapper {
height: 400px;
}

.menu_title {
display: block !important;
}

.sub-menu-parent { 
background: none;
padding: 0; 
}

.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}

.text {
width: 80%;
}

.main-content-wrapper {
padding: 60px 10px
}

.left-column {
width: 100%;
padding: 0;
text-align: center;
}

.right-column {
width: 100%;
padding: 40px 0 0;
text-align: center;
}

.left-column-50 {
width: 100%;
padding: 0;	
}

.right-column-50 {
width: 100%;
padding: 40px 0 0;	
}

.three-column {
width: 100%;
}

.four-column {
width: 50%;
}

.six-column {
width: 50%;
}

.bordleftfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.bordrightfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.left-column-60 {
width: 100%;
padding: 0;
}

.right-column-40 {
width: 100%;
padding: 40px 0 0 0;
}

.footer-column-01 {
width: 45%;	
}

.footer-column-02 {
width: 55%;
padding: 0;	
}

.footer-column-03 {
width: 100%;
padding: 60px 0 0;
text-align: center;	
}

.two-column-flex-wrapper {
flex-flow: column nowrap;
}

.left-column-flex-50.landscape {
width: 100%;
height: 400px;
order: 1;
}

.left-column-flex-50.hut {
width: 100%;
height: 400px;
order: 1;
}

.left-column-flex-50.surfacing {
width: 100%;
height: 400px;
order: 1;
}

.right-column-flex-50.office {
width: 100%;
height: 400px;
order: 2;
}

.right-column-flex-50.house {
width: 100%;
height: 400px;
order: 2;
}

.right-column-flex-50.building {
width: 100%;
height: 400px;
order: 2;
}

.right-column-flex-50.landscape {
width: 100%;
height: 400px;
order: 2;
}

.bordright {
border-right: none;
border-bottom: 4px solid #ffffff;
}

.bordleft {
border-left: none;
}

.editor-field {
width: 100%;
}

.editor-field-full {
width: 97%;
}

.editor-label-buttons {
float: none;
margin: 0 auto 0 0;
text-align: center;
}

h1 {
font-size: 2em;
}

h2 {
font-size: 1.8em;
}

h3 {
font-size: 1.3em;
}

p.header-text {
font-size: 2em;
}

p.header-text.small {
font-size: 0.75em;
}

p.banner-text {
font-size: 2em;
}

p.banner-text.small {
font-size: 1.3em;
}

p.large-text {
font-size: 2em;
}

a.button.large {
font-size: 1em;
padding: 0 30px;
}			  
			  
}


/*********************************************************************/
/*===== Mobile Landscape =====*/
@media screen and (max-width: 768.99px) 
			  and (min-width: 601px) {

#logo {
width: 250px;
}

#header-contact {
padding: 10px 0 0;
}
	  
.banner-wrapper {
height: 400px;
}

.menu_title {
display: block !important;
}

.sub-menu-parent { 
background: none;
padding: 0; 
}

.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}

.text {
width: 80%;
}

.main-content-wrapper {
padding: 60px 10px
}

.left-column {
width: 100%;
padding: 0;
text-align: center;
}

.right-column {
width: 100%;
padding: 40px 0 0;
text-align: center;
}

.three-column {
width: 100%;
}

.four-column {
width: 50%;
}

.six-column {
width: 33.333%;
}

.bordleftfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.bordrightfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.left-column-60 {
width: 100%;
padding: 0;
}

.right-column-40 {
width: 100%;
padding: 40px 0 0 0;
}

.footer-column-01 {
width: 40%;	
}

.footer-column-02 {
width: 60%;
padding: 0;	
}

.footer-column-03 {
width: 100%;
padding: 60px 0 0;
text-align: center;	
}

.two-column-flex-wrapper {
flex-flow: column nowrap;
}

.left-column-flex-50.landscape {
width: 100%;
height: 500px;
order: 1;
}

.left-column-flex-50.hut {
width: 100%;
height: 500px;
order: 1;
}

.left-column-flex-50.surfacing {
width: 100%;
height: 500px;
order: 1;
}

.right-column-flex-50.office {
width: 100%;
height: 500px;
order: 2;
}

.right-column-flex-50.house {
width: 100%;
height: 500px;
order: 2;
}

.right-column-flex-50.building {
width: 100%;
height: 500px;
order: 2;
}

.right-column-flex-50.landscape {
width: 100%;
height: 500px;
order: 2;
}

.bordright {
border-right: none;
border-bottom: 4px solid #ffffff;
}

.bordleft {
border-left: none;
}

.editor-field {
width: 32%;
}

textarea.contact {
width: 95.5%;
}

h1 {
font-size: 2.5em;
}

h3 {
font-size: 1.3em;
}

p.header-text {
font-size: 2em;
}

p.header-text.small {
font-size: 0.75em;
}

p.banner-text {
font-size: 2.3em;
}

a.button.large {
font-size: 1em;
padding: 0 40px;
}			  
			  
}


/*********************************************************************/
/*===== Small Tablet Portrait ======*/
@media screen and (max-width: 872.99px) 
			  and (min-width: 769px) {

.banner-wrapper {
height: 400px;
}

.menu_title {
display: block !important;
}

.sub-menu-parent { 
background: none;
padding: 0; 
}

.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}

.text {
width: 80%;
}

.main-content-wrapper {
padding: 60px 10px
}

.left-column {
width: 100%;
padding: 0;
text-align: center;
}

.right-column {
width: 100%;
padding: 40px 0 0;
text-align: center;
}

.four-column {
width: 50%;
}

.six-column {
width: 33.333%;
}

.bordleftfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.bordrightfour {
border-left: 2px solid #ffffff;
border-right: 2px solid #ffffff;
}

.editor-field {
width: 32%;
}

textarea.contact {
width: 95.5%;
}

p.banner-text {
font-size: 2.5em;
}

a.button.large {
font-size: 1em;
padding: 0 40px;
}		  

}


/*********************************************************************/
/*===== Tablet Portrait =====*/
@media screen and (max-width: 1090.99px) 
			  and (min-width: 873px) {
			  
.banner-wrapper {
height: 450px;
}

.menu_title {
display: block !important;
}

.sub-menu-parent { 
background: none;
padding: 0; 
}

.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}

.editor-field {
width: 32%;
}

textarea.contact {
width: 95.5%;
}
		  
}


/*********************************************************************/
/*===== Tablet Portrait =====*/
@media screen and (max-width: 1152.99px) 
			  and (min-width: 1091px) {
				  
.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}

nav a.first {
padding: 0 20px 0 0;
}

nav a {
padding: 0 20px;
}

nav a.last {
padding: 0 0 0 20px;
}			  
			  
}


/*********************************************************************/
/*===== Tablet Portrait =====*/
@media screen and (max-width: 1650px) 
			  and (min-width: 1152px) {

.scroll-up {
right: 20px;
padding: 12px 20px 18px 20px;
}	
			  
}