:root {
    --navy: #004F6D;
    --light-navy: #33728A;
    --lime: #3A8703;
    --dark-lime: #3A8703; 
    --white: #FFFFFF;
    --gray-100: #f8f9fa;
    --gray-200: #e9ecef;
    --gray-300: #dee2e6;
    --gray-400: #ced4da;
    --gray-500: #adb5bd;
    --gray-600: #6c757d;
    --gray-700: #495057;
    --gray-800: #343a40;
    --gray-900: #212529;
    --black: #000000;
    --red: #ED3E43;
    --clear: rgba(0,0,0,0);
}


/* GENERAL */

#skip_nav_btn {
    font-size: 14px;
    display: block;
    border-radius: 0;
    border: 0;
    padding: .5rem !important;
    margin: 0 !important;
}

.text-shadow {
    text-shadow: 0px 2px 2px rgba(75,75,75,1);
}

.text-shadow-dark {
    text-shadow: 0px 2px 2px rgba(0,0,0,1);
}

.box-shadow {
	box-shadow: 0px 10px 20px rgba(0,0,0,.08);
}

.box-shadow-dark {
	box-shadow: 0px 10px 20px rgba(0,0,0,.15);
}

.image-overlay-25 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,.25);
}

.image-overlay-50 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,.5);
}

.image-overlay-75 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,.75);
}

.image-overlay-text {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    transform: translateY(-50%);
    margin: auto;
    padding: 1rem 1.5rem;
    color: var(--white);
}

.no-hover {
	color: inherit;
}

.no-hover:hover {
	text-decoration: none;
	color: inherit;
}

.centered {
	top: 50%;
	left: 0;
	right: 0;
    transform: translateY(-50%);
	text-align: center;
	margin: auto;
}

.bg-cover {
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
}

.hero-arrow {
    width: 200px;
    position: absolute;
    z-index: 2;
    margin: auto;
    top: -4.2rem;
    left: 0;
    right: 0;
}

.badge {
    border-radius: 0;
    text-transform: uppercase;
}

.badge-trans {
    color: var(--navy);
    background: rgba(255,255,255,.75);
}

.rounded-xl {
    border-radius: 30px !important;
}

blockquote {
	margin: 1rem;
  padding-left: 1rem;
  border-left: .5rem solid var(--lime);
	font-weight:bold;
	font-size:1.35rem;
	font-style:italic;
}


/* MARGIN/PADDING */

.ml-125 {
    margin-left: .125rem;
}

.my-10px {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
}

.my-15px {
    margin-top: 15px !important;
    margin-bottom: 15px !important;
}

.mx-15px {
    margin-left: 15px !important;
    margin-right: 15px !important;
}

.mx-30px {
    margin-left: 30px !important;
    margin-right: 30px !important;
}

.ml-15px {
    margin-left: 15px !important;
}

.mr-15px {
    margin-right: 15px !important;
}

.m-15px {
    margin: 15px !important;
}

.mt-n375 {
    margin-top: -.375rem;
}

.mt-15px {
    margin-top: 15px !important;
}

.mt-18px {
    margin-top: 18px !important;
}

.mt-20px {
    margin-top: 20px !important;
}

.mt-30px {
    margin-top: 30px !important;
}

.mt-33px {
    margin-top: 33px !important;
}

.mb-10px {
    margin-bottom: 10px !important;
}

.mb-15px {
    margin-bottom: 15px !important;
}

.mb-18px {
    margin-bottom: 18px !important;
}

.mb-20px {
    margin-bottom: 20px !important;
}

.mb-30px {
    margin-bottom: 30px !important;
}

.mb-33px {
    margin-bottom: 33px !important;
}

.mb-38px {
    margin-bottom: 38px !important;
}

.px-15px {
    padding-left: 15px !important;
    padding-right: 15px !important;
}

.px-30px {
    padding-left: 30px !important;
    padding-right: 30px !important;
}

.px-33px {
    padding-left: 33px !important;
    padding-right: 33px !important;
}

.py-7-5px {
    padding-top: 7.5px !important;
    padding-bottom: 7.5px !important;
}

.py-10px {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}

.py-15px {
    padding-top: 15px !important;
    padding-bottom: 15px !important;
}

.py-30px {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
}

.pb-10px {
    padding-bottom: 10px !important;
}

.pb-15px {
    padding-bottom: 15px !important;
}

.pb-18px {
    padding-bottom: 18px !important;
}

.pb-30px {
    padding-bottom: 30px !important;
}

.pb-33px {
    padding-bottom: 33px !important;
}

.pb-38px {
    padding-bottom: 38px !important;
}

.pt-10px {
    padding-top: 10px !important;
}

.pt-15px {
    padding-top: 15px !important;
}

.pt-18px {
    padding-top: 18px !important;
}

.pt-30px {
    padding-top: 30px !important;
}

.pt-33px {
    padding-top: 33px !important;
}

.pt-38px {
    padding-top: 38px !important;
}

.p-15px {
    padding: 15px !important;
}

.p-30px {
    padding: 30px !important;
}

.row-15px {
    padding-left: 7.5px;
    padding-right: 7.5px;
}

.row-15px [class*=col-],
.row-15px [class*=col] {
    padding-left: 7.5px;
    padding-right: 7.5px;
}

.row-small {
    justify-content: center;
}

.row-small>.col-12,
.row-small>.col-xl-12 {
    -ms-flex: 0 0 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
}

@media (min-width: 576px) {

    .row-small>.col-12,
    .row-small>.col-xl-12 {
        -ms-flex: 0 0 91.666667% !important;
        flex: 0 0 91.666667% !important;
        max-width: 91.666667% !important;
    }
}

@media (min-width: 768px) {

    .row-small>.col-12,
    .row-small>.col-xl-12 {
        -ms-flex: 0 0 83.333333% !important;
        flex: 0 0 83.333333% !important;
        max-width: 83.333333% !important;
    }
}

