.static-page .top-content-block {
	padding: 2rem 1rem;
	background: #ff9016;
	text-align: center;
}

@media only screen and (min-width: 768px) {
	.static-page .top-content-block {
		padding-top: 4.5rem;
	}
}


.static-page .top-content-block h1 {
	font-size: 2.75rem;
	padding: 4rem 0 6rem 0;
	line-height: 3.5rem;
}


.static-page .top-content-block.has-p h1 {
	padding-bottom: 0;
}

.static-page .top-content-block.has-p .text-content {
	padding-bottom: 4rem;
}

.static-page .top-content-block h1 {
	font-weight: 500;
}

.static-page .top-content-block .page-block {
	max-width: 38rem;
}

.static-page.about .top-content-block,
.static-page.about header {
	background: #a05bbf;
}

.static-page.faq .top-content-block,
.static-page.faq header {
	background: #e81d75;
}

.static-page.contact .top-content-block,
.static-page.contact header {
	background: #00a0e0;
}

.static-page.about .top-content-block,
.static-page.faq .top-content-block {
	margin-bottom: 4rem;
}


.static-page.faq .header .a,
.static-page.faq .header .button,
.static-page.about .header .a,
.static-page.about .header .button {
	color: white;
}


.static-page.faq .header .a.active,
.static-page.about .header .a.active {
	border-bottom: solid 1px white;
}

.static-page.faq .header .a.active:hover,
.static-page.about .header .a.active:hover {
	border-bottom: solid 1px black;
}

.static-page.faq .header .a:hover,
.static-page.faq .header .button:hover {
	color: black;
	transition: color 0.25s, border-bottom 0.25s;
}


/*************** Contact Form **************/

.static-page.contact .form .label:after {
	content: "*";
	position: relative;
	top: -1px;
	left: 2px;
}

.static-page.contact .message {
	max-width: 37.5rem;
	margin: 2rem auto;
	padding: 0 0.5rem;
	text-align: center;
	font-size: 1.25rem;
}

.static-page.contact .form {
	display: flex;
	flex-wrap: wrap;
	max-width: 37.5rem;
	padding: 0 0 4rem 0;
}

.static-page.contact .form .formrow {
	width: 100%;
	box-sizing: border-box;
	align-items: flex-end;
	padding: 0 0.5rem;
}

.static-page.contact .form .formrow {
	margin-bottom: 2rem;
}

.static-page.contact .form .formrow.label-only {
	margin-bottom: 0;
}

.static-page.contact .form .formrow.w50 {
	width: 50%;
}

.static-page.contact .form input + .label {
	font-size: 0.875rem;
}

.static-page.contact .form input + .label:after {
	content: none;
}

.static-page.contact .form input[type="text"],
.static-page.contact .form textarea {
	color: black;
	resize: none;
	width: 100%;
	padding: 0.75rem;
	margin: 0.375rem 0 0.25rem;
	border: 1px solid #ccc;
	background: #fafafa;
	font-family: inherit;
	font-size: 0.875rem;
	line-height: normal;
	box-sizing: border-box;
	border-radius: 2px;
}

.static-page.contact .form button:disabled {
	opacity: 0.75;
}

.static-page.contact .form .error {
	display: none;
}

.static-page.contact .form .error.render {
	display: block;
}

/*************** Splash Page **************/

.static-page.splashPage .top-content-block {
	padding-bottom: 2rem;
}


.static-page.splashPage .top-content-block h1  {
	font-size: 2.25rem;
	line-height: 2.5rem;
	margin-bottom: 0;
	padding-bottom: 2rem;
	max-width: 48rem;
}

.static-page.splashPage .top-content-block a {
	display: inline-block;
}

.static-page.splashPage .top-content-block a + a {
	margin-top: 1rem;
}

@media only screen and (min-width: 768px) { 
	.static-page.splashPage .top-content-block a + a {
		margin-left: 1rem;
		margin-top: 0;
	}	
}

.static-page.splashPage h2 {
	padding: 1rem;
	text-align: center;
	font-size: 2rem;
	line-height: 2.5rem;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage h2 {
		padding: 0 4rem;
		text-align: center;
		font-size: 2.75rem;
		line-height: 3rem;
		margin-bottom: 4rem;
	}
}


.static-page.splashPage .splash-block {
	background-size: contain;
	background-repeat: no-repeat;
}

.static-page.splashPage .splash-block.pt-28 {
	padding-top: 8rem;
}

@media only screen and (min-width: 544px) {
	.static-page.splashPage .splash-block.pt-28 {
		padding-top: 12rem;
	}
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .splash-block.pt-28 {
		padding-top: 28rem;
	}
}


.static-page.splashPage .column-container {
	padding: 4rem 0;
}

.static-page.splashPage h2 + .column-container {
	padding: 0;
}

.static-page.splashPage .column-container.col-2 .text-content {
	width: 100%;
	box-sizing: border-box;
	padding: 1rem;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .column-container.col-2 .text-content {
		width: 50%;
		padding: 0 4rem;
	}	
}

