/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace, monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type="button"],[type="reset"],[type="submit"],button{-webkit-appearance:button}[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type="checklist"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}

/* screen reader */
.sr-only {border:0;clip:rect(0, 0, 0, 0);height:1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}
.sr-only-focusable:active,.sr-only-focusable:focus{clip:auto;height:auto;overflow:visible;position:static;white-space:normal;width:auto}

/* vars */
:root {
	--primary: #e5edf4;
	--secondary: #435363;
	--headers: #4196B4;
	--form_bg: #435363e0;
	--light: #ffffff;
	--dark: #000000;
	--gradient: linear-gradient(180deg, #4196B4 40%, #6EBE49 100%);
}

html {height: 100%; scroll-behavior: smooth}
body {background-color: var(--primary); display: flex; flex-direction: column; font-family: sans-serif; margin: 0 auto; max-width: 1920px; min-height: 100%}
[id] {scroll-margin-top: 7rem}
a {color: inherit}
a:hover{text-decoration: underline}
img {height: auto; max-width: 100%}
.container {padding: 0 1em}
.container > :first-child, .copy > :first-child {margin-top: 0}
.container > :last-child, .copy > :last-child {margin-bottom: 0}
.tbl {border-collapse: collapse; border-style: hidden; display: table; table-layout: fixed; width: 100%}
.tbl_row {display: table-row}
.tbl_cell {border: 1em solid transparent; display: table-cell; vertical-align: top}
.caps {text-transform: uppercase}
.button {background-color: var(--buttons); border: none; border-radius: 0.5em; color: var(--light); cursor: pointer; display: inline-block; padding: 0.5em 1em; width: 100%; font-weight: bold; font-size: 150%; width: auto}
.button:hover {text-decoration: none}
.buttonholder {margin-top: 2em; text-align: center}
.accordion_toggle {cursor: pointer}
body.js .accordion_content{display: none}
.mapholder {height: 0; padding-bottom: 56.25%; position: relative}
.mapholder iframe {height: 100%; left: 0; position: absolute; top: 0; width: 100%}
.videoWrap {aspect-ratio: 16/9; margin: 2em auto; max-height: calc(85vh - 6rem); max-width: 720px; position: relative}
.videoWrap.vertical_vid {aspect-ratio: 9/16}
.videoWrap iframe, .videoWrap video {height: 100%; left: 0; position: absolute; top: 0; width: 100%}

/* header */
header, footer {color: var(--light); flex-grow: 0; flex-shrink: 0}
header {background-color: var(--headers); padding: 0.5rem 0; position: sticky; top: 0; z-index: 5}
#header_cta {display: none}
#header_logo, #header_menu {vertical-align: middle}
#header_logo img {display: block; margin: 0 auto; width: 320px}
#header_phone {text-align: center; vertical-align: middle}
#header_phone a {text-decoration: none}
#header_menu {position: relative; text-align:right; width: 3em; z-index: 10}
#header_menu_toggle {border: none; background-color: transparent; padding: 0; color: var(--light); font-size: 300%}
#header_menu_menu {display: none; position: absolute; right: 0; background: var(--gradient); color: var(--light); padding: 0.5em 1em; top: 100%; box-shadow: 0 0.25em 0.5em var(--form_bg)}
body.nojs #header_menu:hover #header_menu_menu {display: block}
#header_menu_menu ul {list-style: none; margin: 0; padding: 0; white-space: nowrap}
#header_menu_menu a {color: var(--light); display: block; padding: 0.25em; text-decoration:none}

/* hero */
#hero {padding: 0}
#hero_img {background-image: url('/sem/assets/img/hero/ma_640.jpg'); background-position: center; background-size: cover; height: 0; padding-bottom: 50%}
#hero_wrap {background-color: var(--light); padding: 0}
#hero_wrap .container {padding: 0}
#hero_copy {font-size: 125%; padding: 2em 1em}
#hero_copy h1 {font-size: 2rem; margin: 1rem 0}
#hero_copy h1 .subhead {display: block; font-size: 1.5rem}
#top_form {background-color: var(--headers); color: var(--light); padding: 2em 1em}

/* thankyou */
#thanks h1, #thanks .socials, .phones {text-align: center}
.container#thanks {background-color: rgba(255,255,255,0.75); border-radius: 2rem; margin: 0 1rem; padding: 2rem}
.container#thanks a {font-weight: bold}
#thanksBottom {background-color: transparent}

/*form*/
.field {margin: 1em 0}
.fieldset .field {border-width: 1em; vertical-align: bottom}
.field label {display: block; margin-bottom: 0.25em}
.field input[type=email], .field input[type=tel], .field input[type=text], .field select {height: 1.75em; width: 100%; box-sizing: border-box; border: none; padding: 0.25em 0.5em; border-radius: 0.25em; background-color: var(--light)}
.field input[type="submit"] {background-color: var(--headers); border: none; border-radius: 0.5em; box-sizing: border-box; color: var(--light); cursor: pointer; font-size: 150%; font-weight: bold; padding: 0.5em; width: 100%}
fieldset.cb {border: none; margin: 1em 0; padding: 0}
fieldset.cb .fields {display: table; border-collapse: collapse; border-style: hidden}
fieldset.cb .field {display: table-row}
fieldset.cb .cb_wrap, fieldset.cb .lb_wrap {display: table-cell; border: 0.5em solid transparent}
legend {margin-bottom: 0.25rem}
.lb_wrap label {margin: 0}
textarea.comments{display: none}
.deadline {background-color: var(--light); border-radius: 10rem; color: var(--dark); font-size: 1rem; font-weight: bold; padding: 1rem; text-align: center; text-transform: none}
.deadline span {whitespace: nowrap}
.guide_cta {font-size: 90%; font-weight: bold}
.disclaimer {font-size: 75%}
.cf-turnstile {text-align: center}

/* footer */
footer {background: var(--gradient); text-align: center}
footer > .container {padding: 1em} 
footer .location {margin-bottom: 2em}
.subfooter {padding: 1rem 0}
.subfooter p {/* font-size: 66.6667%;*/ margin: 0.5em 0}
#footerbtn {background-color: transparent; bottom: 0; padding: 0.5em 0; position: sticky}
#footerbtn .button {border: 2px solid var(--light)}

/* sections */
#hero_copy, #stickywrap section {text-align: center}
#hero_copy ol, #stickywrap ol, #hero_copy ul, #stickywrap section ul {display: inline-block; margin:0; text-align: left}
main{flex-grow: 1}
section::after {clear: both; content: ""; display: block}
main section {padding: 2rem 0}
main section:nth-child(2n):not(section section) {background-color: var(--secondary); color: var(--light); margin: 0; padding: 2rem 0}
main .bar + #bottom, main .bar + #bottom + #accreditation {background-color: transparent; margin: 2rem 0; padding: 0}
.subsection {margin-top: 4rem}
.subsection:first-child {margin-top: 0}
.dualCol {text-align: center;}
.dCol {display: inline-block;text-align: left;margin: 30px;}
.dColHeader {
    vertical-align: middle;
    position: relative;
    background-color: white;
    color: black;
    font-weight: bold;
    border-radius: 8px;
    height: 20px;
    text-indent: 115px;
    padding: 13px 0px;
    border: 2px solid;
}
.dColHeader.green {border-color: #19CE37;}
.dColHeader.red {border-color: #FF0000;}
.dCol img {
    vertical-align: middle;
    margin-right: 10px;
    width: 70px;
    position: absolute;
    left: 20px;
    top: -11px;
}
section ul.compList {
    margin-left: 28px;
    line-height: 2;
    margin-top: 30px !important;
}
.greenList li::marker {color: #19CE37;}

/*programs blocks*/
.program {margin: 4rem 0}
.program .img {aspect-ratio: 1.5; background-size: cover; display: block; margin: 1rem auto; max-width: 640px}

/*boxes*/
.box {background-color: var(--light); border-radius: 1rem; color: var(--dark); margin: 1rem 0; padding: 2rem 1rem; text-align: center}
.box_icon {height: 80px; width: auto}
.box > :first-child {margin-top: 0}
.box > :last-child {margin-bottom: 0}

/*testimonials*/
#testimonials h2 {text-align: center}
.testimonial {background-color: var(--secondary); color: var(--light); margin: 2em 0; padding: 1em}
#testimonials:nth-child(2n) .testimonial {background-color: var(--primary); color: var(--dark)}
.testimonial_name {font-weight: bold}

@media(min-width: 980px) {
	.container {margin: 0 auto; max-width: 1080px}
	.d-tbl {border-collapse: collapse; border-style: hidden; display: table; table-layout: fixed; width: 100%}
	.d-tbl.rev {direction: rtl}
	.d-tbl_row {display: table-row}
	.tbl_cell, .d-tbl_cell {border: 2em solid transparent; direction: ltr; display: table-cell; vertical-align: top}
	.d-tbl_cell.middle {vertical-align: middle}
	.cert-logo {float: right; margin: -2em 0 0 2em}
	.cols {column-count: 2; column-gap: 2rem}
	.cols3 {column-count: 3}
  
	/* header */
	header .container, footer .container {margin: 0 auto; max-width: 1200px}
	#header_logo {width: 30%; vertical-align: middle}
	#header_logo img {margin: 0; width: auto}
	#header_phone {text-align: right}
	#header_phone a {font-size: 1.5rem}
	header .phones {margin-top: 1em}
	header .phones a, header .phones a span {display: block}
	header .phones .location_name {color: #e0e0e0}
	header .tagline {font-size: 110%; margin: 0}
	.phone_callout {margin: 0}
	.phone_callout_heading {font-size: 175%; font-weight: bold; margin: 0.33em 0}

	/* hero */
	#hero_img {background-image: url('/sem/assets/img/hero/ma_1920.jpg'); padding-bottom: 400px; position: relative; z-index: 2}
	#hero {position: relative}
	#hero_wrap {padding-bottom: 2em}
	#hero_wrap .container {margin-top: -400px; padding: 0 1em}
	#hero_copy, #top_form {border: none; vertical-align: top}
	#hero_copy {padding-left: 0; padding-right: 2em; position: relative; width: 60%; z-index: 1}
	#hero_copy .copy {margin-top: 400px}
	#top_form {background-color: transparent; padding: 0; position: relative; width: 24rem; z-index: 3}
	#top_form_inner {background-color: var(--form_bg); padding: 1rem}
	#top_form h2 {font-size: 1.5rem; text-align: center}

	/*thanks*/
	.container#thanks {margin: 0 auto}
	
	/* form */
	.deadline {white-space: nowrap}

	/* sections */
	/*programs blocks*/
	.programs {display: flex; flex-wrap: wrap; gap: 4rem; justify-content: center}
	.program {margin: 0; width: calc(50% - 2rem)}
	.program .img {margin: 0 auto 1rem; max-width: none}
	
	/*boxes*/
	.boxes {display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, calc(25% - 0.75rem)); grid-template-rows: auto auto auto auto}
	.box {display: grid; grid-row: span 4; grid-template-rows: subgrid; margin: 0}
	.box > * {margin: 0}
	.box_heading {align-self: center}
	.box_icon {align-self: end; display: block; margin: 0 auto}
}