@media (min-width: 992px) {

    .row-small>.col-12,
    .row-small>.col-xl-12 {
        -ms-flex: 0 0 75% !important;
        flex: 0 0 75% !important;
        max-width: 75% !important;
    }
}

@media (min-width: 1200px) {

    .row-small>.col-12,
    .row-small>.col-xl-12 {
        -ms-flex: 0 0 66.666667% !important;
        flex: 0 0 66.666667% !important;
        max-width: 66.666667% !important;
    }
}

@media (min-width: 576px) {
    .col-sm-5ths {
        -ms-flex: 0 0 20% !important;
        flex: 0 0 20% !important;
        max-width: 0 0 20% !important;
    }

    .col-sm-7ths {
        -ms-flex: 0 0 14.285714% !important;
        flex: 0 0 14.285714% !important;
        max-width: 0 0 14.285714% !important;
    }

    .col-sm-8ths {
        -ms-flex: 0 0 12.5% !important;
        flex: 0 0 12.5% !important;
        max-width: 0 0 12.5% !important;
    }
}

@media (min-width: 768px) {
    .col-md-5ths {
        -ms-flex: 0 0 20% !important;
        flex: 0 0 20% !important;
        max-width: 0 0 20% !important;
    }

    .col-md-7ths {
        -ms-flex: 0 0 14.285714% !important;
        flex: 0 0 14.285714% !important;
        max-width: 0 0 14.285714% !important;
    }

    .col-md-8ths {
        -ms-flex: 0 0 12.5% !important;
        flex: 0 0 12.5% !important;
        max-width: 0 0 12.5% !important;
    }
}

@media (min-width: 992px) {
    .col-lg-5ths {
        -ms-flex: 0 0 20% !important;
        flex: 0 0 20% !important;
        max-width: 0 0 20% !important;
    }

    .col-lg-7ths {
        -ms-flex: 0 0 14.285714% !important;
        flex: 0 0 14.285714% !important;
        max-width: 0 0 14.285714% !important;
    }

    .col-lg-8ths {
        -ms-flex: 0 0 12.5% !important;
        flex: 0 0 12.5% !important;
        max-width: 0 0 12.5% !important;
    }
}

@media (min-width: 1200px) {
    .col-xl-5ths {
        -ms-flex: 0 0 20% !important;
        flex: 0 0 20% !important;
        max-width: 0 0 20% !important;
    }

    .col-xl-7ths {
        -ms-flex: 0 0 14.285714% !important;
        flex: 0 0 14.285714% !important;
        max-width: 0 0 14.285714% !important;
    }

    .col-xl-8ths {
        -ms-flex: 0 0 12.5% !important;
        flex: 0 0 12.5% !important;
        max-width: 0 0 12.5% !important;
    }

    .col-xl-10ths {
        -ms-flex: 0 0 10% !important;
        flex: 0 0 10% !important;
        max-width: 0 0 10% !important;
    }
}

@media (min-width: 1400px) {
    .col-xxl-1 {
        -ms-flex: 0 0 8.333333% !important;
        flex: 0 0 8.333333% !important;
        max-width: 8.333333% !important;
    }
}


/* COLORS

Navy: var(--navy);
Blue: #008ED6;
Aqua: #00B2AA;
Yellow: #FFCC49;
Plum: #9B4F96;
Lime: var(--lime);
Gray: #494C49;
Orange: #FC9E49;

*/

.bg-navy {
    background: var(--navy);
}

.bg-navy p {
	color: var(--white) !important;
}

.text-navy {
    color: var(--navy);
}

.border-navy {
    border: 1px solid var(--navy);
}

.bg-blue {
    background: #008ED6;
}

.text-blue {
    color: #008ED6;
}

.bg-aqua {
    background: #00B2AA;
}

.text-aqua {
    color: #00B2AA;
}

.bg-yellow {
    background: #FFCC49;
}

.text-yellow {
    color: #FFCC49;
}

.bg-plum {
    background: #9B4F96;
}

.text-plum {
    color: #9B4F96;
}

.bg-lime {
    background: var(--lime);
}

.text-lime {
    color: var(--lime);
}

a.text-lime:hover,
a.text-lime:focus,
a.text-lime:target,
a.text-lime:active {
    color: var(--lime);
    opacity: .8;
}

.border-lime {
    border: 1px solid var(--lime);
}

.bg-gray {
    background: #494C49;
}

.text-gray {
    color: #494C49;
}

.bg-orange {
    background: #FC9E49;
}

.text-orange {
    color: #FC9E49;
}

.bg-trans {
    background: transparent;
}


/* TYPOGRAPHY

font-family: 'Roboto', sans-serif;

*/

.banner-text {
	margin-top:0.5rem !important;
	margin-bottom:0.5rem !important;
}

@media (max-width: 1200px) {
    h1, .h1 {
        font-size: calc(1.5rem + 1vw);
    }

    h2, .h2 {
        font-size: calc(1.4rem + 0.75vw);
    }

    h3, .h3 {
        font-size: calc(1.3rem + 0.6vw);
    }

    h4, .h4 {
        font-size: calc(1.25rem + 0.5vw);
    }

    .display-1 {
        font-size: calc(1.6rem + 3vw);
    }

    .display-2 {
        font-size: calc(1.5rem + 2.75vw);
    }

    .display-3 {
        font-size: calc(1.4rem + 2.25vw);
    }

    .display-4 {
        font-size: calc(1.3rem + 2vw);
    }
}