.static-page.splashPage .column-container.col-3 .text-content {
	width: 100%;
	box-sizing: border-box;
	padding: 1rem;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .column-container.col-3 .text-content {
		width: 33.3%;
		padding: 0 2rem;
	}
}


.static-page.splashPage .column-container .text-content .align-center {
	text-align: center;
}

.static-page.splashPage .column-container .text-content h3 {
	font-size: 2.25rem;
	margin: 2rem 0;
}

.static-page.splashPage .column-container .text-content h4 {
	font-size: 1.25rem;
	margin-bottom: 2rem;
	line-height: 1.5rem;
}

.static-page.splashPage .column-container .text-content p + p {
	margin-top: 2rem;
}

.static-page.splashPage .column-container .text-content + .text-content {
	margin-top: 2rem;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .column-container .text-content + .text-content {
		margin-top: 0;
	}
}



.static-page.splashPage .splash-block.fix-image-height .text-content img {
	width: 100%;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .splash-block.fix-image-height .text-content img {
		width: auto;
		height: 370px;
	}
}


.static-page.splashPage .splash-block .text-content form {
	display: block;
	margin: 0;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .splash-block .text-content form {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		width: 70%;
		margin: 0 auto;
	}
}


.static-page.splashPage .splash-block .text-content form .formrow {
	padding: 1rem;
	box-sizing: border-box;
	text-align: center;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .splash-block .text-content form .formrow {
		width: 50%;
		padding: 1rem 2rem;
	}
}


.static-page.splashPage .splash-block .text-content form .formrow label {
	position: absolute;
	left: -9999px;
}

.static-page.splashPage .splash-block .text-content form .formrow input[type="text"] {
	padding: 1rem;
	line-height: 1.2rem;
	font-size: 1rem;
	font-family: inherit;
	font-weight: 300;
	display: block;
	margin: 0 auto;
	box-sizing: border-box;
	width: 100%;
}

@media only screen and (min-width: 768px) {
	.static-page.splashPage .splash-block .text-content form .formrow input[type="text"] {
		padding: 1.4rem 2rem;
	}
}


.static-page.splashPage .splash-block .text-content form .buttons {
	width: 100%;
	text-align: center;
	margin: 1rem 0 3rem 0;
}


/*************** Lessons Page **************/

.static-page.lesson-listing .ul.lesson-container {
	list-style: none;
}

.static-page.lesson-listing .ul.lesson-container .li {
	display: flex;
	padding: 2rem;
	border-bottom: solid 2px #ff9016;
	cursor: pointer;
}

.static-page.lesson-listing .ul.lesson-container .li .image-container {
	flex: 1 1 33.3%;
	box-sizing: border-box;
	padding-right: 1rem;
}

.static-page.lesson-listing .ul.lesson-container .li .text-content {
	flex: 1 1 66.7%;
	box-sizing: border-box;
	padding-left: 1rem;
}

.static-page.lesson-listing .ul.lesson-container .li .img {
	display: block;
	width: 100%;
}



/*************** Dashboard Page **************/
.static-page.dashboardPage {
	padding-top: 6rem;
}

@media only screen and (min-width: 768px) {
	.static-page.dashboardPage {
		padding-top: 8rem;
	}
}

.static-page.dashboardPage .h1,
.static-page.dashboardPage .p  {
	font-size: 2.25rem;
	line-height: 2.5rem;
	margin-bottom: 0;
	padding-bottom: 2rem;
	text-align: center;
	padding: 2rem 1rem 1rem 1rem;
}

.static-page.dashboardPage .p {
	font-size: 1.5rem;
	padding: 0 1rem;
}

.static-page.dashboardPage .ul.tiles {
	margin-top: 3rem;
	width: 100%;
	box-sizing: border-box;
	padding: 1rem;
}

.static-page.dashboardPage .ul.tiles .li .img {
	display: block;
	width: 100%;
	margin-bottom: 1rem;
}


@media only screen and (min-width: 768px) {
	.static-page.dashboardPage .ul.tiles {
		display: flex;
		flex-wrap: wrap;
		max-width: 77.5rem;
		margin: 3rem auto;
	}

	.static-page.dashboardPage .ul.tiles .li {
		box-sizing: border-box;
		width: 33.3%;
		padding: 1rem;
		display: flex;
		justify-content: center;
		align-items: center;
		text-align: center;
	}

	.static-page.dashboardPage .ul.tiles .li .a {
		box-sizing: border-box;
		display: block;
		width: 100%;
		height: 100%;
		padding: 2rem 1rem;
		text-decoration: none;
		font-size: 1.5rem;
		text-align: center;
		background: #212424;
		border-radius: 12px;
		transition: background 0.25s;
	}

	.static-page.dashboardPage .ul.tiles .li .a:hover {
		background: #2a2d2d;
		transition: background 0.25s;
	}

	.static-page.dashboardPage .ul.tiles .li .img {
		width: auto;
		height: 250px;
		margin: 0 auto 2rem auto;
	}
}
