body {
	
	background-size: cover;
	box-sizing: border-box;
	overflow-x: hidden;
	font-family: 'Open Sans';
}

p {

}

#white-top {
	height: 45vh;
	/*width: 300vw;*/
	position: absolute;
	top: -80px;
	left: -5px;
	animation-name: smallbob;
	animation-duration: 2.5s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-fill-mode: forwards;
	transition-property: top, right;
	transition-duration: 2s, .1s;
	z-index: 1000;
}


#top-logo {
	height: 50px;
	position: fixed;
	top: 25px;
	left: 50%;
	transform: translateX(-50%);
}

#wave-text {
	position: fixed;
	width: 70%;
	top: 9%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1001;
	color: #287BDC;
	font-size: 20px;
	text-align: center;
	transition-duration: .4s;
	transition-delay: 1s;
	font-weight: 700;
}

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

	#white-top {
		display: none;
		height: 340px;
		/*width: 100vw;*/
		top: -50px;
		right: 0px;
		animation-name: smallbob;
		animation-duration: 2.5s;
		animation-timing-function: ease-in-out;
		animation-iteration-count: infinite;
		animation-fill-mode: forwards;
		transition-property: top;
		transition-duration: 2s;
		z-index: 1000;
	}

	#top-logo {
		height: 50px;
		position: fixed;
		top: 25px;
		left: 50%;
		transform: translateX(-50%);
	}

	#wave-text {
		top: 70px;
	}

	.bigtext {
		font-size: 15px !important;
		margin: 100px auto;
		padding: 20px;
	}
	input.button {
		width: 89%;
	}

	.fl-order-1 {
		order:1;
	}
	.fl-order-2 {
		order:2;
	}
	.fl-order-3 {
		order:3;
	}
}


@keyframes smallbob {
	0% {
		transform: translateY(-6px);
	}
	50% {
		transform: translateY(-3px);
	}
	100% {
		transform: translateY(-6px);
	}
}

@keyframes bigbob {
	0% {
		transform: translateY(-15px);
	}
	50% {
		transform: translateY(0px);
	}
	100% {
		transform: translateY(-15px);
	}
}

@keyframes bigbobcentered {
	0% {
		transform: translate(-50%,-8px);
	}
	50% {
		transform: translate(-50%,-4px);
	}
	100% {
		transform: translate(-50%,-8px);
	}
}

@keyframes massivebob {
	0% {
		transform: translateY(-10px);
	}
	50% {
		transform: translateY(30px);
	}
	100% {
		transform: translateY(-10px);
	}
}


@keyframes massivebobcentered {
	0% {
		transform: translate(-50%,-30px);
	}
	50% {
		transform: translate(-50%,20px);
	}
	100% {
		transform: translate(-50%,-30px);
	}
}



#main {
	padding-top: 100px;
	padding-bottom: 0px;
	width: 100vw;
	background: url('../images/damsupersmall.png');
	background-repeat: no-repeat;
	background-size: cover;
}

.hero {
	position: relative;
	height: 100vh;
	width: 100vw;
	display: flex;
	justify-content: center;
	align-items: center;
}

.hero .center-div{
	margin-top: 50%;
	text-align: center;
	width: 90%;
}

.hero .center-div img{
	width: 70%;
}

.hero .scroll {

	position: fixed;
	bottom: 5%;
	height: 50px;
	left: 90%;
	animation-name: massivebobcentered;
	animation-duration: 1.5s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-fill-mode: forwards;
}


#main p {
	color: white;
	font-size: 20px;
	text-align: center;
	width: 100%;
	padding: 30px 12.5%;
	font-weight: 600;
}

.hidden-mobile {
	display: none;
}

.mobile-only {
	display: block;
}

#content {
	padding-top: 0px;
	text-align: center;
	position: relative;
	padding-bottom: 200px;
}


#content .wibbly {
	width: 90%;
	margin: 0px;
}



#content .floater.mobile-only {
	position: relative;
	width: 70%;
	display: block;
	margin: 100px auto 20px auto;
}



.bobbing {
	animation-name: bigbob;
	animation-duration: 2.5s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-fill-mode: forwards;
}


.dam {
	width: 101%;
	position: absolute;
	bottom: 0;
	left: -.5%;
	z-index: 1050;
}

