

/* ==========================================================================
   GLOBAL STYLES
   ========================================================================== */


html {
  width: 100%;
  height: 100%;
  background: url("../img/splash.jpg") center center repeat;
	background-size: cover; 
	text-align: center;
 }

body {
	font-family: 'Mercury SSm A', 'Mercury SSm B', Georgia, serif; 
	font-weight: 200; 
	font-style: normal;
  font-size: 1em;
	color: #666;
	line-height: 1.5;
}

h1 {
	font-family: 'Gotham SSm A', 'Gotham SSm B', 'Gotham', Arial, sans-serif; 
	font-weight: 500; 
	font-style: normal;
	font-size: 3em;
	line-height: 1.125;
	margin: 0 0 .75em 0;
	padding: 0;
	font-weight: 200;
}

h2 {
	font-family: 'Gotham SSm A', 'Gotham SSm B', 'Gotham', Arial, sans-serif; 
	font-weight: 500; 
	font-style: normal;
	line-height: 1.125;
	margin: 2em 0 .75em 0;
	padding: 0;
	font-size: 1.25em;
	text-transform: uppercase;
	color: #111;
}

h3 {
	font-family: 'Mercury SSm A', 'Mercury SSm B', Georgia, serif; 
	font-style: normal;
	line-height: 1.125;
	margin: 0 0 .25em 0;
	padding: 0;
	font-size: 1.75em;
	font-weight: 400;
	color: #111;
}

h4 {
	font-family: 'Mercury SSm A', 'Mercury SSm B', Georgia, serif; 
	font-style: normal;
	line-height: 1.125;
	margin: 0 0 .25em 0;
	padding: 0;
	font-size: 1.125em;
	font-weight: 500;
	color: #111;
}

h5 {
	font-family: 'Mercury SSm A', 'Mercury SSm B', Georgia, serif; 
	font-size: 3em;
	line-height: 1.125;
	margin: 0 0 .5em 0;
	padding: 0;
	font-weight: 300;
	font-style: italic;
}


p {
	margin: 0 0 1.25em 0;
  line-height: 1.875;
}

img {
	max-width: 100%;
}

a {
	outline: none;
	text-decoration: none;
	color: #bf1e2e;
	-o-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	-ms-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	-moz-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	-webkit-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out, opacity .2s ease-in-out;
}

a:hover {
	color: #00326f;
}

a:focus{
    outline:0;
}


.contentwidth {
	max-width: 1140px;
	margin: 0 auto;
}

@media screen and (max-width: 1240px) {
	.contentwidth {
		width: 90%;
		margin: 0 5%;
	}
}

a.button {
	display: block;
	font-family: 'Gotham SSm A', 'Gotham SSm B', 'Gotham', Arial, sans-serif; 
	font-weight: 400; 
	padding: .8125em 1.375em .6875em 1.375em;
	border-radius: 2em;
	text-transform: uppercase;
	font-size: .875em;
	letter-spacing: .0625em; 
	background: #006cc7;
	color: #fff;
}


::-moz-selection {
    background: #7ac2ff;
    text-shadow: none;
}

::selection {
    background: #7ac2ff;
    text-shadow: none;
}

img {
    vertical-align: middle;
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

textarea {
    resize: vertical;
}


/* ==========================================================================
   Loading Styles for Parallax Scroll
   ========================================================================== */
   
html {
	height: 100%;
	min-height: 100%;
}
body {
	height: 100%;
	min-height: 100%;
}
.loading {
	background: url('../img/ico_loading.gif') no-repeat center 43%;
}
section {
	opacity: 0;
}
.loaded section, .no-js section {
	opacity: 1;
	-webkit-transition: opacity 300ms ease-out;
	-moz-transition: opacity 300ms ease-out;
	transition: opacity 300ms ease-out;
}
main {
	overflow-x: hidden;
}
#preload {
	width: 1px;
	height: 1px;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
}








/* ==========================================================================
   NAV STYLES
   ========================================================================== */

#mobileheader {
	display: none;
}

header {
	position: absolute;
	z-index: 10;
	width: 100%;
}