body {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6, .display-1, .display-2, .display-3, .display-4 {
    color: var(--navy);
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
}

.bg-navy h1,
.bg-navy .h1,
.bg-navy h2,
.bg-navy .h2,
.bg-navy h3,
.bg-navy .h3,
.bg-navy h4,
.bg-navy .h4,
.bg-navy h5,
.bg-navy .h5,
.bg-navy h6,
.bg-navy .h6,
.bg-navy .display-4,
.bg-navy .display-3,
.bg-navy .display-2,
.bg-navy .display-1 {
    color: var(--white);
}

.lh-1 {
    line-height: 1 !important;
}

.lh-115 {
    line-height: 1.15 !important;
}

.lh-125 {
    line-height: 1.25 !important;
}

a {
    font-weight: 500;
    color: var(--navy);
    transition: all .3s ease;
}

a:hover,
a:focus,
a:target,
a:active {
    color: var(--light-navy);
    transition: all .3s ease;
}

.font-weight-400 {
    font-weight: 400;
}

.font-weight-500 {
    font-weight: 500;
}

.font-weight-700 {
    font-weight: 700;
}

.font-weight-900 {
    font-weight: 900;
}

.font-weight-bold {
    font-weight: 700 !important;
}

strong, b {
    font-weight: 700 !important;
}

.font-12px {
    font-size: 12px !important;
}

.font-13px {
    font-size: 13px !important;
}

.font-14px {
    font-size: 14px !important;
}

.font-15px {
    font-size: 15px !important;
}

.font-16px {
    font-size: 16px !important;
}

.font-17px {
    font-size: 17px !important;
}

.font-18px {
    font-size: 18px !important;
}

.font-19px {
    font-size: 19px !important;
}

.font-20px {
    font-size: 20px !important;
}

.font-21px {
    font-size: 21px !important;
}

.font-22px {
    font-size: 22px !important;
}

.font-23px {
    font-size: 23px !important;
}

.font-24px {
    font-size: 24px !important;
}

.font-25px {
    font-size: 25px !important;
}

.font-26px {
    font-size: 26px !important;
}

.font-50px {
    font-size: 50px !important;
}

.font-75px {
    font-size: 75px !important;
}

@media (max-width: 1199.98px) {
    .lead {
        font-size: 1.2rem;
    }
}

@media (max-width: 575.98px) {
    .lead {
        font-size: 1.1rem;
    }
}

hr {
    margin: 1.5rem 0;
}


/* BUTTONS */

.btn-row {
    padding-left: 7.5px !important;
    padding-right: 7.5px !important;
}

.btn-row [class*=col-],
.btn-row [class*=col] {
    padding-left: 7.5px !important;
    padding-right: 7.5px !important;
}

.btn-row .btn {
    margin-top: 15px;
}

.btn {
    font-weight: 500;
}

.btn-rounded {
    border-radius: 30px;
}

.btn-reg {
    padding: .75rem 1.75rem;
    border-radius: 30px;
}

.content-loop-row btn-reg {
	margin-bottom:20px;
}

.btn-reg .fa-external-link {
    font-size: 12px;
    vertical-align: top;
    margin-top: 6px;
}

.btn-sm {
    font-size: 12px;
}

.btn.focus,
.btn:focus {
    box-shadow: none !important;
    outline: -webkit-focus-ring-color auto 1px !important;
}

.btn-lime {
    background-color: var(--lime);
    color: var(--white);
}

.btn-lime:hover,
.btn-lime:focus,
.btn-lime:target,
.btn-lime:active {
    background-color: var(--dark-lime);
    color: var(--white);
}

.btn-navy {
    background-color: var(--navy);
    color: var(--white);
}

.btn-navy:hover,
.btn-navy:focus,
.btn-navy:target,
.btn-navy:active {
    background-color: var(--light-navy);
    color: var(--gray-100);
}

.btn-light {
    color: var(--navy);
}

.btn-light:hover,
.btn-light:focus,
.btn-light:target,
.btn-light:active {
    color: var(--light-navy) !important;
}

.btn-outline-light:hover,
.btn-outline-light:focus,
.btn-outline-light:target,
.btn-outline-light:active {
    color: var(--light-navy) !important;
    background-color: var(--gray-100);
    border-color: var(--gray-100);
}

@media (max-width: 991.98px) {
    .contact-buttons {
        flex-direction: column;
    }

    .contact-buttons .btn:first-of-type {
        margin-left: -1px;
    }

    .contact-buttons .btn {
        margin-bottom: 15px;
        border-radius: 30px !important;
    }

    .contact-buttons .btn:last-of-type {
        margin-bottom: 0;
    }
}


/* TOP BAR */

#top_bar {
    font-size: 14px;
}

ul.sm-nav {
	padding: 0;
	margin: 0;
}

@media (min-width: 1200px) {
    ul.sm-nav {
    	margin-left: -.5rem;
    }
}

.sm-nav li {
	list-style-type: none;
	padding: 0;
	display: inline-block;
}

.sm-nav li a {
    padding: .5rem;
	color: var(--white);
}

.sm-nav li a:hover,
.sm-nav li a:focus {
	opacity: .8;
}

.sm-nav.text-blue li a {
    color: var(--navy) !important;
}

a.topbar {
	color: var(--white);
}

a.topbar:hover,
a.topbar:focus {
	opacity: .8;
}

@media (max-width: 1199.98px) {
    .sm-nav li a {
        font-size: 1.5rem;
    }
}


/* NAVIGATION */

.navbar {
    padding-top: 15px;
    padding-bottom: 15px;
    transition: all .3s ease;
    background: transparent;
}

a.navbar-brand {
    padding: 0;
}

a.navbar-brand:hover,
a.navbar-brand:focus {
    opacity: .8;
}

.navbar-nav .nav-item .nav-link {
    font-weight: 500;
    color: var(--white);
}

.dropdown-menu {
    border-radius: 0;
    background-clip: border-box;
    border: 1px solid var(--gray-300);
    padding: .5rem;
}

.dropdown-item {
    font-weight: 500;
    padding: .5rem .75rem;
    font-size: 14px;
    color: var(--navy);
    line-height: 1.25;
    white-space: normal;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--white);
    color: var(--light-navy);
}

.dropdown-item span {
    float: right;
    margin-left: .25rem;
}

