﻿/*@import "https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap";
@import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Noto+Serif+Hentaigana:wght@200..900&display=swap";
@import "https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&display=swap";*/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');


:root, [data-bs-theme="light"] {
    --bs-blue: #0d6efd;
    --bs-indigo: #6610f2;
    --bs-purple: #6f42c1;
    --bs-pink: #d63384;
    --bs-red: #dc3545;
    --bs-orange: #fd7e14;
    --bs-orange: #fd7e14;
    --bs-yellow: #ffc107;
    --bs-green: #198754;
    --bs-teal: #20c997;
    --bs-cyan: #0dcaf0;
    --bs-black: #000;
    --bs-white: #fff;
    --bs-gray: #6c757d;
    --bs-gray-dark: #343a40;
    --bs-gray-100: #f8f9fa;
    --bs-gray-200: #e9ecef;
    --bs-gray-300: #dee2e6;
    --bs-gray-400: #ced4da;
    --bs-gray-500: #adb5bd;
    --bs-gray-600: #6c757d;
    --bs-gray-700: #495057;
    --bs-gray-800: #343a40;
    --bs-gray-900: #212529;
    --bs-primary: #0d6efd;
    --bs-secondary: #6c757d;
    --bs-success: #198754;
    --bs-info: #0dcaf0;
    --bs-warning: #ffc107;
    --bs-danger: #dc3545;
    --bs-light: #f8f9fa;
    --bs-dark: #212529;
    --bs-primary-rgb: 13, 110, 253;
    --bs-secondary-rgb: 108, 117, 125;
    --bs-success-rgb: 25, 135, 84;
    --bs-info-rgb: 13, 202, 240;
    --bs-warning-rgb: 255, 193, 7;
    --bs-danger-rgb: 220, 53, 69;
    --bs-light-rgb: 248, 249, 250;
    --bs-dark-rgb: 33, 37, 41;
    --bs-primary-text-emphasis: #052c65;
    --bs-secondary-text-emphasis: #2b2f32;
    --bs-success-text-emphasis: #0a3622;
    --bs-info-text-emphasis: #055160;
    --bs-warning-text-emphasis: #664d03;
    --bs-danger-text-emphasis: #58151c;
    --bs-light-text-emphasis: #495057;
    --bs-dark-text-emphasis: #495057;
    --bs-primary-bg-subtle: #cfe2ff;
    --bs-secondary-bg-subtle: #e2e3e5;
    --bs-success-bg-subtle: #d1e7dd;
    --bs-info-bg-subtle: #cff4fc;
    --bs-warning-bg-subtle: #fff3cd;
    --bs-danger-bg-subtle: #f8d7da;
    --bs-light-bg-subtle: #fcfcfd;
    --bs-dark-bg-subtle: #ced4da;
    --bs-primary-border-subtle: #9ec5fe;
    --bs-secondary-border-subtle: #c4c8cb;
    --bs-success-border-subtle: #a3cfbb;
    --bs-info-border-subtle: #9eeaf9;
    --bs-warning-border-subtle: #ffe69c;
    --bs-danger-border-subtle: #f1aeb5;
    --bs-light-border-subtle: #e9ecef;
    --bs-dark-border-subtle: #adb5bd;
    --bs-white-rgb: 255, 255, 255;
    --bs-black-rgb: 0, 0, 0;
    --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --bs-gradient: linear-gradient(180deg, #ffffff26, #fff0);
    --bs-body-font-family: var(--bs-font-sans-serif);
    --bs-body-font-size: 1rem;
    --bs-body-font-weight: 400;
    --bs-body-line-height: 1.5;
    --bs-body-color: #212529;
    --bs-body-color-rgb: 33, 37, 41;
    --bs-body-bg: #fff;
    --bs-body-bg-rgb: 255, 255, 255;
    --bs-emphasis-color: #000;
    --bs-emphasis-color-rgb: 0, 0, 0;
    --bs-secondary-color: #212529bf;
    --bs-secondary-color-rgb: 33, 37, 41;
    --bs-secondary-bg: #e9ecef;
    --bs-secondary-bg-rgb: 233, 236, 239;
    --bs-tertiary-color: #21252980;
    --bs-tertiary-color-rgb: 33, 37, 41;
    --bs-tertiary-bg: #f8f9fa;
    --bs-tertiary-bg-rgb: 248, 249, 250;
    --bs-heading-color: inherit;
    --bs-link-color: #0d6efd;
    --bs-link-color-rgb: 13, 110, 253;
    --bs-link-decoration: underline;
    --bs-link-hover-color: #0a58ca;
    --bs-link-hover-color-rgb: 10, 88, 202;
    --bs-code-color: #d63384;
    --bs-highlight-color: #212529;
    --bs-highlight-bg: #fff3cd;
    --bs-border-width: 1px;
    --bs-border-style: solid;
    --bs-border-color: #dee2e6;
    --bs-border-color-translucent: #0000002d;
    --bs-border-radius: .375rem;
    --bs-border-radius-sm: .25rem;
    --bs-border-radius-lg: .5rem;
    --bs-border-radius-xl: 1rem;
    --bs-border-radius-xxl: 2rem;
    --bs-border-radius-2xl: var(--bs-border-radius-xxl);
    --bs-border-radius-pill: 50rem;
    --bs-box-shadow: 0 .5rem 1rem #00000026;
    --bs-box-shadow-sm: 0 .125rem .25rem #00000013;
    --bs-box-shadow-lg: 0 1rem 3rem #0000002d;
    --bs-box-shadow-inset: inset 0 1px 2px #00000013;
    --bs-focus-ring-width: .25rem;
    --bs-focus-ring-opacity: .25;
    --bs-focus-ring-color: #0d6efd40;
    --bs-form-valid-color: #198754;
    --bs-form-valid-border-color: #198754;
    --bs-form-invalid-color: #dc3545;
    --bs-form-invalid-border-color: #dc3545;
}

[data-bs-theme="dark"] {
    color-scheme: dark;
    --bs-body-color: #dee2e6;
    --bs-body-color-rgb: 222, 226, 230;
    --bs-body-bg: #212529;
    --bs-body-bg-rgb: 33, 37, 41;
    --bs-emphasis-color: #fff;
    --bs-emphasis-color-rgb: 255, 255, 255;
    --bs-secondary-color: #dee2e6bf;
    --bs-secondary-color-rgb: 222, 226, 230;
    --bs-secondary-bg: #343a40;
    --bs-secondary-bg-rgb: 52, 58, 64;
    --bs-tertiary-color: #dee2e680;
    --bs-tertiary-color-rgb: 222, 226, 230;
    --bs-tertiary-bg: #2b3035;
    --bs-tertiary-bg-rgb: 43, 48, 53;
    --bs-primary-text-emphasis: #6ea8fe;
    --bs-secondary-text-emphasis: #a7acb1;
    --bs-success-text-emphasis: #75b798;
    --bs-info-text-emphasis: #6edff6;
    --bs-warning-text-emphasis: #ffda6a;
    --bs-danger-text-emphasis: #ea868f;
    --bs-light-text-emphasis: #f8f9fa;
    --bs-dark-text-emphasis: #dee2e6;
    --bs-primary-bg-subtle: #031633;
    --bs-secondary-bg-subtle: #161719;
    --bs-success-bg-subtle: #051b11;
    --bs-info-bg-subtle: #032830;
    --bs-warning-bg-subtle: #332701;
    --bs-danger-bg-subtle: #2c0b0e;
    --bs-light-bg-subtle: #343a40;
    --bs-dark-bg-subtle: #1a1d20;
    --bs-primary-border-subtle: #084298;
    --bs-secondary-border-subtle: #41464b;
    --bs-success-border-subtle: #0f5132;
    --bs-info-border-subtle: #087990;
    --bs-warning-border-subtle: #997404;
    --bs-danger-border-subtle: #842029;
    --bs-light-border-subtle: #495057;
    --bs-dark-border-subtle: #343a40;
    --bs-heading-color: inherit;
    --bs-link-color: #6ea8fe;
    --bs-link-hover-color: #8bb9fe;
    --bs-link-color-rgb: 110, 168, 254;
    --bs-link-hover-color-rgb: 139, 185, 254;
    --bs-code-color: #e685b5;
    --bs-highlight-color: #dee2e6;
    --bs-highlight-bg: #664d03;
    --bs-border-color: #495057;
    --bs-border-color-translucent: #ffffff26;
    --bs-form-valid-color: #75b798;
    --bs-form-valid-border-color: #75b798;
    --bs-form-invalid-color: #ea868f;
    --bs-form-invalid-border-color: #ea868f;
}

*, :before, :after {
    box-sizing: border-box;
}

@media (prefers-reduced-motion: no-preference) {
    :root {
        scroll-behavior: smooth;
    }
}

body {
    font-family: var(--bs-body-font-family);
    font-size: var(--bs-body-font-size);
    font-weight: var(--bs-body-font-weight);
    line-height: var(--bs-body-line-height);
    color: var(--bs-body-color);
    text-align: var(--bs-body-text-align);
    background-color: var(--bs-body-bg);
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: #0000;
    margin: 0;
}

hr {
    color: inherit;
    border: 0;
    border-top: var(--bs-border-width) solid;
    opacity: .25;
    margin: 1rem 0;
}

h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1 {
    color: var(--bs-heading-color);
    margin-top: 0;
    margin-bottom: .5rem;
    font-weight: 500;
    line-height: 1.2;
}

h1, .h1 {
    font-size: calc(1.375rem + 1.5vw);
}

@media (width >= 1200px) {
    h1, .h1 {
        font-size: 2.5rem;
    }
}

h2, .h2 {
    font-size: calc(1.325rem + .9vw);
}

@media (width >= 1200px) {
    h2, .h2 {
        font-size: 2rem;
    }
}

h3, .h3 {
    font-size: calc(1.3rem + .6vw);
}

@media (width >= 1200px) {
    h3, .h3 {
        font-size: 1.75rem;
    }
}

h4, .h4 {
    font-size: calc(1.275rem + .3vw);
}

@media (width >= 1200px) {
    h4, .h4 {
        font-size: 1.5rem;
    }
}

h5, .h5 {
    font-size: 1.25rem;
}

h6, .h6 {
    font-size: 1rem;
}

p {
    margin-top: 0;
    margin-bottom: 1rem;
}

abbr[title] {
    cursor: help;
    text-decoration-skip-ink: none;
    text-decoration: underline dotted;
}

address {
    font-style: normal;
    line-height: inherit;
    margin-bottom: 1rem;
}

ol, ul {
    padding-left: 2rem;
}

ol, ul, dl {
    margin-top: 0;
    margin-bottom: 1rem;
}

    ol ol, ul ul, ol ul, ul ol {
        margin-bottom: 0;
    }

dt {
    font-weight: 700;
}

dd {
    margin-bottom: .5rem;
    margin-left: 0;
}

blockquote {
    margin: 0 0 1rem;
}

b, strong {
    font-weight: bolder;
}

small, .small {
    font-size: .875em;
}

mark, .mark {
    color: var(--bs-highlight-color);
    background-color: var(--bs-highlight-bg);
    padding: .1875em;
}

sub, sup {
    vertical-align: baseline;
    font-size: .75em;
    line-height: 0;
    position: relative;
}

sub {
    bottom: -.25em;
}

sup {
    top: -.5em;
}

a {
    color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1));
    text-decoration: underline;
}

    a:hover {
        --bs-link-color-rgb: var(--bs-link-hover-color-rgb);
    }

    a:not([href]):not([class]), a:not([href]):not([class]):hover {
        color: inherit;
        text-decoration: none;
    }

pre, code, kbd, samp {
    font-family: var(--bs-font-monospace);
    font-size: 1em;
}

pre {
    margin-top: 0;
    margin-bottom: 1rem;
    font-size: .875em;
    display: block;
    overflow: auto;
}

    pre code {
        font-size: inherit;
        color: inherit;
        word-break: normal;
    }

code {
    color: var(--bs-code-color);
    word-wrap: break-word;
    font-size: .875em;
}

a > code {
    color: inherit;
}

kbd {
    color: var(--bs-body-bg);
    background-color: var(--bs-body-color);
    border-radius: .25rem;
    padding: .1875rem .375rem;
    font-size: .875em;
}

    kbd kbd {
        padding: 0;
        font-size: 1em;
    }

figure {
    margin: 0 0 1rem;
}

img, svg {
    vertical-align: middle;
}

table {
    caption-side: bottom;
    border-collapse: collapse;
}

caption {
    color: var(--bs-secondary-color);
    text-align: left;
    padding-top: .5rem;
    padding-bottom: .5rem;
}

th {
    text-align: inherit;
    text-align: -webkit-match-parent;
}

thead, tbody, tfoot, tr, td, th {
    border-color: inherit;
    border-style: solid;
    border-width: 0;
}

label {
    display: inline-block;
}

button {
    border-radius: 0;
}

    button:focus:not(:focus-visible) {
        outline: 0;
    }

input, button, select, optgroup, textarea {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
}

button, select {
    text-transform: none;
}

[role="button"] {
    cursor: pointer;
}

select {
    word-wrap: normal;
}

    select:disabled {
        opacity: 1;
    }

[list]:not([type="date"]):not([type="datetime-local"]):not([type="month"]):not([type="week"]):not([type="time"])::-webkit-calendar-picker-indicator {
    display: none !important;
}

button, [type="button"], [type="reset"], [type="submit"] {
    -webkit-appearance: button;
}

    button:not(:disabled), [type="button"]:not(:disabled), [type="reset"]:not(:disabled), [type="submit"]:not(:disabled) {
        cursor: pointer;
    }

::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

textarea {
    resize: vertical;
}

fieldset {
    border: 0;
    min-width: 0;
    margin: 0;
    padding: 0;
}

legend {
    float: left;
    width: 100%;
    font-size: calc(1.275rem + .3vw);
    line-height: inherit;
    margin-bottom: .5rem;
    padding: 0;
}

@media (width >= 1200px) {
    legend {
        font-size: 1.5rem;
    }
}

legend + * {
    clear: left;
}

::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
}

::-webkit-datetime-edit-text {
    padding: 0;
}

::-webkit-datetime-edit-minute {
    padding: 0;
}

::-webkit-datetime-edit-hour-field {
    padding: 0;
}

::-webkit-datetime-edit-day-field {
    padding: 0;
}

::-webkit-datetime-edit-month-field {
    padding: 0;
}

::-webkit-datetime-edit-year-field {
    padding: 0;
}

::-webkit-inner-spin-button {
    height: auto;
}

[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}

::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-color-swatch-wrapper {
    padding: 0;
}

::file-selector-button {
    font: inherit;
    -webkit-appearance: button;
}

output {
    display: inline-block;
}

iframe {
    border: 0;
}

summary {
    cursor: pointer;
    display: list-item;
}

progress {
    vertical-align: baseline;
}

[hidden] {
    display: none !important;
}

.lead {
    font-size: 1.25rem;
    font-weight: 300;
}

.display-1 {
    font-size: calc(1.625rem + 4.5vw);
    font-weight: 300;
    line-height: 1.2;
}

@media (width >= 1200px) {
    .display-1 {
        font-size: 5rem;
    }
}

.display-2 {
    font-size: calc(1.575rem + 3.9vw);
    font-weight: 300;
    line-height: 1.2;
}

@media (width >= 1200px) {
    .display-2 {
        font-size: 4.5rem;
    }
}

.display-3 {
    font-size: calc(1.525rem + 3.3vw);
    font-weight: 300;
    line-height: 1.2;
}

@media (width >= 1200px) {
    .display-3 {
        font-size: 4rem;
    }
}

.display-4 {
    font-size: calc(1.475rem + 2.7vw);
    font-weight: 300;
    line-height: 1.2;
}

@media (width >= 1200px) {
    .display-4 {
        font-size: 3.5rem;
    }
}

.display-5 {
    font-size: calc(1.425rem + 2.1vw);
    font-weight: 300;
    line-height: 1.2;
}

@media (width >= 1200px) {
    .display-5 {
        font-size: 3rem;
    }
}

.display-6 {
    font-size: calc(1.375rem + 1.5vw);
    font-weight: 300;
    line-height: 1.2;
}

@media (width >= 1200px) {
    .display-6 {
        font-size: 2.5rem;
    }
}

.list-unstyled, .list-inline {
    padding-left: 0;
    list-style: none;
}

.list-inline-item {
    display: inline-block;
}

    .list-inline-item:not(:last-child) {
        margin-right: .5rem;
    }

.initialism {
    text-transform: uppercase;
    font-size: .875em;
}

.blockquote {
    margin-bottom: 1rem;
    font-size: 1.25rem;
}

    .blockquote > :last-child {
        margin-bottom: 0;
    }

.blockquote-footer {
    color: #6c757d;
    margin-top: -1rem;
    margin-bottom: 1rem;
    font-size: .875em;
}

    .blockquote-footer:before {
        content: "— ";
    }

.img-fluid, .sub-header-hero .hero-image img {
    max-width: 100%;
    height: auto;
}

.img-thumbnail {
    background-color: var(--bs-body-bg);
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    max-width: 100%;
    height: auto;
    padding: .25rem;
}

.figure {
    display: inline-block;
}

.figure-img {
    margin-bottom: .5rem;
    line-height: 1;
}

.figure-caption {
    color: var(--bs-secondary-color);
    font-size: .875em;
}

.container, .container-fluid, .container-xxl, .container-xl, .container-lg, .container-md, .container-sm {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
    margin-left: auto;
    margin-right: auto;
}

@media (width >= 576px) {
    .container-sm, .container {
        max-width: 540px;
    }
}

@media (width >= 768px) {
    .container-md, .container-sm, .container {
        max-width: 720px;
    }
}

@media (width >= 992px) {
    .container-lg, .container-md, .container-sm, .container {
        max-width: 960px;
    }
}

@media (width >= 1200px) {
    .container-xl, .container-lg, .container-md, .container-sm, .container {
        max-width: 1140px;
    }
}

@media (width >= 1400px) {
    .container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container {
        max-width: 1320px;
    }
}

:root {
    --bs-breakpoint-xs: 0;
    --bs-breakpoint-sm: 576px;
    --bs-breakpoint-md: 768px;
    --bs-breakpoint-lg: 992px;
    --bs-breakpoint-xl: 1200px;
    --bs-breakpoint-xxl: 1400px;
}

.row {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    margin-top: calc(-1 * var(--bs-gutter-y));
    margin-right: calc(-.5 * var(--bs-gutter-x));
    margin-left: calc(-.5 * var(--bs-gutter-x));
    flex-wrap: wrap;
    display: flex;
}

    .row > * {
        width: 100%;
        max-width: 100%;
        padding-right: calc(var(--bs-gutter-x) * .5);
        padding-left: calc(var(--bs-gutter-x) * .5);
        margin-top: var(--bs-gutter-y);
        flex-shrink: 0;
    }

.col {
    flex: 1 0;
}

.row-cols-auto > * {
    flex: none;
    width: auto;
}

.row-cols-1 > * {
    flex: none;
    width: 100%;
}

.row-cols-2 > * {
    flex: none;
    width: 50%;
}

.row-cols-3 > * {
    flex: none;
    width: 33.3333%;
}

.row-cols-4 > * {
    flex: none;
    width: 25%;
}

.row-cols-5 > * {
    flex: none;
    width: 20%;
}

.row-cols-6 > * {
    flex: none;
    width: 16.6667%;
}

.col-auto {
    flex: none;
    width: auto;
}

.col-1 {
    flex: none;
    width: 8.33333%;
}

.col-2 {
    flex: none;
    width: 16.6667%;
}

.col-3 {
    flex: none;
    width: 25%;
}

.col-4 {
    flex: none;
    width: 33.3333%;
}

.col-5 {
    flex: none;
    width: 41.6667%;
}

.col-6 {
    flex: none;
    width: 50%;
}

.col-7 {
    flex: none;
    width: 58.3333%;
}

.col-8 {
    flex: none;
    width: 66.6667%;
}

.col-9 {
    flex: none;
    width: 75%;
}

.col-10 {
    flex: none;
    width: 83.3333%;
}

.col-11 {
    flex: none;
    width: 91.6667%;
}

.col-12 {
    flex: none;
    width: 100%;
}

.offset-1 {
    margin-left: 8.33333%;
}

.offset-2 {
    margin-left: 16.6667%;
}

.offset-3 {
    margin-left: 25%;
}

.offset-4 {
    margin-left: 33.3333%;
}

.offset-5 {
    margin-left: 41.6667%;
}

.offset-6 {
    margin-left: 50%;
}

.offset-7 {
    margin-left: 58.3333%;
}

.offset-8 {
    margin-left: 66.6667%;
}

.offset-9 {
    margin-left: 75%;
}

.offset-10 {
    margin-left: 83.3333%;
}

.offset-11 {
    margin-left: 91.6667%;
}

.g-0, .gx-0 {
    --bs-gutter-x: 0;
}

.g-0, .gy-0 {
    --bs-gutter-y: 0;
}

.g-1, .gx-1 {
    --bs-gutter-x: .25rem;
}

.g-1, .gy-1 {
    --bs-gutter-y: .25rem;
}

.g-2, .gx-2 {
    --bs-gutter-x: .5rem;
}

.g-2, .gy-2 {
    --bs-gutter-y: .5rem;
}

.g-3, .gx-3 {
    --bs-gutter-x: 1rem;
}

.g-3, .gy-3 {
    --bs-gutter-y: 1rem;
}

.g-4, .gx-4 {
    --bs-gutter-x: 1.5rem;
}

.g-4, .gy-4 {
    --bs-gutter-y: 1.5rem;
}

.g-5, .gx-5 {
    --bs-gutter-x: 3rem;
}

.g-5, .gy-5 {
    --bs-gutter-y: 3rem;
}

@media (width >= 576px) {
    .col-sm {
        flex: 1 0;
    }

    .row-cols-sm-auto > * {
        flex: none;
        width: auto;
    }

    .row-cols-sm-1 > * {
        flex: none;
        width: 100%;
    }

    .row-cols-sm-2 > * {
        flex: none;
        width: 50%;
    }

    .row-cols-sm-3 > * {
        flex: none;
        width: 33.3333%;
    }

    .row-cols-sm-4 > * {
        flex: none;
        width: 25%;
    }

    .row-cols-sm-5 > * {
        flex: none;
        width: 20%;
    }

    .row-cols-sm-6 > * {
        flex: none;
        width: 16.6667%;
    }

    .col-sm-auto {
        flex: none;
        width: auto;
    }

    .col-sm-1 {
        flex: none;
        width: 8.33333%;
    }

    .col-sm-2 {
        flex: none;
        width: 16.6667%;
    }

    .col-sm-3 {
        flex: none;
        width: 25%;
    }

    .col-sm-4 {
        flex: none;
        width: 33.3333%;
    }

    .col-sm-5 {
        flex: none;
        width: 41.6667%;
    }

    .col-sm-6 {
        flex: none;
        width: 50%;
    }

    .col-sm-7 {
        flex: none;
        width: 58.3333%;
    }

    .col-sm-8 {
        flex: none;
        width: 66.6667%;
    }

    .col-sm-9 {
        flex: none;
        width: 75%;
    }

    .col-sm-10 {
        flex: none;
        width: 83.3333%;
    }

    .col-sm-11 {
        flex: none;
        width: 91.6667%;
    }

    .col-sm-12 {
        flex: none;
        width: 100%;
    }

    .offset-sm-0 {
        margin-left: 0;
    }

    .offset-sm-1 {
        margin-left: 8.33333%;
    }

    .offset-sm-2 {
        margin-left: 16.6667%;
    }

    .offset-sm-3 {
        margin-left: 25%;
    }

    .offset-sm-4 {
        margin-left: 33.3333%;
    }

    .offset-sm-5 {
        margin-left: 41.6667%;
    }

    .offset-sm-6 {
        margin-left: 50%;
    }

    .offset-sm-7 {
        margin-left: 58.3333%;
    }

    .offset-sm-8 {
        margin-left: 66.6667%;
    }

    .offset-sm-9 {
        margin-left: 75%;
    }

    .offset-sm-10 {
        margin-left: 83.3333%;
    }

    .offset-sm-11 {
        margin-left: 91.6667%;
    }

    .g-sm-0, .gx-sm-0 {
        --bs-gutter-x: 0;
    }

    .g-sm-0, .gy-sm-0 {
        --bs-gutter-y: 0;
    }

    .g-sm-1, .gx-sm-1 {
        --bs-gutter-x: .25rem;
    }

    .g-sm-1, .gy-sm-1 {
        --bs-gutter-y: .25rem;
    }

    .g-sm-2, .gx-sm-2 {
        --bs-gutter-x: .5rem;
    }

    .g-sm-2, .gy-sm-2 {
        --bs-gutter-y: .5rem;
    }

    .g-sm-3, .gx-sm-3 {
        --bs-gutter-x: 1rem;
    }

    .g-sm-3, .gy-sm-3 {
        --bs-gutter-y: 1rem;
    }

    .g-sm-4, .gx-sm-4 {
        --bs-gutter-x: 1.5rem;
    }

    .g-sm-4, .gy-sm-4 {
        --bs-gutter-y: 1.5rem;
    }

    .g-sm-5, .gx-sm-5 {
        --bs-gutter-x: 3rem;
    }

    .g-sm-5, .gy-sm-5 {
        --bs-gutter-y: 3rem;
    }
}

@media (width >= 768px) {
    .col-md {
        flex: 1 0;
    }

    .row-cols-md-auto > * {
        flex: none;
        width: auto;
    }

    .row-cols-md-1 > * {
        flex: none;
        width: 100%;
    }

    .row-cols-md-2 > * {
        flex: none;
        width: 50%;
    }

    .row-cols-md-3 > * {
        flex: none;
        width: 33.3333%;
    }

    .row-cols-md-4 > * {
        flex: none;
        width: 25%;
    }

    .row-cols-md-5 > * {
        flex: none;
        width: 20%;
    }

    .row-cols-md-6 > * {
        flex: none;
        width: 16.6667%;
    }

    .col-md-auto {
        flex: none;
        width: auto;
    }

    .col-md-1 {
        flex: none;
        width: 8.33333%;
    }

    .col-md-2 {
        flex: none;
        width: 16.6667%;
    }

    .col-md-3 {
        flex: none;
        width: 25%;
    }

    .col-md-4 {
        flex: none;
        width: 33.3333%;
    }

    .col-md-5 {
        flex: none;
        width: 41.6667%;
    }

    .col-md-6 {
        flex: none;
        width: 50%;
    }

    .col-md-7 {
        flex: none;
        width: 58.3333%;
    }

    .col-md-8 {
        flex: none;
        width: 66.6667%;
    }

    .col-md-9 {
        flex: none;
        width: 75%;
    }

    .col-md-10 {
        flex: none;
        width: 83.3333%;
    }

    .col-md-11 {
        flex: none;
        width: 91.6667%;
    }

    .col-md-12 {
        flex: none;
        width: 100%;
    }

    .offset-md-0 {
        margin-left: 0;
    }

    .offset-md-1 {
        margin-left: 8.33333%;
    }

    .offset-md-2 {
        margin-left: 16.6667%;
    }

    .offset-md-3 {
        margin-left: 25%;
    }

    .offset-md-4 {
        margin-left: 33.3333%;
    }

    .offset-md-5 {
        margin-left: 41.6667%;
    }

    .offset-md-6 {
        margin-left: 50%;
    }

    .offset-md-7 {
        margin-left: 58.3333%;
    }

    .offset-md-8 {
        margin-left: 66.6667%;
    }

    .offset-md-9 {
        margin-left: 75%;
    }

    .offset-md-10 {
        margin-left: 83.3333%;
    }

    .offset-md-11 {
        margin-left: 91.6667%;
    }

    .g-md-0, .gx-md-0 {
        --bs-gutter-x: 0;
    }

    .g-md-0, .gy-md-0 {
        --bs-gutter-y: 0;
    }

    .g-md-1, .gx-md-1 {
        --bs-gutter-x: .25rem;
    }

    .g-md-1, .gy-md-1 {
        --bs-gutter-y: .25rem;
    }

    .g-md-2, .gx-md-2 {
        --bs-gutter-x: .5rem;
    }

    .g-md-2, .gy-md-2 {
        --bs-gutter-y: .5rem;
    }

    .g-md-3, .gx-md-3 {
        --bs-gutter-x: 1rem;
    }

    .g-md-3, .gy-md-3 {
        --bs-gutter-y: 1rem;
    }

    .g-md-4, .gx-md-4 {
        --bs-gutter-x: 1.5rem;
    }

    .g-md-4, .gy-md-4 {
        --bs-gutter-y: 1.5rem;
    }

    .g-md-5, .gx-md-5 {
        --bs-gutter-x: 3rem;
    }

    .g-md-5, .gy-md-5 {
        --bs-gutter-y: 3rem;
    }
}

@media (width >= 992px) {
    .col-lg {
        flex: 1 0;
    }

    .row-cols-lg-auto > * {
        flex: none;
        width: auto;
    }

    .row-cols-lg-1 > * {
        flex: none;
        width: 100%;
    }

    .row-cols-lg-2 > * {
        flex: none;
        width: 50%;
    }

    .row-cols-lg-3 > * {
        flex: none;
        width: 33.3333%;
    }

    .row-cols-lg-4 > * {
        flex: none;
        width: 25%;
    }

    .row-cols-lg-5 > * {
        flex: none;
        width: 20%;
    }

    .row-cols-lg-6 > * {
        flex: none;
        width: 16.6667%;
    }

    .col-lg-auto {
        flex: none;
        width: auto;
    }

    .col-lg-1 {
        flex: none;
        width: 8.33333%;
    }

    .col-lg-2 {
        flex: none;
        width: 16.6667%;
    }

    .col-lg-3 {
        flex: none;
        width: 25%;
    }

    .col-lg-4 {
        flex: none;
        width: 33.3333%;
    }

    .col-lg-5 {
        flex: none;
        width: 41.6667%;
    }

    .col-lg-6 {
        flex: none;
        width: 50%;
    }

    .col-lg-7 {
        flex: none;
        width: 58.3333%;
    }

    .col-lg-8 {
        flex: none;
        width: 66.6667%;
    }

    .col-lg-9 {
        flex: none;
        width: 75%;
    }

    .col-lg-10 {
        flex: none;
        width: 83.3333%;
    }

    .col-lg-11 {
        flex: none;
        width: 91.6667%;
    }

    .col-lg-12 {
        flex: none;
        width: 100%;
    }

    .offset-lg-0 {
        margin-left: 0;
    }

    .offset-lg-1 {
        margin-left: 8.33333%;
    }

    .offset-lg-2 {
        margin-left: 16.6667%;
    }

    .offset-lg-3 {
        margin-left: 25%;
    }

    .offset-lg-4 {
        margin-left: 33.3333%;
    }

    .offset-lg-5 {
        margin-left: 41.6667%;
    }

    .offset-lg-6 {
        margin-left: 50%;
    }

    .offset-lg-7 {
        margin-left: 58.3333%;
    }

    .offset-lg-8 {
        margin-left: 66.6667%;
    }

    .offset-lg-9 {
        margin-left: 75%;
    }

    .offset-lg-10 {
        margin-left: 83.3333%;
    }

    .offset-lg-11 {
        margin-left: 91.6667%;
    }

    .g-lg-0, .gx-lg-0 {
        --bs-gutter-x: 0;
    }

    .g-lg-0, .gy-lg-0 {
        --bs-gutter-y: 0;
    }

    .g-lg-1, .gx-lg-1 {
        --bs-gutter-x: .25rem;
    }

    .g-lg-1, .gy-lg-1 {
        --bs-gutter-y: .25rem;
    }

    .g-lg-2, .gx-lg-2 {
        --bs-gutter-x: .5rem;
    }

    .g-lg-2, .gy-lg-2 {
        --bs-gutter-y: .5rem;
    }

    .g-lg-3, .gx-lg-3 {
        --bs-gutter-x: 1rem;
    }

    .g-lg-3, .gy-lg-3 {
        --bs-gutter-y: 1rem;
    }

    .g-lg-4, .gx-lg-4 {
        --bs-gutter-x: 1.5rem;
    }

    .g-lg-4, .gy-lg-4 {
        --bs-gutter-y: 1.5rem;
    }

    .g-lg-5, .gx-lg-5 {
        --bs-gutter-x: 3rem;
    }

    .g-lg-5, .gy-lg-5 {
        --bs-gutter-y: 3rem;
    }
}

@media (width >= 1200px) {
    .col-xl {
        flex: 1 0;
    }

    .row-cols-xl-auto > * {
        flex: none;
        width: auto;
    }

    .row-cols-xl-1 > * {
        flex: none;
        width: 100%;
    }

    .row-cols-xl-2 > * {
        flex: none;
        width: 50%;
    }

    .row-cols-xl-3 > * {
        flex: none;
        width: 33.3333%;
    }

    .row-cols-xl-4 > * {
        flex: none;
        width: 25%;
    }

    .row-cols-xl-5 > * {
        flex: none;
        width: 20%;
    }

    .row-cols-xl-6 > * {
        flex: none;
        width: 16.6667%;
    }

    .col-xl-auto {
        flex: none;
        width: auto;
    }

    .col-xl-1 {
        flex: none;
        width: 8.33333%;
    }

    .col-xl-2 {
        flex: none;
        width: 16.6667%;
    }

    .col-xl-3 {
        flex: none;
        width: 25%;
    }

    .col-xl-4 {
        flex: none;
        width: 33.3333%;
    }

    .col-xl-5 {
        flex: none;
        width: 41.6667%;
    }

    .col-xl-6 {
        flex: none;
        width: 50%;
    }

    .col-xl-7 {
        flex: none;
        width: 58.3333%;
    }

    .col-xl-8 {
        flex: none;
        width: 66.6667%;
    }

    .col-xl-9 {
        flex: none;
        width: 75%;
    }

    .col-xl-10 {
        flex: none;
        width: 83.3333%;
    }

    .col-xl-11 {
        flex: none;
        width: 91.6667%;
    }

    .col-xl-12 {
        flex: none;
        width: 100%;
    }

    .offset-xl-0 {
        margin-left: 0;
    }

    .offset-xl-1 {
        margin-left: 8.33333%;
    }

    .offset-xl-2 {
        margin-left: 16.6667%;
    }

    .offset-xl-3 {
        margin-left: 25%;
    }

    .offset-xl-4 {
        margin-left: 33.3333%;
    }

    .offset-xl-5 {
        margin-left: 41.6667%;
    }

    .offset-xl-6 {
        margin-left: 50%;
    }

    .offset-xl-7 {
        margin-left: 58.3333%;
    }

    .offset-xl-8 {
        margin-left: 66.6667%;
    }

    .offset-xl-9 {
        margin-left: 75%;
    }

    .offset-xl-10 {
        margin-left: 83.3333%;
    }

    .offset-xl-11 {
        margin-left: 91.6667%;
    }

    .g-xl-0, .gx-xl-0 {
        --bs-gutter-x: 0;
    }

    .g-xl-0, .gy-xl-0 {
        --bs-gutter-y: 0;
    }

    .g-xl-1, .gx-xl-1 {
        --bs-gutter-x: .25rem;
    }

    .g-xl-1, .gy-xl-1 {
        --bs-gutter-y: .25rem;
    }

    .g-xl-2, .gx-xl-2 {
        --bs-gutter-x: .5rem;
    }

    .g-xl-2, .gy-xl-2 {
        --bs-gutter-y: .5rem;
    }

    .g-xl-3, .gx-xl-3 {
        --bs-gutter-x: 1rem;
    }

    .g-xl-3, .gy-xl-3 {
        --bs-gutter-y: 1rem;
    }

    .g-xl-4, .gx-xl-4 {
        --bs-gutter-x: 1.5rem;
    }

    .g-xl-4, .gy-xl-4 {
        --bs-gutter-y: 1.5rem;
    }

    .g-xl-5, .gx-xl-5 {
        --bs-gutter-x: 3rem;
    }

    .g-xl-5, .gy-xl-5 {
        --bs-gutter-y: 3rem;
    }
}

@media (width >= 1400px) {
    .col-xxl {
        flex: 1 0;
    }

    .row-cols-xxl-auto > * {
        flex: none;
        width: auto;
    }

    .row-cols-xxl-1 > * {
        flex: none;
        width: 100%;
    }

    .row-cols-xxl-2 > * {
        flex: none;
        width: 50%;
    }

    .row-cols-xxl-3 > * {
        flex: none;
        width: 33.3333%;
    }

    .row-cols-xxl-4 > * {
        flex: none;
        width: 25%;
    }

    .row-cols-xxl-5 > * {
        flex: none;
        width: 20%;
    }

    .row-cols-xxl-6 > * {
        flex: none;
        width: 16.6667%;
    }

    .col-xxl-auto {
        flex: none;
        width: auto;
    }

    .col-xxl-1 {
        flex: none;
        width: 8.33333%;
    }

    .col-xxl-2 {
        flex: none;
        width: 16.6667%;
    }

    .col-xxl-3 {
        flex: none;
        width: 25%;
    }

    .col-xxl-4 {
        flex: none;
        width: 33.3333%;
    }

    .col-xxl-5 {
        flex: none;
        width: 41.6667%;
    }

    .col-xxl-6 {
        flex: none;
        width: 50%;
    }

    .col-xxl-7 {
        flex: none;
        width: 58.3333%;
    }

    .col-xxl-8 {
        flex: none;
        width: 66.6667%;
    }

    .col-xxl-9 {
        flex: none;
        width: 75%;
    }

    .col-xxl-10 {
        flex: none;
        width: 83.3333%;
    }

    .col-xxl-11 {
        flex: none;
        width: 91.6667%;
    }

    .col-xxl-12 {
        flex: none;
        width: 100%;
    }

    .offset-xxl-0 {
        margin-left: 0;
    }

    .offset-xxl-1 {
        margin-left: 8.33333%;
    }

    .offset-xxl-2 {
        margin-left: 16.6667%;
    }

    .offset-xxl-3 {
        margin-left: 25%;
    }

    .offset-xxl-4 {
        margin-left: 33.3333%;
    }

    .offset-xxl-5 {
        margin-left: 41.6667%;
    }

    .offset-xxl-6 {
        margin-left: 50%;
    }

    .offset-xxl-7 {
        margin-left: 58.3333%;
    }

    .offset-xxl-8 {
        margin-left: 66.6667%;
    }

    .offset-xxl-9 {
        margin-left: 75%;
    }

    .offset-xxl-10 {
        margin-left: 83.3333%;
    }

    .offset-xxl-11 {
        margin-left: 91.6667%;
    }

    .g-xxl-0, .gx-xxl-0 {
        --bs-gutter-x: 0;
    }

    .g-xxl-0, .gy-xxl-0 {
        --bs-gutter-y: 0;
    }

    .g-xxl-1, .gx-xxl-1 {
        --bs-gutter-x: .25rem;
    }

    .g-xxl-1, .gy-xxl-1 {
        --bs-gutter-y: .25rem;
    }

    .g-xxl-2, .gx-xxl-2 {
        --bs-gutter-x: .5rem;
    }

    .g-xxl-2, .gy-xxl-2 {
        --bs-gutter-y: .5rem;
    }

    .g-xxl-3, .gx-xxl-3 {
        --bs-gutter-x: 1rem;
    }

    .g-xxl-3, .gy-xxl-3 {
        --bs-gutter-y: 1rem;
    }

    .g-xxl-4, .gx-xxl-4 {
        --bs-gutter-x: 1.5rem;
    }

    .g-xxl-4, .gy-xxl-4 {
        --bs-gutter-y: 1.5rem;
    }

    .g-xxl-5, .gx-xxl-5 {
        --bs-gutter-x: 3rem;
    }

    .g-xxl-5, .gy-xxl-5 {
        --bs-gutter-y: 3rem;
    }
}

.table {
    --bs-table-color-type: initial;
    --bs-table-bg-type: initial;
    --bs-table-color-state: initial;
    --bs-table-bg-state: initial;
    --bs-table-color: var(--bs-emphasis-color);
    --bs-table-bg: var(--bs-body-bg);
    --bs-table-border-color: var(--bs-border-color);
    --bs-table-accent-bg: transparent;
    --bs-table-striped-color: var(--bs-emphasis-color);
    --bs-table-striped-bg: rgba(var(--bs-emphasis-color-rgb), .05);
    --bs-table-active-color: var(--bs-emphasis-color);
    --bs-table-active-bg: rgba(var(--bs-emphasis-color-rgb), .1);
    --bs-table-hover-color: var(--bs-emphasis-color);
    --bs-table-hover-bg: rgba(var(--bs-emphasis-color-rgb), .075);
    vertical-align: top;
    border-color: var(--bs-table-border-color);
    width: 100%;
    margin-bottom: 1rem;
}

    .table > :not(caption) > * > * {
        color: var(--bs-table-color-state, var(--bs-table-color-type, var(--bs-table-color)));
        background-color: var(--bs-table-bg);
        border-bottom-width: var(--bs-border-width);
        box-shadow: inset 0 0 0 9999px var(--bs-table-bg-state, var(--bs-table-bg-type, var(--bs-table-accent-bg)));
        padding: .5rem;
    }

    .table > tbody {
        vertical-align: inherit;
    }

    .table > thead {
        vertical-align: bottom;
    }

.table-group-divider {
    border-top: calc(var(--bs-border-width) * 2) solid currentcolor;
}

.caption-top {
    caption-side: top;
}

.table-sm > :not(caption) > * > * {
    padding: .25rem;
}

.table-bordered > :not(caption) > * {
    border-width: var(--bs-border-width) 0;
}

    .table-bordered > :not(caption) > * > * {
        border-width: 0 var(--bs-border-width);
    }

.table-borderless > :not(caption) > * > * {
    border-bottom-width: 0;
}

.table-borderless > :not(:first-child) {
    border-top-width: 0;
}

.table-striped > tbody > tr:nth-of-type(odd) > *, .table-striped-columns > :not(caption) > tr > :nth-child(2n) {
    --bs-table-color-type: var(--bs-table-striped-color);
    --bs-table-bg-type: var(--bs-table-striped-bg);
}

.table-active {
    --bs-table-color-state: var(--bs-table-active-color);
    --bs-table-bg-state: var(--bs-table-active-bg);
}

.table-hover > tbody > tr:hover > * {
    --bs-table-color-state: var(--bs-table-hover-color);
    --bs-table-bg-state: var(--bs-table-hover-bg);
}

.table-primary {
    --bs-table-color: #000;
    --bs-table-bg: #cfe2ff;
    --bs-table-border-color: #a6b5cc;
    --bs-table-striped-bg: #c5d7f2;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #bacbe6;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #bfd1ec;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-secondary {
    --bs-table-color: #000;
    --bs-table-bg: #e2e3e5;
    --bs-table-border-color: #b5b6b7;
    --bs-table-striped-bg: #d7d8da;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #cbccce;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #d1d2d4;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-success {
    --bs-table-color: #000;
    --bs-table-bg: #d1e7dd;
    --bs-table-border-color: #a7b9b1;
    --bs-table-striped-bg: #c7dbd2;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #bcd0c7;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #c1d6cc;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-info {
    --bs-table-color: #000;
    --bs-table-bg: #cff4fc;
    --bs-table-border-color: #a6c3ca;
    --bs-table-striped-bg: #c5e8ef;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #badce3;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #bfe2e9;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-warning {
    --bs-table-color: #000;
    --bs-table-bg: #fff3cd;
    --bs-table-border-color: #ccc2a4;
    --bs-table-striped-bg: #f2e7c3;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #e6dbb9;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #ece1be;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-danger {
    --bs-table-color: #000;
    --bs-table-bg: #f8d7da;
    --bs-table-border-color: #c6acae;
    --bs-table-striped-bg: #eccccf;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #dfc2c4;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #e5c7ca;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-light {
    --bs-table-color: #000;
    --bs-table-bg: #f8f9fa;
    --bs-table-border-color: #c6c7c8;
    --bs-table-striped-bg: #ecedee;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #dfe0e1;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #e5e6e7;
    --bs-table-hover-color: #000;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-dark {
    --bs-table-color: #fff;
    --bs-table-bg: #212529;
    --bs-table-border-color: #4d5154;
    --bs-table-striped-bg: #2c3034;
    --bs-table-striped-color: #fff;
    --bs-table-active-bg: #373b3e;
    --bs-table-active-color: #fff;
    --bs-table-hover-bg: #323539;
    --bs-table-hover-color: #fff;
    color: var(--bs-table-color);
    border-color: var(--bs-table-border-color);
}

.table-responsive {
    -webkit-overflow-scrolling: touch;
    overflow-x: auto;
}

@media (width <= 575.98px) {
    .table-responsive-sm {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
    }
}

@media (width <= 767.98px) {
    .table-responsive-md {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
    }
}

@media (width <= 991.98px) {
    .table-responsive-lg {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
    }
}

@media (width <= 1199.98px) {
    .table-responsive-xl {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
    }
}

@media (width <= 1399.98px) {
    .table-responsive-xxl {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
    }
}

.form-label {
    margin-bottom: .5rem;
}

.col-form-label {
    padding-top: calc(.375rem + var(--bs-border-width));
    padding-bottom: calc(.375rem + var(--bs-border-width));
    font-size: inherit;
    margin-bottom: 0;
    line-height: 1.5;
}

.col-form-label-lg {
    padding-top: calc(.5rem + var(--bs-border-width));
    padding-bottom: calc(.5rem + var(--bs-border-width));
    font-size: 1.25rem;
}

.col-form-label-sm {
    padding-top: calc(.25rem + var(--bs-border-width));
    padding-bottom: calc(.25rem + var(--bs-border-width));
    font-size: .875rem;
}

.form-text {
    color: var(--bs-secondary-color);
    margin-top: .25rem;
    font-size: .875em;
}

.form-control {
    width: 100%;
    color: var(--bs-body-color);
    appearance: none;
    background-color: var(--bs-body-bg);
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    background-clip: padding-box;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    display: block;
}

@media (prefers-reduced-motion: reduce) {
    .form-control {
        transition: none;
    }
}

.form-control[type="file"] {
    overflow: hidden;
}

    .form-control[type="file"]:not(:disabled):not([readonly]) {
        cursor: pointer;
    }

.form-control:focus {
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 .25rem #0d6efd40;
}

.form-control::-webkit-date-and-time-value {
    min-width: 85px;
    height: 1.5em;
    margin: 0;
}

.form-control::-webkit-datetime-edit {
    padding: 0;
    display: block;
}

.form-control::placeholder {
    color: var(--bs-secondary-color);
    opacity: 1;
}

.form-control:disabled {
    background-color: var(--bs-secondary-bg);
    opacity: 1;
}

.form-control::file-selector-button {
    color: var(--bs-body-color);
    background-color: var(--bs-tertiary-bg);
    pointer-events: none;
    border-color: inherit;
    border-style: solid;
    border-width: 0;
    border-inline-end-width: var(--bs-border-width);
    margin: -.375rem -.75rem;
    border-radius: 0;
    margin-inline-end: .75rem;
    padding: .375rem .75rem;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .form-control::file-selector-button {
        transition: none;
    }
}

.form-control:hover:not(:disabled):not([readonly])::file-selector-button {
    background-color: var(--bs-secondary-bg);
}

.form-control-plaintext {
    width: 100%;
    color: var(--bs-body-color);
    border: solid #0000;
    border-width: var(--bs-border-width) 0;
    background-color: #0000;
    margin-bottom: 0;
    padding: .375rem 0;
    line-height: 1.5;
    display: block;
}

    .form-control-plaintext:focus {
        outline: 0;
    }

    .form-control-plaintext.form-control-sm, .form-control-plaintext.form-control-lg {
        padding-left: 0;
        padding-right: 0;
    }

.form-control-sm {
    min-height: calc(1.5em + .5rem + calc(var(--bs-border-width) * 2));
    border-radius: var(--bs-border-radius-sm);
    padding: .25rem .5rem;
    font-size: .875rem;
}

    .form-control-sm::file-selector-button {
        margin: -.25rem -.5rem;
        margin-inline-end: .5rem;
        padding: .25rem .5rem;
    }

.form-control-lg {
    min-height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
    border-radius: var(--bs-border-radius-lg);
    padding: .5rem 1rem;
    font-size: 1.25rem;
}

    .form-control-lg::file-selector-button {
        margin: -.5rem -1rem;
        margin-inline-end: 1rem;
        padding: .5rem 1rem;
    }

textarea.form-control {
    min-height: calc(1.5em + .75rem + calc(var(--bs-border-width) * 2));
}

textarea.form-control-sm {
    min-height: calc(1.5em + .5rem + calc(var(--bs-border-width) * 2));
}

textarea.form-control-lg {
    min-height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
}

.form-control-color {
    width: 3rem;
    height: calc(1.5em + .75rem + calc(var(--bs-border-width) * 2));
    padding: .375rem;
}

    .form-control-color:not(:disabled):not([readonly]) {
        cursor: pointer;
    }

    .form-control-color::-moz-color-swatch {
        border-radius: var(--bs-border-radius);
        border: 0 !important;
    }

    .form-control-color::-webkit-color-swatch {
        border-radius: var(--bs-border-radius);
        border: 0 !important;
    }

    .form-control-color.form-control-sm {
        height: calc(1.5em + .5rem + calc(var(--bs-border-width) * 2));
    }

    .form-control-color.form-control-lg {
        height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
    }

.form-select {
    --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    width: 100%;
    color: var(--bs-body-color);
    appearance: none;
    background-color: var(--bs-body-bg);
    background-image: var(--bs-form-select-bg-img), var(--bs-form-select-bg-icon, none);
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    background-position: right .75rem center;
    background-repeat: no-repeat;
    background-size: 16px 12px;
    padding: .375rem 2.25rem .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    display: block;
}

@media (prefers-reduced-motion: reduce) {
    .form-select {
        transition: none;
    }
}

.form-select:focus {
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 .25rem #0d6efd40;
}

.form-select[multiple], .form-select[size]:not([size="1"]) {
    background-image: none;
    padding-right: .75rem;
}

.form-select:disabled {
    background-color: var(--bs-secondary-bg);
}

.form-select:-moz-focusring {
    color: #0000;
    text-shadow: 0 0 0 var(--bs-body-color);
}

.form-select-sm {
    border-radius: var(--bs-border-radius-sm);
    padding-top: .25rem;
    padding-bottom: .25rem;
    padding-left: .5rem;
    font-size: .875rem;
}

.form-select-lg {
    border-radius: var(--bs-border-radius-lg);
    padding-top: .5rem;
    padding-bottom: .5rem;
    padding-left: 1rem;
    font-size: 1.25rem;
}

[data-bs-theme="dark"] .form-select {
    --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23dee2e6' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

.form-check {
    min-height: 1.5rem;
    margin-bottom: .125rem;
    padding-left: 1.5em;
    display: block;
}

    .form-check .form-check-input {
        float: left;
        margin-left: -1.5em;
    }

.form-check-reverse {
    text-align: right;
    padding-left: 0;
    padding-right: 1.5em;
}

    .form-check-reverse .form-check-input {
        float: right;
        margin-left: 0;
        margin-right: -1.5em;
    }

.form-check-input {
    --bs-form-check-bg: var(--bs-body-bg);
    vertical-align: top;
    appearance: none;
    background-color: var(--bs-form-check-bg);
    background-image: var(--bs-form-check-bg-image);
    border: var(--bs-border-width) solid var(--bs-border-color);
    print-color-adjust: exact;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    flex-shrink: 0;
    width: 1em;
    height: 1em;
    margin-top: .25em;
}

    .form-check-input[type="checkbox"] {
        border-radius: .25em;
    }

    .form-check-input[type="radio"] {
        border-radius: 50%;
    }

    .form-check-input:active {
        filter: brightness(90%);
    }

    .form-check-input:focus {
        border-color: #86b7fe;
        outline: 0;
        box-shadow: 0 0 0 .25rem #0d6efd40;
    }

    .form-check-input:checked {
        background-color: #0d6efd;
        border-color: #0d6efd;
    }

        .form-check-input:checked[type="checkbox"] {
            --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
        }

        .form-check-input:checked[type="radio"] {
            --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e");
        }

    .form-check-input[type="checkbox"]:indeterminate {
        --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3e%3c/svg%3e");
        background-color: #0d6efd;
        border-color: #0d6efd;
    }

    .form-check-input:disabled {
        pointer-events: none;
        filter: none;
        opacity: .5;
    }

        .form-check-input[disabled] ~ .form-check-label, .form-check-input:disabled ~ .form-check-label {
            cursor: default;
            opacity: .5;
        }

.form-switch {
    padding-left: 2.5em;
}

    .form-switch .form-check-input {
        --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%280, 0, 0, 0.25%29'/%3e%3c/svg%3e");
        background-image: var(--bs-form-switch-bg);
        background-position: 0;
        border-radius: 2em;
        width: 2em;
        margin-left: -2.5em;
        transition: background-position .15s ease-in-out;
    }

@media (prefers-reduced-motion: reduce) {
    .form-switch .form-check-input {
        transition: none;
    }
}

.form-switch .form-check-input:focus {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%2386b7fe'/%3e%3c/svg%3e");
}

.form-switch .form-check-input:checked {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
    background-position: 100%;
}

.form-switch.form-check-reverse {
    padding-left: 0;
    padding-right: 2.5em;
}

    .form-switch.form-check-reverse .form-check-input {
        margin-left: 0;
        margin-right: -2.5em;
    }

.form-check-inline {
    margin-right: 1rem;
    display: inline-block;
}

.btn-check {
    clip: rect(0, 0, 0, 0);
    pointer-events: none;
    position: absolute;
}

    .btn-check[disabled] + .btn, .btn-check:disabled + .btn {
        pointer-events: none;
        filter: none;
        opacity: .65;
    }

[data-bs-theme="dark"] .form-switch .form-check-input:not(:checked):not(:focus) {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%28255, 255, 255, 0.25%29'/%3e%3c/svg%3e");
}

.form-range {
    appearance: none;
    background-color: #0000;
    width: 100%;
    height: 1.5rem;
    padding: 0;
}

    .form-range:focus {
        outline: 0;
    }

        .form-range:focus::-webkit-slider-thumb {
            box-shadow: 0 0 0 1px #fff, 0 0 0 .25rem #0d6efd40;
        }

        .form-range:focus::-moz-range-thumb {
            box-shadow: 0 0 0 1px #fff, 0 0 0 .25rem #0d6efd40;
        }

    .form-range::-moz-focus-outer {
        border: 0;
    }

    .form-range::-webkit-slider-thumb {
        appearance: none;
        background-color: #0d6efd;
        border: 0;
        border-radius: 1rem;
        width: 1rem;
        height: 1rem;
        margin-top: -.25rem;
        transition: background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    }

@media (prefers-reduced-motion: reduce) {
    .form-range::-webkit-slider-thumb {
        transition: none;
    }
}

.form-range::-webkit-slider-thumb:active {
    background-color: #b6d4fe;
}

.form-range::-webkit-slider-runnable-track {
    color: #0000;
    cursor: pointer;
    background-color: var(--bs-secondary-bg);
    border-color: #0000;
    border-radius: 1rem;
    width: 100%;
    height: .5rem;
}

.form-range::-moz-range-thumb {
    appearance: none;
    background-color: #0d6efd;
    border: 0;
    border-radius: 1rem;
    width: 1rem;
    height: 1rem;
    transition: background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

@media (prefers-reduced-motion: reduce) {
    .form-range::-moz-range-thumb {
        transition: none;
    }
}

.form-range::-moz-range-thumb:active {
    background-color: #b6d4fe;
}

.form-range::-moz-range-track {
    color: #0000;
    cursor: pointer;
    background-color: var(--bs-secondary-bg);
    border-color: #0000;
    border-radius: 1rem;
    width: 100%;
    height: .5rem;
}

.form-range:disabled {
    pointer-events: none;
}

    .form-range:disabled::-webkit-slider-thumb {
        background-color: var(--bs-secondary-color);
    }

    .form-range:disabled::-moz-range-thumb {
        background-color: var(--bs-secondary-color);
    }

.form-floating {
    position: relative;
}

    .form-floating > .form-control, .form-floating > .form-control-plaintext, .form-floating > .form-select {
        height: calc(3.5rem + calc(var(--bs-border-width) * 2));
        min-height: calc(3.5rem + calc(var(--bs-border-width) * 2));
        line-height: 1.25;
    }

    .form-floating > label {
        z-index: 2;
        text-align: start;
        text-overflow: ellipsis;
        white-space: nowrap;
        pointer-events: none;
        border: var(--bs-border-width) solid transparent;
        transform-origin: 0 0;
        height: 100%;
        padding: 1rem .75rem;
        transition: opacity .1s ease-in-out, transform .1s ease-in-out;
        position: absolute;
        top: 0;
        left: 0;
        overflow: hidden;
    }

@media (prefers-reduced-motion: reduce) {
    .form-floating > label {
        transition: none;
    }
}

.form-floating > .form-control, .form-floating > .form-control-plaintext {
    padding: 1rem .75rem;
}

    .form-floating > .form-control::placeholder, .form-floating > .form-control-plaintext::placeholder {
        color: #0000;
    }

    .form-floating > .form-control:focus, .form-floating > .form-control:not(:placeholder-shown), .form-floating > .form-control-plaintext:focus, .form-floating > .form-control-plaintext:not(:placeholder-shown), :-webkit-any(.form-floating > .form-control:-webkit-autofill, .form-floating > .form-control-plaintext:-webkit-autofill), .form-floating > .form-select {
        padding-top: 1.625rem;
        padding-bottom: .625rem;
    }

    .form-floating > .form-control:focus, .form-floating > .form-control:not(:placeholder-shown), .form-floating > .form-control-plaintext:focus, .form-floating > .form-control-plaintext:not(:placeholder-shown), :is(.form-floating > .form-control:autofill, .form-floating > .form-control-plaintext:autofill), .form-floating > .form-select {
        padding-top: 1.625rem;
        padding-bottom: .625rem;
    }

        .form-floating > .form-control:focus ~ label, .form-floating > .form-control:not(:placeholder-shown) ~ label, .form-floating > .form-control-plaintext ~ label, .form-floating > .form-select ~ label {
            color: rgba(var(--bs-body-color-rgb), .65);
            transform: scale(.85)translateY(-.5rem)translateX(.15rem);
        }

            .form-floating > .form-control:focus ~ label:after, .form-floating > .form-control:not(:placeholder-shown) ~ label:after, .form-floating > .form-control-plaintext ~ label:after, .form-floating > .form-select ~ label:after {
                z-index: -1;
                content: "";
                background-color: var(--bs-body-bg);
                border-radius: var(--bs-border-radius);
                height: 1.5em;
                position: absolute;
                inset: 1rem .375rem;
            }

    .form-floating > .form-control:-webkit-autofill ~ label {
        color: rgba(var(--bs-body-color-rgb), .65);
        transform: scale(.85)translateY(-.5rem)translateX(.15rem);
    }

    .form-floating > .form-control-plaintext ~ label {
        border-width: var(--bs-border-width) 0;
    }

    .form-floating > :disabled ~ label, .form-floating > .form-control:disabled ~ label {
        color: #6c757d;
    }

        .form-floating > :disabled ~ label:after, .form-floating > .form-control:disabled ~ label:after {
            background-color: var(--bs-secondary-bg);
        }

.input-group {
    flex-wrap: wrap;
    align-items: stretch;
    width: 100%;
    display: flex;
    position: relative;
}

    .input-group > .form-control, .input-group > .form-select, .input-group > .form-floating {
        flex: auto;
        width: 1%;
        min-width: 0;
        position: relative;
    }

        .input-group > .form-control:focus, .input-group > .form-select:focus, .input-group > .form-floating:focus-within {
            z-index: 5;
        }

    .input-group .btn {
        z-index: 2;
        position: relative;
    }

        .input-group .btn:focus {
            z-index: 5;
        }

.input-group-text {
    color: var(--bs-body-color);
    text-align: center;
    white-space: nowrap;
    background-color: var(--bs-tertiary-bg);
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    align-items: center;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    display: flex;
}

.input-group-lg > .form-control, .input-group-lg > .form-select, .input-group-lg > .input-group-text, .input-group-lg > .btn {
    border-radius: var(--bs-border-radius-lg);
    padding: .5rem 1rem;
    font-size: 1.25rem;
}

.input-group-sm > .form-control, .input-group-sm > .form-select, .input-group-sm > .input-group-text, .input-group-sm > .btn {
    border-radius: var(--bs-border-radius-sm);
    padding: .25rem .5rem;
    font-size: .875rem;
}

.input-group-lg > .form-select, .input-group-sm > .form-select {
    padding-right: 3rem;
}

.input-group:not(.has-validation) > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating), .input-group:not(.has-validation) > .dropdown-toggle:nth-last-child(n+3), .input-group:not(.has-validation) > .form-floating:not(:last-child) > .form-control, .input-group:not(.has-validation) > .form-floating:not(:last-child) > .form-select, .input-group.has-validation > :nth-last-child(n+3):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating), .input-group.has-validation > .dropdown-toggle:nth-last-child(n+4), .input-group.has-validation > .form-floating:nth-last-child(n+3) > .form-control, .input-group.has-validation > .form-floating:nth-last-child(n+3) > .form-select {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    margin-left: calc(var(--bs-border-width) * -1);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.input-group > .form-floating:not(:first-child) > .form-control, .input-group > .form-floating:not(:first-child) > .form-select {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.valid-feedback {
    width: 100%;
    color: var(--bs-form-valid-color);
    margin-top: .25rem;
    font-size: .875em;
    display: none;
}

.valid-tooltip {
    z-index: 5;
    color: #fff;
    background-color: var(--bs-success);
    border-radius: var(--bs-border-radius);
    max-width: 100%;
    margin-top: .1rem;
    padding: .25rem .5rem;
    font-size: .875rem;
    display: none;
    position: absolute;
    top: 100%;
}

.was-validated :valid ~ .valid-feedback, .was-validated :valid ~ .valid-tooltip, .is-valid ~ .valid-feedback, .is-valid ~ .valid-tooltip {
    display: block;
}

.was-validated .form-control:valid, .form-control.is-valid {
    border-color: var(--bs-form-valid-border-color);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.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");
    background-position: right calc(.375em + .1875rem) center;
    background-repeat: no-repeat;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem);
    padding-right: calc(1.5em + .75rem);
}

    .was-validated .form-control:valid:focus, .form-control.is-valid:focus {
        border-color: var(--bs-form-valid-border-color);
        box-shadow: 0 0 0 .25rem rgba(var(--bs-success-rgb), .25);
    }

.was-validated textarea.form-control:valid, textarea.form-control.is-valid {
    background-position: right calc(.375em + .1875rem) top calc(.375em + .1875rem);
    padding-right: calc(1.5em + .75rem);
}

.was-validated .form-select:valid, .form-select.is-valid {
    border-color: var(--bs-form-valid-border-color);
}

    .was-validated .form-select:valid:not([multiple]):not([size]), .was-validated .form-select:valid:not([multiple])[size="1"], .form-select.is-valid:not([multiple]):not([size]), .form-select.is-valid:not([multiple])[size="1"] {
        --bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.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");
        background-position: right .75rem center, right 2.25rem center;
        background-size: 16px 12px, calc(.75em + .375rem) calc(.75em + .375rem);
        padding-right: 4.125rem;
    }

    .was-validated .form-select:valid:focus, .form-select.is-valid:focus {
        border-color: var(--bs-form-valid-border-color);
        box-shadow: 0 0 0 .25rem rgba(var(--bs-success-rgb), .25);
    }

.was-validated .form-control-color:valid, .form-control-color.is-valid {
    width: calc(1.5em + 3.75rem);
}

.was-validated .form-check-input:valid, .form-check-input.is-valid {
    border-color: var(--bs-form-valid-border-color);
}

    .was-validated .form-check-input:valid:checked, .form-check-input.is-valid:checked {
        background-color: var(--bs-form-valid-color);
    }

    .was-validated .form-check-input:valid:focus, .form-check-input.is-valid:focus {
        box-shadow: 0 0 0 .25rem rgba(var(--bs-success-rgb), .25);
    }

    .was-validated .form-check-input:valid ~ .form-check-label, .form-check-input.is-valid ~ .form-check-label {
        color: var(--bs-form-valid-color);
    }

.form-check-inline .form-check-input ~ .valid-feedback {
    margin-left: .5em;
}

.was-validated .input-group > .form-control:not(:focus):valid, .input-group > .form-control:not(:focus).is-valid, .was-validated .input-group > .form-select:not(:focus):valid, .input-group > .form-select:not(:focus).is-valid, .was-validated .input-group > .form-floating:not(:focus-within):valid, .input-group > .form-floating:not(:focus-within).is-valid {
    z-index: 3;
}

.invalid-feedback {
    width: 100%;
    color: var(--bs-form-invalid-color);
    margin-top: .25rem;
    font-size: .875em;
    display: none;
}

.invalid-tooltip {
    z-index: 5;
    color: #fff;
    background-color: var(--bs-danger);
    border-radius: var(--bs-border-radius);
    max-width: 100%;
    margin-top: .1rem;
    padding: .25rem .5rem;
    font-size: .875rem;
    display: none;
    position: absolute;
    top: 100%;
}

.was-validated :invalid ~ .invalid-feedback, .was-validated :invalid ~ .invalid-tooltip, .is-invalid ~ .invalid-feedback, .is-invalid ~ .invalid-tooltip {
    display: block;
}

.was-validated .form-control:invalid, .form-control.is-invalid {
    border-color: var(--bs-form-invalid-border-color);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%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='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-position: right calc(.375em + .1875rem) center;
    background-repeat: no-repeat;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem);
    padding-right: calc(1.5em + .75rem);
}

    .was-validated .form-control:invalid:focus, .form-control.is-invalid:focus {
        border-color: var(--bs-form-invalid-border-color);
        box-shadow: 0 0 0 .25rem rgba(var(--bs-danger-rgb), .25);
    }

.was-validated textarea.form-control:invalid, textarea.form-control.is-invalid {
    background-position: right calc(.375em + .1875rem) top calc(.375em + .1875rem);
    padding-right: calc(1.5em + .75rem);
}

.was-validated .form-select:invalid, .form-select.is-invalid {
    border-color: var(--bs-form-invalid-border-color);
}

    .was-validated .form-select:invalid:not([multiple]):not([size]), .was-validated .form-select:invalid:not([multiple])[size="1"], .form-select.is-invalid:not([multiple]):not([size]), .form-select.is-invalid:not([multiple])[size="1"] {
        --bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%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='%23dc3545' stroke='none'/%3e%3c/svg%3e");
        background-position: right .75rem center, right 2.25rem center;
        background-size: 16px 12px, calc(.75em + .375rem) calc(.75em + .375rem);
        padding-right: 4.125rem;
    }

    .was-validated .form-select:invalid:focus, .form-select.is-invalid:focus {
        border-color: var(--bs-form-invalid-border-color);
        box-shadow: 0 0 0 .25rem rgba(var(--bs-danger-rgb), .25);
    }

.was-validated .form-control-color:invalid, .form-control-color.is-invalid {
    width: calc(1.5em + 3.75rem);
}

.was-validated .form-check-input:invalid, .form-check-input.is-invalid {
    border-color: var(--bs-form-invalid-border-color);
}

    .was-validated .form-check-input:invalid:checked, .form-check-input.is-invalid:checked {
        background-color: var(--bs-form-invalid-color);
    }

    .was-validated .form-check-input:invalid:focus, .form-check-input.is-invalid:focus {
        box-shadow: 0 0 0 .25rem rgba(var(--bs-danger-rgb), .25);
    }

    .was-validated .form-check-input:invalid ~ .form-check-label, .form-check-input.is-invalid ~ .form-check-label {
        color: var(--bs-form-invalid-color);
    }

.form-check-inline .form-check-input ~ .invalid-feedback {
    margin-left: .5em;
}

.was-validated .input-group > .form-control:not(:focus):invalid, .input-group > .form-control:not(:focus).is-invalid, .was-validated .input-group > .form-select:not(:focus):invalid, .input-group > .form-select:not(:focus).is-invalid, .was-validated .input-group > .form-floating:not(:focus-within):invalid, .input-group > .form-floating:not(:focus-within).is-invalid {
    z-index: 4;
}

.btn {
    --bs-btn-padding-x: .75rem;
    --bs-btn-padding-y: .375rem;
    --bs-btn-font-family:;
    --bs-btn-font-size: 1rem;
    --bs-btn-font-weight: 400;
    --bs-btn-line-height: 1.5;
    --bs-btn-color: var(--bs-body-color);
    --bs-btn-bg: transparent;
    --bs-btn-border-width: var(--bs-border-width);
    --bs-btn-border-color: transparent;
    --bs-btn-border-radius: var(--bs-border-radius);
    --bs-btn-hover-border-color: transparent;
    --bs-btn-box-shadow: inset 0 1px 0 #ffffff26, 0 1px 1px #00000013;
    --bs-btn-disabled-opacity: .65;
    --bs-btn-focus-box-shadow: 0 0 0 .25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);
    padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
    font-family: var(--bs-btn-font-family);
    font-size: var(--bs-btn-font-size);
    font-weight: var(--bs-btn-font-weight);
    line-height: var(--bs-btn-line-height);
    color: var(--bs-btn-color);
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
    border-radius: var(--bs-btn-border-radius);
    background-color: var(--bs-btn-bg);
    text-decoration: none;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    display: inline-block;
}

@media (prefers-reduced-motion: reduce) {
    .btn {
        transition: none;
    }
}

.btn:hover {
    color: var(--bs-btn-hover-color);
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color);
}

.btn-check + .btn:hover {
    color: var(--bs-btn-color);
    background-color: var(--bs-btn-bg);
    border-color: var(--bs-btn-border-color);
}

.btn:focus-visible {
    color: var(--bs-btn-hover-color);
    background-color: var(--bs-btn-hover-bg);
    border-color: var(--bs-btn-hover-border-color);
    box-shadow: var(--bs-btn-focus-box-shadow);
    outline: 0;
}

.btn-check:focus-visible + .btn {
    border-color: var(--bs-btn-hover-border-color);
    box-shadow: var(--bs-btn-focus-box-shadow);
    outline: 0;
}

.btn-check:checked + .btn, :not(.btn-check) + .btn:active, .btn:first-child:active, .btn.active, .btn.show {
    color: var(--bs-btn-active-color);
    background-color: var(--bs-btn-active-bg);
    border-color: var(--bs-btn-active-border-color);
}

    .btn-check:checked + .btn:focus-visible, :not(.btn-check) + .btn:active:focus-visible, .btn:first-child:active:focus-visible, .btn.active:focus-visible, .btn.show:focus-visible, .btn-check:checked:focus-visible + .btn {
        box-shadow: var(--bs-btn-focus-box-shadow);
    }

.btn:disabled, .btn.disabled, fieldset:disabled .btn {
    color: var(--bs-btn-disabled-color);
    pointer-events: none;
    background-color: var(--bs-btn-disabled-bg);
    border-color: var(--bs-btn-disabled-border-color);
    opacity: var(--bs-btn-disabled-opacity);
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #0d6efd;
    --bs-btn-border-color: #0d6efd;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #0b5ed7;
    --bs-btn-hover-border-color: #0a58ca;
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #0a58ca;
    --bs-btn-active-border-color: #0a53be;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #0d6efd;
    --bs-btn-disabled-border-color: #0d6efd;
}

.btn-secondary {
    --bs-btn-color: #fff;
    --bs-btn-bg: #6c757d;
    --bs-btn-border-color: #6c757d;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #5c636a;
    --bs-btn-hover-border-color: #565e64;
    --bs-btn-focus-shadow-rgb: 130, 138, 145;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #565e64;
    --bs-btn-active-border-color: #51585e;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #6c757d;
    --bs-btn-disabled-border-color: #6c757d;
}

.btn-success {
    --bs-btn-color: #fff;
    --bs-btn-bg: #198754;
    --bs-btn-border-color: #198754;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #157347;
    --bs-btn-hover-border-color: #146c43;
    --bs-btn-focus-shadow-rgb: 60, 153, 110;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #146c43;
    --bs-btn-active-border-color: #13653f;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #198754;
    --bs-btn-disabled-border-color: #198754;
}

.btn-info {
    --bs-btn-color: #000;
    --bs-btn-bg: #0dcaf0;
    --bs-btn-border-color: #0dcaf0;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #31d2f2;
    --bs-btn-hover-border-color: #25cff2;
    --bs-btn-focus-shadow-rgb: 11, 172, 204;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #3dd5f3;
    --bs-btn-active-border-color: #25cff2;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #000;
    --bs-btn-disabled-bg: #0dcaf0;
    --bs-btn-disabled-border-color: #0dcaf0;
}

.btn-warning {
    --bs-btn-color: #000;
    --bs-btn-bg: #ffc107;
    --bs-btn-border-color: #ffc107;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #ffca2c;
    --bs-btn-hover-border-color: #ffc720;
    --bs-btn-focus-shadow-rgb: 217, 164, 6;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #ffcd39;
    --bs-btn-active-border-color: #ffc720;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #000;
    --bs-btn-disabled-bg: #ffc107;
    --bs-btn-disabled-border-color: #ffc107;
}

.btn-danger {
    --bs-btn-color: #fff;
    --bs-btn-bg: #dc3545;
    --bs-btn-border-color: #dc3545;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #bb2d3b;
    --bs-btn-hover-border-color: #b02a37;
    --bs-btn-focus-shadow-rgb: 225, 83, 97;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #b02a37;
    --bs-btn-active-border-color: #a52834;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #dc3545;
    --bs-btn-disabled-border-color: #dc3545;
}

.btn-light {
    --bs-btn-color: #000;
    --bs-btn-bg: #f8f9fa;
    --bs-btn-border-color: #f8f9fa;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #d3d4d5;
    --bs-btn-hover-border-color: #c6c7c8;
    --bs-btn-focus-shadow-rgb: 211, 212, 213;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #c6c7c8;
    --bs-btn-active-border-color: #babbbc;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #000;
    --bs-btn-disabled-bg: #f8f9fa;
    --bs-btn-disabled-border-color: #f8f9fa;
}

.btn-dark {
    --bs-btn-color: #fff;
    --bs-btn-bg: #212529;
    --bs-btn-border-color: #212529;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #424649;
    --bs-btn-hover-border-color: #373b3e;
    --bs-btn-focus-shadow-rgb: 66, 70, 73;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #4d5154;
    --bs-btn-active-border-color: #373b3e;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #212529;
    --bs-btn-disabled-border-color: #212529;
}

.btn-outline-primary {
    --bs-btn-color: #0d6efd;
    --bs-btn-border-color: #0d6efd;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #0d6efd;
    --bs-btn-hover-border-color: #0d6efd;
    --bs-btn-focus-shadow-rgb: 13, 110, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #0d6efd;
    --bs-btn-active-border-color: #0d6efd;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #0d6efd;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #0d6efd;
    --bs-gradient: none;
}

.btn-outline-secondary {
    --bs-btn-color: #6c757d;
    --bs-btn-border-color: #6c757d;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #6c757d;
    --bs-btn-hover-border-color: #6c757d;
    --bs-btn-focus-shadow-rgb: 108, 117, 125;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #6c757d;
    --bs-btn-active-border-color: #6c757d;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #6c757d;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #6c757d;
    --bs-gradient: none;
}

.btn-outline-success {
    --bs-btn-color: #198754;
    --bs-btn-border-color: #198754;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #198754;
    --bs-btn-hover-border-color: #198754;
    --bs-btn-focus-shadow-rgb: 25, 135, 84;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #198754;
    --bs-btn-active-border-color: #198754;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #198754;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #198754;
    --bs-gradient: none;
}

.btn-outline-info {
    --bs-btn-color: #0dcaf0;
    --bs-btn-border-color: #0dcaf0;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #0dcaf0;
    --bs-btn-hover-border-color: #0dcaf0;
    --bs-btn-focus-shadow-rgb: 13, 202, 240;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #0dcaf0;
    --bs-btn-active-border-color: #0dcaf0;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #0dcaf0;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #0dcaf0;
    --bs-gradient: none;
}

.btn-outline-warning {
    --bs-btn-color: #ffc107;
    --bs-btn-border-color: #ffc107;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #ffc107;
    --bs-btn-hover-border-color: #ffc107;
    --bs-btn-focus-shadow-rgb: 255, 193, 7;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #ffc107;
    --bs-btn-active-border-color: #ffc107;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #ffc107;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #ffc107;
    --bs-gradient: none;
}

.btn-outline-danger {
    --bs-btn-color: #dc3545;
    --bs-btn-border-color: #dc3545;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #dc3545;
    --bs-btn-hover-border-color: #dc3545;
    --bs-btn-focus-shadow-rgb: 220, 53, 69;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #dc3545;
    --bs-btn-active-border-color: #dc3545;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #dc3545;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #dc3545;
    --bs-gradient: none;
}

.btn-outline-light {
    --bs-btn-color: #f8f9fa;
    --bs-btn-border-color: #f8f9fa;
    --bs-btn-hover-color: #000;
    --bs-btn-hover-bg: #f8f9fa;
    --bs-btn-hover-border-color: #f8f9fa;
    --bs-btn-focus-shadow-rgb: 248, 249, 250;
    --bs-btn-active-color: #000;
    --bs-btn-active-bg: #f8f9fa;
    --bs-btn-active-border-color: #f8f9fa;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #f8f9fa;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #f8f9fa;
    --bs-gradient: none;
}

.btn-outline-dark {
    --bs-btn-color: #212529;
    --bs-btn-border-color: #212529;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #212529;
    --bs-btn-hover-border-color: #212529;
    --bs-btn-focus-shadow-rgb: 33, 37, 41;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #212529;
    --bs-btn-active-border-color: #212529;
    --bs-btn-active-shadow: inset 0 3px 5px #00000020;
    --bs-btn-disabled-color: #212529;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #212529;
    --bs-gradient: none;
}

.btn-link {
    --bs-btn-font-weight: 400;
    --bs-btn-color: var(--bs-link-color);
    --bs-btn-bg: transparent;
    --bs-btn-border-color: transparent;
    --bs-btn-hover-color: var(--bs-link-hover-color);
    --bs-btn-hover-border-color: transparent;
    --bs-btn-active-color: var(--bs-link-hover-color);
    --bs-btn-active-border-color: transparent;
    --bs-btn-disabled-color: #6c757d;
    --bs-btn-disabled-border-color: transparent;
    --bs-btn-box-shadow: 0 0 0 #000;
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    text-decoration: underline;
}

    .btn-link:focus-visible {
        color: var(--bs-btn-color);
    }

    .btn-link:hover {
        color: var(--bs-btn-hover-color);
    }

.btn-lg, .btn-group-lg > .btn {
    --bs-btn-padding-y: .5rem;
    --bs-btn-padding-x: 1rem;
    --bs-btn-font-size: 1.25rem;
    --bs-btn-border-radius: var(--bs-border-radius-lg);
}

.btn-sm, .btn-group-sm > .btn {
    --bs-btn-padding-y: .25rem;
    --bs-btn-padding-x: .5rem;
    --bs-btn-font-size: .875rem;
    --bs-btn-border-radius: var(--bs-border-radius-sm);
}

.fade {
    transition: opacity .15s linear;
}

@media (prefers-reduced-motion: reduce) {
    .fade {
        transition: none;
    }
}

.fade:not(.show) {
    opacity: 0;
}

.collapse:not(.show) {
    display: none;
}

.collapsing {
    height: 0;
    transition: height .35s;
    overflow: hidden;
}

@media (prefers-reduced-motion: reduce) {
    .collapsing {
        transition: none;
    }
}

.collapsing.collapse-horizontal {
    width: 0;
    height: auto;
    transition: width .35s;
}

@media (prefers-reduced-motion: reduce) {
    .collapsing.collapse-horizontal {
        transition: none;
    }
}

.dropup, .dropend, .dropdown, .dropstart, .dropup-center, .dropdown-center {
    position: relative;
}

.dropdown-toggle {
    white-space: nowrap;
}

    .dropdown-toggle:after {
        vertical-align: .255em;
        content: "";
        border: .3em solid #0000;
        border-top-color: currentColor;
        border-bottom: 0;
        margin-left: .255em;
        display: inline-block;
    }

    .dropdown-toggle:empty:after {
        margin-left: 0;
    }

.dropdown-menu {
    --bs-dropdown-zindex: 1000;
    --bs-dropdown-min-width: 10rem;
    --bs-dropdown-padding-x: 0;
    --bs-dropdown-padding-y: .5rem;
    --bs-dropdown-spacer: .125rem;
    --bs-dropdown-font-size: 1rem;
    --bs-dropdown-color: var(--bs-body-color);
    --bs-dropdown-bg: var(--bs-body-bg);
    --bs-dropdown-border-color: var(--bs-border-color-translucent);
    --bs-dropdown-border-radius: var(--bs-border-radius);
    --bs-dropdown-border-width: var(--bs-border-width);
    --bs-dropdown-inner-border-radius: calc(var(--bs-border-radius) - var(--bs-border-width));
    --bs-dropdown-divider-bg: var(--bs-border-color-translucent);
    --bs-dropdown-divider-margin-y: .5rem;
    --bs-dropdown-box-shadow: var(--bs-box-shadow);
    --bs-dropdown-link-color: var(--bs-body-color);
    --bs-dropdown-link-hover-color: var(--bs-body-color);
    --bs-dropdown-link-hover-bg: var(--bs-tertiary-bg);
    --bs-dropdown-link-active-color: #fff;
    --bs-dropdown-link-active-bg: #0d6efd;
    --bs-dropdown-link-disabled-color: var(--bs-tertiary-color);
    --bs-dropdown-item-padding-x: 1rem;
    --bs-dropdown-item-padding-y: .25rem;
    --bs-dropdown-header-color: #6c757d;
    --bs-dropdown-header-padding-x: 1rem;
    --bs-dropdown-header-padding-y: .5rem;
    z-index: var(--bs-dropdown-zindex);
    min-width: var(--bs-dropdown-min-width);
    padding: var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);
    font-size: var(--bs-dropdown-font-size);
    color: var(--bs-dropdown-color);
    text-align: left;
    background-color: var(--bs-dropdown-bg);
    border: var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);
    border-radius: var(--bs-dropdown-border-radius);
    background-clip: padding-box;
    margin: 0;
    list-style: none;
    display: none;
    position: absolute;
}

    .dropdown-menu[data-bs-popper] {
        margin-top: var(--bs-dropdown-spacer);
        top: 100%;
        left: 0;
    }

.dropdown-menu-start {
    --bs-position: start;
}

    .dropdown-menu-start[data-bs-popper] {
        left: 0;
        right: auto;
    }

.dropdown-menu-end {
    --bs-position: end;
}

    .dropdown-menu-end[data-bs-popper] {
        left: auto;
        right: 0;
    }

@media (width >= 576px) {
    .dropdown-menu-sm-start {
        --bs-position: start;
    }

        .dropdown-menu-sm-start[data-bs-popper] {
            left: 0;
            right: auto;
        }

    .dropdown-menu-sm-end {
        --bs-position: end;
    }

        .dropdown-menu-sm-end[data-bs-popper] {
            left: auto;
            right: 0;
        }
}

@media (width >= 768px) {
    .dropdown-menu-md-start {
        --bs-position: start;
    }

        .dropdown-menu-md-start[data-bs-popper] {
            left: 0;
            right: auto;
        }

    .dropdown-menu-md-end {
        --bs-position: end;
    }

        .dropdown-menu-md-end[data-bs-popper] {
            left: auto;
            right: 0;
        }
}

@media (width >= 992px) {
    .dropdown-menu-lg-start {
        --bs-position: start;
    }

        .dropdown-menu-lg-start[data-bs-popper] {
            left: 0;
            right: auto;
        }

    .dropdown-menu-lg-end {
        --bs-position: end;
    }

        .dropdown-menu-lg-end[data-bs-popper] {
            left: auto;
            right: 0;
        }
}

@media (width >= 1200px) {
    .dropdown-menu-xl-start {
        --bs-position: start;
    }

        .dropdown-menu-xl-start[data-bs-popper] {
            left: 0;
            right: auto;
        }

    .dropdown-menu-xl-end {
        --bs-position: end;
    }

        .dropdown-menu-xl-end[data-bs-popper] {
            left: auto;
            right: 0;
        }
}

@media (width >= 1400px) {
    .dropdown-menu-xxl-start {
        --bs-position: start;
    }

        .dropdown-menu-xxl-start[data-bs-popper] {
            left: 0;
            right: auto;
        }

    .dropdown-menu-xxl-end {
        --bs-position: end;
    }

        .dropdown-menu-xxl-end[data-bs-popper] {
            left: auto;
            right: 0;
        }
}

.dropup .dropdown-menu[data-bs-popper] {
    margin-top: 0;
    margin-bottom: var(--bs-dropdown-spacer);
    top: auto;
    bottom: 100%;
}

.dropup .dropdown-toggle:after {
    vertical-align: .255em;
    content: "";
    border: .3em solid #0000;
    border-top: 0;
    border-bottom-color: currentColor;
    margin-left: .255em;
    display: inline-block;
}

.dropup .dropdown-toggle:empty:after {
    margin-left: 0;
}

.dropend .dropdown-menu[data-bs-popper] {
    margin-top: 0;
    margin-left: var(--bs-dropdown-spacer);
    top: 0;
    left: 100%;
    right: auto;
}

.dropend .dropdown-toggle:after {
    vertical-align: .255em;
    content: "";
    border: .3em solid #0000;
    border-left-color: currentColor;
    border-right: 0;
    margin-left: .255em;
    display: inline-block;
}

.dropend .dropdown-toggle:empty:after {
    margin-left: 0;
}

.dropend .dropdown-toggle:after {
    vertical-align: 0;
}

.dropstart .dropdown-menu[data-bs-popper] {
    margin-top: 0;
    margin-right: var(--bs-dropdown-spacer);
    top: 0;
    left: auto;
    right: 100%;
}

.dropstart .dropdown-toggle:after {
    vertical-align: .255em;
    content: "";
    margin-left: .255em;
    display: none;
}

.dropstart .dropdown-toggle:before {
    vertical-align: .255em;
    content: "";
    border-top: .3em solid #0000;
    border-bottom: .3em solid #0000;
    border-right: .3em solid;
    margin-right: .255em;
    display: inline-block;
}

.dropstart .dropdown-toggle:empty:after {
    margin-left: 0;
}

.dropstart .dropdown-toggle:before {
    vertical-align: 0;
}

.dropdown-divider {
    height: 0;
    margin: var(--bs-dropdown-divider-margin-y) 0;
    border-top: 1px solid var(--bs-dropdown-divider-bg);
    opacity: 1;
    overflow: hidden;
}

.dropdown-item {
    width: 100%;
    padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
    clear: both;
    color: var(--bs-dropdown-link-color);
    text-align: inherit;
    white-space: nowrap;
    border-radius: var(--bs-dropdown-item-border-radius, 0);
    background-color: #0000;
    border: 0;
    font-weight: 400;
    text-decoration: none;
    display: block;
}

    .dropdown-item:hover, .dropdown-item:focus {
        color: var(--bs-dropdown-link-hover-color);
        background-color: var(--bs-dropdown-link-hover-bg);
    }

    .dropdown-item.active, .dropdown-item:active {
        color: var(--bs-dropdown-link-active-color);
        background-color: var(--bs-dropdown-link-active-bg);
        text-decoration: none;
    }

    .dropdown-item.disabled, .dropdown-item:disabled {
        color: var(--bs-dropdown-link-disabled-color);
        pointer-events: none;
        background-color: #0000;
    }

.dropdown-menu.show {
    display: block;
}

.dropdown-header {
    padding: var(--bs-dropdown-header-padding-y) var(--bs-dropdown-header-padding-x);
    color: var(--bs-dropdown-header-color);
    white-space: nowrap;
    margin-bottom: 0;
    font-size: .875rem;
    display: block;
}

.dropdown-item-text {
    padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
    color: var(--bs-dropdown-link-color);
    display: block;
}

.dropdown-menu-dark {
    --bs-dropdown-color: #dee2e6;
    --bs-dropdown-bg: #343a40;
    --bs-dropdown-border-color: var(--bs-border-color-translucent);
    --bs-dropdown-box-shadow:;
    --bs-dropdown-link-color: #dee2e6;
    --bs-dropdown-link-hover-color: #fff;
    --bs-dropdown-divider-bg: var(--bs-border-color-translucent);
    --bs-dropdown-link-hover-bg: #ffffff26;
    --bs-dropdown-link-active-color: #fff;
    --bs-dropdown-link-active-bg: #0d6efd;
    --bs-dropdown-link-disabled-color: #adb5bd;
    --bs-dropdown-header-color: #adb5bd;
}

.btn-group, .btn-group-vertical {
    vertical-align: middle;
    display: inline-flex;
    position: relative;
}

    .btn-group > .btn, .btn-group-vertical > .btn {
        flex: auto;
        position: relative;
    }

        .btn-group > .btn-check:checked + .btn, .btn-group > .btn-check:focus + .btn, .btn-group > .btn:hover, .btn-group > .btn:focus, .btn-group > .btn:active, .btn-group > .btn.active, .btn-group-vertical > .btn-check:checked + .btn, .btn-group-vertical > .btn-check:focus + .btn, .btn-group-vertical > .btn:hover, .btn-group-vertical > .btn:focus, .btn-group-vertical > .btn:active, .btn-group-vertical > .btn.active {
            z-index: 1;
        }

.btn-toolbar {
    flex-wrap: wrap;
    justify-content: flex-start;
    display: flex;
}

    .btn-toolbar .input-group {
        width: auto;
    }

.btn-group {
    border-radius: var(--bs-border-radius);
}

    .btn-group > :not(.btn-check:first-child) + .btn, .btn-group > .btn-group:not(:first-child) {
        margin-left: calc(var(--bs-border-width) * -1);
    }

    .btn-group > .btn:not(:last-child):not(.dropdown-toggle), .btn-group > .btn.dropdown-toggle-split:first-child, .btn-group > .btn-group:not(:last-child) > .btn {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .btn-group > .btn:nth-child(n+3), .btn-group > :not(.btn-check) + .btn, .btn-group > .btn-group:not(:first-child) > .btn {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

.dropdown-toggle-split {
    padding-left: .5625rem;
    padding-right: .5625rem;
}

    .dropdown-toggle-split:after, .dropup .dropdown-toggle-split:after, .dropend .dropdown-toggle-split:after {
        margin-left: 0;
    }

.dropstart .dropdown-toggle-split:before {
    margin-right: 0;
}

.btn-sm + .dropdown-toggle-split, .btn-group-sm > .btn + .dropdown-toggle-split {
    padding-left: .375rem;
    padding-right: .375rem;
}

.btn-lg + .dropdown-toggle-split, .btn-group-lg > .btn + .dropdown-toggle-split {
    padding-left: .75rem;
    padding-right: .75rem;
}

.btn-group-vertical {
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

    .btn-group-vertical > .btn, .btn-group-vertical > .btn-group {
        width: 100%;
    }

        .btn-group-vertical > .btn:not(:first-child), .btn-group-vertical > .btn-group:not(:first-child) {
            margin-top: calc(var(--bs-border-width) * -1);
        }

        .btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle), .btn-group-vertical > .btn-group:not(:last-child) > .btn {
            border-bottom-right-radius: 0;
            border-bottom-left-radius: 0;
        }

        .btn-group-vertical > .btn ~ .btn, .btn-group-vertical > .btn-group:not(:first-child) > .btn {
            border-top-left-radius: 0;
            border-top-right-radius: 0;
        }

.nav {
    --bs-nav-link-padding-x: 1rem;
    --bs-nav-link-padding-y: .5rem;
    --bs-nav-link-font-weight:;
    --bs-nav-link-color: var(--bs-link-color);
    --bs-nav-link-hover-color: var(--bs-link-hover-color);
    --bs-nav-link-disabled-color: var(--bs-secondary-color);
    flex-wrap: wrap;
    margin-bottom: 0;
    padding-left: 0;
    list-style: none;
    display: flex;
}

.nav-link {
    padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
    font-size: var(--bs-nav-link-font-size);
    font-weight: var(--bs-nav-link-font-weight);
    color: var(--bs-nav-link-color);
    background: none;
    border: 0;
    text-decoration: none;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
    display: block;
}

@media (prefers-reduced-motion: reduce) {
    .nav-link {
        transition: none;
    }
}

.nav-link:hover, .nav-link:focus {
    color: var(--bs-nav-link-hover-color);
}

.nav-link:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 .25rem #0d6efd40;
}

.nav-link.disabled, .nav-link:disabled {
    color: var(--bs-nav-link-disabled-color);
    pointer-events: none;
    cursor: default;
}

.nav-tabs {
    --bs-nav-tabs-border-width: var(--bs-border-width);
    --bs-nav-tabs-border-color: var(--bs-border-color);
    --bs-nav-tabs-border-radius: var(--bs-border-radius);
    --bs-nav-tabs-link-hover-border-color: var(--bs-secondary-bg) var(--bs-secondary-bg) var(--bs-border-color);
    --bs-nav-tabs-link-active-color: var(--bs-emphasis-color);
    --bs-nav-tabs-link-active-bg: var(--bs-body-bg);
    --bs-nav-tabs-link-active-border-color: var(--bs-border-color) var(--bs-border-color) var(--bs-body-bg);
    border-bottom: var(--bs-nav-tabs-border-width) solid var(--bs-nav-tabs-border-color);
}

    .nav-tabs .nav-link {
        margin-bottom: calc(-1 * var(--bs-nav-tabs-border-width));
        border: var(--bs-nav-tabs-border-width) solid transparent;
        border-top-left-radius: var(--bs-nav-tabs-border-radius);
        border-top-right-radius: var(--bs-nav-tabs-border-radius);
    }

        .nav-tabs .nav-link:hover, .nav-tabs .nav-link:focus {
            isolation: isolate;
            border-color: var(--bs-nav-tabs-link-hover-border-color);
        }

        .nav-tabs .nav-link.active, .nav-tabs .nav-item.show .nav-link {
            color: var(--bs-nav-tabs-link-active-color);
            background-color: var(--bs-nav-tabs-link-active-bg);
            border-color: var(--bs-nav-tabs-link-active-border-color);
        }

    .nav-tabs .dropdown-menu {
        margin-top: calc(-1 * var(--bs-nav-tabs-border-width));
        border-top-left-radius: 0;
        border-top-right-radius: 0;
    }

.nav-pills {
    --bs-nav-pills-border-radius: var(--bs-border-radius);
    --bs-nav-pills-link-active-color: #fff;
    --bs-nav-pills-link-active-bg: #0d6efd;
}

    .nav-pills .nav-link {
        border-radius: var(--bs-nav-pills-border-radius);
    }

        .nav-pills .nav-link.active, .nav-pills .show > .nav-link {
            color: var(--bs-nav-pills-link-active-color);
            background-color: var(--bs-nav-pills-link-active-bg);
        }

.nav-underline {
    --bs-nav-underline-gap: 1rem;
    --bs-nav-underline-border-width: .125rem;
    --bs-nav-underline-link-active-color: var(--bs-emphasis-color);
    gap: var(--bs-nav-underline-gap);
}

    .nav-underline .nav-link {
        border-bottom: var(--bs-nav-underline-border-width) solid transparent;
        padding-left: 0;
        padding-right: 0;
    }

        .nav-underline .nav-link:hover, .nav-underline .nav-link:focus {
            border-bottom-color: currentColor;
        }

        .nav-underline .nav-link.active, .nav-underline .show > .nav-link {
            color: var(--bs-nav-underline-link-active-color);
            border-bottom-color: currentColor;
            font-weight: 700;
        }

.nav-fill > .nav-link, .nav-fill .nav-item {
    text-align: center;
    flex: auto;
}

.nav-justified > .nav-link, .nav-justified .nav-item {
    text-align: center;
    flex-grow: 1;
    flex-basis: 0;
}

    .nav-fill .nav-item .nav-link, .nav-justified .nav-item .nav-link {
        width: 100%;
    }

.tab-content > .tab-pane {
    display: none;
}

.tab-content > .active {
    display: block;
}

.navbar {
    --bs-navbar-padding-x: 0;
    --bs-navbar-padding-y: .5rem;
    --bs-navbar-color: rgba(var(--bs-emphasis-color-rgb), .65);
    --bs-navbar-hover-color: rgba(var(--bs-emphasis-color-rgb), .8);
    --bs-navbar-disabled-color: rgba(var(--bs-emphasis-color-rgb), .3);
    --bs-navbar-active-color: rgba(var(--bs-emphasis-color-rgb), 1);
    --bs-navbar-brand-padding-y: .3125rem;
    --bs-navbar-brand-margin-end: 1rem;
    --bs-navbar-brand-font-size: 1.25rem;
    --bs-navbar-brand-color: rgba(var(--bs-emphasis-color-rgb), 1);
    --bs-navbar-brand-hover-color: rgba(var(--bs-emphasis-color-rgb), 1);
    --bs-navbar-nav-link-padding-x: .5rem;
    --bs-navbar-toggler-padding-y: .25rem;
    --bs-navbar-toggler-padding-x: .75rem;
    --bs-navbar-toggler-font-size: 1.25rem;
    --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2833, 37, 41, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
    --bs-navbar-toggler-border-color: rgba(var(--bs-emphasis-color-rgb), .15);
    --bs-navbar-toggler-border-radius: var(--bs-border-radius);
    --bs-navbar-toggler-focus-width: .25rem;
    --bs-navbar-toggler-transition: box-shadow .15s ease-in-out;
    padding: var(--bs-navbar-padding-y) var(--bs-navbar-padding-x);
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    display: flex;
    position: relative;
}

    .navbar > .container, .navbar > .container-fluid, .navbar > .container-sm, .navbar > .container-md, .navbar > .container-lg, .navbar > .container-xl, .navbar > .container-xxl {
        flex-wrap: inherit;
        justify-content: space-between;
        align-items: center;
        display: flex;
    }

.navbar-brand {
    padding-top: var(--bs-navbar-brand-padding-y);
    padding-bottom: var(--bs-navbar-brand-padding-y);
    margin-right: var(--bs-navbar-brand-margin-end);
    font-size: var(--bs-navbar-brand-font-size);
    color: var(--bs-navbar-brand-color);
    white-space: nowrap;
    text-decoration: none;
}

    .navbar-brand:hover, .navbar-brand:focus {
        color: var(--bs-navbar-brand-hover-color);
    }

.navbar-nav {
    --bs-nav-link-padding-x: 0;
    --bs-nav-link-padding-y: .5rem;
    --bs-nav-link-font-weight:;
    --bs-nav-link-color: var(--bs-navbar-color);
    --bs-nav-link-hover-color: var(--bs-navbar-hover-color);
    --bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);
    flex-direction: column;
    margin-bottom: 0;
    padding-left: 0;
    list-style: none;
    display: flex;
}

    .navbar-nav .nav-link.active, .navbar-nav .nav-link.show {
        color: var(--bs-navbar-active-color);
    }

    .navbar-nav .dropdown-menu {
        position: static;
    }

.navbar-text {
    color: var(--bs-navbar-color);
    padding-top: .5rem;
    padding-bottom: .5rem;
}

    .navbar-text a, .navbar-text a:hover, .navbar-text a:focus {
        color: var(--bs-navbar-active-color);
    }

.navbar-collapse {
    flex-grow: 1;
    flex-basis: 100%;
    align-items: center;
}

.navbar-toggler {
    padding: var(--bs-navbar-toggler-padding-y) var(--bs-navbar-toggler-padding-x);
    font-size: var(--bs-navbar-toggler-font-size);
    color: var(--bs-navbar-color);
    border: var(--bs-border-width) solid var(--bs-navbar-toggler-border-color);
    border-radius: var(--bs-navbar-toggler-border-radius);
    transition: var(--bs-navbar-toggler-transition);
    background-color: #0000;
    line-height: 1;
}

@media (prefers-reduced-motion: reduce) {
    .navbar-toggler {
        transition: none;
    }
}

.navbar-toggler:hover {
    text-decoration: none;
}

.navbar-toggler:focus {
    box-shadow: 0 0 0 var(--bs-navbar-toggler-focus-width);
    outline: 0;
    text-decoration: none;
}

.navbar-toggler-icon {
    vertical-align: middle;
    background-image: var(--bs-navbar-toggler-icon-bg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100%;
    width: 1.5em;
    height: 1.5em;
    display: inline-block;
}

.navbar-nav-scroll {
    max-height: var(--bs-scroll-height, 75vh);
    overflow-y: auto;
}

@media (width >= 576px) {
    .navbar-expand-sm {
        flex-wrap: nowrap;
        justify-content: flex-start;
    }

        .navbar-expand-sm .navbar-nav {
            flex-direction: row;
        }

            .navbar-expand-sm .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-sm .navbar-nav .nav-link {
                padding-right: var(--bs-navbar-nav-link-padding-x);
                padding-left: var(--bs-navbar-nav-link-padding-x);
            }

        .navbar-expand-sm .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-sm .navbar-collapse {
            flex-basis: auto;
            display: flex !important;
        }

        .navbar-expand-sm .navbar-toggler {
            display: none;
        }

        .navbar-expand-sm .offcanvas {
            z-index: auto;
            flex-grow: 1;
            transition: none;
            position: static;
            visibility: visible !important;
            background-color: #0000 !important;
            border: 0 !important;
            width: auto !important;
            height: auto !important;
            transform: none !important;
        }

            .navbar-expand-sm .offcanvas .offcanvas-header {
                display: none;.global__widgets.widget-sm
            }

            .navbar-expand-sm .offcanvas .offcanvas-body {
                flex-grow: 0;
                padding: 0;
                display: flex;
                overflow-y: visible;
            }
}

@media (width >= 768px) {
    .navbar-expand-md {
        flex-wrap: nowrap;
        justify-content: flex-start;
    }

        .navbar-expand-md .navbar-nav {
            flex-direction: row;
        }

            .navbar-expand-md .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-md .navbar-nav .nav-link {
                padding-right: var(--bs-navbar-nav-link-padding-x);
                padding-left: var(--bs-navbar-nav-link-padding-x);
            }

        .navbar-expand-md .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-md .navbar-collapse {
            flex-basis: auto;
            display: flex !important;
        }

        .navbar-expand-md .navbar-toggler {
            display: none;
        }

        .navbar-expand-md .offcanvas {
            z-index: auto;
            flex-grow: 1;
            transition: none;
            position: static;
            visibility: visible !important;
            background-color: #0000 !important;
            border: 0 !important;
            width: auto !important;
            height: auto !important;
            transform: none !important;
        }

            .navbar-expand-md .offcanvas .offcanvas-header {
                display: none;
            }

            .navbar-expand-md .offcanvas .offcanvas-body {
                flex-grow: 0;
                padding: 0;
                display: flex;
                overflow-y: visible;
            }
}

@media (width >= 992px) {
    .navbar-expand-lg {
        flex-wrap: nowrap;
        justify-content: flex-start;
    }

        .navbar-expand-lg .navbar-nav {
            flex-direction: row;
        }

            .navbar-expand-lg .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-lg .navbar-nav .nav-link {
                padding-right: var(--bs-navbar-nav-link-padding-x);
                padding-left: var(--bs-navbar-nav-link-padding-x);
            }

        .navbar-expand-lg .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-lg .navbar-collapse {
            flex-basis: auto;
            display: flex !important;
        }

        .navbar-expand-lg .navbar-toggler {
            display: none;
        }

        .navbar-expand-lg .offcanvas {
            z-index: auto;
            flex-grow: 1;
            transition: none;
            position: static;
            visibility: visible !important;
            background-color: #0000 !important;
            border: 0 !important;
            width: auto !important;
            height: auto !important;
            transform: none !important;
        }

            .navbar-expand-lg .offcanvas .offcanvas-header {
                display: none;
            }

            .navbar-expand-lg .offcanvas .offcanvas-body {
                flex-grow: 0;
                padding: 0;
                display: flex;
                overflow-y: visible;
            }
}

@media (width >= 1200px) {
    .navbar-expand-xl {
        flex-wrap: nowrap;
        justify-content: flex-start;
    }

        .navbar-expand-xl .navbar-nav {
            flex-direction: row;
        }

            .navbar-expand-xl .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-xl .navbar-nav .nav-link {
                padding-right: var(--bs-navbar-nav-link-padding-x);
                padding-left: var(--bs-navbar-nav-link-padding-x);
            }

        .navbar-expand-xl .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-xl .navbar-collapse {
            flex-basis: auto;
            display: flex !important;
        }

        .navbar-expand-xl .navbar-toggler {
            display: none;
        }

        .navbar-expand-xl .offcanvas {
            z-index: auto;
            flex-grow: 1;
            transition: none;
            position: static;
            visibility: visible !important;
            background-color: #0000 !important;
            border: 0 !important;
            width: auto !important;
            height: auto !important;
            transform: none !important;
        }

            .navbar-expand-xl .offcanvas .offcanvas-header {
                display: none;
            }

            .navbar-expand-xl .offcanvas .offcanvas-body {
                flex-grow: 0;
                padding: 0;
                display: flex;
                overflow-y: visible;
            }
}

@media (width >= 1400px) {
    .navbar-expand-xxl {
        flex-wrap: nowrap;
        justify-content: flex-start;
    }

        .navbar-expand-xxl .navbar-nav {
            flex-direction: row;
        }

            .navbar-expand-xxl .navbar-nav .dropdown-menu {
                position: absolute;
            }

            .navbar-expand-xxl .navbar-nav .nav-link {
                padding-right: var(--bs-navbar-nav-link-padding-x);
                padding-left: var(--bs-navbar-nav-link-padding-x);
            }

        .navbar-expand-xxl .navbar-nav-scroll {
            overflow: visible;
        }

        .navbar-expand-xxl .navbar-collapse {
            flex-basis: auto;
            display: flex !important;
        }

        .navbar-expand-xxl .navbar-toggler {
            display: none;
        }

        .navbar-expand-xxl .offcanvas {
            z-index: auto;
            flex-grow: 1;
            transition: none;
            position: static;
            visibility: visible !important;
            background-color: #0000 !important;
            border: 0 !important;
            width: auto !important;
            height: auto !important;
            transform: none !important;
        }

            .navbar-expand-xxl .offcanvas .offcanvas-header {
                display: none;
            }

            .navbar-expand-xxl .offcanvas .offcanvas-body {
                flex-grow: 0;
                padding: 0;
                display: flex;
                overflow-y: visible;
            }
}

.navbar-expand {
    flex-wrap: nowrap;
    justify-content: flex-start;
}

    .navbar-expand .navbar-nav {
        flex-direction: row;
    }

        .navbar-expand .navbar-nav .dropdown-menu {
            position: absolute;
        }

        .navbar-expand .navbar-nav .nav-link {
            padding-right: var(--bs-navbar-nav-link-padding-x);
            padding-left: var(--bs-navbar-nav-link-padding-x);
        }

    .navbar-expand .navbar-nav-scroll {
        overflow: visible;
    }

    .navbar-expand .navbar-collapse {
        flex-basis: auto;
        display: flex !important;
    }

    .navbar-expand .navbar-toggler {
        display: none;
    }

    .navbar-expand .offcanvas {
        z-index: auto;
        flex-grow: 1;
        transition: none;
        position: static;
        visibility: visible !important;
        background-color: #0000 !important;
        border: 0 !important;
        width: auto !important;
        height: auto !important;
        transform: none !important;
    }

        .navbar-expand .offcanvas .offcanvas-header {
            display: none;
        }

        .navbar-expand .offcanvas .offcanvas-body {
            flex-grow: 0;
            padding: 0;
            display: flex;
            overflow-y: visible;
        }

.navbar-dark, .navbar[data-bs-theme="dark"] {
    --bs-navbar-color: #ffffff8c;
    --bs-navbar-hover-color: #ffffffbf;
    --bs-navbar-disabled-color: #ffffff40;
    --bs-navbar-active-color: #fff;
    --bs-navbar-brand-color: #fff;
    --bs-navbar-brand-hover-color: #fff;
    --bs-navbar-toggler-border-color: #ffffff1a;
    --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

[data-bs-theme="dark"] .navbar-toggler-icon {
    --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.card {
    --bs-card-spacer-y: 1rem;
    --bs-card-spacer-x: 1rem;
    --bs-card-title-spacer-y: .5rem;
    --bs-card-title-color:;
    --bs-card-subtitle-color:;
    --bs-card-border-width: var(--bs-border-width);
    --bs-card-border-color: var(--bs-border-color-translucent);
    --bs-card-border-radius: var(--bs-border-radius);
    --bs-card-box-shadow:;
    --bs-card-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));
    --bs-card-cap-padding-y: .5rem;
    --bs-card-cap-padding-x: 1rem;
    --bs-card-cap-bg: rgba(var(--bs-body-color-rgb), .03);
    --bs-card-cap-color:;
    --bs-card-height:;
    --bs-card-color:;
    --bs-card-bg: var(--bs-body-bg);
    --bs-card-img-overlay-padding: 1rem;
    --bs-card-group-margin: .75rem;
    min-width: 0;
    height: var(--bs-card-height);
    color: var(--bs-body-color);
    word-wrap: break-word;
    background-color: var(--bs-card-bg);
    border: var(--bs-card-border-width) solid var(--bs-card-border-color);
    border-radius: var(--bs-card-border-radius);
    background-clip: border-box;
    flex-direction: column;
    display: flex;
    position: relative;
}

    .card > hr {
        margin-left: 0;
        margin-right: 0;
    }

    .card > .list-group {
        border-top: inherit;
        border-bottom: inherit;
    }

        .card > .list-group:first-child {
            border-top-left-radius: var(--bs-card-inner-border-radius);
            border-top-right-radius: var(--bs-card-inner-border-radius);
            border-top-width: 0;
        }

        .card > .list-group:last-child {
            border-bottom-right-radius: var(--bs-card-inner-border-radius);
            border-bottom-left-radius: var(--bs-card-inner-border-radius);
            border-bottom-width: 0;
        }

        .card > .card-header + .list-group, .card > .list-group + .card-footer {
            border-top: 0;
        }

.card-body {
    padding: var(--bs-card-spacer-y) var(--bs-card-spacer-x);
    color: var(--bs-card-color);
    flex: auto;
}

.card-title {
    margin-bottom: var(--bs-card-title-spacer-y);
    color: var(--bs-card-title-color);
}

.card-subtitle {
    margin-top: calc(-.5 * var(--bs-card-title-spacer-y));
    color: var(--bs-card-subtitle-color);
    margin-bottom: 0;
}

.card-text:last-child {
    margin-bottom: 0;
}

.card-link + .card-link {
    margin-left: var(--bs-card-spacer-x);
}

.card-header {
    padding: var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);
    color: var(--bs-card-cap-color);
    background-color: var(--bs-card-cap-bg);
    border-bottom: var(--bs-card-border-width) solid var(--bs-card-border-color);
    margin-bottom: 0;
}

    .card-header:first-child {
        border-radius: var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius) 0 0;
    }

.card-footer {
    padding: var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);
    color: var(--bs-card-cap-color);
    background-color: var(--bs-card-cap-bg);
    border-top: var(--bs-card-border-width) solid var(--bs-card-border-color);
}

    .card-footer:last-child {
        border-radius: 0 0 var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius);
    }

.card-header-tabs {
    margin-right: calc(-.5 * var(--bs-card-cap-padding-x));
    margin-bottom: calc(-1 * var(--bs-card-cap-padding-y));
    margin-left: calc(-.5 * var(--bs-card-cap-padding-x));
    border-bottom: 0;
}

    .card-header-tabs .nav-link.active {
        background-color: var(--bs-card-bg);
        border-bottom-color: var(--bs-card-bg);
    }

.card-header-pills {
    margin-right: calc(-.5 * var(--bs-card-cap-padding-x));
    margin-left: calc(-.5 * var(--bs-card-cap-padding-x));
}

.card-img-overlay {
    padding: var(--bs-card-img-overlay-padding);
    border-radius: var(--bs-card-inner-border-radius);
    position: absolute;
    inset: 0;
}

.card-img, .card-img-top, .card-img-bottom {
    width: 100%;
}

.card-img, .card-img-top {
    border-top-left-radius: var(--bs-card-inner-border-radius);
    border-top-right-radius: var(--bs-card-inner-border-radius);
}

.card-img, .card-img-bottom {
    border-bottom-right-radius: var(--bs-card-inner-border-radius);
    border-bottom-left-radius: var(--bs-card-inner-border-radius);
}

.card-group > .card {
    margin-bottom: var(--bs-card-group-margin);
}

@media (width >= 576px) {
    .card-group {
        flex-flow: wrap;
        display: flex;
    }

        .card-group > .card {
            flex: 1 0;
            margin-bottom: 0;
        }

            .card-group > .card + .card {
                border-left: 0;
                margin-left: 0;
            }

            .card-group > .card:not(:last-child) {
                border-top-right-radius: 0;
                border-bottom-right-radius: 0;
            }

                .card-group > .card:not(:last-child) .card-img-top, .card-group > .card:not(:last-child) .card-header {
                    border-top-right-radius: 0;
                }

                .card-group > .card:not(:last-child) .card-img-bottom, .card-group > .card:not(:last-child) .card-footer {
                    border-bottom-right-radius: 0;
                }

            .card-group > .card:not(:first-child) {
                border-top-left-radius: 0;
                border-bottom-left-radius: 0;
            }

                .card-group > .card:not(:first-child) .card-img-top, .card-group > .card:not(:first-child) .card-header {
                    border-top-left-radius: 0;
                }

                .card-group > .card:not(:first-child) .card-img-bottom, .card-group > .card:not(:first-child) .card-footer {
                    border-bottom-left-radius: 0;
                }
}

.accordion {
    --bs-accordion-color: var(--bs-body-color);
    --bs-accordion-bg: var(--bs-body-bg);
    --bs-accordion-transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out, border-radius .15s ease;
    --bs-accordion-border-color: var(--bs-border-color);
    --bs-accordion-border-width: var(--bs-border-width);
    --bs-accordion-border-radius: var(--bs-border-radius);
    --bs-accordion-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));
    --bs-accordion-btn-padding-x: 1.25rem;
    --bs-accordion-btn-padding-y: 1rem;
    --bs-accordion-btn-color: var(--bs-body-color);
    --bs-accordion-btn-bg: var(--bs-accordion-bg);
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23212529' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e");
    --bs-accordion-btn-icon-width: 1.25rem;
    --bs-accordion-btn-icon-transform: rotate(-180deg);
    --bs-accordion-btn-icon-transition: transform .2s ease-in-out;
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23052c65' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e");
    --bs-accordion-btn-focus-box-shadow: 0 0 0 .25rem #0d6efd40;
    --bs-accordion-body-padding-x: 1.25rem;
    --bs-accordion-body-padding-y: 1rem;
    --bs-accordion-active-color: var(--bs-primary-text-emphasis);
    --bs-accordion-active-bg: var(--bs-primary-bg-subtle);
}

.accordion-button {
    width: 100%;
    padding: var(--bs-accordion-btn-padding-y) var(--bs-accordion-btn-padding-x);
    color: var(--bs-accordion-btn-color);
    text-align: left;
    background-color: var(--bs-accordion-btn-bg);
    overflow-anchor: none;
    transition: var(--bs-accordion-transition);
    border: 0;
    border-radius: 0;
    align-items: center;
    font-size: 1rem;
    display: flex;
    position: relative;
}

@media (prefers-reduced-motion: reduce) {
    .accordion-button {
        transition: none;
    }
}

.accordion-button:not(.collapsed) {
    color: var(--bs-accordion-active-color);
    background-color: var(--bs-accordion-active-bg);
    box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color);
}

    .accordion-button:not(.collapsed):after {
        background-image: var(--bs-accordion-btn-active-icon);
        transform: var(--bs-accordion-btn-icon-transform);
    }

.accordion-button:after {
    width: var(--bs-accordion-btn-icon-width);
    height: var(--bs-accordion-btn-icon-width);
    content: "";
    background-image: var(--bs-accordion-btn-icon);
    background-repeat: no-repeat;
    background-size: var(--bs-accordion-btn-icon-width);
    transition: var(--bs-accordion-btn-icon-transition);
    flex-shrink: 0;
    margin-left: auto;
}

@media (prefers-reduced-motion: reduce) {
    .accordion-button:after {
        transition: none;
    }
}

.accordion-button:hover {
    z-index: 2;
}

.accordion-button:focus {
    z-index: 3;
    box-shadow: var(--bs-accordion-btn-focus-box-shadow);
    outline: 0;
}

.accordion-header {
    margin-bottom: 0;
}

.accordion-item {
    color: var(--bs-accordion-color);
    background-color: var(--bs-accordion-bg);
    border: var(--bs-accordion-border-width) solid var(--bs-accordion-border-color);
}

    .accordion-item:first-of-type {
        border-top-left-radius: var(--bs-accordion-border-radius);
        border-top-right-radius: var(--bs-accordion-border-radius);
    }

        .accordion-item:first-of-type > .accordion-header .accordion-button {
            border-top-left-radius: var(--bs-accordion-inner-border-radius);
            border-top-right-radius: var(--bs-accordion-inner-border-radius);
        }

    .accordion-item:not(:first-of-type) {
        border-top: 0;
    }

    .accordion-item:last-of-type {
        border-bottom-right-radius: var(--bs-accordion-border-radius);
        border-bottom-left-radius: var(--bs-accordion-border-radius);
    }

        .accordion-item:last-of-type > .accordion-header .accordion-button.collapsed {
            border-bottom-right-radius: var(--bs-accordion-inner-border-radius);
            border-bottom-left-radius: var(--bs-accordion-inner-border-radius);
        }

        .accordion-item:last-of-type > .accordion-collapse {
            border-bottom-right-radius: var(--bs-accordion-border-radius);
            border-bottom-left-radius: var(--bs-accordion-border-radius);
        }

.accordion-body {
    padding: var(--bs-accordion-body-padding-y) var(--bs-accordion-body-padding-x);
}

.accordion-flush > .accordion-item {
    border-left: 0;
    border-right: 0;
    border-radius: 0;
}

    .accordion-flush > .accordion-item:first-child {
        border-top: 0;
    }

    .accordion-flush > .accordion-item:last-child {
        border-bottom: 0;
    }

    .accordion-flush > .accordion-item > .accordion-header .accordion-button, .accordion-flush > .accordion-item > .accordion-header .accordion-button.collapsed, .accordion-flush > .accordion-item > .accordion-collapse {
        border-radius: 0;
    }

[data-bs-theme="dark"] .accordion-button:after {
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236ea8fe'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236ea8fe'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.breadcrumb {
    --bs-breadcrumb-padding-x: 0;
    --bs-breadcrumb-padding-y: 0;
    --bs-breadcrumb-margin-bottom: 1rem;
    --bs-breadcrumb-bg:;
    --bs-breadcrumb-border-radius:;
    --bs-breadcrumb-divider-color: var(--bs-secondary-color);
    --bs-breadcrumb-item-padding-x: .5rem;
    --bs-breadcrumb-item-active-color: var(--bs-secondary-color);
    padding: var(--bs-breadcrumb-padding-y) var(--bs-breadcrumb-padding-x);
    margin-bottom: var(--bs-breadcrumb-margin-bottom);
    font-size: var(--bs-breadcrumb-font-size);
    background-color: var(--bs-breadcrumb-bg);
    border-radius: var(--bs-breadcrumb-border-radius);
    flex-wrap: wrap;
    list-style: none;
    display: flex;
}

.breadcrumb-item + .breadcrumb-item {
    padding-left: var(--bs-breadcrumb-item-padding-x);
}

    .breadcrumb-item + .breadcrumb-item:before {
        float: left;
        padding-right: var(--bs-breadcrumb-item-padding-x);
        color: var(--bs-breadcrumb-divider-color);
        content: var(--bs-breadcrumb-divider, "/");
    }

.breadcrumb-item.active {
    color: var(--bs-breadcrumb-item-active-color);
}

.pagination {
    --bs-pagination-padding-x: .75rem;
    --bs-pagination-padding-y: .375rem;
    --bs-pagination-font-size: 1rem;
    --bs-pagination-color: var(--bs-link-color);
    --bs-pagination-bg: var(--bs-body-bg);
    --bs-pagination-border-width: var(--bs-border-width);
    --bs-pagination-border-color: var(--bs-border-color);
    --bs-pagination-border-radius: var(--bs-border-radius);
    --bs-pagination-hover-color: var(--bs-link-hover-color);
    --bs-pagination-hover-bg: var(--bs-tertiary-bg);
    --bs-pagination-hover-border-color: var(--bs-border-color);
    --bs-pagination-focus-color: var(--bs-link-hover-color);
    --bs-pagination-focus-bg: var(--bs-secondary-bg);
    --bs-pagination-focus-box-shadow: 0 0 0 .25rem #0d6efd40;
    --bs-pagination-active-color: #fff;
    --bs-pagination-active-bg: #0d6efd;
    --bs-pagination-active-border-color: #0d6efd;
    --bs-pagination-disabled-color: var(--bs-secondary-color);
    --bs-pagination-disabled-bg: var(--bs-secondary-bg);
    --bs-pagination-disabled-border-color: var(--bs-border-color);
    padding-left: 0;
    list-style: none;
    display: flex;
}

.page-link {
    padding: var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);
    font-size: var(--bs-pagination-font-size);
    color: var(--bs-pagination-color);
    background-color: var(--bs-pagination-bg);
    border: var(--bs-pagination-border-width) solid var(--bs-pagination-border-color);
    text-decoration: none;
    transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
    display: block;
    position: relative;
}

@media (prefers-reduced-motion: reduce) {
    .page-link {
        transition: none;
    }
}

.page-link:hover {
    z-index: 2;
    color: var(--bs-pagination-hover-color);
    background-color: var(--bs-pagination-hover-bg);
    border-color: var(--bs-pagination-hover-border-color);
}

.page-link:focus {
    z-index: 3;
    color: var(--bs-pagination-focus-color);
    background-color: var(--bs-pagination-focus-bg);
    box-shadow: var(--bs-pagination-focus-box-shadow);
    outline: 0;
}

.page-link.active, .active > .page-link {
    z-index: 3;
    color: var(--bs-pagination-active-color);
    background-color: var(--bs-pagination-active-bg);
    border-color: var(--bs-pagination-active-border-color);
}

.page-link.disabled, .disabled > .page-link {
    color: var(--bs-pagination-disabled-color);
    pointer-events: none;
    background-color: var(--bs-pagination-disabled-bg);
    border-color: var(--bs-pagination-disabled-border-color);
}

.page-item:not(:first-child) .page-link {
    margin-left: calc(var(--bs-border-width) * -1);
}

.page-item:first-child .page-link {
    border-top-left-radius: var(--bs-pagination-border-radius);
    border-bottom-left-radius: var(--bs-pagination-border-radius);
}

.page-item:last-child .page-link {
    border-top-right-radius: var(--bs-pagination-border-radius);
    border-bottom-right-radius: var(--bs-pagination-border-radius);
}

.pagination-lg {
    --bs-pagination-padding-x: 1.5rem;
    --bs-pagination-padding-y: .75rem;
    --bs-pagination-font-size: 1.25rem;
    --bs-pagination-border-radius: var(--bs-border-radius-lg);
}

.pagination-sm {
    --bs-pagination-padding-x: .5rem;
    --bs-pagination-padding-y: .25rem;
    --bs-pagination-font-size: .875rem;
    --bs-pagination-border-radius: var(--bs-border-radius-sm);
}

.badge {
    --bs-badge-padding-x: .65em;
    --bs-badge-padding-y: .35em;
    --bs-badge-font-size: .75em;
    --bs-badge-font-weight: 700;
    --bs-badge-color: #fff;
    --bs-badge-border-radius: var(--bs-border-radius);
    padding: var(--bs-badge-padding-y) var(--bs-badge-padding-x);
    font-size: var(--bs-badge-font-size);
    font-weight: var(--bs-badge-font-weight);
    color: var(--bs-badge-color);
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: var(--bs-badge-border-radius);
    line-height: 1;
    display: inline-block;
}

    .badge:empty {
        display: none;
    }

.btn .badge {
    position: relative;
    top: -1px;
}

.alert {
    --bs-alert-bg: transparent;
    --bs-alert-padding-x: 1rem;
    --bs-alert-padding-y: 1rem;
    --bs-alert-margin-bottom: 1rem;
    --bs-alert-color: inherit;
    --bs-alert-border-color: transparent;
    --bs-alert-border: var(--bs-border-width) solid var(--bs-alert-border-color);
    --bs-alert-border-radius: var(--bs-border-radius);
    --bs-alert-link-color: inherit;
    padding: var(--bs-alert-padding-y) var(--bs-alert-padding-x);
    margin-bottom: var(--bs-alert-margin-bottom);
    color: var(--bs-alert-color);
    background-color: var(--bs-alert-bg);
    border: var(--bs-alert-border);
    border-radius: var(--bs-alert-border-radius);
    position: relative;
}

.alert-heading {
    color: inherit;
}

.alert-link {
    color: var(--bs-alert-link-color);
    font-weight: 700;
}

.alert-dismissible {
    padding-right: 3rem;
}

    .alert-dismissible .btn-close {
        z-index: 2;
        padding: 1.25rem 1rem;
        position: absolute;
        top: 0;
        right: 0;
    }

.alert-primary {
    --bs-alert-color: var(--bs-primary-text-emphasis);
    --bs-alert-bg: var(--bs-primary-bg-subtle);
    --bs-alert-border-color: var(--bs-primary-border-subtle);
    --bs-alert-link-color: var(--bs-primary-text-emphasis);
}

.alert-secondary {
    --bs-alert-color: var(--bs-secondary-text-emphasis);
    --bs-alert-bg: var(--bs-secondary-bg-subtle);
    --bs-alert-border-color: var(--bs-secondary-border-subtle);
    --bs-alert-link-color: var(--bs-secondary-text-emphasis);
}

.alert-success {
    --bs-alert-color: var(--bs-success-text-emphasis);
    --bs-alert-bg: var(--bs-success-bg-subtle);
    --bs-alert-border-color: var(--bs-success-border-subtle);
    --bs-alert-link-color: var(--bs-success-text-emphasis);
}

.alert-info {
    --bs-alert-color: var(--bs-info-text-emphasis);
    --bs-alert-bg: var(--bs-info-bg-subtle);
    --bs-alert-border-color: var(--bs-info-border-subtle);
    --bs-alert-link-color: var(--bs-info-text-emphasis);
}

.alert-warning {
    --bs-alert-color: var(--bs-warning-text-emphasis);
    --bs-alert-bg: var(--bs-warning-bg-subtle);
    --bs-alert-border-color: var(--bs-warning-border-subtle);
    --bs-alert-link-color: var(--bs-warning-text-emphasis);
}

.alert-danger {
    --bs-alert-color: var(--bs-danger-text-emphasis);
    --bs-alert-bg: var(--bs-danger-bg-subtle);
    --bs-alert-border-color: var(--bs-danger-border-subtle);
    --bs-alert-link-color: var(--bs-danger-text-emphasis);
}

.alert-light {
    --bs-alert-color: var(--bs-light-text-emphasis);
    --bs-alert-bg: var(--bs-light-bg-subtle);
    --bs-alert-border-color: var(--bs-light-border-subtle);
    --bs-alert-link-color: var(--bs-light-text-emphasis);
}

.alert-dark {
    --bs-alert-color: var(--bs-dark-text-emphasis);
    --bs-alert-bg: var(--bs-dark-bg-subtle);
    --bs-alert-border-color: var(--bs-dark-border-subtle);
    --bs-alert-link-color: var(--bs-dark-text-emphasis);
}

@keyframes progress-bar-stripes {
    0% {
        background-position-x: 1rem;
    }
}

.progress, .progress-stacked {
    --bs-progress-height: 1rem;
    --bs-progress-font-size: .75rem;
    --bs-progress-bg: var(--bs-secondary-bg);
    --bs-progress-border-radius: var(--bs-border-radius);
    --bs-progress-box-shadow: var(--bs-box-shadow-inset);
    --bs-progress-bar-color: #fff;
    --bs-progress-bar-bg: #0d6efd;
    --bs-progress-bar-transition: width .6s ease;
    height: var(--bs-progress-height);
    font-size: var(--bs-progress-font-size);
    background-color: var(--bs-progress-bg);
    border-radius: var(--bs-progress-border-radius);
    display: flex;
    overflow: hidden;
}

.progress-bar {
    color: var(--bs-progress-bar-color);
    text-align: center;
    white-space: nowrap;
    background-color: var(--bs-progress-bar-bg);
    transition: var(--bs-progress-bar-transition);
    flex-direction: column;
    justify-content: center;
    display: flex;
    overflow: hidden;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar {
        transition: none;
    }
}

.progress-bar-striped {
    background-image: linear-gradient(45deg, #ffffff26 25%, #0000 25% 50%, #ffffff26 50% 75%, #0000 75%, #0000);
    background-size: var(--bs-progress-height) var(--bs-progress-height);
}

.progress-stacked > .progress {
    overflow: visible;
}

    .progress-stacked > .progress > .progress-bar {
        width: 100%;
    }

.progress-bar-animated {
    animation: 1s linear infinite progress-bar-stripes;
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar-animated {
        animation: none;
    }
}

.list-group {
    --bs-list-group-color: var(--bs-body-color);
    --bs-list-group-bg: var(--bs-body-bg);
    --bs-list-group-border-color: var(--bs-border-color);
    --bs-list-group-border-width: var(--bs-border-width);
    --bs-list-group-border-radius: var(--bs-border-radius);
    --bs-list-group-item-padding-x: 1rem;
    --bs-list-group-item-padding-y: .5rem;
    --bs-list-group-action-color: var(--bs-secondary-color);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-tertiary-bg);
    --bs-list-group-action-active-color: var(--bs-body-color);
    --bs-list-group-action-active-bg: var(--bs-secondary-bg);
    --bs-list-group-disabled-color: var(--bs-secondary-color);
    --bs-list-group-disabled-bg: var(--bs-body-bg);
    --bs-list-group-active-color: #fff;
    --bs-list-group-active-bg: #0d6efd;
    --bs-list-group-active-border-color: #0d6efd;
    border-radius: var(--bs-list-group-border-radius);
    flex-direction: column;
    margin-bottom: 0;
    padding-left: 0;
    display: flex;
}

.list-group-numbered {
    counter-reset: section;
    list-style-type: none;
}

    .list-group-numbered > .list-group-item:before {
        content: counters(section, ".") ". ";
        counter-increment: section;
    }

.list-group-item-action {
    width: 100%;
    color: var(--bs-list-group-action-color);
    text-align: inherit;
}

    .list-group-item-action:hover, .list-group-item-action:focus {
        z-index: 1;
        color: var(--bs-list-group-action-hover-color);
        background-color: var(--bs-list-group-action-hover-bg);
        text-decoration: none;
    }

    .list-group-item-action:active {
        color: var(--bs-list-group-action-active-color);
        background-color: var(--bs-list-group-action-active-bg);
    }

.list-group-item {
    padding: var(--bs-list-group-item-padding-y) var(--bs-list-group-item-padding-x);
    color: var(--bs-list-group-color);
    background-color: var(--bs-list-group-bg);
    border: var(--bs-list-group-border-width) solid var(--bs-list-group-border-color);
    text-decoration: none;
    display: block;
    position: relative;
}

    .list-group-item:first-child {
        border-top-left-radius: inherit;
        border-top-right-radius: inherit;
    }

    .list-group-item:last-child {
        border-bottom-right-radius: inherit;
        border-bottom-left-radius: inherit;
    }

    .list-group-item.disabled, .list-group-item:disabled {
        color: var(--bs-list-group-disabled-color);
        pointer-events: none;
        background-color: var(--bs-list-group-disabled-bg);
    }

    .list-group-item.active {
        z-index: 2;
        color: var(--bs-list-group-active-color);
        background-color: var(--bs-list-group-active-bg);
        border-color: var(--bs-list-group-active-border-color);
    }

    .list-group-item + .list-group-item {
        border-top-width: 0;
    }

        .list-group-item + .list-group-item.active {
            margin-top: calc(-1 * var(--bs-list-group-border-width));
            border-top-width: var(--bs-list-group-border-width);
        }

.list-group-horizontal {
    flex-direction: row;
}

    .list-group-horizontal > .list-group-item:first-child:not(:last-child) {
        border-bottom-left-radius: var(--bs-list-group-border-radius);
        border-top-right-radius: 0;
    }

    .list-group-horizontal > .list-group-item:last-child:not(:first-child) {
        border-top-right-radius: var(--bs-list-group-border-radius);
        border-bottom-left-radius: 0;
    }

    .list-group-horizontal > .list-group-item.active {
        margin-top: 0;
    }

    .list-group-horizontal > .list-group-item + .list-group-item {
        border-top-width: var(--bs-list-group-border-width);
        border-left-width: 0;
    }

        .list-group-horizontal > .list-group-item + .list-group-item.active {
            margin-left: calc(-1 * var(--bs-list-group-border-width));
            border-left-width: var(--bs-list-group-border-width);
        }

@media (width >= 576px) {
    .list-group-horizontal-sm {
        flex-direction: row;
    }

        .list-group-horizontal-sm > .list-group-item:first-child:not(:last-child) {
            border-bottom-left-radius: var(--bs-list-group-border-radius);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-sm > .list-group-item:last-child:not(:first-child) {
            border-top-right-radius: var(--bs-list-group-border-radius);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-sm > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-sm > .list-group-item + .list-group-item {
            border-top-width: var(--bs-list-group-border-width);
            border-left-width: 0;
        }

            .list-group-horizontal-sm > .list-group-item + .list-group-item.active {
                margin-left: calc(-1 * var(--bs-list-group-border-width));
                border-left-width: var(--bs-list-group-border-width);
            }
}

@media (width >= 768px) {
    .list-group-horizontal-md {
        flex-direction: row;
    }

        .list-group-horizontal-md > .list-group-item:first-child:not(:last-child) {
            border-bottom-left-radius: var(--bs-list-group-border-radius);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-md > .list-group-item:last-child:not(:first-child) {
            border-top-right-radius: var(--bs-list-group-border-radius);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-md > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-md > .list-group-item + .list-group-item {
            border-top-width: var(--bs-list-group-border-width);
            border-left-width: 0;
        }

            .list-group-horizontal-md > .list-group-item + .list-group-item.active {
                margin-left: calc(-1 * var(--bs-list-group-border-width));
                border-left-width: var(--bs-list-group-border-width);
            }
}

@media (width >= 992px) {
    .list-group-horizontal-lg {
        flex-direction: row;
    }

        .list-group-horizontal-lg > .list-group-item:first-child:not(:last-child) {
            border-bottom-left-radius: var(--bs-list-group-border-radius);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-lg > .list-group-item:last-child:not(:first-child) {
            border-top-right-radius: var(--bs-list-group-border-radius);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-lg > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-lg > .list-group-item + .list-group-item {
            border-top-width: var(--bs-list-group-border-width);
            border-left-width: 0;
        }

            .list-group-horizontal-lg > .list-group-item + .list-group-item.active {
                margin-left: calc(-1 * var(--bs-list-group-border-width));
                border-left-width: var(--bs-list-group-border-width);
            }
}

@media (width >= 1200px) {
    .list-group-horizontal-xl {
        flex-direction: row;
    }

        .list-group-horizontal-xl > .list-group-item:first-child:not(:last-child) {
            border-bottom-left-radius: var(--bs-list-group-border-radius);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-xl > .list-group-item:last-child:not(:first-child) {
            border-top-right-radius: var(--bs-list-group-border-radius);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-xl > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-xl > .list-group-item + .list-group-item {
            border-top-width: var(--bs-list-group-border-width);
            border-left-width: 0;
        }

            .list-group-horizontal-xl > .list-group-item + .list-group-item.active {
                margin-left: calc(-1 * var(--bs-list-group-border-width));
                border-left-width: var(--bs-list-group-border-width);
            }
}

@media (width >= 1400px) {
    .list-group-horizontal-xxl {
        flex-direction: row;
    }

        .list-group-horizontal-xxl > .list-group-item:first-child:not(:last-child) {
            border-bottom-left-radius: var(--bs-list-group-border-radius);
            border-top-right-radius: 0;
        }

        .list-group-horizontal-xxl > .list-group-item:last-child:not(:first-child) {
            border-top-right-radius: var(--bs-list-group-border-radius);
            border-bottom-left-radius: 0;
        }

        .list-group-horizontal-xxl > .list-group-item.active {
            margin-top: 0;
        }

        .list-group-horizontal-xxl > .list-group-item + .list-group-item {
            border-top-width: var(--bs-list-group-border-width);
            border-left-width: 0;
        }

            .list-group-horizontal-xxl > .list-group-item + .list-group-item.active {
                margin-left: calc(-1 * var(--bs-list-group-border-width));
                border-left-width: var(--bs-list-group-border-width);
            }
}

.list-group-flush {
    border-radius: 0;
}

    .list-group-flush > .list-group-item {
        border-width: 0 0 var(--bs-list-group-border-width);
    }

        .list-group-flush > .list-group-item:last-child {
            border-bottom-width: 0;
        }

.list-group-item-primary {
    --bs-list-group-color: var(--bs-primary-text-emphasis);
    --bs-list-group-bg: var(--bs-primary-bg-subtle);
    --bs-list-group-border-color: var(--bs-primary-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-primary-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-primary-border-subtle);
    --bs-list-group-active-color: var(--bs-primary-bg-subtle);
    --bs-list-group-active-bg: var(--bs-primary-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-primary-text-emphasis);
}

.list-group-item-secondary {
    --bs-list-group-color: var(--bs-secondary-text-emphasis);
    --bs-list-group-bg: var(--bs-secondary-bg-subtle);
    --bs-list-group-border-color: var(--bs-secondary-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-secondary-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-secondary-border-subtle);
    --bs-list-group-active-color: var(--bs-secondary-bg-subtle);
    --bs-list-group-active-bg: var(--bs-secondary-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-secondary-text-emphasis);
}

.list-group-item-success {
    --bs-list-group-color: var(--bs-success-text-emphasis);
    --bs-list-group-bg: var(--bs-success-bg-subtle);
    --bs-list-group-border-color: var(--bs-success-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-success-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-success-border-subtle);
    --bs-list-group-active-color: var(--bs-success-bg-subtle);
    --bs-list-group-active-bg: var(--bs-success-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-success-text-emphasis);
}

.list-group-item-info {
    --bs-list-group-color: var(--bs-info-text-emphasis);
    --bs-list-group-bg: var(--bs-info-bg-subtle);
    --bs-list-group-border-color: var(--bs-info-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-info-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-info-border-subtle);
    --bs-list-group-active-color: var(--bs-info-bg-subtle);
    --bs-list-group-active-bg: var(--bs-info-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-info-text-emphasis);
}

.list-group-item-warning {
    --bs-list-group-color: var(--bs-warning-text-emphasis);
    --bs-list-group-bg: var(--bs-warning-bg-subtle);
    --bs-list-group-border-color: var(--bs-warning-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-warning-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-warning-border-subtle);
    --bs-list-group-active-color: var(--bs-warning-bg-subtle);
    --bs-list-group-active-bg: var(--bs-warning-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-warning-text-emphasis);
}

.list-group-item-danger {
    --bs-list-group-color: var(--bs-danger-text-emphasis);
    --bs-list-group-bg: var(--bs-danger-bg-subtle);
    --bs-list-group-border-color: var(--bs-danger-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-danger-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-danger-border-subtle);
    --bs-list-group-active-color: var(--bs-danger-bg-subtle);
    --bs-list-group-active-bg: var(--bs-danger-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-danger-text-emphasis);
}

.list-group-item-light {
    --bs-list-group-color: var(--bs-light-text-emphasis);
    --bs-list-group-bg: var(--bs-light-bg-subtle);
    --bs-list-group-border-color: var(--bs-light-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-light-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-light-border-subtle);
    --bs-list-group-active-color: var(--bs-light-bg-subtle);
    --bs-list-group-active-bg: var(--bs-light-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-light-text-emphasis);
}

.list-group-item-dark {
    --bs-list-group-color: var(--bs-dark-text-emphasis);
    --bs-list-group-bg: var(--bs-dark-bg-subtle);
    --bs-list-group-border-color: var(--bs-dark-border-subtle);
    --bs-list-group-action-hover-color: var(--bs-emphasis-color);
    --bs-list-group-action-hover-bg: var(--bs-dark-border-subtle);
    --bs-list-group-action-active-color: var(--bs-emphasis-color);
    --bs-list-group-action-active-bg: var(--bs-dark-border-subtle);
    --bs-list-group-active-color: var(--bs-dark-bg-subtle);
    --bs-list-group-active-bg: var(--bs-dark-text-emphasis);
    --bs-list-group-active-border-color: var(--bs-dark-text-emphasis);
}

.btn-close {
    --bs-btn-close-color: #000;
    --bs-btn-close-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e");
    --bs-btn-close-opacity: .5;
    --bs-btn-close-hover-opacity: .75;
    --bs-btn-close-focus-shadow: 0 0 0 .25rem #0d6efd40;
    --bs-btn-close-focus-opacity: 1;
    --bs-btn-close-disabled-opacity: .25;
    --bs-btn-close-white-filter: invert(1) grayscale(100%) brightness(200%);
    box-sizing: content-box;
    width: 1em;
    height: 1em;
    color: var(--bs-btn-close-color);
    background: transparent var(--bs-btn-close-bg) center / 1em auto no-repeat;
    opacity: var(--bs-btn-close-opacity);
    border: 0;
    border-radius: .375rem;
    padding: .25em;
}

    .btn-close:hover {
        color: var(--bs-btn-close-color);
        opacity: var(--bs-btn-close-hover-opacity);
        text-decoration: none;
    }

    .btn-close:focus {
        box-shadow: var(--bs-btn-close-focus-shadow);
        opacity: var(--bs-btn-close-focus-opacity);
        outline: 0;
    }

    .btn-close:disabled, .btn-close.disabled {
        pointer-events: none;
        user-select: none;
        opacity: var(--bs-btn-close-disabled-opacity);
    }

.btn-close-white, [data-bs-theme="dark"] .btn-close {
    filter: var(--bs-btn-close-white-filter);
}

.toast {
    --bs-toast-zindex: 1090;
    --bs-toast-padding-x: .75rem;
    --bs-toast-padding-y: .5rem;
    --bs-toast-spacing: 1.5rem;
    --bs-toast-max-width: 350px;
    --bs-toast-font-size: .875rem;
    --bs-toast-color:;
    --bs-toast-bg: rgba(var(--bs-body-bg-rgb), .85);
    --bs-toast-border-width: var(--bs-border-width);
    --bs-toast-border-color: var(--bs-border-color-translucent);
    --bs-toast-border-radius: var(--bs-border-radius);
    --bs-toast-box-shadow: var(--bs-box-shadow);
    --bs-toast-header-color: var(--bs-secondary-color);
    --bs-toast-header-bg: rgba(var(--bs-body-bg-rgb), .85);
    --bs-toast-header-border-color: var(--bs-border-color-translucent);
    width: var(--bs-toast-max-width);
    max-width: 100%;
    font-size: var(--bs-toast-font-size);
    color: var(--bs-toast-color);
    pointer-events: auto;
    background-color: var(--bs-toast-bg);
    border: var(--bs-toast-border-width) solid var(--bs-toast-border-color);
    box-shadow: var(--bs-toast-box-shadow);
    border-radius: var(--bs-toast-border-radius);
    background-clip: padding-box;
}

    .toast.showing {
        opacity: 0;
    }

    .toast:not(.show) {
        display: none;
    }

.toast-container {
    --bs-toast-zindex: 1090;
    z-index: var(--bs-toast-zindex);
    pointer-events: none;
    width: max-content;
    max-width: 100%;
    position: absolute;
}

    .toast-container > :not(:last-child) {
        margin-bottom: var(--bs-toast-spacing);
    }

.toast-header {
    padding: var(--bs-toast-padding-y) var(--bs-toast-padding-x);
    color: var(--bs-toast-header-color);
    background-color: var(--bs-toast-header-bg);
    border-bottom: var(--bs-toast-border-width) solid var(--bs-toast-header-border-color);
    border-top-left-radius: calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width));
    border-top-right-radius: calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width));
    background-clip: padding-box;
    align-items: center;
    display: flex;
}

    .toast-header .btn-close {
        margin-right: calc(-.5 * var(--bs-toast-padding-x));
        margin-left: var(--bs-toast-padding-x);
    }

.toast-body {
    padding: var(--bs-toast-padding-x);
    word-wrap: break-word;
}

.modal {
    --bs-modal-zindex: 1055;
    --bs-modal-width: 500px;
    --bs-modal-padding: 1rem;
    --bs-modal-margin: .5rem;
    --bs-modal-color:;
    --bs-modal-bg: var(--bs-body-bg);
    --bs-modal-border-color: var(--bs-border-color-translucent);
    --bs-modal-border-width: var(--bs-border-width);
    --bs-modal-border-radius: var(--bs-border-radius-lg);
    --bs-modal-box-shadow: var(--bs-box-shadow-sm);
    --bs-modal-inner-border-radius: calc(var(--bs-border-radius-lg) - (var(--bs-border-width)));
    --bs-modal-header-padding-x: 1rem;
    --bs-modal-header-padding-y: 1rem;
    --bs-modal-header-padding: 1rem 1rem;
    --bs-modal-header-border-color: var(--bs-border-color);
    --bs-modal-header-border-width: var(--bs-border-width);
    --bs-modal-title-line-height: 1.5;
    --bs-modal-footer-gap: .5rem;
    --bs-modal-footer-bg:;
    --bs-modal-footer-border-color: var(--bs-border-color);
    --bs-modal-footer-border-width: var(--bs-border-width);
    z-index: var(--bs-modal-zindex);
    outline: 0;
    width: 100%;
    height: 100%;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    overflow: hidden auto;
}

.modal-dialog {
    width: auto;
    margin: var(--bs-modal-margin);
    pointer-events: none;
    position: relative;
}

.modal.fade .modal-dialog {
    transition: transform .3s ease-out;
    transform: translate(0, -50px);
}

@media (prefers-reduced-motion: reduce) {
    .modal.fade .modal-dialog {
        transition: none;
    }
}

.modal.show .modal-dialog {
    transform: none;
}

.modal.modal-static .modal-dialog {
    transform: scale(1.02);
}

.modal-dialog-scrollable {
    height: calc(100% - var(--bs-modal-margin) * 2);
}

    .modal-dialog-scrollable .modal-content {
        max-height: 100%;
        overflow: hidden;
    }

    .modal-dialog-scrollable .modal-body {
        overflow-y: auto;
    }

.modal-dialog-centered {
    min-height: calc(100% - var(--bs-modal-margin) * 2);
    align-items: center;
    display: flex;
}

.modal-content {
    width: 100%;
    color: var(--bs-modal-color);
    pointer-events: auto;
    background-color: var(--bs-modal-bg);
    border: var(--bs-modal-border-width) solid var(--bs-modal-border-color);
    border-radius: var(--bs-modal-border-radius);
    background-clip: padding-box;
    outline: 0;
    flex-direction: column;
    display: flex;
    position: relative;
}

.modal-backdrop {
    --bs-backdrop-zindex: 1050;
    --bs-backdrop-bg: #000;
    --bs-backdrop-opacity: .5;
    z-index: var(--bs-backdrop-zindex);
    background-color: var(--bs-backdrop-bg);
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
}

    .modal-backdrop.fade {
        opacity: 0;
    }

    .modal-backdrop.show {
        opacity: var(--bs-backdrop-opacity);
    }

.modal-header {
    padding: var(--bs-modal-header-padding);
    border-bottom: var(--bs-modal-header-border-width) solid var(--bs-modal-header-border-color);
    border-top-left-radius: var(--bs-modal-inner-border-radius);
    border-top-right-radius: var(--bs-modal-inner-border-radius);
    flex-shrink: 0;
    align-items: center;
    display: flex;
}

    .modal-header .btn-close {
        padding: calc(var(--bs-modal-header-padding-y) * .5) calc(var(--bs-modal-header-padding-x) * .5);
        margin: calc(-.5 * var(--bs-modal-header-padding-y)) calc(-.5 * var(--bs-modal-header-padding-x)) calc(-.5 * var(--bs-modal-header-padding-y)) auto;
    }

.modal-title {
    line-height: var(--bs-modal-title-line-height);
    margin-bottom: 0;
}

.modal-body {
    padding: var(--bs-modal-padding);
    flex: auto;
    position: relative;
}

.modal-footer {
    padding: calc(var(--bs-modal-padding) - var(--bs-modal-footer-gap) * .5);
    background-color: var(--bs-modal-footer-bg);
    border-top: var(--bs-modal-footer-border-width) solid var(--bs-modal-footer-border-color);
    border-bottom-right-radius: var(--bs-modal-inner-border-radius);
    border-bottom-left-radius: var(--bs-modal-inner-border-radius);
    flex-wrap: wrap;
    flex-shrink: 0;
    justify-content: flex-end;
    align-items: center;
    display: flex;
}

    .modal-footer > * {
        margin: calc(var(--bs-modal-footer-gap) * .5);
    }

@media (width >= 576px) {
    .modal {
        --bs-modal-margin: 1.75rem;
        --bs-modal-box-shadow: var(--bs-box-shadow);
    }

    .modal-dialog {
        max-width: var(--bs-modal-width);
        margin-left: auto;
        margin-right: auto;
    }

    .modal-sm {
        --bs-modal-width: 300px;
    }
}

@media (width >= 992px) {
    .modal-lg, .modal-xl {
        --bs-modal-width: 800px;
    }
}

@media (width >= 1200px) {
    .modal-xl {
        --bs-modal-width: 1140px;
    }
}

.modal-fullscreen {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
}

    .modal-fullscreen .modal-content {
        border: 0;
        border-radius: 0;
        height: 100%;
    }

    .modal-fullscreen .modal-header, .modal-fullscreen .modal-footer {
        border-radius: 0;
    }

    .modal-fullscreen .modal-body {
        overflow-y: auto;
    }

@media (width <= 575.98px) {
    .modal-fullscreen-sm-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0;
    }

        .modal-fullscreen-sm-down .modal-content {
            border: 0;
            border-radius: 0;
            height: 100%;
        }

        .modal-fullscreen-sm-down .modal-header, .modal-fullscreen-sm-down .modal-footer {
            border-radius: 0;
        }

        .modal-fullscreen-sm-down .modal-body {
            overflow-y: auto;
        }
}

@media (width <= 767.98px) {
    .modal-fullscreen-md-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0;
    }

        .modal-fullscreen-md-down .modal-content {
            border: 0;
            border-radius: 0;
            height: 100%;
        }

        .modal-fullscreen-md-down .modal-header, .modal-fullscreen-md-down .modal-footer {
            border-radius: 0;
        }

        .modal-fullscreen-md-down .modal-body {
            overflow-y: auto;
        }
}

@media (width <= 991.98px) {
    .modal-fullscreen-lg-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0;
    }

        .modal-fullscreen-lg-down .modal-content {
            border: 0;
            border-radius: 0;
            height: 100%;
        }

        .modal-fullscreen-lg-down .modal-header, .modal-fullscreen-lg-down .modal-footer {
            border-radius: 0;
        }

        .modal-fullscreen-lg-down .modal-body {
            overflow-y: auto;
        }
}

@media (width <= 1199.98px) {
    .modal-fullscreen-xl-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0;
    }

        .modal-fullscreen-xl-down .modal-content {
            border: 0;
            border-radius: 0;
            height: 100%;
        }

        .modal-fullscreen-xl-down .modal-header, .modal-fullscreen-xl-down .modal-footer {
            border-radius: 0;
        }

        .modal-fullscreen-xl-down .modal-body {
            overflow-y: auto;
        }
}

@media (width <= 1399.98px) {
    .modal-fullscreen-xxl-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0;
    }

        .modal-fullscreen-xxl-down .modal-content {
            border: 0;
            border-radius: 0;
            height: 100%;
        }

        .modal-fullscreen-xxl-down .modal-header, .modal-fullscreen-xxl-down .modal-footer {
            border-radius: 0;
        }

        .modal-fullscreen-xxl-down .modal-body {
            overflow-y: auto;
        }
}

.tooltip {
    --bs-tooltip-zindex: 1080;
    --bs-tooltip-max-width: 200px;
    --bs-tooltip-padding-x: .5rem;
    --bs-tooltip-padding-y: .25rem;
    --bs-tooltip-margin:;
    --bs-tooltip-font-size: .875rem;
    --bs-tooltip-color: var(--bs-body-bg);
    --bs-tooltip-bg: var(--bs-emphasis-color);
    --bs-tooltip-border-radius: var(--bs-border-radius);
    --bs-tooltip-opacity: .9;
    --bs-tooltip-arrow-width: .8rem;
    --bs-tooltip-arrow-height: .4rem;
    z-index: var(--bs-tooltip-zindex);
    margin: var(--bs-tooltip-margin);
    font-family: var(--bs-font-sans-serif);
    text-align: left;
    text-align: start;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    white-space: normal;
    word-spacing: normal;
    line-break: auto;
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    font-size: var(--bs-tooltip-font-size);
    word-wrap: break-word;
    opacity: 0;
    text-decoration: none;
    display: block;
}

    .tooltip.show {
        opacity: var(--bs-tooltip-opacity);
    }

    .tooltip .tooltip-arrow {
        width: var(--bs-tooltip-arrow-width);
        height: var(--bs-tooltip-arrow-height);
        display: block;
    }

        .tooltip .tooltip-arrow:before {
            content: "";
            border-style: solid;
            border-color: #0000;
            position: absolute;
        }

.bs-tooltip-top .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow {
    bottom: calc(-1 * var(--bs-tooltip-arrow-height));
}

    .bs-tooltip-top .tooltip-arrow:before, .bs-tooltip-auto[data-popper-placement^="top"] .tooltip-arrow:before {
        border-width: var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;
        border-top-color: var(--bs-tooltip-bg);
        top: -1px;
    }

.bs-tooltip-end .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow {
    left: calc(-1 * var(--bs-tooltip-arrow-height));
    width: var(--bs-tooltip-arrow-height);
    height: var(--bs-tooltip-arrow-width);
}

    .bs-tooltip-end .tooltip-arrow:before, .bs-tooltip-auto[data-popper-placement^="right"] .tooltip-arrow:before {
        border-width: calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;
        border-right-color: var(--bs-tooltip-bg);
        right: -1px;
    }

.bs-tooltip-bottom .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow {
    top: calc(-1 * var(--bs-tooltip-arrow-height));
}

    .bs-tooltip-bottom .tooltip-arrow:before, .bs-tooltip-auto[data-popper-placement^="bottom"] .tooltip-arrow:before {
        border-width: 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);
        border-bottom-color: var(--bs-tooltip-bg);
        bottom: -1px;
    }

.bs-tooltip-start .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow {
    right: calc(-1 * var(--bs-tooltip-arrow-height));
    width: var(--bs-tooltip-arrow-height);
    height: var(--bs-tooltip-arrow-width);
}

    .bs-tooltip-start .tooltip-arrow:before, .bs-tooltip-auto[data-popper-placement^="left"] .tooltip-arrow:before {
        border-width: calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);
        border-left-color: var(--bs-tooltip-bg);
        left: -1px;
    }

.tooltip-inner {
    max-width: var(--bs-tooltip-max-width);
    padding: var(--bs-tooltip-padding-y) var(--bs-tooltip-padding-x);
    color: var(--bs-tooltip-color);
    text-align: center;
    background-color: var(--bs-tooltip-bg);
    border-radius: var(--bs-tooltip-border-radius);
}

.popover {
    --bs-popover-zindex: 1070;
    --bs-popover-max-width: 276px;
    --bs-popover-font-size: .875rem;
    --bs-popover-bg: var(--bs-body-bg);
    --bs-popover-border-width: var(--bs-border-width);
    --bs-popover-border-color: var(--bs-border-color-translucent);
    --bs-popover-border-radius: var(--bs-border-radius-lg);
    --bs-popover-inner-border-radius: calc(var(--bs-border-radius-lg) - var(--bs-border-width));
    --bs-popover-box-shadow: var(--bs-box-shadow);
    --bs-popover-header-padding-x: 1rem;
    --bs-popover-header-padding-y: .5rem;
    --bs-popover-header-font-size: 1rem;
    --bs-popover-header-color: inherit;
    --bs-popover-header-bg: var(--bs-secondary-bg);
    --bs-popover-body-padding-x: 1rem;
    --bs-popover-body-padding-y: 1rem;
    --bs-popover-body-color: var(--bs-body-color);
    --bs-popover-arrow-width: 1rem;
    --bs-popover-arrow-height: .5rem;
    --bs-popover-arrow-border: var(--bs-popover-border-color);
    z-index: var(--bs-popover-zindex);
    max-width: var(--bs-popover-max-width);
    font-family: var(--bs-font-sans-serif);
    text-align: left;
    text-align: start;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    white-space: normal;
    word-spacing: normal;
    line-break: auto;
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    font-size: var(--bs-popover-font-size);
    word-wrap: break-word;
    background-color: var(--bs-popover-bg);
    border: var(--bs-popover-border-width) solid var(--bs-popover-border-color);
    border-radius: var(--bs-popover-border-radius);
    background-clip: padding-box;
    text-decoration: none;
    display: block;
}

    .popover .popover-arrow {
        width: var(--bs-popover-arrow-width);
        height: var(--bs-popover-arrow-height);
        display: block;
    }

        .popover .popover-arrow:before, .popover .popover-arrow:after {
            content: "";
            border: 0 solid #0000;
            display: block;
            position: absolute;
        }

.bs-popover-top > .popover-arrow, .bs-popover-auto[data-popper-placement^="top"] > .popover-arrow {
    bottom: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
}

    .bs-popover-top > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="top"] > .popover-arrow:before, .bs-popover-top > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="top"] > .popover-arrow:after {
        border-width: var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * .5) 0;
    }

    .bs-popover-top > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="top"] > .popover-arrow:before {
        border-top-color: var(--bs-popover-arrow-border);
        bottom: 0;
    }

    .bs-popover-top > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="top"] > .popover-arrow:after {
        bottom: var(--bs-popover-border-width);
        border-top-color: var(--bs-popover-bg);
    }

.bs-popover-end > .popover-arrow, .bs-popover-auto[data-popper-placement^="right"] > .popover-arrow {
    left: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
    width: var(--bs-popover-arrow-height);
    height: var(--bs-popover-arrow-width);
}

    .bs-popover-end > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="right"] > .popover-arrow:before, .bs-popover-end > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="right"] > .popover-arrow:after {
        border-width: calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * .5) 0;
    }

    .bs-popover-end > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="right"] > .popover-arrow:before {
        border-right-color: var(--bs-popover-arrow-border);
        left: 0;
    }

    .bs-popover-end > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="right"] > .popover-arrow:after {
        left: var(--bs-popover-border-width);
        border-right-color: var(--bs-popover-bg);
    }

.bs-popover-bottom > .popover-arrow, .bs-popover-auto[data-popper-placement^="bottom"] > .popover-arrow {
    top: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
}

    .bs-popover-bottom > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="bottom"] > .popover-arrow:before, .bs-popover-bottom > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="bottom"] > .popover-arrow:after {
        border-width: 0 calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height);
    }

    .bs-popover-bottom > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="bottom"] > .popover-arrow:before {
        border-bottom-color: var(--bs-popover-arrow-border);
        top: 0;
    }

    .bs-popover-bottom > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="bottom"] > .popover-arrow:after {
        top: var(--bs-popover-border-width);
        border-bottom-color: var(--bs-popover-bg);
    }

.bs-popover-bottom .popover-header:before, .bs-popover-auto[data-popper-placement^="bottom"] .popover-header:before {
    width: var(--bs-popover-arrow-width);
    margin-left: calc(-.5 * var(--bs-popover-arrow-width));
    content: "";
    border-bottom: var(--bs-popover-border-width) solid var(--bs-popover-header-bg);
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
}

.bs-popover-start > .popover-arrow, .bs-popover-auto[data-popper-placement^="left"] > .popover-arrow {
    right: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
    width: var(--bs-popover-arrow-height);
    height: var(--bs-popover-arrow-width);
}

    .bs-popover-start > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="left"] > .popover-arrow:before, .bs-popover-start > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="left"] > .popover-arrow:after {
        border-width: calc(var(--bs-popover-arrow-width) * .5) 0 calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height);
    }

    .bs-popover-start > .popover-arrow:before, .bs-popover-auto[data-popper-placement^="left"] > .popover-arrow:before {
        border-left-color: var(--bs-popover-arrow-border);
        right: 0;
    }

    .bs-popover-start > .popover-arrow:after, .bs-popover-auto[data-popper-placement^="left"] > .popover-arrow:after {
        right: var(--bs-popover-border-width);
        border-left-color: var(--bs-popover-bg);
    }

.popover-header {
    padding: var(--bs-popover-header-padding-y) var(--bs-popover-header-padding-x);
    font-size: var(--bs-popover-header-font-size);
    color: var(--bs-popover-header-color);
    background-color: var(--bs-popover-header-bg);
    border-bottom: var(--bs-popover-border-width) solid var(--bs-popover-border-color);
    border-top-left-radius: var(--bs-popover-inner-border-radius);
    border-top-right-radius: var(--bs-popover-inner-border-radius);
    margin-bottom: 0;
}

    .popover-header:empty {
        display: none;
    }

.popover-body {
    padding: var(--bs-popover-body-padding-y) var(--bs-popover-body-padding-x);
    color: var(--bs-popover-body-color);
}

.carousel {
    position: relative;
}

    .carousel.pointer-event {
        touch-action: pan-y;
    }

.carousel-inner {
    width: 100%;
    position: relative;
    overflow: hidden;
}

    .carousel-inner:after {
        clear: both;
        content: "";
        display: block;
    }

.carousel-item {
    float: left;
    backface-visibility: hidden;
    width: 100%;
    margin-right: -100%;
    transition: transform .6s ease-in-out;
    display: none;
    position: relative;
}

@media (prefers-reduced-motion: reduce) {
    .carousel-item {
        transition: none;
    }
}

.carousel-item.active, .carousel-item-next, .carousel-item-prev {
    display: block;
}

    .carousel-item-next:not(.carousel-item-start), .active.carousel-item-end {
        transform: translateX(100%);
    }

    .carousel-item-prev:not(.carousel-item-end), .active.carousel-item-start {
        transform: translateX(-100%);
    }

.carousel-fade .carousel-item {
    opacity: 0;
    transition-property: opacity;
    transform: none;
}

    .carousel-fade .carousel-item.active, .carousel-fade .carousel-item-next.carousel-item-start, .carousel-fade .carousel-item-prev.carousel-item-end {
        z-index: 1;
        opacity: 1;
    }

.carousel-fade .active.carousel-item-start, .carousel-fade .active.carousel-item-end {
    z-index: 0;
    opacity: 0;
    transition: opacity 0s .6s;
}

@media (prefers-reduced-motion: reduce) {
    .carousel-fade .active.carousel-item-start, .carousel-fade .active.carousel-item-end {
        transition: none;
    }
}

.carousel-control-prev, .carousel-control-next {
    z-index: 1;
    color: #fff;
    text-align: center;
    opacity: .5;
    background: none;
    border: 0;
    justify-content: center;
    align-items: center;
    width: 15%;
    padding: 0;
    transition: opacity .15s;
    display: flex;
    position: absolute;
    top: 0;
    bottom: 0;
}

@media (prefers-reduced-motion: reduce) {
    .carousel-control-prev, .carousel-control-next {
        transition: none;
    }
}

.carousel-control-prev:hover, .carousel-control-prev:focus, .carousel-control-next:hover, .carousel-control-next:focus {
    color: #fff;
    opacity: .9;
    outline: 0;
    text-decoration: none;
}

.carousel-control-prev {
    left: 0;
}

.carousel-control-next {
    right: 0;
}

.carousel-control-prev-icon, .carousel-control-next-icon {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    width: 2rem;
    height: 2rem;
    display: inline-block;
}

.carousel-control-prev-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}

.carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.carousel-indicators {
    z-index: 2;
    justify-content: center;
    margin-bottom: 1rem;
    margin-left: 15%;
    margin-right: 15%;
    padding: 0;
    display: flex;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}

    .carousel-indicators [data-bs-target] {
        box-sizing: content-box;
        text-indent: -999px;
        cursor: pointer;
        opacity: .5;
        background-color: #fff;
        background-clip: padding-box;
        border: 10px solid #0000;
        border-left: 0;
        border-right: 0;
        flex: 0 auto;
        width: 30px;
        height: 3px;
        margin-left: 3px;
        margin-right: 3px;
        padding: 0;
        transition: opacity .6s;
    }

@media (prefers-reduced-motion: reduce) {
    .carousel-indicators [data-bs-target] {
        transition: none;
    }
}

.carousel-indicators .active {
    opacity: 1;
}

.carousel-caption {
    color: #fff;
    text-align: center;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    position: absolute;
    bottom: 1.25rem;
    left: 15%;
    right: 15%;
}

.carousel-dark .carousel-control-prev-icon, .carousel-dark .carousel-control-next-icon {
    filter: invert() grayscale(100);
}

.carousel-dark .carousel-indicators [data-bs-target] {
    background-color: #000;
}

.carousel-dark .carousel-caption {
    color: #000;
}

[data-bs-theme="dark"] .carousel .carousel-control-prev-icon, [data-bs-theme="dark"] .carousel .carousel-control-next-icon, [data-bs-theme="dark"].carousel .carousel-control-prev-icon, [data-bs-theme="dark"].carousel .carousel-control-next-icon {
    filter: invert() grayscale(100);
}

[data-bs-theme="dark"] .carousel .carousel-indicators [data-bs-target], [data-bs-theme="dark"].carousel .carousel-indicators [data-bs-target] {
    background-color: #000;
}

[data-bs-theme="dark"] .carousel .carousel-caption, [data-bs-theme="dark"].carousel .carousel-caption {
    color: #000;
}

.spinner-grow, .spinner-border {
    width: var(--bs-spinner-width);
    height: var(--bs-spinner-height);
    vertical-align: var(--bs-spinner-vertical-align);
    animation: var(--bs-spinner-animation-speed) linear infinite var(--bs-spinner-animation-name);
    border-radius: 50%;
    display: inline-block;
}

@keyframes spinner-border {
    to {
        transform: rotate(360deg);
    }
}

.spinner-border {
    --bs-spinner-width: 2rem;
    --bs-spinner-height: 2rem;
    --bs-spinner-vertical-align: -.125em;
    --bs-spinner-border-width: .25em;
    --bs-spinner-animation-speed: .75s;
    --bs-spinner-animation-name: spinner-border;
    border: var(--bs-spinner-border-width) solid currentcolor;
    border-right-color: #0000;
}

.spinner-border-sm {
    --bs-spinner-width: 1rem;
    --bs-spinner-height: 1rem;
    --bs-spinner-border-width: .2em;
}

@keyframes spinner-grow {
    0% {
        transform: scale(0);
    }

    50% {
        opacity: 1;
        transform: none;
    }
}

.spinner-grow {
    --bs-spinner-width: 2rem;
    --bs-spinner-height: 2rem;
    --bs-spinner-vertical-align: -.125em;
    --bs-spinner-animation-speed: .75s;
    --bs-spinner-animation-name: spinner-grow;
    opacity: 0;
    background-color: currentColor;
}

.spinner-grow-sm {
    --bs-spinner-width: 1rem;
    --bs-spinner-height: 1rem;
}

@media (prefers-reduced-motion: reduce) {
    .spinner-border, .spinner-grow {
        --bs-spinner-animation-speed: 1.5s;
    }
}

.offcanvas, .offcanvas-xxl, .offcanvas-xl, .offcanvas-lg, .offcanvas-md, .offcanvas-sm {
    --bs-offcanvas-zindex: 1045;
    --bs-offcanvas-width: 400px;
    --bs-offcanvas-height: 30vh;
    --bs-offcanvas-padding-x: 1rem;
    --bs-offcanvas-padding-y: 1rem;
    --bs-offcanvas-color: var(--bs-body-color);
    --bs-offcanvas-bg: var(--bs-body-bg);
    --bs-offcanvas-border-width: var(--bs-border-width);
    --bs-offcanvas-border-color: var(--bs-border-color-translucent);
    --bs-offcanvas-box-shadow: var(--bs-box-shadow-sm);
    --bs-offcanvas-transition: transform .3s ease-in-out;
    --bs-offcanvas-title-line-height: 1.5;
}

@media (width <= 575.98px) {
    .offcanvas-sm {
        z-index: var(--bs-offcanvas-zindex);
        max-width: 100%;
        color: var(--bs-offcanvas-color);
        visibility: hidden;
        background-color: var(--bs-offcanvas-bg);
        transition: var(--bs-offcanvas-transition);
        background-clip: padding-box;
        outline: 0;
        flex-direction: column;
        display: flex;
        position: fixed;
        bottom: 0;
    }
}

@media (width <= 575.98px) and (prefers-reduced-motion: reduce) {
    .offcanvas-sm {
        transition: none;
    }
}

@media (width <= 575.98px) {
    .offcanvas-sm.offcanvas-start {
        width: var(--bs-offcanvas-width);
        border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        left: 0;
        transform: translateX(-100%);
    }

    .offcanvas-sm.offcanvas-end {
        width: var(--bs-offcanvas-width);
        border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        right: 0;
        transform: translateX(100%);
    }

    .offcanvas-sm.offcanvas-top {
        height: var(--bs-offcanvas-height);
        border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        top: 0;
        left: 0;
        right: 0;
        transform: translateY(-100%);
    }

    .offcanvas-sm.offcanvas-bottom {
        height: var(--bs-offcanvas-height);
        border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        left: 0;
        right: 0;
        transform: translateY(100%);
    }

    .offcanvas-sm.showing, .offcanvas-sm.show:not(.hiding) {
        transform: none;
    }

    .offcanvas-sm.showing, .offcanvas-sm.hiding, .offcanvas-sm.show {
        visibility: visible;
    }
}

@media (width >= 576px) {
    .offcanvas-sm {
        --bs-offcanvas-height: auto;
        --bs-offcanvas-border-width: 0;
        background-color: #0000 !important;
    }

        .offcanvas-sm .offcanvas-header {
            display: none;
        }

        .offcanvas-sm .offcanvas-body {
            flex-grow: 0;
            padding: 0;
            display: flex;
            overflow-y: visible;
            background-color: #0000 !important;
        }
}

@media (width <= 767.98px) {
    .offcanvas-md {
        z-index: var(--bs-offcanvas-zindex);
        max-width: 100%;
        color: var(--bs-offcanvas-color);
        visibility: hidden;
        background-color: var(--bs-offcanvas-bg);
        transition: var(--bs-offcanvas-transition);
        background-clip: padding-box;
        outline: 0;
        flex-direction: column;
        display: flex;
        position: fixed;
        bottom: 0;
    }
}

@media (width <= 767.98px) and (prefers-reduced-motion: reduce) {
    .offcanvas-md {
        transition: none;
    }
}

@media (width <= 767.98px) {
    .offcanvas-md.offcanvas-start {
        width: var(--bs-offcanvas-width);
        border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        left: 0;
        transform: translateX(-100%);
    }

    .offcanvas-md.offcanvas-end {
        width: var(--bs-offcanvas-width);
        border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        right: 0;
        transform: translateX(100%);
    }

    .offcanvas-md.offcanvas-top {
        height: var(--bs-offcanvas-height);
        border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        top: 0;
        left: 0;
        right: 0;
        transform: translateY(-100%);
    }

    .offcanvas-md.offcanvas-bottom {
        height: var(--bs-offcanvas-height);
        border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        left: 0;
        right: 0;
        transform: translateY(100%);
    }

    .offcanvas-md.showing, .offcanvas-md.show:not(.hiding) {
        transform: none;
    }

    .offcanvas-md.showing, .offcanvas-md.hiding, .offcanvas-md.show {
        visibility: visible;
    }
}

@media (width >= 768px) {
    .offcanvas-md {
        --bs-offcanvas-height: auto;
        --bs-offcanvas-border-width: 0;
        background-color: #0000 !important;
    }

        .offcanvas-md .offcanvas-header {
            display: none;
        }

        .offcanvas-md .offcanvas-body {
            flex-grow: 0;
            padding: 0;
            display: flex;
            overflow-y: visible;
            background-color: #0000 !important;
        }
}

@media (width <= 991.98px) {
    .offcanvas-lg {
        z-index: var(--bs-offcanvas-zindex);
        max-width: 100%;
        color: var(--bs-offcanvas-color);
        visibility: hidden;
        background-color: var(--bs-offcanvas-bg);
        transition: var(--bs-offcanvas-transition);
        background-clip: padding-box;
        outline: 0;
        flex-direction: column;
        display: flex;
        position: fixed;
        bottom: 0;
    }
}

@media (width <= 991.98px) and (prefers-reduced-motion: reduce) {
    .offcanvas-lg {
        transition: none;
    }
}

@media (width <= 991.98px) {
    .offcanvas-lg.offcanvas-start {
        width: var(--bs-offcanvas-width);
        border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        left: 0;
        transform: translateX(-100%);
    }

    .offcanvas-lg.offcanvas-end {
        width: var(--bs-offcanvas-width);
        border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        right: 0;
        transform: translateX(100%);
    }

    .offcanvas-lg.offcanvas-top {
        height: var(--bs-offcanvas-height);
        border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        top: 0;
        left: 0;
        right: 0;
        transform: translateY(-100%);
    }

    .offcanvas-lg.offcanvas-bottom {
        height: var(--bs-offcanvas-height);
        border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        left: 0;
        right: 0;
        transform: translateY(100%);
    }

    .offcanvas-lg.showing, .offcanvas-lg.show:not(.hiding) {
        transform: none;
    }

    .offcanvas-lg.showing, .offcanvas-lg.hiding, .offcanvas-lg.show {
        visibility: visible;
    }
}

@media (width >= 992px) {
    .offcanvas-lg {
        --bs-offcanvas-height: auto;
        --bs-offcanvas-border-width: 0;
        background-color: #0000 !important;
    }

        .offcanvas-lg .offcanvas-header {
            display: none;
        }

        .offcanvas-lg .offcanvas-body {
            flex-grow: 0;
            padding: 0;
            display: flex;
            overflow-y: visible;
            background-color: #0000 !important;
        }
}

@media (width <= 1199.98px) {
    .offcanvas-xl {
        z-index: var(--bs-offcanvas-zindex);
        max-width: 100%;
        color: var(--bs-offcanvas-color);
        visibility: hidden;
        background-color: var(--bs-offcanvas-bg);
        transition: var(--bs-offcanvas-transition);
        background-clip: padding-box;
        outline: 0;
        flex-direction: column;
        display: flex;
        position: fixed;
        bottom: 0;
    }
}

@media (width <= 1199.98px) and (prefers-reduced-motion: reduce) {
    .offcanvas-xl {
        transition: none;
    }
}

@media (width <= 1199.98px) {
    .offcanvas-xl.offcanvas-start {
        width: var(--bs-offcanvas-width);
        border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        left: 0;
        transform: translateX(-100%);
    }

    .offcanvas-xl.offcanvas-end {
        width: var(--bs-offcanvas-width);
        border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        right: 0;
        transform: translateX(100%);
    }

    .offcanvas-xl.offcanvas-top {
        height: var(--bs-offcanvas-height);
        border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        top: 0;
        left: 0;
        right: 0;
        transform: translateY(-100%);
    }

    .offcanvas-xl.offcanvas-bottom {
        height: var(--bs-offcanvas-height);
        border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        left: 0;
        right: 0;
        transform: translateY(100%);
    }

    .offcanvas-xl.showing, .offcanvas-xl.show:not(.hiding) {
        transform: none;
    }

    .offcanvas-xl.showing, .offcanvas-xl.hiding, .offcanvas-xl.show {
        visibility: visible;
    }
}

@media (width >= 1200px) {
    .offcanvas-xl {
        --bs-offcanvas-height: auto;
        --bs-offcanvas-border-width: 0;
        background-color: #0000 !important;
    }

        .offcanvas-xl .offcanvas-header {
            display: none;
        }

        .offcanvas-xl .offcanvas-body {
            flex-grow: 0;
            padding: 0;
            display: flex;
            overflow-y: visible;
            background-color: #0000 !important;
        }
}

@media (width <= 1399.98px) {
    .offcanvas-xxl {
        z-index: var(--bs-offcanvas-zindex);
        max-width: 100%;
        color: var(--bs-offcanvas-color);
        visibility: hidden;
        background-color: var(--bs-offcanvas-bg);
        transition: var(--bs-offcanvas-transition);
        background-clip: padding-box;
        outline: 0;
        flex-direction: column;
        display: flex;
        position: fixed;
        bottom: 0;
    }
}

@media (width <= 1399.98px) and (prefers-reduced-motion: reduce) {
    .offcanvas-xxl {
        transition: none;
    }
}

@media (width <= 1399.98px) {
    .offcanvas-xxl.offcanvas-start {
        width: var(--bs-offcanvas-width);
        border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        left: 0;
        transform: translateX(-100%);
    }

    .offcanvas-xxl.offcanvas-end {
        width: var(--bs-offcanvas-width);
        border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        top: 0;
        right: 0;
        transform: translateX(100%);
    }

    .offcanvas-xxl.offcanvas-top {
        height: var(--bs-offcanvas-height);
        border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        top: 0;
        left: 0;
        right: 0;
        transform: translateY(-100%);
    }

    .offcanvas-xxl.offcanvas-bottom {
        height: var(--bs-offcanvas-height);
        border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
        max-height: 100%;
        left: 0;
        right: 0;
        transform: translateY(100%);
    }

    .offcanvas-xxl.showing, .offcanvas-xxl.show:not(.hiding) {
        transform: none;
    }

    .offcanvas-xxl.showing, .offcanvas-xxl.hiding, .offcanvas-xxl.show {
        visibility: visible;
    }
}

@media (width >= 1400px) {
    .offcanvas-xxl {
        --bs-offcanvas-height: auto;
        --bs-offcanvas-border-width: 0;
        background-color: #0000 !important;
    }

        .offcanvas-xxl .offcanvas-header {
            display: none;
        }

        .offcanvas-xxl .offcanvas-body {
            flex-grow: 0;
            padding: 0;
            display: flex;
            overflow-y: visible;
            background-color: #0000 !important;
        }
}

.offcanvas {
    z-index: var(--bs-offcanvas-zindex);
    max-width: 100%;
    color: var(--bs-offcanvas-color);
    visibility: hidden;
    background-color: var(--bs-offcanvas-bg);
    transition: var(--bs-offcanvas-transition);
    background-clip: padding-box;
    outline: 0;
    flex-direction: column;
    display: flex;
    position: fixed;
    bottom: 0;
}

@media (prefers-reduced-motion: reduce) {
    .offcanvas {
        transition: none;
    }
}

.offcanvas.offcanvas-start {
    width: var(--bs-offcanvas-width);
    border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    top: 0;
    left: 0;
    transform: translateX(-100%);
}

.offcanvas.offcanvas-end {
    width: var(--bs-offcanvas-width);
    border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    top: 0;
    right: 0;
    transform: translateX(100%);
}

.offcanvas.offcanvas-top {
    height: var(--bs-offcanvas-height);
    border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    max-height: 100%;
    top: 0;
    left: 0;
    right: 0;
    transform: translateY(-100%);
}

.offcanvas.offcanvas-bottom {
    height: var(--bs-offcanvas-height);
    border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    max-height: 100%;
    left: 0;
    right: 0;
    transform: translateY(100%);
}

.offcanvas.showing, .offcanvas.show:not(.hiding) {
    transform: none;
}

.offcanvas.showing, .offcanvas.hiding, .offcanvas.show {
    visibility: visible;
}

.offcanvas-backdrop {
    z-index: 1040;
    background-color: #000;
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
}

    .offcanvas-backdrop.fade {
        opacity: 0;
    }

    .offcanvas-backdrop.show {
        opacity: .5;
    }

.offcanvas-header {
    padding: var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);
    align-items: center;
    display: flex;
}

    .offcanvas-header .btn-close {
        padding: calc(var(--bs-offcanvas-padding-y) * .5) calc(var(--bs-offcanvas-padding-x) * .5);
        margin: calc(-.5 * var(--bs-offcanvas-padding-y)) calc(-.5 * var(--bs-offcanvas-padding-x)) calc(-.5 * var(--bs-offcanvas-padding-y)) auto;
    }

.offcanvas-title {
    line-height: var(--bs-offcanvas-title-line-height);
    margin-bottom: 0;
}

.offcanvas-body {
    padding: var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);
    flex-grow: 1;
    overflow-y: auto;
}

.placeholder {
    vertical-align: middle;
    cursor: wait;
    opacity: .5;
    background-color: currentColor;
    min-height: 1em;
    display: inline-block;
}

    .placeholder.btn:before {
        content: "";
        display: inline-block;
    }

.placeholder-xs {
    min-height: .6em;
}

.placeholder-sm {
    min-height: .8em;
}

.placeholder-lg {
    min-height: 1.2em;
}

.placeholder-glow .placeholder {
    animation: 2s ease-in-out infinite placeholder-glow;
}

@keyframes placeholder-glow {
    50% {
        opacity: .2;
    }
}

.placeholder-wave {
    animation: 2s linear infinite placeholder-wave;
    mask-image: linear-gradient(130deg, #000 55%, #000c 75%, #000 95%);
    mask-size: 200% 100%;
}

@keyframes placeholder-wave {
    100% {
        mask-position: -200% 0;
    }
}

.clearfix:after {
    clear: both;
    content: "";
    display: block;
}

.text-bg-primary {
    color: #fff !important;
    background-color: RGBA(var(--bs-primary-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-secondary {
    color: #fff !important;
    background-color: RGBA(var(--bs-secondary-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-success {
    color: #fff !important;
    background-color: RGBA(var(--bs-success-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-info {
    color: #000 !important;
    background-color: RGBA(var(--bs-info-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-warning {
    color: #000 !important;
    background-color: RGBA(var(--bs-warning-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-danger {
    color: #fff !important;
    background-color: RGBA(var(--bs-danger-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-light {
    color: #000 !important;
    background-color: RGBA(var(--bs-light-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-dark {
    color: #fff !important;
    background-color: RGBA(var(--bs-dark-rgb), var(--bs-bg-opacity, 1)) !important;
}

.link-primary {
    color: RGBA(var(--bs-primary-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-primary-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-primary:hover, .link-primary:focus {
        color: RGBA(10, 88, 202, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(10, 88, 202, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-secondary {
    color: RGBA(var(--bs-secondary-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-secondary-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-secondary:hover, .link-secondary:focus {
        color: RGBA(86, 94, 100, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(86, 94, 100, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-success {
    color: RGBA(var(--bs-success-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-success-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-success:hover, .link-success:focus {
        color: RGBA(20, 108, 67, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(20, 108, 67, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-info {
    color: RGBA(var(--bs-info-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-info-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-info:hover, .link-info:focus {
        color: RGBA(61, 213, 243, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(61, 213, 243, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-warning {
    color: RGBA(var(--bs-warning-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-warning-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-warning:hover, .link-warning:focus {
        color: RGBA(255, 205, 57, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(255, 205, 57, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-danger {
    color: RGBA(var(--bs-danger-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-danger-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-danger:hover, .link-danger:focus {
        color: RGBA(176, 42, 55, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(176, 42, 55, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-light {
    color: RGBA(var(--bs-light-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-light-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-light:hover, .link-light:focus {
        color: RGBA(249, 250, 251, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(249, 250, 251, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-dark {
    color: RGBA(var(--bs-dark-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-dark-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-dark:hover, .link-dark:focus {
        color: RGBA(26, 30, 33, var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(26, 30, 33, var(--bs-link-underline-opacity, 1)) !important;
    }

.link-body-emphasis {
    color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 1)) !important;
    text-decoration-color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

    .link-body-emphasis:hover, .link-body-emphasis:focus {
        color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, .75)) !important;
        text-decoration-color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, .75)) !important;
    }

.focus-ring:focus {
    box-shadow: var(--bs-focus-ring-x, 0) var(--bs-focus-ring-y, 0) var(--bs-focus-ring-blur, 0) var(--bs-focus-ring-width) var(--bs-focus-ring-color);
    outline: 0;
}

.icon-link {
    text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, .5));
    text-underline-offset: .25em;
    backface-visibility: hidden;
    align-items: center;
    gap: .375rem;
    display: inline-flex;
}

    .icon-link > .bi {
        fill: currentColor;
        flex-shrink: 0;
        width: 1em;
        height: 1em;
        transition: transform .2s ease-in-out;
    }

@media (prefers-reduced-motion: reduce) {
    .icon-link > .bi {
        transition: none;
    }
}

.icon-link-hover:hover > .bi, .icon-link-hover:focus-visible > .bi {
    transform: var(--bs-icon-link-transform, translate3d(.25em, 0, 0));
}

.ratio {
    width: 100%;
    position: relative;
}

    .ratio:before {
        padding-top: var(--bs-aspect-ratio);
        content: "";
        display: block;
    }

    .ratio > * {
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
    }

.ratio-1x1 {
    --bs-aspect-ratio: 100%;
}

.ratio-4x3 {
    --bs-aspect-ratio: 75%;
}

.ratio-16x9 {
    --bs-aspect-ratio: 56.25%;
}

.ratio-21x9 {
    --bs-aspect-ratio: 42.8571%;
}

.fixed-top {
    z-index: 1030;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
}

.fixed-bottom {
    z-index: 1030;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
}

.sticky-top {
    z-index: 1020;
    position: sticky;
    top: 0;
}

.sticky-bottom {
    z-index: 1020;
    position: sticky;
    bottom: 0;
}

@media (width >= 576px) {
    .sticky-sm-top {
        z-index: 1020;
        position: sticky;
        top: 0;
    }

    .sticky-sm-bottom {
        z-index: 1020;
        position: sticky;
        bottom: 0;
    }
}

@media (width >= 768px) {
    .sticky-md-top {
        z-index: 1020;
        position: sticky;
        top: 0;
    }

    .sticky-md-bottom {
        z-index: 1020;
        position: sticky;
        bottom: 0;
    }
}

@media (width >= 992px) {
    .sticky-lg-top {
        z-index: 1020;
        position: sticky;
        top: 0;
    }

    .sticky-lg-bottom {
        z-index: 1020;
        position: sticky;
        bottom: 0;
    }
}

@media (width >= 1200px) {
    .sticky-xl-top {
        z-index: 1020;
        position: sticky;
        top: 0;
    }

    .sticky-xl-bottom {
        z-index: 1020;
        position: sticky;
        bottom: 0;
    }
}

@media (width >= 1400px) {
    .sticky-xxl-top {
        z-index: 1020;
        position: sticky;
        top: 0;
    }

    .sticky-xxl-bottom {
        z-index: 1020;
        position: sticky;
        bottom: 0;
    }
}

.hstack {
    flex-direction: row;
    align-self: stretch;
    align-items: center;
    display: flex;
}

.vstack {
    flex-direction: column;
    flex: auto;
    align-self: stretch;
    display: flex;
}

.visually-hidden, .visually-hidden-focusable:not(:focus):not(:focus-within) {
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    padding: 0 !important;
    overflow: hidden !important;
}

    .visually-hidden:not(caption), .visually-hidden-focusable:not(:focus):not(:focus-within):not(caption) {
        position: absolute !important;
    }

.stretched-link:after {
    z-index: 1;
    content: "";
    position: absolute;
    inset: 0;
}

.text-truncate {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
}

.vr {
    width: var(--bs-border-width);
    opacity: .25;
    background-color: currentColor;
    align-self: stretch;
    min-height: 1em;
    display: inline-block;
}

.align-baseline {
    vertical-align: baseline !important;
}

.align-top {
    vertical-align: top !important;
}

.align-middle {
    vertical-align: middle !important;
}

.align-bottom {
    vertical-align: bottom !important;
}

.align-text-bottom {
    vertical-align: text-bottom !important;
}

.align-text-top {
    vertical-align: text-top !important;
}

.float-start {
    float: left !important;
}

.float-end {
    float: right !important;
}

.float-none {
    float: none !important;
}

.object-fit-contain {
    object-fit: contain !important;
}

.object-fit-cover {
    object-fit: cover !important;
}

.object-fit-fill {
    object-fit: fill !important;
}

.object-fit-scale {
    object-fit: scale-down !important;
}

.object-fit-none {
    object-fit: none !important;
}

.opacity-0 {
    opacity: 0 !important;
}

.opacity-25 {
    opacity: .25 !important;
}

.opacity-50 {
    opacity: .5 !important;
}

.opacity-75 {
    opacity: .75 !important;
}

.opacity-100 {
    opacity: 1 !important;
}

.overflow-auto {
    overflow: auto !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

.overflow-visible {
    overflow: visible !important;
}

.overflow-scroll {
    overflow: scroll !important;
}

.overflow-x-auto {
    overflow-x: auto !important;
}

.overflow-x-hidden {
    overflow-x: hidden !important;
}

.overflow-x-visible {
    overflow-x: visible !important;
}

.overflow-x-scroll {
    overflow-x: scroll !important;
}

.overflow-y-auto {
    overflow-y: auto !important;
}

.overflow-y-hidden {
    overflow-y: hidden !important;
}

.overflow-y-visible {
    overflow-y: visible !important;
}

.overflow-y-scroll {
    overflow-y: scroll !important;
}

.d-inline {
    display: inline !important;
}

.d-inline-block {
    display: inline-block !important;
}

.d-block {
    display: block !important;
}

.d-grid {
    display: grid !important;
}

.d-inline-grid {
    display: inline-grid !important;
}

.d-table {
    display: table !important;
}

.d-table-row {
    display: table-row !important;
}

.d-table-cell {
    display: table-cell !important;
}

.d-flex {
    display: flex !important;
}

.d-inline-flex {
    display: inline-flex !important;
}

.d-none {
    display: none !important;
}

.shadow {
    box-shadow: var(--bs-box-shadow) !important;
}

.shadow-sm {
    box-shadow: var(--bs-box-shadow-sm) !important;
}

.shadow-lg {
    box-shadow: var(--bs-box-shadow-lg) !important;
}

.shadow-none {
    box-shadow: none !important;
}

.focus-ring-primary {
    --bs-focus-ring-color: rgba(var(--bs-primary-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-secondary {
    --bs-focus-ring-color: rgba(var(--bs-secondary-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-success {
    --bs-focus-ring-color: rgba(var(--bs-success-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-info {
    --bs-focus-ring-color: rgba(var(--bs-info-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-warning {
    --bs-focus-ring-color: rgba(var(--bs-warning-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-danger {
    --bs-focus-ring-color: rgba(var(--bs-danger-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-light {
    --bs-focus-ring-color: rgba(var(--bs-light-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-dark {
    --bs-focus-ring-color: rgba(var(--bs-dark-rgb), var(--bs-focus-ring-opacity));
}

.position-static {
    position: static !important;
}

.position-relative {
    position: relative !important;
}

.position-absolute {
    position: absolute !important;
}

.position-fixed {
    position: fixed !important;
}

.position-sticky {
    position: sticky !important;
}

.top-0 {
    top: 0 !important;
}

.top-50 {
    top: 50% !important;
}

.top-100 {
    top: 100% !important;
}

.bottom-0 {
    bottom: 0 !important;
}

.bottom-50 {
    bottom: 50% !important;
}

.bottom-100 {
    bottom: 100% !important;
}

.start-0 {
    left: 0 !important;
}

.start-50 {
    left: 50% !important;
}

.start-100 {
    left: 100% !important;
}

.end-0 {
    right: 0 !important;
}

.end-50 {
    right: 50% !important;
}

.end-100 {
    right: 100% !important;
}

.translate-middle {
    transform: translate(-50%, -50%) !important;
}

.translate-middle-x {
    transform: translateX(-50%) !important;
}

.translate-middle-y {
    transform: translateY(-50%) !important;
}

.border {
    border: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-0 {
    border: 0 !important;
}

.border-top {
    border-top: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-top-0 {
    border-top: 0 !important;
}

.border-end {
    border-right: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-end-0 {
    border-right: 0 !important;
}

.border-bottom, .grid-row {
    border-bottom: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-bottom-0 {
    border-bottom: 0 !important;
}

.border-start {
    border-left: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-start-0 {
    border-left: 0 !important;
}

.border-primary {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-primary-rgb), var(--bs-border-opacity)) !important;
}

.border-secondary {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-secondary-rgb), var(--bs-border-opacity)) !important;
}

.border-success {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-success-rgb), var(--bs-border-opacity)) !important;
}

.border-info {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-info-rgb), var(--bs-border-opacity)) !important;
}

.border-warning {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-warning-rgb), var(--bs-border-opacity)) !important;
}

.border-danger {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-danger-rgb), var(--bs-border-opacity)) !important;
}

.border-light {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-light-rgb), var(--bs-border-opacity)) !important;
}

.border-dark {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-dark-rgb), var(--bs-border-opacity)) !important;
}

.border-black {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-black-rgb), var(--bs-border-opacity)) !important;
}

.border-white {
    --bs-border-opacity: 1;
    border-color: rgba(var(--bs-white-rgb), var(--bs-border-opacity)) !important;
}

.border-primary-subtle {
    border-color: var(--bs-primary-border-subtle) !important;
}

.border-secondary-subtle {
    border-color: var(--bs-secondary-border-subtle) !important;
}

.border-success-subtle {
    border-color: var(--bs-success-border-subtle) !important;
}

.border-info-subtle {
    border-color: var(--bs-info-border-subtle) !important;
}

.border-warning-subtle {
    border-color: var(--bs-warning-border-subtle) !important;
}

.border-danger-subtle {
    border-color: var(--bs-danger-border-subtle) !important;
}

.border-light-subtle {
    border-color: var(--bs-light-border-subtle) !important;
}

.border-dark-subtle {
    border-color: var(--bs-dark-border-subtle) !important;
}

.border-1 {
    border-width: 1px !important;
}

.border-2 {
    border-width: 2px !important;
}

.border-3 {
    border-width: 3px !important;
}

.border-4 {
    border-width: 4px !important;
}

.border-5 {
    border-width: 5px !important;
}

.border-opacity-10 {
    --bs-border-opacity: .1;
}

.border-opacity-25 {
    --bs-border-opacity: .25;
}

.border-opacity-50 {
    --bs-border-opacity: .5;
}

.border-opacity-75 {
    --bs-border-opacity: .75;
}

.border-opacity-100 {
    --bs-border-opacity: 1;
}

.w-25 {
    width: 25% !important;
}

.w-50 {
    width: 50% !important;
}

.w-75 {
    width: 75% !important;
}

.w-100, .PPNSwiper.swiper .swiper-slide .btn.btn-cta {
    width: 100% !important;
}

.w-auto {
    width: auto !important;
}

.mw-100 {
    max-width: 100% !important;
}

.vw-100 {
    width: 100vw !important;
}

.min-vw-100 {
    min-width: 100vw !important;
}

.h-25 {
    height: 25% !important;
}

.h-50 {
    height: 50% !important;
}

.h-75 {
    height: 75% !important;
}

.h-100 {
    height: 100% !important;
}

.h-auto {
    height: auto !important;
}

.mh-100 {
    max-height: 100% !important;
}

.vh-100 {
    height: 100vh !important;
}

.min-vh-100 {
    min-height: 100vh !important;
}

.flex-fill {
    flex: auto !important;
}

.flex-row {
    flex-direction: row !important;
}

.flex-column {
    flex-direction: column !important;
}

.flex-row-reverse {
    flex-direction: row-reverse !important;
}

.flex-column-reverse {
    flex-direction: column-reverse !important;
}

.flex-grow-0 {
    flex-grow: 0 !important;
}

.flex-grow-1 {
    flex-grow: 1 !important;
}

.flex-shrink-0 {
    flex-shrink: 0 !important;
}

.flex-shrink-1 {
    flex-shrink: 1 !important;
}

.flex-wrap {
    flex-wrap: wrap !important;
}

.flex-nowrap {
    flex-wrap: nowrap !important;
}

.flex-wrap-reverse {
    flex-wrap: wrap-reverse !important;
}

.justify-content-start {
    justify-content: flex-start !important;
}

.justify-content-end {
    justify-content: flex-end !important;
}

.justify-content-center {
    justify-content: center !important;
}

.justify-content-between {
    justify-content: space-between !important;
}

.justify-content-around {
    justify-content: space-around !important;
}

.justify-content-evenly {
    justify-content: space-evenly !important;
}

.align-items-start {
    align-items: flex-start !important;
}

.align-items-end {
    align-items: flex-end !important;
}

.align-items-center {
    align-items: center !important;
}

.align-items-baseline {
    align-items: baseline !important;
}

.align-items-stretch {
    align-items: stretch !important;
}

.align-content-start {
    align-content: flex-start !important;
}

.align-content-end {
    align-content: flex-end !important;
}

.align-content-center {
    align-content: center !important;
}

.align-content-between {
    align-content: space-between !important;
}

.align-content-around {
    align-content: space-around !important;
}

.align-content-stretch {
    align-content: stretch !important;
}

.align-self-auto {
    align-self: auto !important;
}

.align-self-start {
    align-self: flex-start !important;
}

.align-self-end {
    align-self: flex-end !important;
}

.align-self-center {
    align-self: center !important;
}

.align-self-baseline {
    align-self: baseline !important;
}

.align-self-stretch {
    align-self: stretch !important;
}

.order-first {
    order: -1 !important;
}

.order-0 {
    order: 0 !important;
}

.order-1 {
    order: 1 !important;
}

.order-2 {
    order: 2 !important;
}

.order-3 {
    order: 3 !important;
}

.order-4 {
    order: 4 !important;
}

.order-5 {
    order: 5 !important;
}

.order-last {
    order: 6 !important;
}

.m-0 {
    margin: 0 !important;
}

.m-1 {
    margin: .25rem !important;
}

.m-2 {
    margin: .5rem !important;
}

.m-3 {
    margin: 1rem !important;
}

.m-4 {
    margin: 1.5rem !important;
}

.m-5 {
    margin: 3rem !important;
}

.m-auto {
    margin: auto !important;
}

.mx-0, .grid-row {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.mx-1 {
    margin-left: .25rem !important;
    margin-right: .25rem !important;
}

.mx-2 {
    margin-left: .5rem !important;
    margin-right: .5rem !important;
}

.mx-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
}

.mx-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
}

.mx-5 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
}

.mx-auto {
    margin-left: auto !important;
    margin-right: auto !important;
}

.my-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.my-1 {
    margin-top: .25rem !important;
    margin-bottom: .25rem !important;
}

.my-2 {
    margin-top: .5rem !important;
    margin-bottom: .5rem !important;
}

.my-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
}

.my-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}

.my-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
}

.my-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
}

.mt-0 {
    margin-top: 0 !important;
}

.mt-1 {
    margin-top: .25rem !important;
}

.mt-2 {
    margin-top: .5rem !important;
}

.mt-3 {
    margin-top: 1rem !important;
}

.mt-4 {
    margin-top: 1.5rem !important;
}

.mt-5 {
    margin-top: 3rem !important;
}

.mt-auto {
    margin-top: auto !important;
}

.me-0 {
    margin-right: 0 !important;
}

.me-1 {
    margin-right: .25rem !important;
}

.me-2 {
    margin-right: .5rem !important;
}

.me-3 {
    margin-right: 1rem !important;
}

.me-4 {
    margin-right: 1.5rem !important;
}

.me-5 {
    margin-right: 3rem !important;
}

.me-auto {
    margin-right: auto !important;
}

.mb-0 {
    margin-bottom: 0 !important;
}

.mb-1 {
    margin-bottom: .25rem !important;
}

.mb-2 {
    margin-bottom: .5rem !important;
}

.mb-3, label {
    margin-bottom: 1rem !important;
}

.mb-4, section .ppn-filters .radius-slider, section .ppn-filters .title, .hero.homepage h1, .hero.homepage .h1 {
    margin-bottom: 1.5rem !important;
}

.mb-5 {
    margin-bottom: 3rem !important;
}

.mb-auto {
    margin-bottom: auto !important;
}

.ms-0 {
    margin-left: 0 !important;
}

.ms-1 {
    margin-left: .25rem !important;
}

.ms-2 {
    margin-left: .5rem !important;
}

.ms-3 {
    margin-left: 1rem !important;
}

.ms-4 {
    margin-left: 1.5rem !important;
}

.ms-5 {
    margin-left: 3rem !important;
}

.ms-auto {
    margin-left: auto !important;
}

.p-0 {
    padding: 0 !important;
}

.p-1 {
    padding: .25rem !important;
}

.p-2 {
    padding: .5rem !important;
}

.p-3, .ai-chat .card-footer {
    padding: 1rem !important;
}

.p-4 {
    padding: 1.5rem !important;
}

.p-5 {
    padding: 3rem !important;
}

.px-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.px-1 {
    padding-left: .25rem !important;
    padding-right: .25rem !important;
}

.px-2 {
    padding-left: .5rem !important;
    padding-right: .5rem !important;
}

.px-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
}

.px-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
}

.px-5 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
}

.py-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.py-1 {
    padding-top: .25rem !important;
    padding-bottom: .25rem !important;
}

.py-2, .grid-row .grid-item {
    padding-top: .5rem !important;
    padding-bottom: .5rem !important;
}

.py-3, .grid-sub-header {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

.py-4, .col-results, .col-filters, .grid-header {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
}

.py-5, .sub-header-hero h1, .sub-header-hero .h1 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
}

.pt-0 {
    padding-top: 0 !important;
}

.pt-1 {
    padding-top: .25rem !important;
}

.pt-2 {
    padding-top: .5rem !important;
}

.pt-3 {
    padding-top: 1rem !important;
}

.pt-4 {
    padding-top: 1.5rem !important;
}

.pt-5 {
    padding-top: 3rem !important;
}

.pe-0 {
    padding-right: 0 !important;
}

.pe-1 {
    padding-right: .25rem !important;
}

.pe-2 {
    padding-right: .5rem !important;
}

.pe-3 {
    padding-right: 1rem !important;
}

.pe-4 {
    padding-right: 1.5rem !important;
}

.pe-5 {
    padding-right: 3rem !important;
}

.pb-0 {
    padding-bottom: 0 !important;
}

.pb-1 {
    padding-bottom: .25rem !important;
}

.pb-2 {
    padding-bottom: .5rem !important;
}

.pb-3 {
    padding-bottom: 1rem !important;
}

.pb-4 {
    padding-bottom: 1.5rem !important;
}

.pb-5 {
    padding-bottom: 3rem !important;
}

.ps-0 {
    padding-left: 0 !important;
}

.ps-1 {
    padding-left: .25rem !important;
}

.ps-2 {
    padding-left: .5rem !important;
}

.ps-3 {
    padding-left: 1rem !important;
}

.ps-4 {
    padding-left: 1.5rem !important;
}

.ps-5 {
    padding-left: 3rem !important;
}

.gap-0 {
    gap: 0 !important;
}

.gap-1 {
    gap: .25rem !important;
}

.gap-2 {
    gap: .5rem !important;
}

.gap-3 {
    gap: 1rem !important;
}

.gap-4 {
    gap: 1.5rem !important;
}

.gap-5 {
    gap: 3rem !important;
}

.row-gap-0 {
    row-gap: 0 !important;
}

.row-gap-1 {
    row-gap: .25rem !important;
}

.row-gap-2 {
    row-gap: .5rem !important;
}

.row-gap-3 {
    row-gap: 1rem !important;
}

.row-gap-4 {
    row-gap: 1.5rem !important;
}

.row-gap-5 {
    row-gap: 3rem !important;
}

.column-gap-0 {
    column-gap: 0 !important;
}

.column-gap-1 {
    column-gap: .25rem !important;
}

.column-gap-2 {
    column-gap: .5rem !important;
}

.column-gap-3 {
    column-gap: 1rem !important;
}

.column-gap-4 {
    column-gap: 1.5rem !important;
}

.column-gap-5 {
    column-gap: 3rem !important;
}

.font-monospace {
    font-family: var(--bs-font-monospace) !important;
}

.fs-1 {
    font-size: calc(1.375rem + 1.5vw) !important;
}

.fs-2 {
    font-size: calc(1.325rem + .9vw) !important;
}

.fs-3 {
    font-size: calc(1.3rem + .6vw) !important;
}

.fs-4 {
    font-size: calc(1.275rem + .3vw) !important;
}

.fs-5 {
    font-size: 1.25rem !important;
}

.fs-6 {
    font-size: 1rem !important;
}

.fst-italic {
    font-style: italic !important;
}

.fst-normal {
    font-style: normal !important;
}

.fw-lighter {
    font-weight: lighter !important;
}

.fw-light {
    font-weight: 300 !important;
}

.fw-normal {
    font-weight: 400 !important;
}

.fw-medium {
    font-weight: 500 !important;
}

.fw-semibold {
    font-weight: 600 !important;
}

.fw-bold {
    font-weight: 700 !important;
}

.fw-bolder {
    font-weight: bolder !important;
}

.lh-1 {
    line-height: 1 !important;
}

.lh-sm {
    line-height: 1.25 !important;
}

.lh-base {
    line-height: 1.5 !important;
}

.lh-lg {
    line-height: 2 !important;
}

.text-start {
    text-align: left !important;
}

.text-end {
    text-align: right !important;
}

.text-center {
    text-align: center !important;
}

.text-decoration-none {
    text-decoration: none !important;
}

.text-decoration-underline {
    text-decoration: underline !important;
}

.text-decoration-line-through {
    text-decoration: line-through !important;
}

.text-lowercase {
    text-transform: lowercase !important;
}

.text-uppercase {
    text-transform: uppercase !important;
}

.text-capitalize {
    text-transform: capitalize !important;
}

.text-wrap {
    white-space: normal !important;
}

.text-nowrap {
    white-space: nowrap !important;
}

.text-break {
    word-wrap: break-word !important;
    word-break: break-word !important;
}

.text-primary {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-primary-rgb), var(--bs-text-opacity)) !important;
}

.text-secondary {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-secondary-rgb), var(--bs-text-opacity)) !important;
}

.text-success {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-success-rgb), var(--bs-text-opacity)) !important;
}

.text-info {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-info-rgb), var(--bs-text-opacity)) !important;
}

.text-warning {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-warning-rgb), var(--bs-text-opacity)) !important;
}

.text-danger {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important;
}

.text-light {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-light-rgb), var(--bs-text-opacity)) !important;
}

.text-dark {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-dark-rgb), var(--bs-text-opacity)) !important;
}

.text-black {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-black-rgb), var(--bs-text-opacity)) !important;
}

.text-white {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-white-rgb), var(--bs-text-opacity)) !important;
}

.text-body {
    --bs-text-opacity: 1;
    color: rgba(var(--bs-body-color-rgb), var(--bs-text-opacity)) !important;
}

.text-muted {
    --bs-text-opacity: 1;
    color: var(--bs-secondary-color) !important;
}

.text-black-50 {
    --bs-text-opacity: 1;
    color: #00000080 !important;
}

.text-white-50 {
    --bs-text-opacity: 1;
    color: #ffffff80 !important;
}

.text-body-secondary {
    --bs-text-opacity: 1;
    color: var(--bs-secondary-color) !important;
}

.text-body-tertiary {
    --bs-text-opacity: 1;
    color: var(--bs-tertiary-color) !important;
}

.text-body-emphasis {
    --bs-text-opacity: 1;
    color: var(--bs-emphasis-color) !important;
}

.text-reset {
    --bs-text-opacity: 1;
    color: inherit !important;
}

.text-opacity-25 {
    --bs-text-opacity: .25;
}

.text-opacity-50 {
    --bs-text-opacity: .5;
}

.text-opacity-75 {
    --bs-text-opacity: .75;
}

.text-opacity-100 {
    --bs-text-opacity: 1;
}

.text-primary-emphasis {
    color: var(--bs-primary-text-emphasis) !important;
}

.text-secondary-emphasis {
    color: var(--bs-secondary-text-emphasis) !important;
}

.text-success-emphasis {
    color: var(--bs-success-text-emphasis) !important;
}

.text-info-emphasis {
    color: var(--bs-info-text-emphasis) !important;
}

.text-warning-emphasis {
    color: var(--bs-warning-text-emphasis) !important;
}

.text-danger-emphasis {
    color: var(--bs-danger-text-emphasis) !important;
}

.text-light-emphasis {
    color: var(--bs-light-text-emphasis) !important;
}

.text-dark-emphasis {
    color: var(--bs-dark-text-emphasis) !important;
}

.link-opacity-10, .link-opacity-10-hover:hover {
    --bs-link-opacity: .1;
}

.link-opacity-25, .link-opacity-25-hover:hover {
    --bs-link-opacity: .25;
}

.link-opacity-50, .link-opacity-50-hover:hover {
    --bs-link-opacity: .5;
}

.link-opacity-75, .link-opacity-75-hover:hover {
    --bs-link-opacity: .75;
}

.link-opacity-100, .link-opacity-100-hover:hover {
    --bs-link-opacity: 1;
}

.link-offset-1, .link-offset-1-hover:hover {
    text-underline-offset: .125em !important;
}

.link-offset-2, .link-offset-2-hover:hover {
    text-underline-offset: .25em !important;
}

.link-offset-3, .link-offset-3-hover:hover {
    text-underline-offset: .375em !important;
}

.link-underline-primary {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-primary-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-secondary {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-secondary-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-success {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-success-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-info {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-info-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-warning {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-warning-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-danger {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-danger-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-light {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-light-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-dark {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-dark-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline {
    --bs-link-underline-opacity: 1;
    text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

.link-underline-opacity-0, .link-underline-opacity-0-hover:hover {
    --bs-link-underline-opacity: 0;
}

.link-underline-opacity-10, .link-underline-opacity-10-hover:hover {
    --bs-link-underline-opacity: .1;
}

.link-underline-opacity-25, .link-underline-opacity-25-hover:hover {
    --bs-link-underline-opacity: .25;
}

.link-underline-opacity-50, .link-underline-opacity-50-hover:hover {
    --bs-link-underline-opacity: .5;
}

.link-underline-opacity-75, .link-underline-opacity-75-hover:hover {
    --bs-link-underline-opacity: .75;
}

.link-underline-opacity-100, .link-underline-opacity-100-hover:hover {
    --bs-link-underline-opacity: 1;
}

.bg-primary {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-secondary {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-secondary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-success {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-success-rgb), var(--bs-bg-opacity)) !important;
}

.bg-info {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-info-rgb), var(--bs-bg-opacity)) !important;
}

.bg-warning {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-warning-rgb), var(--bs-bg-opacity)) !important;
}

.bg-danger {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-danger-rgb), var(--bs-bg-opacity)) !important;
}

.bg-light {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-light-rgb), var(--bs-bg-opacity)) !important;
}

.bg-dark {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-dark-rgb), var(--bs-bg-opacity)) !important;
}

.bg-black {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-black-rgb), var(--bs-bg-opacity)) !important;
}

.bg-white {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-white-rgb), var(--bs-bg-opacity)) !important;
}

.bg-body {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-body-bg-rgb), var(--bs-bg-opacity)) !important;
}

.bg-transparent {
    --bs-bg-opacity: 1;
    background-color: #0000 !important;
}

.bg-body-secondary {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-secondary-bg-rgb), var(--bs-bg-opacity)) !important;
}

.bg-body-tertiary {
    --bs-bg-opacity: 1;
    background-color: rgba(var(--bs-tertiary-bg-rgb), var(--bs-bg-opacity)) !important;
}

.bg-opacity-10 {
    --bs-bg-opacity: .1;
}

.bg-opacity-25 {
    --bs-bg-opacity: .25;
}

.bg-opacity-50 {
    --bs-bg-opacity: .5;
}

.bg-opacity-75 {
    --bs-bg-opacity: .75;
}

.bg-opacity-100 {
    --bs-bg-opacity: 1;
}

.bg-primary-subtle {
    background-color: var(--bs-primary-bg-subtle) !important;
}

.bg-secondary-subtle {
    background-color: var(--bs-secondary-bg-subtle) !important;
}

.bg-success-subtle {
    background-color: var(--bs-success-bg-subtle) !important;
}

.bg-info-subtle {
    background-color: var(--bs-info-bg-subtle) !important;
}

.bg-warning-subtle {
    background-color: var(--bs-warning-bg-subtle) !important;
}

.bg-danger-subtle {
    background-color: var(--bs-danger-bg-subtle) !important;
}

.bg-light-subtle {
    background-color: var(--bs-light-bg-subtle) !important;
}

.bg-dark-subtle {
    background-color: var(--bs-dark-bg-subtle) !important;
}

.bg-gradient {
    background-image: var(--bs-gradient) !important;
}

.user-select-all {
    user-select: all !important;
}

.user-select-auto {
    user-select: auto !important;
}

.user-select-none {
    user-select: none !important;
}

.pe-none {
    pointer-events: none !important;
}

.pe-auto {
    pointer-events: auto !important;
}

.rounded {
    border-radius: var(--bs-border-radius) !important;
}

.rounded-0 {
    border-radius: 0 !important;
}

.rounded-1 {
    border-radius: var(--bs-border-radius-sm) !important;
}

.rounded-2 {
    border-radius: var(--bs-border-radius) !important;
}

.rounded-3 {
    border-radius: var(--bs-border-radius-lg) !important;
}

.rounded-4 {
    border-radius: var(--bs-border-radius-xl) !important;
}

.rounded-5 {
    border-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-circle {
    border-radius: 50% !important;
}

.rounded-pill {
    border-radius: var(--bs-border-radius-pill) !important;
}

.rounded-top {
    border-top-left-radius: var(--bs-border-radius) !important;
    border-top-right-radius: var(--bs-border-radius) !important;
}

.rounded-top-0 {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
}

.rounded-top-1 {
    border-top-left-radius: var(--bs-border-radius-sm) !important;
    border-top-right-radius: var(--bs-border-radius-sm) !important;
}

.rounded-top-2 {
    border-top-left-radius: var(--bs-border-radius) !important;
    border-top-right-radius: var(--bs-border-radius) !important;
}

.rounded-top-3 {
    border-top-left-radius: var(--bs-border-radius-lg) !important;
    border-top-right-radius: var(--bs-border-radius-lg) !important;
}

.rounded-top-4 {
    border-top-left-radius: var(--bs-border-radius-xl) !important;
    border-top-right-radius: var(--bs-border-radius-xl) !important;
}

.rounded-top-5 {
    border-top-left-radius: var(--bs-border-radius-xxl) !important;
    border-top-right-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-top-circle {
    border-top-left-radius: 50% !important;
    border-top-right-radius: 50% !important;
}

.rounded-top-pill {
    border-top-left-radius: var(--bs-border-radius-pill) !important;
    border-top-right-radius: var(--bs-border-radius-pill) !important;
}

.rounded-end {
    border-top-right-radius: var(--bs-border-radius) !important;
    border-bottom-right-radius: var(--bs-border-radius) !important;
}

.rounded-end-0 {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.rounded-end-1 {
    border-top-right-radius: var(--bs-border-radius-sm) !important;
    border-bottom-right-radius: var(--bs-border-radius-sm) !important;
}

.rounded-end-2 {
    border-top-right-radius: var(--bs-border-radius) !important;
    border-bottom-right-radius: var(--bs-border-radius) !important;
}

.rounded-end-3 {
    border-top-right-radius: var(--bs-border-radius-lg) !important;
    border-bottom-right-radius: var(--bs-border-radius-lg) !important;
}

.rounded-end-4 {
    border-top-right-radius: var(--bs-border-radius-xl) !important;
    border-bottom-right-radius: var(--bs-border-radius-xl) !important;
}

.rounded-end-5 {
    border-top-right-radius: var(--bs-border-radius-xxl) !important;
    border-bottom-right-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-end-circle {
    border-top-right-radius: 50% !important;
    border-bottom-right-radius: 50% !important;
}

.rounded-end-pill {
    border-top-right-radius: var(--bs-border-radius-pill) !important;
    border-bottom-right-radius: var(--bs-border-radius-pill) !important;
}

.rounded-bottom {
    border-bottom-right-radius: var(--bs-border-radius) !important;
    border-bottom-left-radius: var(--bs-border-radius) !important;
}

.rounded-bottom-0 {
    border-bottom-right-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.rounded-bottom-1 {
    border-bottom-right-radius: var(--bs-border-radius-sm) !important;
    border-bottom-left-radius: var(--bs-border-radius-sm) !important;
}

.rounded-bottom-2 {
    border-bottom-right-radius: var(--bs-border-radius) !important;
    border-bottom-left-radius: var(--bs-border-radius) !important;
}

.rounded-bottom-3 {
    border-bottom-right-radius: var(--bs-border-radius-lg) !important;
    border-bottom-left-radius: var(--bs-border-radius-lg) !important;
}

.rounded-bottom-4 {
    border-bottom-right-radius: var(--bs-border-radius-xl) !important;
    border-bottom-left-radius: var(--bs-border-radius-xl) !important;
}

.rounded-bottom-5 {
    border-bottom-right-radius: var(--bs-border-radius-xxl) !important;
    border-bottom-left-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-bottom-circle {
    border-bottom-right-radius: 50% !important;
    border-bottom-left-radius: 50% !important;
}

.rounded-bottom-pill {
    border-bottom-right-radius: var(--bs-border-radius-pill) !important;
    border-bottom-left-radius: var(--bs-border-radius-pill) !important;
}

.rounded-start {
    border-bottom-left-radius: var(--bs-border-radius) !important;
    border-top-left-radius: var(--bs-border-radius) !important;
}

.rounded-start-0 {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.rounded-start-1 {
    border-bottom-left-radius: var(--bs-border-radius-sm) !important;
    border-top-left-radius: var(--bs-border-radius-sm) !important;
}

.rounded-start-2 {
    border-bottom-left-radius: var(--bs-border-radius) !important;
    border-top-left-radius: var(--bs-border-radius) !important;
}

.rounded-start-3 {
    border-bottom-left-radius: var(--bs-border-radius-lg) !important;
    border-top-left-radius: var(--bs-border-radius-lg) !important;
}

.rounded-start-4 {
    border-bottom-left-radius: var(--bs-border-radius-xl) !important;
    border-top-left-radius: var(--bs-border-radius-xl) !important;
}

.rounded-start-5 {
    border-bottom-left-radius: var(--bs-border-radius-xxl) !important;
    border-top-left-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-start-circle {
    border-top-left-radius: 50% !important;
    border-bottom-left-radius: 50% !important;
}

.rounded-start-pill {
    border-bottom-left-radius: var(--bs-border-radius-pill) !important;
    border-top-left-radius: var(--bs-border-radius-pill) !important;
}

.visible {
    visibility: visible !important;
}

.invisible {
    visibility: hidden !important;
}

.z-n1 {
    z-index: -1 !important;
}

.z-0 {
    z-index: 0 !important;
}

.z-1 {
    z-index: 1 !important;
}

.z-2 {
    z-index: 2 !important;
}

.z-3 {
    z-index: 3 !important;
}

@media (width >= 576px) {
    .float-sm-start {
        float: left !important;
    }

    .float-sm-end {
        float: right !important;
    }

    .float-sm-none {
        float: none !important;
    }

    .object-fit-sm-contain {
        object-fit: contain !important;
    }

    .object-fit-sm-cover {
        object-fit: cover !important;
    }

    .object-fit-sm-fill {
        object-fit: fill !important;
    }

    .object-fit-sm-scale {
        object-fit: scale-down !important;
    }

    .object-fit-sm-none {
        object-fit: none !important;
    }

    .d-sm-inline {
        display: inline !important;
    }

    .d-sm-inline-block {
        display: inline-block !important;
    }

    .d-sm-block {
        display: block !important;
    }

    .d-sm-grid {
        display: grid !important;
    }

    .d-sm-inline-grid {
        display: inline-grid !important;
    }

    .d-sm-table {
        display: table !important;
    }

    .d-sm-table-row {
        display: table-row !important;
    }

    .d-sm-table-cell {
        display: table-cell !important;
    }

    .d-sm-flex {
        display: flex !important;
    }

    .d-sm-inline-flex {
        display: inline-flex !important;
    }

    .d-sm-none {
        display: none !important;
    }

    .flex-sm-fill {
        flex: auto !important;
    }

    .flex-sm-row {
        flex-direction: row !important;
    }

    .flex-sm-column {
        flex-direction: column !important;
    }

    .flex-sm-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-sm-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-sm-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-sm-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-sm-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-sm-shrink-1 {
        flex-shrink: 1 !important;
    }

    .flex-sm-wrap {
        flex-wrap: wrap !important;
    }

    .flex-sm-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-sm-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .justify-content-sm-start {
        justify-content: flex-start !important;
    }

    .justify-content-sm-end {
        justify-content: flex-end !important;
    }

    .justify-content-sm-center {
        justify-content: center !important;
    }

    .justify-content-sm-between {
        justify-content: space-between !important;
    }

    .justify-content-sm-around {
        justify-content: space-around !important;
    }

    .justify-content-sm-evenly {
        justify-content: space-evenly !important;
    }

    .align-items-sm-start {
        align-items: flex-start !important;
    }

    .align-items-sm-end {
        align-items: flex-end !important;
    }

    .align-items-sm-center {
        align-items: center !important;
    }

    .align-items-sm-baseline {
        align-items: baseline !important;
    }

    .align-items-sm-stretch {
        align-items: stretch !important;
    }

    .align-content-sm-start {
        align-content: flex-start !important;
    }

    .align-content-sm-end {
        align-content: flex-end !important;
    }

    .align-content-sm-center {
        align-content: center !important;
    }

    .align-content-sm-between {
        align-content: space-between !important;
    }

    .align-content-sm-around {
        align-content: space-around !important;
    }

    .align-content-sm-stretch {
        align-content: stretch !important;
    }

    .align-self-sm-auto {
        align-self: auto !important;
    }

    .align-self-sm-start {
        align-self: flex-start !important;
    }

    .align-self-sm-end {
        align-self: flex-end !important;
    }

    .align-self-sm-center {
        align-self: center !important;
    }

    .align-self-sm-baseline {
        align-self: baseline !important;
    }

    .align-self-sm-stretch {
        align-self: stretch !important;
    }

    .order-sm-first {
        order: -1 !important;
    }

    .order-sm-0 {
        order: 0 !important;
    }

    .order-sm-1 {
        order: 1 !important;
    }

    .order-sm-2 {
        order: 2 !important;
    }

    .order-sm-3 {
        order: 3 !important;
    }

    .order-sm-4 {
        order: 4 !important;
    }

    .order-sm-5 {
        order: 5 !important;
    }

    .order-sm-last {
        order: 6 !important;
    }

    .m-sm-0 {
        margin: 0 !important;
    }

    .m-sm-1 {
        margin: .25rem !important;
    }

    .m-sm-2 {
        margin: .5rem !important;
    }

    .m-sm-3 {
        margin: 1rem !important;
    }

    .m-sm-4 {
        margin: 1.5rem !important;
    }

    .m-sm-5 {
        margin: 3rem !important;
    }

    .m-sm-auto {
        margin: auto !important;
    }

    .mx-sm-0 {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .mx-sm-1 {
        margin-left: .25rem !important;
        margin-right: .25rem !important;
    }

    .mx-sm-2 {
        margin-left: .5rem !important;
        margin-right: .5rem !important;
    }

    .mx-sm-3 {
        margin-left: 1rem !important;
        margin-right: 1rem !important;
    }

    .mx-sm-4 {
        margin-left: 1.5rem !important;
        margin-right: 1.5rem !important;
    }

    .mx-sm-5 {
        margin-left: 3rem !important;
        margin-right: 3rem !important;
    }

    .mx-sm-auto {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .my-sm-0 {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .my-sm-1 {
        margin-top: .25rem !important;
        margin-bottom: .25rem !important;
    }

    .my-sm-2 {
        margin-top: .5rem !important;
        margin-bottom: .5rem !important;
    }

    .my-sm-3 {
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .my-sm-4 {
        margin-top: 1.5rem !important;
        margin-bottom: 1.5rem !important;
    }

    .my-sm-5 {
        margin-top: 3rem !important;
        margin-bottom: 3rem !important;
    }

    .my-sm-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .mt-sm-0 {
        margin-top: 0 !important;
    }

    .mt-sm-1 {
        margin-top: .25rem !important;
    }

    .mt-sm-2 {
        margin-top: .5rem !important;
    }

    .mt-sm-3 {
        margin-top: 1rem !important;
    }

    .mt-sm-4 {
        margin-top: 1.5rem !important;
    }

    .mt-sm-5 {
        margin-top: 3rem !important;
    }

    .mt-sm-auto {
        margin-top: auto !important;
    }

    .me-sm-0 {
        margin-right: 0 !important;
    }

    .me-sm-1 {
        margin-right: .25rem !important;
    }

    .me-sm-2 {
        margin-right: .5rem !important;
    }

    .me-sm-3 {
        margin-right: 1rem !important;
    }

    .me-sm-4 {
        margin-right: 1.5rem !important;
    }

    .me-sm-5 {
        margin-right: 3rem !important;
    }

    .me-sm-auto {
        margin-right: auto !important;
    }

    .mb-sm-0 {
        margin-bottom: 0 !important;
    }

    .mb-sm-1 {
        margin-bottom: .25rem !important;
    }

    .mb-sm-2 {
        margin-bottom: .5rem !important;
    }

    .mb-sm-3 {
        margin-bottom: 1rem !important;
    }

    .mb-sm-4 {
        margin-bottom: 1.5rem !important;
    }

    .mb-sm-5 {
        margin-bottom: 3rem !important;
    }

    .mb-sm-auto {
        margin-bottom: auto !important;
    }

    .ms-sm-0 {
        margin-left: 0 !important;
    }

    .ms-sm-1 {
        margin-left: .25rem !important;
    }

    .ms-sm-2 {
        margin-left: .5rem !important;
    }

    .ms-sm-3 {
        margin-left: 1rem !important;
    }

    .ms-sm-4 {
        margin-left: 1.5rem !important;
    }

    .ms-sm-5 {
        margin-left: 3rem !important;
    }

    .ms-sm-auto {
        margin-left: auto !important;
    }

    .p-sm-0 {
        padding: 0 !important;
    }

    .p-sm-1 {
        padding: .25rem !important;
    }

    .p-sm-2 {
        padding: .5rem !important;
    }

    .p-sm-3 {
        padding: 1rem !important;
    }

    .p-sm-4 {
        padding: 1.5rem !important;
    }

    .p-sm-5 {
        padding: 3rem !important;
    }

    .px-sm-0 {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .px-sm-1 {
        padding-left: .25rem !important;
        padding-right: .25rem !important;
    }

    .px-sm-2 {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

    .px-sm-3 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .px-sm-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .px-sm-5 {
        padding-left: 3rem !important;
        padding-right: 3rem !important;
    }

    .py-sm-0 {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .py-sm-1 {
        padding-top: .25rem !important;
        padding-bottom: .25rem !important;
    }

    .py-sm-2 {
        padding-top: .5rem !important;
        padding-bottom: .5rem !important;
    }

    .py-sm-3 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .py-sm-4 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }

    .py-sm-5 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .pt-sm-0 {
        padding-top: 0 !important;
    }

    .pt-sm-1 {
        padding-top: .25rem !important;
    }

    .pt-sm-2 {
        padding-top: .5rem !important;
    }

    .pt-sm-3 {
        padding-top: 1rem !important;
    }

    .pt-sm-4 {
        padding-top: 1.5rem !important;
    }

    .pt-sm-5 {
        padding-top: 3rem !important;
    }

    .pe-sm-0 {
        padding-right: 0 !important;
    }

    .pe-sm-1 {
        padding-right: .25rem !important;
    }

    .pe-sm-2 {
        padding-right: .5rem !important;
    }

    .pe-sm-3 {
        padding-right: 1rem !important;
    }

    .pe-sm-4 {
        padding-right: 1.5rem !important;
    }

    .pe-sm-5 {
        padding-right: 3rem !important;
    }

    .pb-sm-0 {
        padding-bottom: 0 !important;
    }

    .pb-sm-1 {
        padding-bottom: .25rem !important;
    }

    .pb-sm-2 {
        padding-bottom: .5rem !important;
    }

    .pb-sm-3 {
        padding-bottom: 1rem !important;
    }

    .pb-sm-4 {
        padding-bottom: 1.5rem !important;
    }

    .pb-sm-5 {
        padding-bottom: 3rem !important;
    }

    .ps-sm-0 {
        padding-left: 0 !important;
    }

    .ps-sm-1 {
        padding-left: .25rem !important;
    }

    .ps-sm-2 {
        padding-left: .5rem !important;
    }

    .ps-sm-3 {
        padding-left: 1rem !important;
    }

    .ps-sm-4 {
        padding-left: 1.5rem !important;
    }

    .ps-sm-5 {
        padding-left: 3rem !important;
    }

    .gap-sm-0 {
        gap: 0 !important;
    }

    .gap-sm-1 {
        gap: .25rem !important;
    }

    .gap-sm-2 {
        gap: .5rem !important;
    }

    .gap-sm-3 {
        gap: 1rem !important;
    }

    .gap-sm-4 {
        gap: 1.5rem !important;
    }

    .gap-sm-5 {
        gap: 3rem !important;
    }

    .row-gap-sm-0 {
        row-gap: 0 !important;
    }

    .row-gap-sm-1 {
        row-gap: .25rem !important;
    }

    .row-gap-sm-2 {
        row-gap: .5rem !important;
    }

    .row-gap-sm-3 {
        row-gap: 1rem !important;
    }

    .row-gap-sm-4 {
        row-gap: 1.5rem !important;
    }

    .row-gap-sm-5 {
        row-gap: 3rem !important;
    }

    .column-gap-sm-0 {
        column-gap: 0 !important;
    }

    .column-gap-sm-1 {
        column-gap: .25rem !important;
    }

    .column-gap-sm-2 {
        column-gap: .5rem !important;
    }

    .column-gap-sm-3 {
        column-gap: 1rem !important;
    }

    .column-gap-sm-4 {
        column-gap: 1.5rem !important;
    }

    .column-gap-sm-5 {
        column-gap: 3rem !important;
    }

    .text-sm-start {
        text-align: left !important;
    }

    .text-sm-end {
        text-align: right !important;
    }

    .text-sm-center {
        text-align: center !important;
    }
}

@media (width >= 768px) {
    .float-md-start {
        float: left !important;
    }

    .float-md-end {
        float: right !important;
    }

    .float-md-none {
        float: none !important;
    }

    .object-fit-md-contain {
        object-fit: contain !important;
    }

    .object-fit-md-cover {
        object-fit: cover !important;
    }

    .object-fit-md-fill {
        object-fit: fill !important;
    }

    .object-fit-md-scale {
        object-fit: scale-down !important;
    }

    .object-fit-md-none {
        object-fit: none !important;
    }

    .d-md-inline {
        display: inline !important;
    }

    .d-md-inline-block {
        display: inline-block !important;
    }

    .d-md-block {
        display: block !important;
    }

    .d-md-grid {
        display: grid !important;
    }

    .d-md-inline-grid {
        display: inline-grid !important;
    }

    .d-md-table {
        display: table !important;
    }

    .d-md-table-row {
        display: table-row !important;
    }

    .d-md-table-cell {
        display: table-cell !important;
    }

    .d-md-flex {
        display: flex !important;
    }

    .d-md-inline-flex {
        display: inline-flex !important;
    }

    .d-md-none {
        display: none !important;
    }

    .flex-md-fill {
        flex: auto !important;
    }

    .flex-md-row {
        flex-direction: row !important;
    }

    .flex-md-column {
        flex-direction: column !important;
    }

    .flex-md-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-md-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-md-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-md-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-md-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-md-shrink-1 {
        flex-shrink: 1 !important;
    }

    .flex-md-wrap {
        flex-wrap: wrap !important;
    }

    .flex-md-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-md-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .justify-content-md-start {
        justify-content: flex-start !important;
    }

    .justify-content-md-end {
        justify-content: flex-end !important;
    }

    .justify-content-md-center {
        justify-content: center !important;
    }

    .justify-content-md-between {
        justify-content: space-between !important;
    }

    .justify-content-md-around {
        justify-content: space-around !important;
    }

    .justify-content-md-evenly {
        justify-content: space-evenly !important;
    }

    .align-items-md-start {
        align-items: flex-start !important;
    }

    .align-items-md-end {
        align-items: flex-end !important;
    }

    .align-items-md-center {
        align-items: center !important;
    }

    .align-items-md-baseline {
        align-items: baseline !important;
    }

    .align-items-md-stretch {
        align-items: stretch !important;
    }

    .align-content-md-start {
        align-content: flex-start !important;
    }

    .align-content-md-end {
        align-content: flex-end !important;
    }

    .align-content-md-center {
        align-content: center !important;
    }

    .align-content-md-between {
        align-content: space-between !important;
    }

    .align-content-md-around {
        align-content: space-around !important;
    }

    .align-content-md-stretch {
        align-content: stretch !important;
    }

    .align-self-md-auto {
        align-self: auto !important;
    }

    .align-self-md-start {
        align-self: flex-start !important;
    }

    .align-self-md-end {
        align-self: flex-end !important;
    }

    .align-self-md-center {
        align-self: center !important;
    }

    .align-self-md-baseline {
        align-self: baseline !important;
    }

    .align-self-md-stretch {
        align-self: stretch !important;
    }

    .order-md-first {
        order: -1 !important;
    }

    .order-md-0 {
        order: 0 !important;
    }

    .order-md-1 {
        order: 1 !important;
    }

    .order-md-2 {
        order: 2 !important;
    }

    .order-md-3 {
        order: 3 !important;
    }

    .order-md-4 {
        order: 4 !important;
    }

    .order-md-5 {
        order: 5 !important;
    }

    .order-md-last {
        order: 6 !important;
    }

    .m-md-0 {
        margin: 0 !important;
    }

    .m-md-1 {
        margin: .25rem !important;
    }

    .m-md-2 {
        margin: .5rem !important;
    }

    .m-md-3 {
        margin: 1rem !important;
    }

    .m-md-4 {
        margin: 1.5rem !important;
    }

    .m-md-5 {
        margin: 3rem !important;
    }

    .m-md-auto {
        margin: auto !important;
    }

    .mx-md-0 {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .mx-md-1 {
        margin-left: .25rem !important;
        margin-right: .25rem !important;
    }

    .mx-md-2 {
        margin-left: .5rem !important;
        margin-right: .5rem !important;
    }

    .mx-md-3 {
        margin-left: 1rem !important;
        margin-right: 1rem !important;
    }

    .mx-md-4 {
        margin-left: 1.5rem !important;
        margin-right: 1.5rem !important;
    }

    .mx-md-5 {
        margin-left: 3rem !important;
        margin-right: 3rem !important;
    }

    .mx-md-auto {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .my-md-0 {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .my-md-1 {
        margin-top: .25rem !important;
        margin-bottom: .25rem !important;
    }

    .my-md-2 {
        margin-top: .5rem !important;
        margin-bottom: .5rem !important;
    }

    .my-md-3 {
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .my-md-4 {
        margin-top: 1.5rem !important;
        margin-bottom: 1.5rem !important;
    }

    .my-md-5 {
        margin-top: 3rem !important;
        margin-bottom: 3rem !important;
    }

    .my-md-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .mt-md-0 {
        margin-top: 0 !important;
    }

    .mt-md-1 {
        margin-top: .25rem !important;
    }

    .mt-md-2 {
        margin-top: .5rem !important;
    }

    .mt-md-3 {
        margin-top: 1rem !important;
    }

    .mt-md-4 {
        margin-top: 1.5rem !important;
    }

    .mt-md-5 {
        margin-top: 3rem !important;
    }

    .mt-md-auto {
        margin-top: auto !important;
    }

    .me-md-0 {
        margin-right: 0 !important;
    }

    .me-md-1 {
        margin-right: .25rem !important;
    }

    .me-md-2 {
        margin-right: .5rem !important;
    }

    .me-md-3 {
        margin-right: 1rem !important;
    }

    .me-md-4 {
        margin-right: 1.5rem !important;
    }

    .me-md-5 {
        margin-right: 3rem !important;
    }

    .me-md-auto {
        margin-right: auto !important;
    }

    .mb-md-0 {
        margin-bottom: 0 !important;
    }

    .mb-md-1 {
        margin-bottom: .25rem !important;
    }

    .mb-md-2 {
        margin-bottom: .5rem !important;
    }

    .mb-md-3 {
        margin-bottom: 1rem !important;
    }

    .mb-md-4 {
        margin-bottom: 1.5rem !important;
    }

    .mb-md-5 {
        margin-bottom: 3rem !important;
    }

    .mb-md-auto {
        margin-bottom: auto !important;
    }

    .ms-md-0 {
        margin-left: 0 !important;
    }

    .ms-md-1 {
        margin-left: .25rem !important;
    }

    .ms-md-2 {
        margin-left: .5rem !important;
    }

    .ms-md-3 {
        margin-left: 1rem !important;
    }

    .ms-md-4 {
        margin-left: 1.5rem !important;
    }

    .ms-md-5 {
        margin-left: 3rem !important;
    }

    .ms-md-auto {
        margin-left: auto !important;
    }

    .p-md-0 {
        padding: 0 !important;
    }

    .p-md-1 {
        padding: .25rem !important;
    }

    .p-md-2 {
        padding: .5rem !important;
    }

    .p-md-3 {
        padding: 1rem !important;
    }

    .p-md-4 {
        padding: 1.5rem !important;
    }

    .p-md-5 {
        padding: 3rem !important;
    }

    .px-md-0 {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .px-md-1 {
        padding-left: .25rem !important;
        padding-right: .25rem !important;
    }

    .px-md-2 {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

    .px-md-3 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .px-md-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .px-md-5 {
        padding-left: 3rem !important;
        padding-right: 3rem !important;
    }

    .py-md-0 {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .py-md-1 {
        padding-top: .25rem !important;
        padding-bottom: .25rem !important;
    }

    .py-md-2 {
        padding-top: .5rem !important;
        padding-bottom: .5rem !important;
    }

    .py-md-3 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .py-md-4 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }

    .py-md-5 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .pt-md-0 {
        padding-top: 0 !important;
    }

    .pt-md-1 {
        padding-top: .25rem !important;
    }

    .pt-md-2 {
        padding-top: .5rem !important;
    }

    .pt-md-3 {
        padding-top: 1rem !important;
    }

    .pt-md-4 {
        padding-top: 1.5rem !important;
    }

    .pt-md-5 {
        padding-top: 3rem !important;
    }

    .pe-md-0 {
        padding-right: 0 !important;
    }

    .pe-md-1 {
        padding-right: .25rem !important;
    }

    .pe-md-2 {
        padding-right: .5rem !important;
    }

    .pe-md-3 {
        padding-right: 1rem !important;
    }

    .pe-md-4 {
        padding-right: 1.5rem !important;
    }

    .pe-md-5 {
        padding-right: 3rem !important;
    }

    .pb-md-0 {
        padding-bottom: 0 !important;
    }

    .pb-md-1 {
        padding-bottom: .25rem !important;
    }

    .pb-md-2 {
        padding-bottom: .5rem !important;
    }

    .pb-md-3 {
        padding-bottom: 1rem !important;
    }

    .pb-md-4 {
        padding-bottom: 1.5rem !important;
    }

    .pb-md-5 {
        padding-bottom: 3rem !important;
    }

    .ps-md-0 {
        padding-left: 0 !important;
    }

    .ps-md-1 {
        padding-left: .25rem !important;
    }

    .ps-md-2 {
        padding-left: .5rem !important;
    }

    .ps-md-3 {
        padding-left: 1rem !important;
    }

    .ps-md-4 {
        padding-left: 1.5rem !important;
    }

    .ps-md-5 {
        padding-left: 3rem !important;
    }

    .gap-md-0 {
        gap: 0 !important;
    }

    .gap-md-1 {
        gap: .25rem !important;
    }

    .gap-md-2 {
        gap: .5rem !important;
    }

    .gap-md-3 {
        gap: 1rem !important;
    }

    .gap-md-4 {
        gap: 1.5rem !important;
    }

    .gap-md-5 {
        gap: 3rem !important;
    }

    .row-gap-md-0 {
        row-gap: 0 !important;
    }

    .row-gap-md-1 {
        row-gap: .25rem !important;
    }

    .row-gap-md-2 {
        row-gap: .5rem !important;
    }

    .row-gap-md-3 {
        row-gap: 1rem !important;
    }

    .row-gap-md-4 {
        row-gap: 1.5rem !important;
    }

    .row-gap-md-5 {
        row-gap: 3rem !important;
    }

    .column-gap-md-0 {
        column-gap: 0 !important;
    }

    .column-gap-md-1 {
        column-gap: .25rem !important;
    }

    .column-gap-md-2 {
        column-gap: .5rem !important;
    }

    .column-gap-md-3 {
        column-gap: 1rem !important;
    }

    .column-gap-md-4 {
        column-gap: 1.5rem !important;
    }

    .column-gap-md-5 {
        column-gap: 3rem !important;
    }

    .text-md-start {
        text-align: left !important;
    }

    .text-md-end {
        text-align: right !important;
    }

    .text-md-center {
        text-align: center !important;
    }
}

@media (width >= 992px) {
    .float-lg-start {
        float: left !important;
    }

    .float-lg-end {
        float: right !important;
    }

    .float-lg-none {
        float: none !important;
    }

    .object-fit-lg-contain {
        object-fit: contain !important;
    }

    .object-fit-lg-cover {
        object-fit: cover !important;
    }

    .object-fit-lg-fill {
        object-fit: fill !important;
    }

    .object-fit-lg-scale {
        object-fit: scale-down !important;
    }

    .object-fit-lg-none {
        object-fit: none !important;
    }

    .d-lg-inline {
        display: inline !important;
    }

    .d-lg-inline-block {
        display: inline-block !important;
    }

    .d-lg-block {
        display: block !important;
    }

    .d-lg-grid {
        display: grid !important;
    }

    .d-lg-inline-grid {
        display: inline-grid !important;
    }

    .d-lg-table {
        display: table !important;
    }

    .d-lg-table-row {
        display: table-row !important;
    }

    .d-lg-table-cell {
        display: table-cell !important;
    }

    .d-lg-flex {
        display: flex !important;
    }

    .d-lg-inline-flex {
        display: inline-flex !important;
    }

    .d-lg-none {
        display: none !important;
    }

    .flex-lg-fill {
        flex: auto !important;
    }

    .flex-lg-row {
        flex-direction: row !important;
    }

    .flex-lg-column {
        flex-direction: column !important;
    }

    .flex-lg-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-lg-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-lg-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-lg-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-lg-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-lg-shrink-1 {
        flex-shrink: 1 !important;
    }

    .flex-lg-wrap {
        flex-wrap: wrap !important;
    }

    .flex-lg-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-lg-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .justify-content-lg-start {
        justify-content: flex-start !important;
    }

    .justify-content-lg-end {
        justify-content: flex-end !important;
    }

    .justify-content-lg-center {
        justify-content: center !important;
    }

    .justify-content-lg-between {
        justify-content: space-between !important;
    }

    .justify-content-lg-around {
        justify-content: space-around !important;
    }

    .justify-content-lg-evenly {
        justify-content: space-evenly !important;
    }

    .align-items-lg-start {
        align-items: flex-start !important;
    }

    .align-items-lg-end {
        align-items: flex-end !important;
    }

    .align-items-lg-center {
        align-items: center !important;
    }

    .align-items-lg-baseline {
        align-items: baseline !important;
    }

    .align-items-lg-stretch {
        align-items: stretch !important;
    }

    .align-content-lg-start {
        align-content: flex-start !important;
    }

    .align-content-lg-end {
        align-content: flex-end !important;
    }

    .align-content-lg-center {
        align-content: center !important;
    }

    .align-content-lg-between {
        align-content: space-between !important;
    }

    .align-content-lg-around {
        align-content: space-around !important;
    }

    .align-content-lg-stretch {
        align-content: stretch !important;
    }

    .align-self-lg-auto {
        align-self: auto !important;
    }

    .align-self-lg-start {
        align-self: flex-start !important;
    }

    .align-self-lg-end {
        align-self: flex-end !important;
    }

    .align-self-lg-center {
        align-self: center !important;
    }

    .align-self-lg-baseline {
        align-self: baseline !important;
    }

    .align-self-lg-stretch {
        align-self: stretch !important;
    }

    .order-lg-first {
        order: -1 !important;
    }

    .order-lg-0 {
        order: 0 !important;
    }

    .order-lg-1 {
        order: 1 !important;
    }

    .order-lg-2 {
        order: 2 !important;
    }

    .order-lg-3 {
        order: 3 !important;
    }

    .order-lg-4 {
        order: 4 !important;
    }

    .order-lg-5 {
        order: 5 !important;
    }

    .order-lg-last {
        order: 6 !important;
    }

    .m-lg-0 {
        margin: 0 !important;
    }

    .m-lg-1 {
        margin: .25rem !important;
    }

    .m-lg-2 {
        margin: .5rem !important;
    }

    .m-lg-3 {
        margin: 1rem !important;
    }

    .m-lg-4 {
        margin: 1.5rem !important;
    }

    .m-lg-5 {
        margin: 3rem !important;
    }

    .m-lg-auto {
        margin: auto !important;
    }

    .mx-lg-0 {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .mx-lg-1 {
        margin-left: .25rem !important;
        margin-right: .25rem !important;
    }

    .mx-lg-2 {
        margin-left: .5rem !important;
        margin-right: .5rem !important;
    }

    .mx-lg-3 {
        margin-left: 1rem !important;
        margin-right: 1rem !important;
    }

    .mx-lg-4 {
        margin-left: 1.5rem !important;
        margin-right: 1.5rem !important;
    }

    .mx-lg-5 {
        margin-left: 3rem !important;
        margin-right: 3rem !important;
    }

    .mx-lg-auto {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .my-lg-0 {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .my-lg-1 {
        margin-top: .25rem !important;
        margin-bottom: .25rem !important;
    }

    .my-lg-2 {
        margin-top: .5rem !important;
        margin-bottom: .5rem !important;
    }

    .my-lg-3 {
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .my-lg-4 {
        margin-top: 1.5rem !important;
        margin-bottom: 1.5rem !important;
    }

    .my-lg-5 {
        margin-top: 3rem !important;
        margin-bottom: 3rem !important;
    }

    .my-lg-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .mt-lg-0 {
        margin-top: 0 !important;
    }

    .mt-lg-1 {
        margin-top: .25rem !important;
    }

    .mt-lg-2 {
        margin-top: .5rem !important;
    }

    .mt-lg-3 {
        margin-top: 1rem !important;
    }

    .mt-lg-4 {
        margin-top: 1.5rem !important;
    }

    .mt-lg-5 {
        margin-top: 3rem !important;
    }

    .mt-lg-auto {
        margin-top: auto !important;
    }

    .me-lg-0 {
        margin-right: 0 !important;
    }

    .me-lg-1 {
        margin-right: .25rem !important;
    }

    .me-lg-2 {
        margin-right: .5rem !important;
    }

    .me-lg-3 {
        margin-right: 1rem !important;
    }

    .me-lg-4 {
        margin-right: 1.5rem !important;
    }

    .me-lg-5 {
        margin-right: 3rem !important;
    }

    .me-lg-auto {
        margin-right: auto !important;
    }

    .mb-lg-0 {
        margin-bottom: 0 !important;
    }

    .mb-lg-1 {
        margin-bottom: .25rem !important;
    }

    .mb-lg-2 {
        margin-bottom: .5rem !important;
    }

    .mb-lg-3 {
        margin-bottom: 1rem !important;
    }

    .mb-lg-4 {
        margin-bottom: 1.5rem !important;
    }

    .mb-lg-5 {
        margin-bottom: 3rem !important;
    }

    .mb-lg-auto {
        margin-bottom: auto !important;
    }

    .ms-lg-0 {
        margin-left: 0 !important;
    }

    .ms-lg-1 {
        margin-left: .25rem !important;
    }

    .ms-lg-2 {
        margin-left: .5rem !important;
    }

    .ms-lg-3 {
        margin-left: 1rem !important;
    }

    .ms-lg-4 {
        margin-left: 1.5rem !important;
    }

    .ms-lg-5 {
        margin-left: 3rem !important;
    }

    .ms-lg-auto {
        margin-left: auto !important;
    }

    .p-lg-0 {
        padding: 0 !important;
    }

    .p-lg-1 {
        padding: .25rem !important;
    }

    .p-lg-2 {
        padding: .5rem !important;
    }

    .p-lg-3 {
        padding: 1rem !important;
    }

    .p-lg-4 {
        padding: 1.5rem !important;
    }

    .p-lg-5 {
        padding: 3rem !important;
    }

    .px-lg-0 {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .px-lg-1 {
        padding-left: .25rem !important;
        padding-right: .25rem !important;
    }

    .px-lg-2 {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

    .px-lg-3 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .px-lg-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .px-lg-5 {
        padding-left: 3rem !important;
        padding-right: 3rem !important;
    }

    .py-lg-0 {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .py-lg-1 {
        padding-top: .25rem !important;
        padding-bottom: .25rem !important;
    }

    .py-lg-2 {
        padding-top: .5rem !important;
        padding-bottom: .5rem !important;
    }

    .py-lg-3 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .py-lg-4 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }

    .py-lg-5 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .pt-lg-0 {
        padding-top: 0 !important;
    }

    .pt-lg-1 {
        padding-top: .25rem !important;
    }

    .pt-lg-2 {
        padding-top: .5rem !important;
    }

    .pt-lg-3 {
        padding-top: 1rem !important;
    }

    .pt-lg-4 {
        padding-top: 1.5rem !important;
    }

    .pt-lg-5 {
        padding-top: 3rem !important;
    }

    .pe-lg-0 {
        padding-right: 0 !important;
    }

    .pe-lg-1 {
        padding-right: .25rem !important;
    }

    .pe-lg-2 {
        padding-right: .5rem !important;
    }

    .pe-lg-3 {
        padding-right: 1rem !important;
    }

    .pe-lg-4 {
        padding-right: 1.5rem !important;
    }

    .pe-lg-5 {
        padding-right: 3rem !important;
    }

    .pb-lg-0 {
        padding-bottom: 0 !important;
    }

    .pb-lg-1 {
        padding-bottom: .25rem !important;
    }

    .pb-lg-2 {
        padding-bottom: .5rem !important;
    }

    .pb-lg-3 {
        padding-bottom: 1rem !important;
    }

    .pb-lg-4 {
        padding-bottom: 1.5rem !important;
    }

    .pb-lg-5 {
        padding-bottom: 3rem !important;
    }

    .ps-lg-0 {
        padding-left: 0 !important;
    }

    .ps-lg-1 {
        padding-left: .25rem !important;
    }

    .ps-lg-2 {
        padding-left: .5rem !important;
    }

    .ps-lg-3 {
        padding-left: 1rem !important;
    }

    .ps-lg-4 {
        padding-left: 1.5rem !important;
    }

    .ps-lg-5 {
        padding-left: 3rem !important;
    }

    .gap-lg-0 {
        gap: 0 !important;
    }

    .gap-lg-1 {
        gap: .25rem !important;
    }

    .gap-lg-2 {
        gap: .5rem !important;
    }

    .gap-lg-3 {
        gap: 1rem !important;
    }

    .gap-lg-4 {
        gap: 1.5rem !important;
    }

    .gap-lg-5 {
        gap: 3rem !important;
    }

    .row-gap-lg-0 {
        row-gap: 0 !important;
    }

    .row-gap-lg-1 {
        row-gap: .25rem !important;
    }

    .row-gap-lg-2 {
        row-gap: .5rem !important;
    }

    .row-gap-lg-3 {
        row-gap: 1rem !important;
    }

    .row-gap-lg-4 {
        row-gap: 1.5rem !important;
    }

    .row-gap-lg-5 {
        row-gap: 3rem !important;
    }

    .column-gap-lg-0 {
        column-gap: 0 !important;
    }

    .column-gap-lg-1 {
        column-gap: .25rem !important;
    }

    .column-gap-lg-2 {
        column-gap: .5rem !important;
    }

    .column-gap-lg-3 {
        column-gap: 1rem !important;
    }

    .column-gap-lg-4 {
        column-gap: 1.5rem !important;
    }

    .column-gap-lg-5 {
        column-gap: 3rem !important;
    }

    .text-lg-start {
        text-align: left !important;
    }

    .text-lg-end {
        text-align: right !important;
    }

    .text-lg-center {
        text-align: center !important;
    }
}

@media (width >= 1200px) {
    .float-xl-start {
        float: left !important;
    }

    .float-xl-end {
        float: right !important;
    }

    .float-xl-none {
        float: none !important;
    }

    .object-fit-xl-contain {
        object-fit: contain !important;
    }

    .object-fit-xl-cover {
        object-fit: cover !important;
    }

    .object-fit-xl-fill {
        object-fit: fill !important;
    }

    .object-fit-xl-scale {
        object-fit: scale-down !important;
    }

    .object-fit-xl-none {
        object-fit: none !important;
    }

    .d-xl-inline {
        display: inline !important;
    }

    .d-xl-inline-block {
        display: inline-block !important;
    }

    .d-xl-block {
        display: block !important;
    }

    .d-xl-grid {
        display: grid !important;
    }

    .d-xl-inline-grid {
        display: inline-grid !important;
    }

    .d-xl-table {
        display: table !important;
    }

    .d-xl-table-row {
        display: table-row !important;
    }

    .d-xl-table-cell {
        display: table-cell !important;
    }

    .d-xl-flex {
        display: flex !important;
    }

    .d-xl-inline-flex {
        display: inline-flex !important;
    }

    .d-xl-none {
        display: none !important;
    }

    .flex-xl-fill {
        flex: auto !important;
    }

    .flex-xl-row {
        flex-direction: row !important;
    }

    .flex-xl-column {
        flex-direction: column !important;
    }

    .flex-xl-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-xl-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-xl-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-xl-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-xl-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-xl-shrink-1 {
        flex-shrink: 1 !important;
    }

    .flex-xl-wrap {
        flex-wrap: wrap !important;
    }

    .flex-xl-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-xl-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .justify-content-xl-start {
        justify-content: flex-start !important;
    }

    .justify-content-xl-end {
        justify-content: flex-end !important;
    }

    .justify-content-xl-center {
        justify-content: center !important;
    }

    .justify-content-xl-between {
        justify-content: space-between !important;
    }

    .justify-content-xl-around {
        justify-content: space-around !important;
    }

    .justify-content-xl-evenly {
        justify-content: space-evenly !important;
    }

    .align-items-xl-start {
        align-items: flex-start !important;
    }

    .align-items-xl-end {
        align-items: flex-end !important;
    }

    .align-items-xl-center {
        align-items: center !important;
    }

    .align-items-xl-baseline {
        align-items: baseline !important;
    }

    .align-items-xl-stretch {
        align-items: stretch !important;
    }

    .align-content-xl-start {
        align-content: flex-start !important;
    }

    .align-content-xl-end {
        align-content: flex-end !important;
    }

    .align-content-xl-center {
        align-content: center !important;
    }

    .align-content-xl-between {
        align-content: space-between !important;
    }

    .align-content-xl-around {
        align-content: space-around !important;
    }

    .align-content-xl-stretch {
        align-content: stretch !important;
    }

    .align-self-xl-auto {
        align-self: auto !important;
    }

    .align-self-xl-start {
        align-self: flex-start !important;
    }

    .align-self-xl-end {
        align-self: flex-end !important;
    }

    .align-self-xl-center {
        align-self: center !important;
    }

    .align-self-xl-baseline {
        align-self: baseline !important;
    }

    .align-self-xl-stretch {
        align-self: stretch !important;
    }

    .order-xl-first {
        order: -1 !important;
    }

    .order-xl-0 {
        order: 0 !important;
    }

    .order-xl-1 {
        order: 1 !important;
    }

    .order-xl-2 {
        order: 2 !important;
    }

    .order-xl-3 {
        order: 3 !important;
    }

    .order-xl-4 {
        order: 4 !important;
    }

    .order-xl-5 {
        order: 5 !important;
    }

    .order-xl-last {
        order: 6 !important;
    }

    .m-xl-0 {
        margin: 0 !important;
    }

    .m-xl-1 {
        margin: .25rem !important;
    }

    .m-xl-2 {
        margin: .5rem !important;
    }

    .m-xl-3 {
        margin: 1rem !important;
    }

    .m-xl-4 {
        margin: 1.5rem !important;
    }

    .m-xl-5 {
        margin: 3rem !important;
    }

    .m-xl-auto {
        margin: auto !important;
    }

    .mx-xl-0 {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .mx-xl-1 {
        margin-left: .25rem !important;
        margin-right: .25rem !important;
    }

    .mx-xl-2 {
        margin-left: .5rem !important;
        margin-right: .5rem !important;
    }

    .mx-xl-3 {
        margin-left: 1rem !important;
        margin-right: 1rem !important;
    }

    .mx-xl-4 {
        margin-left: 1.5rem !important;
        margin-right: 1.5rem !important;
    }

    .mx-xl-5 {
        margin-left: 3rem !important;
        margin-right: 3rem !important;
    }

    .mx-xl-auto {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .my-xl-0 {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .my-xl-1 {
        margin-top: .25rem !important;
        margin-bottom: .25rem !important;
    }

    .my-xl-2 {
        margin-top: .5rem !important;
        margin-bottom: .5rem !important;
    }

    .my-xl-3 {
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .my-xl-4 {
        margin-top: 1.5rem !important;
        margin-bottom: 1.5rem !important;
    }

    .my-xl-5 {
        margin-top: 3rem !important;
        margin-bottom: 3rem !important;
    }

    .my-xl-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .mt-xl-0 {
        margin-top: 0 !important;
    }

    .mt-xl-1 {
        margin-top: .25rem !important;
    }

    .mt-xl-2 {
        margin-top: .5rem !important;
    }

    .mt-xl-3 {
        margin-top: 1rem !important;
    }

    .mt-xl-4 {
        margin-top: 1.5rem !important;
    }

    .mt-xl-5 {
        margin-top: 3rem !important;
    }

    .mt-xl-auto {
        margin-top: auto !important;
    }

    .me-xl-0 {
        margin-right: 0 !important;
    }

    .me-xl-1 {
        margin-right: .25rem !important;
    }

    .me-xl-2 {
        margin-right: .5rem !important;
    }

    .me-xl-3 {
        margin-right: 1rem !important;
    }

    .me-xl-4 {
        margin-right: 1.5rem !important;
    }

    .me-xl-5 {
        margin-right: 3rem !important;
    }

    .me-xl-auto {
        margin-right: auto !important;
    }

    .mb-xl-0 {
        margin-bottom: 0 !important;
    }

    .mb-xl-1 {
        margin-bottom: .25rem !important;
    }

    .mb-xl-2 {
        margin-bottom: .5rem !important;
    }

    .mb-xl-3 {
        margin-bottom: 1rem !important;
    }

    .mb-xl-4 {
        margin-bottom: 1.5rem !important;
    }

    .mb-xl-5 {
        margin-bottom: 3rem !important;
    }

    .mb-xl-auto {
        margin-bottom: auto !important;
    }

    .ms-xl-0 {
        margin-left: 0 !important;
    }

    .ms-xl-1 {
        margin-left: .25rem !important;
    }

    .ms-xl-2 {
        margin-left: .5rem !important;
    }

    .ms-xl-3 {
        margin-left: 1rem !important;
    }

    .ms-xl-4 {
        margin-left: 1.5rem !important;
    }

    .ms-xl-5 {
        margin-left: 3rem !important;
    }

    .ms-xl-auto {
        margin-left: auto !important;
    }

    .p-xl-0 {
        padding: 0 !important;
    }

    .p-xl-1 {
        padding: .25rem !important;
    }

    .p-xl-2 {
        padding: .5rem !important;
    }

    .p-xl-3 {
        padding: 1rem !important;
    }

    .p-xl-4 {
        padding: 1.5rem !important;
    }

    .p-xl-5 {
        padding: 3rem !important;
    }

    .px-xl-0 {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .px-xl-1 {
        padding-left: .25rem !important;
        padding-right: .25rem !important;
    }

    .px-xl-2 {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

    .px-xl-3 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .px-xl-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .px-xl-5 {
        padding-left: 3rem !important;
        padding-right: 3rem !important;
    }

    .py-xl-0 {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .py-xl-1 {
        padding-top: .25rem !important;
        padding-bottom: .25rem !important;
    }

    .py-xl-2 {
        padding-top: .5rem !important;
        padding-bottom: .5rem !important;
    }

    .py-xl-3 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .py-xl-4 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }

    .py-xl-5 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .pt-xl-0 {
        padding-top: 0 !important;
    }

    .pt-xl-1 {
        padding-top: .25rem !important;
    }

    .pt-xl-2 {
        padding-top: .5rem !important;
    }

    .pt-xl-3 {
        padding-top: 1rem !important;
    }

    .pt-xl-4 {
        padding-top: 1.5rem !important;
    }

    .pt-xl-5 {
        padding-top: 3rem !important;
    }

    .pe-xl-0 {
        padding-right: 0 !important;
    }

    .pe-xl-1 {
        padding-right: .25rem !important;
    }

    .pe-xl-2 {
        padding-right: .5rem !important;
    }

    .pe-xl-3 {
        padding-right: 1rem !important;
    }

    .pe-xl-4 {
        padding-right: 1.5rem !important;
    }

    .pe-xl-5 {
        padding-right: 3rem !important;
    }

    .pb-xl-0 {
        padding-bottom: 0 !important;
    }

    .pb-xl-1 {
        padding-bottom: .25rem !important;
    }

    .pb-xl-2 {
        padding-bottom: .5rem !important;
    }

    .pb-xl-3 {
        padding-bottom: 1rem !important;
    }

    .pb-xl-4 {
        padding-bottom: 1.5rem !important;
    }

    .pb-xl-5 {
        padding-bottom: 3rem !important;
    }

    .ps-xl-0 {
        padding-left: 0 !important;
    }

    .ps-xl-1 {
        padding-left: .25rem !important;
    }

    .ps-xl-2 {
        padding-left: .5rem !important;
    }

    .ps-xl-3 {
        padding-left: 1rem !important;
    }

    .ps-xl-4 {
        padding-left: 1.5rem !important;
    }

    .ps-xl-5 {
        padding-left: 3rem !important;
    }

    .gap-xl-0 {
        gap: 0 !important;
    }

    .gap-xl-1 {
        gap: .25rem !important;
    }

    .gap-xl-2 {
        gap: .5rem !important;
    }

    .gap-xl-3 {
        gap: 1rem !important;
    }

    .gap-xl-4 {
        gap: 1.5rem !important;
    }

    .gap-xl-5 {
        gap: 3rem !important;
    }

    .row-gap-xl-0 {
        row-gap: 0 !important;
    }

    .row-gap-xl-1 {
        row-gap: .25rem !important;
    }

    .row-gap-xl-2 {
        row-gap: .5rem !important;
    }

    .row-gap-xl-3 {
        row-gap: 1rem !important;
    }

    .row-gap-xl-4 {
        row-gap: 1.5rem !important;
    }

    .row-gap-xl-5 {
        row-gap: 3rem !important;
    }

    .column-gap-xl-0 {
        column-gap: 0 !important;
    }

    .column-gap-xl-1 {
        column-gap: .25rem !important;
    }

    .column-gap-xl-2 {
        column-gap: .5rem !important;
    }

    .column-gap-xl-3 {
        column-gap: 1rem !important;
    }

    .column-gap-xl-4 {
        column-gap: 1.5rem !important;
    }

    .column-gap-xl-5 {
        column-gap: 3rem !important;
    }

    .text-xl-start {
        text-align: left !important;
    }

    .text-xl-end {
        text-align: right !important;
    }

    .text-xl-center {
        text-align: center !important;
    }
}

@media (width >= 1400px) {
    .float-xxl-start {
        float: left !important;
    }

    .float-xxl-end {
        float: right !important;
    }

    .float-xxl-none {
        float: none !important;
    }

    .object-fit-xxl-contain {
        object-fit: contain !important;
    }

    .object-fit-xxl-cover {
        object-fit: cover !important;
    }

    .object-fit-xxl-fill {
        object-fit: fill !important;
    }

    .object-fit-xxl-scale {
        object-fit: scale-down !important;
    }

    .object-fit-xxl-none {
        object-fit: none !important;
    }

    .d-xxl-inline {
        display: inline !important;
    }

    .d-xxl-inline-block {
        display: inline-block !important;
    }

    .d-xxl-block {
        display: block !important;
    }

    .d-xxl-grid {
        display: grid !important;
    }

    .d-xxl-inline-grid {
        display: inline-grid !important;
    }

    .d-xxl-table {
        display: table !important;
    }

    .d-xxl-table-row {
        display: table-row !important;
    }

    .d-xxl-table-cell {
        display: table-cell !important;
    }

    .d-xxl-flex {
        display: flex !important;
    }

    .d-xxl-inline-flex {
        display: inline-flex !important;
    }

    .d-xxl-none {
        display: none !important;
    }

    .flex-xxl-fill {
        flex: auto !important;
    }

    .flex-xxl-row {
        flex-direction: row !important;
    }

    .flex-xxl-column {
        flex-direction: column !important;
    }

    .flex-xxl-row-reverse {
        flex-direction: row-reverse !important;
    }

    .flex-xxl-column-reverse {
        flex-direction: column-reverse !important;
    }

    .flex-xxl-grow-0 {
        flex-grow: 0 !important;
    }

    .flex-xxl-grow-1 {
        flex-grow: 1 !important;
    }

    .flex-xxl-shrink-0 {
        flex-shrink: 0 !important;
    }

    .flex-xxl-shrink-1 {
        flex-shrink: 1 !important;
    }

    .flex-xxl-wrap {
        flex-wrap: wrap !important;
    }

    .flex-xxl-nowrap {
        flex-wrap: nowrap !important;
    }

    .flex-xxl-wrap-reverse {
        flex-wrap: wrap-reverse !important;
    }

    .justify-content-xxl-start {
        justify-content: flex-start !important;
    }

    .justify-content-xxl-end {
        justify-content: flex-end !important;
    }

    .justify-content-xxl-center {
        justify-content: center !important;
    }

    .justify-content-xxl-between {
        justify-content: space-between !important;
    }

    .justify-content-xxl-around {
        justify-content: space-around !important;
    }

    .justify-content-xxl-evenly {
        justify-content: space-evenly !important;
    }

    .align-items-xxl-start {
        align-items: flex-start !important;
    }

    .align-items-xxl-end {
        align-items: flex-end !important;
    }

    .align-items-xxl-center {
        align-items: center !important;
    }

    .align-items-xxl-baseline {
        align-items: baseline !important;
    }

    .align-items-xxl-stretch {
        align-items: stretch !important;
    }

    .align-content-xxl-start {
        align-content: flex-start !important;
    }

    .align-content-xxl-end {
        align-content: flex-end !important;
    }

    .align-content-xxl-center {
        align-content: center !important;
    }

    .align-content-xxl-between {
        align-content: space-between !important;
    }

    .align-content-xxl-around {
        align-content: space-around !important;
    }

    .align-content-xxl-stretch {
        align-content: stretch !important;
    }

    .align-self-xxl-auto {
        align-self: auto !important;
    }

    .align-self-xxl-start {
        align-self: flex-start !important;
    }

    .align-self-xxl-end {
        align-self: flex-end !important;
    }

    .align-self-xxl-center {
        align-self: center !important;
    }

    .align-self-xxl-baseline {
        align-self: baseline !important;
    }

    .align-self-xxl-stretch {
        align-self: stretch !important;
    }

    .order-xxl-first {
        order: -1 !important;
    }

    .order-xxl-0 {
        order: 0 !important;
    }

    .order-xxl-1 {
        order: 1 !important;
    }

    .order-xxl-2 {
        order: 2 !important;
    }

    .order-xxl-3 {
        order: 3 !important;
    }

    .order-xxl-4 {
        order: 4 !important;
    }

    .order-xxl-5 {
        order: 5 !important;
    }

    .order-xxl-last {
        order: 6 !important;
    }

    .m-xxl-0 {
        margin: 0 !important;
    }

    .m-xxl-1 {
        margin: .25rem !important;
    }

    .m-xxl-2 {
        margin: .5rem !important;
    }

    .m-xxl-3 {
        margin: 1rem !important;
    }

    .m-xxl-4 {
        margin: 1.5rem !important;
    }

    .m-xxl-5 {
        margin: 3rem !important;
    }

    .m-xxl-auto {
        margin: auto !important;
    }

    .mx-xxl-0 {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .mx-xxl-1 {
        margin-left: .25rem !important;
        margin-right: .25rem !important;
    }

    .mx-xxl-2 {
        margin-left: .5rem !important;
        margin-right: .5rem !important;
    }

    .mx-xxl-3 {
        margin-left: 1rem !important;
        margin-right: 1rem !important;
    }

    .mx-xxl-4 {
        margin-left: 1.5rem !important;
        margin-right: 1.5rem !important;
    }

    .mx-xxl-5 {
        margin-left: 3rem !important;
        margin-right: 3rem !important;
    }

    .mx-xxl-auto {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .my-xxl-0 {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .my-xxl-1 {
        margin-top: .25rem !important;
        margin-bottom: .25rem !important;
    }

    .my-xxl-2 {
        margin-top: .5rem !important;
        margin-bottom: .5rem !important;
    }

    .my-xxl-3 {
        margin-top: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .my-xxl-4 {
        margin-top: 1.5rem !important;
        margin-bottom: 1.5rem !important;
    }

    .my-xxl-5 {
        margin-top: 3rem !important;
        margin-bottom: 3rem !important;
    }

    .my-xxl-auto {
        margin-top: auto !important;
        margin-bottom: auto !important;
    }

    .mt-xxl-0 {
        margin-top: 0 !important;
    }

    .mt-xxl-1 {
        margin-top: .25rem !important;
    }

    .mt-xxl-2 {
        margin-top: .5rem !important;
    }

    .mt-xxl-3 {
        margin-top: 1rem !important;
    }

    .mt-xxl-4 {
        margin-top: 1.5rem !important;
    }

    .mt-xxl-5 {
        margin-top: 3rem !important;
    }

    .mt-xxl-auto {
        margin-top: auto !important;
    }

    .me-xxl-0 {
        margin-right: 0 !important;
    }

    .me-xxl-1 {
        margin-right: .25rem !important;
    }

    .me-xxl-2 {
        margin-right: .5rem !important;
    }

    .me-xxl-3 {
        margin-right: 1rem !important;
    }

    .me-xxl-4 {
        margin-right: 1.5rem !important;
    }

    .me-xxl-5 {
        margin-right: 3rem !important;
    }

    .me-xxl-auto {
        margin-right: auto !important;
    }

    .mb-xxl-0 {
        margin-bottom: 0 !important;
    }

    .mb-xxl-1 {
        margin-bottom: .25rem !important;
    }

    .mb-xxl-2 {
        margin-bottom: .5rem !important;
    }

    .mb-xxl-3 {
        margin-bottom: 1rem !important;
    }

    .mb-xxl-4 {
        margin-bottom: 1.5rem !important;
    }

    .mb-xxl-5 {
        margin-bottom: 3rem !important;
    }

    .mb-xxl-auto {
        margin-bottom: auto !important;
    }

    .ms-xxl-0 {
        margin-left: 0 !important;
    }

    .ms-xxl-1 {
        margin-left: .25rem !important;
    }

    .ms-xxl-2 {
        margin-left: .5rem !important;
    }

    .ms-xxl-3 {
        margin-left: 1rem !important;
    }

    .ms-xxl-4 {
        margin-left: 1.5rem !important;
    }

    .ms-xxl-5 {
        margin-left: 3rem !important;
    }

    .ms-xxl-auto {
        margin-left: auto !important;
    }

    .p-xxl-0 {
        padding: 0 !important;
    }

    .p-xxl-1 {
        padding: .25rem !important;
    }

    .p-xxl-2 {
        padding: .5rem !important;
    }

    .p-xxl-3 {
        padding: 1rem !important;
    }

    .p-xxl-4 {
        padding: 1.5rem !important;
    }

    .p-xxl-5 {
        padding: 3rem !important;
    }

    .px-xxl-0 {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .px-xxl-1 {
        padding-left: .25rem !important;
        padding-right: .25rem !important;
    }

    .px-xxl-2 {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

    .px-xxl-3 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .px-xxl-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
    }

    .px-xxl-5 {
        padding-left: 3rem !important;
        padding-right: 3rem !important;
    }

    .py-xxl-0 {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .py-xxl-1 {
        padding-top: .25rem !important;
        padding-bottom: .25rem !important;
    }

    .py-xxl-2 {
        padding-top: .5rem !important;
        padding-bottom: .5rem !important;
    }

    .py-xxl-3 {
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .py-xxl-4 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }

    .py-xxl-5 {
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }

    .pt-xxl-0 {
        padding-top: 0 !important;
    }

    .pt-xxl-1 {
        padding-top: .25rem !important;
    }

    .pt-xxl-2 {
        padding-top: .5rem !important;
    }

    .pt-xxl-3 {
        padding-top: 1rem !important;
    }

    .pt-xxl-4 {
        padding-top: 1.5rem !important;
    }

    .pt-xxl-5 {
        padding-top: 3rem !important;
    }

    .pe-xxl-0 {
        padding-right: 0 !important;
    }

    .pe-xxl-1 {
        padding-right: .25rem !important;
    }

    .pe-xxl-2 {
        padding-right: .5rem !important;
    }

    .pe-xxl-3 {
        padding-right: 1rem !important;
    }

    .pe-xxl-4 {
        padding-right: 1.5rem !important;
    }

    .pe-xxl-5 {
        padding-right: 3rem !important;
    }

    .pb-xxl-0 {
        padding-bottom: 0 !important;
    }

    .pb-xxl-1 {
        padding-bottom: .25rem !important;
    }

    .pb-xxl-2 {
        padding-bottom: .5rem !important;
    }

    .pb-xxl-3 {
        padding-bottom: 1rem !important;
    }

    .pb-xxl-4 {
        padding-bottom: 1.5rem !important;
    }

    .pb-xxl-5 {
        padding-bottom: 3rem !important;
    }

    .ps-xxl-0 {
        padding-left: 0 !important;
    }

    .ps-xxl-1 {
        padding-left: .25rem !important;
    }

    .ps-xxl-2 {
        padding-left: .5rem !important;
    }

    .ps-xxl-3 {
        padding-left: 1rem !important;
    }

    .ps-xxl-4 {
        padding-left: 1.5rem !important;
    }

    .ps-xxl-5 {
        padding-left: 3rem !important;
    }

    .gap-xxl-0 {
        gap: 0 !important;
    }

    .gap-xxl-1 {
        gap: .25rem !important;
    }

    .gap-xxl-2 {
        gap: .5rem !important;
    }

    .gap-xxl-3 {
        gap: 1rem !important;
    }

    .gap-xxl-4 {
        gap: 1.5rem !important;
    }

    .gap-xxl-5 {
        gap: 3rem !important;
    }

    .row-gap-xxl-0 {
        row-gap: 0 !important;
    }

    .row-gap-xxl-1 {
        row-gap: .25rem !important;
    }

    .row-gap-xxl-2 {
        row-gap: .5rem !important;
    }

    .row-gap-xxl-3 {
        row-gap: 1rem !important;
    }

    .row-gap-xxl-4 {
        row-gap: 1.5rem !important;
    }

    .row-gap-xxl-5 {
        row-gap: 3rem !important;
    }

    .column-gap-xxl-0 {
        column-gap: 0 !important;
    }

    .column-gap-xxl-1 {
        column-gap: .25rem !important;
    }

    .column-gap-xxl-2 {
        column-gap: .5rem !important;
    }

    .column-gap-xxl-3 {
        column-gap: 1rem !important;
    }

    .column-gap-xxl-4 {
        column-gap: 1.5rem !important;
    }

    .column-gap-xxl-5 {
        column-gap: 3rem !important;
    }

    .text-xxl-start {
        text-align: left !important;
    }

    .text-xxl-end {
        text-align: right !important;
    }

    .text-xxl-center {
        text-align: center !important;
    }
}

@media (width >= 1200px) {
    .fs-1 {
        font-size: 2.5rem !important;
    }

    .fs-2 {
        font-size: 2rem !important;
    }

    .fs-3 {
        font-size: 1.75rem !important;
    }

    .fs-4 {
        font-size: 1.5rem !important;
    }
}

@media print {
    .d-print-inline {
        display: inline !important;
    }

    .d-print-inline-block {
        display: inline-block !important;
    }

    .d-print-block {
        display: block !important;
    }

    .d-print-grid {
        display: grid !important;
    }

    .d-print-inline-grid {
        display: inline-grid !important;
    }

    .d-print-table {
        display: table !important;
    }

    .d-print-table-row {
        display: table-row !important;
    }

    .d-print-table-cell {
        display: table-cell !important;
    }

    .d-print-flex {
        display: flex !important;
    }

    .d-print-inline-flex {
        display: inline-flex !important;
    }

    .d-print-none {
        display: none !important;
    }
}

:root {
    --school-color-auarts: #582877;
    --school-color-scc: #026937;
    --school-color-dsu: #32bcad;
    --school-color-dcsa: #26234f;
    --bs-primary: #3b3b3b;
    --bs-primary-rgb: 0, 0, 0;
    --bs-secondary: #000;
    --bs-secondary-rgb: 128, 128, 128;
}

@supports (color: color-mix(in srgb, red, white)) {
    :root {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

[data-theme="ausu"] {
    --bs-primary: #08225d;
    --bs-primary-rgb: 8, 34, 93;
    --bs-secondary: #526796;
    --bs-secondary-rgb: 82, 103, 150;
}

@supports (color: color-mix(in srgb, red, white)) {
    [data-theme="ausu"] {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

[data-theme="ambrose"] {
    --bs-primary: #000;
    --bs-primary-rgb: 0, 0, 0;
    --bs-secondary: #edab20;
    --bs-secondary-rgb: 237, 171, 32;
}

@supports (color: color-mix(in srgb, red, white)) {
    [data-theme="ambrose"] {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

[data-theme="auarts"] {
    --bs-primary: #582877;
    --bs-primary-rgb: 88, 40, 119;
    --bs-secondary: #b8d548;
    --bs-secondary-rgb: 184, 213, 72;
}

@supports (color: color-mix(in srgb, red, white)) {
    [data-theme="auarts"] {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

[data-theme="scc"] {
    --bs-primary: #026937;
    --bs-primary-rgb: 2, 105, 55;
    --bs-secondary: #ffc627;
    --bs-secondary-rgb: 255, 198, 39;
}

@supports (color: color-mix(in srgb, red, white)) {
    [data-theme="scc"] {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

[data-theme="dsu"] {
    --bs-primary: #32bcad;
    --bs-primary-rgb: 50, 188, 173;
    --bs-secondary: #70bf54;
    --bs-secondary-rgb: 112, 191, 84;
}

@supports (color: color-mix(in srgb, red, white)) {
    [data-theme="dsu"] {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

[data-theme="dcsa"] {
    --bs-primary: #26234f;
    --bs-primary-rgb: 38, 35, 79;
    --bs-secondary: #bfb3be;
    --bs-secondary-rgb: 191, 179, 190;
}

@supports (color: color-mix(in srgb, red, white)) {
    [data-theme="dcsa"] {
        --bs-primary-tint-10: color-mix(in srgb, var(--bs-primary) 90%, white);
        --bs-primary-tint-20: color-mix(in srgb, var(--bs-primary) 80%, white);
        --bs-primary-tint-30: color-mix(in srgb, var(--bs-primary) 70%, white);
        --bs-primary-tint-40: color-mix(in srgb, var(--bs-primary) 60%, white);
        --bs-primary-tint-50: color-mix(in srgb, var(--bs-primary) 50%, white);
        --bs-primary-tint-60: color-mix(in srgb, var(--bs-primary) 40%, white);
        --bs-primary-tint-70: color-mix(in srgb, var(--bs-primary) 30%, white);
        --bs-primary-tint-80: color-mix(in srgb, var(--bs-primary) 20%, white);
        --bs-primary-tint-90: color-mix(in srgb, var(--bs-primary) 10%, white);
        --bs-secondary-tint-10: color-mix(in srgb, var(--bs-secondary) 90%, white);
        --bs-secondary-tint-20: color-mix(in srgb, var(--bs-secondary) 80%, white);
        --bs-secondary-tint-30: color-mix(in srgb, var(--bs-secondary) 70%, white);
        --bs-secondary-tint-40: color-mix(in srgb, var(--bs-secondary) 60%, white);
        --bs-secondary-tint-50: color-mix(in srgb, var(--bs-secondary) 50%, white);
        --bs-secondary-tint-60: color-mix(in srgb, var(--bs-secondary) 40%, white);
        --bs-secondary-tint-70: color-mix(in srgb, var(--bs-secondary) 30%, white);
        --bs-secondary-tint-80: color-mix(in srgb, var(--bs-secondary) 20%, white);
        --bs-secondary-tint-90: color-mix(in srgb, var(--bs-secondary) 10%, white);
    }
}

.primary_nav {
    background-color: var(--bs-primary);
}

    .primary_nav .navbar-brand {
        color: #fff;
        font-size: 1.2rem;
        font-weight: bold;
    }

        .primary_nav .navbar-brand .school_brand-logo {
            max-width: 100%;
            height: auto;
            max-height: 75px;
        }

@media (width >= 992px) {
    .primary_nav .navbar-brand .school_brand-logo {
        max-height: 135px;
    }
}

@media (width >= 1200px) {
    .primary_nav .navbar-brand .school_brand-logo {
        max-height: 125px;
    }
}

.primary_nav .navbar-toggler {
    background-color: hsl(from var(--bs-primary) h s calc(l * .7));
    border: none;
    border-radius: 0;
    width: 75px;
    height: 98px;
    position: absolute;
    right: -10px;
}

    .primary_nav .navbar-toggler .navbar-toggler-icon {
        background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyBmaWxsPSIjRkZGRkZGIiB3aWR0aD0iMTAwcHQiIGhlaWdodD0iMTAwcHQiIHZlcnNpb249IjEuMSIgdmlld0JveD0iMCAwIDEwMCAxMDAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CiA8cGF0aCBkPSJtMjAgMjl2Nmg2MHYtNnptMCAxOHY2aDYwdi02em0wIDE4djZoNjB2LTZ6Ii8+Cjwvc3ZnPgo=");
        width: 38px;
        height: 38px;
    }

    .primary_nav .navbar-toggler:focus {
        box-shadow: none;
        outline: none;
    }

.primary_nav .navbar-nav .nav-item {
    margin: 0 10px;
}

.primary_nav .navbar-nav .nav-link {
    color: #fff;
    font-size: 1rem;
    font-weight: 500;
    transition: color .3s;
}

    .primary_nav .navbar-nav .nav-link:hover {
        color: var(--bs-secondary);
    }

.btn-close {
    --bs-btn-close-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath d='M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-btn-close-opacity: 1;
    width: auto;
    height: auto;
    font-size: 2em;
}

.offcanvas {
    background: hsl(from var(--bs-primary) h s calc(l * .7));
    width: 250px;
    padding: 20px;
}

    .offcanvas .offcanvas-header {
        color: #fff;
        border-bottom: 1px solid #ddd;
    }

    .offcanvas .offcanvas-title {
        font-size: 1.2rem;
        font-weight: bold;
    }

    .offcanvas .navbar-nav .nav-item {
        margin-bottom: 10px;
    }

    .offcanvas .navbar-nav .nav-link {
        color: #fff;
        font-size: 1rem;
        font-weight: 500;
        transition: color .3s;
    }

        .offcanvas .navbar-nav .nav-link:hover {
            color: var(--bs-secondary);
        }

.btn-cta {
    background-color: var(--bs-primary);
    color: #fff;
    border-radius: 2rem;
    align-items: center;
    gap: .5rem;
    width: fit-content;
    padding: .75rem 2.5rem;
    text-decoration: none;
    transition: background-color .3s;
    display: inline-flex;
}

    .btn-cta:hover {
        background-color: hsl(from var(--bs-primary) h s calc(l * .7));
        color: var(--bs-light);
    }

.btn.btn-primary {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: var(--bs-light);
    padding: .35rem 1.5rem;
}

    .btn.btn-primary:hover, .btn.btn-primary:focus, .btn.btn-primary:active {
        background-color: hsl(from var(--bs-primary) h s calc(l * .85));
        border-color: hsl(from var(--bs-primary) h s calc(l * .85));
        color: #fff;
    }

.btn.btn-lg, .btn-group-lg > .btn {
    border-radius: .5rem;
    padding: .75rem 1.5rem;
    font-size: 1.25rem;
}

.btn.btn-sm, .btn-group-sm > .btn {
    border-radius: .25rem;
    padding: .75rem;
    font-size: .875rem;
}

.btn.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

    .btn.btn-outline-primary:hover, .btn.btn-outline-primary:focus, .btn.btn-outline-primary:active {
        background-color: var(--bs-primary);
        border-color: var(--bs-primary);
        color: var(--bs-light);
    }

.btn.btn-secondary {
    background-color: var(--bs-secondary, #6c757d);
    border-color: var(--bs-secondary, #6c757d);
}

    .btn.btn-secondary:hover, .btn.btn-secondary:focus, .btn.btn-secondary:active {
        background-color: hsl(from var(--bs-secondary, #6c757d) h s calc(l * .85));
        border-color: hsl(from var(--bs-secondary, #6c757d) h s calc(l * .85));
    }

.btn.animated-btn {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: var(--bs-light);
    border-radius: var(--bs-border-radius-2xl);
    padding: .375rem .75rem;
    font-weight: 700;
    transition: all .2s ease-in-out;
}

    .btn.animated-btn i {
        margin-right: .5rem;
        transition: transform .3s ease-in-out;
    }

    .btn.animated-btn:hover i {
        animation: .5s ease-in-out iconClipUp;
    }

@keyframes iconClipUp {
    0% {
        opacity: 1;
        transform: translateY(0);
    }

    50% {
        opacity: 0;
        transform: translateY(-100%);
    }

    51% {
        opacity: 0;
        transform: translateY(100%);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.policy-navbar {
    background-color: #fff;
    border-bottom: 1px solid #ddd;
    padding: .5rem 0;
    position: relative;
}

    .policy-navbar .navbar-brand {
        color: #000;
        align-items: center;
        font-size: 1rem;
        font-weight: bold;
        text-decoration: none;
        display: flex;
    }

        .policy-navbar .navbar-brand .svip-logo {
            width: 165px;
            height: auto;
        }

    .policy-navbar .policy-container {
        background-color: rgba(var(--bs-primary-rgb), .1);
        background-color: var(--bs-primary-tint-90);
        border-radius: 20px;
        align-items: center;
        padding: 4px 26px;
        display: flex;
    }

    .policy-navbar .copy-btn {
        cursor: pointer;
        width: 20px;
        height: 20px;
        color: var(--bs-primary);
        float: left;
        background-color: currentColor;
        border: none;
        justify-content: flex-start;
        align-items: flex-start;
        padding: 7px;
        display: flex;
        position: relative;
        left: -12px;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cpath d='m5.9609 2.5938h62.09v29.359h29.359v65.457h-65.457v-29.359h-29.359v-65.457zm62.09 36.098v29.359h-29.359v22.625h51.984v-51.984zm-6.7383-29.359h-51.984v51.984h51.984z'/%3E%3C/svg%3E") center / cover no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100' viewBox='0 0 100 100'%3E%3Cpath d='m5.9609 2.5938h62.09v29.359h29.359v65.457h-65.457v-29.359h-29.359v-65.457zm62.09 36.098v29.359h-29.359v22.625h51.984v-51.984zm-6.7383-29.359h-51.984v51.984h51.984z'/%3E%3C/svg%3E") center / cover no-repeat;
    }

        .policy-navbar .copy-btn:hover {
            color: rgba(var(--bs-primary-rgb), .75);
        }

    .policy-navbar .policy-dropdown {
        color: var(--bs-primary);
        cursor: pointer;
        border-radius: 30px;
        display: inline-block;
        position: relative;
    }

    .policy-navbar .dropdown-toggle {
        background-color: rgba(var(--bs-primary-rgb), .1);
        color: var(--bs-primary);
        cursor: pointer;
        border: none;
        padding: 0;
        font-weight: 500;
    }

    .policy-navbar .dropdown-menu {
        background-color: var(--bs-primary-tint-90);
        border-color: var(--bs-primary-tint-80);
        min-width: 350px;
        min-height: 300px;
        cursor: normal;
        border-radius: 6px;
        margin-top: 8px;
        display: none;
        position: absolute;
        top: 100%;
        left: -35px;
    }

        .policy-navbar .dropdown-menu:before {
            content: "";
            background: none;
            width: 100%;
            height: 8px;
            position: absolute;
            top: -8px;
            left: 0;
        }

    .policy-navbar .policy-dropdown:hover .dropdown-menu {
        display: block;
    }

    .policy-navbar .dropdown-item:hover {
        background-color: rgba(var(--bs-primary-rgb), .1);
    }

.hero.homepage {
    background-image: linear-gradient(330deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.85) 100%), url(/css/hero-bg-school-2025.png);
    align-items: center;
    display: flex;
    position: relative;
    overflow: hidden;
}

    .hero.homepage h1, .hero.homepage .h1 {
        color: #fff;
        text-align: center;
        font-family: Lato, sans-serif;
        font-size: 4.1rem;
        font-weight: 900;
        line-height: 1.25;
    }

        @media only screen and (max-width: 767px) and (min-width: 320px) {
            .hero.homepage h1, .hero.homepage .h1 {
                font-size: 3rem;
                margin-top: 1rem;
            }
        }

    .hero.homepage .hero-bubble {
        position: relative;
    }

        .hero.homepage .hero-bubble span {
            background-repeat: no-repeat;
            height: auto;
            display: block;
            background-size: contain;
            background-position: center center;
        }

        @media only screen and (max-width: 767px) and (min-width: 320px) {
            .hero.homepage .hero-bubble span {
                min-height: 320px !important;
            }
        }

        .hero.homepage .hero-bubble:after {
            content: " ";
            z-index: 2;
            background-image: url("welcome-benefits-bubble-ico.e10d592a.png");
            background-position: center;
            background-repeat: no-repeat;
            background-size: cover;
            width: 193.333px;
            height: 111.852px;
            position: absolute;
            top: 20%;
            left: 90%;
            transform: translate(-50%, -50%);
        }

@media (width >= 768px) {
    .hero.homepage .hero-bubble {
        position: relative;
    }

        .hero.homepage .hero-bubble:after {
            content: " ";
            z-index: 2;
            background-image: url("welcome-benefits-bubble-ico.e10d592a.png");
            background-position: center;
            background-repeat: no-repeat;
            background-size: cover;
            width: 261px;
            height: 151px;
            position: absolute;
            top: 20%;
            left: 90%;
            transform: translate(-50%, -50%);
        }

    .hero.homepage h1, .hero.homepage .h1 {
        text-align: left;
    }
}

.hero-img {
    z-index: 1;
    position: relative;
}

    .hero-img:after {
        content: " ";
        width: 152px;
        height: 140px;
        color: var(--bs-secondary);
        background-color: currentColor;
        position: absolute;
        top: 60%;
        right: 50px;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
    }

    .hero-img:before {
        content: " ";
        width: 152px;
        height: 140px;
        color: hsl(from var(--bs-primary) h s calc(l * .7));
        z-index: -1;
        background-color: currentColor;
        width: 275px;
        height: 275px;
        position: absolute;
        top: 6%;
        left: 25px;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
    }

.alert {
    --bs-alert-bg: hsl(from var(--bs-primary) h s calc(l * .7));
    --bs-alert-color: white;
    --bs-alert-margin-bottom: 0;
    --bs-alert-link-color: var(--bs-primary);
    --bs-alert-border-color: hsl(from var(--bs-primary) h s calc(l * .7));
    --bs-alert-border-radius: 0;
    padding-right: 0;
    font-weight: 300;
}

    .alert.policy-alert {
        background-color: rgba(var(--bs-primary-rgb), .72);
        z-index: 10;
        border-color: #0000;
        position: relative;
    }

    .alert.d2u-alert {
        background-color: rgba(var(--bs-primary-rgb), .22);
        z-index: 10;
        color: var(--bs-dark);
        border-color: #0000;
        position: relative;
    }

.global__alert span {
    display: block;
}

    .global__alert span.bld {
        font-weight: bold;
    }

.global__alert a {
    color: var(--bs-secondary);
}

.global__widgets.widget-sm {
    border-radius: var(--bs-border-radius-lg);
    z-index: 2;
    background-color: rgb(var(--bs-white), 0.9);
    border: 1px solid #dee2e6;
    padding: 1rem 0;
    position: relative;
    top: -10px;
    margin-top: -60px;
    margin-bottom: 60px;
    box-shadow: 0 .125rem .25rem #00000013;
    backdrop-filter: blur(40px);
}

    .global__widgets.widget-sm .nav-link {
        color: #495057;
        text-align: left;
        hyphens: auto;
        align-items: flex-start;
        height: 100%;
        padding: .75rem .5rem;
        text-decoration: none;
        transition: all .2s ease-in-out;
        display: flex;
        .nav-link-ico

{
    background-color: var(--bs-primary);
    max-width: 60px;
    text-align: center;
    display: flex;
    justify-content: center;
    border-radius: 30px;
    padding: 5px 30px;
    img

{
    width: auto;
    max-height: 27px;
}

}
}

.global__widgets.widget-sm .nav-link span {
    flex: 1;
    align-items: center;
    min-width: 0;
    min-height: 30px;
    line-height: 1.2;
    display: flex;
    text-transform: capitalize;
}

.global__widgets.widget-sm .nav-link:hover {
    color: var(--bs-primary);
    background-color: rgba(var(--bs-primary-rgb), .05);
    border-radius: .375rem;
}

@media (width <= 767.98px) {
    .global__widgets.widget-sm .nav-link {
        margin-bottom: 0;
        padding: .5rem;
        font-size: .875rem;
    }
}

.global__widgets.widget-sm i {
    text-align: center;
    background-color: var(--bs-primary);
    color: #fff;
    border-radius: var(--bs-border-radius-2xl);
    flex-shrink: 0;
    justify-content: center;
    align-items: center;
    width: 30px;
    height: 30px;
    margin-right: .5rem;
    padding: 1.25rem;
    display: flex;
}

@media (width >= 768px) {
    .global__widgets.widget-sm .row {
        margin-left: 0;
        margin-right: 0;
    }
}

.global__widgets.widget-sm .container {
    padding: 0 1rem;
}

.global__widgets.widget-sm .row {
    row-gap: 1rem;
}

@media (width <= 767.98px) {
    .global__widgets.widget-sm .row {
        row-gap: .5rem;
    }
}

.global__widgets {
    font-family: Lato, sans-serif;
}

    .global__widgets.widget-md .heading {
        margin-bottom: 1rem 0rem;
        padding-bottom: 45px;
        font-size: 1.35em;
        position: relative;
        color: var(--bs-black);
    }

        .global__widgets.widget-md .heading:after {
            content: "";
            background-color: var(--bs-primary);
            width: 30px;
            height: 3px;
            position: absolute;
            bottom: 30px;
            left: 0;
        }

    .global__widgets.widget-md .helpful-links .btn-container .btn {
        background-color: rgba(var(--bs-primary-rgb), .12);
        border-color: rgba(var(--bs-primary-rgb), .4);
        width: calc(50% - 5px);
        color: var(--bs-dark);
        --bs-btn-padding-x: 1rem;
        --bs-btn-padding-y: .65rem;
        margin-bottom: 10px;
    }

        .global__widgets.widget-md .helpful-links .btn-container .btn:hover {
            background-color: rgba(var(--bs-primary-rgb), .22);
            border-color: rgba(var(--bs-primary-rgb), .4);
        }

@media (width <= 575.98px) {
    .global__widgets.widget-md .helpful-links .btn-container .btn {
        width: 100%;
    }
}

.global__widgets.widget-md .files-and-docs .file-item {
    border-bottom: 1px solid #dee2e6;
    align-items: center;
    gap: .25rem;
    margin-bottom: .65em;
    padding: .25em 1rem;
    font-size: 1.2em;
    display: flex;
}

.global__widgets.widget-md .files-and-docs .file-icon {
    background-color: rgba(var(--bs-primary-rgb), .12);
    border-color: rgba(var(--bs-primary-rgb), .4);
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    display: flex;
    position: relative;
    left: -20px;
}

    .global__widgets.widget-md .files-and-docs .file-icon .text-secondary, .global__widgets.widget-md .files-and-docs .file-icon .far.fa-file-alt.text-secondary {
        color: rgba(var(--bs-primary-rgb), var(--bs-text-opacity)) !important;
    }

.global__widgets.widget-md .files-and-docs .file-name {
    color: var(--bs-black);
    flex-grow: 1;
    font-size: 1rem;
    text-decoration: none;
}

    .global__widgets.widget-md .files-and-docs .file-name:hover {
        text-decoration: underline;
    }

.global__widgets.widget-md .files-and-docs .language-links {
    align-items: center;
    gap: .75rem;
    font-size: 1rem;
    display: flex;
}

    .global__widgets.widget-md .files-and-docs .language-links:hover {
        text-decoration: underline;
    }

    .global__widgets.widget-md .files-and-docs .language-links a {
        color: var(--bs-primary);
        font-weight: 500;
        text-decoration: none;
    }

    .global__widgets.widget-md .files-and-docs .language-links .separator {
        color: var(--bs-primary);
    }

.global__widgets.widget-md .files-and-docs .view-all {
    color: var(--bs-primary);
    margin-top: .5rem;
    font-size: .95rem;
    text-decoration: none;
    display: inline-block;
}

    .global__widgets.widget-md .files-and-docs .view-all:hover {
        text-decoration: underline;
    }

.global__widgets.widget-md .support-tabs .tab-content {
    background-color: rgba(var(--bs-primary-rgb), .12);
    border-color: rgba(var(--bs-primary-rgb), .4);
    padding: 2em !important;
}

.global__widgets.widget-md .support-tabs .nav-tabs {
    display: flex;
}

    .global__widgets.widget-md .support-tabs .nav-tabs .school-logo-pad {
        padding: .5em;
    }

    .global__widgets.widget-md .support-tabs .nav-tabs .nav-item {
        text-align: center;
        flex: 1;
    }

    .global__widgets.widget-md .support-tabs .nav-tabs .nav-link {
        background-color: rgba(var(--bs-primary-rgb), .04);
        border-color: rgba(var(--bs-primary-rgb), .04);
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: .5rem;
        width: 100%;
        height: 100%;
        min-height: 70px;
        padding: 1rem .5rem;
        display: flex;
    }

        .global__widgets.widget-md .support-tabs .nav-tabs .nav-link.nav-link.active {
            background-color: rgba(var(--bs-primary-rgb), .12);
            border-color: rgba(var(--bs-primary-rgb), 0);
        }

        .global__widgets.widget-md .support-tabs .nav-tabs .nav-link i {
            font-size: 1.25rem;
        }

@media (width <= 575.98px) {
    .global__widgets.widget-md .support-tabs .nav-tabs {
        border-bottom: 0;
    }

        .global__widgets.widget-md .support-tabs .nav-tabs .nav-item {
            width: 100%;
            margin-bottom: 2px;
        }

        .global__widgets.widget-md .support-tabs .nav-tabs .nav-link {
            background-color: #f8f9fa;
            border: 1px solid #dee2e6;
            border-radius: 4px;
            flex-direction: row;
            justify-content: flex-start;
            min-height: 50px;
            margin-bottom: 0;
            padding: .75rem 1rem;
        }

            .global__widgets.widget-md .support-tabs .nav-tabs .nav-link.active {
                background-color: rgba(var(--bs-primary-rgb), .12);
                border-color: rgba(var(--bs-primary-rgb), .4);
            }
}

.cards-container {
    margin: 0 auto;
}

.card-wrapper {
    flex-direction: column;
    height: 100%;
    display: flex;
}

.widget-lg {
    background-color: #f8f9fa;
    border: none;
    border-radius: 1rem;
    height: 100%;
    display: flex;
    overflow: hidden;
    box-shadow: 0 4px 6px #0000000d;
}

.card-inner {
    width: 100%;
    display: flex;
}

.card-row {
    flex-wrap: nowrap;
    gap: 2rem;
    width: 100%;
    display: flex;
}

.card-row-reverse {
    flex-direction: row-reverse;
}

.card-image-column {
    flex: none;
    width: 40%;
}

.card-content-column {
    flex-direction: column;
    flex: 1;
    display: flex;
}

.card-image-wrapper {
    height: 100%;
    min-height: 250px;
}

    .card-image-wrapper img {
        object-fit: cover;
        border-radius: .75rem;
        width: 100%;
        height: 100%;
        min-height: 250px;
    }

.card-content {
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
    padding: 1rem;
    display: flex;
}

.card-text-content {
    flex-direction: column;
    flex-grow: 1;
    display: flex;
}

.brand-section {
    margin-bottom: 1.5rem;
}

.logo-wrapper {
    border-radius: 12px;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 1rem;
    display: flex;
}

.title {
    color: #333;
    margin-bottom: 0;
    font-size: 1.5rem;
    font-weight: 600;
}

.description {
    color: #555;
    margin-bottom: 1.5rem;
    font-size: 1rem;
    line-height: 1.5;
}

.card-button-container {
    margin-top: auto;
}

.btn-cta i {
    font-size: 1.1rem;
}

@media (width <= 767px) {
    .cards-container {
        padding: 1rem;
    }

    .widget-lg {
        padding: 1.5rem;
    }

    .card-row {
        flex-direction: column;
        gap: 1rem;
    }

    .card-image-column, .card-content-column {
        width: 100%;
    }

    .card-content {
        padding: 1.5rem 0 0;
    }
}

.sidebar-nav-container {
    background-color: rgba(var(--bs-primary-rgb), .12);
    background-color: var(--bs-light);
    border-radius: 4px;
}

    .sidebar-nav-container .sticky-top {
        color: var(--bs-dark);
        border-radius: 4px 4px 0 0;
    }

    .sidebar-nav-container .sidebar-nav .sidebar-link {
        color: var(--bs-black);
        border-left: 3px solid #0000;
        align-items: flex-start;
        padding: 15px 0;
        text-decoration: none;
        transition: all .3s;
        display: flex;
    }

        .sidebar-nav-container .sidebar-nav .sidebar-link:hover {
            background-color: rgba(var(--bs-primary-rgb), .12);
            border-left: 3px solid var(--bs-primary);
        }

        .sidebar-nav-container .sidebar-nav .sidebar-link.active {
            color: var(--bs-primary);
            border-left: 3px solid rgba(var(--bs-primary-rgb), .42);
            background-color: rgba(var(--bs-primary-rgb), .12);
            text-decoration: underline;
        }

        .sidebar-nav-container .sidebar-nav .sidebar-link i {
            color: var(--bs-primary);
            margin-right: 25px;
        }

@media (width >= 769px) {
    .left-sidebar {
        align-self: flex-start;
        height: fit-content;
        position: -webkit-sticky;
        position: sticky !important;
        top: 20px !important;
    }

        .left-sidebar .p-3.border-bottom.sticky-top, .left-sidebar .p-3.sticky-top.grid-row, .left-sidebar .ai-chat .border-bottom.sticky-top.card-footer, .left-sidebar .ai-chat .sticky-top.card-footer.grid-row, .ai-chat .left-sidebar .border-bottom.sticky-top.card-footer, .ai-chat .left-sidebar .sticky-top.card-footer.grid-row {
            z-index: 1 !important;
            position: relative !important;
            top: auto !important;
        }

        .left-sidebar .sidebar-nav-container, .left-sidebar .coverage-sidebar {
            border: 1px solid #00000020;
            border-radius: .25rem;
            margin-bottom: 20px;
            overflow: hidden;
        }

        .left-sidebar .sidebar-link {
            color: #495057;
            border-bottom: 1px solid #0000000d;
            border-radius: 0;
            padding: .75rem 1rem;
        }

            .left-sidebar .sidebar-link:last-child {
                border-bottom: none;
            }

            .left-sidebar .sidebar-link.active {
                color: #212529;
                background-color: #f8f9fa;
                border-radius: 0;
                font-weight: 500;
            }

            .left-sidebar .sidebar-link:hover {
                background-color: #f1f3f5;
                border-radius: 0;
            }

        .left-sidebar .btn-brand-green {
            text-align: center;
            width: 100%;
        }
}

@media (width <= 768px) {
    .left-sidebar {
        margin-bottom: 1rem;
        position: static !important;
    }

        .left-sidebar .sidebar-nav-container, .left-sidebar .coverage-sidebar {
            display: none;
        }

        .left-sidebar.mobile-nav-active .mobile-dropdown {
            display: block;
        }

    .mobile-section-header {
        z-index: 1000;
        background-color: #fff;
        border-bottom: 1px solid #00000020;
        padding: 10px 15px;
        transition: all .3s;
        display: block;
        position: relative;
    }

        .mobile-section-header.fixed {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            box-shadow: 0 2px 4px #0000001a;
        }

    .dropdown-toggle {
        cursor: pointer;
        background: none;
        border: none;
        padding: 0;
        font-size: 1.5rem;
    }

        .dropdown-toggle:focus {
            outline: none;
        }

    .progress-container {
        direction: ltr;
        background-color: #e0e0e0;
        border-radius: 2px;
        width: 100%;
        height: 4px;
        margin-top: 8px;
        overflow: hidden;
    }

    .progress-bar {
        background-color: var(--bs-primary);
        float: left;
        width: 0;
        height: 100%;
        transition: width .3s ease-out;
    }

    .mobile-dropdown {
        z-index: 999;
        background-color: #fff;
        width: 100%;
        display: none;
        box-shadow: 0 4px 6px #0000001a;
    }

    .mobile-nav-links {
        margin: 0;
        padding: 0;
        list-style: none;
    }

        .mobile-nav-links li {
            border-bottom: 1px solid #0000000d;
        }

            .mobile-nav-links li:last-child {
                border-bottom: none;
            }

        .mobile-nav-links a {
            color: #495057;
            padding: 12px 15px;
            text-decoration: none;
            display: block;
        }

            .mobile-nav-links a.active {
                background-color: rgba(var(--bs-primary-rgb), .12);
                color: var(--bs-primary);
                border-left: 3px solid var(--bs-primary);
            }

            .mobile-nav-links a:hover {
                background-color: #f8f9fa;
            }

            .mobile-nav-links a i {
                color: var(--bs-primary);
                margin-right: 10px;
            }

    .tab-content {
        position: relative;
    }

    .mobile-section-header.fixed + .tab-content {
        padding-top: 60px;
    }
}

.tab-content {
    width: 100%;
    min-height: 250px;
}

.tab-pane {
    width: 100%;
    display: none;
}

    .tab-pane.active.show {
        display: block;
    }

.coverage-grid {
    border: 1px solid #dee2e6;
    border-radius: .25rem;
    margin-bottom: 1.5rem;
    overflow: hidden;
}

@media (width <= 768px) {
    .sidebar-nav-container {
        z-index: 100;
        background-color: #fff;
        margin-bottom: 1rem;
        position: sticky;
        top: 0;
    }

    .tab-content {
        min-height: auto;
    }

    .grid-row {
        flex-direction: column;
    }

    .grid-item {
        border-bottom: 1px solid #dee2e6;
        border-right: none;
    }

        .grid-item:last-child {
            border-bottom: none;
        }
}

.mobile-section-header {
    display: none;
}

.sub-header-hero {
    background-color: var(--bs-white);
    background-position: 100%;
    background-repeat: no-repeat;
    min-height: 100%;
    position: relative;
    overflow: hidden;
}

    .sub-header-hero .header-cols {
        align-items: center !important;
    }

@media (width <= 991.98px) {
    .sub-header-hero .header-cols {
        text-align: center;
        flex-direction: column;
    }
}

.sub-header-hero:after {
    content: "";
    background: linear-gradient(90deg, #fff 30%, #ffffff6e 97%, #fff 100%) center / cover no-repeat;
    width: 100%;
    height: 105%;
    position: absolute;
    top: 0px;
    left: 0;
}

.sub-header-hero .hero-image {
    z-index: 10;
    position: relative;
    right: -35px;
}

    .sub-header-hero .hero-image img {
        max-width: 75%;
    }

    .sub-header-hero .hero-image:before {
        content: " ";
        width: 152px;
        height: 140px;
        color: rgba(var(--bs-primary-rgb), .22);
        z-index: -1;
        background-color: currentColor;
        width: 220px;
        height: 220px;
        position: absolute;
        top: 20%;
        left: -8%;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
    }

    .sub-header-hero .hero-image:after {
        content: " ";
        width: 152px;
        height: 140px;
        color: rgba(var(--bs-secondary-rgb), 1);
        z-index: 2;
        background-color: currentColor;
        width: 120px;
        height: 120px;
        position: absolute;
        bottom: 9%;
        right: 10%;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
    }

.sub-header-hero h1, .sub-header-hero .h1 {
    background: linear-gradient(to bottom, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.75) 20%, rgba(var(--bs-primary-rgb), 1) 60%, var(--bs-primary) 80%);
    -webkit-text-fill-color: transparent;
    z-index: 2;
    background-size: 200%;
    background-clip: text;
    font-size: calc(1.56rem + 3.72vw);
    font-weight: bolder;
    position: relative;
}

@media (width >= 1200px) {
    .sub-header-hero h1, .sub-header-hero .h1 {
        font-size: 3rem;
    }
}

@media (width <= 991.98px) {
    .sub-header-hero h1, .sub-header-hero .h1 {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }
}

.sub-header-hero.support-hero {
    background-color: var(--bs-gray-200);
    justify-content: center;
    align-items: center;
    min-height: 325px;
    margin-bottom: -50px;
    display: flex;
}

    .sub-header-hero.support-hero:before, .sub-header-hero.support-hero:after {
        content: "";
        width: 100%;
        height: 100%;
        display: none;
        position: absolute;
        top: 0;
        left: 0;
    }

    .sub-header-hero.support-hero .header-cols {
        margin-top: -50px;
    }

        .sub-header-hero.support-hero .header-cols h1, .sub-header-hero.support-hero .header-cols .h1 {
            padding-top: 0 !important;
            padding-bottom: 0 !important;
        }

        .sub-header-hero.support-hero .header-cols .header-cols {
            background-color: rgba(var(--bs-primary-rgb), .22);
        }

.form-control:focus {
    border-color: rgba(var(--bs-primary-rgb), .4);
    box-shadow: 0 0 0 .35rem rgba(var(--bs-primary-rgb), .12);
}

input {
    height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
    border-radius: var(--bs-border-radius-2xl) !important;
}

label {
    color: var(--bs-black);
    font-size: 1rem;
    font-weight: 300;
    position: relative;
}

    label:after {
        background-color: var(--bs-primary);
        width: 15px;
        height: 2px;
        position: absolute;
        bottom: -4px;
        left: 0;
    }

form .input-search-container {
    position: relative;
}

    form .input-search-container .search-icon {
        height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
        background-color: var(--bs-primary);
        color: var(--bs-white);
        border-radius: var(--bs-border-radius-2xl);
        cursor: pointer;
        justify-content: center;
        align-items: center;
        width: 55px;
        transition: background-color .2s;
        display: flex;
        position: absolute;
        bottom: 0;
        right: 1px;
    }

        form .input-search-container .search-icon:hover {
            background: hsl(from var(--bs-primary) h s calc(l * 1.2));
        }

.accordion-item {
    margin-bottom: .5rem;
    transition: all .3s;
    border-radius: var(--bs-border-radius) !important;
}

    .accordion-item:hover {
        background-color: rgba(var(--bs-primary-rgb), .5);
    }

        .accordion-item:hover .accordion-button {
            color: var(--bs-light);
            background-color: var(--bs-primary);
        }

            .accordion-item:hover .accordion-button:after {
                filter: brightness(0) invert();
            }

.accordion-button {
    padding: 1.25rem;
    font-weight: 700;
}

    .accordion-button:not(.collapsed) {
        background-color: var(--bs-primary);
        color: var(--bs-light);
    }

        .accordion-button:not(.collapsed):after {
            filter: brightness(0) invert();
        }

    .accordion-button:focus {
        box-shadow: none;
        border-color: rgba(var(--bs-primary-rgb), .5);
    }

.accordion-body {
    background-color: #fff;
    padding: 1.5rem;
}

    .accordion-body ul li {
        margin-bottom: 1rem;
        padding-left: 0;
        position: relative;
    }

        .accordion-body ul li i {
            color: var(--bs-primary);
        }

    .accordion-body .btn {
        transition: all .3s;
    }

.ai-chat .card {
    background-color: hsl(from var(--bs-primary) h s calc(l * .75));
    backdrop-filter: blur(20px);
}

.ai-chat .card-body {
    padding: .5rem;
    --bs-card-border-radius: 3rem !important;
}

    .ai-chat .card-body .d-flex {
        position: relative;
    }

        .ai-chat .card-body .d-flex .robot-icon-container {
            z-index: 10;
            justify-content: center;
            align-items: center;
            width: 46px;
            height: 46px;
            display: flex;
            position: relative;
        }

        .ai-chat .card-body .d-flex .robot-image {
            z-index: 10;
            background-position: center;
            background-repeat: no-repeat;
            background-size: contain;
            width: 46px;
            height: 46px;
            transition: all .3s;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
        }

        .ai-chat .card-body .d-flex .fa-robot {
            opacity: 1;
            color: var(--bs-gray-500);
            justify-content: center;
            align-items: center;
            width: 36px;
            height: 36px;
            font-size: 1.2rem;
            transition: all .3s;
            display: flex;
            position: relative;
        }

            .ai-chat .card-body .d-flex .fa-robot.active {
                color: var(--bs-primary);
            }

            .ai-chat .card-body .d-flex .fa-robot:before {
                content: "";
                background-image: url("static-robot.195bbaef.png");
                background-position: center;
                background-repeat: no-repeat;
                background-size: contain;
                width: 36px;
                height: 36px;
                transition: all .3s;
                position: absolute;
                top: 50%;
                left: 50%;
                transform: translate(-50%, -50%);
            }

            .ai-chat .card-body .d-flex .fa-robot.active:before {
                background-image: url("fa-robot.114ec7b2.gif");
            }

    .ai-chat .card-body .thinking-indicator {
        transition: opacity .3s;
        position: absolute;
        top: 50%;
        right: 90px;
        transform: translateY(-50%);
    }

        .ai-chat .card-body .thinking-indicator .dots-container {
            gap: 4px;
            display: flex;
        }

        .ai-chat .card-body .thinking-indicator .dot {
            background-color: var(--bs-primary);
            border-radius: 50%;
            width: 8px;
            height: 8px;
            animation: 1.2s ease-in-out infinite dotWaveBounce;
            display: inline-block;
        }

            .ai-chat .card-body .thinking-indicator .dot:first-child {
                animation-delay: 0s;
            }

            .ai-chat .card-body .thinking-indicator .dot:nth-child(2) {
                animation-delay: .2s;
            }

            .ai-chat .card-body .thinking-indicator .dot:nth-child(3) {
                animation-delay: .4s;
            }

        .ai-chat .card-body .thinking-indicator.d-none {
            display: none !important;
        }

    .ai-chat .card-body .btn-ai-search {
        background-color: var(--bs-gray-300);
        width: 38px;
        height: 38px;
        color: var(--bs-primary);
        border-color: #0000;
        border-radius: 5rem;
        justify-content: center;
        align-items: center;
        transition: all .3s;
        display: flex;
        position: absolute;
        top: 5px;
        bottom: 0;
        right: 7px;
    }

        .ai-chat .card-body .btn-ai-search i {
            color: var(--bs-primary);
            font-size: 1.35rem;
            transition: all .3s;
        }

        .ai-chat .card-body .btn-ai-search:hover {
            background-color: var(--bs-gray-400);
        }

        .ai-chat .card-body .btn-ai-search:active {
            background-color: rgba(var(--bs-primary-rgb), .85);
        }

        .ai-chat .card-body .btn-ai-search.is-clear {
            background-color: rgba(var(--bs-primary-rgb), .95);
        }

            .ai-chat .card-body .btn-ai-search.is-clear i {
                color: var(--bs-white);
                transform: rotate(0);
            }

            .ai-chat .card-body .btn-ai-search.is-clear:hover {
                background-color: rgba(var(--bs-primary-rgb), .75);
            }

    .ai-chat .card-body .ai-form-control {
        border-color: #0000;
        transition: all .3s;
        border-radius: 8px !important;
    }

        .ai-chat .card-body .ai-form-control:focus {
            box-shadow: 10px 15px 25px rgba(var(--bs-primary-rgb), 1), 0 28px 0 2px #ffffffe6, 1px 0 0 5px rgba(var(--bs-secoundary-rgb), 1);
            border-color: #0000;
            outline: none;
            transition: all .3s ease-in-out;
            animation: 2s ease-in-out infinite gradientBorder;
            position: relative;
        }

            .ai-chat .card-body .ai-form-control:focus:after {
                content: "";
                background: linear-gradient(45deg, var(--bs-primary), var(--bs-secondary), var(--bs-primary), var(--bs-secondary));
                z-index: -1;
                opacity: 1;
                background-size: 300% 300%;
                border-radius: 8px;
                animation: 2s infinite gradientMove;
                position: absolute;
                inset: -3px;
            }

        .ai-chat .card-body .ai-form-control:hover:not(:focus) {
            box-shadow: 0 8px 15px rgba(var(--bs-primary-rgb), .85);
        }

.ai-chat .card-footer {
    border-top: 1px solid #ffffff1a;
    padding: .75rem 1rem;
}

    .ai-chat .card-footer .btn-cta.quick-action-btn {
        color: var(--bs-white);
        background-color: rgba(var(--bs-primary-rgb), .55);
        border: 1px solid #fff3;
        border-radius: 20px;
        padding: .4rem .85rem;
        font-size: .85rem;
        transition: all .3s;
        display: block;
    }

        .ai-chat .card-footer .btn-cta.quick-action-btn i {
            color: var(--bs-secondary);
            margin-right: .75rem;
            font-size: .9rem;
            transition: transform .3s;
        }

        .ai-chat .card-footer .btn-cta.quick-action-btn:hover {
            background-color: rgba(var(--bs-primary-rgb), 1.1);
        }

        .ai-chat .card-footer .btn-cta.quick-action-btn:active {
            transform: translateY(0);
        }

@media (width <= 575.98px) {
    .ai-chat .card-footer .btn-cta.quick-action-btn button {
        width: 100%;
        display: block;
    }
}

.ai-chat .ai-response-container {
    backdrop-filter: blur(20px);
    background-color: hsl(from var(--bs-primary) h s calc(l * .75));
    opacity: 0;
    border-top: none;
    border-radius: 0 0 .75rem .75rem;
    max-height: 0;
    margin-top: 0;
    padding: 2rem;
    transition: max-height .5s cubic-bezier(.4, 0, .8, 1), opacity .4s ease-in-out, transform .4s ease-out;
    overflow: hidden;
    transform: translateY(-10px);
}

    .ai-chat .ai-response-container.fade-in-response {
        opacity: 1;
        max-height: 300px;
        transform: translateY(0);
    }

    .ai-chat .ai-response-container.fade-out-response {
        opacity: 0;
        max-height: 0;
        transform: translateY(-10px);
    }

    .ai-chat .ai-response-container .ai-message {
        color: var(--bs-white);
        max-height: 250px;
        padding: 0;
        font-size: .95rem;
        line-height: 1.5;
        overflow-y: auto;
    }

        .ai-chat .ai-response-container .ai-message a {
            color: var(--bs-white);
            text-decoration: underline;
        }

    .ai-chat .ai-response-container .response-item {
        border-bottom: 1px solid hsl(from var(--bs-primary) h s calc(l * .9));
        color: var(--bs-white);
        background-color: hsl(from var(--bs-primary) h s calc(l * .75));
        padding: .75rem 1.25rem;
        text-decoration: none;
        transition: all .2s;
        display: block;
        position: relative;
    }

        .ai-chat .ai-response-container .response-item .response-content {
            flex-direction: column;
            display: flex;
        }

        .ai-chat .ai-response-container .response-item .response-text {
            margin: 0;
            font-size: .95rem;
            line-height: 1.5;
        }

            .ai-chat .ai-response-container .response-item .response-text .response-link {
                padding-right: .5rem;
                font-weight: bolder;
                text-decoration: underline;
                transition: all .2s;
                position: relative;
            }

                .ai-chat .ai-response-container .response-item .response-text .response-link:after {
                    content: "";
                    opacity: .7;
                    margin-left: .25rem;
                    font-family: "Font Awesome 6 Free";
                    font-size: .75rem;
                    font-weight: 900;
                }

                .ai-chat .ai-response-container .response-item .response-text .response-link:hover {
                    color: var(--bs-white);
                    opacity: .9;
                    text-decoration: none;
                }

                    .ai-chat .ai-response-container .response-item .response-text .response-link:hover:after {
                        opacity: 1;
                    }

        .ai-chat .ai-response-container .response-item:last-child {
            border-bottom: none;
        }

.ai-chat .card.bg-primary.text-white {
    border-radius: 1rem;
}

    .ai-chat .card.bg-primary.text-white .form-control::placeholder {
        color: var(--bs-white);
    }

.ai-chat .card-footer {
    border-top: 1px solid #ffffff1a;
}

    .ai-chat .card-footer .animated-btn.btn {
        color: var(--bs-white);
    }

        .ai-chat .card-footer .animated-btn.btn i {
            color: var(--bs-secondary);
        }

.ai-chat.support-ai-chat .card {
    background-color: var(--bs-white);
}

.ai-chat.support-ai-chat .card-body {
    background-color: var(--bs-white);
    border-radius: .5rem;
    box-shadow: 0 0 10px #00000233;
}

    .ai-chat.support-ai-chat .card-body .ai-assistant-icon {
        z-index: 10;
        pointer-events: auto;
        cursor: pointer;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        width: 32px;
        height: 32px;
        transition: all .3s;
        position: absolute;
        top: 50%;
        right: 60px;
        transform: translateY(-50%);
    }

    .ai-chat.support-ai-chat .card-body .robot-image {
        z-index: 10;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        width: 32px;
        height: 32px;
        transition: all .3s;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    .ai-chat.support-ai-chat .card-body .btn-ai-search {
        background-color: var(--bs-gray-300);
        width: 38px;
        height: 38px;
        color: var(--bs-primary);
        border-color: #0000;
        border-radius: 5rem;
        justify-content: center;
        align-items: center;
        transition: all .3s;
        display: flex;
        position: absolute;
        top: 10px;
        bottom: 0;
        right: 10px;
    }

        .ai-chat.support-ai-chat .card-body .btn-ai-search i {
            color: var(--bs-primary);
            font-size: 1.35rem;
            transition: all .3s;
        }

        .ai-chat.support-ai-chat .card-body .btn-ai-search:hover {
            background-color: var(--bs-gray-400);
        }

        .ai-chat.support-ai-chat .card-body .btn-ai-search:active {
            background-color: rgba(var(--bs-primary-rgb), .85);
        }

        .ai-chat.support-ai-chat .card-body .btn-ai-search.is-clear {
            background-color: rgba(var(--bs-primary-rgb), .95);
        }

            .ai-chat.support-ai-chat .card-body .btn-ai-search.is-clear i {
                color: var(--bs-white);
                transform: rotate(180deg);
            }

            .ai-chat.support-ai-chat .card-body .btn-ai-search.is-clear:hover {
                background-color: rgba(var(--bs-primary-rgb), .75);
            }

    .ai-chat.support-ai-chat .card-body .ai-form-control {
        background-color: var(--bs-white);
        border-color: rgba(var(--bs-primary-rgb), .5);
        border: 3px solid rgba(var(--bs-primary-rgb), .5);
        min-height: 60px;
    }

        .ai-chat.support-ai-chat .card-body .ai-form-control:hover {
            background-color: var(--bs-white);
        }

            .ai-chat.support-ai-chat .card-body .ai-form-control:hover:not(:focus) {
                box-shadow: 0 8px 15px #0000;
            }

.ai-chat.support-ai-chat .card .ai-response-container {
    backdrop-filter: blur(20px);
    background-color: var(--bs-white);
    opacity: 0;
    border-top: none;
    border-radius: 0 0 .75rem .75rem;
    max-height: 0;
    margin-top: 0;
    padding: 0 25px;
    transition: max-height .5s cubic-bezier(.4, 0, .8, 1), opacity .4s ease-in-out, transform .4s ease-out;
    overflow: hidden;
    transform: translateY(-10px);
}

    .ai-chat.support-ai-chat .card .ai-response-container.fade-in-response {
        opacity: 1;
        max-height: 300px;
        transform: translateY(0);
    }

    .ai-chat.support-ai-chat .card .ai-response-container.fade-out-response {
        opacity: 0;
        max-height: 0;
        transform: translateY(-10px);
    }

    .ai-chat.support-ai-chat .card .ai-response-container .ai-message {
        color: var(--bs-gray-900);
        max-height: 250px;
        padding: 0;
        font-size: .95rem;
        line-height: 1.65;
        overflow-y: auto;
    }

        .ai-chat.support-ai-chat .card .ai-response-container .ai-message a {
            color: var(--bs-primary);
            font-weight: bolder;
            text-decoration: underline;
        }

    .ai-chat.support-ai-chat .card .ai-response-container .response-item {
        border-bottom: 1px solid hsl(from var(--bs-white) h s calc(l * .9));
        color: var(--bs-dark);
        background-color: var(--bs-white);
        padding: .75rem 1.25rem;
        text-decoration: none;
        transition: all .2s;
        display: block;
        position: relative;
    }

        .ai-chat.support-ai-chat .card .ai-response-container .response-item a {
            color: var(--bs-dark);
        }

        .ai-chat.support-ai-chat .card .ai-response-container .response-item:last-child {
            border-bottom: none;
        }

        .ai-chat.support-ai-chat .card .ai-response-container .response-item:hover {
            background-color: var(--bs-gray-200);
            color: var(--bs-dark);
            padding-right: 2.25rem;
        }

            .ai-chat.support-ai-chat .card .ai-response-container .response-item:hover .item-icon {
                opacity: 1;
                right: 1.25rem;
            }

        .ai-chat.support-ai-chat .card .ai-response-container .response-item .item-icon {
            opacity: 0;
            color: var(--bs-dark);
            font-size: .85rem;
            transition: all .2s;
            position: absolute;
            top: 50%;
            right: 1.75rem;
            transform: translateY(-50%);
        }

@keyframes pulseFade {
    0% {
        opacity: .4;
    }

    50% {
        opacity: .9;
    }

    100% {
        opacity: .4;
    }
}

@keyframes dotWaveBounce {
    0%, 100% {
        opacity: .6;
        transform: translateY(0);
    }

    25% {
        opacity: 1;
        transform: translateY(-8px);
    }

    50% {
        opacity: .8;
        transform: translateY(0);
    }

    75% {
        opacity: .9;
        transform: translateY(-4px);
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0;
        transform: translateY(10px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes expandSection {
    from {
        max-height: 0;
    }

    to {
        max-height: 300px;
    }
}

@keyframes fadeInResponse {
    0% {
        opacity: 0;
        transform: translateY(-5px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes collapseSection {
    from {
        opacity: 1;
        max-height: 300px;
    }

    to {
        opacity: 0;
        max-height: 0;
    }
}

@keyframes gradientBorder {
    0% {
        border-color: rgba(var(--bs-primary-rgb), .5);
        box-shadow: 0 5px 15px rgba(var(--bs-primary-rgb), .2), 0 0 0 2px #fff6, 0 0 0 4px rgba(var(--bs-primary-rgb), .2);
    }

    50% {
        border-color: rgba(var(--bs-info-rgb), .5);
        box-shadow: 0 8px 20px rgba(var(--bs-info-rgb), .25), 0 0 0 2px #fff6, 0 0 0 4px rgba(var(--bs-info-rgb), .2);
    }

    100% {
        border-color: rgba(var(--bs-primary-rgb), .5);
        box-shadow: 0 5px 15px rgba(var(--bs-primary-rgb), .2), 0 0 0 2px #fff6, 0 0 0 4px rgba(var(--bs-primary-rgb), .2);
    }
}

@keyframes robotPulse {
    0% {
        opacity: .9;
        transform: scale(1);
    }

    50% {
        opacity: 1;
        transform: scale(1.1);
    }

    100% {
        opacity: .9;
        transform: scale(1.02);
    }
}

.thinking-state {
    padding: .75rem 0;
}

    .thinking-state .thinking-dots-container {
        gap: 5px;
        margin-top: 8px;
        display: flex;
    }

    .thinking-state .thinking-dot {
        background-color: var(--bs-primary);
        opacity: .7;
        border-radius: 50%;
        width: 10px;
        height: 10px;
        animation: 1.5s ease-in-out infinite thinkingDotPulse;
        display: inline-block;
    }

        .thinking-state .thinking-dot:first-child {
            animation-delay: 0s;
        }

        .thinking-state .thinking-dot:nth-child(2) {
            animation-delay: .3s;
        }

        .thinking-state .thinking-dot:nth-child(3) {
            animation-delay: .6s;
        }

@keyframes thinkingDotPulse {
    0%, 100% {
        opacity: .5;
        transform: scale(1);
    }

    50% {
        opacity: 1;
        transform: scale(1.3);
    }
}

.thinking-animation .dots-container {
    gap: 4px;
    display: flex;
}

.thinking-animation .dot {
    background-color: var(--bs-primary);
    border-radius: 50%;
    width: 8px;
    height: 8px;
    animation: 1.4s ease-in-out infinite dotWaveBounce;
    display: inline-block;
}

    .thinking-animation .dot:first-child {
        animation-delay: 0s;
    }

    .thinking-animation .dot:nth-child(2) {
        animation-delay: .2s;
    }

    .thinking-animation .dot:nth-child(3) {
        animation-delay: .4s;
    }

@keyframes robotActivate {
    0% {
        color: #888;
        transform: scale(1);
    }

    50% {
        transform: scale(1.1);
    }

    100% {
        color: #06f;
        transform: scale(1);
    }
}

@keyframes robotDeactivate {
    0% {
        color: #06f;
        transform: scale(1);
    }

    50% {
        transform: scale(.9);
    }

    100% {
        color: #888;
        transform: scale(1);
    }
}

@keyframes robotShake {
    0%, 100% {
        transform: translateX(0);
    }

    25% {
        transform: translateX(-5px);
    }

    75% {
        transform: translateX(5px);
    }
}

.search-suggestions {
    margin-top: 1rem;
}

    .search-suggestions h4, .search-suggestions .h4 {
        color: #666;
        margin-bottom: .5rem;
        font-size: .9rem;
    }

    .search-suggestions .suggestion-tags {
        flex-wrap: wrap;
        gap: .5rem;
        display: flex;
    }

        .search-suggestions .suggestion-tags .tag {
            color: #495057;
            cursor: pointer;
            background-color: #f8f9fa;
            border: 1px solid #e9ecef;
            border-radius: 1rem;
            padding: .25rem .75rem;
            font-size: .9rem;
            transition: all .3s ease-in-out;
        }

            .search-suggestions .suggestion-tags .tag:hover {
                color: #212529;
                background-color: #e9ecef;
                border-color: #dee2e6;
            }

.search-results {
    margin-top: 2rem;
}

    .search-results .result-stats {
        color: #6c757d;
        margin-bottom: 1rem;
        font-size: .9rem;
    }

    .search-results .result-filters {
        gap: 1rem;
        margin-bottom: 1rem;
        display: flex;
    }

        .search-results .result-filters .filter {
            color: #495057;
            cursor: pointer;
            background-color: #f8f9fa;
            border: 1px solid #e9ecef;
            border-radius: .25rem;
            align-items: center;
            gap: .5rem;
            padding: .5rem 1rem;
            font-size: .9rem;
            transition: all .3s ease-in-out;
            display: flex;
        }

            .search-results .result-filters .filter:hover {
                color: #212529;
                background-color: #e9ecef;
                border-color: #dee2e6;
            }

            .search-results .result-filters .filter.active {
                color: #fff;
                background-color: #06c;
                border-color: #06c;
            }

                .search-results .result-filters .filter.active:hover {
                    background-color: #0052a3;
                    border-color: #0052a3;
                }

            .search-results .result-filters .filter .fas {
                font-size: .8rem;
            }

.loading-state {
    background-color: #0000;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    min-height: 100px;
    padding: 1.5rem;
    display: flex;
}

    .loading-state .thinking-dots .dot {
        background-color: var(--bs-primary);
        border-radius: 50%;
        width: 8px;
        height: 8px;
        animation: 1.4s ease-in-out infinite thinking;
    }

@keyframes thinking {
    0%, 100% {
        transform: translateY(0);
    }

    25% {
        transform: translateY(-6px);
    }

    50% {
        transform: translateY(0);
    }

    75% {
        transform: translateY(6px);
    }
}

.ai-response-container {
    opacity: 0;
    transition: opacity .3s, transform .3s;
    transform: translateY(10px);
}

    .ai-response-container.fade-in-response {
        opacity: 1;
        transform: translateY(0);
    }

    .ai-response-container.fade-out-response {
        opacity: 0;
        transform: translateY(-10px);
    }

main.homepage .ai-chat .loading-state {
    background-color: #0000;
}

.robot-icon-container .fa-robot {
    color: var(--bs-gray-500);
    transition: color .3s;
}

.robot-icon-container.active .fa-robot {
    color: var(--bs-primary);
}

.thinking-indicator {
    transition: opacity .3s;
    position: absolute;
    top: 50%;
    right: 90px;
    transform: translateY(-50%);
}

    .thinking-indicator .dots-container {
        gap: 4px;
        display: flex;
    }

    .thinking-indicator .dot {
        background-color: var(--bs-primary);
        border-radius: 50%;
        width: 8px;
        height: 8px;
        animation: 1.5s ease-in-out infinite dotWave;
        display: inline-block;
    }

        .thinking-indicator .dot:first-child {
            animation-delay: 0s;
        }

        .thinking-indicator .dot:nth-child(2) {
            animation-delay: .2s;
        }

        .thinking-indicator .dot:nth-child(3) {
            animation-delay: .4s;
        }

    .thinking-indicator.d-none {
        display: none !important;
    }

@keyframes dotWave {
    0%, 100% {
        transform: translateY(0);
    }

    25% {
        transform: translateY(-6px);
    }

    50% {
        transform: translateY(0);
    }

    75% {
        transform: translateY(6px);
    }
}

.ai-response-container {
    background-color: var(--bs-white);
    box-shadow: none;
    border-radius: 0;
    margin-top: 1rem;
    padding: 1.5rem;
}

.homepage-indicator ~ .ai-chat .ai-response-container {
    background-color: var(--bs-primary);
    padding: 2rem;
}

    .homepage-indicator ~ .ai-chat .ai-response-container .ai-message {
        padding: 0 1rem;
    }

.loading-state {
    padding: 1.5rem;
    background-color: #0000 !important;
}

    .loading-state .thinking-dots {
        gap: .5rem;
        display: flex;
    }

        .loading-state .thinking-dots .dot {
            border-radius: 50%;
            width: 8px;
            height: 8px;
            animation: 1.4s ease-in-out infinite thinking;
        }

            .loading-state .thinking-dots .dot:first-child {
                animation-delay: -.32s;
            }

            .loading-state .thinking-dots .dot:nth-child(2) {
                animation-delay: -.16s;
            }

.homepage-indicator ~ .ai-response-container .loading-state .thinking-dots .dot {
    background-color: var(--bs-white);
}

.support-ai-chat .loading-state .thinking-dots .dot {
    background-color: var(--bs-primary);
}

.opt-in-out .payment-methods .payment-option {
    border: 1px solid var(--bs-gray-300);
    background-color: var(--bs-white);
    transition: all .3s;
}

    .opt-in-out .payment-methods .payment-option:hover {
        transition: all .3s;
        border-color: var(--bs-primary) !important;
        background-color: rgba(var(--bs-primary-rgb), .1) !important;
    }

.multi-step-form {
    margin: 2.5rem 0;
    position: relative;
}

    .multi-step-form .stepper-container {
        z-index: 1000;
        background-color: #fff;
        width: 100%;
        padding: 1rem 0;
        transition: box-shadow .3s;
        position: sticky;
        top: 0;
    }

        .multi-step-form .stepper-container.scrolled {
            background-color: rgba(var(--bs-white-rgb), .5);
            backdrop-filter: blur(20px);
            box-shadow: 0 0 2px #0000001a;
        }

    .multi-step-form .stepper-wrapper {
        justify-content: space-between;
        align-items: center;
        width: 100%;
        max-width: 100%;
        margin: 0 auto;
        padding: 0 25px;
        display: flex;
        position: relative;
    }

        .multi-step-form .stepper-wrapper:before {
            content: "";
            z-index: 1;
            background-color: #e9ecef;
            height: 3px;
            position: absolute;
            top: 15px;
            left: 90px;
            right: 50px;
        }

        .multi-step-form .stepper-wrapper:after {
            content: "";
            background-color: var(--bs-primary);
            z-index: 2;
            width: 0;
            height: 3px;
            transition: width .3s;
            position: absolute;
            top: 15px;
            left: 90px;
        }

        .multi-step-form .stepper-wrapper[data-progress="0"]:after {
            width: 0;
        }

        .multi-step-form .stepper-wrapper[data-progress="1"]:after {
            width: calc(33.33% - 16px);
        }

        .multi-step-form .stepper-wrapper[data-progress="2"]:after {
            width: calc(61.66% - 16px);
        }

        .multi-step-form .stepper-wrapper[data-progress="3"]:after {
            width: calc(91% - 50px);
        }

        .multi-step-form .stepper-wrapper .stepper-item {
            z-index: 5;
            flex-direction: column;
            align-items: center;
            display: flex;
            position: relative;
        }

            .multi-step-form .stepper-wrapper .stepper-item .step-counter {
                width: 30px;
                height: 30px;
                color: var(--bs-gray-500);
                z-index: 10;
                background-color: #fff;
                border: 2px solid #cdd0d6;
                border-radius: 50%;
                justify-content: center;
                align-items: center;
                margin-bottom: 8px;
                font-size: 14px;
                font-weight: 500;
                display: flex;
                position: relative;
            }

                .multi-step-form .stepper-wrapper .stepper-item .step-counter .number {
                    line-height: 1;
                }

                .multi-step-form .stepper-wrapper .stepper-item .step-counter .fa-check {
                    font-size: 12px;
                    line-height: 1;
                }

            .multi-step-form .stepper-wrapper .stepper-item .step-name {
                color: var(--bs-gray-500);
                text-align: center;
                font-size: .875rem;
                font-weight: 500;
            }

            .multi-step-form .stepper-wrapper .stepper-item.active .step-counter {
                background-color: var(--bs-primary);
                border-color: var(--bs-primary);
                color: #fff;
            }

            .multi-step-form .stepper-wrapper .stepper-item.active .step-name {
                color: var(--bs-primary);
                font-weight: 600;
            }

            .multi-step-form .stepper-wrapper .stepper-item.completed .step-counter {
                background-color: var(--bs-primary);
                border-color: var(--bs-primary);
                color: #fff;
            }

            .multi-step-form .stepper-wrapper .stepper-item.completed .step-name {
                color: var(--bs-primary);
            }

        .multi-step-form .stepper-wrapper .connector, .multi-step-form .stepper-wrapper .connector-progress {
            display: none;
        }

    .multi-step-form .form-step {
        background-color: var(--bs-gray-200);
        border-radius: .375rem;
        width: 100%;
        margin-top: 1rem;
        padding: 1.5rem;
        display: none;
        box-shadow: 0 .125rem .25rem #00000013;
    }

        .multi-step-form .form-step.active {
            animation: .3s ease-in-out fadeIn;
            display: block;
        }

        .multi-step-form .form-step h3, .multi-step-form .form-step .h3 {
            color: var(--bs-primary);
            margin-bottom: 1.5rem;
            font-weight: 600;
        }

    .multi-step-form .form-navigation {
        justify-content: space-between;
        gap: 1rem;
        margin-top: 2rem;
        display: flex;
    }

        .multi-step-form .form-navigation .btn-prev, .multi-step-form .form-navigation .btn-next, .multi-step-form .form-navigation .btn-submit {
            border-radius: 4px;
            min-width: 140px;
            padding: .75rem 1.5rem;
            font-size: 1rem;
            font-weight: 500;
        }

        .multi-step-form .form-navigation .btn-prev {
            color: #495057;
            background-color: #ced4da;
        }

            .multi-step-form .form-navigation .btn-prev:hover {
                background-color: #dee2e6;
            }

        .multi-step-form .form-navigation .btn-next, .multi-step-form .form-navigation .btn-submit {
            background-color: var(--bs-primary);
            color: #fff;
            margin-left: auto;
        }

            .multi-step-form .form-navigation .btn-next:hover, .multi-step-form .form-navigation .btn-submit:hover {
                background-color: hsl(from var(--bs-primary) h s calc(l * .8));
                color: #fff;
            }

            .multi-step-form .form-navigation .btn-next:active, .multi-step-form .form-navigation .btn-submit:active {
                background-color: hsl(from var(--bs-primary) h s calc(l * .8));
                transform: translateY(1px);
            }

            .multi-step-form .form-navigation .btn-next:focus, .multi-step-form .form-navigation .btn-submit:focus {
                box-shadow: 0 0 0 .25rem #4ea15240;
            }

        .multi-step-form .form-navigation .btn-submit {
            min-width: 200px;
            font-weight: 600;
        }

    .multi-step-form .form-control, .multi-step-form .form-select {
        border: 1px solid #dee2e6;
        height: calc(3rem + 2px);
        padding: .75rem;
        line-height: 1.5;
        transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
        border-radius: 4px !important;
    }

        .multi-step-form .form-control:focus, .multi-step-form .form-select:focus {
            border-color: #4ea152;
            outline: 0;
            box-shadow: 0 0 0 .25rem #4ea15240;
        }

        .multi-step-form .form-control.is-invalid, .multi-step-form .form-select.is-invalid {
            background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%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='%23dc3545' stroke='none'/%3e%3c/svg%3e");
            background-position: right calc(.375em + .1875rem) center;
            background-repeat: no-repeat;
            background-size: calc(.75em + .375rem) calc(.75em + .375rem);
            border-color: #dc3545;
        }

            .multi-step-form .form-control.is-invalid:focus, .multi-step-form .form-select.is-invalid:focus {
                border-color: #dc3545;
                box-shadow: 0 0 0 .25rem #dc354540;
            }

    .multi-step-form .form-select {
        background-position: right .75rem center;
        padding-right: 2.25rem;
    }

        .multi-step-form .form-select:focus {
            border-color: #4ea152;
            outline: 0;
            box-shadow: 0 0 0 .25rem #4ea15240;
        }

    .multi-step-form .form-label {
        color: #6c757d;
        margin-bottom: .2rem;
        font-weight: 400;
        text-decoration: none !important;
    }

        .multi-step-form .form-label:after {
            display: none !important;
        }

        .multi-step-form .form-label.fw-medium {
            color: #495057;
            margin-bottom: .5rem;
            font-weight: 500;
        }

    .multi-step-form .dependant-card .card {
        border: 1px solid #e9ecef;
        box-shadow: 0 2px 4px #0000000d;
    }

        .multi-step-form .dependant-card .card .card-header {
            background-color: #f8f9fa;
            border-bottom: 1px solid #e9ecef;
        }

            .multi-step-form .dependant-card .card .card-header h6, .multi-step-form .dependant-card .card .card-header .h6 {
                color: #495057;
                font-size: .95rem;
            }

            .multi-step-form .dependant-card .card .card-header .btn-link {
                padding: .25rem .5rem;
                text-decoration: none;
            }

                .multi-step-form .dependant-card .card .card-header .btn-link:hover {
                    background-color: #4ea1521a;
                    border-radius: .25rem;
                }

                .multi-step-form .dependant-card .card .card-header .btn-link i {
                    font-size: .875rem;
                }

        .multi-step-form .dependant-card .card .collapse {
            transition: all .2s ease-in-out;
        }

    .multi-step-form #dependents-container .dependent-card {
        border: 1px solid #dee2e6;
        border-radius: .375rem;
        transition: all .2s;
        overflow: hidden;
    }

        .multi-step-form #dependents-container .dependent-card:hover {
            box-shadow: 0 .125rem .25rem #00000013;
        }

        .multi-step-form #dependents-container .dependent-card .card-header {
            cursor: pointer;
            background-color: #f8f9fa;
            border-bottom: 1px solid #dee2e6;
            padding: .75rem 1rem;
            transition: background-color .2s;
        }

            .multi-step-form #dependents-container .dependent-card .card-header:hover {
                background-color: #e9ecef;
            }

            .multi-step-form #dependents-container .dependent-card .card-header h6, .multi-step-form #dependents-container .dependent-card .card-header .h6 {
                color: #343a40;
                margin: 0;
                font-weight: 600;
            }

            .multi-step-form #dependents-container .dependent-card .card-header .status-badge {
                padding: .2rem .5rem;
                font-size: .7rem;
                font-weight: 500;
            }

            .multi-step-form #dependents-container .dependent-card .card-header .btn-group .btn {
                z-index: 5;
                padding: .25rem .5rem;
            }

                .multi-step-form #dependents-container .dependent-card .card-header .btn-group .btn:hover {
                    background-color: #e9ecef;
                }

                .multi-step-form #dependents-container .dependent-card .card-header .btn-group .btn.btn-outline-danger:hover {
                    color: #dc3545;
                    background-color: #dc35451a;
                    border-color: #dc3545;
                }

        .multi-step-form #dependents-container .dependent-card .collapse, .multi-step-form #dependents-container .dependent-card .collapsing {
            border-top: 0;
        }

        .multi-step-form #dependents-container .dependent-card .card-body {
            background-color: #fff;
            padding: 1rem;
        }

        .multi-step-form #dependents-container .dependent-card .form-floating > .form-control {
            height: calc(3.5rem + 2px);
            padding: 1rem .75rem;
        }

        .multi-step-form #dependents-container .dependent-card .form-floating > label {
            padding: 1rem .75rem;
        }

        .multi-step-form #dependents-container .dependent-card.complete .card-header {
            border-left: 4px solid #198754;
        }

            .multi-step-form #dependents-container .dependent-card.complete .card-header .status-badge {
                background-color: #198754 !important;
            }

    .multi-step-form #dependent-template {
        display: none;
    }

    .multi-step-form #add-dependent {
        transition: all .2s;
    }

        .multi-step-form #add-dependent:hover {
            color: #fff;
            background-color: #0d6efd;
            transform: translateY(-2px);
        }

        .multi-step-form #add-dependent i {
            transition: all .2s;
        }

        .multi-step-form #add-dependent:hover i {
            transform: rotate(90deg);
        }

    .multi-step-form #add-dependant {
        transition: all .2s ease-in-out;
    }

        .multi-step-form #add-dependant:hover {
            background-color: #4ea1521a;
        }

    .multi-step-form .confirmation-icon {
        color: var(--bs-success);
        margin-bottom: 1.5rem;
        font-size: 4rem;
    }

        .multi-step-form .confirmation-icon .fa-check-circle {
            animation: .5s ease-in-out scaleIn;
        }

    .multi-step-form .download-receipt {
        transition: all .2s;
    }

        .multi-step-form .download-receipt:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 8px #0000001a;
        }

    .multi-step-form #confirmation-plan-details, .multi-step-form #confirmation-family-members {
        background-color: #f8f9fa80;
        border-radius: .25rem;
    }

@keyframes scaleIn {
    0% {
        opacity: 0;
        transform: scale(.5);
    }

    70% {
        transform: scale(1.1);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.multi-step-form #plan-total-badge, .multi-step-form #total-cost-display, .multi-step-form #dependent-cost-display, .multi-step-form #total-amount, .multi-step-form #payment-dependent-cost, .multi-step-form #confirmation-total {
    transition: all .5s;
}

.multi-step-form .price-highlight {
    border-color: var(--bs-primary);
    animation: .7s pricePulse;
}

@keyframes pricePulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.1);
    }

    100% {
        transform: scale(1);
    }
}

@media (width <= 767.98px) {
    .multi-step-form .stepper-wrapper .stepper-item .step-name {
        font-size: .75rem;
    }

    .multi-step-form .stepper-wrapper .stepper-item .step-counter {
        width: 28px;
        height: 28px;
    }
}

.multi-step-form .form-step .row.g-4 #dependentCount, .multi-step-form .form-step .row.g-4 #planType {
    background-color: #fff;
    height: calc(3rem + 2px);
    padding: .75rem 1rem;
    font-size: 1rem;
}

    .multi-step-form .form-step .row.g-4 #dependentCount:focus, .multi-step-form .form-step .row.g-4 #planType:focus {
        border-color: var(--bs-primary);
    }

.footer-cta {
    color: var(--bs-white);
    background-image: linear-gradient(90deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 1) 100%);
    height: 100%;
    min-height: 300px;
    display: flex;
    position: relative;
}

    .footer-cta:after {
        content: " ";
        z-index: 0;
        background-color: #fff;
        width: 100%;
        height: 50px;
        position: absolute;
    }

@media (width <= 575.98px) {
    .footer-cta {
        text-align: center;
        justify-content: center;
        align-items: center;
    }

        .footer-cta:after {
            display: none;
        }
}

.footer-cta .container {
    height: 100%;
}

.footer-cta .row {
    align-items: center;
    height: 100%;
}

.footer-cta h4, .footer-cta .h4 {
    margin-bottom: 1rem;
    font-weight: 700;
}

.footer-cta p {
    margin: 0;
    font-size: 1.125rem;
}

.footer-cta .col-lg-4 {
    height: 100%;
}

.footer-cta .bg-brand-chevron {
    z-index: 3;
    height: 100%;
    min-height: 300px;
    position: relative;
}

    .footer-cta .bg-brand-chevron:before {
        content: " ";
        width: 152px;
        height: 140px;
        color: hsl(from var(--bs-primary) h s calc(l * .4));
        z-index: 0;
        background-color: currentColor;
        width: 195px;
        height: 195px;
        position: absolute;
        top: 55px;
        left: 110px;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
    }

    .footer-cta .bg-brand-chevron:after {
        content: " ";
        width: 152px;
        height: 140px;
        color: rgba(var(--bs-secondary-rgb), 1);
        z-index: 3;
        background-color: currentColor;
        width: 125px;
        height: 125px;
        position: absolute;
        bottom: 20px;
        right: -20px;
        -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
        mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='152' height='140' viewBox='0 0 152 140'%3E%3Cpath fill='none' stroke='%23000000' stroke-width='15' d='M110.438 16L77.926 73.9067H13L45.4136 132H110.438L143 73.9915L110.438 16Z'/%3E%3C/svg%3E") center / contain no-repeat;
    }

@media (width <= 575.98px) {
    .footer-cta .bg-brand-chevron {
        min-height: 150px;
    }

        .footer-cta .bg-brand-chevron:before, .footer-cta .bg-brand-chevron:after {
            display: none;
        }
}

.footer-cta .bg-cta {
    z-index: 1;
    justify-content: center;
    align-items: center;
    height: 100%;
    min-height: 300px;
    display: flex;
    position: relative;
    overflow: hidden;
}

@media (width <= 575.98px) {
    .footer-cta .bg-cta {
        min-height: 100px;
    }
}

.footer-cta .bg-cta:before {
    content: "";
    z-index: 0;
    background-image: url("no-bg-telemarketing-workers-sitting-at-call-center-and-t-2024-01-23-19-15-14-utc 1.2be51293.png");
    background-repeat: no-repeat;
    justify-content: center;
    align-items: center;
    width: 90%;
    height: 100%;
    display: flex;
    position: absolute;
    background-size: contain;
    background-position-x: 90%;
}

/*.footer-cta .bg-cta:after {
    content: " ";
    background-image: linear-gradient(90deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), .8) 30%, rgba(var(--bs-primary-rgb), 0) 70%);
    z-index: 1;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 15px;
    left: 0;
    z-index:-1;
}*/

@media (width <= 575.98px) {
    .footer-cta .bg-cta:before, .footer-cta .bg-cta:after {
        display: none;
    }
}

.footer-cta .content-cta {
    padding-top: 50px;
}

.footer-cta::before {
    content:"";
    height: 45px;
    background-color: var(--bs-white);
    position:absolute;
    top:0;
    left:0;
    width: 100%;
}

.footer-cta .cta-btn {
    background-color: rgba(var(--bs-secondary-rgb), 1);
    color: var(--bs-dark);
    z-index: 3;
    border-radius: 50px;
    margin-top: 0px;
    padding: .75rem 1.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: all .3s;
    position: relative;
    margin: .75rem 0rem;
    display: inline-flex;
}

    .footer-cta .cta-btn:hover {
        background-color: rgba(var(--bs-secondary-rgb), .9);
        color: var(--bs-dark);
        text-decoration: underline;
    }

.footer-top {
    background-color: hsl(from var(--bs-primary) h s calc(l * .7));
    padding: 1rem 0;
    display: flex;
}

    .footer-top .logo, .footer-top .footer-nav {
        text-align: center;
        flex: none;
        width: 100%;
        padding: 1rem 0;
    }

        .footer-top .logo a, .footer-top .footer-nav a {
            color: #fff;
            padding: 1rem 8px;
            text-decoration: none;
        }

            .footer-top .logo a:hover, .footer-top .footer-nav a:hover {
                color: var(--bs-secondary);
            }

@media (width >= 768px) {
    .footer {
        flex: none;
        width: 100%;
    }

        .footer .logo, .footer .footer-nav {
            text-align: center;
            float: left;
            flex: none;
            align-items: center;
            width: 50%;
            min-height: 78px;
        }

        .footer .logo {
            float: left;
            align-items: flex-start;
            display: flex;
        }

        .footer .footer-nav {
            flex-direction: row-reverse;
            display: flex;
        }
}

.footer-bottom {
    background-color: hsl(from var(--bs-primary) h s calc(l * .5));
    color: #fff;
    flex: none;
    width: 100%;
    padding: 1rem 6px;
    display: flex;
}

    .footer-bottom .copyrights, .footer-bottom .social {
        text-align: center;
        flex: none;
        justify-content: center;
        align-items: center;
        width: 100%;
        display: flex;
    }

@media (width >= 576px) {
    .footer-bottom .social, .footer-bottom .copyrights {
        float: left;
        color: #fff;
        flex: none;
        width: 50%;
    }

    .footer-bottom .copyrights {
        justify-content: flex-start;
        display: flex;
    }

    .footer-bottom .social {
        justify-content: flex-end;
        display: flex;
    }

    .footer-bottom .copyrights p {
        margin: 0;
    }
}

.social a {
    transition: transform .2s;
}

    .social a:hover {
        transform: translateY(-2px);
    }

.social-icon {
    color: #fff;
    align-items: center;
    margin-left: 1rem;
    font-size: 1.25rem;
    transition: color .3s;
    display: inline-flex;
}

    .social-icon svg path {
        fill: #fff;
        transition: fill .3s;
    }

    .social-icon:hover {
        color: var(--bs-secondary);
    }

        .social-icon:hover svg path {
            fill: var(--bs-secondary);
        }

@media (width <= 767.98px) {
    .social-icon:first-child {
        margin-left: 0;
    }
}

.grid-header {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    border-radius: 4px 4px 0 0;
    padding: 0 1em;
}

    .grid-header .title {
        color: var(--bs-white);
        font-size: 2em;
    }

.grid-sub-header {
    background-color: rgba(var(--bs-primary-rgb), .12);
    min-height: 65px;
    padding: 0 1em;
    font-style: italic;
}

.grid-row {
    border-left: 1px solid rgba(var(--bs-primary-rgb), .12);
    border-right: 1px solid rgba(var(--bs-primary-rgb), .12);
    align-items: center;
    min-height: 65px;
}

    .grid-row:nth-child(odd) {
        background-color: var(--bs-white);
    }

    .grid-row:nth-child(2n) {
        background-color: rgba(var(--bs-primary-rgb), .12);
    }

body {
    background-color: #fff;
    overflow-x: hidden;
}

main.ppn-main {
    overflow: hidden;
}

section.ppn {
    background-color: #e7e5e5;
    margin:0;
}

    section.ppn .ppn-notice {
        background-color: rgba(var(--bs-black-rgb), .1);
        border: rgba(var(--bs-black-rgb), .15);
        border-left: 4px solid rgba(var(--bs-black-rgb), .5);
        color: var(--bs-black);
        padding: 1rem 4rem 1rem 1rem;
    }

    section.ppn .ppn-wrapper {
        padding: 2.75%;
    }

    section.ppn .ppn-alert {
        background-color: rgba(var(--bs-primary-rgb), .12);
        border: rgba(var(--bs-primary-rgb), .12);
        color: var(--bs-primary);
        border-radius: 4px;
    }

        section.ppn .ppn-alert p{
            margin:0;
        }

        section.ppn .ppn-alert a#CarrierLink {
            color: var(--bs-primary);
            font-weight: bold;
            text-decoration: none;
            display: inline-block;
            position: relative;
        }

        section.ppn .ppn-alert a#CarrierLink:hover {
            color: var(--bs-primary);
            font-weight: bold;
            text-decoration: underline;
            display: inline-block;
            position: relative;
        }

            section.ppn .ppn-alert a:after {
                margin-left: .5rem;
                font-family: "Font Awesome 5 Free", FontAwesome;
                font-weight: 900;
                transition: all .3s;
                display: inline-block;
            }

            section.ppn .ppn-alert a:hover:after {
                margin-left: .8rem;
            }

        section.ppn .ppn-alert .btn-close {
            color: var(--bs-primary);
            opacity: 1;
            border-radius: 20px;
        }

            section.ppn .ppn-alert .btn-close:hover {
                opacity: .75;
            }

section .ppn {
    padding: 5%;
}

.ppn .sub-header-hero .hero-image img {
    width:80%;
}

section .ppn-filters label {
    color: var(--bs-black);
    font-size: 1rem;
    font-weight: 300;
    position: relative;
    margin-bottom: 1rem;
    display: block;
}

section .ppn-filters input {
    height: 50px;
}

    section .ppn-filters label::after {
        content: " ";
        background-color: var(--bs-primary);
        width: 15px;
        height: 2px;
        position: absolute;
        bottom: -4px;
        left: 0;
    }

section .ppn-filters .title {
    color: var(--bs-primary);
    font-size: calc(1.275rem + .3vw);
    display: block;
}

@media (width >= 1200px) {
    section .ppn-filters .title {
        font-size: 1.5rem;
    }
}

section .ppn-filters .radius-slider .form-range::-webkit-slider-runnable-track {
    background-color: #dee2e6 !important;
    border-radius: 1rem !important;
    height: .5rem !important;
}

section .ppn-filters .radius-slider .form-range::-moz-range-track {
    background-color: #dee2e6 !important;
    border-radius: 1rem !important;
    height: .5rem !important;
}

section .ppn-filters .radius-slider .form-range::-webkit-slider-thumb {
    background-color: var(--bs-primary) !important;
    -webkit-appearance: none !important;
    border: 0 !important;
    border-radius: 50% !important;
    width: 1.25rem !important;
    height: 1.25rem !important;
    margin-top: -.375rem !important;
    transition: all .3s ease-in-out !important;
}

    section .ppn-filters .radius-slider .form-range::-webkit-slider-thumb:focus {
        background-color: var(--bs-primary) !important;
        box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .12) !important;
    }

    section .ppn-filters .radius-slider .form-range::-webkit-slider-thumb:active {
        background-color: var(--bs-primary) !important;
    }

    section .ppn-filters .radius-slider .form-range::-webkit-slider-thumb:hover {
        cursor: pointer;
        transform: scale(1.08);
        background-color: hsl(from var(--bs-primary) h s calc(l * 1.2)) !important;
        box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .32) !important;
    }

section .ppn-filters .radius-slider .form-range::-moz-range-thumb {
    background-color: var(--bs-primary) !important;
    border: 0 !important;
    border-radius: 50% !important;
    width: 1.25rem !important;
    height: 1.25rem !important;
    transition: all .3s ease-in-out !important;
}

    section .ppn-filters .radius-slider .form-range::-moz-range-thumb:focus {
        background-color: var(--bs-primary) !important;
        box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .32) !important;
    }

    section .ppn-filters .radius-slider .form-range::-moz-range-thumb:active {
        background-color: var(--bs-primary) !important;
        box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .32) !important;
    }

    section .ppn-filters .radius-slider .form-range::-moz-range-thumb:hover {
        cursor: pointer;
        transform: scale(1.08);
        background-color: hsl(from var(--bs-primary) h s calc(l * 1.2)) !important;
        box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .32) !important;
    }

section .ppn-filters .radius-slider .form-range:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .32) !important;
}

section .ppn-filters .radius-slider .form-range:focus::-moz-range-thumb {
    box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), .32) !important;
}

section .ppn-filters .radius-slider .form-range:disabled {
    opacity: .5 !important;
}

    section .ppn-filters .radius-slider .form-range:disabled::-webkit-slider-thumb {
        background-color: #adb5bd !important;
    }

    section .ppn-filters .radius-slider .form-range:disabled::-moz-range-thumb {
        background-color: #adb5bd !important;
    }

section .ppn-filters .category-filters .clear-filters {
    color: var(--bs-primary);
}

section .ppn-filters .category-filters .filter-button {
    text-align: left;
    background-color: rgba(var(--bs-primary-rgb), .12);
    border-color: rgba(var(--bs-primary-rgb), .4);
    width: 100%;
    color: var(--bs-dark);
    --bs-btn-padding-x: 1rem;
    --bs-btn-padding-y: .65rem;
    border-radius: 50px;
    margin-bottom: 10px;
    font-size: 13px;
}

    section .ppn-filters .category-filters .filter-button:hover {
        background-color: rgba(var(--bs-primary-rgb), .22);
        border-color: rgba(var(--bs-primary-rgb), .4);
    }

    section .ppn-filters .category-filters .filter-button.active {
        background-color: rgba(var(--bs-primary-rgb), .32);
        color: var(--bs-primary);
        border-color: rgba(var(--bs-primary-rgb), .32);
    }

section .ppn-filters .category-filters .toggle-link {
    cursor: pointer;
    color: var(--bs-primary);
    text-align: center;
    margin-top: 10px;
    text-decoration: underline;
    display: block;
}

    section .ppn-filters .category-filters .toggle-link:hover {
        text-decoration: underline;
    }

section .ppn-filters .category-filters .active-filters {
    margin-top: 10px;
}

section .ppn-filters .category-filters .active-filter-badge {
    background-color: rgba(var(--bs-primary-rgb), 1);
    border: 1px solid var(--bs-primary);
    color: var(--bs-white);
    border-radius: 4px;
    border-radius: var(--bs-border-radius-2xl);
    align-items: center;
    margin-bottom: 8px;
    margin-right: 8px;
    padding: 6px 12px;
    font-size: 13px;
    display: inline-flex;
}

    section .ppn-filters .category-filters .active-filter-badge .close-btn {
        cursor: pointer;
        color: var(--bs-white);
        margin-left: 8px;
        font-size: 18px;
        line-height: 1;
    }

        section .ppn-filters .category-filters .active-filter-badge .close-btn:hover {
            color: var(--bs-primary);
        }

section .ppn-filters .category-filters .sort-container {
    justify-content: flex-end;
    margin-bottom: 15px;
    display: flex;
}

    section .ppn-filters .category-filters .sort-container .dropdown-toggle {
        border: none;
        font-size: 13px;
    }

        section .ppn-filters .category-filters .sort-container .dropdown-toggle:hover, section .ppn-filters .category-filters .sort-container .dropdown-toggle:active, section .ppn-filters .category-filters .sort-container .dropdown-toggle:focus {
            background-color: rgba(var(--bs-black-rgb), .12);
            color: var(--bs-primary);
        }

.main-container {
    height: calc(100vh - 56px);
    max-height: 900px;
}

.map-container {
    border-radius: var(--bs-card-border-radius);
    height: 100%;
    min-height: 400px;
    position: relative;
    overflow: hidden;
}

.map-pin {
    cursor: pointer;
    z-index: 10;
    color: var(--bs-primary);
    text-shadow: 0 0 3px #fffc;
    font-size: 22px;
    transition: width .3s;
    position: absolute;
    transform: translate(-50%, -50%);
}

    .map-pin:hover {
        color: var(--bs-secondary);
        transform: translate(-50%, -50%)scale(1.3);
    }

    .map-pin.active {
        color: var(--bs-secondary);
    }

.pin-popup {
    opacity: 0;
    visibility: hidden;
    z-index: 11;
    background-color: #fff;
    border-radius: 5px;
    width: 220px;
    padding: 10px;
    transition: all .3s;
    position: absolute;
    transform: translate(-50%, -120%);
    box-shadow: 0 2px 10px #0003;
}

    .pin-popup:after {
        content: "";
        border-top: 8px solid #fff;
        border-left: 8px solid #0000;
        border-right: 8px solid #0000;
        width: 0;
        height: 0;
        position: absolute;
        bottom: -8px;
        left: 50%;
        transform: translateX(-50%);
    }

.map-pin:hover .pin-popup {
    opacity: 1;
    visibility: visible;
}

.popup-title {
    color: var(--bs-primary);
    margin-bottom: 5px;
    font-size: 14px;
    font-weight: 600;
}

.popup-address {
    margin-bottom: 5px;
    font-size: 12px;
}

.popup-discount {
    color: #666;
    align-items: center;
    font-size: 12px;
    display: flex;
}

    .popup-discount i {
        color: var(--bs-secondary);
        margin-right: 5px;
    }

.search-sidebar, .results-sidebar {
    height: 100%;
    overflow-y: auto;
}

.filter-section {
    border-radius: var(--bs-card-border-radius);
    box-shadow: var(--bs-card-shadow);
    background-color: #fff;
    margin-bottom: 1rem;
    padding: 1.25rem;
}

.distance-filter {
    padding: 10px 0 20px;
    position: relative;
}

.slider-container {
    height: 6px;
    padding: 0;
    position: relative;
}

.slider-track {
    background: linear-gradient(to right, #ccc, var(--bs-primary));
    border-radius: 3px;
    height: 3px;
    position: absolute;
    top: 3px;
    left: 0;
    right: 0;
}

.distance-range {
    appearance: none;
    z-index: 2;
    background: none;
    width: 100%;
    height: 6px;
    position: absolute;
}

    .distance-range::-webkit-slider-thumb {
        appearance: none;
        cursor: pointer;
        background: none;
        width: 0;
        height: 0;
    }

    .distance-range::-moz-range-thumb {
        cursor: pointer;
        background: none;
        border: none;
        width: 0;
        height: 0;
    }

.slider-thumb {
    width: 18px;
    height: 18px;
    color: var(--bs-primary);
    z-index: 1;
    pointer-events: none;
    font-size: 18px;
    transition: color .2s;
    position: absolute;
    top: -5px;
    transform: translateX(-50%);
}

.slider-active .slider-thumb {
    color: var(--bs-secondary);
}

.search-heading {
    color: var(--bs-primary);
    margin-bottom: 1rem;
    font-weight: 500;
}

.filter-option {
    cursor: pointer;
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 5px;
    margin-bottom: .5rem;
    padding: .5rem 1rem;
    transition: all .2s;
}

    .filter-option:hover {
        border-color: var(--bs-primary);
    }

    .filter-option.active {
        background-color: var(--bs-primary);
        color: #fff;
        border-color: var(--bs-primary);
    }

.filter-search {
    position: relative;
}

    .filter-search .bi-geo-alt {
        color: #6c757d;
        position: absolute;
        top: .85rem;
        left: 1rem;
    }

    .filter-search input {
        border-radius: 30px;
        padding-left: 2.5rem;
    }

.search-btn {
    background-color: var(--bs-primary);
    color: #fff;
    border: none;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 32px;
    height: 32px;
    display: flex;
    position: absolute;
    top: .5rem;
    right: .5rem;
}

.provider-card {
    border-radius: var(--bs-card-border-radius);
    box-shadow: var(--bs-card-shadow);
    opacity: 0;
    border: 1px solid #00000014;
    margin-bottom: 1rem;
    animation: .5s forwards fadeInUp;
    transform: translateY(10px);
}

@keyframes fadeInUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.provider-card:nth-child(2) {
    animation-delay: .1s;
}

.provider-card:nth-child(3) {
    animation-delay: .2s;
}

.provider-icon {
    background-color: var(--bs-primary);
    color: #fff;
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    font-size: 20px;
    display: flex;
}

.provider-badge {
    background-color: var(--bs-light-primary);
    color: var(--bs-primary);
    border-radius: 20px;
    padding: 2px 10px;
    font-size: 12px;
    font-weight: bold;
}

.provider-type {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    border-radius: 20px;
    padding: 2px 10px;
    font-weight: bold;
}

.plus-badge {
    color: var(--bs-black);
    background-color: #a5cf4d;
}

.discount-text {
    color: #666;
    font-size: 14px;
}

.provider-link {
    color: var(--bs-primary);
    text-decoration: none;
}

    .provider-link:hover {
        text-decoration: underline;
    }

.location-text {
    margin-bottom: .5rem;
    font-size: .875rem;
}

.results-heading {
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
    display: flex;
}

.results-counter {
    color: #6c757d;
    font-size: .875rem;
}

.clear-btn {
    color: var(--bs-primary);
    font-size: .875rem;
    text-decoration: none;
}

    .clear-btn:hover {
        text-decoration: underline;
    }

.expanded-filters {
    max-height: 0;
    transition: max-height .5s;
    overflow: hidden;
}

    .expanded-filters.show {
        max-height: 500px;
    }

.show-more-btn {
    color: var(--bs-primary);
    cursor: pointer;
    background: none;
    border: none;
    align-items: center;
    padding: 0;
    font-size: .875rem;
    display: flex;
}

    .show-more-btn .bi {
        transition: transform .3s;
    }

    .show-more-btn.expanded .bi {
        transform: rotate(180deg);
    }

.results-container {
/*    border: 1px solid #dbdbdb;*/
    min-height: 100vh;
}

    .results-container .card.provider-card {
        border: 1px solid rgba(var(--bs-primary-rgb), .1);
        transition: all .3s ease-in-out;
        position: relative;
        overflow: hidden;
        box-shadow: 0 2px 5px #0000000d;
    }

        .results-container .card.provider-card:before {
            content: "";
            background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), .05) 0%, rgba(var(--bs-primary-rgb), 0) 100%);
            z-index: 0;
            width: 100%;
            height: 100%;
            transition: transform .4s;
            position: absolute;
            top: 0;
            left: 0;
            transform: translateY(100%);
        }

        .results-container .card.provider-card:hover {
            border-color: rgba(var(--bs-primary-rgb), .3);
            transform: translateY(-5px);
            box-shadow: 0 10px 20px #0000001a;
        }

            .results-container .card.provider-card:hover:before {
                transform: translateY(0);
            }

        .results-container .card.provider-card .card-body {
            z-index: 1;
            position: relative;
        }

            .results-container .card.provider-card .card-body:after {
                content: "";
                background-color: var(--bs-primary);
                width: 0;
                height: 3px;
                transition: width .3s;
                position: absolute;
                bottom: 0;
                left: 0;
            }

        .results-container .card.provider-card:hover .card-body:after {
            width: 100%;
        }

        .results-container .card.provider-card .card-title {
            transition: color .3s;
            font-size:1rem;
            font-weight: bold;
        }

        .results-container .card.provider-card:hover .card-title {
            color: var(--bs-primary);
            font-size: 1rem;
            font-weight: bold;
        }

        .results-container .card.provider-card .card-img-top {
            z-index: 1;
            transition: opacity .3s;
            position: relative;
        }

        .results-container .card.provider-card:hover .card-img-top {
            opacity: .9;
        }

@media (width <= 992px) {
    .main-container {
        height: auto;
    }

    .map-container, .search-sidebar {
        margin-bottom: 1rem;
    }
}

.col-map {
    background: var(--bs-white);
    border: 1px solid #dbdbdb;
    flex: none;
    width: 54.1667%;
    padding: 0;
}

@media (width >= 768px) and (width <= 1199px) {
    .col-map {
        flex: none;
        width: 100%;
    }
}

@media (width <= 767.98px) {
    .col-map {
        flex: none;
        width: 100%;
    }
}

.col-results {
    flex: none;
    width: 20.8333%;
}

@media (width >= 768px) and (width <= 1199px) {
    .col-results {
        flex: none;
        width: 100%;
    }
}

@media (width <= 991.98px) {
    .col-results {
        flex: none;
        width: 100%;
    }
}

.col-filters {
    background: var(--bs-white);
}

.col-results {
    background: var(--bs-white);
    min-height: 100vh;
}

.PPNSwiper .swiper-wrapper {
    z-index: 1;
    width: 100%;
    height: 100%;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    box-sizing: content-box;
    margin-bottom: 1em;
    display: flex;
    position: relative;
}

.PPNSwiper.swiper {
    width: 100%;
    min-height: 425px;
    padding-bottom: 40px;
}

    .PPNSwiper.swiper .swiper-slide {
        color: #fff;
        opacity: .9;
        border-radius: 4px;
        justify-content: center;
        align-items: center;
        min-width: 325px;
        height: 100%;
        margin-bottom: 1em;
        padding: 15px;
        font-size: 24px;
        font-weight: 600;
        transition: transform .4s;
        display: flex;
        transform: scale(.89);
        box-shadow: 0 12px 20px #00000040;
    }

        .PPNSwiper.swiper .swiper-slide.swiper-slide-active {
            opacity: 1;
            transform: scale(1);
        }

        .PPNSwiper.swiper .swiper-slide .btn.btn-cta {
            background-color: var(--bs-secondary);
            justify-content: center;
            display: flex;
        }

            .PPNSwiper.swiper .swiper-slide .btn.btn-cta:hover {
                background-color: hsl(from var(--bs-secondary) h s calc(l * .8));
            }

    .PPNSwiper.swiper p {
        font-size: 1rem;
        font-weight: var(--bs-body-font-weight);
        margin-top: 1em;
    }

    .PPNSwiper.swiper .swiper-slide:nth-child(odd), .PPNSwiper.swiper .swiper-slide:nth-child(2n) {
        background-color: var(--bs-primary);
    }

    .PPNSwiper.swiper .swiper-pagination-bullet {
        background-color: rgba(var(--bs-primary-rgb), .25);
        border-radius: 8px;
        width: 10px;
        height: 10px;
        margin: 0 2px;
        transition: width .35s ease-in-out;
        position: relative;
        overflow: hidden;
    }

    .PPNSwiper.swiper .swiper-pagination-bullet-active {
        background-color: rgba(var(--bs-primary-rgb), .5);
        border-radius: 8px;
        width: 44px;
        transition: width .35s ease-in-out;
    }

        .PPNSwiper.swiper .swiper-pagination-bullet-active:after {
            content: "";
            background-color: var(--bs-primary);
            height: 100%;
            animation: 6s linear infinite timer;
            position: absolute;
            top: 0;
            left: 0;
        }

@keyframes timer {
    from {
        width: 0%;
    }

    to {
        width: 100%;
    }
}

.PPNSwiper .swiper-pagination {
    justify-content: center;
    align-items: center;
    display: flex;
}

.PPNSwiper .swiper-pagination-bullet {
    background-color: #0009;
    width: 10px;
    height: 10px;
    transition: width .5s ease-in-out;
    position: relative;
    overflow: hidden;
}

.PPNSwiper .swiper-pagination-bullet-active {
    background-color: rgba(var(--bs-primary-rgb), .5);
    border-radius: 8px;
    width: 44px;
    transition: width .35s ease-in-out;
}

    .PPNSwiper .swiper-pagination-bullet-active:after {
        content: "";
        background-color: var(--bs-primary);
        height: 100%;
        animation: 6s linear infinite timer;
        position: absolute;
        top: 0;
        left: 0;
    }

.ppn-slider h2, .ppn-slider .h2 {
    color: var(--bs-primary);
    font-weight: bolder;
}

.ppn-wrapper {
    position: relative;
}

.ppn-content {
    padding-left: 0;
    padding-right: 0;
}

@media (width >= 768px) {
    .ppn-content {
        flex: none;
        width: 25%;
    }
}

@media (width >= 769px) and (width <= 1199px) {
    .ppn-content {
        flex: none;
        width: 100%;
    }
}

.ppn-filters {
    background: var(--bs-white);
    border: 1px solid #dbdbdb;
    border-radius: 4px;
    height: 100%;
    padding: 1.5rem;
    position: relative;
    box-shadow: 0 2px 4px #0000000d;
}

@media (width >= 992px) {
    .ppn-filters .mobile-filter-header {
        display: none;
    }
}

.ppn-filters .mobile-filter-header .btn.btn-menu, .ppn-filters .mobile-filter-header .btn.btn-menu.collapsed {
    background-color: rgba(var(--bs-primary-rgb), 1);
    color: var(--bs-white);
    border-radius: 50px;
    margin-right: 1em;
}

.ppn-filters .title {
    color: var(--bs-primary);
    margin-bottom: 1.5rem;
    display: block;
}

.ppn-filters .input-search-container {
    margin-bottom: 1.5rem;
    position: relative;
}

    .ppn-filters .input-search-container .search-icon {
        color: var(--bs-gray-600);
        position: absolute;
        top: 50%;
        right: 1rem;
        transform: translateY(-50%);
    }

.ppn-filters .radius-slider {
    margin-bottom: 1.5rem;
}

.ppn-filters .category-filters .filter-button {
    text-align: left;
    width: 100%;
    margin-bottom: .5rem;
}

    .ppn-filters .category-filters .filter-button.active {
        background-color: var(--bs-primary);
        border-color: var(--bs-primary);
        color: #fff;
    }

.col-map {
    background: var(--bs-white);
    border-radius: var(--bs-border-radius);
    border: 1px solid #dbdbdb;
    padding: 0;
}

.filter-content .title {
    color: var(--bs-primary);
    margin-bottom: 1.5rem;
    display: block;
}

.filter-content .col-filters {
    border: 1px solid red;
    flex: none;
    width: 20.8333%;
}

@media (width >= 768px) and (width <= 1199px) {
    .filter-content .col-filters {
        flex: none;
        width: 100%;
    }
}

@media (width <= 991.98px) {
    .filter-content .col-filters {
        flex: none;
        width: 100%;
    }
}

.filter-content .input-search-container {
    position: relative;
}

    .filter-content .input-search-container .search-icon {
        color: var(--bs-white);
        position: absolute;
        bottom: 0;
        right: 0;
        transform: translateY(0%);
    }

.filter-content .radius-slider {
    margin-bottom: 1.5rem;
}

.filter-content .category-filters .filter-button {
    text-align: left;
    width: 100%;
    margin-bottom: .5rem;
}

    .filter-content .category-filters .filter-button.active {
        background-color: var(--bs-primary);
        border-color: var(--bs-primary);
        color: #fff;
    }

html {
    scroll-behavior: smooth;
}

main .make-a-claim-alert.alert {
    background-color: rgba(var(--bs-primary-rgb), .12);
    border: rgba(var(--bs-primary-rgb), .12);
    color: var(--bs-primary);
    border-radius: 4px;
    justify-content: flex-start;
    align-items: center;
    display: flex;
}

.quick-links .quick-link-card {
    background: var(--bs-light);
    height: 100%;
    color: inherit;
    border: 1px solid #0000002e;
    border-radius: .5rem;
    text-decoration: none;
    transition: all .3s;
}

    .quick-links .quick-link-card:hover {
        box-shadow: 0 10px 20px rgba(var(--bs-primary-rgb), .22);
        transform: translateY(-3px);
    }

    .quick-links .quick-link-card .icon-wrapper {
        color: var(--bs-primary);
        font-size: 2.5rem;
    }

    .quick-links .quick-link-card h3, .quick-links .quick-link-card .h3 {
        margin-bottom: 0;
    }

section.directhealthhub-section, section.directhealthhub-section .grid-row:nth-child(2n) {
    background-color: var(--bs-white);
}

    section.directhealthhub-section .sidebar-link {
        color: var(--bs-light);
        align-items: center;
        padding: .75rem 1rem;
        text-decoration: none;
        transition: all .3s;
        display: flex;
    }

        section.directhealthhub-section .sidebar-link:hover {
            background-color: var(--bs-light);
            color: var(--bs-primary);
        }

            section.directhealthhub-section .sidebar-link:hover .icon-circle {
                background-color: rgba(var(--bs-primary-rgb), .2);
                color: var(--bs-white);
            }

        section.directhealthhub-section .sidebar-link.active {
            background-color: rgba(var(--bs-primary-rgb), .1);
            color: var(--bs-primary);
            font-weight: 500;
        }

            section.directhealthhub-section .sidebar-link.active .icon-circle {
                background-color: rgba(var(--bs-primary-rgb), .1);
                color: var(--bs-white);
            }

        section.directhealthhub-section .sidebar-link .icon-circle {
            background-color: rgba(var(--bs-dark-rgb), .1);
            width: 1.5rem;
            height: 1.5rem;
            color: var(--bs-white);
            border-radius: 50%;
            justify-content: center;
            align-items: center;
            margin-left: .5rem;
            margin-right: 1rem;
            transition: all .3s;
            display: flex;
            position: relative;
        }

            section.directhealthhub-section .sidebar-link .icon-circle i {
                font-size: 1rem;
                position: absolute;
                top: 50%;
                left: 50%;
                transform: translate(-50%, -50%);
            }

@media (width <= 767.98px) {
    section.directhealthhub-section .sidebar-link {
        padding: .5rem;
    }

        section.directhealthhub-section .sidebar-link .icon-circle {
            width: 2rem;
            height: 2rem;
            margin-right: .5rem;
        }

            section.directhealthhub-section .sidebar-link .icon-circle i {
                font-size: .875rem;
            }
}

section.directhealthhub-section .d2u-alert-container {
    padding-left: var(--bs-gutter-width);
    padding-right: var(--bs-gutter-width);
}

    section.directhealthhub-section .d2u-alert-container a {
        border-radius: var(--bs-border-radius-2xl);
    }

.sub-header-hero.support-hero {
    background: linear-gradient(-190deg, rgba(var(--bs-white-rgb), .15) 0%, rgba(var(--bs-primary-rgb), .15) 100%);
    position: relative;
    overflow: hidden;
}

    .sub-header-hero.support-hero .floating-icons-container {
        z-index: 0;
        pointer-events: none;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
    }

        .sub-header-hero.support-hero .floating-icons-container i {
            color: var(--bs-primary);
            opacity: .1;
            font-size: 2rem;
            animation: 20s linear infinite float;
            position: absolute;
        }

            .sub-header-hero.support-hero .floating-icons-container i:first-child {
                animation-delay: 0s;
                top: 5%;
                left: 5%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(2) {
                animation-delay: -1s;
                top: 15%;
                left: 20%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(3) {
                animation-delay: -2s;
                top: 25%;
                left: 35%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(4) {
                animation-delay: -3s;
                top: 35%;
                left: 50%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(5) {
                animation-delay: -4s;
                top: 45%;
                left: 65%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(6) {
                animation-delay: -5s;
                top: 55%;
                left: 80%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(7) {
                animation-delay: -6s;
                top: 65%;
                left: 95%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(8) {
                animation-delay: -7s;
                top: 75%;
                left: 10%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(9) {
                animation-delay: -8s;
                top: 85%;
                left: 25%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(10) {
                animation-delay: -9s;
                top: 20%;
                left: 40%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(11) {
                animation-delay: -10s;
                top: 40%;
                left: 55%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(12) {
                animation-delay: -11s;
                top: 60%;
                left: 70%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(13) {
                animation-delay: -12s;
                top: 30%;
                left: 85%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(14) {
                animation-delay: -13s;
                top: 50%;
                left: 15%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(15) {
                animation-delay: -14s;
                top: 70%;
                left: 30%;
            }

            .sub-header-hero.support-hero .floating-icons-container i:nth-child(16) {
                animation-delay: -15s;
                top: 80%;
                left: 45%;
            }

    .sub-header-hero.support-hero .header-cols {
        z-index: 1;
        position: relative;
    }

@keyframes float {
    0% {
        opacity: .1;
        transform: translateY(0)rotate(0);
    }

    50% {
        opacity: .2;
        transform: translateY(-20px)rotate(180deg);
    }

    100% {
        opacity: .1;
        transform: translateY(0)rotate(360deg);
    }
}

.faq-section {
    background-color: #fff;
    padding: 80px 0;
}

    .faq-section .text-gradient {
        -webkit-text-fill-color: transparent;
        background: linear-gradient(#026937 0%, #00512a 100%) text;
    }

    .faq-section .search-box {
        background: #fff;
        box-shadow: 0 4px 34px -10px #00000069;
    }

        .faq-section .search-box .search-icon-circle {
            color: #026937;
            background: #0269372e;
            border-radius: 50%;
            justify-content: center;
            align-items: center;
            width: 40px;
            height: 40px;
            display: flex;
        }

        .faq-section .search-box .input-group .input-group-text {
            background-color: #0000;
        }

        .faq-section .search-box .input-group .form-control {
            font-size: 1.25rem;
        }

            .faq-section .search-box .input-group .form-control::placeholder {
                color: #757575;
            }

            .faq-section .search-box .input-group .form-control:focus {
                box-shadow: none;
                border-color: #026937;
            }

    .faq-section .faq-card {
        cursor: pointer;
        border: 1px solid rgba(var(--bs-primary-rgb), .1);
        background: var(--bs-light);
        transition: all .3s;
        position: relative;
        overflow: hidden;
    }

        .faq-section .faq-card:before {
            content: "";
            background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), .1) 0%, rgba(var(--bs-primary-rgb), .05) 100%);
            opacity: 0;
            width: 100%;
            height: 100%;
            transition: opacity .3s;
            position: absolute;
            top: 0;
            left: 0;
        }

        .faq-section .faq-card:hover {
            border-color: var(--bs-primary);
            background: var(--bs-white);
            box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), .1);
        }

            .faq-section .faq-card:hover:before {
                opacity: 1;
            }

            .faq-section .faq-card:hover h3, .faq-section .faq-card:hover .h3 {
                color: var(--bs-primary);
            }

            .faq-section .faq-card:hover:after {
                content: "→";
                color: var(--bs-primary);
                opacity: 0;
                font-size: 1.25rem;
                animation: .3s forwards fadeInRight;
                position: absolute;
                top: 50%;
                right: 1.5rem;
                transform: translateY(-50%);
            }

        .faq-section .faq-card h3, .faq-section .faq-card .h3 {
            color: var(--bs-dark);
            padding-right: 2rem;
            font-weight: 400;
            line-height: 1.4;
            transition: color .3s;
        }

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translate(10px, -50%);
    }

    to {
        opacity: .8;
        transform: translate(0, -50%);
    }
}

.faq-section .service-card {
    cursor: pointer;
    text-align: center;
    border: 1px solid #0000001a;
    transition: all .3s;
    position: relative;
    overflow: hidden;
}

    .faq-section .service-card i {
        color: var(--bs-primary);
        margin-bottom: 1rem;
        font-size: 2rem;
        transition: transform .3s;
    }

    .faq-section .service-card h3, .faq-section .service-card .h3 {
        margin-bottom: 0;
        font-size: 1.25rem;
        transition: color .3s;
    }

    .faq-section .service-card:hover {
        border-color: var(--bs-primary);
        box-shadow: 0 4px 12px #0000001a;
    }

        .faq-section .service-card:hover i {
            transform: scale(1.1);
        }

        .faq-section .service-card:hover h3, .faq-section .service-card:hover .h3 {
            color: var(--bs-primary);
        }

        .faq-section .service-card:hover:before {
            content: "";
            background: var(--bs-primary);
            width: 100%;
            height: 3px;
            transition: transform .3s;
            position: absolute;
            bottom: 0;
            left: 0;
            transform: scaleX(1);
        }

:root {
    --school-color-auarts: #582877;
    --school-color-scc: #026937;
    --school-color-dsu: #32bcad;
    --school-color-dcsa: #26234f;
}

main.school-selector {
    background-color: #262424;
    align-items: center;
    width: 100vw;
    min-height: 100vh;
    display: flex;
    position: relative;
    overflow: hidden;
}

main.school-selector .animated-background {
    z-index: 990;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
}

main.school-selector .gradient-circle {
    filter: blur(304px);
    transition: background all .3s ease-in-out;
    background: #fff3;
    border-radius: 50%;
    position: absolute;
}

main.school-selector .circle-1 {
    width: 80vh;
    height: 80vh;
    animation: 25s ease-in-out infinite alternate move1;
    top: -20vh;
    right: -20vh;
}

main.school-selector .circle-2 {
    width: 90vh;
    height: 90vh;
    animation: 30s ease-in-out infinite alternate move2;
    bottom: -30vh;
    left: -15vh;
}

@keyframes move1 {
    0% {
        transform: translate(0);
    }

    100% {
        transform: translate(5vw, 5vh);
    }
}

@keyframes move2 {
    0% {
        transform: translate(0);
    }

    100% {
        transform: translate(8vw, -5vh);
    }
}

main.school-selector .content-wrapper {
    z-index: 995;
    height: 90vh;
    position: relative;
}

    main.school-selector .content-wrapper:before {
        content: " ";
        color: #fff;
        z-index: 0;
        background-image: url("young-happy-woman-at-university-classroom-looking-2023-11-27-05-15-47-utc 3.f56b5a24.png");
        background-position: 100% 100%;
        background-repeat: no-repeat;
        background-size: contain;
        width: 90%;
        height: 90%;
        font-size: 30px;
        position: absolute;
        bottom: 0;
        right: 0%;
    }

main.school-selector .main-title {
    text-align: left;
    color: #fff;
    margin-bottom: 1.5rem;
    font-size: 4.5rem;
    font-weight: 400;
    line-height: 1.25;
}

main.school-selector .input-container {
    transition: all all .3s ease-in-out;
    background-color: #ffffff1a;
    border: 1px solid #dee2e6;
    border-radius: .375rem;
    align-items: center;
    margin-bottom: 1rem;
    padding: 0;
    display: flex;
    position: relative;
}

    main.school-selector .input-container .form-control:focus {
        box-shadow: none;
    }

    main.school-selector .input-container .search-icon {
        flex-shrink: 0;
        width: 24px;
        height: 24px;
        margin-left: 1rem;
        margin-right: .75rem;
    }

    main.school-selector .input-container .enter-icon {
        cursor: pointer;
        transition: all all .3s ease-in-out;
        background-color: #0006;
        border-radius: .375rem;
        flex-shrink: 0;
        justify-content: center;
        align-items: center;
        width: 54px;
        height: 54px;
        margin: 5px 5px 5px 0;
        display: flex;
        position: relative;
    }

        main.school-selector .input-container .enter-icon:hover {
            background-color: #0009;
        }

        main.school-selector .input-container .enter-icon svg {
            width: 20px;
            height: 20px;
        }

        main.school-selector .input-container .enter-icon.active {
            border: none;
            animation: 4s infinite gradientAnimation;
            position: relative;
            background-size: 200% 200% !important;
        }

            main.school-selector .input-container .enter-icon.active:before, main.school-selector .input-container .enter-icon.active:after {
                content: none;
            }

@keyframes borderAnimation {
    0% {
        transform: rotate(0);
    }

    100% {
        transform: rotate(360deg);
    }
}

@keyframes gradientAnimation {
    0% {
        background-position: 0%;
    }

    50% {
        background-position: 100%;
    }

    100% {
        background-position: 0%;
    }
}

@keyframes subtlePulse {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.03);
    }
}

main.school-selector .input-container .clear-icon.visible {
    opacity: .7;
    visibility: visible;
}

main.school-selector .input-container .clear-icon:hover {
    opacity: 1;
    transform: scale(1.1);
}

main.school-selector #schoolInput {
    color: #fff;
    background: none;
    border: none;
    outline: none;
    width: 100%;
    height: 64px;
    padding: 0;
    font-size: 1.25rem;
}

main.school-selector #clearButton {
    transition: opacity all .3s ease-in-out, transform all .3s ease-in-out;
    flex-shrink: 0;
}

    main.school-selector #clearButton:hover {
        transform: scale(1.1);
        opacity: 1 !important;
    }

main.school-selector #schoolInput::placeholder {
    color: #fffc;
}

main.school-selector .dropdown-menu {
    z-index: 1000;
    background-color: #343a40;
    border: 1px solid #495057;
    border-radius: .375rem;
    width: 100%;
    max-height: 300px;
    margin-top: .25rem;
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    overflow: hidden auto;
    box-shadow: 0 .5rem 1rem #00000026;
}

    main.school-selector .dropdown-menu.show {
        display: block;
    }

main.school-selector .dropdown-item {
    color: #fff;
    cursor: pointer;
    transition: all all .3s ease-in-out;
    border-left: 3px solid #0000;
    align-items: center;
    gap: .75rem;
    padding: .75rem 1rem;
    display: flex;
}

    main.school-selector .dropdown-item:hover, main.school-selector .dropdown-item.active {
        background-color: #495057;
        border-left: 3px solid #fff;
    }

main.school-selector .school-logo {
    object-fit: contain;
    flex-shrink: 0;
    width: 66px;
    height: 36px;
}

main.school-selector .dropdown-item span {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

main.school-selector .illustration {
    object-fit: contain;
    width: 100%;
    height: auto;
    max-height: 90vh;
}

main.school-selector .content-column {
    flex-direction: column;
    justify-content: center;
    height: 100%;
    display: flex;
}

main.school-selector .subtitle {
    color: #fffc;
    text-align: left;
    margin-bottom: 2.5rem;
    font-size: 1.25rem;
}

main.school-selector #changingText {
    color: #b8d44a;
    -webkit-text-fill-color: transparent;
    background: linear-gradient(90deg, #b8d44a, #7fe57f, #85c1e9, #b8d44a) 0 0 / 300% text;
    padding: 0 4px;
    font-weight: 700;
    animation: 6s infinite gradientText;
    display: inline-block;
}

main.school-selector .text-mask-container {
    vertical-align: bottom;
    height: 1.5em;
    width: var(--text-container-width);
    perspective: 1000px;
    text-align: left;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    display: inline-block;
    position: relative;
    overflow: hidden;
}

main.school-selector .changing-text-wrapper {
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    text-align: left;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    position: absolute;
    top: 0;
    left: 0;
}

main.school-selector #changingText, main.school-selector #nextChangingText {
    white-space: nowrap;
    display: block;
    text-align: left !important;
    transform-origin: center !important;
    width: 100% !important;
    height: 100% !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
}

main.school-selector .next-text {
    opacity: 0;
    transform: translateY(100%);
}

@keyframes gradientText {
    0% {
        background-position: 0%;
    }

    50% {
        background-position: 100%;
    }

    100% {
        background-position: 0%;
    }
}

main.school-selector .gradient-overlay {
    z-index: 992;
    opacity: 0;
    pointer-events: none;
    will-change: opacity;
    width: 100%;
    height: 100%;
    transition: opacity .7s ease-in-out;
    position: absolute;
    top: 0;
    left: 0;
}

main.school-selector .auarts-gradient {
    z-index: 993;
    background: radial-gradient(circle at 100% 0, #582877b3, #0000 70%), radial-gradient(circle at 0 100%, #58287780, #0000 70%);
}

main.school-selector .scc-gradient {
    z-index: 993;
    background: radial-gradient(circle at 100% 0, #026937b3, #0000 70%), radial-gradient(circle at 0 100%, #02693766, #0000 70%);
}

main.school-selector .dsu-gradient {
    z-index: 993;
    background: radial-gradient(circle at 100% 0, #32bcade6, #0000 70%), radial-gradient(circle at 0 100%, #32bcad66, #0000 70%);
}

main.school-selector .dcsa-gradient {
    z-index: 993;
    background: radial-gradient(circle at 100% 0, #26234fe6, #0000 70%), radial-gradient(circle at 0 100%, #26234f66, #0000 70%);
}

main.school-selector .gradient-overlay.active {
    opacity: 1;
    z-index: 993;
}

@media (width <= 991.98px) {
    main.school-selector .main-title {
        text-align: center;
        font-size: 3rem;
    }

    main.school-selector .subtitle {
        text-align: center;
    }

    main.school-selector .content-column {
        padding: 2rem;
    }

    main.school-selector .illustration-column {
        display: none;
    }

    main.school-selector .input-container {
        max-width: 500px;
        margin: 0 auto 1rem;
    }
}

main.school-selector .dropdown-item[data-school="auarts-theme"]:hover, main.school-selector .dropdown-item[data-school="auarts-theme"].active {
    background-color: #58287733;
    border-left-color: #582877;
}

main.school-selector .dropdown-item[data-school="scc-theme"]:hover, main.school-selector .dropdown-item[data-school="scc-theme"].active {
    background-color: #02693733;
    border-left-color: #026937;
}

main.school-selector .dropdown-item[data-school="dsu-theme"]:hover, main.school-selector .dropdown-item[data-school="dsu-theme"].active {
    background-color: #32bcad33;
    border-left-color: #32bcad;
}

main.school-selector .dropdown-item[data-school="dcsa-theme"]:hover, main.school-selector .dropdown-item[data-school="dcsa-theme"].active {
    background-color: #26234f33;
    border-left-color: #26234f;
}

main.school-selector .input-container.auarts-theme {
    border-color: #58287780;
}

    main.school-selector .input-container.auarts-theme .enter-icon.active {
        background: linear-gradient(135deg, #582877, #9045c0);
    }

main.school-selector .input-container.scc-theme {
    border-color: #02693780;
}

    main.school-selector .input-container.scc-theme .enter-icon.active {
        background: linear-gradient(135deg, #026937, #04cd6b);
    }

main.school-selector .input-container.dcsa-theme {
    border-color: #26234f80;
}

    main.school-selector .input-container.dcsa-theme .enter-icon.active {
        background: linear-gradient(135deg, #26234f, #484296);
    }

.opt-in-out .family-plan-options {
    margin: 2rem 0;
}

    .opt-in-out .family-plan-options .card {
        border: 1px solid #e9ecef;
        transition: all .3s;
    }

        .opt-in-out .family-plan-options .card:hover {
            transform: translateY(-5px);
            box-shadow: 0 .125rem .25rem #00000013;
        }

        .opt-in-out .family-plan-options .card .card-header {
            color: #fff;
            background-color: #0d6efd;
            font-weight: bold;
        }

        .opt-in-out .family-plan-options .card .card-body {
            padding: 1.5rem;
        }

        .opt-in-out .family-plan-options .card .price {
            color: #0d6efd;
            margin: 1rem 0;
            font-size: 1.75rem;
            font-weight: bold;
        }

        .opt-in-out .family-plan-options .card .price-period {
            color: #6c757d;
            font-size: .875rem;
            font-weight: normal;
            display: block;
        }

        .opt-in-out .family-plan-options .card .benefit-list {
            margin: 1.5rem 0;
            padding-left: 0;
            list-style: none;
        }

            .opt-in-out .family-plan-options .card .benefit-list li {
                border-bottom: 1px solid #e9ecef;
                padding: .5rem 0;
            }

                .opt-in-out .family-plan-options .card .benefit-list li:last-child {
                    border-bottom: none;
                }

                .opt-in-out .family-plan-options .card .benefit-list li:before {
                    content: "✓";
                    color: #198754;
                    margin-right: .5rem;
                    font-weight: bold;
                }

.opt-in-out .plan-selection {
    margin-bottom: 2rem;
}

    .opt-in-out .plan-selection .form-check-input:checked {
        background-color: #0d6efd;
        border-color: #0d6efd;
    }

    .opt-in-out .plan-selection .form-check-label {
        font-weight: 500;
    }

        .opt-in-out .plan-selection .form-check-label .price-tag {
            color: #0d6efd;
            font-weight: bold;
        }

.opt-in-out .payment-methods .payment-option {
    cursor: pointer;
    border: 1px solid #dee2e6;
    border-radius: .375rem;
    margin-bottom: 1rem;
    padding: 1rem;
    transition: all .2s;
}

    .opt-in-out .payment-methods .payment-option:hover {
        border-color: #0d6efd;
    }

    .opt-in-out .payment-methods .payment-option.selected {
        background-color: #0d6efd0d;
        border-color: #0d6efd;
    }

    .opt-in-out .payment-methods .payment-option .payment-icon {
        width: 48px;
        height: 48px;
        margin-right: 1rem;
    }
/*# sourceMappingURL=404.3ebda1e7.css.map */


/* Global Widgets :: BEGIN  */
.global__widgets.widget-sm .widget_sm_flex {
    justify-content: space-between;
}

.global__widgets.widget-sm .col .nav-link {
    align-items: center;
}

    .global__widgets.widget-sm .col .nav-link img {
        width: 35px;
        height: auto;
    }

.global__widgets.widget-sm .col .nav__ico {
    max-width: 45px;
    display: flex;
    justify-content: center;
}

.global__widgets.widget-sm .col .nav__text {
    padding-left: 1.3rem;
    text-transform: uppercase;
}

.global__widgets.widget-sm .col .nav-link .nav__ico::before {
    content: " ";
    position: absolute;
    width: 65px;
    height: 45px;
    background-color: var(--bs-primary);
    border-radius: 60px;
    z-index: -1;
}
/* Global Widgets :: ENDS */

.divProviderLocationResult {
    background-color: #F5F5F5;
    border-radius: 15px 15px 15px 15px;
}

.divProviderLocationResult2 {
    color: white;
    border-radius: 15px 15px 15px 15px;
}

    .divProviderLocationResult2 a {
        color: white;
    }

/*Login Dialog*/
.svip_login_dialog {
    width: 400px;

}

    .svip_login_dialog .mud-dialog-title {
        background-color: var(--bs-primary);
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .svip_login_dialog .mud-dialog-title .school_brand-logo {
        max-width: 20%;  
    }

.mud-dialog .mud-dialog-title .mud-button-close {
    background-color: hsl(from var(--bs-primary) h s calc(l * .9));
    color: var(--bs-white);
    font-size: 1rem;

    &:hover
{
    background-color: hsl(from var(--bs-primary) h s calc(l * .7));
}
}
.svip_login_dialog .btn-login {
    background-color: var(--bs-primary);
    color: var(--bs-white);
    padding: 0.7rem;
}

    .svip_login_dialog .btn-login:hover {
        background-color: hsl(from var(--bs-primary) h s calc(l * .7));
        color: var(--bs-white);
    }

.offcanvas {
    transition: transform 0.3s ease-in-out;
}

    .offcanvas.show {
        transform: translateX(0);
    }

.offcanvas-end {
    transform: translateX(100%);
}

.offcanvas-backdrop {
    opacity: 0;
    transition: opacity 0.15s linear;
}

    .offcanvas-backdrop.show {
        opacity: 0.5;
    }

@media (max-width: 991.98px) {
    .offcanvas {
        visibility: visible !important;
    }

        .offcanvas .offcanvas-body {
            padding: 1rem 0;
        }

        .offcanvas .dropdown-menu {
            position: static !important;
            float: none;
            width: auto;
            margin-top: 0;
            background-color: transparent;
            border: 0;
            box-shadow: none;
            padding-right: 0 !important;
            padding-left: 0 !important;
        }

        .offcanvas .dropdown-item {
            padding-right: 0 !important;
            padding-left: 1rem !important;
            border: none;
            color: var(--bs-white);
        }

        .offcanvas .nav-link {
            padding-right: 0 !important;
            line-height: 1.85;
            font-size: 1.12rem;
            text-transform: uppercase;
        }

    .nav-link.dropdown-toggle.show, .dropdown-menu.show {
        background-color: hsl(from var(--bs-primary) h s calc(l * .8));
        border-radius: 3px;
    }

    .nav-link.dropdown-toggle.show {
        border-bottom: 1px solid hsl(from var(--bs-primary) h s calc(l * .88));
    }

        .offcanvas .navbar-nav {
            padding-right: 0 !important;
        }

            /* Override existing nav-item styles */
            .offcanvas .navbar-nav .nav-item {
                margin: 0 !important;
                margin-bottom: 0 !important;
                padding: 0 !important;
            }

        .offcanvas .nav-item {
            padding: 0 !important;
            margin: 0 !important;
        }

        /* Ensure consistent padding for all nav links in offcanvas */
        .offcanvas .nav-link,
        .offcanvas .dropdown-toggle {
            padding: 0.5rem 1rem !important;
        }
}


/* Main marquee container */
.logo-marquee {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
    z-index: 3;
}

    /* Fade edges for seamless scrolling */
    .logo-marquee::before,
    .logo-marquee::after {
        content: "";
        position: absolute;
        top: 0;
        width: 200px;
        height: 100%;
        z-index: 10;
        pointer-events: none;
    }

    .logo-marquee::before {
        left: 0;
        background: linear-gradient(to right, #262424 0%, transparent 100%);
    }

    .logo-marquee::after {
        right: 0;
        background: linear-gradient(to left, #262424 0%, transparent 100%);
    }

/* Scrolling rows */
.marquee-row {
    position: absolute;
    display: flex;
    align-items: center;
    width: max-content;
}

    .marquee-row.row-1 {
        top: 15%;
        animation: scroll-left 80s linear infinite;
    }

    .marquee-row.row-2 {
        top: 35%;
        animation: scroll-right 60s linear infinite;
    }

    .marquee-row.row-3 {
        top: 50%;
        animation: scroll-left 100s linear infinite;
    }

/* Logo styling */
.logo-item {
    height: 150px;
    width: auto;
    margin: 0 4rem;
    opacity: 0.08;
    filter: grayscale(1);
    flex-shrink: 0;
}

/* Scroll animations */
@keyframes scroll-left {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

@keyframes scroll-right {
    0% {
        transform: translateX(-50%);
    }

    100% {
        transform: translateX(0);
    }
}

/* Responsive: Mobile */
@media (max-width: 768px) {
    .marquee-row.row-3 {
        display: none;
    }

    .logo-item {
        height: 50px;
        margin: 0 2rem;
        opacity: 0.06;
    }

    .logo-marquee::before,
    .logo-marquee::after {
        width: 100px;
    }
}

