@charset "utf-8";
/* CSS Document */

/*------------------------------------------------------------------------------------------------
Information
------------------------------------------------------------------------------------------------*/

/*

Max Content Width	=	1440px (10px x 144rem)

Default		=	Mobile
Media: 42+	=	Tablet / Desktop
Media: 64+	=	Large Desktop

*/

/*------------------------------------------------------------------------------------------------
RESET
------------------------------------------------------------------------------------------------*/

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;
}
 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;
}

/*------------------------------------------------------------------------------------------------
Global
------------------------------------------------------------------------------------------------*/

* {
	margin: 0;
	padding: 0;
}

html {
	height: 100%;
	font-size: 10px;
	
}

body {
	font-family: 'Montserrat', sans-serif;
	height: 100%;
	display: flex;
	flex-direction: column;
	background-color: white;
}

.content-width {
	width: 100%;
}
@media (min-width: 42rem){
	.content-width {
		max-width: 144rem;
	}
}

/*------------------------------------------------------------------------------------------------
Main Layout
------------------------------------------------------------------------------------------------*/

header {
	position: fixed;
	right: 0;
	left: 0;
	margin-right: auto;
	margin-left: auto;
	display: flex;
	align-items: center;
	min-height: 6rem;
	background-color: black;
	z-index: 1;
}
@media (min-width: 42rem){
	header {
		min-height: 8rem;
	}
}

section {
	margin: 6rem auto 0 auto;
	width: 100%;
	flex-grow: 1;
	background-color: white;
}
@media (min-width: 42rem){
	section {
		margin: 8rem auto 0 auto;
	}
}

footer {
	margin: 0 auto;
	width: 100%;
	display: flex;
	align-items: center;
	flex-shrink: 0;
	height: 6rem;
	background-color: black;
}

/*------------------------------------------------------------------------------------------------
Header - Content
------------------------------------------------------------------------------------------------*/

/*--------------------------------------------
Navigation - Desktop (Text)
--------------------------------------------*/

#nav-ul {
	list-style-type: none;
	margin-left: 2rem;
}

.nav-li {
	display: inline;
	padding-right: 2rem;
}

.nav-text-link {
	font-size: 1.6rem;
	color: white;
	text-decoration: none;
}

.nav-text-link:hover {
	text-decoration: underline
}

.nav-text-link:active {
	text-decoration: none
}

/*--------------------------------------------
Navigation - End
--------------------------------------------*/

#m-logo {
	margin-left: 2rem;
	margin-right: auto;
	height: 4rem;
}
@media (min-width: 42rem){
	#m-logo {
		height: 6rem;
	}
}

/*------------------------------------------------------------------------------------------------
Section - Content
------------------------------------------------------------------------------------------------*/

/*--------------------------------------------
Home
--------------------------------------------*/

.home-container {
	display: flex;
	flex-flow: column;
	width: 100%;
	height: 100vh;
	align-items: center;
	justify-content: center;
}

.home {
	display: flex;
	width: 100%;
	height: 100%;
	background-image: url("../images/hero.jpg");
	background-size: cover;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-position: center;
}

/*--------------------------------------------
Bio Page
--------------------------------------------*/

.bio-photo {
	margin-top: 2.5rem;
	width: 20rem;
	border-radius: 1.2rem;
}
@media (min-width: 42rem){
.bio-photo {
		margin-top: 5rem;
		width: 30rem;
	}
}

/*
.company-logo-container {
	display: flex;
	flex-flow: wrap;
	width: 80%;
	justify-content: center;

}
@media (min-width: 42rem){
	.company-logo-container {
		width: 70%;
	}
}

.company-logo {
	margin-bottom: 6%;
	margin-left: 6%;
	margin-right: 6%;
	width: 24%;
	box-sizing: border-box;

}
@media (min-width: 42rem){
	.company-logo {
		margin-left: 2%;
		margin-right: 2%;
		width: 12%;
	}
}
*/

.company-logo-container {
	display: flex;
	flex-flow: wrap;
	width: 80%;
	justify-content: center;
}
@media (min-width: 42rem){
	.company-logo-container {
		display: flex;
		flex-flow: wrap;
		width: 70%;
	}
}

.company-logo {
	display: flex;
	margin-left: 6%;
	margin-right: 6%;
	width: 24%;
	height: 4rem;
	justify-content: center;
}
@media (min-width: 42rem){
	.company-logo {
		margin-left: 2%;
		margin-right: 2%;
		width: 12%;
	}
}

.company-logo img {
	width: 100%;
}

