/* Import Rules */
 @import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

/* Variables.css | Oct 24, 2025 @5:01:34 PM  */

:root {
--body-background-color: rgb(247, 250, 252);
--header-background-color: #FFF;

    --brand-color: #1B51A3;
--brand-color-secondary: #3f9efc;
--brand-color-tertiary: #e7e7e8;
--link-color: var(--brand-color);

    --btn-text-color:#FFF;
    --btn-background-color:var(--brand-color);
    --btn-border:none;

    --btn-text-color-hover: var(--btn-text-color);
    --btn-background-color-hover: var(--brand-color);
    --btn-border-hover: var(--btn-border);

    --btn-alt-text-color: var(--brand-color);
    --btn-alt-background-color: var(--brand-color-tertiary);
    --btn-alt-border:none;

    --btn-alt-text-color-hover: var(--brand-color);
    --btn-alt-background-color-hover: #FFF;
    --btn-alt-border-hover: var(--btn-alt-border);

    --wrapper-width: 1024px;
    --wrapper-width-slim: 660px;
    --wrapper-width-thin: 900px;
    --wrapper-width-wide: 1400px;

    --column-padding: 2rem;   
}/* Typography.css | Oct 24, 2025 @5:40:04 PM  */

body {
font-family: Barlow, sans-serif;
font-weight: 300;
}

a {
color: var(--brand-color);
text-decoration: underline;
}

p:last-child {
margin: 0;
}

.module-intro-text p {
font-size: 2.3rem;
font-weight: normal;
}

/* Buttons */

.btn {
position: relative;
font-size: var(--font-size-md);
font-weight: 700;
letter-spacing: 1px;
text-transform: uppercase;
padding: 15px 25px;
border-radius: 100px;
}

.btn:not(.alt) {
color: #FFF;
background: var(--btn-background-color);
}

.btn:not(.alt):hover {
color: #FFF;
background: var(--btn-background-color);
}

.btn.alt,
.btn.alt:hover {
color: var(--brand-color);
background: var(--btn-alt-background-color);
}

.btn::after {
content: "";
display: block;
position: absolute;
bottom: -3px;
left: 30px;
border-radius: 100px;
width: 0;
height: 6px;
background-color: var(--brand-color);
transition: 0.2s ease all;
}

.btn:hover::after {
width: calc(100% - 60px);
background-color: var(--brand-color-tertiary);
}

.btn.alt::after {
background-color: var(--brand-color-tertiary);
}

.btn.alt:hover::after {
background-color: var(--brand-color);
}

/* Headings */

h1, h2, h3, h4, h5, h6 {
line-height: 1.25em;
margin-bottom: 2rem;
color: var(--brand-color);
}

.column-widget .module-intro-text h2:only-child {
margin: 0;
}/* General.css | Oct 24, 2025 @5:06:47 PM  */

body {
background: var(--body-background-color);
overflow-x: hidden;
}

img {
max-width: 100%;
height: auto;
}

main .content-module img {
border-radius: 20px;
overflow: hidden;
}
.wrapper {
max-width: var(--wrapper-width-wide);
margin: auto;
padding: var(--column-padding);
}

hr {
margin: 2rem auto;
padding: 0;
width: 100%;
height: 2px;
background-color: var(--brand-color);
border: none;
opacity: 0.5;
}

.btn + .btn {
margin: 0 0 0 5px;
}

/* Header & Navigation */

.include-header {
position: relative;
z-index: 10;
}
header {
width: 100%;
display: block;
background-color: var(--header-background-color);
box-shadow: 0 3px 50px rgba(0,0,0,0.3);

.wrapper {
display: flex;
align-items: center;
justify-content: space-between;
}

.site-logo {
display: flex;
width: 100%;
max-width: 290px;
padding: 0 2rem;
}

.navigation-widget {
flex: 1;
text-align: right;

&.standard:not(.collapse) {
.l1 {

> a {
position: relative;
padding: 2rem;
font-size: 1.6rem;
font-weight: 700;
letter-spacing: 1px;
color: var(--brand-color);
text-transform: uppercase;

&::after {
content: "";
display: block;
position: absolute;
bottom: 0;
left: 30px;
border-radius: 100px;
width: 0;
height: 6px;
background-color: var(--brand-color);
transition: 0.2s ease all;
}
}

&.active > a::after {
width: calc(100% - 60px);
background-color: var(--brand-color-tertiary);
}

&:hover {
> a {
background: none;

&::after {
width: calc(100% - 60px);
background: var(--brand-color);
}
}
}

&.flyout a {
padding-right: 3rem;
}

&.item-login {
> a {
background-color: var(--brand-color);
color: #FFF;
border-radius: 2rem;
padding: 0.5rem 2rem;
}

&:hover > a {
background-color: var(--brand-color-secondary);
}
}

.submenu {
background-color: #FFF;
border-radius: 10px;
box-shadow: 2px 2px 20px rgba(0,0,0,0.2);
padding: 1rem;

a {
color: var(--brand-color);
font-size: 1.4rem;
font-weight: 700;
}

.l2:hover > a {
color: var(--brand-color-secondary);
}
}
}
}
}
}

