:root {
	--purple: #480E66;
	--purple-light: #e4e1ea;
	--purple-dark: #2C073F;
	--blue: #00548c;
	--blue-light: #dde6ec;
	--blue-dark: #072345;
	--teal: #006580;
	--teal-light: #268AAA;
	--teal-dark: #072345;
	--red: #AF0C22;
	--red-light: #CF6666;
	--red-dark: #760505;
	--black: #252525;
	--yellow: #F4B235;
	--green: #8CA727;
	--green-light: #AAC547;
	--green-dark: #68810C;
	--black: #252525;
	--black-light: #44474E;
	--black-lighter: #585862;
	--gray-light: #E3E9EA;
	--gray-lighter: #F4F9FA;
	--space-xs: 0.5rem;
	--space-sm: 1rem;
	--space-md: 2rem;
	--space-lg: 3rem;
	--space-xl: 6.25rem;
	--container-sm: 600px;
	--container-lg: 1200px;
	--container-xl: 1600px;
}

body {
	margin: 0
}

body, p, li, a {
	font-size: 16px;
	line-height: 1.75;
	color: #252525;
	font-family: 'Lexend', sans-serif;
}

section, article, header, footer { clear: both }

h1, h2, h3, h4, h5, h6 {
	font-family: 'Urbanist', sans-serif;
	color: #252525;
	line-height: 1.4;
	font-weight: 700;
}

h1 {
	font-size: 2rem;
	line-height: 1.25;
}

h2, .card-title {
	font-size: 1.75rem;
	line-height: 1.25;
}

h3, .cws-sidebar .wp-block-heading {
	font-size: 1.625rem
}

h4 {
	font-size: 1.625rem;
	font-weight: 400;
}

h5, .side-list-title {
	font-size: 1.375rem;
	line-height: 1.75;
}

.side-list-title {
	font-weight: 600;
	margin: 0;
	padding: var(--space-sm);
	background: var(--gray-lighter);
	border: 1px solid var(--gray-light);
	border-bottom: none;
}

h6, .text-lead, .text-large, .text-large p, .text-large a {
	font-size: 1.25rem;
	line-height: 1.6;
}

.text-lead {
	margin: var(--space-md) 0 var(--space-md);
}

.text-lead > a {
	font-size: 1.25rem;
	line-height: 1.6;
}

a, .nav-links a, .nav-links a:visited {
	color: var(--blue);
}

a:visited {
	color: var(--purple);
}

a:hover, a:focus, a:active {
	color: var(--blue-dark);
}

a:focus {
	outline: thin dotted;
}

a:hover, a:active {
	outline: 0;
}

.nav-links a {
	text-decoration: none;
	padding-bottom: 5px;
	border-bottom: 2px solid var(--blue);
	font-weight: bold;
}

.bg-gray-light {
	background-color: var(--gray-light);
}

.bg-gray-lighter {
	background-color: var(--gray-lighter);
}

.bg-black {
	background-color: var(--black);
}

.bg-blue {
	background-color: var(--blue);
}

.bg-purple {
	background-color: var(--purple);
}

.bg-gold {
	background-color: var(--yellow)
}

.bg-teal {
	background-color: var(--teal)
}

.bg-teal, 
.bg-teal h1,
.bg-teal h2,
.bg-teal h3,
.bg-teal h4,
.bg-teal h5,
.bg-teal h6,
.bg-teal p,
.bg-teal ol li,
.bg-teal ul li {
    color: #FFF;
}

a {
	color: var(--teal);
}

a:hover {
	color: var(--teal-dark);
}

a:visited {
	color: var(--purple);
}

.bg-black a {
	color: var(--teal-light);
}

.bg-blue a, .bg-purple a, .bg-teal a {
	color: #FFF;
}

.bg-black a:hover {
	color: var(--teal);
}

.bg-blue a:hover, .bg-purple a:hover, .bg-teal a:hover {
	color: var(--gray-light);
}

.bg-black a:visited, .bg-blue a:visited, .bg-purple a:visited, .bg-teal a:visited {
	color: var(--gray-lighter);
}

.d-block, .fte-nav a.custom-logo-link {
	display: block
}

.fte-nav {
	position: relative;
}

.fte-nav-grid {
	display: flex;     /* position: relative; */
	justify-content: space-between;
	align-items: center;
	align-content: center;
	gap: 0.5rem;
}

.fte-nav a.custom-logo-link img {
	display: block;
	max-height: 100px;
	max-width: 100%;
	width: auto;
}

.fte-nav button:not(.btn) {
	border: 1px solid transparent;
	background: transparent;
	padding: var(--space-sm);
	cursor: pointer;
}

.fte-nav .nav-menu a, .fte-nav .nav-menu a:visited {
	color: var(--black);
	text-decoration: none;
	transition: color 180ms ease-in;
}

.fte-nav .nav-menu a:hover {
	color: var(--black-light);
}

.fte-nav .nav-menu a:focus {
	color: #000;
	outline: 1px dotted #000;
}

.fte-nav .nav-menu a:active {
	text-decoration: underline;
}

.menu-toggle {
	margin: 0 0 0 auto;
}

a.class-btn {
    border-radius: 8px;
    background-color: var(--red);
    color: #fff;
    padding: 10px;
	text-decoration: none;
}

a.class-btn:hover {
	background-color: var(--red-dark);
}

