@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined");
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@400;700;900&display=swap");

:root {
    --purple: #5949a7;
    --error: #990000;
    --pinky: #f9e2e2;
    --blue: #396196;
    --bloo: #017acd;
    --light-bloo: #aed9f9;
    --snow-bloo: #e0eff9;
    --dark-bloo: #003da5;
    --charcoal: #343639;
    --midnight: #000;
    --snow: #fff;
    --cool-gray: #A7A8AA;
    --invisible: transparent;

    --font-size--root: 1.2rem;

    --text: var(--midnight);
    --text-highlight: var(--purple);
    --secondary-text: #53565a;
    --separators: #d8d8d8;
    --background-color: var(--snow);
    --offset-background: #f5f5f5;
    --link-color: #0773be;
    --required: var(--error);

    --focus-border: 2px solid var(--midnight);
    --focus-shadow: 2px solid var(--blue);
    --focus-highlight: var(--blue);
    --focus-error-border: 1px solid var(--error);
    --focus-error-shadow: 0 0 2px 2px var(--error);

    --opt-in-link: var(--link-color);

    --form-margin: 0;
    --form-padding: 0;
    --form-font-size: 1.2rem;
    --form-line-height: 1.65;
    --form-color: var(--midnight);
    --form-background: var(--invisible);
    --form-border: 2px solid #cdcccc;
    --form-column-gap: 1rem;
    --form-row-gap: 0;
    --form-label-margin: 0 0 .3rem 0;

    --form-field-margin: .75rem 0;
    --form-field-flex-basis: 100%;
    --form-field-fullwidth-flex-basis: calc(100% - var(--form-column-gap));
    --form-input-bg-color: var(--snow);
    --form-input-border: 1px solid var(--midnight);
    --form-input-border-radius: 0;
    --form-input-color: var(--midnight);

    --typeahead-bg-color: var(--snow);
    --typeahead-suggestion-hover-bg-color: var(--bloo);
    --typeahead-suggestion-hover-color: var(--snow);
    --typeahead-suggestion-hover-border: 1px solid var(--blue);
    --typeahead-suggestion-highlight: var(--dark-bloo);

    --form-invalid-feedback-margin: 0;
    --form-invalid-feedback-padding: .3rem 0 0 0;
    --form-invalid-feedback-Bg-color: var(--invisible);
    --form-invalid-feedback-color: var(--error);

    --form-optin-margin: .5rem 0;
    --form-optin-font-size: 1rem;
    --form-optin-link-color: var(--link-color);

    --button-background: var(--bloo);
    --button-background--hover: var(--dark-bloo);
    --button-background--active: var(--bloo);
    --button-color: var(--snow);
    --button-color--hover: var(--snow);
    --button-radius: 1rem;
    --button-font-size: 1.2rem;
    --button-margin: 1rem 0;
    --button-padding: .5rem 2rem;
    --button-width: max-content;

    --secondary-button-background: var(--snow);
    --secondary-button-color: var(--bloo);
    --secondary-button-border: 1px solid var(--bloo);
    --secondary-button-color-hover: var(--dark-bloo);
    --secondary-button-border-hover: 1px solid var(--dark-bloo);
    --secondary-button-shadow-active: 0 0 3px 1px #00b5e2;

    --size-small: 480px;
    --size-phone: var(--size-small);
    --size-medium: 768px;
    --size-tablet: var(--size-medium);
    --size-large: 992px;
    --size-desktop: var(--size-large);
    --size-xlarge: 1200px;
    --size-widescreen: var(--size-xlarge);
}

.theme--Dark {
    --required: var(--pinky);

    --font-size--root: 1.125rem;

    --focus-border: var(--blue);
    --focus-highlight: var(--snow);
    --opt-in-link: var(--snow);

    --form-margin: 0;
    --form-padding: 1rem;
    --form-background: var(--purple);
    --form-color: var(--snow);
    --form-optin-link-color: var(--light-bloo);
    --link-color: var(--light-bloo);

    --form-invalid-feedback-margin: .2rem 0 0 0;
    --form-invalid-feedback-padding: .3rem;
    --form-invalid-feedback-Bg-color: var(--pinky);

    --button-background: var(--snow);
    --button-background--hover: var(--charcoal);
    --button-background--active: var(--snow);
    --button-color: black;
    --button-color--hover: var(--snow);
    --button-color--active: black;
    --button-focus-highlight: var(--bloo);
}

.theme--STEM {
    --form-background: var(--charcoal);
}

/* Global */
body {
    color: var(--text);
    background-color: var(--offset-background);
    font-family: "Lato", Arial, sans-serif;
    font-size: var(--font-size--root);
    margin: 0 auto;
}

.show {
    display: inline-block !important;
}

.hide {
    display: none !important;
}
sup {
    font-size: 40%;
}

#GDPR-modal .btn {
    color: #000;
}

#GDPR-modal .btn:hover {
    color: #fff;
}

/* Form */
.cfa label {
    display: block;
    font-size: inherit;
    margin: var(--form-label-margin);
}

.required:after {
    content: "*";
    color: var(--required);
}

.cfa form {
    margin: var(--form-margin);
    padding: var(--form-padding);
    font-size: var(--form-font-size);
    line-height: var(--form-line-height);
    color: var(--form-color);
    background: var(--form-background);
}