.headerContainer {
	position: relative;
  width: 92%;
  height: 4.75em;
  margin: 0 auto;
  padding: 1.5em 4% 0 4%;
	font-family: 'Gotham SSm A', 'Gotham SSm B', 'Gotham', Arial, sans-serif; 
	font-weight: 400;
}

.logo {
	float: left;
}

.logo a:hover {
	opacity: .8;
}
	
.desktopNav {
	float: right;
	font-size: .875em;
	text-transform: uppercase;
	letter-spacing: .0625em; 
	margin: 1em 0 0 0;
}

.desktopNav a {
	float: left;
	color: rgba(255,255,255,.95);
	padding: 0;
	margin: 2px 2.5em 0 0;
	border-bottom: 3px solid rgba(255,255,255,0);
	padding-top: .125em;
}

@media screen and (max-width: 1140px) {
	.desktopNav a {
		margin: 2px 2em 0 0;
	}
}


.desktopNav a:hover {
	color: rgba(255,255,255,1);
	border-bottom: 3px solid rgba(255,255,255,1);
}

.desktopNav a.active {
	color: rgba(255,255,255,1);
	border-bottom: 3px solid rgba(255,255,255,.25);
}

.contactButton {
	float: right;
	margin: .5625em 0 0 0;
}

.contactButton a {
	color: rgba(255,255,255,.95);
	display: block;
	padding: .5625em 1.375em .4375em 1.375em;
	border: 2px solid rgba(255,255,255,.8);
	border-radius: 2em;
	text-transform: uppercase;
	font-size: .875em;
	letter-spacing: .0625em; 

}

.contactButton a:hover {
	color: rgba(255,255,255,1);
	background: #fff;
	color: #111;
	border: 2px solid rgba(255,255,255,1);
}


.mobileNav {
	display: none;
}


@media screen and (max-width: 1024px) {
	
	.desktopNav, .contactButton {
		display: none;
	}
	.mobileNav {
		display: inline;
	}	
}



@media screen and (max-width: 1024px) {

/* ==========================================================================
   TOUCH NAV
   ========================================================================== */


	.mobileNav {
		float: right;
		text-align: right;
	}

	
	.mobileNav #trigger-overlay {
		padding: .125em 0 0 0;
		font-size: 2em;
	}
	
	.icon-menu {
	  color: #fff;
	}
	
	.mobileNav #trigger-overlay:hover p, .mobileNav #trigger-overlay:hover p .icon-menu {
	  color: #111;
	  cursor: pointer;
	  -o-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	-ms-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	-moz-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	-webkit-transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out;
	transition: color .2s ease-in-out, border .2s ease-in-out, background .2s ease-in-out, opacity .2s ease-in-out;
	}

}





/* ==========================================================================
   FULLSCREEN MENU
   ========================================================================== */



/* Overlay style */


.overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: rgba(0,50,111,.98);
	z-index: 11;
}

/* Overlay closing cross */
.overlay .overlay-close {
	width: 80px;
	height: 80px;
	position: absolute;
	right: 20px;
	top: 20px;
	overflow: hidden;
	border: none;
	background: url(../img/cross.png) no-repeat center center;
	text-indent: 200%;
	color: transparent;
	outline: none;
	z-index: 100;
}

