@charset "utf-8";

/* ==========================================================================
 Photo Gallery
 ========================================================================== */
.gallery,
.album,
.photo {
	float: left;
	display: block;
	overflow: hidden;
	width: 100px;
	height: 140px;
	margin: 0 2rem 2rem;
	line-height: 1.5rem;
	text-align: center;
}

a.photo img {
	width: 100px;
	height: 100px;
	padding: 0.4rem;
	border: 1px solid #473019;
}

a.photo:hover img { border-color: #000; }

a.photo p {
	margin: 0;
	text-align: center;
	color: #473019;
}

a.photo:hover p { color: #000; }



/* ==========================================================================
 Banners
 ========================================================================== */
.banner_main,
.banner_main .banners {
	position: relative;
	max-width: 1500px;
	max-height: 650px;
	z-index: 1;
	margin: 0 auto;
	margin-top: .5rem;
}

.banners .banner {
	position: relative;
	float: left;
}

.banners .banner img {
	float: left;
	width: 100%;
}

.banners .banner a {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	display: block;
}

.banners .banner .bottom {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 10px;
	background: repeat url("/images/body/banner_bg.png");
}

.banners .banner .bottom .display_title {
	font-size: 2rem;
	color: #fff;
}

.banner_main .control {
	position: absolute;
	width: 100%;
	text-align: center;
	bottom: 1.6rem;
	left: 0;
	z-index: 500;
	height: 1.6rem;
	font-size: 1.1rem;
	line-height: 1.6rem;
}

.banner_main .control .nav a,
.banner_main .control .stop_play {
	display: inline-block;
	width: 1.6rem;
	height: 1.6rem;
	margin-left: 6px;
	text-align: center;
	text-decoration: none;
	color: #F6F4F3;
	background-color: #F6F4F3;
	-moz-border-radius: 100%;
	-webkit-border-radius: 100%;
	border-radius: 100%;
	cursor: pointer;
}

.banner_main .control.no_num,
.banner_main .control .stop_play {
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}

.banner_main .control .nav a:hover,
.banner_main .control .nav a.active_slide,
.banner_main .control .stop_play:hover {
	background-color: #F03A47;
	color: #F03A47;
}

.banner_main .control .nav a.active_slide:hover {
	background-color: #265FBC;
	color: #265FBC;

}

.banner_main .control .stop_play {
	display: none;
	background-image: url("/images/body/banner_stop_play.png");
	background-repeat: no-repeat;
}

.banner_main .control .stop { background-position: -16px 0; }
.banner_main .control .play { background-position: 0 0; }


/* ==========================================================================
 Calendar & Events
 ========================================================================== */
.event_event { margin: 1rem 0; }

.event_event span {
	display: inline-block;
	width: 90px;
}

.event_month { margin: 1rem 0 2.5rem; }

.event_month h3 {
	width: 100%;
	margin: 0 0 0.4rem;
	padding: 0;
	color: #333;
	font-weight: bold;
	border-bottom: 1px solid #333;
}

.event_details {
	margin: 1.5rem 0 2rem;
	padding: 0;
	list-style: none;
}

.event_desc {
	border: 1px solid #ccc;
	border-width: 1px 0;
}

.event_details li {
	position: relative;
	margin-top: 0.3rem;
	padding-left: 20px;
	line-height: 18px;
}

.event_details li span {
	position: absolute;
	top: 1px;
	left: 0;
	display: block;
	width: 16px;
	height: 16px;
	background: no-repeat url(/images/body/event_icons.gif);
}

.event_details li.address_location span { background-position: 0 0; }
.event_details li.register span { background-position: 0 -16px; }
.event_details li.contact span { background-position: 0 -32px; }
.event_details li.date span { background-position: 0 -48px; }
.event_details li.pdf span { background-position: 0 -64px; }
.event_details li.rate span { background-position: 0 -80px; }
.event_details li.ics span { background-position: 0 -112px; }

.event_details a.location {
	font-weight: normal !important;
	color: #22225b !important;
}

.event_details a.location em { color: #76a962 !important; }


/* ==========================================================================
 FAQ (questions and answer listing)
 ========================================================================== */
#faqs h3 {
	font-size: 1.6rem;
	font-weight: bold;
}

#faqs .faq_list { margin: 0 0 2.5rem; }

#faqs .faq_list .question_link {
	width: 100%;
	margin: 0 0 1rem;
	color: #666;
	font-weight: bold;
	cursor: pointer;
}

#faqs .faq_list .question_link:hover { text-decoration: underline; }

#faqs .faq_list .answer {
	display: none;
	margin: 0 0 1.5rem 1.5rem;
	color: #000;
}