.cws-content ul li .docs-title-input-label-inner .class-btn {
	display: inline-block;
	transform: translateX(-2rem);
}

.btn, .cws-sidebar .widget .wp-block-search__button, .search-nav-display > form > input:last-of-type {
	position: relative;
	display: inline-block;
	text-decoration: none;
	background: transparent;
	border: 2px solid transparent;
	padding: 0.8rem calc(2rem + 23px) 0.8rem 1.375rem;
	border-radius: 1.5rem;
	line-height: 1;
	font-size: 1rem;
	text-transform: uppercase;
	font-weight: 400;
	font-family: 'Lexend', sans-serif;
	z-index: 2;
	overflow: hidden;
	cursor: pointer;
}

.btn:before {
	content: "";
	background: url(../img/right-arrow.png);
	position: absolute;
	right: 1.375rem;
	width: 23px;
	height: 12px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}

.btn:after {
	position: absolute;
	top: 0;
	left: 0;
	right: 100%;
	bottom: 0;
	content: "";
	z-index: -1;
	transition: right 180ms ease-out;
}

.btn.btn-icon-plus:before {
	background: url(../img/btn-plus.png);
	height: 18px;
	width: 18px;
}

.btn:hover::after, .blog-card-content:hover .btn::after, .search-nav-display > form > input:last-of-type:hover {
	right: 0;
}

.btn-sm {
	padding: 0.4rem calc(1rem + 20px) 0.4rem 0.8rem;
}

.btn-sm:before {
	right: 10px;
    width: 20px;
	background-size: contain;
    background-repeat: no-repeat;
    height: 10px;
}

.btn-blue, .btn-blue:visited, .search-nav-display > form > input:last-of-type, .search-nav-display > form > input:last-of-type:visited {
	background: var(--blue);
	border-color: var(--blue);
	color: #FFF;
}

