/*
	Theme Name: Steve Gould
	Author: Two Infinity
	Description: Custom built theme for Steve Gould
	Version: 0.0.1
*/
/* Font stack */
/* Colours */
/* Media sizes */
footer .sitemap > div:not(.clearfix) ul li a { white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }

input[type=submit]:hover, .btn:hover { background-image: linear-gradient(rgba(0, 0, 0, 0.03), rgba(0, 0, 0, 0.03)); }

/* Flaticon icon font: Flaticon Creation date: 24/08/2016 03:22
*/
@font-face { font-family: "Flaticon"; src: url("../fonts/Flaticon.eot"); src: url("../fonts/Flaticon.eot?#iefix") format("embedded-opentype"), url("../fonts/Flaticon.woff") format("woff"), url("../fonts/Flaticon.ttf") format("truetype"), url("../fonts/Flaticon.svg#Flaticon") format("svg"); font-weight: normal; font-style: normal; }
@media screen and (-webkit-min-device-pixel-ratio: 0) { @font-face { font-family: "Flaticon"; src: url("../fonts/Flaticon.svg#Flaticon") format("svg"); } }
.fi:before { display: inline-block; font-family: "Flaticon"; font-style: normal; font-weight: normal; font-variant: normal; line-height: 1; text-decoration: inherit; text-rendering: optimizeLegibility; text-transform: none; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; font-smoothing: antialiased; }

.flaticon-close:before { content: "\f100"; }

.flaticon-facebook:before { content: "\f101"; }

.flaticon-linkedin:before { content: "\f102"; }

.flaticon-menu:before { content: "\f103"; }

.flaticon-twitter:before { content: "\f104"; }

.flaticon-youtube:before { content: "\f105"; }

@font-face { font-family: 'montserratbold'; src: url("../fonts/montserrat-bold-webfont.woff2") format("woff2"), url("../fonts/montserrat-bold-webfont.woff") format("woff"); font-weight: normal; font-style: normal; }
@font-face { font-family: 'montserrathairline'; src: url("../fonts/montserrat-hairline-webfont.woff2") format("woff2"), url("../fonts/montserrat-hairline-webfont.woff") format("woff"); font-weight: normal; font-style: normal; }
@font-face { font-family: 'montserratlight'; src: url("../fonts/montserrat-light-webfont.woff2") format("woff2"), url("../fonts/montserrat-light-webfont.woff") format("woff"); font-weight: normal; font-style: normal; }
@font-face { font-family: 'montserratregular'; src: url("../fonts/montserrat-regular-webfont.woff2") format("woff2"), url("../fonts/montserrat-regular-webfont.woff") format("woff"); font-weight: normal; font-style: normal; }
@font-face { font-family: 'montserratultra_light'; src: url("../fonts/montserrat-ultralight-webfont.woff2") format("woff2"), url("../fonts/montserrat-ultralight-webfont.woff") format("woff"); font-weight: normal; font-style: normal; }
.soft-hide { display: none; }

.text-center { text-align: center; }

html, body { margin: 0; }