.cta-btn {
    color: var(--white) !important;
    opacity: 1 !important;
    padding-left: 2rem !important;
    padding-right: 2rem !important;
}

@media (min-width: 1200px) {
    #searchbar {
        position: absolute;
        left: 0;
        right: 0;
        margin: auto;
        width: 1110px;
        transition: all .3s ease;
        top: 50%;
        transform: translateY(-50%);
    }

    /* .navbar {
        background: linear-gradient(rgba(0,0,0,.25),rgba(0,0,0,0));
    } */

    .navbar-scrolled {
        background: var(--white);
        box-shadow: 0px 10px 20px rgba(0,0,0,.08);
        transition: all .3s ease;
    }

    .navbar-brand img {
        width: 78px;
        height: 48px;
    }

    .navbar-expand-xl .navbar-nav .nav-link {
    	padding: .75rem;
    }

    .navbar-scrolled.navbar-expand-xl .navbar-nav .nav-link {
    	color: var(--navy);
        text-shadow: none;
    }

    .navbar-nav .nav-item .nav-link:hover,
    .navbar-nav .nav-item .nav-link:focus {
        opacity: .8;
        transition: all .3s ease;
    }

    .navbar-expand-xl .navbar-nav .nav-link .fa-search {
        -webkit-filter: drop-shadow(0px 0px 15px rgba(0,0,0,.27));
        filter: drop-shadow(0px 0px 15px rgba(0,0,0,.27));
    }

    .navbar-scrolled.navbar-expand-xl .navbar-nav .nav-link .fa-search {
        -webkit-filter: none;
        filter: none;
    }

    .dropdown:hover a.nav-link {
        opacity: .8;
        transition: all .3s ease;
    }

    .dropdown-toggle:after {
        border: 0;
        content: "\f078";
        font: var(--fa-font-solid);
        font-size: 10px !important;
        width: 10px;
        right: 0;
        top: 1px;
        position: relative;
        margin-left: 2px;
        color: inherit;
        display: inline-block !important;
        font-style: normal;
        font-variant: normal;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        transform: rotate(0deg);
        transition: transform .2s ease;
    }

    .dropdown.show .dropdown-toggle:after {
        transform: rotate(-180deg);
        transition: transform .1s ease-in-out;
    }

    .dropdown.show .dropdown-menu {
        margin: 0;
    }

    .dropdown-menu {
        margin: 0;
        min-width: 255px;
        box-shadow: 0px 10px 20px rgba(0,0,0,.08);
    }

    .dropdown:last-of-type > .dropdown-menu {
	    left: auto;
	    right: 0;
	}

    .nav-item-search {
        width: 46px;
    }
}

@media (max-width: 1199.98px) {
    .navbar {
        background-color: var(--white);
        padding: 15px;
    }

    .brand-color {
        display: none !important;
    }

    a.navbar-brand {
        padding: 0;
    }

    .navbar-brand img {
        width: 71px;
        height: 44px;
        transition: all .3s ease;
    }

    .brand-white {
        display: none !important;
    }

    .navbar-nav .nav-item .nav-link {
        color: var(--navy);
    	padding: .75rem 1.25rem .75rem .75rem;
        border: 1px solid transparent;
        border-top: 1px solid #DEE2E6;
    }

    .navbar-nav .nav-item:first-of-type .nav-link {
        border-top: none;
    }

    .navbar-collapse {
		max-height: calc(80vh - 70px);
		overflow-y: auto;
        -ms-overflow-style: none;
        scrollbar-width: none;
	}

	.navbar-collapse::-webkit-scrollbar {
		display: none;
	}

    .navbar-nav {
        padding: 15px 0;
    }

    .dropdown.show .nav-link {
    	color: var(--white);
        background-color: var(--navy);
        outline: none;
    }

    .dropdown .dropdown-toggle:after {
        position: absolute;
        right: .75rem;
        top: 15px;
        font-size: 1rem;
        background-color: none;
        border: 0;
        font-size: 1rem;
        content: "\f078";
        font: var(--fa-font-solid);
        color: inherit;
        display: inline-block !important;
        font-style: normal;
        font-variant: normal;
        text-rendering: auto;
        -webkit-font-smoothing: antialiased;
        transform: rotate(0deg);
        transition: transform .2s ease;
    }

    .dropdown.show .dropdown-toggle:after {
        transform: rotate(-180deg);
        transition: transform .1s ease-in-out;
    }

    .dropdown-menu {
        padding: .5rem;
        margin: 0;
        background-color: var(--white);
        border-top: 1px solid transparent;
        border-bottom: 1px solid transparent;
    }

    .dropdown-item {
        padding: .5rem .75rem;
    }

    .nav-item-search {
        display: none;
    }
}

.navbar-nav .nav-item.nav-link-active .nav-link {
    opacity: .8 !important;
    text-decoration: underline;
}


/* MOBILE MENU */

@media (min-width: 1200px) {
    .navbar-toggler {
        display: none;
    }
}

.navbar-toggler {
    margin: 0 -15px 0 0;
    padding: 15px;
    border: none;
    background: transparent;
}

.navbar-toggler:focus {
    outline: none;
    background: transparent !important;
}

.navbar-toggler .icon-bar {
    background-color: var(--navy);
    transform: rotate(0deg) translate(0px, 0px);
    transition: ease all .2s;
}

.navbar-toggler .icon-bar {
    display: block;
    width: 22px;
    height: 2px;
    border-radius: 0;
}

.navbar-toggler .icon-bar+.icon-bar {
    margin-top: 4px;
}

.icon-bar:nth-child(2) {
    width: 22px;
    transition: ease all .2s;
}

.navbar-toggler:hover>.icon-bar:nth-child(2) {
    width: 22px;
    transition: ease all .2s;
}

.navbar-toggler:active>.icon-bar:nth-child(2) {
    width: 22px;
    transition: ease all .2s;
}

.navbar-toggler:not(.collapsed) .icon-bar:nth-child(1) {
    background-color: red;
    transform: rotate(45deg) translate(5px, 4px);
    transition: ease all .2s;
}