/* Tagline */

.tagline {
background: rgb(63,158,252);
background: var(--brand-color);
color: #FFF;
text-align: center;

.content-module {
position: relative;
display: inline-block;

&::before {
position: absolute;
content: "";
width: calc(100% + 20px);
height: calc(100% + 0px);
top: calc(50% + 10px);
left: calc(50% + 10px);
transform: translate(-50%, -50%) skew(-14deg);
background: rgba(255,255,255,0.3);
border-radius: 5px;
mix-blend-mode: soft-light;
}

p {
position: relative;
display: inline-block;
font-size: var(--font-size-2xl);
font-weight: 900;
line-height: 1em;
text-shadow: 3px 3px 20px rgba(0,0,0,0.2);
}
}
}

.column-widget {

/* Column Type - Thin */
&.thin {
.wrapper {
max-width: var(--wrapper-width-thin);
}
}

/* Column Type - Vertical (Centered) */
&.vertical {
.column-wrapper {
align-items: center;
}
}

/* Column Type - Brand Color */
&.brand-color {
.backdrop {
background: var(--brand-color) !important;
}

&:has(+ .column-widget.brand-color) {
padding-bottom: 0;
}

+ .column-widget.brand-color {
padding-top: 0;
}

.column {
border-radius: 20px;
}
}
}

/* Footer */

footer {
width: 100%;
background: var(--brand-color);

.wrapper {
display: flex;
align-items: center;
justify-content: space-between;
}

.site-logo {
display: flex;
width: 100%;
max-width: 150px;
}

.navigation-widget {
flex: 1;
text-align: left;

&.standard:not(.collapse) {
.l1 {
> a {
color: #FFF;
text-transform: uppercase;
font-size: 1.2rem;
font-weight: 500;
letter-spacing: 2px;
}

&:hover {
> a {
background: none;
color: var(--brand-color-tertiary);
}
}
}
}
}
}

#templatefooter {
display: none;
}/* Modules-Widgets.css | Oct 24, 2025 @5:23:00 PM  */

/* Testimonials */

.testimonials-module a {
color: inherit;
}

.column-widget .testimonials-module .swiper-loaded .testimonial-item-list {
padding-bottom: 0;
}

.testimonials-module .speechbubble-card .item-header {
right: auto;
text-align: center;
}

.testimonials-module .item .item-profile-image {
display: none;
}

.testimonials-module .item-description {
line-height: 1.25em;
}

.swiper-pagination {
display: none;
}

/* Contact Form */

form.formWizForm h2 {
display: none;
}

form.formWizForm div.twFormFooter {
margin-top: 0;
line-height: 0;
}

form.formWizForm ul li.sectionbreak:last-child {
margin-bottom: 0;
}

form.formWizForm .g-recaptcha {
margin-bottom: 2rem;
}

/* Column Widgets */

.column-widget {

/* Thinner Text Wrapper */
&.text {
.wrapper {
max-width: var(--wrapper-width);
}
}
}/* Responsive.css | Oct 24, 2025 @5:13:40 PM  */

/* Mobile Navigation */

header {
.navigation-widget.collapse.hamburger .menu-toggle label {
display: flex;
justify-content: center;
align-items: center;
gap: 0.5rem;
padding: 0;
}

.navigation-widget.collapse.hamburger .menu-toggle label:hover::after {
color: var(--brand-color-tertiary);
}

.navigation-widget.collapse.hamburger .menu-toggle label span {
font-weight: 700;
position: relative;
margin-top: -1px;
}

.navigation-widget.collapse.hamburger .menu-toggle label::after {
position: static;
font-size: 1.8em;
line-height: 1em;
transform: none;
transition: 0.2s ease all;
margin: 0;
}

.navigation-widget.collapse.hamburger nav .menu-toggle {
display: block;
}

.navigation-widget.collapse.hamburger input.menu-toggle-check:checked ~ nav {
background: var(--brand-color);
}

.navigation-widget.collapse.hamburger nav ul.menu {
width: 90vw;
margin: 5vw auto 0;
}

.navigation-widget.collapse.hamburger nav .l1 > a {
font-size: 3rem;
border-radius: 10px;
padding-left: 2rem;
}

.navigation-widget.collapse.hamburger nav .l1:hover > a {
color: var(--brand-color);
background: var(--brand-color-tertiary);
}
}

/* Footer Navigation */

@media only screen and (max-width:767px) {
footer {
.wrapper {
flex-direction: column;

.navigation-widget {
text-align: center;

&.collapse {
.l1 {
border: none;

a {
padding: 2px 0;
color: #FFF;
}

&:hover a {
background: none;
color: var(--brand-color-tertiary);
}
}
}
}
.site-logo {
margin-top: 3rem;
}
}
}
}

@media (max-width: 512px) {
.mobile-reverse {
.primary {
order: 2;
}

.last {
order: 1;
}
}

.testimonials-module {
.swiper-loaded {
padding: 0;
}

--swiper-navigation-sides-offset: -30px;
}
}