
/**** GLOBAL ****/

* { margin: 0; padding: 0; box-sizing: border-box; } 
img { max-width: 100%; max-height: 100%;  }
.container { max-width: 1300px; margin: 0 auto; padding: 80px 30px; }

@media screen and (max-width: 760px){ .col-2 { column-count: 1; } }
@media screen and (min-width: 760px){ .col-2 { column-count: 2; } }

.no-margin-bottom, .list.no-margin-bottom { margin-bottom: 0; }
.small-margin-bottom { margin-bottom: 20px; }




/**** TYPE ****/

body {  font-family: 'Catamaran', sans-serif }
h1 { font-size: 50px; line-height: 50px; margin-bottom: 80px; color: #00ac89; text-align: center; font-weight: 400; }
.hidden { height: 0; overflow: hidden; text-indent: -10000px; margin: 0; padding: 0;}
h1 span.smaller { font-size: 30px; }
h2 { font-size: 44px; line-height: 55px; margin-bottom: 50px; color: #00ac89; text-align: center; font-weight: 400; }
h3 { font-size: 30px; margin-bottom: 50px; color: #00ac89;  font-weight: 400; }
p { font-size: 16px; line-height: 28px; margin-bottom: 80px }
p.intro { text-align: center; font-size: 22px; line-height: 30px; margin-bottom: 25px }
p.center { text-align: center; }
p.narrow { max-width: 810px; margin-left: auto; margin-right: auto; }
p:last-child { margin-bottom: 0; }

ul, li { list-style-type: none }
em { font-style: italic }



h1 span.by { font-size: 20px; color:#645F5F; font-style: italic; }
h1 .by-logo { max-width: 300px; margin: 0 auto}


/**** BACKGROUNDS + HERO ****/

.green { background-image: linear-gradient(-45deg, #077c6d, #00ac89 75%); }
.yellow { background-image: linear-gradient(-45deg, #FBDA04, #f4d13f 75%) }
.green h1, .green h2, .green h3, .green h4, .green p { color: #fff; }

section.bg {  background-color: #000; background-size: cover; background-position: center; }
@media screen and (max-width: 700px){ 
	section.bg.medium { height: 30vh; }
	section.bg.large { height: 60vh; }
}
@media screen and (min-width: 700px){ 
	section.bg.medium { height: 50vh; } 
	section.bg.large { height: 90vh; }
}




/**** MISC ****/

.big-button { padding: 15px 50px; display: inline-block; margin: 0 10px; background: #00ac89; text-decoration: none; color: #fff; transition: all .2s ease-in-out; }
a.big-button:hover { background:#f4d13f; -ms-transform: scale(1.1); -webkit-transform: scale(1.1); transform: scale(1.1)}
.yellow a.big-button:hover { background: #fff; color: #000; }





/**** LISTS ****/

p.list-header { text-transform: uppercase; font-size: 25px; line-height: 30px; text-align: center; margin-bottom: 50px;}	
ul.list { margin-bottom: 80px;  }
ul.list li { display: inline-block; padding: 10px 30px 10px 40px; background-image:url(/img/bullets/bullet-green.png); background-repeat: no-repeat; background-size: 25px; background-position: 0 10px; font-size: 18px; line-height: 24px; }
ul.list.no-bullets li { background-image: none; }
.green ul.list li { background-image:url(/img/bullets/bullet-white.png) }


/* pricelist variation */
ul.pricelist { margin-top: 50px; margin-bottom: 50px }
ul.pricelist h3 { font-size: 25px; line-height: 25px; margin-bottom: 7px;  }
ul.pricelist p { line-height: 24px; margin-bottom: 15px; }
ul.pricelist li span.price { font-weight: 800; width: 60px; color: #00ac89; display: inline-block; margin-right: 3%; vertical-align: top; }
ul.pricelist li span.desc {  width: 80%; display: inline-block; vertical-align: top; }	




.discount{ background:rgba(255,8,12,1.00); margin: 50px auto; width: 500px; padding: 15px;color:#fff; box-shadow: 0 0 5px 5px #fff; text-align:center; font-size: 16px;}
.discount span { font-weight: bold; font-size: 24px;}



/**** LINEUP ****/
ul.lineup { display: flex; flex-wrap: wrap;justify-content: space-around; margin: 50px 0 0 0}
ul.lineup li { margin-bottom: 50px; background: #00ac89; padding: 15px; box-shadow: 5px 5px 5px 0px #ccc; max-width: 520px }

/*@media screen and (max-width: 600px){							ul.lineup li{ width: 100%;}				}
@media screen and (min-width: 600px) and (max-width: 770px) {	ul.lineup li{ width:48%;}				}
@media screen and (min-width: 770px)  {							ul.lineup li{ width:30%;}				}*/

ul.lineup li .faculty { display: flex; }
ul.lineup li .faculty div { padding: 3px;}
ul.lineup li .faculty img { border:2px solid #fff;}

ul.lineup li h3 { color:#f4d13f; font-weight: bold; margin-bottom: 10px;font-size: 30px; line-height: 30px }
ul.lineup li p { color: #fff; font-weight: bold; margin-bottom: 8px; font-size: 12px; line-height: 15px}
ul.lineup li p.date { border-bottom: solid 1px #fff; padding-bottom: 10px; margin-bottom: 20px; font-size: 15px}
ul.lineup li p.city { font-size: 20px; border-bottom: solid 1px #fff; padding-bottom: 20px; margin-bottom: 20px;}
ul.lineup li p span { font-weight: normal; color: #f4d13f; text-transform: uppercase; font-size: 13px}



/**** FOOTER ****/

footer { border-top: 5px solid #00ac89; position: relative; width: 100%; box-sizing:border-box;  } 
footer br { display: none }

/* footer affiliates */	
footer #affiliates { width: 100%; background: #2D2C2C;  padding: 30px 20px 0 20px; box-sizing: border-box; display: flex; flex-wrap: wrap; justify-content: center}
footer #affiliates a { height: 110px; margin: 30px}
footer #affiliates a img { max-height: 100%; max-width: 100%; max-width: 300px; margin-bottom: 30px; }



/* footer info */
footer #info { height: 80px; box-sizing: border-box; background: #000; text-align: center; padding: 30px 5px; color: #D3D3D3; font-size: 13px; line-height: 22px }
footer #info a { color: #FFFFFF; text-decoration: none; padding: 0 7px; margin: 0 7px; border-left: solid 1px #727272; border-right: solid 1px #727272 }
footer #info a:hover { text-decoration: underline }	