.btn-blue:hover, .blog-card-content:hover .btn, .search-nav-display > form > input:last-of-type:hover {
	color: var(--gray-lighter);
	border-color: var(--blue-dark);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-blue:active {
	background: var(--blue-dark);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-blue:focus {
	background: var(--blue-dark);
	color: var(--blue-light);
	border-color: var(--blue-light);
}

.btn-blue:hover::after, .blog-card-content:hover .btn::after {
	background: var(--blue-dark);
}

.btn-red, .btn-red:visited, .btn-error, .btn-error:visited {
	background: var(--red);
	border-color: var(--red);
	color: #FFF;
}

.btn-red:hover, .btn-error:hover {
	color: var(--gray-lighter);
	border-color: var(--red-dark);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-red:active, .btn-error:active {
	background: var(--red-dark);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-red:focus, .btn-error:focus {
	background: var(--red-dark);
	color: var(--red-light);
	border-color: var(--red-light);
}

.btn-red:hover::after, .btn-error:hover::after {
	background: var(--red-dark);
}

.btn-purple, .btn-purple:visited {
	background: var(--purple);
	border-color: var(--purple);
	color: #FFF;
}

.btn-purple:hover, .program-row:hover .btn {
	color: var(--gray-lighter);
	border-color: var(--purple-dark);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-purple:active {
	background: var(--purple-dark);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-purple:focus {
	background: var(--purple-dark);
	color: var(--purple-light);
	border-color: var(--purple-light);
}

.btn-purple:hover::after, .proogram-row:hover .btn::after {
	background: var(--purple-dark);
}

.btn-teal, .btn-teal:visited, .cws-sidebar .widget .wp-block-search__button {
	background: var(--teal);
	border-color: var(--teal);
	color: #FFF;
}

.btn-teal:hover, .cws-sidebar .widget .wp-block-search__button:hover {
	color: var(--gray-lighter);
	border-color: var(--teal-dark);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-teal:active, .cws-sidebar .widget .wp-block-search__button:active {
	background: var(--teal-dark);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-teal:focus, .cws-sidebar .widget .wp-block-search__button:focus {
	background: var(--teal-dark);
	color: var(--teal-light);
	border-color: var(--teal-light);
}

.btn-teal:hover::after {
	background: var(--teal-dark);
}

.btn-hide {
	border-radius: 6px;
	background: var(--gray-light);
	color: var(--black-light);
	display: inline-block;
	padding: 0.4rem 0.8rem;
	border: 2px solid var(--black-lighter);
	border-radius: 1.5rem;
    line-height: 1;
    font-size: 1rem;
    text-transform: uppercase;
    font-weight: 400;
    font-family: 'Lexend', sans-serif;
    z-index: 2;
    overflow: hidden;
    cursor: pointer;
	margin-top: var(--space-xs);
}

.menu-drop-arrow {
	position: relative;
	display: inline-block;
	margin-left: 4px;
	/* height: 12px; */
	width: 0.666rem;
}

.menu-drop-arrow:before {
	position: absolute;
	content: url(../img/chevron-down-solid.svg);
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

.cws-sidebar .widget .wp-block-search__input {
	border: 2px solid var(--teal);
	border-radius: 6px;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
}

.cws-sidebar .widget .wp-block-search__button {
	padding: 0.5em 1em;
	border: 2px solid var(--teal);
	border-radius: 6px;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	margin-left: 0;
}

.btn-success, .btn-success:visited {
	background: var(--green);
	border-color: var(--green);
	color: #FFF;
}

.btn-success:hover {
	color: var(--gray-lighter);
	border-color: var(--green-dark);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-success:active {
	background: var(--green-dark);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-success:focus {
	background: var(--green-dark);
	color: var(--green-light);
	border-color: var(--green-light);
}

.btn-success:hover::after {
	background: var(--green-dark);
}

.btn-outline-white, .btn-outline-white:visited {
	border-color: #FFF;
	color: #FFF;
}

.btn-outline-white:hover {
	color: var(--gray-lighter);
	border-color: var(--gray-lighter);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-outline-white:active {
	background: rgba(255, 255, 255, 0.1);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-outline-white:focus {
	background: rgba(255, 255, 255, 0.1);
	color: var(--gray-lighter);
	border-color: var(--blue-light);
}

.btn-outline-white:hover::after {
	background: rgba(255, 255, 255, 0.1);
}

.btn-outline-gold, .btn-outline-gold:visited {
	border-color: var(--yellow);
	color: var(--yellow);
}

.btn-outline-gold:hover {
	color: var(--yellow);
	border-color: var(--yellow);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-outline-gold:active {
	background: rgba(240, 240, 185, 0.1);
	color: var(--gray-lighter);
	box-shadow: inset 0 2px 6px -2px rgba(0, 0, 0, 0.3);
	text-shadow: 0 2px 2px rgba(0, 0, 0, 0.3);
}

.btn-outline-gold:focus {
	background: rgba(240, 240, 185, 0.1);
	color: var(--gray-lighter);
	border-color: var(--yellow);
}

.btn-outline-gold:hover::after {
	background: rgba(240, 240, 185, 0.1);
}

.search-nav-display {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
	padding: var(--space-md) var(--space-sm);
	display: flex;
	justify-content: center;
	align-content: center;
	align-items: center;
	background: #FFF;
	min-height: 132px;
	z-index: 34;
}

.search-nav-display-close {
	position: absolute;
	top: 0;
	right: 2rem;
	width: 1.2rem;
	height: 1.2rem;
	z-index: 35;
}

.search-nav-display > form {
	display: flex;
	justify-content: center;
	width: 74ch;
	max-width: 100%;
	margin: 0 auto;
}

.search-nav-display > form > input:first-of-type {
	flex-grow: 3;
	border-radius: 0;
	border-top-left-radius: var(--space-sm);
	border-bottom-left-radius: var(--space-sm);
	padding: var(--space-xs) var(--space-md);
}
.search-nav-display > form > input:last-of-type {
	min-width: 7.5rem;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	cursor: pointer;
	padding: var(--space-xs) var(--space-md);
}

.text-white, .text-white h1, .text-white h2, .text-white h3, .text-white h4, .text-white h5 {
	color: #FFF
}


.text-blue {
	color: var(--blue)
}

.text-purple {
	color: var(--purple)
}

.text-yellow {
	color: var(--yellow);
}

.text-center {
	text-align: center
}

.text-right {
	text-align: right
}

.text-uppercase {
	text-transform: uppercase
}

.font-bold {
	font-weight: 700
}

.container {
	width: var(--container-lg);
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.container-xl {
	width: var(--container-xl);
}

.container-sm {
	width: var(--container-sm);
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.block-center {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.flex-center {
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
}

.flex-center-vertical {
	display: flex;
	align-items: center;
	align-content: center;
}

.flex-bottom {
	display: flex;
	justify-content: flex-start;
	align-items: flex-end;
	align-content: flex-end;
}

.video-responsive {
	position: relative;
	overflow: hidden;
	width: 578px;
	max-width: 100%;
}

.video-block .container.full .video-responsive {
	width: 100%;
}

.video-block .container.center {
	flex-direction: column;
}

.video-block .container > .video-body > *:last-child {
	margin-bottom: var(--space-lg);
}

.video-responsive:after {
	display: block;
	content: "";
	padding-top: 56.25%;
}

.video-responsive iframe, .video-responsive video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border-radius: 4px;
	overflow: hidden;
}

.px {
	padding-left: var(--space-sm);
	padding-right: var(--space-sm);
}

.px-lg {
	padding-left: var(--space-lg);
	padding-right: var(--space-lg);
}

.py {
	padding-top: var(--space-sm);
	padding-bottom: var(--space-sm);
}

.py-xs {
	padding-top: var(--space-xs);
	padding-bottom: var(--space-xs);
}

.py-md {
	padding-top: var(--space-md);
	padding-bottom: var(--space-md);
}

.py-lg {
	padding-top: var(--space-lg);
	padding-bottom: var(--space-lg);
}

.py-xl {
	padding-top: var(--space-xl);
	padding-bottom: var(--space-xl);
}

.pb-0 {
	padding-bottom: 0;
}

.my {
	margin-top: var(--space-sm);
	margin-bottom: var(--space-sm);
}

.my-xs {
	margin-top: var(--space-xs);
	margin-bottom: var(--space-xs);
}

.my-sm {
	margin-top: var(--space-sm);
	margin-bottom: var(--space-sm);
}

.my-md {
	margin-top: var(--space-md);
	margin-bottom: var(--space-md);
}

.my-lg {
	margin-top: var(--space-lg);
	margin-bottom: var(--space-lg);
}

.mb-lg {
	margin-bottom: var(--space-lg);
}

.my-xl {
	margin-top: var(--space-xl);
	margin-bottom: var(--space-xl);
}

.mb {
	margin-bottom: var(--space-md)
}

.my-0, .mt-0 {
	margin-top: 0;
}

.my-0, .mb-0 {
	margin-bottom: 0
}

.card {
	text-decoration: none;
	position: relative;
	display: flex;
	align-content: flex-end;
	align-items: flex-end;
	gap: 1rem;
	min-height: 360px;
	border-radius: 0.75rem;
	overflow: hidden;
	cursor: pointer;
}

.card:after {
	content: "";
	position: absolute;
	z-index: 2;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: rgb(45, 0, 93);
	background: linear-gradient(180deg, rgba(45, 0, 93, 0) 0%, rgba(45, 0, 93, 0.8855917366946778) 64%, rgba(45, 0, 93, 1) 100%);
	border-radius: 0.75rem;
	overflow: hidden;
}

.card::before {
	content: "";
	position: absolute;
	z-index: 2;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	opacity: 0;
	transition: opacity 180ms linear;
	background: rgb(45, 0, 93);
	z-index: 2;
}

.card:hover:before {
	opacity: 1;
	background: linear-gradient(180deg, rgba(45, 0, 93, 0.5858718487394958) 0%, rgba(45, 0, 93, 0.9220063025210083) 64%, rgba(45, 0, 93, 1) 100%);
}

.card-blue:after {
	background: var(--blue);
	background: linear-gradient(180deg, rgba(0, 84, 140, 0) 0%, rgba(0, 84, 140, 0.8855917366946778) 64%, rgba(0, 84, 140, 1) 100%);
}

.card-blue::before {
	background: rgb(0, 84, 140);
}

.card-blue:hover:before {
	background: linear-gradient(180deg, rgba(0, 84, 140, 0.5858718487394958) 0%, rgba(0, 84, 140, 0.9220063025210083) 64%, rgba(0, 84, 140, 1) 100%);
}

.card > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
	border-radius: 0.75rem;
	overflow: hidden;
	transition: transform 550ms ease-out;
	-webkit-transition: transform 550ms ease-out;
	-moz-transition: transform 550ms ease-out;
	-ms-transition: transform 550ms ease-out;
	-o-transition: transform 550ms ease-out;
	transform: scale(1) perspective(0px) rotateX(0deg);
	-webkit-transform: scale(1) perspective(0px) rotateX(0deg);
	-moz-transform: scale(1) perspective(0px) rotateX(0deg);
	-ms-transform: scale(1) perspective(0px) rotateX(0deg);
	-o-transform: scale(1) perspective(0px) rotateX(0deg);
}

.card:hover img {
	transform: scale(1.02) perspective(0px) rotateX(-0.01deg);
	-webkit-transform: scale(1.02) perspective(0px) rotateX(-0.01deg);
	-moz-transform: scale(1.02) perspective(0px) rotateX(-0.01deg);
	-ms-transform: scale(1.02) perspective(0px) rotateX(-0.01deg);
	-o-transform: scale(1.02) perspective(0px) rotateX(-0.01deg);
}

.card > .card-body {
	display: block;
	position: relative;
	z-index: 3;
	padding: var(--space-sm);
	color: #FFF;
}

.card > .card-body > .card-title {
	display: block;
	color: #FFF;
	margin-bottom: var(--space-sm)
}

.card > .card-body > .card-description {
	display: block;
	color: #FFF;
	margin-bottom: var(--space-sm)
}

.card > .card-body > .card-description p,
.card > .card-body > .card-description ul li {
	color: #FFF;
}

.card > .card-body > .card-button {
	font-family: 'Lexend', sans-serif;
	display: inline-block;
	position: relative;
	background: #FFF;
	color: var(--purple);
	padding: var(--space-xs) var(--space-sm);
	border-radius: 0.75rem;
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 400;
	overflow: hidden;
	cursor: pointer;
	border: 2px solid #FFF;
	transition: border 180ms linear, color 180ms linear;
	z-index: 3;
}

.card > .card-body > .card-button:after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 100%;
	transition: right 180ms ease-out;
	z-index: -1;
}

.card > .card-body > .card-button:hover, .card:hover > .card-body > .card-button {
	color: var(--gray-lighter);
	border: 2px var(--gray-lighter) solid;
	background: transparent;
}

.card.card-blue .card-body > .card-button, .card.card-blue .card-body > .card-button:hover, a.card.card-blue:visited .card-body > .card-button {
    color: var(--blue);
    border: 2px solid #FFF;
}

.card.card-blue .card-body > .card-button:hover, .card.card-blue:hover .card-body > .card-button, .card.card-blue:visited:hover .card-body > .card-button {
    color: #FFF;
}

.card:hover > .card-body > .card-button:after, .card-button:hover::after {
	right: 0;
	background: rgba(255, 255, 255, 0.2);
}

.main-navigation a.card.nav-card {
	min-height: 250px;
	display: flex;
}

a.card.nav-card > .card-body > .card-title {
	font-size: 1.2rem;
	margin-bottom: 0;
}

.hero-image {
	align-self: center;
	max-width: 100% !important;
}

.hero-image img {
	display: block
}

.hero-image.hero-img-no-subtitle {
	position: relative;
    height: 325px;
    width: 100%;
}

.hero-image.hero-img-no-subtitle img {
	position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-grid {
	display: flex;
	flex-direction: column-reverse;
}

.hero-show-btn { 
	display: inline-block;
	margin-top: var(--space-sm);
}

#bread {
	display: flex;
	align-items: center;
	align-content: center;
	gap: var(--space-sm);
	list-style: none;
	padding-left: 0;
	margin: 0;
	overflow: hidden;
	line-height: 16px;
}

#bread li {
	display: inline-block;
	vertical-align: middle;
	line-height: 16px;
	font-size: 14px;
}

#bread li > * {
	clip-path: border-box;
	white-space: nowrap;
}

#bread .separator {
	font-family: 'Lexend', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: #252525;
	line-height: 16px;
	transform: translateY(-2px);
}

#bread .bc-right {
	justify-self: end;
    margin-left: auto;
    margin-right: 0;
}

#bread .bc-right select {
	padding: var(--space-xs);
	text-align: left;
	font-family: 'Lexend', sans-serif;
	border-radius: 4px;
	border-color: var(--gray-light);
}

.container h2, .container h3, .container h4, .container h5, .container h6, .container p, .container a, .container li,
.container-sm h2, .container-sm h3, .container-sm h4, .container-sm h5, .container-sm h6, .container-sm p, .container-sm a, .container-sm li {
	word-break: break-word;
}

.cws-sidebar.side-stick {
	height: 100%;
	min-height: 250px;
}

.cws-sidebar.side-stick .cws-sidebar-inner {
	position: sticky;
	top: 0;
	right: 0;
	z-index: 10;
	width: 100%;
	height: auto;
}
.cws-sidebar ul {
	list-style-type: none;
	padding-left: 0;
	margin-left: 0;
	margin-bottom: 0;
}

.cws-sidebar ul li a {
	display: inline-block;
	color: var(--blue);
}

.list-block {
	padding-left: var(--space-sm);
	padding-right: var(--space-sm);
}

.list-block.with-title ul > li:first-child {
	padding-top: var(--space-md)
}

#fte-footer {
	font-family: 'Lexend', sans-serif;
}

#fte-footer .footer-bottom {
	border-top: 1px solid var(--gray-light);
	font-weight: bold;
	font-size: 0.8rem;
}

.home-hero h1 {
	margin-top: 0;
	margin-bottom: var(--space-md);
}

.home-hero .home-hero-body p:first-child {
	margin-top: 0;
}

.home-hero .home-hero-body p:last-child {
	margin-bottom: 0;
}

.home-hero .container-sm {
	width: 780px;
}

.hero-content h1, .cws-content h2:first-of-type, .cws-sidebar h3:first-of-type {
	margin-top: 0
}

.hero-content p:last-of-type, .cws-content p:last-of-type {
	margin-bottom: 0
}

.nav-search {
	display: none
}

#slider-hero .splide__slide {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding-top: 480px;
}

#slider-hero .splide__slide img {
	position: absolute;
	top: 0;
	left: 50%;
	width: 100%;
	height: 480px;
	max-width: 2000px;
	transform: translateX(-50%);
	object-fit: cover;
}

.fit-slides #slider-hero .splide__slide {
	padding-top: 0;
}

.fit-slides #slider-hero .splide__slide img {
	position: initial;
	height: initial;
	display: block;
	margin: 0 auto;
	width: 1200px;
	max-width: 100%;
	transform: translateX(0);
	object-fit: initial;
}

#slider-hero h1 {
	font-size: 1.75rem;
	line-height: 1.25;
}

.hero-slider.bg-blue h1, .hero-slider.bg-blue h2, .hero-slider.bg-purple h1, .hero-slider.bg-purple h2 {
	color: #FFF;
}

.link-list-grid {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.link-list-link {
	background: var(--gray-light);
	border-radius: 0.5rem;
	cursor: pointer;
	position: relative;
	display: flex;
	padding: var(--space-sm);
	align-content: center;
	align-items: center;
	border: 2px solid transparent;
	transition: background 180ms ease-in;
	margin-bottom: var(--space-sm);
}

.link-list-link.student-link {
	background: var(--purple-light);
}

.link-list-link.teacher-link {
	background: var(--blue-light);
}

.link-list-link:hover {
	background: var(--gray-lighter);
	border: 2px solid var(--gray-light);
}

.link-list-link:hover .link-list-icon {
	box-shadow: 0 2px 12px -4px rgba(0, 0, 0, 0.22);
}

.link-list-link.student-link:hover {
	border: 2px solid var(--purple-light);
	background: #eeedf1;
}

.link-list-link.teacher-link:hover {
	border: 2px solid var(--blue-light);
	background: #eaedef;
}

.link-list-link a::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}

.link-list-link .link-list-icon {
	flex-basis: 60px;
	flex-shrink: 0;
	height: 60px;
	border-radius: 0.5rem;
	overflow: hidden;
	background: #FFF;
	display: flex;
	justify-content: center;
	align-content: center;
	align-items: center;
	padding: 10px;
}

.link-list-link .link-list-title, .link-list-link .link-list-title:hover, .link-list-link .link-list-title:visited {
	text-decoration: none;
	color: var(--blue-dark);
	flex-grow: 2;
	padding-left: 0.75rem;
	line-height: 1.3;
}

.link-list-link.teacher-link .link-list-title, .link-list-link.teacher-link .link-list-title:hover, .link-list-link.teacher-link .link-list-title:visited {
	color: var(--blue);
}

.link-list-link.student-link .link-list-title, .link-list-link.student-link .link-list-title:hover, .link-list-link.student-link .link-list-title:visited {
	color: var(--purple);
}

.nav-links a {
	display: flex;
	position: relative;
	gap: 0.5rem;
	width: 200px;
	border-bottom: 0;
	overflow: hidden;
}

.nav-links a .nav-title {
	white-space: nowrap;
}

.nav-links .nav-next {
	display: flex;
	justify-content: flex-end;
}

.nav-links a:after {
	content: "";
	position: absolute;
	width: 3rem;
	height: 100%;
	top: 0;
	z-index: 4;
	background: rgb(255,255,255);
	background: linear-gradient(101deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 65%, rgba(255,255,255,1) 100%);
	left: calc(100% - 3rem);
}

.legacy-layout {
	margin-top: var(--space-lg);
}

.blog-card {
	display: flex;
	flex-direction: column;
	position: relative;
	border-radius: 0.5rem;
	box-shadow: 0 2px 12px -4px rgba(0, 0, 0, 0.22);
	overflow: hidden;
}

.blog-card-image {
	position: relative;
	width: 100%;
	height: 250px;
	overflow: hidden;
}

.blog-card-image img {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.blog-card-content {
	display: flex;
	flex-direction: column;
	flex-grow: 2;
	padding: var(--space-md) 1.5rem;
}

.blog-card-content h2, .blog-card-content h3, .blog-card-content p {
	margin-top: 0;
	margin-bottom: var(--space-sm);
}

.blog-card.program-card .blog-card-content h2 {
	margin-bottom: var(--space-xs);
}

.blog-card-content p {
	margin-bottom: var(--space-md)
}

.blog-card-content p.blog-card-img-attribution {
	margin-bottom: 0;
	margin-top: -24px;
    transform: translateY(5px) translateX(8px);
	text-align: right;
	font-size: 84%;
	color: #888;
}

.blog-card-content p.card-session {
	margin-top: 0;
	margin-bottom: var(--space-sm);
}

.blog-card-content h2 a, .blog-card-content h3 a, .blog-card-content h3 a:hover, .blog-card-content h3 a:active, .blog-card-content h3 a:focus {
	font-family: 'Urbanist', sans-serif;
	color: var(--black);
	text-decoration: none;
	font-size: 1.425rem;
	line-height: 1.3;
	font-weight: 700;
}

.blog-card-content h2 a::after, .blog-card-content h3 a::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 3;
}

.blog-card-content p {
	line-height: 1.5;
}

.blog-card-content .btn {
	cursor: pointer
}

.blog-card-content > div {
	margin-top: auto;
}

.blog-card.program-card .program-status, .blog-card .blog-card-cost {
	position: absolute;
	bottom: 0;
	right: 0;
	width: auto;
	padding: 4px 6px;
	line-height: 1;
	margin: 0;
	height: auto;
	background: var(--gray-lighter);
	border-top-left-radius: 3px;
	z-index: 3;
}

.blog-card .blog-card-cost {
	display: inline-block;
	top: 0;
	left: 0;
	bottom: initial;
	right: initial;
	border-top-left-radius: 0;
	border-bottom-right-radius: 3px;
	z-index: 3;
	font-weight: 700;
	text-transform: uppercase;
}

.blog-card.program-card .blog-card-image {
	height: 160px;
	transition: height 240ms ease-in;
}

.blog-card.program-card-link:hover .blog-card-image {
	height: 105px;
}

.blog-card.program-card .card-btn-row {
	opacity: 0;
	height: 0px;
	display: flex;
	align-items: flex-end;
	transition: height 240ms ease-in, opacity 220ms ease-in;
}

.blog-card.program-card-link:hover .card-btn-row {
	opacity: 1;
	height: 55px;
}

.blog-card.program-card .blog-card-content {
	padding: var(--space-sm) 1rem;
}

.blog-card.program-card h2 {
	font-size: 1.2rem;
}

.blog-card.program-card .card-dates {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: var(--space-xs);
}

.blog-card.program-card .card-dates strong, .blog-card.program-card .card-dates p {
	margin: 0;
	display: block;
	line-height: 1.2;
}

.test-slide {
	display: flex;
	flex-direction: column;
	align-items: center;
	align-content: center;
	justify-content: center;
	text-align: center;
	padding: var(--space-lg) var(--space-md);
	gap: var(--space-sm);
}

.test-slide > div {
	margin-top: 0;
	margin-bottom: 0;
}

.test-quote p:first-child {
	margin-top: 0;
}

.test-quote p:last-child {
	margin-bottom: 0;
}

.test-logo {
	max-width: 170px;
	max-height: 240px;
	height: auto;
	width: auto;
}

.footer-left {
	display: flex;
	gap: var(--space-md);
}

.ci-row-single .content-img-img img {
	border-radius: var(--space-sm);
}

.content-img-content {
	padding-top: var(--space-md);
	padding-bottom: var(--space-md);
}

.content-img-content-btn {
	margin-top: var(--space-sm) !important;
}

.pagination {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-bottom: var(--space-lg);
}

.pagination .page-numbers {
	display: inline-block;
	padding: 10px;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	color: var(--gray-light);
	border: 1px solid var(--gray-light);
	border-radius: 18px;
	min-width: 36px;
}

.pagination a.page-numbers {
	text-decoration: none;
	color: var(--blue);
	border-color: var(--blue);
	transition: background-color 220ms ease-out;
}

.pagination a.page-numbers:hover {
	background-color: var(--blue);
	color: #FFF;
}

.footer-right ul {
	list-style: none;
	padding-left: 0;
	margin-left: 0;
}

.footer-social a {
	border: 1px solid transparent;
	overflow: hidden;
}

.footer-social {
	display: flex;
	justify-content: flex-start;
	gap: 0.5em;
	align-items: flex-start;
	align-content: flex-start;
}

.footer-social li {
	width: 48px;
	height: 48px;
	display: flex;
	justify-content: center;
	align-content: center;
}

.footer-social li a {
	display: inline-block;
}

.social-sprite {
	display: inline-block;
	background: url(../img/fte-social-sprite.png);
	height: 46px;
	width: 46px;
	border: 1px solid transparent;
	border-radius: var(--space-sm);
	height: 46px;
	width: 46px;
}

.social-sprite > span {
	visibility: hidden;
	height: 1px;
	width: 1px;
}

.footer-social a:hover .social-sprite {
	border: 1px solid var(--blue)
}

.social-yt {
	background-position: 0 0;
}

.social-fb {
	background-position: 92px 0;
}

.social-ig {
	background-position: 46px 0;
}

.social-li {
	background-position: 0 46px;
}

.social-tw {
	background-position: 92px 46px;
}

.social-tt {
	background-position: 46px 46px;
}

.footer-left .footer-logo img {
	width: 100px;
	height: auto;
}

.hero-text-only .hero-subtitle {
	margin-bottom: 0;
}

.hero-text-only .hero-content {
	padding: var(--space-md) var(--space-sm);
	max-width: 76ch
}

main#primary article#general > .content-img-block:first-child, 
main#primary article#general > .blog-posts-block:first-child, 
main#primary article#general > .link-list-block:first-child, 
main#primary article#general > .side-by-side-block:first-child, 
main#primary article#general > .content-with-sidebar-block:first-child {
	margin-top: var(--space-lg);
}

main#primary article#general > .content-img-block:last-child, 
main#primary article#general > .blog-posts-block:last-child, 
main#primary article#general > .link-list-block:last-child, 
main#primary article#general > .side-by-side-block:last-child, 
main#primary article#general > .content-with-sidebar-block:last-child {
	margin-bottom: var(--space-lg);
}