.navbar-toggler:not(.collapsed) .icon-bar:nth-child(2) {
    opacity: 0;
    transition: ease all .2s;
}

.navbar-toggler:not(.collapsed) .icon-bar:nth-child(3) {
    background-color: red;
    transform: rotate(-45deg) translate(4px, -4px);
    transition: ease all .2s;
}


/* HERO */

@media (min-width: 1200px) {
    .nav-offset {
        margin-top: -90px;
    }
}

#hero {
    position: relative;
    background-color: var(--navy);
    border-bottom: 6px solid var(--lime);
}

#hero .carousel-item {
    overflow: hidden;
}

.hero-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: linear-gradient(rgba(0,0,0,.54),rgba(0,0,0,.54));
}

.hero-text {
    color: var(--white);
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    transform: translateY(-50%);
}

.hero-text h2 {
    color: var(--white);
    line-height: 1.1;
    margin-bottom: 0;
    text-shadow: 0px 0px 15px rgba(0,0,0,.15);
}

.hero-text p {
    color: var(--white);
    font-size: 1.25rem;
    margin-top: .75rem;
    margin-bottom: 0;
    text-shadow: 0px 0px 15px rgba(0,0,0,.27);
}

.hero-text a {
    margin-top: 1.25rem;
    color: var(--white);
}

.hero-text a:hover,
.hero-text a:focus {
    color: #CBD3DA;
}

.hero-text a.btn {
    color: var(--white) !important;
    font-size: 1.15rem;
}

.bg-hero {
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
    height: calc(90vh - 134px);
    max-height: 1080px;
    min-height: 540px;
}

@media (max-width: 1199.98px) {
    .bg-hero {
        height: calc(90vh - 40px);
    }

    .hero-text p {
        font-size: 1.2rem;
    }

    .hero-text a.btn {
        font-size: 1rem;
    }
}

@media (max-width: 991.98px) {
    .bg-hero {
        height: calc(85vh - 44px);
    }

    .hero-text h2 {
        margin-bottom: .75rem;
    }

    .hero-text p {
        font-size: 1.175rem;
        margin-bottom: 1rem;
    }
}

@media (max-width: 767.98px) {
    .bg-hero {
        height: calc(85vh - 44px);
    }

    .hero-text p {
        line-height: 1.35;
        font-size: 1.15rem;
    }
}

@media (max-width: 575.98px) {
    .bg-hero {
        height: calc(80vh - 44px);
    }

    .hero-text p {
        font-size: 1.1rem;
    }
}

ol.carousel-indicators {
    bottom: 15px;
    margin-bottom: 0;
}

#hero .carousel-indicators li {
    border-radius: 100%;
    width: 12px;
    height: 12px;
    margin-left: 5px;
    margin-right: 5px;
    opacity: 1;
}

.carousel-indicators li {
    background-color: rgba(255,255,255,.5);
    border: 1px solid rgba(255,255,255,.5);
    height: 4px;
    margin-left: 4px;
    margin-right: 4px;
    border-radius: 1px;
    opacity: 1;
    box-shadow: 0px 10px 20px rgba(0,0,0,.15);
}

.carousel-indicators li.active {
    background-color: var(--white);
    border: 1px solid var(--white);
    opacity: 1;
}

.carousel-control-prev,
.carousel-control-next {
    width: 35px;
    opacity: 1;
}

@media (max-width: 767.98px) {
    #hero .carousel-control-prev, #hero .carousel-control-next {
        display: none;
    }
}


/* TEAM */

.team-link {
    color: var(--navy) !important;
    margin-bottom: 0;
}

.team-container.has-link:hover .team-img {
    border: 1px solid var(--lime);
}

.team-img {
    position: relative;
    margin-bottom: .5rem;
    border: 1px solid var(--gray-300);
    border-radius: 100%;
    transition: all .3s ease;
}

.team-img img {
    width: 100%;
    border-radius: 100%;
    aspect-ratio: 1/1;
}

.modal-body .team-img {
    width: 225px;
    margin: 0 auto .5rem auto;
}

.team-subcategory {
    display: block;
    width: 100%;
    position: absolute;
    z-index: 1;
    top: auto;
    left: auto;
    right: 5px;
    bottom: 5px;
    /* left: 50%;
    transform: translateX(-50%);
    text-align: center; */
    font-size: 12px;
    text-align: right;
}

.team-subcategory span {
    color: var(--black);
    background-color: var(--white);
    padding: 2px 5px;
}


/* CARDS */

.card {
    border: 1px solid var(--gray-300);
    border-radius: 0;
    transition: all .3s ease;
}

.card-header:first-child {
    border-radius: 0;
}

.card-body p:last-child {
    margin-bottom: 0;
}

.card-footer:last-child {
    border-radius: 0;
}

.blue-card-header {
    background-color: var(--navy);
	color: var(--white);
    padding: .8rem;
	font-weight:bold;
	line-height: 1.2rem;
}

.card-header {
    background-color: var(--white);
    padding: 1.5rem;
    border-bottom: 1px solid var(--gray-300);
}

.card-body {
    padding: 1.5rem;
}

.card-footer {
    padding: 1.5rem;
}

.card-img-overlay {
    background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.85));
}

.card-img-overlay p {
    color: var(--white);
    position: absolute;
    bottom: 1.5rem;
    left: 0;
    right: 0;
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: 0;
    text-shadow: 0px 2px 5px rgba(75,75,75,1);
}

@media (min-width: 1200px) {
  .zoom-wrapper {
		position: relative;
		overflow: hidden !important;
	}

	.zoom-wrapper img {
		max-width: 100% !important;
		-webkit-transition: all 0.3s ease;
		-moz-transition: all 0.3s ease;
		transition: all 0.3s ease;
	}

	.card-zoom:hover img {
		-webkit-transform: scale(1.05);
		-moz-transform: scale(1.05);
		transform: scale(1.05);
  }
}