.company-logo-padding-toprow {
	padding-top: 2.4rem;
}
@media (min-width: 42rem){
	.company-logo-padding-toprow {
		padding-top: 0rem;
	}
}

.company-logo-padding-bottomrow {
	padding-top: 2.4rem;
}
@media (min-width: 42rem){
	.company-logo-padding-bottomrow {
		padding-top: 4.2rem;
	}
}

/*--------------------------------------------
Bio & Get In Touch Page (Common)
--------------------------------------------*/

.section-content-container {
	display: flex;
	flex-flow: wrap;
	flex-grow: 1;
	width: 100%;
	height: calc(100vh - 8rem);
}

.fact-box-container {
	margin: 8rem auto 0 auto;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 70vh;
	width: 90%;
	max-width: 140rem;
}
@media (min-width: 42rem){
	.fact-box-container {
		height: auto;
		flex-flow: wrap;
		justify-content: space-between;
		align-items: flex-start;
	}
}

.fact-box {
/*	height: 100%;*/
	text-align: center;
}
@media (min-width: 42rem){
	.fact-box {
/*		height: 100%;*/
		width: 30%;
		min-width: 30%;
		text-align: center;
	}
}

.info-box {
	padding-top: 8rem;
	padding-bottom: 8rem;
	display: flex;
	flex-flow: column;
	width: 100%;
/*	min-height: 50%;*/
	align-items: center;
	justify-content: center;
}
@media (min-width: 42rem){
	.info-box {
		padding-top: 12rem;
		padding-bottom: 12rem;
	}
}

.info-box-content {
	display: flex;
	flex-flow: column;
	width: 80%;
	align-items: center;
	justify-content: center;
}
@media (min-width: 42rem){
	.info-box-content {
		width: 50%;
	}
}
.info-divider {
	margin-top: 2.5rem;
	margin-bottom: 2.5rem;
	width: 60%;
	height: 0.2rem;
	background-color: white;
}
@media (min-width: 42rem){
	.info-divider {
		margin-top: 5rem;
		margin-bottom: 5rem;
	}
}

.info-icon-container {
	margin-top: 2.5rem;
	display: flex;
	flex-flow: wrap;
	width: 100%;
	height: 6rem;
	justify-content: center;
}
@media (min-width: 42rem){
	.info-icon-container {
		margin-top: 5rem;
		height: 8rem;
	}
}

.info-icon {
	margin-left: 3%;
	margin-right: 3%;
	height: 100%;
	max-height: 100%;
}
@media (min-width: 42rem){
	.info-icon {
		margin-left: 3%;
		margin-right: 3%;
	}
}

.info-logo-container {
	margin-top: 2.5rem;
	display: flex;
	flex-flow: wrap;
	width: 100%;
	height: 3rem;
	justify-content: center;
}
@media (min-width: 42rem){
	.info-logo-container {
		margin-top: 5rem;
		height: 8rem;
	}
}

.info-logo {
	margin-left: 3%;
	margin-right: 3%;
	height: 100%;
	max-height: 100%;
}
@media (min-width: 42rem){
	.info-logo {
		margin-left: 3%;
		margin-right: 3%;
	}
}


/*--------------------------------------------
Services
--------------------------------------------*/

.service-icon-container {
	display: flex;
	flex-flow: wrap;
	width: 80%;
/*	background-color: aqua*/
}
@media (min-width: 42rem){
	.service-icon-container {
		display: flex;
		flex-flow: wrap;
		width: 80%;
	}
}

.service-icon {
	width: 50%;
	text-align: center;
/*	background-color: blue*/
}
@media (min-width: 42rem){
	.service-icon {
		width: 25%;
	}
}

.service-icon img {
	margin: 0;
	width: 50%;
}

.service-icon-padding-toprow {
	padding-top: 2.4rem;
}
@media (min-width: 42rem){
	.service-icon-padding-toprow {
		padding-top: 0rem;
	}
}

.service-icon-padding-bottomrow {
	padding-top: 2.4rem;
}
@media (min-width: 42rem){
	.service-icon-padding-bottomrow {
		padding-top: 4.2rem;
	}
}

/*--------------------------------------------
Slick
--------------------------------------------*/

.slick {
	width: 100%;
	height: auto;
}

/*--------------------------------------------
Get in Touch Page
--------------------------------------------*/

form {
	display: flex;
	flex-flow: column;
	width: 80%;
	justify-content: center;
}
@media (min-width: 42rem){
	form{
		width: 50%;
	}
}