.hero-content.no-subtitle h1 { margin: 0 }

.slide-bottom > :first-child {
	flex-grow: 0;
	flex-shrink: 15;
	flex-basis: 52ch;
}

.slide-bottom > *:nth-child(2) {
	flex-grow: 50;
    display: inline-block;
    word-break: normal;
    flex-basis: 200px;
	flex-shrink: 0;
	text-align: right;
}

@media(max-width:37.5em) {
	#bread { 
		flex-wrap: wrap;
		gap: var(--space-xs);
	}
	#bread li.item-cat, #bread li.item-current {
		width: fit-content;
		white-space: nowrap;
		overflow: hidden;
		min-width: 120px;
	}
	#bread, #bread li, #bread li > * {
		font-size: 13px;
		line-height: 0.9;
	}
	#bread .bread-link svg {
		height: 13px;
	}
	.blog-content img {
		float: none;
		display: block;
	}
	.nav-col-one-card {
		width: 48%;
		display: block;
		float: left;
	}

	.nav-card-left {
		margin-right: 1%;
	}

	.nav-card-right {
		margin-left: 1%;
	}

	.main-navigation .nav-col-one-card a.card.nav-card {
		min-height: 210px;
	}

	.main-navigation .nav-col-one-card a.card.nav-card > .card-body > .card-title {
		font-size: 0.9rem;
	}

	.main-navigation.toggled {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: #FFF;
		padding: 1rem;
		z-index: 9999;
		overflow-y:scroll;
	}

	.hero-content { justify-content: stretch }

	#footer-menu li {
		padding-bottom: 0.5rem;
	}

	.footer-left {
		justify-content: center;
	}

	.footer-right.py-lg {
		padding-top: var(--space-sm);
		padding-bottom: var(--space-lg);
	}

	.menu-footer-nav-container {
		text-align: center;
		margin-bottom: var(--space-lg);
	}

	.menu-footer-nav-container li a {
		font-size: 1.25rem;
	}

	.footer-social {
		justify-content: center;
		margin-bottom: 0;
	}

	.slide-bottom > *:nth-child(2) {
		text-align: left;
	}

}