/* ==========================================================================
 News Articles listing
 ========================================================================== */
.news_status {
	float: right;
}

.news_articles { margin: 2rem 0; }

.news_article { margin-bottom: 2.5rem; }

.news_article .title {
	font-size: 2rem;
    font-weight: bold;
}

.news_article .date, .article_details .date {
	font-style: italic;
}

.article_details .description {
	font-size: 1.6rem;
}

.news_article .intro {
	/* placeholder for intro styling */
}


/* ==========================================================================
 News Articles comments
 ========================================================================== */
.comment_contain {
	margin-top: 1.5rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px dashed #fff;
}

.comment_contain.last { border-bottom: 0; }

.comment_contain .avatar {
	float: left;
	width: 70px;
	height: 70px;
}

.comment_contain .comment {
	min-height: 70px;
	padding-left: 80px;
}

.comment_contain .comment .header {
	font-size: 1.3rem;
	margin-bottom: 1rem;
}

.comment_contain .comment .header a, 
.comment_contain .comment .header span { font-weight: bold; }


/* ==========================================================================
 News Articles comment submission form
 ========================================================================== */
textarea.news_comment_textarea { height: 300px; }


/* ==========================================================================
 Partners
 ========================================================================== */
.partners {
	display: flex;
	flex-wrap: wrap;
}

.partner {
	float: left;
	width: 50%;
	margin-bottom: 1.5rem;
	padding-right: 1.5rem;
}

.partner .partner_logo {
	float: left;
	width: 25%;
}

.partner .partner_logo img {
	max-width: 100%;
}

.partner .partner_text {
	float: left;
	width: 75%;
	padding-left: 1rem;
}

.partner .partner_name {
	/* placeholder for name styling */
}

.partner .partner_location {
	/* placeholder for location styling */
}

.partner .partner_phone {
	/* placeholder for phone styling */
}



/* ==========================================================================
 Partner Widget
 ========================================================================== */
.partner_widget {
    height: auto;
    display: flex;
    flex-wrap: wrap;
    padding-left: 1.5rem;
	text-align: center;
	padding-top: 2rem;
}

.partner1 {
	width: 16.66%;
	padding-right: 1rem;
	padding-bottom: 1rem;
}

.partner1 img {
	max-width: 100%;
	max-height: 100%;
}


/* ==========================================================================
 Resources & Links
 ========================================================================== */
.resources .resource {
	margin-bottom: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid #ccc;
}

.resources .resource a.pdf,
.resources .resource a.www {
	padding-left: 20px;
	background-position: 0 50%;
	background-repeat: no-repeat;
}

.resources .resource a.pdf { background-image: url(/images/body/pdf-icon.gif); }
.resources .resource a.www { background-image: url(/images/body/www-icon.gif); }

.resources .resource p { margin-bottom: 0; }

/* ==========================================================================
 Sub-Banners
 ========================================================================== */
.subbanners {
	padding-left: 1.6rem;
	overflow: hidden;
	margin-top: 5rem;
}

.subbanner {
	position: relative;
	min-height: 18.8rem;
	margin-bottom: 1.6rem;
	padding: 3.2rem;
	background-color: #265FBC;
	color: #F6F4F3;
}

.subbanner:last-of-type { margin-bottom: 0; }

.subbanner img {
	max-width: 115px;
	float: left;
	margin-top: 3%; /*magic number*/
}

