/*///////////////////////////////////// GENERAL SETTINGS//////////////////////////// */


* {
	
	font-size: inherit;
	font-weight: 400;
	font-family: "Source Sans Pro", "Trebuchet MS";
	color: inherit;
	position: relative;
	overflow: hidden;
	padding:0;
	margin:0;
	box-sizing: border-box;
	flex-shrink:1;
	flex-grow:0;
	flex-basis: auto;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body, html {
	overflow: visible;
	background-color: #FFF;
	font-size: 18px;
	height: 100%;
}
a:link, a:visited {
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}





/*///////////////////////////////////// HELPER CLASSES //////////////////////////// */
.overflow {
	overflow: visible;
}

.fullWidth {
	width: 100%;
}

.fullHeight {
	height: 100%;
}

.postMargins {
	max-width: 850px;
	margin: 0 auto;
	padding: 0 50px;
}

.mobileOnly {
	display: none;
}

.mobileHidden {
	display: block;
}

.margins, .mobileNoMargins {
	margin: 0 auto;
	max-width: 1200px;
	padding: 0 50px;
	overflow: hidden;
}

.textCenter {
	text-align: center;
}

.lightText {
	font-weight: 100;
}

.left {
	float:left;
}

.right {
	float:right;
}

.padding {
	padding:30px;
}

.paddingY {
	padding-top:30px;
	padding-bottom:30px;
}

.postPadding {
	padding-bottom:50px;
	padding-top: 50px;
}

.itemMarginBottom {
	margin-bottom: 30px;
}

.page {
	background-color: #f2f4f9;
	z-index: 1;
}

.aspectRatio32 {
	padding-bottom: calc(66.6666666666666666666667%);
	width:100%;
	background-color: #222;
}


.aspectRatio169 {
	padding-bottom: calc(100% * (9 / 16));
}

.aspectRatio52 {
	padding-bottom: calc(100% * (2 / 5));
}

.aspectFit {
	display: block;
	position: absolute;
	top: -1px;
	left: -1px;
	right: 0;
	bottom: 0;
	margin: auto;
	max-height: calc(100% + 2px);
	max-width: calc(100% + 2px);
}

.aspectFill {
	width: auto;
	max-height: 100%;
	object-fit:cover;
}

.overlay {
	position: absolute;
	background-color: rgba(0,0,0,0);
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	pointer-events: none;
	color:#FFF;
}

.absoluteFullArea {
	position: absolute;
	width: 100%;
	height: 100%;
}

.flexNoGrow {
	flex-grow:0;
}

















/*///////////////////////////////////// MAIN LAYOUT //////////////////////////// */
.columns {
	width: calc((100% - 60px) * 0.33333333333333333);
	float: left;
	margin-right: 30px;
	max-width: calc((100% - 60px) * 0.33333333333333333);
}

.columns:nth-of-type(3n) {
	margin-right: 0px;
}

.flexContainer {
	display:flex;
	flex-direction: row;
	align-items: flex-start;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items:stretch;
}

.flexContainerVC {
	display:flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flexContainerCenter {
	display:flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}

.flexContainerStart {
	display:flex;
	flex-direction: row;
	align-items: stretch;
	justify-content: flex-start;
	flex-wrap: wrap;
}

.bigColumn {
	width: calc((100% - 40px) * 0.6);
	
}

.smallColumn {
	top: 0;
	width: calc(30%);
}

.smallColumn.withCTA {
	padding-bottom:110px;
}





.buttonBlurb {
	text-align: center;
	color: #85bcdf;
	font-size: 18px;
	font-weight: 300;
	margin-top: 25px;
	margin-bottom: 10px;
}

.hireMe {
	float: right;
	border-radius: 30px;
	background-color: #45abec;
	padding: 7px 20px;
	color: #FFF;
	font-weight: 600;
	margin-top: 0px;
	cursor: pointer;
	min-width: 200px;
	text-align: center;
	line-height: 35px;
	font-size: 24px;
}

.hireMeBig {
	width:100%;
}

.hireMe:hover {
	background-color: #55bbfc;
}


.headerButton {
	float: right;
	border-radius: 20px;
	background-color: #45abec;
	border: solid 2px #FFF;
	padding: 5px 20px;
	color: #FFF;
	font-weight: 600;
	margin-top: 10px;
	cursor: pointer;
	min-width: initial;
	line-height: 24px;
	font-size: 20px;
}

.headerButton:hover {
	background-color: #55bbfc;
}

a.hireMe {
	text-decoration: none;
}


.postBackgroundImage 
{
	opacity: 1;
	display: block;
	position: absolute;
	object-fit: cover;
	width: 100%;
	height: 100%;
	top: 0px;
}

.postBackgroundContainer {
	position: relative;
	background-color: #000;
	width: 100%;
	margin-top: -20px;
	padding:20px 0px;
	padding-bottom: 20px;
}


.featureText {
	flex-shrink:6;
	overflow: visible;
}

.featureText.home {
	padding: 60px 0;
}


.featureText.smallLeftMargin {
	margin-left: 20px;
}

.featureTitle {
	font-size: 45px;
	color: #FFF;
	flex-shrink:6;
	line-height: 50px;
	overflow: visible;
	font-weight: 300;
}

.featureTitle.home {
	text-align: center;
	font-size: 60px;
	line-height: 65px;
	font-weight: 300;
	overflow: visible;

}

.featureSubtitle {
	font-size: 30px;
	color: #b1e1ff;
	overflow: visible;
	font-weight: 300;
	line-height: 35px;
}

.featureSubtitle.home {
	text-align: center;
	font-size: 30px;
	margin-top: 10px;
	line-height: 33px;
}



.meImage {
	margin: 20px 0px;
	margin-right: 20px;
	width: 100px;
	border-radius: 50px;
	border: solid 3px #FFF;

}

.blurbSection {
	background-color: #153d5c;
}

.blurbText {
	padding: 20px 0px;
}

.blurbTitle {
	font-size: 28px;
	color: #b8e4ff;
	font-weight: 300;
	line-height: 43px;
}

.blurbSubtitle {
	font-size: 20px;
	color: #88c8f1;
	font-weight: 300;
}

h2 {
	color: #153d5c;
	font-size: 50px;
	font-weight: 300;
	width:100%;
	line-height: 60px;
}

p {
	color: #254d6c;
	font-size: 18px;
	line-height: 30px;
	margin-bottom: 20px;
}

.contactSection * p {
	color: #496d8c;
}

p:nth-last-child(1) {
	margin-bottom: 0px;
}


.sideImage { 
	margin-top: 60px;
}



.lightSection {
	background-color: #cbe2f0;
}

.photoGrid {
	align-items: flex-start;
}


.photoGridPhoto {
	width: calc(50% - 10px);
	flex-grow:0;
	margin-bottom: 20px;
}

.photoGridPhotoSmall {
	width:100%;
	flex-grow:0;
	margin-bottom: 20px;
	margin-top: 10px;
}

.ctaSection {
	padding-top: 20px;
	padding-bottom: 20px;
}

.photoGrid a {
	width: calc(33% - 10px);
}

.contactSection {
	background-color: #021423;
}

.whiteText {
	color: #b8e4ff;
}

.lighterText {
	color: #88c8f1;
}



.contactLink {
	top: -20px;
	margin-bottom: 10px;
	display: block;
	background-color:#45abec;
	border-radius: 20px;
	padding: 5px 15px;
	color: #e5efff;
}

.contactLink:hover {
	text-decoration: none;
	background-color:#55bbfc;
}

p {
	overflow: visible;
}

.photoCaption {
	color: #254d6c;
	font-size: 14px;
	float: right;
}


.borderButton {
	border: solid 2px #FFF;
}


/*////////////////////////////////////////////////////// Header */
header {
	background-color: #45abec;
	width: 100%;
}

.logoImage {
	width: 180px;
	margin-top: 18px;
	margin-bottom: 18px;
}



.footerSection {
	background-color: #45abec;
	width: 100%;
}

.footerSection h2 {
	color: #b8e8ff;

}


@media (max-width:700px) {

	.margins {
		padding: 0px 20px;
	}

	.bigColumn {
		width: 100%;

	}

	.smallColumn {
		width: 100%;
	}


	.featureTitle.home {
		font-size: 35px;
		line-height: 40px;
	}

	.featureSubtitle.home {
		font-size: 20px;
		margin-top: 0px;
	}

	.postBackgroundContainer {
		padding-bottom: 0px;
	}

	.meImage {
		width: 70px;
		border-width: 2px;
	}

	.blurbText {
		width: calc(100% - 90px);
	}

	.blurbButtonContainer {
		width: 100%;
			margin-top: -20px;
			
	}

	.hireMe {
		width: 100%;
		margin-bottom: 20px;
	}

	.hireMe.headerButton {
		width: initial;
		margin-bottom: 0px;
	}

	.blurbTextContainer {
		border-bottom: solid 1px #557d9c;
	}

	.sideImage {
		margin-bottom: 20px;
		margin-top: 20px;
	}

	.photoGridPhoto {
		width: 100%;
	}


}




