/* Basic Structure/Typography */

#alert {
	background: #C23A2C;
	margin: 0.9em 0;
	padding: 0.9em 1.8em;
	color: #FFF;
}

#alert a {
	color: #FFF;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	margin: 0.45em 0;
	width: 100%;
}

th, td {
	border: 1px solid #FFF;
	padding: 0.45em;
	text-align: left;
}

th {
	background: #FFF;
	color: #FFF;
}

/* Forms */

label, input, textarea, select, button, .btn, .boxLink a, .validation-error {
	display: block;
	font-family: Roboto, sans-serif;
	font-size: 16px;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.8em;
	position: relative;
	text-align: left;
	text-decoration: none;
	vertical-align: top;
	z-index: 2;
}

label {
	padding: 0.45em 0;
}

label .optional {
	font-size: 0.75em;
	font-style: italic;
	padding-left: 0.45em;
}

input, textarea, select, button, .btn, .boxLink a {
	background: #FFF;
	border: 1px solid #006f98;
	border-radius: 0.2em;
	box-shadow: none;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	-ms-box-sizing: content-box;
	box-sizing: content-box;
	color: #333;
	margin: 1px;
	outline: none;
	padding: 0.45em 0.675em;
	width: 75%;
	width: calc(100% - 1.35em - 4px);
}

input, select {
	line-height: normal;/* IE and FX don't like line height */
	height: 1.8em;/* height works tho */
}

select {
	padding: 0.45em 0.45em 0.45em 0.675em;
	width: calc(100% - 1.125em);
}

option {
	padding: 0 0.675em;
}

input:focus, textarea:focus, select:focus {
	box-shadow: 0 0 0 0.4em rgba(255,255,255,0.4);
	border: 2px solid #b000b0;
	margin: 0;
	outline: none;
}

input[disabled] {
	background: #CCC;
	font-style: italic;
}

textarea {
	height: 14.4em;
	max-width: 75%;
	max-width: calc(100% - 1.35em - 2px);
	min-height: 14.4em;
	min-width: 75%;
	min-width: calc(100% - 1.35em - 2px);
	overflow: auto;
}

button, .btn, .boxLink a {
	background: #B000B0;
	border: none;
	border-radius: 0.2em;
	box-shadow: none;
	color: #FFF;
	cursor: pointer;
	display: inline-block;
	font-weight: 500;
	padding: 0.45em 2.7em;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	width: auto;
}

button:focus, .btn:focus, .boxLink a:focus {
	box-shadow: none;
}

button:hover, .btn:hover, .boxLink a:hover {
	background-color: #c033c0;
	color: #FFF;
}

button:active, .btn:active, .boxLink a:active {
	background-color: #8d008d;
	color: #FFF;
}

form, form p, form div {
	position: relative;
}

.hint + label {
	cursor: text;
	left: 0;
	overflow: hidden;
	padding: 0.45em 0.675em;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 3;
}

select.slim {
	width: auto;
}

p .hint + label {
	bottom: 0.45em;
	top: 0.45em;
}

.hint:focus + label, .filled + label {
	opacity: 0;
	z-index: 1;
}

.NewPassword {
	display: inline-block;
	vertical-align: middle;
	width: 70%;
	width: calc(100% - 94px);
	width: calc(100% - 1.35em - 84px);
}

.NewPassword + button, .NewPassword + button + button {
	border-radius: 0;
	padding: 0.45em 0;
	padding-top: calc(0.45em - 1px);
	vertical-align: middle;
	width: 40px;
}

.NewPassword + button + button {
	border-left: none;
	border-radius: 0 3px 3px 0;
}

.validation-error {
	background: #f3d8d5;
	color: #c23a2c;
	display: block;
	padding: 0.45em 0.675em;
	position: relative;
	top: -2px;
	z-index: 1;
}

.file, .file label {
	display: block;
	position: relative;
}

.file label {
	bottom: 0;
	left: 0;
	padding: 0;
	right: 0;
	text-align: left;
	top: 0;
	position: absolute;
	z-index: 2;
}

.file input, .file input:focus, .file input:hover {
	background: transparent;
	border: 1px solid transparent;
	box-shadow: none;
	margin: 0;
	position: relative;
	width: auto;
	z-index: 1;
}

.file .btn {
	border: 1px solid transparent;
	border-radius: 0.2em 0 0 0.2em;
	display: inline-block;
	padding: 0.45em 0;
	text-align: center;
	vertical-align: bottom;
	width: 33%;
	width: calc(0% + 8em);
}

.file .label {
	background: #FFF;
	border: 1px solid #B000B0;
	border-radius: 0 0.2em 0.2em 0;
	color: #333;
	display: inline-block;
	height: 1.8em;
	margin-left: -1px;
	overflow: hidden;
	padding: 0.45em 0.675em;
	position: relative;
	vertical-align: bottom;
	width: 60%;
	width: calc(100% - 9.3em - 8px);
}