/* Menu style */
.overlay nav {
	position: absolute;
	text-align: left;
	left: 0;
	top: 50%;
	height: 60%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.overlay ul {
	list-style: none;
	padding: 0 0 0 10%;
	margin: 0 auto;
	display: inline-block;
	height: 100%;
	position: relative;
}

.overlay ul li {
	display: block;
	height: 20%;
	height: calc(100% / 6);
	min-height: 54px;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.overlay ul li a {
	font-family: 'Mercury SSm A', 'Mercury SSm B', Georgia, serif; 
	font-size: 2.75em;
	font-weight: 300;
	display: block;
	color: #fff;
	-webkit-transition: color 0.3s;
	transition: color 0.3s;
}

.overlay ul li a .icon-lock {
	margin-left: .5em;
	font-size: 90%;
}



.overlay ul li a:hover,
.overlay ul li a:focus {
	color: #000;
	-webkit-transition: color 0.3s;
	transition: color 0.3s;
}

/* Effects */
.overlay-scale {
	visibility: hidden;
	opacity: 0;
	-webkit-transform: scale(0.9);
	transform: scale(0.9);
	-webkit-transition: -webkit-transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
	transition: transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
}

.overlay-scale.open {
	visibility: visible;
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1);	
	-webkit-transition: -webkit-transform 0.4s, opacity 0.4s;
	transition: transform 0.4s, opacity 0.4s;
}



/* ==========================================================================
   PHOTO
   ========================================================================== */


.philosophy {
  background: url("../img/philosophy.jpg") center center repeat;
}


.about {
  background: url("../img/about.jpg") center center repeat;
}

.contactBg {
  background: url("../img/contact.jpg") center center repeat;
}



.bloomIcon {
	text-align: center;
	position: absolute;
	z-index: 1000;
	margin: 0 auto;
	margin-top: -4em;
	width: 100%;
}

.hero h1 {
	font-weight: 500; 
	font-size: 4em;
	margin: 100px 0 0 0;
	color: #fff;
	width: 100%;
	text-transform: uppercase;
	border-top: 1px solid rgba(255,255,255,.5);
	border-bottom: 1px solid rgba(255,255,255,.5);
}

.hero h2 {
	font-weight: 500; 
	font-size: 1em;
	color: #fff;
	margin: 0px;
	padding-top: 50px; 
}

.hero h3 {
	font-weight: 500; 
	font-style: italic;
	font-size: 1.75em;
	color: #fff;
	margin: 0px;
	padding-top: 50px; 
}

.icon-phone, .icon-envelop, .icon-location {
	color: #bf1e2e
}


.contentWidth {
	position: relative;
  width: 80%;
  padding: 3em 10% 0 10%;
  max-width: 940px;
  margin: 0 auto;
}


p.intro {
	width: 100%;
	color: #fff;
	font-size: 1.375em;
	line-height: 1.625;
	margin: 0em 0 .875em 0;
	text-align: center;
}

p.intro a {
	color: #fff;
}

p.intro span {
	margin-right: .25em;
	color: #bf1e2e;
}


@media screen and (max-width: 640px) {
	
.hero h1 {
padding: 20px 0;
}


.hero h1 img {
	max-width: 200px;
}

html {
	font-size: 84%;
}

	
}



/* ==========================================================================
   FOOTER
   ========================================================================== */

.footer .show768 {
	display: none;
}


.footer {
  width: 100%;
	float: left;
	width: 84%;
	padding: 4em 8% 3em 8%;
	margin: 6em 0 0;
	background: #111;
	text-align: center;
	font-family: 'Gotham SSm A', 'Gotham SSm B', 'Gotham', Arial, sans-serif; 
	text-transform: uppercase;
	font-size: .8125em;
	letter-spacing: .0875em;
	font-weight: 400;
	color: #ccc;
	line-height: 2.25;
}

.footer p, .footer p a {
	color: #ccc;
}

.footer .contact {
	width: 100%;
	float: left;
	margin-bottom: 1em;
}

.footer .nickmerrilldesign {
	width: 100%;
	float: left;
	margin-top: 1.5em;
}


.footer .nickmerrilldesign p a {
	font-family: 'Mercury SSm A', 'Mercury SSm B', Georgia, serif; 
	text-transform: none;
	font-size: 1.125em;
	letter-spacing: 0;
	font-weight: 400;
	font-style: italic;
	color: #777;
	border-top: 1px solid #333;
	padding-top: 2em;
	font-size: .9375em;
}

.footer a:hover {
	color: #fff;
}

.footer .nickmerrilldesign  a:hover{
	color: #9c9c9c;
}
/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */

.clearfix:before,
.clearfix:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.clearfix:after {
    clear: both;
}

/*
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */

.clearfix {
    *zoom: 1;
}

p span.italic {
  font-style: italic;
  color: #111 !important;
  margin: 0;
}










	
	