.card-parent {
    overflow: hidden;
}

.card-parent .card-slant-overlay {
    display: none;
}

span.card-slant-overlay {
    background-color: rgba(0,79,108,.75);
    position: absolute;
    width: 100%;
    height: 40%;
    bottom: 0;
    left: 0;
    transform: skewY(4deg);
    transform-origin: bottom left;
}

.card-overlay-text h2 {
    color: var(--white);
}

.card-overlay-text p {
    color: var(--white);
}

.card-overlay-text {
    position: relative;
    padding: 1.5rem 15px;
    background-color: var(--navy);
}

.card-overlay-text .badge {
    margin-bottom: .75rem;
}

@media (min-width: 768px) {
    .card-overlay-text {
        position: absolute;
        padding: 1.5rem;
        bottom: 0;
        left: 0;
        right: 0;
        background-color: transparent;
    }

    .card-parent .card-slant-overlay {
        display: block;
    }

    .card-overlay-text h2 {
        text-shadow: 0px 0px 10px rgba(0,79,108,.2);
    }

    .card-overlay-text p {
        margin-bottom: 0;
        text-shadow: 0px 0px 10px rgba(0,79,108,.4);
    }
}


/* IMAGE BOXES */

.image-box-text {
    padding: 3rem 15px;
}

@media (min-width: 1200px) {
    .image-box-text {
        padding: 15px 3rem;
    }
}


/* SUB PAGE */

.subpage-banner {
    position: relative;
    padding: 25rem 0 1.5rem 0;
    overflow: hidden;
    background-color: var(--navy);
    -webkit-background-size: cover !important;
    -moz-background-size: cover !important;
    -o-background-size: cover !important;
    background-size: cover !important;
}

.subpage-overlay {
    position: absolute;
    z-index: 1;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: linear-gradient(rgba(0,0,0,.54), rgba(0,0,0,.54));
}

.subpage-banner .subpage-banner-text {
    position: relative;
    z-index: 2;
    text-align: center;
}

.subpage-banner h1 {
    color: var(--white);
    margin-bottom: 0;
    text-shadow: 0px 0px 10px rgba(0,79,108,.2);
}

span.slant-overlay-left {
    background-color: rgba(0,79,108,.75);
    position: absolute;
    z-index: 2;
    width: 50%;
    height: 75%;
    bottom: 0;
    left: 0;
    transform: skewY(-5deg);
    top: 94%;
    transform-origin: bottom left;
}

span.slant-overlay-right {
    background-color: rgba(0,79,108,.75);
    position: absolute;
    z-index: 2;
    width: 50%;
    height: 75%;
    bottom: 0;
    right: 0;
    transform: skewY(5deg);
    top: 94%;
    transform-origin: bottom right;
}

@media (max-width: 1600px) {
    span.slant-overlay-left {
        top: 92%;
    }

    span.slant-overlay-right {
        top: 92%;
    }
}

@media (max-width: 1199.98px) {
    span.slant-overlay-left {
        top: 90%;
    }

    span.slant-overlay-right {
        top: 90%;
    }
}

@media (max-width: 991.98px) {
    span.slant-overlay-left {
        top: 88%;
    }

    span.slant-overlay-right {
        top: 88%;
    }
}

@media (max-width: 767.98px) {
    span.slant-overlay-left {
        top: 84%;
    }

    span.slant-overlay-right {
        top: 84%;
    }
}

@media (max-width: 575.98px) {
    span.slant-overlay-left {
        top: 80%;
    }

    span.slant-overlay-right {
        top: 80%;
    }
}

@media (min-width: 1200px) {
    .subpage-banner {
        margin-top: -90px;
    }
}

@media (max-width: 1199.98px) {
    span.slant-overlay {
        height: 42%;
    }

    .subpage-banner {
        padding: 20rem 0 1rem 0;
    }
}

@media (max-width: 991.98px) {
    span.slant-overlay {
        height: 44%;
    }

    .subpage-banner {
        padding: 16rem 0 1rem 0;
    }
}

@media (max-width: 767.98px) {
    .subpage-banner {
        padding: 14rem 0 1rem 0;
    }
}

@media (max-width: 575.98px) {
    .subpage-banner {
        padding: 12rem 0 1rem 0;
    }
}


/* BREADCRUMBS */

.breadcrumb {
    margin-bottom: .25rem;
    padding: 0;
    background-color: transparent;
}

.breadcrumb li {
    color: var(--white);
}

.breadcrumb li.parent {
    color: var(--white);
    opacity: .8;
}

.breadcrumb li.active {
    color: var(--white);
    opacity: .8;
}

.breadcrumb li a {
    color: var(--white);
}

.breadcrumb li a:hover,
.breadcrumb li a:focus,
.breadcrumb li a:target,
.breadcrumb li a:active {
    color: var(--white);
    opacity: .8;
}

@media (max-width: 991.98px) {
    .breadcrumb {
        font-size: 14px;
    }
}


/* SIDEBAR */

ul.subpage-nav {
    text-decoration: none;
    padding: .75rem .5rem;
    margin: 0;
}

.subpage-nav li {
    padding: 0;
    list-style-type: none;
}

.subpage-nav li a {
    color: var(--navy);
    text-decoration: none;
    font-weight: 500;
    padding: .5rem .75rem;
    font-size: 14px;
    line-height: 1.25;
    display: block;
    width: 100%;
}

.subpage-nav li a:hover,
.subpage-nav li a:focus {
    color: var(--navy);
    text-decoration: none;
    background-color: var(--white);
}

.subpage-nav li a span {
    float: right;
    margin-left: .25rem;
}

.subnav-active a {
    border-left: .5rem solid var(--lime);
    color: var(--light-navy) !important;
    background-color: var(--gray-100);
    text-decoration: none;
    transition: all .2s ease;
}