.file .label:after {
	background: #FFF;
	background: linear-gradient(90deg, transparent 0, #FFF 0.9em, #FFF 100%);
	bottom: 0;
	content: '';
	position: absolute;
	right: 0;
	text-align: center;
	top: 0;
	width: 3.6em;
}

.file .label.uploading:after {
	background: url(/media/system/timer.svg) no-repeat 1.575em 0.675em/1.35em 1.35em #FFF;
	background: url(/media/system/timer.svg) no-repeat 1.575em 0.675em/1.35em 1.35em, linear-gradient(90deg, transparent 0, #FFF 0.9em, #FFF 100%);
}

.file .label.uploaded:after {
	background: url(/media/cms-skin/tick.png) no-repeat 1.575em 0.675em/1.35em 1.35em #FFF;
	background: url(/media/cms-skin/tick.png) no-repeat 1.575em 0.675em/1.35em 1.35em, linear-gradient(90deg, transparent 0, #FFF 0.9em, #FFF 100%);
}

.file .label.error:after {
	background: url(/media/cms-skin/cross.png) no-repeat 1.575em 0.675em/1.35em 1.35em #FFF;
	background: url(/media/cms-skin/cross.png) no-repeat 1.575em 0.675em/1.35em 1.35em, linear-gradient(90deg, transparent 0, #FFF 0.9em, #FFF 100%);
}

.chk, .chk + label {
	cursor: pointer;
	display: inline-block;
	vertical-align: top;
}

.chk, .chk:focus {
	height: 2.7em;
	margin: 0 0.675em 0 0;
	width: 2.7em;
}

.chk + label {
	width: 80%;
	width: calc(100% - 3.675em);
}

/* Data Nav */

.dataNav {
	padding: 0.45em 0;
	text-align: left;
}

.dataNav a {
	border: 1px solid;
	color: #FFF;
	font-size: 16px;
	line-height: 1.8em;
	display: inline-block;
	padding: 0.225em 0.9em;
	text-decoration: none;
}

.dataNav a + a {
	border-left: none;
}

.dataNav a:hover {
	background: rgba(255,255,255,0.2);
	color: #FFF;
}

.dataNav a:active {
	background: rgba(0,0,0,0.2);
	color: #FFF;
}

.dataNav .selected, .dataNav .selected:hover {
	background: #FFF;
	border-color: #FFF;
	color: #02A1ED;
	cursor: default;
	text-decoration: none;
}

/* Footer */

footer .stage {
	height: 41em;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

footer .persp {
	left: 0;
	position: absolute;
	right: 0;
	z-index: 20;
}

footer .cloud-1 {
	top: 1.5em;
	transform: scale(1.1) translateX(calc(40px * (1 - var(--scroll-vis))));
	z-index: 1;
}

footer .mountains {
	top: 0;
	transform: translateY(calc(100px * (1 - var(--scroll-vis))));
	z-index: 2;
}

footer .cloud-2 {
	top: 2em;
	transform: scale(1.1) translateX(calc(-80px * (1 - var(--scroll-vis)))) translateY(calc(150px * (1 - var(--scroll-vis))));
	z-index: 3;
}

footer .bg-tents {
	left: 17em;
	right: 20em;
	top: 9.8em;
	transform: translateY(calc(250px * (1 - var(--scroll-vis))));
	z-index: 4;
}

footer .bg-main {
	bottom: 0;
	transform: translateY(calc(450px * (1 - var(--scroll-vis))));
	z-index: 5;
}

footer .front-trees {
	bottom: 0;
	transform: translateY(calc(650px * (1 - var(--scroll-vis))));
	z-index: 6;
}

footer .actual-content {
	bottom: 5.85em;
	color: #004C5A;
	padding: 0 10.8em;
	transform: translateY(calc(850px * (1 - var(--scroll-vis))));
	z-index: 7;
}

footer .actual-content a {
	color: #004C5A;
}

footer .actual-content a:hover {
	color: #33707b;
}

footer .actual-content a:active {
	color: #003d48;
}

footer .title {
	font-size: 1rem;
	font-weight: 400;
	text-transform: uppercase;
}

footer .customer-service, footer .location, footer .newsletter {
	float: left;
	margin: 0 6% 0 0;
}

footer .customer-service, footer .location {
	font-size: 1.3rem;
	line-height: 1.6em;
}

footer .newsletter {
	color: #000;
}

footer .newsletter .title {
	font-weight: 700;
	text-transform: none;
}

footer input {
	background: none;
	border-color: #000;
	display: inline-block;
	width: 13.5em;
}

footer .hint + label {
	right: auto;
}

footer button {
	background: #222;
	color: #FFF;
	margin-left: 0.45em;
	padding: 0.45em 1.35em;
}

footer button:hover {
	background: #555;
	color: #FFF;
}

footer button:active {
	background: #000;
	color: #FFF;
}

footer .social-media {
	background: #7F8C11;
	bottom: 0;
	z-index: 2;
}

/* View As Guest button */

.viewguest, .viewguest:hover, .viewguest:active {
	background: #354961;
	border-left: 0.45em solid #FFF;
	bottom: 0.9em;
	box-shadow: 0 5px 10px rgba(0,0,0,0.4);
	color: #FFF;
	display: inline-block;
	font-family: "Courier New", Courier, serif;
	font-size: 16px;
	font-weight: 400;
	padding: 0.9em 1.8em;
	position: fixed;
	right: 0;
	text-decoration: none;
	text-transform: none;
	z-index: 2000;
}

.viewguest:hover {
	background-image: linear-gradient(-45deg, rgba(255,255,255,0.2), rgba(255,255,255,0), rgba(255,255,255,0));
}

.viewguest:active {
	background-image: linear-gradient(-45deg, rgba(0,0,0,0.2), rgba(0,0,0,0), rgba(0,0,0,0));
}

@media (max-width: 1000px) {
	
	footer .stage {
		height: 20.9767em;
	}

	footer .actual-content {
		display: none;
	}
	
	footer .persp {
		transform: none;
	}

	footer .bg-tents {
		left: 18.7%;
		right: 22%;
		top: 23.9024%;
	}

}

@media (max-width: 750px) {

	footer .stage {
		height: 15.0843em;
	}

}

@media (max-width: 500px) {

	footer .stage {
		height: 10.1348em;
	}

}