@media(min-width:37.5em) {
	#primary-menu {
		display: flex;
		justify-content: center;
		align-items: center;
		align-content: center;
		gap: var(--space-md);
	}

	.test-slide > div {
		padding-left: 4rem;
		padding-right: 4rem;
	}

	.footer-right {
		display: flex;
		gap: var(--space-lg);
	}

	.footer-right {
		justify-content: space-between;
	}

	#slider-hero .slide-bottom {
		display: flex;
		justify-content: space-between;
		align-items: center;
		align-content: center;
		gap: 2rem;
	}

	#slider-hero .slide-bottom h1, #slider-hero .slide-bottom h2 {
		margin: 0;
	}

}

@media(min-width:578px) and (max-width:840px) {
	.hero-image {
		width: 100%;
	}

	.hero-image img {
		width: 100%;
		height: auto;
	}

}

@media(min-width:840px) {
	.grid-2, .grid-3, .grid-4 {
		display: grid;
		gap: var(--space-sm);
	}

	.grid-2 {
		grid-template-columns: repeat(2, 1fr);
	}

	.content-img-row.grid-2 {
		gap: 0;
	}

	.content-img-row > .content-img-img {
		position: relative;
		min-height: 350px;
		overflow:hidden;
	}

	.content-img-row > .content-img-img > img {
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}

	.content-img-row:nth-child(even) > .content-img-img {
		grid-column-start: 2;
		grid-column-end: 3;
		grid-row-start: 1;
		grid-row-end: 2;
	}

	.content-img-content {
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.content-img-content h2 { font-size: 1.45rem }
	.content-img-content h3, .content-img-content h4 { font-size: 1.35rem }
	.content-img-content h5, .content-img-content h6 { font-size: 1.1rem }
	.content-img-content p, .content-img-content ul, .content-img-content ul li {
		font-size: 0.9rem;
	}

    .ci-row-single .content-img-content {
        padding-left: var(--space-lg);
    }

	.content-img-content > * {
		margin-top: 0;
		margin-bottom: var(--space-xs);
	}

    .content-img-content > *:first-child {
        margin-top: 0;
    }

    .content-img-content > *:last-child {
        margin-bottom: 0;
    }

	.content-img-img img {
		display: block;
		width: 100%;
		height: auto;
	}

	.content-img-row:nth-child(even) > .content-img-content {
		grid-column-start: 1;
		grid-column-end: 2;
		grid-row-start: 1;
		grid-row-end: 2;
	}

	.grid-3 {
		grid-template-columns: repeat(3, 1fr)
	}

	.grid-4 {
		grid-template-columns: repeat(4, 1fr);
	}

	.hero-grid {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--space-sm);
		flex-direction: row;
	}

	.cws {
		display: grid;
		grid-template-columns: 3fr 1fr;
		gap: 2rem;
	}

	.cws.cws-alt {
		grid-template-columns: 2fr 7fr;
	}

	.cws-sidebar .list-block {
		border-left: 1px solid var(--gray-light);
	}

	.list-block {
		padding-left: var(--space-lg);
	}

	.side-list-title {
		border-top-left-radius: var(--space-sm);
		border-top-right-radius: var(--space-sm);
	}

	.list-block.with-title {
		padding-left: var(--space-sm);
		padding-right: var(--space-sm);
		border: 1px solid var(--gray-light);
		margin-bottom: var(--space-lg);
		padding-bottom: var(--space-md);
		border-bottom-right-radius: var(--space-sm);
		border-bottom-left-radius: var(--space-sm);
	}

	.fte-nav-grid {
		display: grid;
		grid-template-columns: 115px 1fr;
		row-gap: 0;
		column-gap: var(--space-sm);
		align-items: center;
	}

	.blog-posts-block { clear: both }

	.blog-posts-block-header.show-vm {
		display: flex;
		justify-content: space-between;
		align-items: center;
		align-content: center;
	}

	.blog-posts-block-header.show-vm > h2 {
		flex-grow: 2;
		margin-top: 0;
		margin-bottom: 0;
	}

	.blog-posts-block-header.show-vm > a {
		display: inline-block;
		flex-shrink: 0;
	}

	.link-list-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: var(--space-sm);
	}

	.link-list-link {
		margin-bottom: 0;
	}

	.test-slide > div {
		padding-left: 10rem;
		padding-right: 10rem;
	}

	.footer-main {
		display: grid;
		grid-template-columns: 6fr 5fr;
		gap: 0.5rem;
	}

}