.mobile-house {
	width: 40% !important;
}



#player {
	position: relative;
	display: block;
	width: 90vw;
	height: calc(9 * 90vw / 16);
	margin-left: 5vw;
	margin-top: 100px;
	z-index: 1000;
}


@media (min-width: 700px) {
	#main p {
		font-size: 25px;
		padding: 30px 20%;
		/*margin-top: 200px;*/
	}

	.hero .center-div{
		margin-top: 0;
	}
	#wave-text {
		font-size: 30px;
	}
	.hero .scroll {
		display: inline;
		left: 95%;
	}

	.hidden-mobile {
		display: block;
	}

	.mobile-only {
		display: none !important;
	}


	#content {
		padding-top: 150px;
		padding-bottom: 400px;
		text-align: center;
		position: relative;
	}

	#content .wibbly {
		width: 60%;
		margin: 200px auto 0px auto;

	}

	.section {
		margin-bottom: 0px;
	}

	#content .floater {
		position: absolute;
		right: 3%;
		top: 420px;
		width: 10%;
	}

	#content .floater.sub  {
		top: auto;
		bottom: 620px ;
		width: 40% ;
	}

	#content .floater.swim  {
		right: auto;
		left: -3%;
		top: 25% ;
		width: 30% ;
	}

	#content .floater.house  {
		top: 350px;
	}
}

@media  (min-width: 1024px) {
	#main p {
		font-size: 30px;
		padding: 30px 25%;
		/*margin-top: 200px;*/
	}
	#wave-text {
		font-size: 40px;
	}

	#content {
		padding-bottom: 1000px;
	}

	#content .floater.sub  {
		top: auto;
		bottom: 1200px ;
		width: 20% ;
	}

	#content .wibbly {
		margin-bottom: 200px;
	}

	@media (max-height: 800px) {
		.hero .center-div{
			padding-top: 100px;
		}


		#wave-text {
			font-size: 30px !important;
		}
		#content {
			padding-bottom: 600px !important;
		}

		.bigtext {
			font-size: 24px !important;
		}
	}

	#player {
		position: relative;
		display: block;
		width: 70vw;
		height: calc(9 * 70vw / 16);
		margin-left: 15vw;
		z-index: 1000;
		margin-top: 0px;
	}

}

.header-bar {
	height: 100px;
	background: white;
	width: 100vw;
	position: relative;
	z-index: 1020;
}

.header-bar img {
	height: 5vh;
	position: absolute;
	top: 25px;
	left: 50%;
	transform: translateX(-50%);
}

#white {
	position: fixed;
	display: none;
	top: 0px;
	width: 100vw;
	left: 0px;
	background: white;
	height: 100px;
	z-index: 1021;
}

.info {
	padding: 1em;
	width: 100vw;
	text-align: center;
	z-index: 1020;
}

.info p {
	margin: 20px auto;
	color: black;
	font-size: 25px;
	/*max-width: 700px;*/
}

.info--white h3 {
	color: #005BBB;
	font-size: 40px;
	font-weight: 700;
}

.info--blue {
	/*background: #005BBB;*/
	color: white;
}

.info--blue p {
	color: white;
	margin: 40px auto 20px auto;
}

.info--blue h2 {
	font-weight: 700;
	color: white;
	margin: 60px auto 60px auto;
}

.info--blue .wibbly {
	width: 100%;
}

.CTA {
	text-align: center;
	padding: 3em;
	background: url('../images/KeyboardBG.png');
	background-size: cover;
}

.CTA h4 {
	margin-top: 30px;
	margin-bottom: -20px;
	font-size: 30px;
}

.buttons {
	margin: 40px auto;

}

.buttons-flex {
	margin-top: 80px;
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-end;
	justify-content: center;
}


@media (max-width: 600px) {
	.buttons-flex {
		flex-wrap: wrap;
		margin-top: 40px;
	}

	.buttons-flex .button {
		width: 100%;
	}
	.buttons-flex input {
		margin-left: 0px;
	}
	.buttons-flex form {
		width: 90%;
	}
	.buttons-flex #cons-email {
		width: 100% !important;
	}
}

.button {
	display: block;
	background: #58A718;
	color: white;
	padding: 1em 2em;
	border-radius: 50px;
	text-decoration: none;
	margin: 20px 20px;
	transition-duration: .3s;
	white-space: nowrap;
	font-weight: 800;
	border: 0px solid transparent;
}