.subbanner .link_button {
	background-color: #F6F4F3;
	color: #265FBC;
	border: none;
	padding: 1.4rem 1.8rem;
	line-height: .5;
	font-size: 1.8rem;
}

.subbanner .link_button svg {
	display: inline-block;
	width: 12px;
	vertical-align: baseline;

	transition: all .125s linear;
	-webkit-transition: all .125s linear;
	-moz-transition: all .125s linear;
	-o-transition: all .125s linear;
}

.subbanner .link_button:hover,
.subbanner .link_button:focus { padding-right: 3.2rem; }

.subbanner .link_button:hover svg,
.subbanner .link_button:focus svg { margin-left: 1rem; }

.subbanner .subbanner_text { padding-left: 16rem; }

.subbanner .subbanner_name {
	display: block;
	width: 100%;
	font-size: 3.2rem;
	font-weight: 300;
	line-height: 1;
	margin-bottom: 1rem;
}

.subbanner .subbanner_description p {
	margin: 0 0 1rem;
}


/* ==========================================================================
 YouTube Videos
 ========================================================================== */
.video_main .player {
	position: relative;
	float: left;
	width: 65%;
	max-width: 600px;
	padding-right: 1rem;
}

.video_main .video_loading {
	position: absolute;
	top: 50%;
	left: 50%;
	display: inline-block;
	width: 60px;
	height: 60px;
	margin: -30px 0 0 -30px;
}

.video_main .video_loading img { width: 100%; }

.video_main .video_embed {
	position: relative;
	overflow: hidden;
	height: 0;
	padding: 30px 0 62.5%;
}

.video_main .video_embed iframe,
.video_main .video_embed object,
.video_main .video_embed embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.video_main h2,
.video_main h3 { margin-top: 0; }

.video_main .list {
	float: left;
	width: 35%;
	margin: 1rem 0;
	padding-left: 1rem;
}

.video_main .list ul {
	padding: 0;
	list-style: none;
}

.video_main .list li { padding: 0.2rem 0; }

.video_main .list .active {
	font-weight: bold;
	color: #000;
	text-decoration: none;
	cursor: default;
}

.fgrid-recaptcha {
	float: left;
	width: 100%;
	margin-bottom: 2rem;
}

input[name="vsi2"] {
	display: none;
}


/* ==========================================================================
Tablet view (less than 1000 pixels)
========================================================================== */
@media all and (max-width: 1005px) {
	.banner_main, .banner_main .banners {
		margin-top: 8rem;
	}
}


/* ==========================================================================
Tablet view (less than 800 pixels)
========================================================================== */
@media all and (max-width: 800px) {
	.banner_main, .banner_main .banners {
		float: left;
		margin-top: -1rem;
	}
	
	.subbanners {
		float: left;
		width: 100%;
		padding-left: 0;
		margin-top: 0;
	}

	.subbanner {
		width: 100%;
		padding: 3.2rem 1.6rem;
		margin-bottom: 1.6rem;
	}
	
	.partner1 { width: 25%; }

	.video_main .player {
		float: none;
		width: 100%;
		padding-right: 0;
	}

	.video_main .list {
		float: none;
		width: 100%;
		padding-left: 0;
	}
}

/* ==========================================================================
Tablet view (less than 620 pixels)
========================================================================== */
@media all and (max-width: 620px) {
	.partner1 { width: 33%; }
	
	.banner_main .control {
		display: none;
	}
}

/* ==========================================================================
Tablet view (less than 520 pixels)
========================================================================== */
@media all and (max-width: 520px) {
	.subbanner img {
		float: none;
		display: block;
		margin: 0 auto 1.6rem auto;
	}

	.subbanner .subbanner_text {
		padding: 0;
		text-align: center;
	}

	.subbanner .link_button { margin-top: 1.6rem; }

	.partner { width: 100%; }
	
	.partner1 { width: 50%; }
	
	.partner .partner_logo {
		width: 110px;
	}
	
	.partner .partner_logo img {
		width: auto;
    	height: 100%;
	    max-width: 100%;
	}
	
	.partner .partner_text {
		width: calc(100% - 110px);
	}
}