.subnav-active a:hover {
    color: var(--light-navy) !important;
}


/* COLLAPSE */

.expand-btn {
    background-color: #007BFF;
    font-size: 1rem;
    font-weight: 700;
    color: var(--white);
    text-align: left;
    padding: .75rem 2.5rem .75rem 1rem;
    white-space: normal;
    border: 1px solid #007BFF;
    position: relative;
}

.expand-btn.collapsed {
    background-color: var(--gray-100);
    font-size: 1rem;
    font-weight: 700;
    color: #007BFF;
    text-align: left;
    padding: .75rem 2.5rem .75rem 1rem;
    white-space: normal;
    border: 1px solid #DEE2E6;
    position: relative;
}

.expand-btn.collapsed:hover {
    color: #007BFF;
    background-color: #E2E6EA;
    box-shadow: none;
}

.expand-btn:hover {
    color: var(--white);
    background-color: #007BFF;
    box-shadow: none;
}

.expand-btn:focus {
    border: 1px solid #007BFF;
    box-shadow: none;
}

.expand-btn::after {
    color: #007BFF;
    font-size: 1rem;
    content: "\f107";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    right: .75rem;
    top: .75rem;
    position: absolute;
    color: inherit;
    display: inline-block !important;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    transform: rotate(-180deg);
    -webkit-font-smoothing: antialiased;
    transition: all .2s ease;
}

.expand-btn.collapsed::after {
    color: #007BFF;
    font-size: 1rem;
    content: "\f107";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    right: .75rem;
    top: .75rem;
    position: absolute;
    color: inherit;
    display: inline-block !important;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    transform: rotate(0deg);
    transition: all .2s ease;
}

ul.link-list {
    padding: 0;
    margin: 0;
}

.link-list li {
    list-style-type: none;
    padding: .25rem 0;
}

.link-list li:last-child {
    border-bottom: none;
}

.link-list li a {
    display: block;
    width: 100%;
}


/* TOOLTIPS */

.tooltip {
    opacity: 1 !important;
}

.tooltip-inner {
    font-size: 12px;
    font-weight: 500;
    color: var(--navy);
    background-color: var(--white);
    border-radius: 0;
    text-align: center;
    padding: 4px 6px !important;
    box-shadow: 0px 0px 30px rgba(0, 0, 0, .1);
}

.tooltip.bs-tooltip-right .arrow:before {
    border-right-color: var(--white) !important;
}

.tooltip.bs-tooltip-left .arrow:before {
    border-left-color: var(--white) !important;
}

.tooltip.bs-tooltip-bottom .arrow:before {
    border-bottom-color: var(--white) !important;
}

.tooltip.bs-tooltip-top .arrow:before {
    margin-top: -1px;
    border-top-color: var(--white) !important;
}


/* MODALS */

.modal-body p:last-child {
	margin-bottom: 0;
}

.modal-content {
    border: 0;
    border-radius: 0;
    background-clip: content-box;
}

.modal-header, .modal-footer {
    border-radius: 0;
}

.modal-header,
.modal-body,
.modal-footer {
    padding: 1.5rem;
}

.modal .close {
    font-size: 1rem;
    opacity: 1;
}

.modal .floating-close {
    position: absolute;
    z-index: 2;
    top: 0;
    right: 0;
    left: auto;
    margin: 0;
    padding: 15px;
}

.modal .floating-close.close {
    background-color: var(--red);
    color: var(--white);
    border-radius: 0;
    border: 0;
}

.modal .floating-close.close:hover,
.modal .floating-close.close:focus,
.modal .floating-close.close:target,
.modal .floating-close.close:active {
    opacity: 1;
    background-color: var(--light-red);
    color: var(--white);
}


/* FORMS */

form.white-labels label {
    color: var(--white);
}

legend {
    text-transform: uppercase;
}

label {
    font-weight: 700;
    font-size: 12px;
    color: var(--gray);
    text-align: left !important;
    margin-bottom: 5px;
}

.label span,
label span {
    font-size: 12px;
}

.input-group-text {
    color: var(--white);
    background-color: var(--navy);
    border: 1px solid var(--white);
    border-radius: 0;
}

.input-group-text label {
    margin-bottom: 0;
}

.input-group-append .btn {
    border-radius: 0 30px 30px 0;
}

.btn-radio {
    text-align: center !important;
    background-color: var(--white);
    border: 1px solid var(--gray-300);
}

form .row {
    margin-bottom: 15px;
}

.form-group {
    margin-bottom: 15px;
}

.custom-select {
    background-color: var(--white);
    border: 1px solid var(--gray-300);
    border-radius: 30px;
    transition: all .3s ease;
}

.form-control {
    background-color: var(--white);
    border: 1px solid var(--gray-300);
    border-radius: 30px;
    transition: all .3s ease;
}

.form-control.flush,
.custom-select.flush {
    border: 1px solid var(--white);
}

.form-control:focus,
.custom-select:focus {
    border: 1px solid var(--gray-300);
    outline: -webkit-focus-ring-color auto 1px;
    box-shadow: none;
}

.form-control.is-invalid,
.was-validated .form-control:invalid {
    border-color: var(--red);
}

.form-control.custom-select.is-invalid,
.was-validated .form-control.custom-select:invalid {
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right .75rem center/8px 10px no-repeat,
        #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545' viewBox='0 0 12 12'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23AA182C' stroke='none'/%3e%3c/svg%3e") center right 1.75rem/calc(.75em + .375rem) calc(.75em + .375rem) no-repeat;
}

.form-control.custom-select.is-valid,
.was-validated .form-control.custom-select:valid {
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='4' height='5' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") right .75rem center/8px 10px no-repeat,
        #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3e%3cpath fill='%2328a745' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") center right 1.75rem/calc(.75em + .375rem) calc(.75em + .375rem) no-repeat;
}

.form-control.is-invalid:focus,
.was-validated .form-control:invalid:focus {
    border-color: var(--red);
    box-shadow: 0 0 0 0.2rem rgb(209 13 31 / 25%);
}

