@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;500;700&display=swap');
@import "nav.css";


/* TEMPORARY -- HIDE MEMBERSHIPS 
a[href='?cid=9'] {display: none;}*/
/* ----------------------------- */

* {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
 
html {
	padding: 0px;
	margin: 0px;
	border: 0px;
	scroll-behavior: smooth;
}

body {
	padding: 0px;
	margin: 0px;
	border: 0px;
	font-size: 100%;
	max-width: 100%;
	min-height: 100%;
	background-color: white;
	color: black;
	font-family: Montserrat;
	font-weight: 300;
	letter-spacing: 0.1em;
	background-image: linear-gradient(30deg, rgb(245,245,245), rgb(255,255,255));
	opacity: 0;
	transition: opacity 0.5s 0.5s;
}

body.wait *{
	cursor: wait!important;
}

h1 {
	margin: 0 0 0.1em 0;
	font-size: 2.5em;
	color: black;
	line-height: 1em;
	font-weight: 300;
}

h2 {
	margin: 0em 0em 0.5em 0em;
	font-size: 2em;
	color: rgb(0,134,200,0.6);
	color: black;
	line-height: 1em;
	font-weight: 500;
}
h1 + h2{
	margin-bottom: 0.75em;
}

h3 {
	margin: 0em 0em;
	font-size: 1.6em;
	color: black;
	text-transform: uppercase;
	line-height: 1.1em;
	font-weight: 300;
}

a{
	color: rgb(159,102,45);
	font-weight: 700;
}

p + h1{
	margin-top: 1em;
}

p{
	line-height: 1.8em;
}

img {vertical-align: top;}

input,
textarea,
select{
	outline: none;
}

option{color: black;font-size: 1.1em;}
option[disabled]{display: none;}
select:invalid{color: rgb(200,200,200); font-size: 0.9em; padding: 0 0 0 3px; height: 2.2em;}

section{
	padding: 6em 0;
}
section>div{
	width: calc(100% - 2em);
	max-width: 1400px;
	margin: 0 auto;
	min-height: 20em;
}

.tbl{display: table}
.tr{display: table-row}
.td{display: table-cell; vertical-align: top;}

.warning{
	width: 100%;
	max-width: 600px;
	text-align: center;
	color: red;
	font-weight: 500;
	font-style: italic;
	padding: 7em 1em;
	margin: 0 auto;
}

/*---------------- TITLE -----------------------------------------*/

.nav-title{	display: none;}

header{
	width: 100%;
	position: relative;
}

.header-image{
	width: 100%;
	height: auto;
	position: relative;
	z-index: 2;
	-webkit-filter: drop-shadow(0 0 1em rgba(0,0,0,0.3));
	filter: drop-shadow(0 0 1em rgba(0,0,0,0.3));
}

.nav-container{
	font-size: 100%;
	position: -webkit-sticky;
	position: sticky;
	width: 100%;
	top: 0;
	padding: 1em 0;
	z-index: 15;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
	background-color: rgb(150,102,45);
	background-color: rgb(239,194,179);
	background-color: rgb(255,255,255);
	text-transform: uppercase;
	border-bottom: 1px solid rgb(200,200,200);
}

.nav-container.smashed{
	padding: 0;
}
ul.nav{
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}
.smashed ul.nav{
	padding: 0.28em 0;
}

.nav-logo{
	width: 18em;
	margin: -0em 0 -18em -3.5em;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}
.page-is-index .nav-logo{
	width: 0em;
}

.social{
	position: fixed;
	z-index: 3;
	right: 0;
	top: 6em;
	background-color: rgba(0,0,0,0.3);
	border-radius: 0.3em 0 0 0.3em;
	padding: 0.5em;
	text-align: center;
	width: 3em;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}
.social img{
	width: 2em;
	height: 2em;
	margin: 0.5em 0;
}
.social a{
	text-decoration: none;
}




/*---------------------------- FOOTER ------------------------------*/


.footer{
	background-color: rgb(255,255,255);
	background-color: rgb(0,0,0);
	border: 1px solid rgb(200,200,200);
	border: 1px solid rgb(0,0,0);
	border-width: 1px 0;
	color: black;
	color: rgb(255,255,255);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	position: relative;
	padding: 0;
	z-index: 2;
	font-size: 65%;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}


.footer>div{
	-webkit-box-flex: 1;
	-ms-flex: 1 1 0px;
	flex: 1 1 0;
}

.footer-image{
	-webkit-box-flex: 5!important;
	-ms-flex: 5 1 0px!important;
	flex: 5 1 0!important;
	text-align: center;
}
.footer-image img{
	height: 20.555em;
	opacity: 0.6;
	
}
.footer-logo{
	text-align: right;
	padding: 2em;
}
.footer-logo img{
	height: 16.181em
}


.footer-links{
	border: 1px solid rgb(200,200,200);
	border-width: 1px 0;
	padding: 3em 0;
	background-color: transparent;
	background-color: rgb(242,234,230);
	
}
.footer-links .link-container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	width: calc(100% - 2em);
	max-width: 1200px;
	margin: 0 auto;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.footer-links a{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-flex: 1;
	-ms-flex: 1 1 4em;
	flex: 1 1 4em;
}
.footer-links h2{
	font-size: 1.6em;
	margin: 0 1em 1em 1em;
}
.footer-links img{
	max-height: 6em;
	width: auto;
	height: auto;
	max-width: 100%;
}
.footer-links h2{
	text-align: center;
}


.contact-info{
	font-size: 90%;
	padding: 2em;
}
.contact-info div.nm{
	font-size: 4em;
	font-weight: bold;
	white-space: nowrap;
}
.contact-info div.epi{
	font-size: 1.5em;
	color: rgba(120, 100, 65, 1);
	position: relative;
	top: -0.3em;
	left: 22em;
	
}
.contact-info div.addr{
	font-size: 2em;
	margin-bottom: 1em;
}
.contact-info div.ph{
	font-size: 3em;
}


.copyright {
	width: 100%;
	vertical-align: middle;
	padding: 0.5em 1em;
	font-size: 70%;
	color: black;
	background-color: rgb(210,206,200);
	position: relative;
	z-index: 1;
	text-align: center;
	font-family: arial;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	line-height: 1.4em;
}
.copyright div{
	 -webkit-box-flex: 1;
	 -ms-flex: 1 1 280px;
	 flex: 1 1 280px;
	 text-align: middle;
}
.copyright div:first-of-type{
	 text-align: center;
}
.copyright a{
	color: rgb(120, 100, 65);
}



/*------------SITE SPECIFIC STYLES --------------------------------*/



.branding{
	text-align: center;
	background-color: rgb(242,234,230);
	border-top: white solid 0.28em;
	font-size: 0;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
}
.smashed .branding{
	font-size: 1.1em;
}
.branding > div{
	background-color: rgb(239,194,179);
	width: 1.6em;
	height: 1.5em;
	line-height: 1.4em;
	font-size: 1.4em;
	font-weight: 700;
	text-align: center;
	color: rgb(159,102,45);
	border: 0.2em solid white;
	border-width: 0 0.1em 0 0.1em;
	display: inline-block;
}
.branding > div:first-of-type{
	border-left-width: 0.2em;
}
.branding > div:last-of-type{
	border-right-width: 0.2em 
}

.divider-slim{
	background-color: white;
	background-image: linear-gradient(90deg, rgb(100,100,100), rgb(10,10,10));
	height: 1em;
}

.quoted{
	position: relative;
	margin: 1em 2em;
	line-height: 1.5em;
}
.quoted:before{
	content: '\201C';
	font-size: 3em;
	font-style: italic;
	font-family: serif;
	font-weight: 700;
	color: rgb(239, 194, 178);
	color: rgb(242,234,230);
	display: inline-block;
	vertical-align: middle;
	position: absolute;
	top: 0;
	left: -0.6em;
}
.quoted:after{
	content: '\201D';
	font-size: 3em;
	font-style: italic;
	font-family: serif;
	font-weight: 700;
	color: rgb(239, 194, 178);
	color: rgb(242,234,230);
	display: inline-block;
	vertical-align: middle;
	position: relative;
	bottom: -0.1em;
	margin: -1em 0;
	left: -0.1em;;
}

.membership-ad{
	background-color: black;
	background-image: url('../images/membership-ad-back.png');
	background-position: left center;
	background-size: auto 100%;
	background-repeat: no-repeat;
	background-blend-mode: luminosity;
	color: white;
	padding: 4em 1em;
	text-shadow: 0 0 0.5em black, 0 0 1em black, 0 0 1em black, 0 0 1.5em black;
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.membership-ad > div{
	-webkit-box-flex: 1;
	-ms-flex: 1 1 0px;
	flex: 1 1 0;
}
.membership-ad > div > div:first-of-type{
	font-size: 2em;
}
.membership-ad > div > div:nth-of-type(2){
	font-size: 1.5em;
}
.membership-ad > div > div:nth-of-type(3){
	font-size: 0.9em;
	font-style: italic;
}
.membership-ad  a{
	background-color: rgb(159,102,45);
	color: white;
	text-decoration: none;
	padding: 0.5em 1em;
	margin: 1em 0;
	display: inline-block;
	text-shadow: none;
	border-radius: 0.25em;
}

/* --------------------- HOME PAGE STYLE -------------------------- */

.home-top{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	background-color: white;
}
.home-top .logo-container{
	-webkit-box-flex: 1;
	-ms-flex: 1 1 0px;
	flex: 1 1 0;
	padding: 1em;
	text-align: center;
}
.home-top .logo-container img{
	height: auto;
	width: 100%;
	margin: 0 auto;
}
.home-top .vid-container{
	-webkit-box-flex: 2.32;
	-ms-flex: 2.32 1 0px;
	flex: 2.32 1 0;
	padding: 1em 1em 1em 0;
}

.home-top .vid-container>div{
	padding-bottom: 56.25%;
	position: relative;
}
.home-top>div>div>video{
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}


.text-divider{
	background-color: rgba(239, 194, 179, 0.8);
	background-color: rgba(0,0,0,1);
	background-image: radial-gradient(circle 50vw at bottom right, rgba(255,255,255,0.3), rgba(255,255,255,0));
	padding: 6em 0;
}
.text-divider h1{
	text-align: center;
	line-height: 1em;
	color: white;
}

.text-divider h3{
	text-align: center;
	line-height: 1em;
	padding: 0.3em 0 0.2em 0;
	font-weight: 400;
	color: white;
	color: rgb(239, 194, 179);
}


.category-container{
	background-color: rgb(242,234,230);
}
.categories{
	padding: 6em 0 6em 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	width: calc(100% - 2em);
	max-width: 1400px;
	margin: 0 auto;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.categories > figure{
	background-color: white;
	-webkit-box-flex: 1;
	-ms-flex: 1 1 20em;
	flex: 1 1 20em;
	border: 2px solid rgb(159,102,45);
	-webkit-filter: drop-shadow(0 0 0.75em rgba(0,0,0,0.2));
	filter: drop-shadow(0 0 0.75em rgba(0,0,0,0.2));
	margin: 1em 1em 5em 1em;
	padding: 2em;
	text-align: center;
	position: relative;
}

.categories figcaption a{
	position: absolute;
	top: calc(100% + 2em);
	left: 0;
	width: 100%;
	padding: 0.75em;
	background-color:  black;
	color: white;
	text-align: center;
	border: 1px solid rgb(200,200,200);
	border-radius: 0.25em;
	text-decoration: none;
}

.categories img{
	width: calc(100% - 2em);
	max-width: 200px;
}



.testimony-container{
	padding: 6em 0;
	background-image: url("../images/home-testimonial-bckgrd.jpg");
	background-size: cover;
	background-position: center;
}

.testimony-container > div{
	width: calc(100% - 2em);
	max-width: 1400px;
	margin: 0 auto;
	background-color: white;
	padding: 2em;
}

.testimonies{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 1em;
}

.testimonial{
	padding: 0 0 1em 0;
	margin: 1em;
	border-right: 1px solid black;
}

.review-header{
	font-size: 1.6em;
	font-weight: 500;
	margin-bottom: 0.5em;
}

.attribution{
	display: block;
	text-align: right;
	padding: 0 2em;
}


.faculty-container{
	position: relative;
	background-color: white;
	padding: 6em 0;
}
.faculty-container > div {
	width: calc(100% - 2em);
	max-width: 1550px;
	margin: 0 auto;
	background-color: white;
	padding: 0;
}

.faculty-members{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.faculty-members figure{
	-webkit-box-flex: 1;
	-ms-flex: 1 1 300px;
	flex: 1 1 300px;
	text-align: center;
	display: flex;
	flex-direction: column;
	;
}
.faculty-members figure img{
	width: 100%;
	max-width: 250px;
	padding: 1em 0;
	margin: 0 auto;
}
.faculty-members figcaption{
	display: table-caption;
	caption-side: bottom;
}
.faculty-name{
	font-weight: 500;
	font-size: 1.4em;
	padding-bottom: 0.25em;
}
.faculty-title{
	font-weight: 300;
}


.academy-link{
	background-color: #000000;
	color: white;
}
.academy-link>div{
	display: -webkit-box;
	display: -ms-flexbox;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	display: flex;
	padding: 3em 2em;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	max-width: 1200px;
	margin: 0 auto;
}
.academy-link>div>div{
	-webkit-box-flex: 1;
	-ms-flex: 1 1 400px;
	flex: 1 1 400px;
	text-align: center;
	padding: 1em 2em;
}
.academy-link>div>div:first-of-type{

}
.academy-link>div>div:last-of-type{
	font-size: 2em;
	font-weight: 600;
}
.academy-link img{
	max-height: 20em;

}

/* --------------- MASTERY PAGE ------------- */

.mastery-container{
	padding: 6em 0;
	background-image: url("../images/home-testimonial-bckgrd.jpg");
	background-size: cover;
	background-position: center;	
	position: relative;
	overflow: hidden;
}
.mastery-container > div {
	width: calc(100% - 2em);
	max-width: 1400px;
	margin: 0 auto;
	background-color: white;
	padding: 4em 2em;
	border-radius: 0.25em;
}

.mastery-container img{
	float: right;
	margin-top: -4em;
	margin-right: 2em;
	width: 38vw;
	max-width: 550px;
	margin-bottom: -25%;
	-webkit-filter: drop-shadow(0 0 2em rgba(0,0,0,0.5));
	filter: drop-shadow(0 0 2em rgba(0,0,0,0.5));
}

.button-container {
	text-align: center;
}

.button-container a {
	display: inline-block;
	padding: 0.75em 1em;
	background-color: black;
	color: white;
	text-align: center;
	border: 1px solid rgb(200, 200, 200);
	border-radius: 0.25em;
	text-decoration: none;
	line-height: normal;
	white-space: nowrap;
}

/* ------------- ALL ACCESS PAGE ---------------------- */

.duration{
	font-size: 80%;
	color: white;
	background-color: black;
	position: absolute;
	bottom: 0.5em;
	left: 1em;
	padding: 0.25em;
}
.BGM-store-vidlib-container figcaption img, 
.BGM-store-vidlib-container figcaption hr{
	display: none;
}
.section-header{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
	color: white;
	background-color: black;
	padding: 0.5em 0.5em;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.section-header > div{
	-webkit-box-flex: 0;
	-ms-flex: 0 0 0;
	flex: 0 0 0;
	text-align: center;
	white-space: nowrap;
	font-size: 1.4em;
}
.section-header > div:first-of-type{
	font-weight: 500;
}
.section-header > div:last-of-type{
	font-size: 100%;
}
	

/* --------------- TOC PAGE ------------- */

.toc-container{
	padding: 6em 0;
	background-color: rgb(180,180,180);	
	position: relative;
	overflow: hidden;
}
.toc-container > div {
	width: calc(100% - 2em);
	max-width: 1400px;
	margin: 0 auto;
	background-color: white;
	padding: 4em 2em;
	border-radius: 0.25em;
}

.toc{
	padding: 1em;
	font-size: 0.8em;
	color: white;
	background-color: rgb(50,42,44);
	text-align: center;
}
	
/* ------------- STORE STYLES --------------------------- */

.anon-login{
	display: none;
}

/* ----------------- BGM CMS OVERRIDES ----------------------------- */

.BGM-CMS-form h1{
	font-size: 2em;
	color: black;
}
.BGM-login-container form{
	min-width: 280px;
}

#priceTableHolder{
	line-height: 1.6em;
}

.BGM-form-vB .inpField label, .BGM-form-vB .inpField select[value=""] + label, .BGM-form-vB .inpField input[type=file]:invalid + label {
	color: rgb(0,0,0,0.7);
}
.BGM-store-vidlib-item figure p{
	font-size: 80%;
}
.BGM-store-vidlib-container figure > div{
	position: relative;
}

/* ---------------- MEDIA QUERY STYLES ------------------------ */



@media only screen and (max-width: 1580px) {
}


@media only screen and (max-width: 1450px) {
}

@media only screen and (max-width: 1350px) {
}

@media only screen and (max-width: 1300px) {
}

@media only screen and (max-width: 1240px) {
}

@media only screen and (max-width: 1100px) {
}


@media only screen and (max-width: 1050px) {

}

@media only screen and (max-width: 1000px) {
}

@media only screen and (max-width: 900px){
	.footer-image{display: none;}
}

@media only screen and (orientation: portrait),
		 only screen and (max-aspect-ratio: 1),
		 only screen and (max-width: 800px) {
			 
			 body{
				 padding-top: 2em;
			 }
			 .nav-switch {
				 top: 17px;
			 }	 
			 .nav-title{
				 display: block;
				 position: fixed;
				 top: 0;
				 left: 0;
				 right: 0;
				 padding: 10px;
				 color: white;
				 line-height: 1em;
				 z-index: 20;
				 background-color: rgba(0,0,0,0.8);
				 -webkit-backdrop-filter: blur(5px);
				 backdrop-filter: blur(5px);
			 }
			 
			 .contact-info{
				 -webkit-box-ordinal-group: 3;
				 -ms-flex-order: 2;
				 order: 2;
				 text-align: center;
				 font-size: 80%;
				 -webkit-box-flex: 1!important;
				 -ms-flex: 1 1 100%!important;
				 flex: 1 1 100%!important;
			 }
			 .footer-image{
				 display: none;
			 }
			 .footer-logo{
				 font-size: 100%;
				 -webkit-box-ordinal-group: 2;
				 -ms-flex-order: 1;
				 order: 1;
				 text-align: center;
				 -webkit-box-flex: 1!important;
				 -ms-flex: 1 1 100%!important;
				 flex: 1 1 100%!important;
				 padding-bottom: 0;
			 }
			 .footer-logo img{
				 height: 24em;
			 }
			 .contact-info div.nm{
				 white-space: normal;
			 }		 
			 section{padding: 3em 0;}
}


@media only screen and (max-width: 800px) {
	.mastery-container img{display: none;}
	.BGM-store-container {
		 font-size: 75%;
	}
	.BGM-form.searchForm{
		font-size: 1.2em;
	}
}

@media only screen and (max-width: 700px){
	.home-top{-ms-flex-wrap: wrap;flex-wrap: wrap;}
	.home-top > div{-webkit-box-flex: 1!important;-ms-flex: 1 1 100%!important;flex: 1 1 100%!important; padding: 1em!important}
	.text-divider{font-size: 70%;}
	.home-top .logo-container{-webkit-box-ordinal-group: 3;-ms-flex-order: 2;order: 2;}
}

@media only screen and (max-width: 600px){
	.home-top .vid-container{padding: 1em;}
	.CCInfoAndLinks{border-width: 0 0 1px 0;padding-bottom: 1em;}
}



@media only screen and (max-width: 500px){
	.membership-ad{
		background-position: center;
	}
}

@media only screen and (max-width: 350px){
}

/* ------------------- PRINT STYLES ------------------- */

@media print{
	.noPrint{display: none;}
}
	