/*=============================================
	DEFAULTS
=============================================*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, img, ins, kbd, q, s, samp, small, strike, sup, sub, tt, var, 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;
}

body {
	font-family: plantin, Georgia, Serif !important;
	font-style: normal;
	font-weight: 300;
	font-size: 22px;
	text-transform: none;
	text-decoration: none;
	letter-spacing: 0em;
	word-spacing: 0em;
	line-height: 1.5;
	color: #393e41;
	background: #fff;
}

img { max-width: 100%; }

td { vertical-align: top; }

td:first-child {
	padding-right: 20px;
	padding-bottom: 10px;
}

ul, ol { margin: 20px 0 20px 40px; }

ul li { list-style-type: circle; }

label, legend {
	font-size: .7em;
	font-family: TTNormsStdCond-Regular, sans-serif;
	font-weight: 400;
	font-style: normal;	
}

legend {
	padding: 1em 1em .5em 0;
}

form {
	margin-top: 40px;
}

form input, form textarea {
	border: 1px solid #b1bcc3; 
	outline: 0;
	padding: 1em;
	display: block;
	width: 100%;
	margin-top: 1em;
	font-family: TTNormsStdCond-Regular, sans-serif;
	font-size: .7em;
	resize: none;
}

form textarea {
	color: #777;
}

input[type="checkbox"] {
    display: inline;
	width: auto;
	padding-left: 1em;
	margin-top: 0;
}

  form input:focus, form textarea:focus, input:checked  {
	box-shadow: 0 0 20px 0 rgba(0,0,0,.05);
  }

  form button {
	padding: 15px 20px; 
	border: 1px solid #b1bcc3; 
	color: #393e41;
	cursor: pointer;
	margin-top: 1em;
  }

  form textarea {
	height: 126px;
  }

/*=============================================
	TEXT STYLES
=============================================*/

a {
	color: #f26c4f;
	position: relative;
  	overflow: hidden;
 	text-decoration: none;
}

h3 a::after, .content a::after, .content-breathe a::after, .introduction a::after {
	content: "";
	background: rgba(242, 108, 79, 0.25);
	position: absolute;
	left: 12px;
	bottom: -4px;
	width: calc(100% - 8px);
	height: calc(100% - 8px);
	z-index: -1;
	-webkit-transition: 0.35s cubic-bezier(0.25, 0.1, 0, 2.05);
	transition: 0.35s cubic-bezier(0.25, 0.1, 0, 2.05);
}

a:hover:after {
	left: 0;
	bottom: -2px;
	width: 100%;
	height: 100%;
  }

.center { text-align: center; }

h1 { 
	font-family: ClearfaceStd-Regular, sans-serif;
	font-weight: 700;
	font-size: 4em; 
	line-height: 2; 
}

h2 { 
	font-family: ClearfaceStd-Regular, sans-serif;
	font-weight: 700;
	font-size: 2.5em; 
	line-height: 1.2; 
}

h3 { 
	font-family: ClearfaceStd-Regular, sans-serif;
	font-weight: 700;
	font-size: 1.3em; 
	line-height: 1.2; 
}

h4 { 
	font-family: TTNormsStdCond-Regular, sans-serif;
	font-weight: 600;
	font-style: normal;
	letter-spacing: 2px;
	font-size: 1em; 
	text-transform: uppercase;
	line-height: 1; 
	margin: 40px 0 20px 0;  
}

sup {
	font-size: .5em;
}

.bold {
	font-family: plantin, Georgia, Serif !important;
	font-style: normal;
	font-weight: 700; 
}

.caption {
	font-size: .7em;
	font-family: TTNormsStdCond-Regular, sans-serif;
	font-weight: 400;
	font-style: normal;	
}

.larger { 
	font-size: 1.3em; 
	line-height: 1.4;
}

.small-ish {
	font-size: .7em;
	font-family: TTNormsStdCond-Regular, sans-serif;
	font-weight: 400;
	font-style: normal;
	text-transform: uppercase;
	letter-spacing: 4px;
}

.footer p em {
	font-family: plantin, serif;
	font-style: italic;
	font-weight: 300;
}

