/**** Main Stylesheet for Harvey ***/

/* Google Font Import - Jost */
@import url('https://fonts.googleapis.com/css?family=Jost:400,500,700&display=swap');
/* Google Font Import - Spectral */
@import url('https://fonts.googleapis.com/css?family=Spectral:500,600&display=swap');
@import '../../_common/css/accred_logo.css';

/* Font families

	font-family: 'Jost', sans-serif;
	font-family: 'Spectral', serif;
*/

/* Base Font size (used for determining REMs)
	18px
*/


html,body{ font-family: 'Jost', sans-serif; font-size: 112.5%; line-height: 155%; margin: 0; padding: 0; height: 100%;}
html{ overflow-x: hidden; overflow-y: auto;}

.flex{ display: flex;}

.wrapper{ margin: 0 auto; width: 90%; max-width: 1170px;} 

/* Font Styles - Headings */
h1,h2,h3,h4,h5{ font-family: 'Spectral', serif;}
h1,h2,h3,h4,h5,h6{ margin: 0; padding: 0;}

h1{ font-size: 3.777777777777778rem; line-height: 103%; color: #fff; font-weight: 500; letter-spacing: -1px;}
h2{ font-size: 2.777777777777778rem; line-height: 112%; color: #151210; font-weight: 500; letter-spacing: -1px;}
h3{ font-size: 2.222222222222222rem; line-height: 115%; color: #151210; font-weight: 500; letter-spacing: -0.8px;}
h4{ font-size: 1.222222222222222rem; line-height: 118%; color: #151210; font-weight: 600;}
h5{ font-size: 1rem; line-height: 144%; color: #151210; font-weight: 600;}
h6{ font-size: 0.7777777777777778rem; line-height: 171%; color: #151210; text-transform: uppercase; letter-spacing: 2px;}

p{ font-size: 1rem; line-height: 155%; color: #151210; font-weight: 400;}
p.small{ font-size: 0.8333333333333333rem; line-height: 167%;}
p.large{ font-size: 1.222222222222222rem; line-height: 136%;}
a{ text-decoration: underline; text-decoration-color: var(--color-base-1); text-underline-position: under; color: #000; transition: all 0.3s; font-weight: 400;}
a:hover{ color: var(--color-base-1);}


/* buttons */
.button{ display: inline-flex; text-decoration: none; position: relative; align-items: center; justify-content: space-between; padding: 0 0 0 2rem; background: rgba(var(--color-rgb-1),0.8); transition: all 0.3s; color: var(--color-overlay-1); font-size: 0.7777777777777778rem; font-weight: 500; text-transform: uppercase; letter-spacing: 2px; border-radius: 4px; overflow: hidden; white-space: nowrap;}
.button:hover{ background: rgba(var(--color-rgb-1),1); color: var(--color-overlay-1);}
.button span.button_icon{ font-size: 0; margin-left: 2rem; padding: 1rem; background: var(--color-base-1); display: flex; align-items: center;}
.button span.button_icon svg{ height: auto; width: 40px; vertical-align: middle;}
.button span.button_icon svg, .button span.button_icon svg *{ fill: var(--color-overlay-1) !important;}
.button:before{ content:""; position: absolute; top: 0; left: 0; background: #fff; width: 100%; height: 100%; z-index: -1; border-radius: 4px;}


/** Tool Headings **/
h3.toolhead{ margin-bottom: 2rem;}

.right_column h3.toolhead{ font-size: 1.777777777777778rem; line-height: 132%; letter-spacing: -1px;}

/********* HEADER **************/
header{ position: relative; z-index: 999; margin: 0; padding: 0;}

header .wrapper{ max-width: 100%;}

.header_top{ background: var(--color-base-1); padding: 1rem 0;}
.header_top .wrapper{ justify-content: space-between;}
.header_top .wrapper.no_utils{justify-content: end;}

.header_top .wrapper.align_right{ justify-content: flex-end;}

.quicklinks_container{ display: flex; align-items: center;}
.quicklinks_container a{ display: inline-block; color: var(--color-overlay-1); text-decoration: none; margin-right: 1rem; font-size: 0.8333333333333333rem; letter-spacing: 1px; transition: all 0.3s;}
.quicklinks_container a:last-child{ margin-right: 0;}
.quicklinks_container a:hover{ text-decoration: underline;}

.header_contact_container{ align-items: center;}
.header_phone, .header_email{ display: flex; align-items: center; }
.header_phone a, .header_email a{ font-size: 0.8333333333333333rem; letter-spacing: 1px; text-decoration: none; color: var(--color-overlay-1); transition: all 0.3s;}
.header_phone a:hover, .header_email a:hover{ text-decoration: underline;}

.header_phone + .header_email{ margin-left: 1rem;}

.contact_label{ margin-right: 10px; font-size: 0; opacity: 0.5;}
.contact_label svg{ height: 15px; width: auto; vertical-align: middle;}
.contact_label svg, .contact_label svg *, .header_social_media svg, .header_social_media svg *{ fill: var(--color-overlay-1) !important;}

.header_social_media{ display: flex; align-items: center; margin-right: -0.75rem;}
.header_social_media a{ font-size: 0; margin: 0 0.5rem; padding: 0 0.25rem; transition: all 0.3s;}
.header_social_media a:hover{ opacity: 0.5;}
.header_social_media svg{ height: 18px; width: auto; vertical-align: middle;}

.header_social_media svg, .header_social_media svg *{ fill: var(--color-overlay-1) !important;}

.header_bottom_bar > .wrapper{ align-items: center; justify-content: space-between;}
.header_right_container{ display: flex; align-items: center; margin-left: 2rem;}

.logo{ font-size: 0; min-width: 190px; display: flex;}
.logo a{ display: flex;}
.logo img{ max-height: 90px; max-width: 100%} /* 10-4-21 */

.header_logo {font-size: 1.50rem; color: var(--color-base-1);}
a.header_logo {text-decoration: none!important;}

.nav_panel{ position: relative; background: #fff;}

/** Desktop Search Form **/
@media all and (min-width: 1100px){
	.header_search_container{ position: relative; margin-left: 1rem;}
	
	.header_search_icon{ font-size: 0; background: var(--color-base-2); border-radius: 50%; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; transition: all 0.3; cursor: pointer;}
	.header_search_icon:hover{ background: var(--color-base-1);}
	.header_search_icon svg{ vertical-align: middle; height: 15px; width: auto;}
	.header_search_icon svg, .header_search_icon svg *{ fill: var(--color-overlay-2) !important;}
	.header_search_icon:hover svg, .header_search_icon:hover svg *{ fill: var(--color-overlay-1) !important;}
	.header_search_form_container{ position: absolute; opacity: 0; top: 0; right: 0; transition: all 0.3s; background: #fff; z-index: -1; display: flex; padding: 1rem;}
	.header_search_form_container.open{ opacity: 1; top: calc(100% + 2rem);}
	
	.header_search_form_container legend{ display: none;}
	.header_search_form_container fieldset{ border: none; padding: 0; margin: 0;}
	.header_search_form_container input[type=search]{ padding: 10px 5px; font-family: 'Jost', sans-serif; font-size: 0.7777777777777778rem; border-color: #C1C7CA; border-radius: 3px;}
	
	.header_search_submit{ background: none; border: none; font-size: 0; cursor: pointer;}
	.header_search_submit svg, .header_search_submit svg *{ fill: var(--color-base-2) !important;}
	
}


/********* FOOTER **************/
footer{ background: var(--color-base-1);}

.footer_top{ padding: 5vw 0;}
.footer_top > .wrapper{ justify-content: space-between;}

.footer_logo{ font-size: 0; display: flex; text-decoration: none;} /* 10-4-21 */
.footer_logo img{ display: block; max-width: 285px; height: auto; max-height: 150px;} /* 10-4-21 */

.footer_logo .fallback_logo{ color: var(--color-overlay-1);}/* 10-4-21 */

.contact_icon{ font-size: 0; margin-right: 1rem; display: inline-block; vertical-align: middle; opacity: 0.75;}
.contact_icon svg{ width: 18px; height: auto; vertical-align: middle;}
.contact_icon svg, .contact_icon svg *{ fill: var(--color-overlay-1) !important;}

.footer_logo + address{ margin-top: 2.5rem;}

address{ font-style: normal; color: var(--color-overlay-1); font-size: 1rem; line-height: 155%; font-weight: 400;}

.address2{margin-top:1rem; border-top: 1px dotted #fff; padding-top: 1rem;}

.contact_info .address_line{ display: block;}

.phone a, .email a{ font-style: normal; color: var(--color-overlay-1); font-size: 1rem; line-height: 155%; font-weight: 400; text-decoration: none; transition: all 0.3s;}
.phone a:hover, .email a:hover{ text-decoration: underline; text-decoration-color: var(--color-overlay-1);}

address + .phone, address + .email{ margin-top: 0.75rem;}

.phone + .email{ margin-top: 0.75rem;}

/* .accreditation{ align-items: center; justify-content: space-around; margin-top: 2.5rem;}
.accred_item{ max-width: 25%;}
.accred_item_3{ max-width: 33%;}
.accred_item_2_1{ max-width: 50%;}
.accred_item img{ display: block; max-width: 100%; max-height: 50px;} */

.footer_col h6{ color: var(--color-overlay-1); opacity: 0.7; margin-bottom: 0.5rem;}

.footer_social_icons{ justify-content: flex-end; margin-right: -0.5rem;}
.footer_social_icons a{ font-size: 0; margin: 0 0.5rem; padding: 0 0.5rem;}
.footer_social_icons svg{ height: 22px; width: auto; transition: all 0.3s; vertical-align: middle;}
.footer_social_icons a svg, .footer_social_icons a svg *{ fill: var(--color-overlay-1) !important;}
.footer_social_icons a:hover svg, .footer_social_icons a:hover svg *{ opacity: 0.7;}

.footer_nav_col{ margin: 0 9.4vw 0 0;}
/* .footer_nav_col.no_margin{ margin: 0;} */
.footer_nav{ list-style: none; margin: 0; padding: 0;}
.footer_nav li{ margin: 0.25rem 0;}
.footer_nav a{ color: var(--color-overlay-1); text-decoration: none;}
.footer_nav a:hover{ text-decoration: underline; text-decoration-color: var(--color-overlay-1);}

.footer_utility_nav{ list-style: none; margin: 0; padding: 0;}
.footer_utility_nav li{ margin: 0.25rem 0;}
.footer_utility_nav a{ color: var(--color-overlay-1); text-decoration: none;}
.footer_utility_nav a:hover{ text-decoration: underline; text-decoration-color: var(--color-overlay-1);}

.footer_social_icons + .footer_links_container{ margin-top: 2.5rem;}

.footer_bottom{ padding: 1.5rem 0; border-top: solid 1px rgba(255,255,255,0.7);}

.credits{ justify-content: space-between; align-items: center;}
.copyright{ margin: 0; padding: 0; color: var(--color-overlay-1);}

.credit_logo img{ display: block; opacity: 0.5; height: 20px; width: auto; transition: all 0.3s;}
.credit_logo:hover img{ opacity: 1;}

.nce_logo img {max-height: 40px;}
.aware_logo img {max-height: 20px;}

.footer_statement_container{ text-align: center; padding-top: 1rem;}
.footer_statement_text{ color: var(--color-overlay-1); margin: 0; padding: 0;}
.footer_statement_text a{ color: var(--color-overlay-1);}

.footer_logo .fallback_logo {font-size: 1.75rem;}

/********* INSIDE PAGES **************/

#main_container{ padding: 5.88235294117647vw 0;}
#main_container ul, #main_container ol{ font-size: 1rem; line-height: 155%; color: #151210; font-weight: 400;}

/* inside buttons */
#main_container .button_container{ display: inline-block;}

.right_column .button{ max-width: 100%; white-space: normal;}

/* inside content editor images with floats */
.middle_column .detail_padding img[style*="float:left;"]{ margin: 0 2rem 2rem 0 !important;}
.middle_column .detail_padding img[style*="float:right;"]{ margin: 0 0 2rem 2rem !important;}

/* inside content editor images shape and caption */
.detail_padding img{ border-radius: 8px;}

.detail_padding figure.image{ margin: 2rem 0; position: relative;}
.detail_padding figure.image img{ display: block; width: calc(100% - 2rem); height: auto; margin: 0 auto; position: relative; z-index: 2;} 

.detail_padding figure.image .editor_image_container + .caption, .detail_padding figure.image .editor_image_container + figcaption{ margin-top: 1rem;}

.detail_padding figure.image .caption, .detail_padding figure.image figcaption{ font-size: 0.8333333333333333rem; color: rgba(0,0,0,0.8);}

/* banner area */
.banner{ position: relative; width: 100%; background: var(--color-base-1);}
.banner.has_photo{ background: #000;}

.banner h1.page_title{ color: var(--color-overlay-1);}
.banner.has_photo h1.page_title{ color: #ffffff;}

.banner_photo_container{ opacity: 0.25; width: 100%; position: absolute; z-index: 1; overflow: hidden; top: 0; left: 0; height: 100%;}
.banner_photo_container img{ width: 100%; height: 100%; object-fit: cover;}

.banner_content{ position: relative; z-index: 2; width: 90%; margin: 0 auto; padding: 5vw 0; text-align: center;}
.banner.has_photo .banner_content{ padding: 11.64705882352941vw 0;}

.breadcrumbs{ margin-top: 1.5rem; display: flex; align-items: center; justify-content: center; flex-flow: wrap;}
.breadcrumb_item a{ text-transform: uppercase; font-size: 0.7777777777777778rem; text-decoration: none; font-weight: 500; letter-spacing: 2px; opacity: 0.8; color: #fff; vertical-align: middle;}
.breadcrumb_divide{ font-size: 0; vertical-align: middle; margin: 0 1rem;}
.breadcrumb_divide svg{ height: 14px; width: auto; vertical-align: middle; opacity: 0.8;}
.breadcrumb_divide svg, .breadcrumb_divide svg *{ fill: #fff !important;}

/* inside page layout */
.middle_column, .right_column{ display: inline-block; vertical-align: top;}

.middle_column{ width: 100%;}
.middle_column.with_right{ width: 66%;}

.right_column{ margin-left: 12%; width: calc(22% - 7px);}

/** inside menu **/
#inside_nav + .right_per_detail{ margin-top: 4rem;}
#menu ul{ list-style: none; margin: 0; padding: 0;}
#menu > ul{ border-left: solid 1px #C1C7CA;}
#menu ul li a{ margin: 0.75rem 0 0.75rem 0;}

#menu > ul > li:first-child a{ margin-top: 0;}
#menu > ul > li:last-child a{ margin-bottom: 0;}

#menu ul ul{ margin-left: 1.5rem;}

#menu ul li a{ text-decoration: none; display: inline-block; padding-left: 1.5rem;}

#menu > ul > li > a{ text-transform: uppercase; letter-spacing: 2px; font-size: 0.7777777777777778rem; font-weight: 500; position: relative;}
#menu > ul > li > a:hover{ border-left: solid 4px var(--color-base-1);}

#menu ul li li a{ font-size: 1rem; font-weight: 400;}
#menu ul li li li a{ font-size: 0.8333333333333333rem; font-weight: 400;}

#menu ul li li a:hover, #menu ul li li li a:hover{ text-decoration: underline;}



/********* HOME PAGE **************/

h2.section_title{ text-align: center;}

/* hero */
.hero{ position: relative; background: #000;}
.hero.has_hero_video.no_hero_text{ padding-top: 50vh;}

.hero_image_slideshow, .hero_video{ position: absolute !important; width: 100%; height: 100%; top: 0; left: 0; opacity: 0.5; z-index: 0; overflow: hidden;}
.hero_image_slideshow *{ height: 100% !important;}
.slide_img_item{ background-size: cover; background-position: center; background-repeat: no-repeat;}
.hero_image_slideshow img, .hero_video video{ width: 100%; height: 100%; object-fit: cover;}

.hero_slideshow_container, .hero_video_text_container{ position: relative; z-index: 3; padding: 31.77966101694915vh 0 27.54237288135593vh 0;}
.slide_text_item{ width: 100%; text-align: center; }

h2.hero_title{ color: #fff; font-size: 3.777777777777778rem;}
.slide_text_item p{ color: #fff;}

.hero_nav{ position: absolute; z-index: 2; bottom: 5vh; left: 50%; transform: translateX(-50%); display: flex; align-items: center;}
.hero_arrow{ background: none; border: none; font-size: 0; cursor: pointer;}
.hero_arrow svg{ height: 30px; width: auto;}
.hero_arrow svg, .hero_arrow svg *{ fill: #fff !important;}

.hero_arrow.hero_prev{ order: 1;}
.hero_arrow.hero_next{ order: 3;}

.hero_nav .slick-dots{ list-style: none; margin: 0 1rem; padding:0; display: flex; order: 2; align-items: center;}
.hero_nav .slick-dots li button{ font-size: 0; background: #C1C7CA; height: 1px; width: 60px; transition: all 0.3s; border: none; cursor: pointer; display: flex;}
.hero_nav .slick-dots li.slick-active button, .hero_nav .slick-dots li:hover button{ height: 4px; background: var(--color-base-2);}


/* events */
.events_container{ border-top: solid 1px rgba(255,255,255,0.25); padding: 5.29661016949153vh 0; position: relative; z-index: 2;}

.events_container > .wrapper{ justify-content: space-around;}

.event_item{ align-items: flex-start; width: calc(33.333333333% - 50px);}
.event_item *{ color: #fff;}

.event_item .date_container{ padding-right: 1rem;}
.event_item .date{ margin: 0; padding: 0; white-space: nowrap; font-weight: 700;}

.event_item p.event_desc, .event_item .time{ opacity: 0.8;}

.event_button{text-align: center; margin-top: 1rem}
.event_button .button{ background: rgba(var(--color-rgb-3),0.8); color: var(--color-overlay-3);}
.event_button .button:hover{ background: rgba(var(--color-rgb-3),1);}
.event_button .button span.button_icon {background: var(--color-base-3);}
.event_button .button span.button_icon svg *{fill: var(--color-overlay-3) !important; }
/* home story section */
.home_story{ padding: 6rem 0 0 0;}

.story_container{ margin-bottom: 5.55rem; justify-content: space-between;}

.story_title_container{ width: 24.4%; padding-right: 9.8%;}
.story_right_col{ width: 65.8%;}
.story_subtitle{ margin: 0; padding: 0;}

.story_buttons_container{ margin-top: 2rem;}
.story_buttons_container.full{ margin: 0 auto;}
.story_buttons_container .button:first-child{ background: rgba(var(--color-rgb-3),0.8); color: var(--color-overlay-3);}
.story_buttons_container .button:first-child:hover{ background: rgba(var(--color-rgb-3),1);}

.story_buttons_container .button:first-child span{ background: var(--color-base-3);}
.story_buttons_container .button:first-child span svg, .story_buttons_container .button:first-child span svg *{ fill: var(--color-overlay-3) !important;}

.story_buttons_container > .button + .button{ margin-left: 1.5rem;}

/* story video */

.section1_video_container{ margin: 0 auto; max-width: 970px; width: 90%; position: relative; overflow: hidden; margin-bottom: -272.5px; z-index: 2;}
.section1_video_container.no_overlay{ margin-bottom: 6rem;}
.section1_video_container video{ display: block; width: 100%; height: auto; position: relative; z-index: 1; border-radius: 8px;}

.section1_video_button_container{ position: absolute; top: 50%; left: 50%; transform: translateX(-50%) translateY(-50%); z-index: 2;}

.hero + .section1_video_container{ margin-top: 5rem;}

.extra-bottom-padding{
	padding-bottom: 2rem;;
}

/* home stats */
.home_stats{ position: relative; padding: 4rem 0; background: #101415;}
.home_stats.editor_only{ padding: 6rem 0;}
.home_stats.has_video{ padding: calc(272.5px + 3.444rem) 0 5.77rem 0;}

.stats_bg_container{ position: absolute; width: 100%; height: 100%; top: 0; left: 0; z-index: 1; opacity: 0.25;}
.stats_bg_container img{ display: block; width: 100%; height: 100%; object-fit: cover;}

.home_stats > .wrapper{ position: relative; z-index: 2; text-align: center;}
.home_stats > .wrapper *{ color: #fff;}
.home_stats .stat_text {font-size: 0.7777777777777778rem; line-height: 171%; color: #151210; text-transform: uppercase; letter-spacing: 2px; color: #fff;    display: block; margin-block-start: 2.33em; margin-block-end: 2.33em; margin-inline-start: 0px; margin-inline-end: 0px;  font-weight: bold; unicode-bidi: isolate; margin: 0; padding: 0;  }

.stats_text_container + .stats_container{ margin-top: 2rem;}
 
.stats_container{ justify-content: space-around; align-items: center;}
.stat_item{ width: 100%; border-right: solid thin rgba(255,255,255,0.25); box-sizing: border-box; text-align: center;}
.stat_item:last-child{ border-right: none;}
.stat_item p{ margin: 0; padding: 0;}

/* home announcements */
.home_announcements{ background: #F9FAFA; padding: 5rem 0 3.055555555555556rem 0;}

.home_announcements h2 + .news_feed_container{ margin-top: 3rem;}

.news_item{ padding: 0 0.5rem;}

.news_item h4 a{ text-decoration: none;}

.news_img_container{ position: relative; padding: 0.75rem; height: 12.5rem; display: flex; align-items: center; justify-content: center;} /** edited on 11-8-21 by WA **/
.news_img_container.no-img{ overflow: hidden; height: 12.5rem; z-index: 2; display: block; display: flex; align-items: center; justify-content: center; padding: 0.75rem;}

.news_img_container img{ background: #fff; position: relative; z-index: 2; border-radius: 4px;}  /** edited on 11-8-21 by WA **/

.news_item .background_color{ position: absolute; top: 0.75rem; left: 0.75rem; width: calc(100% - 1.5rem); background: var(--color-base-1); height: calc(100% - 1.5rem); z-index: 1; border-radius: 4px;}

.news_img_container a, .news_img_window{ overflow: hidden; border-radius: 4px; height: 12.5rem; width: 100%; z-index: 2; display: block; position: relative;}
.news_img_container.no-img a{ display: flex; align-items: center; justify-content: center;}
.news_img_container a img, .news_img_window img{ object-fit: cover; width: 100%; height: 100%;}
.news_img_container.no-img a img{ object-fit: normal; width: auto; height: auto; max-width: 90%;}
.news_img_container.no-img img{ background: none; padding: 0;}  
.news_img_container img{ position: relative; z-index: 2;}

.news_item .background_shape{ position: absolute; z-index: 0; width: 100%; height: 50%; bottom: 0; left: 0; transition: all 0.3s; background: rgba(var(--color-rgb-2),0.8); border-radius: 4px;}

.news_img_container > a:hover + .background_shape{ height: 100%;}

.news_item_content{ padding: 1rem 0.75rem 0;}

.news_item_arrow{ position: absolute; bottom: 0; right: 0; width: 60px; height: 60px; display: flex; align-items: center; justify-content: center; font-size: 0; background: var(--color-base-1); z-index: 3;}
.news_item_arrow svg{ height: 20px; width: auto; vertical-align: middle;}
.news_item_arrow svg, .news_item_arrow svg *{ fill: var(--color-overlay-1) !important;}

.news_slider_nav{ margin-top: 3rem; display: flex; align-items: center; justify-content: center;}

.news_arrow{ background: none; border: none; font-size: 0; cursor: pointer;}
.news_arrow svg{ height: 30px; width: auto;}
.news_arrow svg, .news_arrow svg *{ fill: #151210 !important;}

.news_arrow.news_prev{ order: 1;}
.news_arrow.news_next{ order: 3;}

.news_arrow.slick-disabled{ opacity: 0;}

.news_slider_nav .slick-dots{ list-style: none; margin: 0 1rem; padding:0; display: flex; order: 2; align-items: center;}
.news_slider_nav .slick-dots li button{ font-size: 0; background: #C1C7CA; height: 1px; width: 60px; transition: all 0.3s; border: none; cursor: pointer; display: flex;}
.news_slider_nav .slick-dots li.slick-active button, .news_slider_nav .slick-dots li:hover button{ height: 3px; background: var(--color-base-2);}

/* home image gallery */
.home_gallery{ padding: 5rem 0;}

.home_gallery h2 + .home_gallery_carousel{ margin-top: 3rem;}

.home_gallery_item{ padding: 0 1rem;}

.gallery_img{ overflow: hidden; border-radius: 4px 4px 0 0; display: block; background: #000; position: relative;}
.open_gallery_icon{ opacity: 0; transition: all 0.3s; position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%);}

.open_gallery_icon svg{ height: 40px; width: auto;}
.open_gallery_icon svg, .open_gallery_icon svg *{ fill: #fff !important;}

.gallery_img img{ display: block; width: 100%; height: auto; transition: all 0.3s;}
.gallery_img:hover img{ opacity: 0.3;}

.gallery_img:hover .open_gallery_icon{ opacity: 1;}

.gallery_item_button{ width: calc(100% - 2rem); border-radius: 0 0 4px 4px;}

.home_gallery_slider_nav{ margin-top: 3rem; display: flex; align-items: center; justify-content: center;}

.gallery_arrow{ background: none; border: none; font-size: 0; cursor: pointer;}
.gallery_arrow svg{ height: 30px; width: auto;}
.gallery_arrow svg, .gallery_arrow svg *{ fill: #151210 !important;}

.gallery_arrow.gallery_prev{ order: 1;}
.gallery_arrow.gallery_next{ order: 3;}

.gallery_arrow.slick-disabled{ opacity: 0;}

.home_gallery_slider_nav .slick-dots{ list-style: none; margin: 0 1rem; padding:0; display: flex; order: 2; align-items: center;}
.home_gallery_slider_nav .slick-dots li button{ font-size: 0; background: #C1C7CA; height: 1px; width: 60px; transition: all 0.3s; border: none; cursor: pointer; display: flex;}
.home_gallery_slider_nav .slick-dots li.slick-active button, .home_gallery_slider_nav .slick-dots li:hover button{ height: 3px; background: var(--color-base-2);}

.gallery_hidden{ display: none;}

.featherlight-content .gallery_content_container{ position: relative;}
.featherlight-content .gallery_content_container img{ max-height: 75vh; display: block; width: auto;}
.gallery_item_content{ position: absolute; bottom: 0; left: 0; background: rgba(0,0,0,0.75); width: 100%; padding: 1rem 0;}
.gallery_item_content *{ color: #fff;}
.gallery_item_content > *{ padding: 0 calc(70px + 1rem); margin: 0;}

.featherlight-next span, .featherlight-previous span{ font-size: 25px !important; display: inline-block !important;}
.featherlight-next, .featherlight-previous{ background: rgba(255,255,255,0.25) !important;}
.featherlight-previous{ right: calc( 100% - 70px) !important;}
.featherlight-next{ left: calc( 100% - 70px) !important;}

/* home cta section */
.home_cta{ position: relative; background: #000; padding: 5rem 0; text-align: center;}
.home_cta.no_bg{ background: none;}
.cta_bg_container{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; opacity: 0.25;}
.cta_bg_container img{ display: block; object-fit: cover; width: 100%; height: 100%;}

.home_cta > .wrapper{ max-width: 970px;}

.home_cta_content{ position: relative;}
.home_cta_content h3{ color: #fff;}
.home_cta_content p{ color: #fff;}

.cta_buttons_container{ text-align: center; margin-top: 1.5rem;}

.cta_buttons_container .button span{ position: relative; z-index: 1;}
.cta_buttons_container .button::before{ z-index: 0; opacity: 0.2; transition: all 0.3s;}
.cta_buttons_container .button:hover::before{ opacity: 0;}

.cta_buttons_container .button:first-child{ background: rgba(var(--color-rgb-3),1); color: var(--color-overlay-3);}
.cta_buttons_container .button:first-child:hover{ background: rgba(var(--color-rgb-3),1);}

.cta_buttons_container .button:first-child span.button_icon{ background: var(--color-base-3);}
.cta_buttons_container .button:first-child span.button_icon svg, .cta_buttons_container .button:first-child span.button_icon svg *{ fill: var(--color-overlay-3) !important;}

.cta_buttons_container > .button + .button{ margin-left: 1.5rem;}

/** faculty table fix - added on 7-6-21 by WA **/
.staff_sec table{ font-size: 16px;}
.dir-head-link{ font-weight: 600;}

/** sidebar mini cal fix - added on 7-23-21 by WA **/
.detail_minical .calendar_grid{ font-size: 13px;}

/** sidebar announcements expand font size fix - added on 8-27-21 by WA **/
.expand-container span{ font-size: 1rem !important; line-height: 155% !important; color: #151210 !important; font-weight: 400 !important;}

/* added on 9-15-21 by WA - reduce font size of right sidebar calendar */
.calendar_list{ font-size: 0.8rem;}

.staff_sec .sort_box .sortby-select a {color: #ffffff;}
.staff_sec .sort_box .sortby-select a:hover {text-decoration: underline!important;}
.staff_sec .sort_box .sortby-select li {line-height: 100%!important;}
.detail_profiles .staff_header .profile ul li a {color: #ffffff!important;}
.detail_profiles .staff_header .profile ul li a:hover {text-decoration: underline!important;}


/********* MEDIA QUERIES **************/

@media all and (max-width: 1100px){
	.nav_panel{ position: fixed; right: -110%; top: 50px; width: 100vw; height: 100vh; transition: all 0.3s; z-index: 1000;}
	.nav_panel.open{ right: 0;}
	html.open_nav{ overflow: hidden;}
	
	.nav_panel_content{ max-height: calc(100vh - 50px); overflow: auto;}
	
	.header_top{ padding: 0; height: 50px; display: flex;}
	
	.header_bottom_bar{ padding: 1rem 0;}
	
	.header_top .quicklinks_container, .header_social_media, .header_search_container, .contact_label{ display: none;}
	
	.header_top .wrapper{ justify-content: center; width: 98%;}

	.header_contact_container{ width: 100%; justify-content: center;}
	.header_email, .header_phone{ max-width: 50%; overflow: hidden; text-overflow: ellipsis;}
	
	.logo{ max-width: calc(100% - 2rem - 50px);}
	
	.header_right_container{ margin-left: 0;}
	
	.mobile_top_row{ display: flex; align-items: center; justify-content: space-between; margin: 1rem auto; width: 90%;}
	
	.mobile_search_container{ width: calc(100% - 1rem - 50px);}
	.header_search_form_container{ display: flex; border: solid 1px #C1C7CA; border-radius: 3px; }
	.header_search_form_container legend{ display: none;}
	.header_search_form_container fieldset{ border: none; padding: 0; margin: 0;}
	.header_search_form_container input[type=search]{ padding: 10px 5px; font-family: 'Jost', sans-serif; font-size: 0.7777777777777778rem; border: none; width: 100%;}
	
	.header_search_submit{ background: none; border: none; font-size: 0; cursor: pointer; order: 2;}
	.header_search_submit svg, .header_search_submit svg *{ fill: var(--color-base-2) !important;}

	.header_search_form_container form{ order: 1; width: calc(100% - 2rem);}
	
	.mobile_bottom_row{ margin: 2rem 0 0 0; background: var(--color-base-1); padding: 2rem 0;}
	.utility_nav{ display: flex; flex-direction: column; margin: 0 auto; width: 90%;}
	.utility_nav a{ display: inline-block; padding: 0.25rem 0; margin: 0.25rem 0; text-decoration: none; color: var(--color-overlay-1); font-size: 1rem;}
	
	
	.hero.has_hero_video.no_hero_text{ padding-top: 0;}
	
	/* events */
	.events_container > .wrapper{ flex-direction: column; align-items: center;}
	.event_item{ width: 100%; margin-bottom: 1.5rem; justify-content: center;}
	.event_item .event_desc{ display: none;}
	
	/** INSIDE PAGES **/
	.middle_column.with_right{ width: calc(100% - 237px); }

	.right_column{ margin-left: 30px; width: 200px;}
	
	#main_container .button{ padding-left: 1rem;}
	#main_container .button span.button_icon{ margin-left: 1rem;}
}


@media all and (max-width: 970px){
	.section1_video_container{ margin-bottom: -25%;}
	.home_stats.has_video{ padding: calc(25% + 3.444rem) 0 3rem 0;}
}

@media all and (max-width: 960px){
	.home_story{ padding: 3rem 0 0 0;}
	.story_container{ flex-direction: column; margin-bottom: 3rem;}
	
	.story_title_container{ width: 100%; padding-right: 0;}
	.story_right_col{ width: 100%;}
	
	.story_title_container + .story_right_col{ padding-top: 1rem;}
	
	.story_buttons_container{ display: block; text-align: center;}
	.story_buttons_container > .button + .button{ margin-left: 0; margin-top: 1.5rem;}
	
	.stats_container{ flex-flow: wrap;}
	.stat_item{ width: 50%; padding: 1.5rem;}
	
	.stat_item:nth-child(1){ border-bottom: solid thin rgba(255,255,255,0.25);}
	.stat_item:nth-child(2){ border-bottom: solid thin rgba(255,255,255,0.25); border-right: none;}
	.stat_item:nth-child(4){ border-right: none;}
	
	.section1_video_container.no_overlay{ margin-bottom: 3rem;}
	
	.cta_buttons_container{ display: block; text-align: center;}
	.cta_buttons_container > .button + .button{ margin-left: 0; margin-top: 1.5rem;}
	
	/*** FOOTER ***/
	.footer_top > .wrapper, .footer_links_container{ flex-direction: column; justify-content: center; align-items: center;}
	
	.footer_col{ text-align: center;}
	.footer_logo{ justify-content: center;}
	
	.footer_social_icons, address > .flex{ justify-content: center;}
	
	.footer_nav_col{ margin: 0;}
	
	.footer_left + .footer_right, .footer_nav_col + .footer_links_col{ margin-top: 2.5rem;}
	
	.footer_social_icons svg{ height: 25px;}
	.footer_social_icons a {padding: 0;}
}


/* Mobile and Tablet */
@media all and (max-width: 767px){
	/* mobile font styles */
	h1{ font-size: 2.5rem; line-height: 111%;}
	h2{ font-size: 1.888888888888889rem; line-height: 124%;}
	h3{ font-size: 1.555555555555556rem; line-height: 121%; font-weight: 600; letter-spacing: 0;}
	h4{ font-size: 1rem; line-height: 144%;}
	p.large{ font-size: 1.111111111111111rem; line-height: 150%; font-size: 14px;}
	
	.nav_panel_content{ max-height: calc(100vh - 150px); overflow: auto;}
	
	/** INSIDE PAGES **/
	.middle_column.with_right{ width: 100%;}

	.right_column{ margin-left: 0; width: 100%; margin-top: 3rem; padding-top: 3rem; border-top: solid 5px rgba(0,0,0,0.2);}
	
	/** HOME PAGE **/
	
.hero_slideshow_container, .hero_video_text_container{ padding: 34.66666666666667vw 0 0;}
	h2.hero_title{ font-size: 1.5rem; max-width: 90%; margin: 0 auto;}
	.hero.has_hero_video p.large{ margin: 1rem auto 1rem; max-width: 90%; font-size: 14px;}
    .hero.has_hero_video {height: 973px;}
    .hero.has_hero_video .events_container {bottom: -319px; padding: 0;}
    .hero.has_hero_slideshow .button {font-size: 12px; letter-spacing: normal;line-height: 100%; height: 36px;}
    .hero.has_hero_slideshow .hero_slideshow_container {padding: 34.66666666666667vw 0 3em;}
	.hero_nav{ width: 90%; top: 100%;} /* 41vh; */
	.hero_nav .slick-dots{ width: 100%; justify-content: center;}
	.hero_nav .slick-dots li{ max-width: 6vw; width: 100%;}
	.hero_nav .slick-dots li button{ width: 100%; height:4px;}
	
	.home_announcements{ padding: 3rem 0;}
	.news_slider_nav{ margin-top: 0;}
	.home_announcements h2 + .news_feed_container{ margin-top: 1rem;}
	.news_arrow{ padding: 1rem 0;}
	
	.news_slider_nav .slick-dots{ width: 100%; justify-content: center;}
	.news_slider_nav .slick-dots li{ max-width: 4vw; width: 100%;}
	.news_slider_nav .slick-dots li button{ width: 100%;}
	
	.gallery_slider_nav .slick-dots{ width: 100%; justify-content: center;}
	.gallery_slider_nav .slick-dots li{ max-width: 4vw; width: 100%;}
	.gallery_slider_nav .slick-dots li button{ width: 100%;}
	
	.home_gallery{ padding: 3rem 0;}
	.home_gallery h2 + .home_gallery_carousel{ margin-top: 1rem;}
	
	.home_cta{ padding: 3rem 0;}
	.cta_buttons_container > .button + .button{ margin-left: 0; margin-top: 1rem;}
	
	.story_buttons_container .button, .cta_buttons_container .button{ width: calc(90% - 2rem);}
	
	.gallery_item_button{ width: calc(100% - 1rem); padding: 0 0 0 1rem;}
	
	.button{ padding: 0 0 0 1rem;}
	.button span.button_icon{ margin-left: 1rem;}
	.button span.button_icon svg{ width: 25px;}
	
	.credits{ justify-content: center; flex-direction: column;}
	.copyright + .credit_logo{ margin-top: 1rem;}
	
	/* inside buttons */
	#main_container .button_container{ display: block; text-align: center;}
	
	/* inside nav/right col */
	#right_within{ display: flex; flex-direction: column;}
	#inside_nav{ order: 1000; width: 100%; margin-top: 3rem; padding-top: 3rem; border-top: solid 5px rgba(0,0,0,0.2);}
	
	#inside_nav + .right_per_detail{ margin-top: 0; }
}
@media all and (max-width: 600px){
	
}

/* SM 3.0 CSS */
.tool_content, #inside_nav { font-family: 'Jost', sans-serif;}
.sm3_header_right .account_info a{ font-weight: 500;}
#sm3_body footer{ background: none !important; padding: 0; border: none !important;}
#sm3_body .page_heading_row h1{ font-family: inherit; text-transform: none;}
#sm3_body .main-section{ border: none !important;}

/*EA*/
.hero .events_container .event_title a:hover{
	color: #fff !important;
	text-decoration-color: #fff !important;
}

.sort_box ul a,.profile.active ul a,.social_icon_bar a{text-decoration: none;}


/* Screen Reader Only class */
.sr-only {
    border: 0 !important;
    clip: rect(1px, 1px, 1px, 1px) !important;
    -webkit-clip-path: inset(50%) !important;
    clip-path: inset(50%) !important;
    height: 1px !important;
    margin: -1px !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    width: 1px !important;
    white-space: nowrap !important;
}


/** Color Variables **/
:root{
	--color-base-1: #0a1931;
	--color-rgb-1: 10,25,49;

	--color-base-2: #185adb;
	--color-rgb-2: 24,90,219;
	
	--color-base-3: #feddbe;
	--color-rgb-3: 254,221,190;
	
	--color-overlay-1: #ffffff;
	--color-overlay-2: #ffffff;
	--color-overlay-3: #000000;
	
}


.detail_minical .calendar_form .month_header {
    font-size: 1.2em;
}

.inside a{ font-weight: 700; }
.inside a:not(.button):hover{ text-decoration: none; color: var(--color-base-1); }


/** Tool Headings **/
h3.toolhead{ margin-bottom: 2rem;font-weight:700;color:var(--color-base-1);}

/* buttons - modified for SM3 since arrow icon not possible*/
.ck-content .button{
    padding: 0 1.5rem;
	line-height: 3;
}

/* CK Content Editor 
	.too(l-content: views tool content before clicking to edit the tool
		- cannot hover over individual words, therefore no hover state defined for anchor
	.ck-content: views tool content after clicking to edit the tool
*/

/* Anchor NOT button */
.ck-content a:not(.button,.dir-head-link), .tool_content a:not(.button,.dir-head-link){ 
	text-decoration: underline; 
	text-decoration-thickness: 2px ;
	text-decoration-color: var(--color-base-1); 
	text-underline-position: under; 
	color: var(--color-base-1); 
	transition: all 0.3s; font-weight: 400;
}
.ck-content a:not(.button):hover{ 
	text-decoration-color: var(--color-base-2) !important;  
}


/** Headings' Levels**/
.ck-content h1, .tool_content h1,
.ck-content h2, .tool_content h2,
.ck-content h3, .tool_content h3,
.ck-content h4, .tool_content h4,
.ck-content h5, .tool_content h5,
.ck-content h6, .tool_content h6
{
	margin: 0; 
	padding: 0;
	font-family: 'Spectral', serif;
	/* color: var(--gray-dark); */
	margin-top: 1.5rem;
	margin-bottom: 1rem;
}

/* Headings */

.middle_column h2, .middle_column h3, .middle_column h4, .middle_column h5, .middle_column h6, 
.right_per_detail h2, .right_per_detail h3, .right_per_detail h4, .right_per_detail h5, .right_per_detail h6 {
	line-height: 1.2;
  }

  .middle_column h2, .middle_column h5, 
  .right_per_detail h2, .right_per_detail h5 {
	color: var(--color-base-1);
  }

  .middle_column h4, .middle_column h6, 
  .right_per_detail h4, .right_per_detail h6 {
	font-style: italic;
  }

.middle_column h2 {
	font-size: 3.6rem;
  }
  .middle_column h3 {
	font-size: 3rem;
  }
  .middle_column h4 {
	font-size: 1.9rem;
	text-transform: uppercase;
	letter-spacing: -0.02em;
  }
  .middle_column h5 {
	font-size: 1.6rem;
  }
  .middle_column h6 {
	font-size: 1rem;
	text-transform: uppercase;
  }
  /* .middle_column p, .middle_column li, .middle_column li a, .middle_column div, .middle_column article, .middle_column section {
	font-size: 1.125rem;
  } */
  
  .right_per_detail h2 {
	font-size: 2.3rem;
  }
  .right_per_detail h3 {
	font-size: 1.9rem;
  }
  .right_per_detail h4 {
	font-size: 1.4rem;
	text-transform: uppercase;
	letter-spacing: -0.02em;
  }
  .right_per_detail h5 {
	font-size: 1.3rem;
  }
  .right_per_detail h6 {
	font-size: 0.875rem;
	text-transform: uppercase;
  }
  .right_per_detail p, .right_per_detail li, .right_per_detail li a, .right_per_detail div, .right_per_detail article, .right_per_detail section {
	font-size: 1rem;
  }



/** Quotes **/
.ck-content blockquote, .tool_content blockquote, blockquote{ 
	display: block; 
	/* background: rgba(var(--color-rgb-1),0.15);  */
	padding: 1.5rem 1.5rem 1.5rem 2rem !important; 
	border-left: none !important;
	margin: 0 !important;
	font-style: italic; 
}
.ck-content blockquote p, .tool_content blockquote p,  blockquote p{ margin: 0;}
/* .ck-content p + blockquote,.tool_content p + blockquote{padding-top:0 !important;} */
.ck-content blockquote > *, .tool_content blockquote > *, blockquote > *{ 
	font-size: 1.22rem !important; 
	line-height: 136% !important; 
	font-family: 'Spectral', serif !important;
}

/* lists */
.middle_column ul li, .middle_column ol li,
.right_content ul li, .right_content ol li,
.ck-content ul li, .ck-content ol li
{margin: .25rem;}

/* Tool handle */
a.sm3_tool_handle{
	text-decoration: none !important;
	font-weight: 400 !important;
	&:hover{
		text-decoration: none !important;
	}
}

/* Remove underline on button */
.ck-content .button:hover{
    text-decoration: none !important;
}

/* Site-wide Alert Button */
.swal2-html-container a{
	padding: 0 1.2rem;
}

a.dir-head-link:hover{
	color:#fff !important;
}