.button:hover {
	background: #68af2f;
	color: white;
	padding: 1em 2em;
	border-radius: 50px;
	text-decoration: none;
}

.button--blue {
	background: #005BBB;
}

.button--blue:hover {
	background: #0362C5;
}

.columns {
	width: 100%;
	display: flex;
	justify-content: space-between;
	padding: 3% 15%;
	flex-wrap: wrap;
}

.column {
	width: 100%;
	text-align: center;
}

.column img {
	width: 70%;
}

.column p {
	font-size: 16px;
}

.footer {
	flex-wrap: wrap;
	padding: 3em;
	display: flex;
	justify-content: center;
	background: #005BBB;
}

.footer-column {
	width: 100%;
	margin: 30px 10px;
	color: white;
	text-align: center;
}

.footer-column .logo{
	height: 80px;
	margin-bottom: 20px;
}

.footer-column h5 {
	margin-top: 30px;
	padding-right: 10px;
	line-height: 1.5;
}

.extra-footer {
	background: #0D4075;
	text-align: center;
	color: white;
	padding: 1em;
	font-size: 14px;
}

.extra-footer p {
	margin: 0px;
}


@media (min-width: 700px) {
	.button {
		display: inline-block;
	}

	.columns {
		flex-wrap: nowrap;
	}

	.column {
		width: 20%;
	}
	.info--blue .wibbly {
		width: 50%;
	}



}

@media  (min-width: 1024px) {
	#wave-text {
		font-size: 40px;
	}

	.footer {
		padding: 3em 5em 5em 5em;
		display: flex;
		justify-content: center;
		background: #005BBB;
	}

	.footer-column {
		color: white;
		width: 15%;
		margin: 0 80px;
		text-align: left;
	}

	.footer-column h4 {
		font-weight: 900;
	}

	.footer-column p{
		margin: 20px auto 0px auto;
	}



	.footer-column .button{
		text-align: center;
		display: inline-block;
		margin:0px;
		margin-top: 30px;
		width: 100%;

	}

	.social-icons {
		text-align: left;
		width: auto;
		margin-left: -5px !important;
	}

}

.social	{
	transform: translateY(-2px);
	width: 20px;
	padding-right: 5px;
}

.social + p {
	display: inline;
	color: white;
	margin: 5px 0px;
	font-size: 20px;
}


.fade {
	opacity: 0;
	transform: translate(0, 30px); 
	transition: all 1.5s;
	transition-delay: .5s;
}

.fade.visible {
	opacity: 1;
	transform: translate(0, 0px); 
}

.footer-column h4 {
	font-weight: 700;
}

.social-icons {
	text-align: left;
	width: 200px;
	margin: 0 auto;
}

.social-icons a{
	line-height: 1.7;
}

#video {
	/*display: none;*/
	z-index: 1040;
	width: 100vw;
	height: 100vh;
	background-color: rgba(0,0,0,.8);
	position: fixed;
	top: 0px;
	left: 0px;
}

#modal {
	position: relative;
	height: calc(9 * 80vw / 16 + 3em);
	width: 80vw;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

#modal iframe {
	position: absolute;
	padding: 3em 1em 1em 1em;
	
	width: 100%;
	height: 100%;
	background: white;
	border-radius: 10px;
}

#video:target {
	display: block;
}

#modal-closer img{
	position: absolute;
	top: 15px;
	right: 20px;
	width: 20px;

}
.header {
	background: white;
	height: 100px;
	width: 100vw;
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 1091;
}

.absolute-scroll {
	display: block;
	height: 50px;
	width: 50px;
	margin: 50px auto 0px auto;
	animation-name: massivebob;
	animation-duration: 1.5s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-fill-mode: forwards;
}

@keyframes flash {
	0% {
		box-shadow: 0px 2px 30px 1px white;
	}
	50% {
		box-shadow: 0px 2px 30px 3px white;
	}
	100% {
		box-shadow: 0px 2px 30px 1px white;
	}
}

.donate {
	box-shadow: 0px 2px 30px 1px white;
	/*animation-name: flash;
		animation-duration: 3s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
	animation-fill-mode: forwards;*/
}