.button {
	display: inline;
}

.button a {
	padding: 15px 20px; 
	border: 1px solid #b1bcc3; 
	color: #393e41;
	cursor: pointer;
}

.button a:hover {
	box-shadow: 0 0 20px 0 rgba(0,0,0,.05);
	color: #f26c4f;
}

.outline {
	box-shadow: 0 0 20px 0 rgba(0,0,0,.05);
}

/*=============================================
	SITE STRUCTURE
=============================================*/

.content {
	width: 50%;
	clear: both;
	margin: 0 auto;
	padding: 30px 0;
}

.content-full {
	width: 100%;
	clear: both;
	margin: 0 auto;
	position:relative;
	overflow:visible;
}

.content-wide {
	width: 80%;
	clear: both;
	margin: 0 auto;
}

.content-breathe {
	width: 80%;
	clear: both;
	margin: 0 auto;
	padding: 40px 0;
}

.footer {
	width: 100%;
	margin: 0 auto;
	background: #005038; /* #5c665e; #3b562e; */
	color: #fff;
	font-size: 18px;
	font-family: TTNormsStdCond-Regular;
	margin-top: 20px;
	padding: 0;
}

.footer a {
	color: #a1acb3;
}

.footer a:hover {
	color: #6986a2;
	transition: 0.4s ease;
	text-decoration: underline;
}

.footer ul li a {
	color: #fff;
	text-decoration:underline;
}

.headline {
	width: 100%;
	background: url('img/line.png'); 
	background-repeat: repeat-x; 
	text-align: center;
}

.headline h2 {
	display: inline; 
	background: #fff; 
	padding: 0 30px; 
	line-height: 1.8;
}

.hero-home-3, .hero-about, .hero-budget, .hero-services, .hero-black-and-tan {
	width: 100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	background-attachment: fixed;
	color: #fff;
}

.hero-home-3 div, .hero-about div, .hero-budget div, .hero-services div, .hero-black-and-tan div {
	width: 70%;
	text-align: center;
	margin-top: 40px;
}

.hero-home-3 div h1, .hero-about div h1, .hero-budget div h1, .hero-services div h1, .hero-black-and-tan div h1 {
	line-height: 1;
}

.hero-home-3 {
	background: url('img/forest-path.jpg') no-repeat;
	background-position-y: center;
	background-size: cover;
	height: 60vh;
}

.hero-budget {
	background: #225470;
	height: 50vh;
}

.hero-about, .hero-services {
	background: url('img/forest-path.jpg') no-repeat;
	background-position-y: center;
	background-size: cover;
	height: 50vh;
}

.zoom {
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
	overflow: hidden;
	padding: 0;
	margin: 0;
}

.zoom a::after {
	background: #fff;
}

