
/* =============================================================================
   HTML5 element display
   ========================================================================== */

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { display: block; }
audio[controls], canvas, video { display: inline-block; *display: inline; *zoom: 1; }

html { font-size: 100%; overflow-y: scroll; -webkit-overflow-scrolling: touch; -webkit-tap-highlight-color: rgba(0,0,0,0); -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }
body { margin: 0; font-size: 13px; line-height: 1.231; }

/* body, button, input, select, textarea { font-family: sans-serif; color: #222; } */
body, button, input, select, textarea { font-family: lato; color: #151924; }
h1 { font-family: oswald; }

::-moz-selection { background: #2f94fa; color: #fff; text-shadow: none; }
::selection { background: #2f94fa; color: #fff; text-shadow: none; }



/* =============================================================================
   Lists
   ========================================================================== */

ul, ol { margin: 16px 0; padding: 0 0 0 45px; }
@media only screen and (max-width: 891px){
	ul, ol { padding-left: 30px; }
}
.list-float-friendly { overflow: hidden; } /* overflow:hidden is needed to make floated images not break indents, add to ul element, see: https://css-tricks.com/forums/topic/float-left-combined-with-bullets-problematic/  like by cody's picture here: https://www.breakthroughbasketball.com/pr/athletic-development-program.html*/
 
dd { margin: 0 0 0 40px; }
nav ul, nav ol { list-style: none; margin: 0; padding: 0; }

/*rest of the above sections moved to obscure.css*/



/* =============================================================================
   Primary styles
   Author: Ross Wilson
   ========================================================================== */
/*###########################Start Older Styles############################# */

/*moved from main & print.css*/
/*
body, p, table, td, th, ul, ol, textarea, input { 
	font-family:Verdana, Arial, Tahoma, helvetica, sans-serif; font-size:10pt;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}*/

/* h1, h2, h3, h4 { font-family:Arial, Helvetica, sans-serif; color: #000080;margin: .5em 0;} */
h1 { font-size:1.8em; }
h2 { font-size:1.6em; }
h3 { font-size:1.4em; }
h4 { font-size:1.2em; }
h5 { font-size:1.1em; }
h6 { font-size:1.0em; }

a:focus { outline: thin dotted; }
a:hover, a:active { outline: 0; }
a, a:visited { color: #2172be; }
a:hover {color: #f3871b; text-decoration:underline;}
.contentwrapper a:hover {color: #f3871b; text-decoration:underline;} /* starting from .contentwrapper prevents text colors from overwriting the hover color unless hover color is changed/removed explicitly, or an #id selector is used */
hr{height: 2px;border-top: 1px solid #3350B9;border-bottom: 1px solid #3350B9;}

.pb {page-break-before: always}
.pba {page-break-after: always}
.red{color:#C40306;}
.blue{color: #3350B9;}
.graybox{background: #f2f2f2;border: 1px solid #ccc;margin: 2px;padding: 3px 10px;}
.adbox{float:right;background: #f2f2f2;border: 1px solid #ccc;margin: 2px;padding: 5px 8px;vertical-align:top;font-size:12px;font-family:arial,helvetica,sans-serif;color:black;}
/*yellow popup to signup for newsletter */
#message_box { position: absolute; right: 10px; z-index: 10; background:#ffc;border:1px solid #CCCCCC;text-align:left; display:none;color:#3F3F3F;font: 10px Verdana, Arial, Helvetica, sans-serif; } 
.noshow { display:none; }

#fb-root {display: none;}
/*=====CAPTCHA class====*/
#required { display: none }


/*###########################COMMON TAGS ################################### */
.clear { clear:both; line-height:1px; height:1px; }


/* =============================================================================
   Non-semantic helper classes
   Please define your styles before this section.
   ========================================================================== */

/* For image replacement */
.ir { display: block; text-indent: -999em; overflow: hidden; background-repeat: no-repeat; text-align: left; direction: ltr; }
.ir br { display: none; }

/* Hide for both screenreaders and browsers:
   css-discuss.incutio.com/wiki/Screenreader_Visibility */
.hidden { display: none; visibility: hidden; }

/* Hide only visually, but have it available for screenreaders: by Jon Neal.
  www.webaim.org/techniques/css/invisiblecontent/  &  j.mp/visuallyhidden */
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }

/* Extends the .visuallyhidden class to allow the element to be focusable when navigated to via the keyboard: drupal.org/node/897638 */
.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }

/* Hide visually and from screenreaders, but maintain layout */
.invisible { visibility: hidden; }

/* Contain floats: nicolasgallagher.com/micro-clearfix-hack/ */ 
.clearfix:before, .clearfix:after { content: ""; display: table; }
.clearfix:after { clear: both; }
.clearfix { zoom: 1; }


/* =============================================================================
   Print styles.
   Inlined to avoid required HTTP connection: www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */
 
@media print {
  * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } /* Black prints faster: sanbeiji.com/archives/953 */
  a, a:visited { color: #444 !important; text-decoration: underline; }
  a[href]:after { content: " (" attr(href) ")"; }
  abbr[title]:after { content: " (" attr(title) ")"; }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }  /* Don't show links for images, or javascript/internal links */
  pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
  thead { display: table-header-group; } /* css-discuss.incutio.com/wiki/Printing_Tables */
  tr, img { page-break-inside: avoid; }
  img { max-width: 100% !important; }
  @page { margin: 0.5cm; }
  p, h2, h3 { orphans: 3; widows: 3; }
  h2, h3{ page-break-after: avoid; }
  footer{ display: none;}
  #message_box{ display:none;}
  /*=============Playcreator classes=============*/
  .clearfix:after {content: ".";display: block;clear: both;visibility: hidden;line-height: 0;height: 0;}	
  .clearfix {display: inline-block;}	
  html[xmlns] .clearfix {display: block;}	
  * html .clearfix {height: 1%;}
  .step {vertical-align:top;padding-bottom:25px;padding-right:5px;padding-left:5px;width:100%;}
  * html .step{width: inherit;}
  .stepimage {float:right;display:block-inline;vertical-align:top;padding-left:6px;}
  .step li{padding-bottom:12px;}

  .noprint {display: none;}
}

/*used in comments-script */
.commentcolumn, .commentcolumn p, .commentcolumn a{
	word-wrap: break-word;
	word-break: break-word;
	max-width: 100%;
}


/* OLD big add to cart button on /pr pages */
.addtocartbutton{
	border: 3px solid #B40000;
	width: 78%;
}
.addtocartbuttoncontainer{
	background-color: #FFFFFF;
	border: 3px dashed #CC0000;
	border-collapse: collapse;
	padding: 20px;
	text-decoration: none;
	width: 83%;
}
@media only screen and (min-width: 891px){
	.addtocartbutton { margin-bottom: 10px; }
	.addtocartbutton span { font-size: 32pt; }
}
@media only screen and (max-width: 891px){
	.addtocartbutton { display: none; }
}

/*makes embedded videos fit mobile and use whole width, with 16:9 aspect ratio*/
.videoWrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 25px;
	height: 0;
}
.videoWrapper iframe, .videoWrapper video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* OLD camp pages */
@media screen{	
	.mobile_table_card{
		background-color: #eeeeee;
		border: 1px solid #cccccc;
		border-radius: 4px;
		float: left;
		margin: 3px;
		padding: 3px;
		cursor: pointer;
	}

}
@media only screen and (min-width: 891px){
	.mobile_table_card{ display: none; }
	.camp_registration_form input{ width: 25em; }
}
@media only screen and (max-width: 891px){
	.pc_table{ display: none; }
	a{ 
		word-wrap: break-word;
		-webkit-hyphens: auto;
		-moz-hyphens: auto;
		hyphens: auto;
	}
}



/*
@media only screen and (max-width: 891px){
	#container {display: -webkit-flex; display: flex; -webkit-flex-flow: column wrap; flex-flow: column wrap;}
	#navigation {display: none;}
	#mobilenavigation {-webkit-order: 1; order: 1;}
	#header{ background-image: url("../../../images/bg_header_mobile.jpg") !important; height: 96px !important; background-size: 460px 96px; background-color: #2b4f83;}
	#logo {width:202px; height:76px; padding:7px 0 0 23px; display:block; float:left; }
	#logo a {text-indent:-9999px; display:block; width:202px; height:76px; }
}
@media only screen and (min-width: 891px){
	#mobilenavigation {display: none;}
	.mobilemenubutton{display: none;}
}
*/

/* 2018 WIDERFUNNEL DESIGN */
/*
fonts:
Use px instead of pt on web, same number as in photoshop, converts to about same size
LATO:
light = 300
regular = 400
bold = 700

*/


@media only screen and (max-width: 891px){
	.pc-only { display: none !important; }
	.mobile-centered { text-align: center; }
}
@media only screen and (min-width: 891px){
	.mobile-only { display: none !important; }
	.pc-centered { text-align: center; }
}

#outerwrapper { width: 100%; padding:0; margin:0; overflow: hidden; }
#outerwrapper b, #outerwrapper strong { font-weight: 700; }
#container { width:100%; padding:0; margin:0; }
.contentwrapper { max-width:1170px; padding:0 15px; margin:0 auto; }
.outercontentwrapper { width: 100vw; position: relative; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; } /*makes full screen width. Use another .contentwrapper inside it. PARENT MUST BE CENTERED */
.staticpagewrapper {  background: none; /* background: linear-gradient(to right, #C2D9ED 0%, #ffffff 50%, #C2D9ED 100%); */ } /*#D7E5F3 and #EBF2F9 are blends of white and #2172be */
.staticpagewrapper2 { text-align: center; background: none; padding: 0px 15px 50px 15px; /* border-left: 1px solid #232a3b; border-right: 1px solid #232a3b; */ } /* surrounds content on content pages (articles) */
.staticpagewrapper3 { width: 700px; max-width: 700px; background: none; box-sizing: content-box; padding: 0 20px 20px 20px; display: inline-block; text-align: left; }
.staticpageheader { display: block; color: white; background: #2172be; text-align: center; padding: 50px; box-sizing: border-box; width: 100vw; position: relative; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; margin-bottom: 20px; } 
.staticpagetitle, .staticpagewrapper .staticpagetitle { max-width: 700px; margin: 0 auto; color: white; font: 700 42px oswald; } /* extra selector needed to override h1 styles */
.staticpageauthor { margin-top: 10px; color: #d8e0ef; font: 400 22px lato; }
.staticpageauthor a { color: #d8e0ef; }
.staticpagebreadcrumbs { margin-top: 0px; padding-bottom: 15px; /* color: #d8e0ef; */ color: #151924; font: 400 12px lato; /* margin: -20px auto 20px auto; max-width: 1170px; padding-left: 15px; text-align: left; */ }
.staticpagebreadcrumbs a { /* color: #d8e0ef; */ color: #2172be; }
.staticpagewrapper h1 { font: 400 36px oswald; color: #151924; margin-top: 40px; }
.staticpagewrapper h2 { font: 700 28px lato; color: #151924; }
.staticpagewrapper h3 { font: 700 23px lato; color: #151924; }
.staticpagewrapper h4 { font: 700 20px lato; color: #151924; }
.staticpagewrapper h5 { font: 700 18px lato; color: #151924; }
.staticpagewrapper, .staticpagewrapper p, .staticpagewrapper li, .staticpagewrapper td { font: 400 16px lato; color: #151924; }
.staticpagewrapper li+li { margin-top: 7px; }
.staticpagewrapper3 > *:first-child:not(.staticpageheader){ margin-top: 40px; } /* pages without new blue headers need upper margin */
.aspwrapper { } /* special case of staticpagewrapper for the various .asp pages */
.aspwrapper .staticpagewrapper3 { max-width: 770px; }
.aspwrapper .staticpagetitle { max-width: 770px; }

@media only screen and (max-width: 891px){
	.staticpagewrapper2 { padding: 0; }
	.staticpagewrapper3 { width: 96%; padding: 0 2% 2% 2%; }
	.staticpageheader { font-size: 26px; padding: 30px 20px 30px 20px; }
	.staticpagebreadcrumbs { padding-left: 0px; font-size: 11px; }
	.staticpagewrapper h1 { font-size: 25px; }
	.staticpagewrapper h2 { font-size: 22px; }
	.staticpagewrapper h3 { font-size: 20px; }
	.staticpagewrapper h4 { font-size: 18px; }
	.staticpagewrapper h5 { font-size: 18px; }
	.staticpagetitle, .staticpagewrapper .staticpagetitle { font-size: 34px; }
	.staticpageauthor { font-size: 20px; }
	
	/* new default rules for images on mobile, so they're not too big. Fixes a LOT of content pages. */
	img { max-width: 100vw; height: auto; }
	.contentwrapper img { max-width: calc(100vw - 30px); }
	.staticpagewrapper3 img:not(td img) { max-width: calc(100vw - 4%); }
	img[align="right"], img[align="left"] { max-width: 50vw; height: auto; }
}
@media only screen and (max-width: 891px){
	
}
/* mass-replaced over 500 drill/play/etc diagrams on 120 pages that used table layouts and were bad on mobile. These classes control their new formatting. */
.contentdiagramcontainer { margin-bottom: 20px; margin-top: 10px; overflow: hidden; } 
.contentdiagramtext { display: inline; vertical-align: top; }
.contentdiagramtext p:first-child { margin-top: 0px; }
.contentdiagramtext ol, .contentdiagramtext ul { padding-left: 17px; /* less padding */ }
.contentdiagramtext ol:first-child, .contentdiagramtext ul:first-child { margin-top: 0px; }
.contentdiagramtext h1:first-child, .contentdiagramtext h2:first-child, .contentdiagramtext h3:first-child, .contentdiagramtext h4:first-child, .contentdiagramtext h5:first-child { margin-top: 0px; }
.contentdiagramimage { display: inline; float: right; margin-left: 20px; vertical-align: top; padding-bottom: 10px; }
.contentdiagramimageLeft { display: inline; float: left;  margin-right: 20px; vertical-align: top; padding-bottom: 10px; }
@media only screen and (max-width: 891px){
	.contentdiagramimage { width: 50%; height: auto; }
	.contentdiagramimage img { width: 100%; height: auto; } /* only if there's a caption and the contentdiagramimage class is applied to a div with the img & caption inside */
	.contentdiagramimageLeft  { width: 70%; height: auto; } /* only if there's a caption and the contentdiagramimage class is applied to a div with the img & caption inside */

}

.forumcontainer { margin: 50px auto; max-width: 1170px; overflow: hidden; }
.forumcontainer #wrap { float: none; width: 100%; max-width: 100%; margin: 0; padding: 0; }
.forumcontainer .tablebg { width: 100%; max-width: 100%; }

.navrightwhite { display: inline-block; width: 8px; height: 11px; /* vertical-align: middle; */ background-image: url('/2018wf/overall/navrightwhite.png'); margin-left: 5px; } /* #ffffff */
.navrightwhiteish { display: inline-block; width: 8px; height: 11px; vertical-align: middle; background-image: url('/2018wf/overall/navrightwhiteish.png'); margin-left: 5px; } /* #d8e0ef */
.navrightblue { display: inline-block; width: 8px; height: 11px; vertical-align: middle; background-image: url('/2018wf/overall/navrightblue.png'); margin-left: 5px; } /* #2172be */
/*links styled like buttons*/
.btnlink { cursor: pointer; border-radius: 2px; box-sizing: border-box; display: inline-block; vertical-align: top; height: 36px; line-height: 36px; text-align: center; padding: 7px 15px 9px 15px; background-color: #f3871b; }
.btnlink, a.btnlink:hover, a.btnlink:visited { font: 400 16px oswald; text-decoration: none; color: #ffffff; }

/* 'submit' button version of btnlink. Has a fixed width and an arrow by default... whereas btnlink uses the navrightwhite/etc classes for the arrows.
note: must position background for each button depending on text size, and add space(s) to the value to center it, like: background-position: center right 22%; <input class="btnsubmit" type="submit" value="GET NOTIFIED " /> */
.btnsubmit { border: 0; border-radius: 2px; box-sizing: border-box; background: #f3871b url('/2018wf/overall/navrightwhite.png') no-repeat center right 22%; font: 400 16px oswald; color: #ffffff; display: inline-block; width: 170px; height: 36px; padding: 6px 15px 6px 2px; vertical-align: top; text-align: center; } 

.btn-noarrow { background-image: none; padding-right: 2px; } /* only for btnsubmit, currently only that has arrows */
.btn-blue, a.btn-blue:hover, a.btn-blue:visited { background-color: #2172be; } /* can be used for btnlink or btnsubmit */

#star-rating { margin-left: -4px; } /* todo: change id to class when updating/replacing the comments script */
.star-rating-count { font: 400 14px lato; color: #151924; }
a.star-rating-link, a.star-rating-link:hover { text-decoration: none; }


/* reusable columns classes for any page, 2 column only. Combines to single column on mobile.
use like: <div class="simplecolumns"><div class="simplecolumn">....</div><div class="simplecolumn">....</div></div>*/
@media only screen and (min-width: 891px){
	.simplecolumns:after { content: ""; display: table; clear: both; }
	.simplecolumn { float: left; width: 47%; }
	.simplecolumn+.simplecolumn { margin-left: 6%; }
}

/* styled <select>: .plainselectdropdown { width: 172px; height: 36px; display: inline-block; box-sizing: border-box; padding: 1px 2px 1px 2px; border: 1px solid #656a78; border-radius: 2px; vertical-align: top; font: 300 14px lato; color: #656a78; }*/



/*     SimpleBar.js - v2.6.1    (custom scrollbars, used in custom dropdown) */
[data-simplebar] { position: relative; z-index: 0; overflow: hidden!important; max-height: inherit; -webkit-overflow-scrolling: touch; /* Trigger native scrolling for mobile, if not supported, plugin is used. */ }
[data-simplebar="init"] { display: -webkit-box; display: -ms-flexbox; display: flex; }
.simplebar-scroll-content { overflow-x: hidden!important; overflow-y: scroll; min-width: 100%!important; max-height: inherit!important; -webkit-box-sizing: content-box!important; box-sizing: content-box!important; }
.simplebar-content { overflow-y: hidden!important; overflow-x: scroll; -webkit-box-sizing: border-box!important; box-sizing: border-box!important; min-height: 100%!important; }
.simplebar-track { z-index: 1; position: absolute; right: 0; bottom: 0; width: 11px; }
.simplebar-scrollbar { position: absolute; right: 10px; width: 7px; min-height: 10px; }
.simplebar-scrollbar:before { position: absolute; content: ""; background: #2172be; border-radius: 7px; left: 0; right: 0; opacity: 0; -webkit-transition: opacity 0.2s linear; transition: opacity 0.2s linear; }
.simplebar-track:hover .simplebar-scrollbar:before,
	.simplebar-track .simplebar-scrollbar.visible:before { /* When hovered, remove all transitions from drag handle */ /*opacity: 0.5;*/ opacity: 1; -webkit-transition: opacity 0 linear; transition: opacity 0 linear; }
.simplebar-track.vertical { top: 0; }
.simplebar-track.vertical .simplebar-scrollbar:before { top: 2px; bottom: 2px; }

/*
.simplebar-track.horizontal { left: 0; width: auto; height: 11px; }
.simplebar-track.horizontal .simplebar-scrollbar:before { height: 100%; left: 2px; right: 2px; }
.simplebar-track.horizontal .simplebar-scrollbar { right: auto; top: 2px; height: 7px; min-height: 0; min-width: 10px; width: auto; }
*/
.simplebar-track.horizontal { display: none; }


/*custom select dropdowns, also see bball.main.js "Dropdowns"*/
/* old hardcoded widths
.bbsel_container { display: inline-block; height: 36px; width: 172px; }
.bbsel_optionscontainer { position: relative; overflow: hidden; width: 172px; height: 0px; z-index: 10000; background-color: white; padding: 0; box-sizing: border-box;  border-radius: 0 0 2px 2px; margin-top: -1px; }
.bbsel_opened .bbsel_optionscontainer { height: 220px; width: 187px; padding-bottom: 5px; }
.bbsel_header, .bbsel_header:hover { display: block; width: 187px; box-sizing: border-box; border-radius: 2px; padding: 10px 10px; cursor: pointer; user-select: none; font: 300 14px lato; color: #656a78; background: white url('/2018wf/overall/menu/navigatedown.png') no-repeat right 9px center; }
.bbsel_noscroll .bbsel_option { width: 167px; }
*/

.bbsel_container { display: inline-block; height: 36px; width: 100%; position: relative; text-align: left; }
.bbsel_optionscontainer { overflow: hidden; width:100%; height: 0px; z-index: 10000; background-color: white; padding: 0; box-sizing: border-box;  border-radius: 0 0 2px 2px; margin-top: -1px; }
.bbsel_opened .bbsel_optionscontainer { position: absolute; height: 235px; width: 100%; }
.bbsel_container:not(.bbsel_opened) .bbsel_optionscontainer { display: none; }
.bbsel_option, a.bbsel_option:visited { display: block; padding: 3px 10px; box-sizing: border-box; width: calc(100% - 20px); cursor: pointer; vertical-align: middle; text-decoration: none; -moz-user-select: none; user-select: none; font: 300 14px lato; color: #656a78; }
.bbsel_option:hover, a.bbsel_option:hover, .bbsel_option:focus { background-color: #d8e0ef; color: #656a78; text-decoration: none; outline: none; }
.bbsel_opened .bbsel_selected, .bbsel_opened a.bbsel_selected { color: #f3871b; }
.bbsel_header, .bbsel_header:hover { display: block; width: 100%; box-sizing: border-box; border-radius: 2px; padding: 8.6px 10px; cursor: pointer; -moz-user-select: none; user-select: none; font: 300 14px lato; color: #656a78; background: white url('/2018wf/overall/menu/navigatedown.png') no-repeat right 9px center; }
.bbsel_opened .bbsel_header { background-image: url('/2018wf/overall/menu/navigateup.png'); border-radius: 2px 2px 0 0; }
.bbsel_border .bbsel_header { border: 1px solid #656a78; }
.bbsel_border.bbsel_opened .bbsel_header { border-bottom: none; padding-bottom: 9.6px; }
.bbsel_border.bbsel_opened .bbsel_optionscontainer { border: 1px solid #656a78; border-top: none; }
.bbsel_noscroll { display: flex; flex-direction: column; width: 100%; } /* SimpleBar does display:flex for the ones with scrolling too, needed for noscroll ones so the dropdown doesn't affect height of parent container */
.bbsel_noscroll .bbsel_option { width: 100%; }
.bbsel_container:not(.bbsel_opened) .bbsel_noscroll { height: 0px !important; /*overrides the height set by js when closed*/ }


@media only screen and (max-width: 891px){
	.bbsel_container { height: 48px; } /* bigger dropdowns on mobile */
	.bbsel_option, a.bbsel_option:visited { padding: 6px 10px; font-size: 16px; }
	.bbsel_header, .bbsel_header:hover { padding: 13.6px 10px; font-size: 16px; }
	.bbsel_border.bbsel_opened .bbsel_header { padding-bottom: 15.6px; }
}

input.bbtext { background: white; } /*  input selector is required to override 'invalid' red backgrounds on firefox */
.bbtext { box-sizing: border-box; width: 100%; height: 36px; border-radius: 2px; border: 0px; padding: 9.6px 10px 9.6px 10px; font: 300 14px lato; color: #656a78; } /* for input type[text], similar style to .bbsel */
.bbtext_border { border: 1px solid #656a78; }
.bbtext::placeholder { color: #acacac; opacity: 1; }

.bbtextarea { background: white; box-sizing: border-box; width: 100%; border-radius: 2px; border: 0px; padding: 9.6px 10px 9.6px 10px; font: 300 14px lato; color: #656a78; }
.bbtextarea_border { border: 1px solid #656a78; }

/* camp payment page uses a bigger checkbox than radio buttons... but do we want to make the default the same for each? */
.bbcheck_label { display: inline-block; position: relative; cursor: pointer; -moz-user-select: none; user-select: none; }
.bbcheck_hidden { position: absolute; left: 0; top: 0; width: 18px; height: 18px; opacity: 0; cursor: pointer; }
.bbcheck_box { display: inline-block; box-sizing: border-box; width: 18px; height: 18px; border: 2px solid #2172be; vertical-align: middle; background: #ffffff; }
.bbcheck_inner { display: none; width: 10px; height: 10px; margin-top: 2px; margin-left: 2px; background: url('/2018wf/overall/check.png') no-repeat center center; background-size: 100%; }
.bbcheck_text { font: 400 14px lato; color: #656a78; display: inline-block; margin-left: 8px; vertical-align: middle; } /*copied from bbradio_text... default font not used yet but making same*/
.bbcheck_label .bbcheck_hidden:checked ~ .bbcheck_box .bbcheck_inner { display: block; } /* shows the checks when bbcheck_hidden and bbcheck_box are inside the bbcheck_label... may need to figure something else out if we want the hidden checkbox in the parent */

.bbradio_label { display: inline-block; position: relative; cursor: pointer; -moz-user-select: none; user-select: none; } /* todo ?? */
.bbradio_label:not(:last-of-type) { margin-right: 25px; }
.bbradio_hidden { position: absolute; left: 0; top: 0; width: 18px; height: 18px; opacity: 0; cursor: pointer; } 
.bbradio_box { display: inline-block; box-sizing: border-box; min-width: 18px; min-height: 18px; border: 2px solid #2172be; vertical-align: middle; background: #ffffff; }
.bbradio_inner { display: none; box-sizing: border-box; width: 14px; height: 14px; max-width: 14px; max-height: 14px; border: 2px solid #ffffff; background: #2172be; }
.bbradio_text { font: 400 14px lato; color: #656a78; display: inline-block; margin-left: 8px; vertical-align: middle; }
.bbradio_label .bbradio_hidden:checked ~ .bbradio_box .bbradio_inner { display: block; }
/*.paymentoptionbox { display: inline-block; vertical-align: middle;  width: 22px; height: 22px; border: 1px solid #2172be; box-sizing: border-box; cursor: pointer; }*/

@media only screen and (max-width: 891px){	
	.bbcheck_label, .bbradio_label { width: 100%; }
	.bbcheck_text, .bbradio_text { max-width: calc(100% - 35px); }
}

.videoTranscript { background: #f6f5f3; padding: 5px 10px 10px 10px; margin-top: 10px; }
.videoTranscriptLink { text-align: right; }

.mobilecollapseheader { display: none; }
@media only screen and (max-width: 891px){	
	/* todo: make these into a reusable style and apply to the container for each section? */
	.mobilecollapseheader { display: block; padding: 10px 0; background: url('/2018wf/overall/expand.png') no-repeat right center; }
	.mobilecollapseheader.opened { background-image: url('/2018wf/overall/collapse.png'); padding-bottom: 30px; background-position-y: calc(50% - 10px); /*-10px adjusts for half the extra 20px of padding on bottom*/ }
	.mobilecollapseheaderinner { font: 300 16px oswald; color: #232a3b; }
	.mobilecollapsecontainer { padding-top: 20px; padding-bottom: 15px; border-top: 1px solid #f6f5f3; }
	.mobilecollapseheader:not(.opened) + .mobilecollapsecontainer { display: none; }
}
@media only screen and (max-width: 891px){	
	.multicamp .coachesprofile .mobilecollapseheader  { display: block; padding: 10px 0; background: url('/2018wf/overall/expand.png') no-repeat right center; }
	.multicamp .coachesprofile .mobilecollapseheader.opened  { background-image: url('/2018wf/overall/collapse.png'); padding-bottom: 30px; background-position-y: calc(50% - 10px); /*-10px adjusts for half the extra 20px of padding on bottom*/ }
	.multicamp .coachesprofile .mobilecollapseheaderinner { font: 300 16px oswald; color: #232a3b; }
	.multicamp .coachesprofile .mobilecollapsecontainer { padding-top: 20px; padding-bottom: 15px; border-top: 1px solid #f6f5f3; }
	.multicamp .coachesprofile .mobilecollapseheader:not(.opened) + .mobilecollapsecontainer { display: none; }
}
@media only screen and (min-width: 891px){
	.multicamp .coachesprofile .mobilecollapseheader  { display: block; padding: 10px 0; background: url('/2018wf/overall/expand.png') no-repeat left center; cursor: pointer; }
	.multicamp .coachesprofile .mobilecollapseheader.opened  { background-image: url('/2018wf/overall/collapse.png'); cursor: pointer; padding-bottom: 30px; background-position-y: calc(50% - 10px); /*-10px adjusts for half the extra 20px of padding on bottom*/ }
	.multicamp .coachesprofile .mobilecollapseheaderinner { font: 300 16px oswald; color: #232a3b; }
	.multicamp .coachesprofile .mobilecollapsecontainer { padding-top: 20px; padding-bottom: 15px;  }
	.multicamp .coachesprofile .mobilecollapseheader:not(.opened) + .mobilecollapsecontainer { display: none; }
}
.supernav { background-color: #232a3b; }
.supernav > .contentwrapper { height: 20px; padding-top: 10px; padding-bottom: 10px; }
.valuestatement { font: 300 14px lato; color: #ffffff; float: left;}
.supernav-right { float: right; text-align: right; }
.sitesearch { background-color: #151924; border-radius: 10px; width: 120px; height: 20px; display: inline-block;}
.sitesearchbox { background-color: #151924; margin: 1px 10px; width: 100px; height: 16px; border: none; font: 300 14px lato; color: #ffffff; display: inline-block; text-align: center; }
.sitesearchbox:focus { outline: none; }
.sitesearchbox::placeholder { color: #cccccc; }
.sitesearchbox:focus::placeholder { color: transparent; }
.supernav-right-separator { color: #09090b; margin: 0px 10px 0px 10px; display: inline-block; font-size: 16px; }
a.memberlogin { display: inline-block; font: 300 14px lato; color: #ffffff; }
.memberusername, .memberusername:visited { display: inline-block; font: 700 14px lato; color: #ffffff; text-decoration: none; }

.promobanner, .promobanner-m { display: block; background-color: #d8e0ef; text-align: center; }
.promobanner a, .promobanner a:hover, .promobanner a:visited, .promobanner-m a, .promobanner-m a:hover, .promobanner-m a:visited 
			{ display: block; padding: 10px 15px; text-align: center; font: 400 18px lato; color: #232a3b; text-decoration: none; }
.promobanner-m a { font-size: 12px; }

.logobar { height: 80px; }
.logo { height: 64px; padding: 8px 0px; display:block; float:left; }
.findcampcontainer { float: right; width: 280px; height: 80px; text-align: right; }
.findcamplabel { width: 260px; display: inline-block; height: 18px; margin-top: 5px; font: 400 14px oswald; color: #656a78; text-align: left; }
/*.findcampzip { width: 180px; display: inline-block; margin-top: 2px; vertical-align: top; }*/
.findcampbutton, a.findcampbutton, a.findcampbutton:hover, a.findcampbutton:visited { width: 75px; height: 36px; display: inline-block; margin-top: 2px; vertical-align: top; background-color: #2172be; background-position: center right 21%; }
.findcampselect { margin-top: 5px; width: 190px; }

@media only screen and (max-width: 891px){
	.logobar { height: 50px; }
	.logo { height: 38px; padding: 6px 0 6px 0; }
	.logo img { height: 38px; }
}

.menubar { box-shadow: 0px 10px 15px 0px rgba(0, 0, 0, 0.1); }

@media only screen and (min-width: 891px){
	.menubar > .contentwrapper { text-align: justify; font-size: .1px; }
	.menubar > .contentwrapper:after { content: ''; width: 100%; display: inline-block; }
	.menusection { display: inline-block; box-sizing: border-box; padding: 10px 0px 5px 0px; cursor: pointer; position: relative; overflow: visible; }
	.menusectionheader, a.menusectionheader:hover, a.menusectionheader:visited { padding: 0px 10px; font: 400 18px oswald; color: #232a3b; text-decoration: none; }
	.menuheadercamps { margin-left: -10px; }
	.menuheaderstayconnected { margin-right: -10px; }
	.menusectionheader img { vertical-align: middle; }
	.menusectionheader span { vertical-align: middle; }
	.menuicon { display: inline-block; margin-left: 2px; margin-top: 2px; background: url('/2018wf/overall/menu/navigatedown.png') no-repeat center center; width: 10px; height: 7px; }
	.menuitemscontainer { display: none; position: absolute; left: 0px; top: 40px; min-width: 100%; padding: 15px 0px 10px 0px; border-top: 2px solid #2172be; white-space: nowrap; box-shadow: 0px 10px 10px 0px rgba(0, 0, 0, 0.1); background-color: #ffffff; z-index: 99999; }
	.menucampscontainer { padding: 0px; } /* for camps menu, doesn't expand */
	.menusection:hover .menuitemscontainer, .menuitemscontainer:hover { display: block; }
	.menusection:hover .menuicon, .menuitemscontainer:hover + .menusectionheader .menuicon { background: url('/2018wf/overall/menu/navigateup.png') no-repeat center center; }
	a.menuitem, a.menuitem:hover, a.menuitem:visited { display: block; padding: 5px 10px; font: 300 16px oswald; color: #656a78; text-decoration: none; }
	a.menuitem:hover { background-color: #d8e0ef; }
}
@media only screen and (max-width: 891px){
	.menubar:not(.expanded) { display: none; }
	.mobilemenubutton { float: right; height: 20px; padding-top: 20px; margin-top: 10px; text-align: center; font: 400 12px oswald; color: #656a78; background-image: url('/2018wf/overall/mobilemenu.png'); background-position: top center; background-repeat: no-repeat; }
	.mobilemenubutton.expanded { background-image: url('/2018wf/overall/mobilemenuclose.png'); }
	.menusection { width: 100vw; position: relative; left: 50%; right: 50%; margin: 0 -50vw; padding: 0 15px; box-sizing: border-box; }
	.menusection + .menusection { border-top: 2px solid #d8e0ef; }
	.menusectionheader-m, a.menusectionheader-m:hover, a.menusectionheader-m:visited { font: 400 18px oswald; color: #232a3b; text-decoration: none; padding: 16px 0; }
	.menusectionheader-m { display: block; width: 100%; background-image: url('/2018wf/overall/expand.png'); background-position: right center; background-repeat: no-repeat; }
	.menuheadercamps-m, .memberusername-m, .memberlogin-m { background-image: url('/2018wf/overall/navright.png'); }
	.memberusername-m, .memberusername-m:visited { color: #f3871b; }
	.menusection.expanded .menusectionheader-m { background-image: url('/2018wf/overall/collapse.png'); }
	.menusection:not(.expanded) .menuitemscontainer { display: none; }
	.menuitemscontainer { width: 100%; }
	a.menuitem, a.menuitem:hover, a.menuitem:visited  { display: block; width: 100vw; position: relative; left: 50%; right: 50%; margin: 0 -50vw; padding: 16px 15px; box-sizing: border-box; background-color: #d8e0ef; font: 300 16px oswald; color: #656a78; text-decoration: none; }
	a.menuitem + .menuitem { border-top: 2px solid #ffffff; }
}

.newsletterbar { background-color: #f6f5f3; padding-top: 35px; padding-bottom: 35px; }
.newsletterbar > .contentwrapper { max-width: 960px; margin: 0 auto; }
.newsletterlabelcontainer { width: 100%; }
.newslettericon { width: 25px; height: 19px; float: left; vertical-align: top; margin-top: 4px; }
.newsletterlabel { vertical-align: top; width: 100%; box-sizing: border-box; padding-left: 40px; font: 400 18px lato; color: #232a3b; }
.newsletterformcontainer { width: 100%; height: 40px; margin-top: 30px; }
.newsletterformcolumn { width: 18%; display: inline-block; vertical-align: top; }
.newsletterformcolumn:not(:last-of-type) { margin-right: 2.5%; }
.newsletterbutton { background: #2172be; padding: 0; }

.newsletterbar-m { display: block; background-color: #f6f5f3; padding-top: 15px; padding-bottom: 15px; }
.newsletterbar-m > .contentwrapper { font: 400 14px lato; color: #232a3b; text-align: center; }
.newsletterbar-m span { display: inline-block; margin-bottom: 10px; }

/* Similar too newsletter bar but used inline on certain pages like /fitness/increase-vertical-jump.html */
.newsletterjumpcontainer { max-width: 500px; margin: 0 auto; background-color: #f6f5f3; padding: 25px 35px 15px 35px; border-radius: 10px; }
.newsletterjumpheader { font: 400 18px lato; color: #232a3b; font-weight: 700; text-align: center; }
.newsletterjumpformcontainer { width: 90%; max-width: 400px; margin: 0 auto; padding: 10px 0; }
.newsletterjumpformcontainer > *:not(.noshow) { display: block; width: 100%; margin: 10px 0; }
.newsletterjumpbutton { background: #2172be; padding: 0; width: 100%; }
@media only screen and (max-width: 891px){
	.newsletterjumpcontainer { padding: 20px 20px 10px 20px; }
	.newsletterjumpformcontainer { width: 100%; }
}

.footer { background-color: #232a3b; padding-top: 35px; padding-bottom: 35px; } 
.footercontent { font-size: .1px; text-align: justify; max-width: 960px; margin: 0 auto; }
.footercontent:after { content: ''; width: 100%; display: inline-block; }
.footercontent > div { display: inline-block; vertical-align: top; }
.footerheading { width: 100%; height: 20px; margin-bottom: 25px; display: inline-block; font: 400 18px oswald; color: #ffffff; line-height: 20px; }
.footercontent span, .footercontent a { font: 300 14px lato; color: #ffffff; display: block; width: 100%; vertical-align: middle; margin-bottom: 7px; }
.footercontent a img { margin-right: 10px; vertical-align: middle; }

@media only screen and (max-width: 891px){
	.footer { padding: 0 }
	.footercontent > div { display: block; width: 100vw; position: relative; left: 50%; right: 50%; margin: 0 -50vw; padding: 0 15px; box-sizing: border-box; }
	.footercontent > div + div { border-top: 2px solid #151924; }
	.footerheading { margin: 0; padding-top: 15px; padding-bottom: 15px; background-image: url('/2018wf/overall/expand-footer.png'); background-repeat: no-repeat; background-position: right center; }
	.footerheading.expanded { background-image: url('/2018wf/overall/collapse-footer.png'); }
	.footer a { width: 100vw; position: relative; left: 50%; right: 50%; margin: 0 -50vw; padding: 16px 15px; box-sizing: border-box; background-color: #151924; text-decoration: none; font-size: 16px; }
	.footer a + a { border-top: 2px solid #232a3b; }
	.footer .footerheading:not(.expanded) ~ span, .footer .footerheading:not(.expanded) ~ a { display: none; }
}

.subfooter { overflow: hidden; padding-top: 10px; padding-bottom: 15px; }
.copyright { float: left; font: 300 14px lato; color: #232a3b; }
.subfooter-right { float: right; }
.subfooter-right a { float: right; margin-left: 25px; font: 300 14px lato; color: #232a3b; }

@media only screen and (max-width: 891px){
	.subfooter { text-align: center; }
	.copyright { width: 100%; text-align: center; float: none; } 
	.subfooter-right { width: 100%; max-width: 400px; display: inline-block; float: none; text-align: justify; margin-top: 5px; margin-bottom: 5px; font-size: .1px; }
	.subfooter-right:after { content: ''; width: 100%; display: inline-block; }
	.subfooter-right a { float: none; margin: 0; display: inline-block; } 
}

.exitintentpopupoverlay { display: none; position: fixed; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(19, 22, 31, .6); }
.exitintentpopup { position: relative; width: 800px; height: 390px; margin: 175px auto 0 auto; border-radius: 10px; background-color: #ffffff; box-shadow: 0px 10px 15px 0px rgba(0, 0, 0, 0.1); }
@media only screen and (max-height: 680px) { .exitintentpopup { margin-top: 75px; } }
.popup-left { display: inline-block; width: 500px; padding: 35px 10px 10px 20px; box-sizing: border-box; font: 400 18px lato; color: #232a3b; }
.popup-header { font: 400 40px oswald; color: #2172be; margin-bottom: 20px; }
.popup-subheader { font-weight: 700; }
.popup-checkmark, .popup-star { font-size: 16px; padding-left: 25px; margin-top: 15px; vertical-align: middle; background-image: url('/2018wf/overall/check.png'); background-position: left center; background-repeat: no-repeat; }
.popup-star { background-image: url('/2018wf/overall/star.png'); }
.popup-left-footer { margin-top: 30px; }
.popup-right { position: absolute; left: 500px; right: 0; top: 0; bottom: 0; padding: 10px 15px; background-color: #f6f5f3; border-radius: 0 10px 10px 0; }
.popup-close { float: right; background-image: url('/2018wf/overall/popupclose.png'); background-repeat: no-repeat; cursor: pointer; width: 25px; height: 25px; }
.popupformcontainer { margin-top: 30px; }
.popup-right label { font: 400 14px oswald; color: #656a78; display: block; }
.popup-right input[type="text"], #popup-right select { margin-bottom: 12px; display: block; width: 270px; height: 36px; box-sizing: border-box; padding: 1px 2px 1px 2px; border: 1px solid #656a78; border-radius: 2px; font: 300 14px lato; color: #656a78; }
.popup-right input[type="text"] { padding-left: 6px; }
.popup-button { width: 270px; height: 36px; cursor: pointer; margin-top: 5px; }

.mobilepopup { display: none; position: fixed; z-index: 20; left: 0; bottom: 0; width: 100%; background-color: #f6f5f3; font: 400 14px lato; color: #232a3b; padding: 15px; box-sizing: border-box; text-align: center; }
.mobilepopupclose { position: absolute; top: -22.5px; right: 5px; background-image: url('/2018wf/overall/popupclose.png'); background-repeat: no-repeat; background-position: center center; cursor: pointer; width: 25px; height: 25px; padding: 10px; }
.mobilepopupheader { font: 400 18px oswald; color: #2172be; margin-top: 0px; margin-bottom: 2px; }
.mobilepopupbutton { display: inline-block; width: 170px; height: 36px; cursor: pointer; margin-top: 10px; margin-bottom: 10px; }

/* copied these stytles from ongagemonster "Shooting Popup 2 Duplicate" campaign, which has some built-in om styles, but we want to use them on custom html campaigns. These are our own class names, added to the custom html. */
input.omtextinput { color: #666878 !important; font-size: 20px !important; font-weight: 700 !important; font-family: Lato !important; background: #f9fbff !important; border-style: solid !important; border-color: rgba(60, 91, 151, 0.28) !important; border-top-width: 2px !important; border-right-width: 2px !important; border-bottom-width: 2px !important; border-left-width: 2px !important; border-top-left-radius: 5px !important; border-top-right-radius: 5px !important; border-bottom-right-radius: 5px !important; border-bottom-left-radius: 5px !important; display: block !important; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 10px !important; margin-left: 0px !important; padding-top: 0px !important; padding-right: 20px !important; padding-bottom: 0px !important; padding-left: 20px !important; max-width: 100% !important; width: 100% !important; height: auto !important; line-height: normal !important; }
input.omsubmitbutton { background: #0ac208 !important; border-bottom-left-radius: 5px !important; border-bottom-right-radius: 5px !important; border-bottom-width: 0px !important; border-color: rgba(0,0,0,.35) !important; border-left-width: 0px !important; border-right-width: 0px !important; border-style: none !important; border-top-left-radius: 5px !important; border-top-right-radius: 5px !important; border-top-width: 0px !important; box-shadow: 0px 0px 0px 0px #ffffff !important; color: #ffffff !important; font-family: Lato !important; font-size: 23px !important; font-weight: 800 !important; -webkit-letter-spacing: 0 !important; -moz-letter-spacing: 0 !important; -ms-letter-spacing: 0 !important; letter-spacing: 0 !important; line-height: 1 !important; margin-bottom: 0px !important; margin-left: 0px !important; margin-right: 0px !important; margin-top: 0px !important; max-width: 100% !important; padding-bottom: 20px !important; padding-left: 12px !important; padding-right: 12px !important; padding-top: 20px !important; text-transform: none !important; -webkit-text-decoration: none !important; text-decoration: none !important; width: 100% !important; cursor: pointer; }
input.omsubmitbutton:hover { background: #05f602 !important; box-shadow: 0px 0px 0px 0px #ffffff !important; color: #ffffff !important; font-family: Lato !important; font-size: 20px !important; font-weight: 800 !important; -webkit-letter-spacing: 0 !important; -moz-letter-spacing: 0 !important; -ms-letter-spacing: 0 !important; letter-spacing: 0 !important; line-height: 1 !important; text-transform: none !important; -webkit-text-decoration: none !important; text-decoration: none !important; border-bottom-left-radius: 5px !important; border-bottom-right-radius: 5px !important; border-bottom-width: 0px !important; border-color: rgba(0,0,0,.35) !important; border-left-width: 0px !important; border-right-width: 0px !important; border-style: none !important; border-top-left-radius: 5px !important; border-top-right-radius: 5px !important; border-top-width: 0px !important; }
select.omselect { color: #666878 !important; font-size: 20px !important; font-weight: 700 !important; font-family: Lato !important; background: #f9fbff !important; border-style: solid !important; border-color: rgba(60, 91, 151, 0.28) !important; border-top-width: 2px !important; border-right-width: 2px !important; border-bottom-width: 2px !important; border-left-width: 2px !important; border-top-left-radius: 5px !important; border-top-right-radius: 5px !important; border-bottom-right-radius: 5px !important; border-bottom-left-radius: 5px !important; display: block !important; margin-top: 0px !important; margin-right: 0px !important; margin-bottom: 10px !important; margin-left: 0px !important; padding-top: 0px !important; padding-right: 20px !important; padding-bottom: 0px !important; padding-left: 20px !important; max-width: 100% !important; width: 100% !important; } /* mostly copied from omtextinut styles */
/* for ongagemonster exit-intent popups, the textinput and select both have omtextinput and omomselect classes too, but omexitsubmitbutton is by itself and mostly copies btnsubmit*/
input.omexittextinput { display: inline-block !important; margin-left:3% !important; width: 60% !important }
select.omexitselect { display: inline-block !important; width: 36% !important; }
input.omexitsubmitbutton { margin-top: 5px; border: 0; border-radius: 2px; box-sizing: border-box; background: #f3871b; font: 400 20px oswald; color: #ffffff; display: inline-block; width: 100%; height: 54px; padding: 6px 2px 6px 2px; vertical-align: top; text-align: center;  }
input.omexitsubmitbutton:hover { }
@media only screen and (max-width: 891px){ 
	select.omexitselect { width: 100% !important; }
	input.omexittextinput { margin-left: 0px !important; width: 100% !important; }
}

.om-callout{ background-color: #f6f5f3; border: 1px solid #656a78; border-radius:4px;padding:20px}
.om-callout2 { background-color:#e7f4ff;border:1px solid #acdaff; border-radius:4px;padding:20px }

.errorpagewrapper { background: #f6f5f3; }
.errorpage { height: 100px; padding-top: 100px; color: red; font-size: 16px; }


/* /members area styles */
.membersareacontainer { margin: 50px auto; max-width: 800px; font-size: 15px; }
.ordertable { }
.ordertable td { padding: 10px; border: 1px solid #dddddd; }
.orderheaders td { font-weight: bold; }
.order_product_link, .order_download_link { display: block; min-width: 120px; }
.order_product_link + .order_product_link, .order_download_link + .order_download_link{ margin-top: 10px; }
a.order_download_link { font-weight: bold; color: #f3871b; }
.order_amount { color: blue; }
.order_refunded { color: green; min-width: 120px; }

@media only screen and (max-width: 891px){
	.orderheaders { display: none; }
	.ordertable td { border: none; padding: 5px; border-left: 1px solid #dddddd; border-right: 1px solid #dddddd; display: block; /* display on separate rows */ }
	.ordertable tr td:last-of-type { margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid #dddddd; }
	.ordertable tr { border-top: 1px solid #dddddd; }
	ul.css-tabs { display: inline-block; height: auto; padding-bottom: 1px; } /* see also: /scripts/jquery/jquerytools/membertabs.css */
}