.cfa fieldset {
    border: none;
    display: flex;
    column-gap: var(--form-column-gap);
    row-gap: var(--form-row-gap);
    flex-wrap: wrap;
}

.cfa .form-field {
    margin: var(--form-field-margin);
    flex-basis: var(--form-field-flex-basis);
    position: relative;
}

.cfa .full-width .form-field {
    margin: var(--form-field-margin);
    flex-basis: var(--form-field-fullwidth-flex-basis);
}

.cfa input,
.cfa select {
    width: 100%;
    height: 2.3rem;
    box-sizing: border-box;
    padding: 0 0.5rem;
    background-color: var(--form-input-bg-color);
    border-radius: var(--form-input-border-radius);
    border: var(--form-input-border);
    color: var(--text);
    font-size: inherit;
}

.cfa input:focus,
.cfa select:focus {
    border: var(--focus-border);
    box-shadow: var(--focus-shadow);
    border-radius: var(--form-input-border-radius);
}


/* Typeahead */
.cfa .form-field .has-results {
    display: block;
}

.cfa .form-field ul {
    position: absolute;
    display: none;
    list-style-type: none;
    padding: 0;
    margin: 0;
    border: var(--form-input-border);
    max-height: 200px;
    overflow-y: auto;
    scroll-behavior: auto;
    background-color: var(--form-input-bg-color);
    color: var(--form-input-color);
    font-size: 1.2rem;
    z-index:100; /* place select menu above other elements */
}

.cfa .form-field ul li {
    display: none;
    height: auto;
    padding: 0.5rem;
    cursor: pointer;
    background-color: var(--typeahead-bg-color);
}

.cfa .form-field ul li:hover,
.cfa .form-field ul li:focus {
    background-color: var(--typeahead-suggestion-hover-bg-color);
    color: var(--typeahead-suggestion-hover-color);
    border-bottom: 1px solid var(--typeahead-suggestion-hover-border);
}

.cfa .form-field ul li:hover .highlight,
.form-field ul li:focus .highlight {
    color: var(--typeahead-suggestion-hover-color);
}

.highlight {
    color: var(--typeahead-suggestion-highlight);
    font-weight: 600;
    pointer-events: none;
    margin: 0rem 0 2rem;
}

/* Opt in's */
.opt-in {
    margin: var(--form-optin-margin);
}

.opt-in label {
    font-size: var(--form-optin-font-size);
    line-height: 1.1;
    display: inline;
}

.opt-in a {
    color: var(--form-optin-link-color);
    text-decoration: underline;
    cursor: pointer;
}

.opt-in input {
    padding: 0;
    margin: 0;
    width: 1.2rem;
    height: 1.2rem;
    vertical-align: middle;
}

/* Form Validation Error Styles */
.invalid-feedback {
    background-color: var(--form-invalid-feedback-Bg-color);
    color: var(--form-invalid-feedback-color);
    padding-top: var(--form-invalid-feedback-padding);
}

.material-symbols-outlined {
    vertical-align: text-bottom;
}

.input-select-error {
    border: var(--focus-error-border);
    box-shadow: var(--focus-error-shadow);
}

.input-select-error:focus {
    border: var(--focus-border);
    box-shadow: var(--focus-shadow);
    border-radius: var(--form-input-border-radius);
}

#optin1-error.show,
#optin2-error.show {
    display: block;
}

.cfa .form-btn,
.cfa .form-btn-secondary {
    display: inline-block;
    cursor: pointer;
    text-decoration: none;
    border-radius: var(--button-radius);
    font-size: var(--button-font-size);
    padding: var(--button-padding);
    margin: var(--button-margin);
    width: var(--button-width);
}

.cfa .form-btn {
    background-color: var(--button-background);
    color: var(--button-color);
    border-color: transparent;
}

.cfa .form-btn:hover {
    background-color: var(--button-background--hover);
    color: var(--button-color--hover);
}

.cfa .form-btn:focus {
    border: var(--focus-border);
    box-shadow: var(--focus-shadow);
}

.cfa .form-btn:active {
    background-color: var(--button-background);
    color: var(--button-color);
}

.cfa .form-btn-secondary {
    background-color: var(--secondary-button-background);
    color: var(--secondary-button-color);
    border: var(--secondary-button-border);
}

.cfa .form-btn-secondary:hover {
    border: var(--secondary-button-border-hover);
    color: var(--secondary-button-color-hover);
}

.cfa .form-btn-secondary:focus {
    box-shadow: var(--secondary-button-shadow-active);
}

.cfa .form-btn-secondary:active {
    background-color: var(--secondary-button-background);
    color: var(--secondary-button-color);
    border: var(--secondary-button-border);
}

.cfa .form-btn .material-symbols-outlined {
    width: 1em;
    fill: #fff;
}

.cfa .form-btn:hover .material-symbols-outlined {
    fill: #000;
}

.cfa .btn-disabled {
    cursor: not-allowed;
}

.progress-spinner {
    animation: spin-animation 1s infinite;
    animation-timing-function: linear;
    cursor: not-allowed;
}

@keyframes spin-animation {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

@media (min-width: 768px) {
    :root {
        --form-field-flex-basis: calc(50% - var(--form-column-gap));
        --button-width: auto;
        --font-size--root: 1.3rem;
    }
}