body { font-family: "montserratultra_light", Helvetica, Arial, sans-serif; font-weight: 300; font-size: 18px; color: #444444; }

h1, h2, h3, h4, h5, h6 { font-family: "freight-display-pro", Georgia, sans-serif; font-weight: 300; }

img { max-width: 100%; height: auto; }

a { color: #34cbd4; }

.wrapper { width: 1200px; margin: 0 auto; height: 100%; position: relative; }
@media (max-width: 1279px) { .wrapper { width: 980px; } }
@media (max-width: 1023px) { .wrapper { width: 720px; } }
@media (max-width: 767px) { .wrapper { width: 90%; } }

input[type=submit], .btn { min-width: 200px; padding: 15px 30px; font-family: "montserratlight"; font-size: 18px; line-height: 20px; text-transform: uppercase; background-color: #34cbd4; color: #ffffff; border-radius: 0; }
input[type=submit].light, .btn.light { background-color: #ffffff; color: #1d222a; }
input[type=submit].light:hover, input[type=submit].light:active, input[type=submit].light:focus, .btn.light:hover, .btn.light:active, .btn.light:focus { color: #1d222a; }
input[type=submit].dark, .btn.dark { background-color: #1d222a; color: #ffffff; }
input[type=submit]:hover, input[type=submit]:active, input[type=submit]:focus, .btn:hover, .btn:active, .btn:focus { color: #ffffff; }

.mobile-expanded { overflow: hidden; }

.top-header { height: 80px; line-height: 80px; margin: 20px auto; font-family: "montserratlight", Helvetica, Arial, sans-serif; font-size: 16px; }
.top-header .site-logo { margin: 0; display: inline-block; }
@media (max-width: 767px) { .top-header .site-logo { max-width: 80%; } }
.top-header .main-nav { position: absolute; right: 0; top: 0; height: 80px; line-height: 80px; text-align: right; }
.mobile-expanded .top-header .main-nav { position: fixed; bottom: 0; left: 0; height: 100%; text-align: center; z-index: 100000; background: rgba(255, 255, 255, 0.95); overflow: auto; }
.top-header .main-nav .mobile-menu { display: none; cursor: pointer; font-size: 1.8em; }
.top-header .main-nav .mobile-menu:hover { color: #34cbd4; cursor: pointer; }
@media (max-width: 1023px) { .top-header .main-nav .mobile-menu { display: block; } }
.mobile-expanded .top-header .main-nav .mobile-menu { display: none; }
.top-header .main-nav .close-mobile-menu { display: none; font-size: 1.6em; width: 25px; height: 25px; top: 30px; right: 30px; padding: 0; position: absolute; line-height: 0; }
.top-header .main-nav .close-mobile-menu:hover { color: #34cbd4; cursor: pointer; }
.mobile-expanded .top-header .main-nav .close-mobile-menu { display: block; }
.top-header .main-nav ul { margin: 0; padding: 0; list-style: none; }
@media (max-width: 1023px) { .top-header .main-nav ul { display: none; } }
.mobile-expanded .top-header .main-nav ul { display: block; padding-top: 75px; }
.top-header .main-nav ul li { list-style: none; padding: 0 20px; float: left; }
.mobile-expanded .top-header .main-nav ul li { width: 100%; float: none; padding: 0; font-size: 2.4em; }
.top-header .main-nav ul li:last-child { padding-right: 0; }
.top-header .main-nav ul li a { color: inherit; }
.mobile-expanded .top-header .main-nav ul li a { padding: 25px 0; display: block; }
.top-header .main-nav ul li a:focus, .top-header .main-nav ul li a:hover { text-decoration: none; color: #34cbd4; }

footer .sitemap { display: table; table-layout: fixed; vertical-align: top; padding: 50px 0; }
@media (max-width: 1023px) { footer .sitemap { display: block; } }
footer .sitemap > div:not(.clearfix) { display: table-cell; vertical-align: top; overflow: hidden; width: 33.3333333333%; padding: 0 30px; border-right: 1px solid #e1e1e1; }
@media (max-width: 1023px) { footer .sitemap > div:not(.clearfix) { width: 50%; display: block; float: left; } }
@media (max-width: 767px) { footer .sitemap > div:not(.clearfix) { width: 100%; border: 0 none; margin: 40px 0 0 0; padding: 0; text-align: center; } }
footer .sitemap > div:not(.clearfix) h3 { font-weight: 300; font-family: "montserratlight"; font-size: 18px; margin-top: 0; margin-bottom: 30px; }
footer .sitemap > div:not(.clearfix) ul { margin: 0; padding: 0; list-style: none; }
footer .sitemap > div:not(.clearfix) ul li { list-style: none; letter-spacing: 0.06em; font-size: 16px; }
footer .sitemap > div:not(.clearfix) ul li a { color: #1d222a; padding: 15px 0; display: block; width: 100%; height: 100%; }
footer .sitemap > div:not(.clearfix) ul li a:focus, footer .sitemap > div:not(.clearfix) ul li a:hover { color: #34cbd4; text-decoration: none; }
footer .sitemap > div:not(.clearfix).site-logo { vertical-align: middle; }
@media (max-width: 1023px) { footer .sitemap > div:not(.clearfix).site-logo { width: 100%; display: block; text-align: center; margin: 0 0 40px 0; border: 0 none; } }
footer .sitemap > div:not(.clearfix).site-logo a { display: inline-block; width: 100%; }
footer .sitemap > div:not(.clearfix).projects-list { border-right: 0 none; }
footer .external { border-top: 1px solid #e1e1e1; padding: 50px 0; }
footer .external > .wrapper { height: 50px; line-height: 50px; }
footer .external .slogan { font-weight: 300; font-family: "montserratlight"; color: #34cbd4; float: left; }
@media (max-width: 1023px) { footer .external .slogan { display: none; } }
footer .external .ti-logo { float: right; text-align: right; }
@media (max-width: 1023px) { footer .external .ti-logo { float: none; text-align: center; } }
footer .external .ti-logo a { text-decoration: none; }
footer .external .ti-logo a img { border: 0 none; outline: none; margin-left: 15px; filter: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg'><filter id='grayscale'><feColorMatrix type='matrix' values='0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0'/></filter></svg>#grayscale"); /* Firefox 3.5+ */ filter: gray; /* IE6-9 */ -webkit-filter: grayscale(100%); /* Chrome 19+ & Safari 6+ */ }
footer .external .ti-logo a img:hover { filter: none; -webkit-filter: grayscale(0%); }
footer .external .social { float: right; text-align: right; }
@media (max-width: 1023px) { footer .external .social { float: none; text-align: center; } }
footer .external .social a { margin: 0 10px; border-radius: 0; background-color: #c7c7c7; display: inline-block; text-align: center; width: 50px; height: 50px; line-height: 50px; color: #ffffff; text-decoration: none; font-size: 28px; }
@media (max-width: 767px) { footer .external .social a { margin: 0 5px; } }
footer .external .social a:last-child { margin-right: 0; }
footer .external .social a:hover { background-color: #34cbd4; text-decoration: none; }

.main-content > section { margin: 80px auto 0 auto; position: relative; }
.main-content > section.featured-section { margin-top: 0; min-height: 600px; height: 80vh; background-size: cover; background-position: top center; background-repeat: no-repeat; background-image: url("../img/hero-1.jpg"); }
@media (max-width: 1023px) { .main-content > section.featured-section { background-position: 0; min-height: 0; height: 500px; } }
@media (max-width: 767px) { .main-content > section.featured-section { padding: 20px 0; height: auto; background-image: none; } }
.main-content > section.featured-section .hero-content { position: absolute; top: 200px; top: 15vh; width: 550px; }
@media (max-width: 1023px) { .main-content > section.featured-section .hero-content { font-size: 0.8em; width: 400px; top: 50px; } }
@media (max-width: 767px) { .main-content > section.featured-section .hero-content { width: 100%; text-align: center; position: static; } }
.main-content > section.featured-section .hero-content h2 { font-size: 2.6em; line-height: 1.2em; margin-bottom: 50px; }
.main-content .tile, .main-content .blog-item { position: relative; overflow: hidden; float: left; border: 7.5px solid #fff; background-color: #444444; background-size: cover; background-position: center center; /*
@include media("<small-desktop") {
	width: 100% !important;
	border: 0 none;
	margin: 0 0 15px 0;
}
*/ }
.main-content .tile.tile-12, .main-content .blog-item.tile-12 { width: 100%; }
.main-content .tile.tile-8, .main-content .blog-item.tile-8 { width: 66.6666666667%; }
.main-content .tile.tile-12, .main-content .tile.tile-8, .main-content .blog-item.tile-12, .main-content .blog-item.tile-8 { height: 620px; }
@media (max-width: 767px) { .main-content .tile.tile-12, .main-content .tile.tile-8, .main-content .blog-item.tile-12, .main-content .blog-item.tile-8 { height: 310px; } }
.main-content .tile.tile-6, .main-content .blog-item.tile-6 { width: 50%; height: 310px; }
.main-content .tile.tile-4, .main-content .blog-item.tile-4 { width: 33.3333333333%; height: 310px; }
.main-content .tile .overlay, .main-content .blog-item .overlay { position: absolute; left: 0; top: 100%; width: 100%; height: 100%; overflow: hidden; background-color: rgba(52, 203, 212, 0.95); color: #ffffff; }
.main-content .tile .overlay .content, .main-content .blog-item .overlay .content { display: block; padding: 8%; }
.main-content .tile .overlay .content h3, .main-content .blog-item .overlay .content h3 { margin: 0 0 20px 0; }
.main-content .tile .overlay .content p, .main-content .blog-item .overlay .content p { margin: 12px 0; line-height: 1.6em; }
.main-content .tile .overlay .content .btn, .main-content .blog-item .overlay .content .btn { margin: 12px 0 0 0; }
.main-content .about-section { margin-top: 150px; }
@media (max-width: 767px) { .main-content .about-section { margin-top: 50px; } }
.main-content .about-section h2 { font-size: 36px; font-weight: 400; margin-bottom: 50px; }
.main-content .about-section p.large { margin: 0 auto 50px auto; max-width: 800px; font-size: 1.2em; line-height: 1.6em; }
.main-content .about-section .btn { font-size: 0.8em; }
.main-content .about-section .info { margin-top: 150px; }
@media (max-width: 767px) { .main-content .about-section .info { margin-top: 50px; } }
.main-content .about-section .info section { float: left; width: 50%; padding: 10px 30px; }
@media (max-width: 767px) { .main-content .about-section .info section { width: 100%; border-right: 0 none !important; padding-top: 0; padding-bottom: 0; text-align: center; } }
.main-content .about-section .info section p { line-height: 2em; color: #787878; margin: 30px 0; font-size: 0.9em; }
.main-content .about-section .info section:first-child { border-right: 1px solid #e1e1e1; }
.main-content .blog-section { margin-top: 150px; 		/*
		@include media("<small-desktop") {
			width: 100%;
		}

		@include media("<tablet") {
			width: 90% !important;
			margin: {
				top: 50px;
				left: auto;
				right: auto;
			}
		}
		*/ }
@media (max-width: 767px) { .main-content .blog-section { margin-top: 50px; } }
.main-content .blog-item { margin: 0; border: 0 none; width: 12.5%; height: 0; padding: 12.5%; 		/*
		@include media("<small-desktop") {
			width: 25% !important;
			padding: 25% !important;
		}

		@include media("<tablet") {
			width: 100% !important;
			height: 310px;
			padding: 0;
			margin-bottom: 15px;
		}
		*/ }
.main-content .mailing-section { margin-top: 0; padding-top: 120px; height: 100vh; min-height: 750px; text-align: center; color: #1d222a; background-image: url("../img/cliff-1.jpg"); background-size: cover; background-position: center bottom; }
@media (max-width: 1023px) { .main-content .mailing-section { padding-top: 40px; } }
.main-content .mailing-section h2 { font-size: 68px; font-weight: 300; }
@media (max-width: 1023px) { .main-content .mailing-section h2 { font-size: 36px; } }
.main-content .mailing-section h3 { font-size: 32px; font-weight: 300; line-height: 1.4em; width: 80%; margin: 50px auto; }
@media (max-width: 1023px) { .main-content .mailing-section h3 { font-size: 24px; } }
.main-content .mailing-section .input-group { width: 70%; margin: 80px auto 20px auto; font-family: "freight-display-pro", Georgia, sans-serif; }
@media (max-width: 1023px) { .main-content .mailing-section .input-group { width: 100%; } }
.main-content .mailing-section .input-group input[name=email], .main-content .mailing-section .input-group input[name=EMAIL] { background-color: transparent; border: 2px solid #1d222a; border-radius: 0; padding: 0 20px; height: 80px; color: #1d222a; font-size: 24px; /* WebKit, Blink, Edge */ /* Mozilla Firefox 4 to 18 */ /* Mozilla Firefox 19+ */ /* Internet Explorer 10-11 */ }
@media (max-width: 1279px) { .main-content .mailing-section .input-group input[name=email], .main-content .mailing-section .input-group input[name=EMAIL] { font-size: 20px; height: 60px; background-color: rgba(255, 255, 255, 0.8); } }
.main-content .mailing-section .input-group input[name=email]:focus, .main-content .mailing-section .input-group input[name=EMAIL]:focus { box-shadow: none; outline: 0 none; }
.main-content .mailing-section .input-group input[name=email]::-webkit-input-placeholder, .main-content .mailing-section .input-group input[name=EMAIL]::-webkit-input-placeholder { color: #444444; }
.main-content .mailing-section .input-group input[name=email]:-moz-placeholder, .main-content .mailing-section .input-group input[name=EMAIL]:-moz-placeholder { color: #444444; opacity: 1; }
.main-content .mailing-section .input-group input[name=email]::-moz-placeholder, .main-content .mailing-section .input-group input[name=EMAIL]::-moz-placeholder { color: #444444; opacity: 1; }
.main-content .mailing-section .input-group input[name=email]:-ms-input-placeholder, .main-content .mailing-section .input-group input[name=EMAIL]:-ms-input-placeholder { color: #444444; }
.main-content .mailing-section .input-group .btn { text-transform: none; height: 80px; color: #ffffff; font-family: "freight-display-pro", Georgia, sans-serif; font-weight: 300; font-size: 28px; }
@media (max-width: 1279px) { .main-content .mailing-section .input-group .btn { font-size: 24px; height: 60px; } }
@media (max-width: 767px) { .main-content .mailing-section .input-group .btn { min-width: 100px; } }
.main-content .mailing-section .input-group .btn:active, .main-content .mailing-section .input-group .btn:focus { box-shadow: none; outline: 0 none; }
.main-content .mailing-section .mc4wp-alert { padding: 10px 20px; width: 70%; margin: 0 auto; text-align: left; background-color: rgba(255, 255, 255, 0.8); border: 2px solid #1d222a; }
.main-content .mailing-section .mc4wp-alert.mc4wp-success { border-color: #13b525; }
.main-content .mailing-section .mc4wp-alert.mc4wp-error { border-color: #c12040; }
.main-content .mailing-section .mc4wp-alert p { margin: 0; }
@media (max-width: 1023px) { .main-content .mailing-section .mc4wp-alert { width: 100%; } }
@media (max-width: 767px) { .main-content .mailing-section .mc4wp-alert { padding: 15px 10px; } }
.main-content .contact-section { padding: 60px 0; background-color: #34cbd4; background-image: url("../img/logo-overlay.png"); background-size: 300px; background-position: right -50px bottom -50px; background-repeat: no-repeat; }
@media (max-width: 767px) { .main-content .contact-section { background-image: none; } }
.main-content .contact-section h2, .main-content .contact-section h3 { text-align: center; color: #ffffff; font-size: 48px; letter-spacing: 0.04em; margin-top: 0; }
.main-content .contact-section h2 { font-style: italic; font-size: 55px; font-weight: 400; }
.main-content .contact-section .contact-form { margin: 60px 0 0 0; }
.main-content .contact-section .contact-form .row { margin-top: 20px; }
.main-content .contact-section .contact-form input, .main-content .contact-section .contact-form textarea { background-color: #ffffff; border: 0 none; border-radius: 0; padding: 20px 40px; height: 80px; color: #1d222a; font-family: "freight-display-pro", Georgia, sans-serif; font-weight: 300; font-size: 24px; width: 100%; margin: 15px 0; /* WebKit, Blink, Edge */ /* Mozilla Firefox 4 to 18 */ /* Mozilla Firefox 19+ */ /* Internet Explorer 10-11 */ }
.main-content .contact-section .contact-form input:focus, .main-content .contact-section .contact-form textarea:focus { box-shadow: none; outline: 0 none; }
.main-content .contact-section .contact-form input::-webkit-input-placeholder, .main-content .contact-section .contact-form textarea::-webkit-input-placeholder { color: #cccccc; }
.main-content .contact-section .contact-form input:-moz-placeholder, .main-content .contact-section .contact-form textarea:-moz-placeholder { color: #cccccc; opacity: 1; }
.main-content .contact-section .contact-form input::-moz-placeholder, .main-content .contact-section .contact-form textarea::-moz-placeholder { color: #cccccc; opacity: 1; }
.main-content .contact-section .contact-form input:-ms-input-placeholder, .main-content .contact-section .contact-form textarea:-ms-input-placeholder { color: #cccccc; }
.main-content .contact-section .contact-form .g-recaptcha { margin: 7.5px 0; }
.main-content .contact-section .contact-form textarea { height: 150px; }
.main-content .contact-section .contact-form span.wpcf7-not-valid-tip { color: #ffffff; margin-bottom: 10px; }
.main-content .contact-section .contact-form div.wpcf7-response-output { color: #fff; padding: 0; margin: 0; border: 0 none; }
.main-content .contact-section .contact-form div.wpcf7 img.ajax-loader { margin: 0; }

.divider-line { height: 4px; background-color: #34cbd4; }