.zoom img {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.zoom img:hover {
	-webkit-transform: scale(1.21);
	-ms-transform: scale(1.21);
	transform: scale(1.21);
}

.callout {
	width: 100%;
	display: block;
	margin: 30px 0 20px 0;
	padding: 30px 30px 20px 30px;
	background: #ebeef0;
}

.quote {
	background: url("img/quote.png") no-repeat;
	background-position: top left;
	font-style: italic;
	color: #777;
	padding-left: 50px;
}

.clients {
	width: 80%;
	clear: both;
	margin: 0 auto;
	padding: 30px 0;
}

/*=============================================
	FLEXBOX
=============================================*/

.flex-container-full-width {
	width: 100%; 
	display: flex; 
	flex-flow: row wrap; 
	justify-content: center;
	align-items: center;
}

.flex-container-full-width-clients {
	width: 100%; 
	display: flex; 
	flex-flow: row wrap; 
	justify-content: center;
	align-items: center;
	gap: 60px;
}

.flex-container-full-width-clients img {
	max-height: 100px;
}

.flex-item-two-thirds {
	flex-basis: 66%;
}

.flex-item-one-third {
	flex-basis: 33%;
}

.top-align {
	align-items:start;
}

.flex-item-one-quarter {
	/* flex-basis: 25%; */
}

.flex-item-half {
	flex-basis: 46%;
	margin-bottom: 60px;
}

.flex-item-half:nth-of-type(2n + 1) {
	padding-right: 4%;
} 

.flex-item-half:nth-of-type(2n) {
	padding-left: 4%;
}

.flex-item-half-flush {
	flex-basis: 50%;
}

.flex-item-half-design {
	flex-basis: 48%;
	margin-bottom: 10px;
}

.flex-item-half-design:nth-of-type(2n + 1) {
	padding-right: 1%;
} 

.flex-item-half-design:nth-of-type(2n) {
	padding-left: 1%;
}

.interior-center {
	text-align: center;
}

/*=============================================
	NAVIGATION
=============================================*/

.header { 
	width: 100%;
	position: fixed;
	z-index: 999;
	box-shadow: 0 0 20px 0 rgba(0,0,0,.05);
	font-weight: 400;
	float: right;
}

.header ul, .footer ul {
	margin: 0;
	padding: 0;
	list-style: none;
  }

.header li, .footer li {
	list-style-type: none;
}
  
.header li a {
	font-family: TTNormsStdCond-Medium, sans-serif;
	color: #393e41;
	font-size: .7em;
	text-transform: uppercase;
	letter-spacing: 3px;
	text-decoration: none;
	display: block;
	line-height: 1.1;
	margin: 24px 15px;
}

.header li:last-child {
	margin-right: 25px;
}
  
.header li a:hover, .header .menu-btn:hover {
	color: rgba(242, 108, 79, 0.25);
}

.header .logo {
	font-family: ClearfaceStd-Regular;
	margin: 25px 25px 25px 30px;
	display: inline;
}

.header .logo p {
	line-height: 3;
	display: inline;
}

.header .logo a {
	color: #393e41;
	position: relative;
  	overflow: hidden;
 	text-decoration: none;
}

.header .logo a::after {
	content: "";
	background: rgba(242, 108, 79, 0.25);
	position: absolute;
	left: 12px;
	bottom: -1px;
	width: calc(100% - 8px);
	height: calc(100% - 8px);
	z-index: -1;
	-webkit-transition: 0.35s cubic-bezier(0.25, 0.1, 0, 2.05);
	transition: 0.35s cubic-bezier(0.25, 0.1, 0, 2.05);
}

.header .logo a:hover:after {
	left: 0;
	bottom: -2px;
	width: 100%;
	height: 100%;
  }

/* Navigation Menu - Mobile First */

.header .menu {
	clear: both;
  	max-height: 0;
	transition: max-height .2s ease-out;
	position: relative;
	overflow: hidden;
}

.header .menu-hide {
	display: none;
}

.header .menu-icon {
	cursor: pointer;
	display: inline-block;
	float: right;
	padding: 44px 25px;
	position: relative;
	user-select: none;
}

.header .menu-icon .navicon {
	background: #3e3e3e;
	display: block;
	height: 2px;
	position: relative;
	transition: background .2s ease-out;
	width: 18px;
}
  
.header .menu-icon .navicon:before,
.header .menu-icon .navicon:after {
	background: #3e3e3e;
	content: '';
	display: block;
	height: 100%;
	position: absolute;
	transition: all .2s ease-out;
	width: 100%;
}
  
.header .menu-icon .navicon:before {
	top: 5px;
}
  
.header .menu-icon .navicon:after {
	top: -5px;
}

.menu-item-has-children > a:after {
	content: " \25BE"
}

.header ul ul {
	display: none;
	top: 2em;
	background: #eee;
	z-index: 99999;
}

.menu-cta {
	font-weight: 700;
}

  /* menu btn */
  
.header .menu-btn {
	display: none;
}
  
.header .menu-btn:checked ~ .menu {
	max-height: 340px;
}
  
.header .menu-btn:checked ~ .menu-icon .navicon {
	background: transparent;
}
  
.header .menu-btn:checked ~ .menu-icon .navicon:before {
	transform: rotate(-45deg);
}
  
.header .menu-btn:checked ~ .menu-icon .navicon:after {
	transform: rotate(45deg);
}
  
.header .menu-btn:checked ~ .menu-icon:not(.steps) .navicon:before,
.header .menu-btn:checked ~ .menu-icon:not(.steps) .navicon:after {
	top: 0;
}


/*=============================================
	MEDIA QUERIES
=============================================*/

@media only screen and (max-width: 480px) {
	h1 { font-size: 1.5em; }
	.grid-sizer, .grid-item { width: 100%; }
	.hero img { max-width: 80%; }
}

@media screen and (max-width: 767px) {
	.content, .content-wide, .content-breathe { width: 90%; }
	.flex-item-half, .flex-item-one-third, .flex-item-two-thirds {flex-basis: 100%; }
	.introduction { display: block; }
	.introduction .left, .introduction .right { width: 90%; }
	.introduction .interior { padding: 20px 20px 0 20px; }
	.introduction .interior .larger { margin-top: 0; }
	.header { justify-content: flex-start; }
	.item { padding: 10px; width: auto; }
	.callout { margin: 0; width: auto; }
}

@media screen and (min-width: 1600px) {
	.content, .content-wide, .content-breathe { width: 50%; }
}

/* Navigation Menu - Desktop */

@media (min-width: 900px) {
	.header li {
	  float: left;
	}
	.header .menu {
	  clear: none;
	  float: right;
	  max-height: none;
	  overflow: visible;
	  position: relative;
	}

	.header .menu-hide {
		display: inline-block;
	}

	.header .menu-icon {
	  display: none;
	}
	.header li:last-child {
		padding-bottom: 0;
	}
	.header ul ul {
		position: absolute;
		width: 100%;
		margin-top: 42px;
		box-shadow: 1px 1px 4px 0 rgba(0,0,0,.1);
	}
	.header ul ul li {
		display: block;
		clear: both;
		border-bottom: 1px solid #d9d9d9;
		width: 100%;
	}
	.header ul ul li a {
		padding: 20px;
	}
  }

  /*=============================================
	DESIGN SECTION
=============================================*/

.home-container {
	display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
	max-width: 100vw;
	margin-bottom: 60px;
}

.home-description {
	position: relative;
    background-color: #fff;
	margin-left: -50px;
	width: 33%;
	height: auto;
	z-index: 1;
}

.home-description-left {
	position: relative;
    background-color: #fff;
	margin-right: -50px;
	width: 30%;
	height: auto;
	z-index: 1;
}

.home-interior {
	padding: 40px 60px;
}

.home-image {
	align-self: flex-start;
	position: relative;
	width: 50%;
}

.container {
	width: 80%;
	margin: 0 auto;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}

.container-item {
	flex: 1 1 40%; 
	margin-bottom: 20px;
}

.container-interior {
	width: 50%; 
	background-color: #fff; 
	margin-top: -75px; 
	margin-left: 50px; 
	z-index: 5;
	position: relative;
	padding: 20px 30px;
}

.container-item:nth-child(odd) {
	margin-right: 20px;
}

.see-more {
    cursor: pointer;
    height: 20px;
    position: absolute;
    bottom: 32px;
    width: 100%;
    z-index: 105;
}

.see-more .icon {
    transition: all .2s linear;
    -moz-transition: all .2s linear;
    -webkit-transition: all .2s linear;
    -o-transition: all .2s linear;
    width: 100%;
    position: absolute;
    text-align: center;
}

.see-more .icon svg {
    fill: #ffffff !important;
}

.introduction {
	display: flex;
}

.introduction .left {
	width: 30%;
}

.introduction .right {
	width: 50%;
}

.introduction .interior {
	padding: 80px;
}

.scroll-wrapper {
	display: flex;
 	flex-wrap: nowrap;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.scroll-card {
	max-width: 500px;
	flex: 0 0 auto;
	margin: 0 20px 20px 0;
	color: #5a6064;
}

.scroll-card:last-of-type {
	margin-right: 0;
}

.scroll-card h4 {
	font-family: TTNormsStdCond-Medium, sans-serif;
	margin: 0 20px;
}

.scroll-card p {
	font-size: .7em;
	line-height: 1.4;
	font-family: TTNormsStdCond-Regular, sans-serif;
	font-weight: 400;
	margin: 0 20px;
}