input[type=text], [type=email], select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	height: 6rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.6rem;
	padding: 1.2rem 2rem;
	margin: 0 0 1rem 0;
	display: inline-block;
	border: none;
	border-radius: 1.2rem;
	box-sizing: border-box;
}
@media (min-width: 42rem){
	input[type=text], [type=email], select {
		width: 100%;
		height: 6rem;
	}
}

textarea, select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	height: 24rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.6rem;
	padding: 1.2rem 2rem;
	margin: 0 0 1rem 0;
	display: inline-block;
	border: none;
	border-radius: 1.2rem;
	box-sizing: border-box;
}
@media (min-width: 42rem){
	textarea, select {
		width: 100%;
		height: 30rem;
	}
}

input[type=submit] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 50%;
	height: 6rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.6rem;
	color: white;
	background-color: #00A3E0;
	padding: 1.2rem 2rem;
	border: none;
	border-radius: 1.2rem;
	cursor: pointer;
	box-sizing: border-box;
}
@media (min-width: 42rem){
	input[type=submit] {
		width: 25%;
	}
}

/*--------------------------------------------
Project Page(s)
--------------------------------------------*/

#project-container {
	display: flex;
	flex-grow: 1;
	flex-flow:column;
	margin: 0 3% 5% 3%;
}
@media (min-width: 42rem){
	#project-container {
		margin: 0 3% 5% 3%;
	}
}

#hero-image {
	width: 100%;
}

/*------------------------------------------------------------------------------------------------
Footer - Content
------------------------------------------------------------------------------------------------*/

#matt-media {
	margin-left: 2rem;
	font-size: 1.4rem;
	color: white;
	text-decoration: none
}
@media (min-width: 42rem){
	#matt-media {
		font-size: 1.4rem;
	}
}

.linkedin-link {
	margin-left: auto;
	margin-right: 2rem;
}

.linkedin-icon {
	height: 2rem;
}

/*------------------------------------------------------------------------------------------------
Text
------------------------------------------------------------------------------------------------*/

h1 {
	margin-bottom: 2.5rem;
	font-weight: bold;
	font-size: 2.8rem;
	line-height: 1;
	color: black;
	text-decoration: none;
	padding: 0;
	text-align: center;
}
@media (min-width: 42rem){
	h1 {
		margin-bottom: 5rem;
		font-size: 2.8rem;
/*		font-size: 4.2rem;*/
	}
}

h2 {
	margin-bottom: 2.5rem;
	font-weight: bold;
	font-size: 2.2rem;
	line-height: 1;
	color: grey;
	text-decoration: none;
	padding: 0;
	text-align: center;
}
@media (min-width: 42rem){
	h2 {
		margin-bottom: 5rem;
		font-size: 2rem;
	}
}

.body-text {
	font-size: 1.6rem;
	line-height: 1.8;
	color: grey;
	text-decoration: none;
}
@media (min-width: 42rem){
	.body-text {
		font-size: 2rem;
	}
}

.body-text a {
	color: #6db6fc;
	text-decoration: underline
}

.small-text {
	font-size: 1.2rem;
	color: #888888;
	text-decoration: none
}
@media (min-width: 42rem){
	.small-text {
		font-size: 1.8rem;
	}
}

.text-bold {
	font-weight: bold;
}

.large-text {
	font-size: 6rem;
	line-height: 1.8rem;
}

.text-16 {
	font-size: 5.6rem;
}
.font-color-black {
	color: black;
}

.font-color-white {
	color: white;
}

.font-color-grey {
	color: grey;
}

.font-color-PGBlue {
	color: #00A3E0;
}

/*------------------------------------------------------------------------------------------------
Styles
------------------------------------------------------------------------------------------------*/

.padding-top--10 {
	padding-top: 6rem;
}
@media (min-width: 42rem){
	.padding-top--10 {
		padding-top: 10rem;
	}
}

.padding-bottom--10 {
	padding-bottom: 6rem;
}

.margin-bottom-2p5-5 {
	margin-bottom: 2.5rem;
}
@media (min-width: 42rem){
	.margin-bottom-2p5-5 {
		margin-bottom: 5rem;
	}
}

.margin-bottom-24 {
	margin-bottom: 2.4rem;
}

.background-color-white {
	background-color: white;
}

.background-color-PGBlue {
	background-color: #00A3E0;
}

.background-color-MMGreen {
	background-color: #32BAA3;
}
.background-color-MMPurple {
	background-color: #8C78B0;
}
.background-color-MMBlue {
	background-color: #345E75;
}
.background-color-MMRed {
	background-color: #F2654E;
}
.background-color-MMGrey {
	background-color: rgba(0,0,0,0.8);
}


























