/************************************************

************************************************/

*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

html, body {
	width: 100%; 
	height: 100%; 
	margin: 0; 
	padding: 0;
}

html {
	font-family: sans-serif; 
	font-size: 100%; 
	color: #222;

	/* 
	to prevent font-size being adjusted 
	when mobile device is in landscape mode
	*/
	-webkit-text-size-adjust: 100%; 
	-mos-text-size-adjust: 100%; 
	-ms-text-size-adjust: 100%; 
}

body {
	background-color: #EEE;
}

a, a:link, a:visited {
	font-weight: 700;
	color: #FF7F50;
	text-decoration: none;
}

a:hover, a:active { color: #222; }

a img { border: 0; }

h1, h2, h3, h4, h5 {
	margin: 0;
	padding: 0;
	text-transform: uppercase;
}

h1 { font-size: 200%; }
h2 { font-size: 175%; }
h3 { font-size: 150%; }
h4 { font-size: 125%; }
h5 { font-size: 100%; }

sup { font-size: 50%; }

ul {
	padding: 0;
	margin: 0;
	list-style-type: none;
}

/************************************************

************************************************/

.header {
	padding: 0;
	margin: 0;

	top: 0; 
	left: 0; 
	right:0;  
	z-index: 1000;
}

label .header-bar {
	cursor: pointer;
	user-select: none;
	-moz-user-select: none;
	-webkit-user-select: none;
}

.header-bar {
	position: relative;

	width: 100%;

	padding: 0;
	margin: 0;

	background-color: #FFF;

	border-bottom: 1px solid #DDD;

	overflow: hidden;
}

.header-logo {
	float: left;
	height: 50px;
	padding-left: 15px;
	font-weight: 700;
	line-height: 50px; /* middle */
}

.logo-y {
	font-size: 80%;
	color: #FF7F50;
}

.header-nav-toggle { /* IE Fix; can't just hide it with display:none */
	position: absolute; 
	width: 1px; 
	height: 1px; 
	padding: 0; 
	margin: -1px; 
	border: 0; 
	clip: rect(0, 0, 0, 0); 
	
}

.header-nav-button {
	position: relative; 
	float: right;
	width: 50px;
	height: 50px;
	cursor: pointer;
}

.header-nav-button-line-top, 
.header-nav-button-line-middle,
.header-nav-button-line-bottom {
	position: absolute;
	left: 12px;
	width: 26px;
	height: 1px;
	background-color: #222;

	-o-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.header-nav-button-line-top { top: 16px; }
.header-nav-button-line-middle { top: 24px; }
.header-nav-button-line-bottom { top: 32px; }

.header-nav-toggle:checked + .header-nav-button .header-nav-button-line-top {
	-o-transform: translateY(8px) rotate(45deg);
	-ms-transform: translateY(8px) rotate(45deg);
	-moz-transform: translateY(8px) rotate(45deg);
	-webkit-transform: translateY(8px) rotate(45deg);
	transform: translateY(8px) rotate(45deg);
}
.header-nav-toggle:checked + .header-nav-button .header-nav-button-line-middle { opacity: 0; }
.header-nav-toggle:checked + .header-nav-button .header-nav-button-line-bottom {
	-o-transform: translateY(-8px) rotate(-45deg);
	-ms-transform: translateY(-8px) rotate(-45deg);
	-moz-transform: translateY(-8px) rotate(-45deg);
	-webkit-transform: translateY(-8px) rotate(-45deg);
	transform: translateY(-8px) rotate(-45deg);
}

.header-nav-list-container {
	float: left;
	width: 100%;
	height: 0px;
	overflow: hidden;

	background-color: #EEE;

	-o-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;

	zoom: 1; /* Trigger hasLayout */
}

.header-nav-toggle:checked + .header-nav-button + .header-nav-list-container { 
	height: 400px; 
	border-top: 1px solid #DDD; 
}

.header-nav-list-item, 
.header-nav-list-item a {
	display: block;
	height: 50px; 
	line-height: 50px;
	padding-left: 15px;
}

.header-nav-list-item a,
.header-nav-list-item a:link,
.header-nav-list-item a:visited { color: #222; }

.header-nav-list-item a:hover,
.header-nav-list-item a:active { color: #FF7F50; }

/************************************************

************************************************/

.section { position: relative; }
.section-first { padding-top: 50px; }

.section-header { 
	padding-top: 20px;
	text-align: center;
}

.section-subheader {
	text-align: center;
}

.inner-section {
	padding: 30px 0px;
	overflow: hidden;
	position: relative;
}

.inner-section-header {
	text-align: center;
}

/************************************************

************************************************/

.generic-list-wrapper { position: relative; }
.generic-list-280 {
	position: relative;
	padding: 0; 
	text-align: center;
	list-style-type: none; 
}
.generic-list-item {
	display: inline-block;
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */
	min-height: 150px;
	padding: 0px 5px;
	margin: 10px 10px;
	vertical-align: top;
}
.generic-list-280 .generic-list-item { width: 280px; }


/************************************************

************************************************/

.feature-list-wrapper { position: relative; }
.feature-list-120, 
.feature-list-180,
.feature-list-280,
.feature-list-320  {
	position: relative;
	padding: 0; 
	margin-top: 30px; 
	text-align: center;
	list-style-type: none; 
}
.feature-list-item {
	display: inline-block;
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */
	min-height: 150px;
	padding: 0px 5px;
	margin: 10px 10px;
	vertical-align: top;
}
.feature-list-item-icon-wrapper {
	width: 100px;
	height: 100px;
	margin: 0 auto;
	background-color: #FF7F50;
	border-radius: 50%;
}
.feature-list-item-icon {
	width: 70px;
	height: 70px;
	margin: 15px;
}
.feature-list-item-icon-no-bg {
	width: 100px;
	height: 100px;
	margin: 0px;
}
.feature-list-item-title,
.feature-list-item-title-underline {
	display: inline-block;
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */
	margin: 10px 0px; 
	font-weight: 700;
	text-align: center;
}
.feature-list-item-title-underline {
	padding-bottom: 5px;
	padding-left: 10px;
	padding-right: 10px;
	border-bottom: 3px solid #FF7F50; 
}

.bg-coral .feature-list-item-title-underline { border-bottom-color: #555; }

.feature-list-120 .feature-list-item { width: 120px; }
.feature-list-180 .feature-list-item { width: 180px; }
.feature-list-280 .feature-list-item { width: 280px; }

/************************************************

************************************************/

.gallery-container { 
	padding: 20px 5%;
	text-align: center; 
}

.gallery-header {
	display: inline-block;
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */
	margin: 10px 0px; 
	padding-bottom: 5px;
	padding-left: 10px;
	padding-right: 10px;
	font-weight: 700;
	text-align: center;
	border-bottom: 3px solid #FF7F50; 
}

.gallery-wrapper { 
	display: inline-block;
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */ 
	line-height: 0; /* Fix space between inline-block elements */
}

.gallery-thumbnail-box { 
	display: inline-block; 
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */
	width: 244px; 
	height: 244px; 
}

[class*="gallery-thumbnail-wrapper"] { margin: 2px; overflow: hidden; float: left; }
.gallery-thumbnail-wrapper-1-1 { height: 118px; width: 118px; }
.gallery-thumbnail-wrapper-1-2 { height: 118px; width: 240px; }
.gallery-thumbnail-wrapper-2-1 { height: 240px; width: 118px; }
.gallery-thumbnail-wrapper-2-2 { height: 240px; width: 240px; }

.gallery-thumbnail-wrapper-1-1 img.landscape { height: 118px; }
.gallery-thumbnail-wrapper-1-2 img.landscape { width: 240px; }
.gallery-thumbnail-wrapper-2-1 img.landscape { height: 240px; }
.gallery-thumbnail-wrapper-2-2 img.landscape { height: 240px; }

.gallery-thumbnail-wrapper-1-1 img.portrait { width: 118px; }
.gallery-thumbnail-wrapper-1-2 img.portrait { width: 240px; }
.gallery-thumbnail-wrapper-2-1 img.portrait { height: 240px; }
.gallery-thumbnail-wrapper-2-2 img.portrait { width: 240px; }

/*
.gallery-thumbnail-wrapper-1-1 img { min-width: 118px; min-height: 118px; }
.gallery-thumbnail-wrapper-1-2 img { min-width: 240px; min-height: 118px; }
.gallery-thumbnail-wrapper-2-1 img { min-width: 118px; min-height: 240px; }
.gallery-thumbnail-wrapper-2-2 img { min-width: 240px; min-height: 240px; }
*/

/************************************************

************************************************/

.contact { 
	line-height: 200%; 
	font-weight: 700; 
	text-align: center; 
}
.contact img { height: 25px; }

/************************************************

************************************************/

.map-container { 
	margin-top: 50px;
	margin-bottom: 20px;
	text-align: center; 
}
.map-inner-pic { 
	display: inline-block; 
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */ 
	margin: 5px 0px;
}
.map-inner-pic img { max-width: 100%; }
.map-inner-google { 
	display:inline-block; 
	*display: inline; zoom: 1; /* Fix IE:; display:inline-block */
	width: 100%; 
	max-width: 500px; 
	margin: 5px 0px;
}
.map-inner-google-wrapper { 
	position: relative; 
	width: 100%; 
	padding-top: 100%; 
	overflow: hidden;
}
.map-inner-google-wrapper iframe { 
	position: absolute; 
	top:0; 
	left: 0;
	right: 0; 
	bottom: 0; 
	width: 100%; 
	height: 100%; 
}

/************************************************

************************************************/

.footer { font-size: 50%; text-align: center; }

/************************************************

************************************************/

.sandwich {
	background-color: #FFF;
	color: #222;
}

.sandwich-container {
	height: 0px;
	overflow: hidden; 

	-o-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}

.sandwich.show .sandwich-container { 
	height: 350px;
	max-height: 100%; 
}

.sandwich-wrapper { padding: 30px; }

.sandwich-header {
	width: 100%;
	height: 50px;
	margin-bottom: 10px;
	border-collapse: collapse;
	border: 0;
}

.sandwich-header-title {

}

.sandwich-header-close-button {
	width: 30px;
	height: 30px;	
	cursor: pointer;
}

.sandwich-content {
	overflow: scroll;
	height: 240px;
}

/************************************************

************************************************/

.popup {
	position: fixed;
	top: -100%;
	width: 100%;
	height: 100%;
	overflow: hidden;

	color: #FFF;

	text-align: center;

	background-color: transparent; /* Fallback color */
	background-color: rgba(0, 0, 0, 0.9); 
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1, StartColorStr='#E6000000', EndColorStr='#E6000000')"; /* For IE8 */
	filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=1, StartColorStr='#E6000000', EndColorStr='#E6000000'); /* For IE6,IE7 */
	zoom: 1; /* Trigger hasLayout */

	z-index: 10000;	

	-o-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}

.popup.show { top: 0%; }

.popup-close-button {
	position: absolute;
	top: 0;
	right: 0;
	padding: 2%;
	cursor: pointer;

	background-color: transparent; /* Fallback color */
	background-color: rgba(0, 0, 0, 0.9); 
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1, StartColorStr='#E6000000', EndColorStr='#E6000000')"; /* For IE8 */
	filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=1, StartColorStr='#E6000000', EndColorStr='#E6000000'); /* For IE6,IE7 */
	zoom: 1; /* Trigger hasLayout */
	z-index: 10000;
}

.popup-content-img { 
	display: inline-block;
	*display: inline; zoom: 1;
	max-height: 100%;
	max-width: 100%;

	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;

	-webkit-transform-style: preserve-3d;
	-webkit-backface-visibility: hidden;
}

.popup-title {
	margin-top: 50px;
	margin-bottom: 10px;
}

.popup-content-div { 
	position: absolute;
	top: 100px;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 20px;
	overflow: auto;
	text-align: left;
}

.popup-content-div ul, .popup-content-ie-fix ul {
	list-style-type: disc;
	padding-inline-start: 40px;
}

.popup-content-ie-fix { 
	width: 100%; 
	height: 100%; 
	border:0;
	border-collapse: collapse; 
}

.popup-content-ie-fix td {
	width: 100%;
	height: 100%; 
	vertical-align: middle; 
	text-align: center;
}

@keyframes popup-loading { 
	0% { color: #FF7F50; }
	100% { color: #000; }
}

.popup-loading {
	height: 100%;
	text-align: center;
	color: #FF7F50;
	font-weight: 700;
	font-size: 200%;

	animation: popup-loading 2s linear 0s infinite alternate;
}

.popup-loading div {
	display: inline-block;
	*display: inline; zoom: 1;
	height: 100%;
	width: 0;
	vertical-align: middle;
}

/************************************************

************************************************/

.col-10 { width: 10%; }
.col-20 { width: 20%; }
.col-30 { width: 30%; }
.col-40 { width: 40%; }
.col-50 { width: 50%; }
.col-60 { width: 60%; }
.col-70 { width: 70%; }
.col-80 { width: 80%; }
.col-90 { width: 90%; }
.col-100 { width: 100%; }

/************************************************

************************************************/

/* BASE */
.line-white-80-left,
.line-white-50-center,
.line-white-80-center,
.line-coral-80-left,
.line-coral-50-center,
.line-coral-70-center,
.line-coral-80-center {
	height: 3px;
	margin-top: 5px;
	margin-bottom: 5px;
}

/* COLOR */
.line-white-80-left,
.line-white-50-center,
.line-white-80-center {
	background-color: #FFF;
}

.line-coral-80-left,
.line-coral-50-center,
.line-coral-70-center,
.line-coral-80-center {
	background-color: #FF7F50;
}

/* LEFT */
.line-coral-80-left,
.line-white-80-left { 
	margin-left: 0;
	margin-right: 0; 
}

/* CENTER */
.line-white-50-center,
.line-white-80-center,
.line-coral-50-center,
.line-coral-70-center,
.line-coral-80-center {
	margin-left: auto;
	margin-right: auto;
}

/* LENGTH */
.line-white-80-left, 
.line-coral-80-left, 
.line-white-80-center, 
.line-coral-80-center { 
	width: 80%; 
	max-width: 300px; 
}

.line-coral-70-center {
	width: 70%;
	max-width: 225px;
}

.line-white-50-center, 
.line-coral-50-center { 
	width: 50%; 
	max-width: 150px; 
}

/************************************************

************************************************/

.stick-left-right-bottom {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
}

/************************************************

************************************************/

a.link-red, 
a.link-red:link, 
a.link-red:visited { color: #F00; }

a.link-red:hover, 
a.link-red:active { color: #222; }

a.link-white, 
a.link-white:link, 
a.link-white:visited { color: #FFF; }

a.link-white:hover, 
a.link-white:active { color: #222; }

/************************************************

************************************************/

.font-white { color: #FFF; }
.font-coral { color: #FF7F50; }
.font-red { color: #F00; }

.font-bold { font-weight: 700; }

.font-underline-gray-strong { 
	border-bottom: 2px solid #222; 
	line-height: 200%; 
}

.font-big { font-size: 120%; }
.font-small { font-size: 80%; }

.font-space-5 { letter-spacing: 5px; }

.font-strike-through { text-decoration: line-through; }

/************************************************

************************************************/

.float-left { float: left; }
.float-right { float: right; }

/************************************************

************************************************/

.bg-orangered { background-color: #FF4500; }
.bg-coral { background-color: #FF7F50; }
.bg-white { background-color: #FFF; }
.bg-gray { background-color: #DDD; }
.bg-dark-gray { background-color: #555; }
.bg-light-gray { background-color: #EEE; }

.bg-white-70 { 
	background-color: transparent; /* Fallback color */
	background-color: rgba(255, 255, 255, 0.7); 
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1, StartColorStr='#B2FFFFFF', EndColorStr='#B2FFFFFF')"; /* For IE8 */
	filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=1, StartColorStr='#B2FFFFFF', EndColorStr='#B2FFFFFF'); /* For IE6,IE7 */
	zoom: 1; /* Trigger hasLayout */
}
.bg-white-80 { 
	background-color: transparent; /* Fallback color */
	background-color: rgba(255, 255, 255, 0.8); 
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1, StartColorStr='#CCFFFFFF', EndColorStr='#CCFFFFFF')"; /* For IE8 */
	filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=1, StartColorStr='#CCFFFFFF', EndColorStr='#CCFFFFFF'); /* For IE6,IE7 */
	zoom: 1; /* Trigger hasLayout */
}
.bg-white-85 { 
	background-color: transparent; /* Fallback color */
	background-color: rgba(255, 255, 255, 0.85); 
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1, StartColorStr='#D9FFFFFF', EndColorStr='#D9FFFFFF')"; /* For IE8 */
	filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=1, StartColorStr='#D9FFFFFF', EndColorStr='#D9FFFFFF'); /* For IE6,IE7 */
	zoom: 1; /* Trigger hasLayout */
}

.bg-light-gray-70 { 
	background-color: transparent; /* Fallback color */
	background-color: rgba(238, 238, 238, 0.70); 
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=1, StartColorStr='#B3EEEEEE', EndColorStr='#B3EEEEEE')"; /* For IE8 */
	filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=1, StartColorStr='#B3EEEEEE', EndColorStr='#B3EEEEEE'); /* For IE6,IE7 */
	zoom: 1; /* Trigger hasLayout */
}

/************************************************

************************************************/

.ie-bg-fix {
	position: absolute;
	top: 0; 
	left: 0; 
	right: 0; 
	bottom: 0; 
	margin: 0; 
	padding: 0;
	overflow: hidden;
	z-index: -10000;
}

.ie-bg-fix img { width: 100%; }

.ie-nav-button-fix {
	display: none;
	float: right;
	width: 50px;
	height: 50px;
}

.ie-nav-button-fix.show {
	display: block;
}

.hide { display: none; }

/************************************************

************************************************/

.blink {
  animation: blinker 1s linear infinite;
}

@keyframes blinker {  
  50% { opacity: 0; }
}

.photography-bg {
	background: url('img/photography.png');
}