@media (min-width:840px) and (max-width:1050px) {
	h1.hero-title, h1 {
		font-size: 1.6rem
	}

	h2 {
		font-size: 1.4rem
	}

	h3, .cws-sidebar .wp-block-heading {
		font-size: 1.2rem
	}

	h4 {
		font-size: 1rem
	}

	h5, .h6 {
		font-size: 0.9rem
	}

	body, p, li, a, .hero-content p {
		font-size: 0.8rem;
		line-height: 1.3;
	}

}

@media(min-width:1050px) {
	#primary-menu {
		gap: 0;
	}

	.nav-menu {
		gap: var(--space-md)
	}

	.fte-nav-grid {
		grid-template-columns: 115px 1fr 115px;
		column-gap: var(--space-sm);
	}

	.nav-search {
		display: block;
	}

	.card {
		min-height: 500px
	}

	.home-main-options .card {
		min-height: 640px;
	}

	.card.nav-card {
		min-height: 250px;
	}

	.card > .card-body {
		padding: var(--space-md);
	}

	.card.nav-card > .card-body {
		padding: var(--space-sm);
	}

	.content-img-content {
		padding-left: var(--space-md);
		padding-right: var(--space-md);
	}

	.grid-2 {
		gap: var(--space-md);
	}

	.content-img-row.grid-2 {
		gap: 0;
	}

	.hero-grid {
		grid-template-columns: 1fr 578px;
		gap: var(--space-md);
	}

}

#general > article > section:last-child {
	margin-bottom: 0;
}