.invalid-feedback {
    color: var(--red);
    background-color: var(--white);
    font-size: 12px;
    padding: 0 5px;
    margin: 0 1px;
    width: calc(100% - 2px);
}

#newsletter_signup {
    border-radius: 0 30px 30px 0;
}


/* ALERTS */

.alert {
    border: 0;
    border-radius: 0;
    padding-top: .5rem;
    padding-bottom: .5rem;
    font-size: .9rem;
}

.alert a {
    display: inline-block;
}

.alert.bg-danger a {
	color: var(--white);
}

.alert.bg-danger a:hover,
.alert.bg-danger a:focus {
	opacity: .8;
}

.alert.bg-plum a {
	color: var(--white);
}

.alert.bg-plum a:hover,
.alert.bg-plum a:focus {
	opacity: .8;
}

.alert-dismissible .close {
    display: inline-block;
    padding: 0;
    right: 1.5rem;
}

@media (max-width: 575.98px) {
    .alert-dismissible .close {
        right: 15px;
    }
}


/* LOGOS */

.logo-link {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    background-size: 0 0 !important;
    transition: all .3s ease;
}

.logo-link img {
    width: 100%;
    padding: 0.75rem;
}

.logo-link {
    border: 1px solid var(--gray-300);
}

.logo-link:hover,
.logo-link:focus,
.logo-link:target,
.logo-link:active {
    background-color: var(--white);
    border: 1px solid var(--lime);
}

.brand-inner {
    display: flex;
    height: 100%;
}

.brand-inner p {
    font-size: 12px;
    font-weight: 500;
    margin-bottom: 0;
    width: 100%;
    padding: 15px;
    align-self: center;
    text-align: center;
}


/* FOOTER */

footer {
    border-bottom: 6px solid var(--lime);
}

.footer-angle {
    width: 100%;
    height: 8rem;
    background-color: var(--navy);
    overflow: hidden;
    position: relative;
}

@media (max-width: 767.98px) {
    .footer-angle {
        height: 6rem;
    }

    .left-patch:before {
        -moz-transform: skewY(-3deg);
        -webkit-transform: skewY(-3deg);
        -o-transform: skewY(-3deg);
        -ms-transform: skewY(-3deg);
        transform: skewY(-3deg);
    }

    .right-patch:before {
        -moz-transform: skewY(3deg);
        -webkit-transform: skewY(3deg);
        -o-transform: skewY(3deg);
        -ms-transform: skewY(3deg);
        transform: skewY(3deg);
    }
}

.left-patch {
    position: relative;
    width: 50%;
    height: 100%;
    float: left;
}

.right-patch {
    position: relative;
    width: 50%;
    height: 100%;
    float: left;
}

.left-patch:before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100vh;
    background-color: var(--gray-100);
    bottom: 25%;
    -moz-transform: skewY(-6deg);
    -webkit-transform: skewY(-6deg);
    -o-transform: skewY(-6deg);
    -ms-transform: skewY(-6deg);
    transform: skewY(-6deg);
}

.right-patch:after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100vh;
    background-color: var(--gray-100);
    bottom: 25%;
    -moz-transform: skewY(6deg);
    -webkit-transform: skewY(6deg);
    -o-transform: skewY(6deg);
    -ms-transform: skewY(6deg);
    transform: skewY(6deg);
    right: 0;
}

.footer-logo {
    width: 234px;
    height: 60px;
}

ul.sm-nav-footer {
    padding: 0;
    margin: 0;
    display: inline-block;
}

.sm-nav-footer li {
	list-style-type: none;
	display: inline-block;
}

.sm-nav-footer li a {
    font-size: 1.5rem;
    padding: .5rem;
    color: var(--white);
    transition: all .3s ease;
}

.sm-nav-footer li a:hover,
.sm-nav-footer li a:focus {
    color: rgba(255,255,255,.75);
    transition: all .3s ease;
}

ul.contact-links {
    padding: 0;
    margin: 0;
    font-size: 14px;
}

.contact-links li {
	list-style-type: none;
}

.contact-links li:first-of-type {
    border-top: 0;
}

.contact-links li a {
    padding: .35rem 0;
    color: var(--white);
    display: block;
}

.white-list li a:hover,
.white-list li a:focus,
.white-list li a:target,
.white-list li a:active {
	color: var(--white);
}

ul.white-list {
    padding: 0;
    margin: 0;
}

.white-list li {
	list-style-type: none;
}

.white-list li a {
    font-size: .9rem;
    padding: .25rem 0;
    color: var(--white);
    display: block;
}

.white-list li a:hover,
.white-list li a:focus,
.white-list li a:target,
.white-list li a:active {
	color: var(--white);
}

/* CENTERED IMAGE CONTAINER */
    .centered-image-container {
        max-width: 800px;
        margin: 0 auto; /* Center the container horizontally */
    }

    .centered-image-container img {
        width: 100%; /* Ensures the image is responsive */
        height: auto; /* Maintains the aspect ratio */
    }


/* TO TOP */

.scroll-top {
    position: fixed;
    opacity: 0;
    visibility: hidden;
    text-align: center;
    z-index: 1020;
    background-color: var(--white);
    color: var(--navy);
    width: 40px;
    height: 40px;
    border-radius: 100%;
    line-height: 40px;
    right: 15px;
    bottom: 15px;
    transition: all 0.5s ease-in-out;
    box-shadow: 0px 10px 20px rgba(0, 0, 0, .08);
}

.scroll-top.show {
    visibility: visible;
    cursor: pointer;
    opacity: 1;
    box-shadow: 0px 10px 20px rgba(0, 0, 0, .08);
}

.scroll-top.show:hover,
.scroll-top.show:focus {
    color: var(--light-navy);
    background-color: var(--gray-100);
    box-shadow: 0px 10px 20px rgba(0, 0, 0, .15);
}