@charset "UTF-8";



@font-face {
    font-family: swiper-icons;
    src: url(data:application/font-woff;charset=utf-8;base64,\ d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA);
    font-weight: 400;
    font-style: normal
}

:root {
    --swiper-theme-color: #007aff
}

:host {
    position: relative;
    display: block;
    margin-left: auto;
    margin-right: auto;
    z-index: 1
}

.swiper {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
    display: block
}

.swiper-vertical > .swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    box-sizing: content-box
}

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
    transform: translateZ(0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
    display: block
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
    height: auto
}

    .swiper-autoheight .swiper-wrapper {
        align-items: flex-start;
        transition-property: transform,height
    }

.swiper-backface-hidden .swiper-slide {
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

    .swiper-3d .swiper-slide, .swiper-3d .swiper-cube-shadow {
        transform-style: preserve-3d
    }

.swiper-css-mode > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

    .swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
        display: none
    }

    .swiper-css-mode > .swiper-wrapper > .swiper-slide {
        scroll-snap-align: start start
    }

.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
    scroll-snap-type: none
}

    .swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
        scroll-snap-align: none
    }

.swiper-css-mode.swiper-centered > .swiper-wrapper:before {
    content: "";
    flex-shrink: 0;
    order: 9999
}

.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: center center;
    scroll-snap-stop: always
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
    margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper:before {
    height: 100%;
    min-height: 1px;
    width: var(--swiper-centered-offset-after)
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
    margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper:before {
    width: 100%;
    min-width: 1px;
    height: var(--swiper-centered-offset-after)
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: #00000026
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top,#00000080,#0000)
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom,#00000080,#0000)
}

.swiper-lazy-preloader {
    width: 42px;
    height: 42px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -21px;
    margin-top: -21px;
    z-index: 10;
    transform-origin: 50%;
    box-sizing: border-box;
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top-color: transparent
}

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader, .swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(360deg)
    }
}

:root {
    --swiper-navigation-size: 44px
}

.swiper-button-prev, .swiper-button-next {
    position: absolute;
    top: var(--swiper-navigation-top-offset, 50%);
    width: calc(var(--swiper-navigation-size) / 44 * 27);
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--swiper-navigation-color, var(--swiper-theme-color))
}

    .swiper-button-prev.swiper-button-disabled, .swiper-button-next.swiper-button-disabled {
        opacity: .35;
        cursor: auto;
        pointer-events: none
    }

    .swiper-button-prev.swiper-button-hidden, .swiper-button-next.swiper-button-hidden {
        opacity: 0;
        cursor: auto;
        pointer-events: none
    }

.swiper-navigation-disabled .swiper-button-prev, .swiper-navigation-disabled .swiper-button-next {
    display: none !important
}

.swiper-button-prev svg, .swiper-button-next svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transform-origin: center
}

.swiper-rtl .swiper-button-prev svg, .swiper-rtl .swiper-button-next svg {
    transform: rotate(180deg)
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset, 10px);
    right: auto
}

.swiper-button-lock {
    display: none
}

.swiper-button-prev:after, .swiper-button-next:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none !important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
    content: "prev"
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 10px);
    left: auto
}

    .swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
        content: "next"
    }

.swiper-fade.swiper-free-mode .swiper-slide {
    transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}

    .swiper-fade .swiper-slide .swiper-slide {
        pointer-events: none
    }

.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

[data-simplebar] {
    position: relative;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: flex-start
}

.simplebar-wrapper {
    overflow: hidden;
    width: inherit;
    height: inherit;
    max-width: inherit;
    max-height: inherit
}

.simplebar-mask {
    direction: inherit;
    position: absolute;
    overflow: hidden;
    padding: 0;
    margin: 0;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    width: auto !important;
    height: auto !important;
    z-index: 0
}

.simplebar-offset {
    direction: inherit !important;
    box-sizing: inherit !important;
    resize: none !important;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    padding: 0;
    margin: 0;
    -webkit-overflow-scrolling: touch
}

.simplebar-content-wrapper {
    direction: inherit;
    box-sizing: border-box !important;
    position: relative;
    display: block;
    height: 100%;
    width: auto;
    max-width: 100%;
    max-height: 100%;
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

    .simplebar-content-wrapper::-webkit-scrollbar, .simplebar-hide-scrollbar::-webkit-scrollbar {
        display: none;
        width: 0;
        height: 0
    }

.simplebar-content:before, .simplebar-content:after {
    content: " ";
    display: table
}

.simplebar-placeholder {
    max-height: 100%;
    max-width: 100%;
    width: 100%;
    pointer-events: none
}

.simplebar-height-auto-observer-wrapper {
    box-sizing: inherit !important;
    height: 100%;
    width: 100%;
    max-width: 1px;
    position: relative;
    float: left;
    max-height: 1px;
    overflow: hidden;
    z-index: -1;
    padding: 0;
    margin: 0;
    pointer-events: none;
    flex-grow: inherit;
    flex-shrink: 0;
    flex-basis: 0
}

.simplebar-height-auto-observer {
    box-sizing: inherit;
    display: block;
    opacity: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 1000%;
    width: 1000%;
    min-height: 1px;
    min-width: 1px;
    overflow: hidden;
    pointer-events: none;
    z-index: -1
}

.simplebar-track {
    z-index: 1;
    position: absolute;
    right: 0;
    bottom: 0;
    pointer-events: none;
    overflow: hidden
}

[data-simplebar].simplebar-dragging, [data-simplebar].simplebar-dragging .simplebar-content {
    pointer-events: none;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

    [data-simplebar].simplebar-dragging .simplebar-track {
        pointer-events: all
    }

.simplebar-scrollbar {
    position: absolute;
    left: 0;
    right: 0;
    min-height: 10px
}

    .simplebar-scrollbar:before {
        position: absolute;
        content: "";
        background: #000;
        border-radius: 7px;
        left: 2px;
        right: 2px;
        opacity: 0;
        transition: opacity .2s .5s linear
    }

    .simplebar-scrollbar.simplebar-visible:before {
        opacity: .5;
        transition-delay: 0s;
        transition-duration: 0s
    }

.simplebar-track.simplebar-vertical {
    top: 0;
    width: 11px
}

.simplebar-scrollbar:before {
    top: 2px;
    bottom: 2px;
    left: 2px;
    right: 2px
}

.simplebar-track.simplebar-horizontal {
    left: 0;
    height: 11px
}

    .simplebar-track.simplebar-horizontal .simplebar-scrollbar {
        right: auto;
        left: 0;
        top: 0;
        bottom: 0;
        min-height: 0;
        min-width: 10px;
        width: auto
    }

[data-simplebar-direction=rtl] .simplebar-track.simplebar-vertical {
    right: auto;
    left: 0
}

.simplebar-dummy-scrollbar-size {
    direction: rtl;
    position: fixed;
    opacity: 0;
    visibility: hidden;
    height: 500px;
    width: 500px;
    overflow-y: hidden;
    overflow-x: scroll;
    -ms-overflow-style: scrollbar !important
}

    .simplebar-dummy-scrollbar-size > div {
        width: 200%;
        height: 200%;
        margin: 10px 0
    }

.simplebar-hide-scrollbar {
    position: fixed;
    left: 0;
    visibility: hidden;
    overflow-y: scroll;
    scrollbar-width: none;
    -ms-overflow-style: none
}

:root, [data-bs-theme=light] {
    --bs-blue: #0d6efd;
    --bs-indigo: #6610f2;
    --bs-purple: #6f42c1;
    --bs-pink: #d63384;
    --bs-red: #dc3545;
    --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: #0e66f3;
    --bs-secondary: #6c757d;
    --bs-success: #198754;
    --bs-info: #0dcaf0;
    --bs-warning: #ffc107;
    --bs-danger: #dc3545;
    --bs-light: #f8f9fa;
    --bs-dark: #212529;
    --bs-primary-rgb: 14, 102, 243;
    --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: #062961;
    --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: #cfe0fd;
    --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: #9fc2fa;
    --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, rgba(255, 255, 255, .15), rgba(255, 255, 255, 0));
    --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: rgba(33, 37, 41, .75);
    --bs-secondary-color-rgb: 33, 37, 41;
    --bs-secondary-bg: #e9ecef;
    --bs-secondary-bg-rgb: 233, 236, 239;
    --bs-tertiary-color: rgba(33, 37, 41, .5);
    --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: #0e66f3;
    --bs-link-color-rgb: 14, 102, 243;
    --bs-link-decoration: underline;
    --bs-link-hover-color: #0b52c2;
    --bs-link-hover-color-rgb: 11, 82, 194;
    --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: rgba(0, 0, 0, .175);
    --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 rgba(0, 0, 0, .15);
    --bs-box-shadow-sm: 0 .125rem .25rem rgba(0, 0, 0, .075);
    --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, .175);
    --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, .075);
    --bs-focus-ring-width: .25rem;
    --bs-focus-ring-opacity: .25;
    --bs-focus-ring-color: rgba(14, 102, 243, .25);
    --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: rgba(222, 226, 230, .75);
    --bs-secondary-color-rgb: 222, 226, 230;
    --bs-secondary-bg: #343a40;
    --bs-secondary-bg-rgb: 52, 58, 64;
    --bs-tertiary-color: rgba(222, 226, 230, .5);
    --bs-tertiary-color-rgb: 222, 226, 230;
    --bs-tertiary-bg: #2b3035;
    --bs-tertiary-bg-rgb: 43, 48, 53;
    --bs-primary-text-emphasis: #6ea3f8;
    --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: #031431;
    --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: #083d92;
    --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: #6ea3f8;
    --bs-link-hover-color: #8bb5f9;
    --bs-link-color-rgb: 110, 163, 248;
    --bs-link-hover-color-rgb: 139, 181, 249;
    --bs-code-color: #e685b5;
    --bs-highlight-color: #dee2e6;
    --bs-highlight-bg: #664d03;
    --bs-border-color: #495057;
    --bs-border-color-translucent: rgba(255, 255, 255, .15);
    --bs-form-valid-color: #75b798;
    --bs-form-valid-border-color: #75b798;
    --bs-form-invalid-color: #ea868f;
    --bs-form-invalid-border-color: #ea868f
}

.clearfix:after {
    display: block;
    clear: both;
    content: ""
}

.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(11,82,194,var(--bs-link-opacity, 1)) !important;
        text-decoration-color: RGBA(11,82,194,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 {
    outline: 0;
    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)
}

.icon-link {
    display: inline-flex;
    gap: .375rem;
    align-items: center;
    text-decoration-color: rgba(var(--bs-link-color-rgb),var(--bs-link-opacity, .5));
    text-underline-offset: .25em;
    backface-visibility: hidden
}

    .icon-link > .bi {
        flex-shrink: 0;
        width: 1em;
        height: 1em;
        fill: currentcolor;
        transition: .2s ease-in-out transform
    }

@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 {
    position: relative;
    width: 100%
}

    .ratio:before {
        display: block;
        padding-top: var(--bs-aspect-ratio);
        content: ""
    }

    .ratio > * {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%
    }

.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.8571428571%
}

.fixed-top {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030
}

.fixed-bottom {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1030
}

.sticky-top {
    position: sticky;
    top: 0;
    z-index: 1020
}

.sticky-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020
}

@media (min-width: 576px) {
    .sticky-sm-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }

    .sticky-sm-bottom {
        position: sticky;
        bottom: 0;
        z-index: 1020
    }
}

@media (min-width: 768px) {
    .sticky-md-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }

    .sticky-md-bottom {
        position: sticky;
        bottom: 0;
        z-index: 1020
    }
}

@media (min-width: 992px) {
    .sticky-lg-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }

    .sticky-lg-bottom {
        position: sticky;
        bottom: 0;
        z-index: 1020
    }
}

@media (min-width: 1150px) {
    .sticky-xl-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }

    .sticky-xl-bottom {
        position: sticky;
        bottom: 0;
        z-index: 1020
    }
}

@media (min-width: 1400px) {
    .sticky-xxl-top {
        position: sticky;
        top: 0;
        z-index: 1020
    }

    .sticky-xxl-bottom {
        position: sticky;
        bottom: 0;
        z-index: 1020
    }
}

.hstack {
    display: flex;
    flex-direction: row;
    align-items: center;
    align-self: stretch
}

.vstack {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    align-self: stretch
}

.visually-hidden, .visually-hidden-focusable:not(:focus):not(:focus-within) {
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
    white-space: nowrap !important;
    border: 0 !important
}

    .visually-hidden:not(caption), .visually-hidden-focusable:not(:focus):not(:focus-within):not(caption) {
        position: absolute !important
    }

.stretched-link:after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    content: ""
}

.text-truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
}

.vr {
    display: inline-block;
    align-self: stretch;
    width: var(--bs-border-width);
    min-height: 1em;
    background-color: currentcolor;
    opacity: .25
}

*, *:before, *:after {
    box-sizing: border-box
}

@media (prefers-reduced-motion: no-preference) {
    :root {
        scroll-behavior: smooth
    }
}

body {
    margin: 0;
    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: rgba(0,0,0,0)
}

hr {
    margin: 1rem 0;
    color: inherit;
    border: 0;
    border-top: var(--bs-border-width) solid;
    opacity: .25
}

h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1 {
    margin-top: 0;
    margin-bottom: .5rem;
    font-weight: 500;
    line-height: 1.2;
    color: var(--bs-heading-color)
}

h1, .h1 {
    font-size: calc(1.375rem + 1.5vw)
}

@media (min-width: 1200px) {
    h1, .h1 {
        font-size: 2.5rem
    }
}

h2, .h2 {
    font-size: calc(1.325rem + .9vw)
}

@media (min-width: 1200px) {
    h2, .h2 {
        font-size: 2rem
    }
}

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

@media (min-width: 1200px) {
    h3, .h3 {
        font-size: 1.75rem
    }
}

h4, .h4 {
    font-size: calc(1.275rem + .3vw)
}

@media (min-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] {
    text-decoration: underline dotted;
    cursor: help;
    text-decoration-skip-ink: none
}

address {
    margin-bottom: 1rem;
    font-style: normal;
    line-height: inherit
}

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 {
    padding: .1875em;
    color: var(--bs-highlight-color);
    background-color: var(--bs-highlight-bg)
}

sub, sup {
    position: relative;
    font-size: .75em;
    line-height: 0;
    vertical-align: baseline
}

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 {
    display: block;
    margin-top: 0;
    margin-bottom: 1rem;
    overflow: auto;
    font-size: .875em
}

    pre code {
        font-size: inherit;
        color: inherit;
        word-break: normal
    }

code {
    font-size: .875em;
    color: var(--bs-code-color);
    word-wrap: break-word
}

a > code {
    color: inherit
}

kbd {
    padding: .1875rem .375rem;
    font-size: .875em;
    color: var(--bs-body-bg);
    background-color: var(--bs-body-color);
    border-radius: .25rem
}

    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 {
    padding-top: .5rem;
    padding-bottom: .5rem;
    color: var(--bs-secondary-color);
    text-align: left
}

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 {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit
}

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 {
    padding: 0;
    border-style: none
}

textarea {
    resize: vertical
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0
}

legend {
    float: left;
    width: 100%;
    padding: 0;
    margin-bottom: .5rem;
    font-size: calc(1.275rem + .3vw);
    line-height: inherit
}

@media (min-width: 1200px) {
    legend {
        font-size: 1.5rem
    }
}

legend + * {
    clear: left
}

::-webkit-datetime-edit-fields-wrapper, ::-webkit-datetime-edit-text, ::-webkit-datetime-edit-minute, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-month-field, ::-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 {
    display: list-item;
    cursor: pointer
}

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 (min-width: 1200px) {
    .display-1 {
        font-size: 5rem
    }
}

.display-2 {
    font-size: calc(1.575rem + 3.9vw);
    font-weight: 300;
    line-height: 1.2
}

@media (min-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 (min-width: 1200px) {
    .display-3 {
        font-size: 4rem
    }
}

.display-4 {
    font-size: calc(1.475rem + 2.7vw);
    font-weight: 300;
    line-height: 1.2
}

@media (min-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 (min-width: 1200px) {
    .display-5 {
        font-size: 3rem
    }
}

.display-6 {
    font-size: calc(1.375rem + 1.5vw);
    font-weight: 300;
    line-height: 1.2
}

@media (min-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 {
    font-size: .875em;
    text-transform: uppercase
}

.blockquote {
    margin-bottom: 1rem;
    font-size: 1.25rem
}

    .blockquote > :last-child {
        margin-bottom: 0
    }

.blockquote-footer {
    margin-top: -1rem;
    margin-bottom: 1rem;
    font-size: .875em;
    color: #6c757d
}

    .blockquote-footer:before {
        content: "— "
    }

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

.img-thumbnail {
    padding: .25rem;
    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
}

.figure {
    display: inline-block
}

.figure-img {
    margin-bottom: .5rem;
    line-height: 1
}

.figure-caption {
    font-size: .875em;
    color: var(--bs-secondary-color)
}

.container, .container-fluid, .container-xxl, .container-xl, .container-lg, .container-md, .container-sm {
    --bs-gutter-x: 28px;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
    margin-right: auto;
    margin-left: auto
}

@media (min-width: 576px) {
    .container-sm, .container {
        max-width: 540px
    }
}

@media (min-width: 768px) {
    .container-md, .container-sm, .container {
        max-width: 720px
    }
}

@media (min-width: 992px) {
    .container-lg, .container-md, .container-sm, .container {
        max-width: 960px
    }
}

@media (min-width: 1150px) {
    .container-xl, .container-lg, .container-md, .container-sm, .container {
        max-width: 1150px
    }
}

@media (min-width: 1400px) {
    .container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container {
        max-width: 1400px
    }
}

:root {
    --bs-breakpoint-xs: 0;
    --bs-breakpoint-sm: 576px;
    --bs-breakpoint-md: 768px;
    --bs-breakpoint-lg: 992px;
    --bs-breakpoint-xl: 1150px;
    --bs-breakpoint-xxl: 1400px;  
}

.row {
    --bs-gutter-x: 28px;
    --bs-gutter-y: 0;
    display: flex;
    flex-wrap: wrap;
    margin-top: calc(-1 * var(--bs-gutter-y));
    margin-right: calc(-.5 * var(--bs-gutter-x));
    margin-left: calc(-.5 * var(--bs-gutter-x))
}

    .row > * {
        flex-shrink: 0;
        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)
    }

.col {
    flex: 1 0 0%
}

.row-cols-auto > * {
    flex: 0 0 auto;
    width: auto
}

.row-cols-1 > * {
    flex: 0 0 auto;
    width: 100%
}

.row-cols-2 > * {
    flex: 0 0 auto;
    width: 50%
}

.row-cols-3 > * {
    flex: 0 0 auto;
    width: 33.33333333%
}

.row-cols-4 > * {
    flex: 0 0 auto;
    width: 25%
}

.row-cols-5 > * {
    flex: 0 0 auto;
    width: 20%
}

.row-cols-6 > * {
    flex: 0 0 auto;
    width: 16.66666667%
}

.col-auto {
    flex: 0 0 auto;
    width: auto
}

.col-1 {
    flex: 0 0 auto;
    width: 8.33333333%
}

.col-2 {
    flex: 0 0 auto;
    width: 16.66666667%
}

.col-3 {
    flex: 0 0 auto;
    width: 25%
}

.col-4 {
    flex: 0 0 auto;
    width: 33.33333333%
}

.col-5 {
    flex: 0 0 auto;
    width: 41.66666667%
}

.col-6 {
    flex: 0 0 auto;
    width: 50%
}

.col-7 {
    flex: 0 0 auto;
    width: 58.33333333%
}

.col-8 {
    flex: 0 0 auto;
    width: 66.66666667%
}

.col-9 {
    flex: 0 0 auto;
    width: 75%
}

.col-10 {
    flex: 0 0 auto;
    width: 83.33333333%
}

.col-11 {
    flex: 0 0 auto;
    width: 91.66666667%
}

.col-12 {
    flex: 0 0 auto;
    width: 100%
}

.offset-1 {
    margin-left: 8.33333333%
}

.offset-2 {
    margin-left: 16.66666667%
}

.offset-3 {
    margin-left: 25%
}

.offset-4 {
    margin-left: 33.33333333%
}

.offset-5 {
    margin-left: 41.66666667%
}

.offset-6 {
    margin-left: 50%
}

.offset-7 {
    margin-left: 58.33333333%
}

.offset-8 {
    margin-left: 66.66666667%
}

.offset-9 {
    margin-left: 75%
}

.offset-10 {
    margin-left: 83.33333333%
}

.offset-11 {
    margin-left: 91.66666667%
}

.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 (min-width: 576px) {
    .col-sm {
        flex: 1 0 0%
    }

    .row-cols-sm-auto > * {
        flex: 0 0 auto;
        width: auto
    }

    .row-cols-sm-1 > * {
        flex: 0 0 auto;
        width: 100%
    }

    .row-cols-sm-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-sm-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-sm-4 > * {
        flex: 0 0 auto;
        width: 25%
    }

    .row-cols-sm-5 > * {
        flex: 0 0 auto;
        width: 20%
    }

    .row-cols-sm-6 > * {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-sm-auto {
        flex: 0 0 auto;
        width: auto
    }

    .col-sm-1 {
        flex: 0 0 auto;
        width: 8.33333333%
    }

    .col-sm-2 {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-sm-3 {
        flex: 0 0 auto;
        width: 25%
    }

    .col-sm-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .col-sm-5 {
        flex: 0 0 auto;
        width: 41.66666667%
    }

    .col-sm-6 {
        flex: 0 0 auto;
        width: 50%
    }

    .col-sm-7 {
        flex: 0 0 auto;
        width: 58.33333333%
    }

    .col-sm-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }

    .col-sm-9 {
        flex: 0 0 auto;
        width: 75%
    }

    .col-sm-10 {
        flex: 0 0 auto;
        width: 83.33333333%
    }

    .col-sm-11 {
        flex: 0 0 auto;
        width: 91.66666667%
    }

    .col-sm-12 {
        flex: 0 0 auto;
        width: 100%
    }

    .offset-sm-0 {
        margin-left: 0
    }

    .offset-sm-1 {
        margin-left: 8.33333333%
    }

    .offset-sm-2 {
        margin-left: 16.66666667%
    }

    .offset-sm-3 {
        margin-left: 25%
    }

    .offset-sm-4 {
        margin-left: 33.33333333%
    }

    .offset-sm-5 {
        margin-left: 41.66666667%
    }

    .offset-sm-6 {
        margin-left: 50%
    }

    .offset-sm-7 {
        margin-left: 58.33333333%
    }

    .offset-sm-8 {
        margin-left: 66.66666667%
    }

    .offset-sm-9 {
        margin-left: 75%
    }

    .offset-sm-10 {
        margin-left: 83.33333333%
    }

    .offset-sm-11 {
        margin-left: 91.66666667%
    }

    .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 (min-width: 768px) {
    .col-md {
        flex: 1 0 0%
    }

    .row-cols-md-auto > * {
        flex: 0 0 auto;
        width: auto
    }

    .row-cols-md-1 > * {
        flex: 0 0 auto;
        width: 100%
    }

    .row-cols-md-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-md-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-md-4 > * {
        flex: 0 0 auto;
        width: 25%
    }

    .row-cols-md-5 > * {
        flex: 0 0 auto;
        width: 20%
    }

    .row-cols-md-6 > * {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-md-auto {
        flex: 0 0 auto;
        width: auto
    }

    .col-md-1 {
        flex: 0 0 auto;
        width: 8.33333333%
    }

    .col-md-2 {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-md-3 {
        flex: 0 0 auto;
        width: 25%
    }

    .col-md-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .col-md-5 {
        flex: 0 0 auto;
        width: 41.66666667%
    }

    .col-md-6 {
        flex: 0 0 auto;
        width: 50%
    }

    .col-md-7 {
        flex: 0 0 auto;
        width: 58.33333333%
    }

    .col-md-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }

    .col-md-9 {
        flex: 0 0 auto;
        width: 75%
    }

    .col-md-10 {
        flex: 0 0 auto;
        width: 83.33333333%
    }

    .col-md-11 {
        flex: 0 0 auto;
        width: 91.66666667%
    }

    .col-md-12 {
        flex: 0 0 auto;
        width: 100%
    }

    .offset-md-0 {
        margin-left: 0
    }

    .offset-md-1 {
        margin-left: 8.33333333%
    }

    .offset-md-2 {
        margin-left: 16.66666667%
    }

    .offset-md-3 {
        margin-left: 25%
    }

    .offset-md-4 {
        margin-left: 33.33333333%
    }

    .offset-md-5 {
        margin-left: 41.66666667%
    }

    .offset-md-6 {
        margin-left: 50%
    }

    .offset-md-7 {
        margin-left: 58.33333333%
    }

    .offset-md-8 {
        margin-left: 66.66666667%
    }

    .offset-md-9 {
        margin-left: 75%
    }

    .offset-md-10 {
        margin-left: 83.33333333%
    }

    .offset-md-11 {
        margin-left: 91.66666667%
    }

    .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 (min-width: 992px) {
    .col-lg {
        flex: 1 0 0%
    }

    .row-cols-lg-auto > * {
        flex: 0 0 auto;
        width: auto
    }

    .row-cols-lg-1 > * {
        flex: 0 0 auto;
        width: 100%
    }

    .row-cols-lg-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-lg-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-lg-4 > * {
        flex: 0 0 auto;
        width: 25%
    }

    .row-cols-lg-5 > * {
        flex: 0 0 auto;
        width: 20%
    }

    .row-cols-lg-6 > * {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-lg-auto {
        flex: 0 0 auto;
        width: auto
    }

    .col-lg-1 {
        flex: 0 0 auto;
        width: 8.33333333%
    }

    .col-lg-2 {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-lg-3 {
        flex: 0 0 auto;
        width: 25%
    }

    .col-lg-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .col-lg-5 {
        flex: 0 0 auto;
        width: 41.66666667%
    }

    .col-lg-6 {
        flex: 0 0 auto;
        width: 50%
    }

    .col-lg-7 {
        flex: 0 0 auto;
        width: 58.33333333%
    }

    .col-lg-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }

    .col-lg-9 {
        flex: 0 0 auto;
        width: 75%
    }

    .col-lg-10 {
        flex: 0 0 auto;
        width: 83.33333333%
    }

    .col-lg-11 {
        flex: 0 0 auto;
        width: 91.66666667%
    }

    .col-lg-12 {
        flex: 0 0 auto;
        width: 100%
    }

    .offset-lg-0 {
        margin-left: 0
    }

    .offset-lg-1 {
        margin-left: 8.33333333%
    }

    .offset-lg-2 {
        margin-left: 16.66666667%
    }

    .offset-lg-3 {
        margin-left: 25%
    }

    .offset-lg-4 {
        margin-left: 33.33333333%
    }

    .offset-lg-5 {
        margin-left: 41.66666667%
    }

    .offset-lg-6 {
        margin-left: 50%
    }

    .offset-lg-7 {
        margin-left: 58.33333333%
    }

    .offset-lg-8 {
        margin-left: 66.66666667%
    }

    .offset-lg-9 {
        margin-left: 75%
    }

    .offset-lg-10 {
        margin-left: 83.33333333%
    }

    .offset-lg-11 {
        margin-left: 91.66666667%
    }

    .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 (min-width: 1150px) {
    .col-xl {
        flex: 1 0 0%
    }

    .row-cols-xl-auto > * {
        flex: 0 0 auto;
        width: auto
    }

    .row-cols-xl-1 > * {
        flex: 0 0 auto;
        width: 100%
    }

    .row-cols-xl-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-xl-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-xl-4 > * {
        flex: 0 0 auto;
        width: 25%
    }

    .row-cols-xl-5 > * {
        flex: 0 0 auto;
        width: 20%
    }

    .row-cols-xl-6 > * {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-xl-auto {
        flex: 0 0 auto;
        width: auto
    }

    .col-xl-1 {
        flex: 0 0 auto;
        width: 8.33333333%
    }

    .col-xl-2 {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-xl-3 {
        flex: 0 0 auto;
        width: 25%
    }

    .col-xl-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .col-xl-5 {
        flex: 0 0 auto;
        width: 41.66666667%
    }

    .col-xl-6 {
        flex: 0 0 auto;
        width: 50%
    }

    .col-xl-7 {
        flex: 0 0 auto;
        width: 58.33333333%
    }

    .col-xl-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }

    .col-xl-9 {
        flex: 0 0 auto;
        width: 75%
    }

    .col-xl-10 {
        flex: 0 0 auto;
        width: 83.33333333%
    }

    .col-xl-11 {
        flex: 0 0 auto;
        width: 91.66666667%
    }

    .col-xl-12 {
        flex: 0 0 auto;
        width: 100%
    }

    .offset-xl-0 {
        margin-left: 0
    }

    .offset-xl-1 {
        margin-left: 8.33333333%
    }

    .offset-xl-2 {
        margin-left: 16.66666667%
    }

    .offset-xl-3 {
        margin-left: 25%
    }

    .offset-xl-4 {
        margin-left: 33.33333333%
    }

    .offset-xl-5 {
        margin-left: 41.66666667%
    }

    .offset-xl-6 {
        margin-left: 50%
    }

    .offset-xl-7 {
        margin-left: 58.33333333%
    }

    .offset-xl-8 {
        margin-left: 66.66666667%
    }

    .offset-xl-9 {
        margin-left: 75%
    }

    .offset-xl-10 {
        margin-left: 83.33333333%
    }

    .offset-xl-11 {
        margin-left: 91.66666667%
    }

    .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 (min-width: 1400px) {
    .col-xxl {
        flex: 1 0 0%
    }

    .row-cols-xxl-auto > * {
        flex: 0 0 auto;
        width: auto
    }

    .row-cols-xxl-1 > * {
        flex: 0 0 auto;
        width: 100%
    }

    .row-cols-xxl-2 > * {
        flex: 0 0 auto;
        width: 50%
    }

    .row-cols-xxl-3 > * {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .row-cols-xxl-4 > * {
        flex: 0 0 auto;
        width: 25%
    }

    .row-cols-xxl-5 > * {
        flex: 0 0 auto;
        width: 20%
    }

    .row-cols-xxl-6 > * {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-xxl-auto {
        flex: 0 0 auto;
        width: auto
    }

    .col-xxl-1 {
        flex: 0 0 auto;
        width: 8.33333333%
    }

    .col-xxl-2 {
        flex: 0 0 auto;
        width: 16.66666667%
    }

    .col-xxl-3 {
        flex: 0 0 auto;
        width: 25%
    }

    .col-xxl-4 {
        flex: 0 0 auto;
        width: 33.33333333%
    }

    .col-xxl-5 {
        flex: 0 0 auto;
        width: 41.66666667%
    }

    .col-xxl-6 {
        flex: 0 0 auto;
        width: 50%
    }

    .col-xxl-7 {
        flex: 0 0 auto;
        width: 58.33333333%
    }

    .col-xxl-8 {
        flex: 0 0 auto;
        width: 66.66666667%
    }

    .col-xxl-9 {
        flex: 0 0 auto;
        width: 75%
    }

    .col-xxl-10 {
        flex: 0 0 auto;
        width: 83.33333333%
    }

    .col-xxl-11 {
        flex: 0 0 auto;
        width: 91.66666667%
    }

    .col-xxl-12 {
        flex: 0 0 auto;
        width: 100%
    }

    .offset-xxl-0 {
        margin-left: 0
    }

    .offset-xxl-1 {
        margin-left: 8.33333333%
    }

    .offset-xxl-2 {
        margin-left: 16.66666667%
    }

    .offset-xxl-3 {
        margin-left: 25%
    }

    .offset-xxl-4 {
        margin-left: 33.33333333%
    }

    .offset-xxl-5 {
        margin-left: 41.66666667%
    }

    .offset-xxl-6 {
        margin-left: 50%
    }

    .offset-xxl-7 {
        margin-left: 58.33333333%
    }

    .offset-xxl-8 {
        margin-left: 66.66666667%
    }

    .offset-xxl-9 {
        margin-left: 75%
    }

    .offset-xxl-10 {
        margin-left: 83.33333333%
    }

    .offset-xxl-11 {
        margin-left: 91.66666667%
    }

    .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);
    width: 100%;
    margin-bottom: 1rem;
    vertical-align: top;
    border-color: var(--bs-table-border-color)
}

    .table > :not(caption) > * > * {
        padding: .5rem;
        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)))
    }

    .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) > * {
    --bs-table-color-type: var(--bs-table-striped-color);
    --bs-table-bg-type: var(--bs-table-striped-bg)
}

.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: #cfe0fd;
    --bs-table-border-color: #a6b3ca;
    --bs-table-striped-bg: #c5d5f0;
    --bs-table-striped-color: #000;
    --bs-table-active-bg: #bacae4;
    --bs-table-active-color: #000;
    --bs-table-hover-bg: #bfcfea;
    --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 {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch
}

@media (max-width: 575.98px) {
    .table-responsive-sm {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch
    }
}

@media (max-width: 767.98px) {
    .table-responsive-md {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch
    }
}

@media (max-width: 991.98px) {
    .table-responsive-lg {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch
    }
}

@media (max-width: 1149.98px) {
    .table-responsive-xl {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch
    }
}

@media (max-width: 1399.98px) {
    .table-responsive-xxl {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch
    }
}

.form-label {
    margin-bottom: .5rem
}

.col-form-label {
    padding-top: calc(.375rem + var(--bs-border-width));
    padding-bottom: calc(.375rem + var(--bs-border-width));
    margin-bottom: 0;
    font-size: inherit;
    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 {
    margin-top: .25rem;
    font-size: .875em;
    color: var(--bs-secondary-color)
}

.form-control {
    display: block;
    width: 100%;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: var(--bs-body-bg);
    background-clip: padding-box;
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out
}

@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: #87b3f9;
    outline: 0;
    box-shadow: 0 0 0 .25rem #0e66f340
}

.form-control::-webkit-date-and-time-value {
    min-width: 85px;
    height: 1.5em;
    margin: 0
}

.form-control::-webkit-datetime-edit {
    display: block;
    padding: 0
}

.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 {
    padding: .375rem .75rem;
    margin: -.375rem -.75rem;
    margin-inline-end: .75rem;
    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);
    border-radius: 0;
    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 {
    display: block;
    width: 100%;
    padding: .375rem 0;
    margin-bottom: 0;
    line-height: 1.5;
    color: var(--bs-body-color);
    background-color: transparent;
    border: solid transparent;
    border-width: var(--bs-border-width) 0
}

    .form-control-plaintext:focus {
        outline: 0
    }

    .form-control-plaintext.form-control-sm, .form-control-plaintext.form-control-lg {
        padding-right: 0;
        padding-left: 0
    }

.form-control-sm {
    min-height: calc(1.5em + .5rem + calc(var(--bs-border-width) * 2));
    padding: .25rem .5rem;
    font-size: .875rem;
    border-radius: var(--bs-border-radius-sm)
}

    .form-control-sm::file-selector-button {
        padding: .25rem .5rem;
        margin: -.25rem -.5rem;
        margin-inline-end: .5rem
    }

.form-control-lg {
    min-height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
    padding: .5rem 1rem;
    font-size: 1.25rem;
    border-radius: var(--bs-border-radius-lg)
}

    .form-control-lg::file-selector-button {
        padding: .5rem 1rem;
        margin: -.5rem -1rem;
        margin-inline-end: 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: 0 !important;
        border-radius: var(--bs-border-radius)
    }

    .form-control-color::-webkit-color-swatch {
        border: 0 !important;
        border-radius: var(--bs-border-radius)
    }

    .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");
    display: block;
    width: 100%;
    padding: .375rem 2.25rem .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: var(--bs-body-bg);
    background-image: var(--bs-form-select-bg-img),var(--bs-form-select-bg-icon, none);
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 16px 12px;
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out
}

@media (prefers-reduced-motion: reduce) {
    .form-select {
        transition: none
    }
}

.form-select:focus {
    border-color: #87b3f9;
    outline: 0;
    box-shadow: 0 0 0 .25rem #0e66f340
}

.form-select[multiple], .form-select[size]:not([size="1"]) {
    padding-right: .75rem;
    background-image: none
}

.form-select:disabled {
    background-color: var(--bs-secondary-bg)
}

.form-select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 var(--bs-body-color)
}

.form-select-sm {
    padding-top: .25rem;
    padding-bottom: .25rem;
    padding-left: .5rem;
    font-size: .875rem;
    border-radius: var(--bs-border-radius-sm)
}

.form-select-lg {
    padding-top: .5rem;
    padding-bottom: .5rem;
    padding-left: 1rem;
    font-size: 1.25rem;
    border-radius: var(--bs-border-radius-lg)
}

[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 {
    display: block;
    min-height: 1.5rem;
    padding-left: 1.5em;
    margin-bottom: .125rem
}

    .form-check .form-check-input {
        float: left;
        margin-left: -1.5em
    }

.form-check-reverse {
    padding-right: 1.5em;
    padding-left: 0;
    text-align: right
}

    .form-check-reverse .form-check-input {
        float: right;
        margin-right: -1.5em;
        margin-left: 0
    }

.form-check-input {
    --bs-form-check-bg: var(--bs-body-bg);
    flex-shrink: 0;
    width: 1em;
    height: 1em;
    margin-top: .25em;
    vertical-align: top;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: var(--bs-form-check-bg);
    background-image: var(--bs-form-check-bg-image);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    border: var(--bs-border-width) solid var(--bs-border-color);
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact
}

    .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: #87b3f9;
        outline: 0;
        box-shadow: 0 0 0 .25rem #0e66f340
    }

    .form-check-input:checked {
        background-color: #0e66f3;
        border-color: #0e66f3
    }

        .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 {
        background-color: #0e66f3;
        border-color: #0e66f3;
        --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")
    }

    .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");
        width: 2em;
        margin-left: -2.5em;
        background-image: var(--bs-form-switch-bg);
        background-position: left center;
        border-radius: 2em;
        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='%2387b3f9'/%3e%3c/svg%3e")
}

.form-switch .form-check-input:checked {
    background-position: right center;
    --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")
}

.form-switch.form-check-reverse {
    padding-right: 2.5em;
    padding-left: 0
}

    .form-switch.form-check-reverse .form-check-input {
        margin-right: -2.5em;
        margin-left: 0
    }

.form-check-inline {
    display: inline-block;
    margin-right: 1rem
}

.btn-check {
    position: absolute;
    clip: rect(0,0,0,0);
    pointer-events: none
}

    .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 {
    width: 100%;
    height: 1.5rem;
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: transparent
}

    .form-range:focus {
        outline: 0
    }

        .form-range:focus::-webkit-slider-thumb {
            box-shadow: 0 0 0 1px #fff,0 0 0 .25rem #0e66f340
        }

        .form-range:focus::-moz-range-thumb {
            box-shadow: 0 0 0 1px #fff,0 0 0 .25rem #0e66f340
        }

    .form-range::-moz-focus-outer {
        border: 0
    }

    .form-range::-webkit-slider-thumb {
        width: 1rem;
        height: 1rem;
        margin-top: -.25rem;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        background-color: #0e66f3;
        border: 0;
        border-radius: 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::-webkit-slider-thumb {
        transition: none
    }
}

.form-range::-webkit-slider-thumb:active {
    background-color: #b7d1fb
}

.form-range::-webkit-slider-runnable-track {
    width: 100%;
    height: .5rem;
    color: transparent;
    cursor: pointer;
    background-color: var(--bs-secondary-bg);
    border-color: transparent;
    border-radius: 1rem
}

.form-range::-moz-range-thumb {
    width: 1rem;
    height: 1rem;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #0e66f3;
    border: 0;
    border-radius: 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: #b7d1fb
}

.form-range::-moz-range-track {
    width: 100%;
    height: .5rem;
    color: transparent;
    cursor: pointer;
    background-color: var(--bs-secondary-bg);
    border-color: transparent;
    border-radius: 1rem
}

.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 {
        position: absolute;
        top: 0;
        left: 0;
        z-index: 2;
        height: 100%;
        padding: 1rem .75rem;
        overflow: hidden;
        text-align: start;
        text-overflow: ellipsis;
        white-space: nowrap;
        pointer-events: none;
        border: var(--bs-border-width) solid transparent;
        transform-origin: 0 0;
        transition: opacity .1s ease-in-out,transform .1s ease-in-out
    }

@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: transparent
    }

    .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) {
        padding-top: 1.625rem;
        padding-bottom: .625rem
    }

    .form-floating > .form-control:-webkit-autofill, .form-floating > .form-control-plaintext:-webkit-autofill {
        padding-top: 1.625rem;
        padding-bottom: .625rem
    }

.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) translate(.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 {
            position: absolute;
            top: 1rem;
            right: .375rem;
            bottom: 1rem;
            left: .375rem;
            z-index: -1;
            height: 1.5em;
            content: "";
            background-color: var(--bs-body-bg);
            border-radius: var(--bs-border-radius)
        }

.form-floating > .form-control:-webkit-autofill ~ label {
    color: rgba(var(--bs-body-color-rgb),.65);
    transform: scale(.85) translateY(-.5rem) translate(.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 {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 100%
}

    .input-group > .form-control, .input-group > .form-select, .input-group > .form-floating {
        position: relative;
        flex: 1 1 auto;
        width: 1%;
        min-width: 0
    }

        .input-group > .form-control:focus, .input-group > .form-select:focus, .input-group > .form-floating:focus-within {
            z-index: 5
        }

    .input-group .btn {
        position: relative;
        z-index: 2
    }

        .input-group .btn:focus {
            z-index: 5
        }

.input-group-text {
    display: flex;
    align-items: center;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    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)
}

.input-group-lg > .form-control, .input-group-lg > .form-select, .input-group-lg > .input-group-text, .input-group-lg > .btn {
    padding: .5rem 1rem;
    font-size: 1.25rem;
    border-radius: var(--bs-border-radius-lg)
}

.input-group-sm > .form-control, .input-group-sm > .form-select, .input-group-sm > .input-group-text, .input-group-sm > .btn {
    padding: .25rem .5rem;
    font-size: .875rem;
    border-radius: var(--bs-border-radius-sm)
}

.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 {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0
}

.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 {
    display: none;
    width: 100%;
    margin-top: .25rem;
    font-size: .875em;
    color: var(--bs-form-valid-color)
}

.valid-tooltip {
    position: absolute;
    top: 100%;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: .25rem .5rem;
    margin-top: .1rem;
    font-size: .875rem;
    color: #fff;
    background-color: var(--bs-success);
    border-radius: var(--bs-border-radius)
}

.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);
    padding-right: calc(1.5em + .75rem);
    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-repeat: no-repeat;
    background-position: right calc(.375em + .1875rem) center;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem)
}

    .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 {
    padding-right: calc(1.5em + .75rem);
    background-position: top calc(.375em + .1875rem) right calc(.375em + .1875rem)
}

.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");
        padding-right: 4.125rem;
        background-position: right .75rem center,center right 2.25rem;
        background-size: 16px 12px,calc(.75em + .375rem) calc(.75em + .375rem)
    }

    .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(3.75rem + 1.5em)
}

.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 {
    display: none;
    width: 100%;
    margin-top: .25rem;
    font-size: .875em;
    color: var(--bs-form-invalid-color)
}

.invalid-tooltip {
    position: absolute;
    top: 100%;
    z-index: 5;
    display: none;
    max-width: 100%;
    padding: .25rem .5rem;
    margin-top: .1rem;
    font-size: .875rem;
    color: #fff;
    background-color: var(--bs-danger);
    border-radius: var(--bs-border-radius)
}

.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);
    padding-right: calc(1.5em + .75rem);
    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-repeat: no-repeat;
    background-position: right calc(.375em + .1875rem) center;
    background-size: calc(.75em + .375rem) calc(.75em + .375rem)
}

    .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 {
    padding-right: calc(1.5em + .75rem);
    background-position: top calc(.375em + .1875rem) right calc(.375em + .1875rem)
}

.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");
        padding-right: 4.125rem;
        background-position: right .75rem center,center right 2.25rem;
        background-size: 16px 12px,calc(.75em + .375rem) calc(.75em + .375rem)
    }

    .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(3.75rem + 1.5em)
}

.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 rgba(255, 255, 255, .15), 0 1px 1px rgba(0, 0, 0, .075);
    --bs-btn-disabled-opacity: .65;
    --bs-btn-focus-box-shadow: 0 0 0 .25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);
    display: inline-block;
    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;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    -webkit-user-select: none;
    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);
    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) {
    .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);
    outline: 0;
    box-shadow: var(--bs-btn-focus-box-shadow)
}

.btn-check:focus-visible + .btn {
    border-color: var(--bs-btn-hover-border-color);
    outline: 0;
    box-shadow: var(--bs-btn-focus-box-shadow)
}

.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 {
        box-shadow: var(--bs-btn-focus-box-shadow)
    }

.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: #0e66f3;
    --bs-btn-border-color: #0e66f3;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #0c57cf;
    --bs-btn-hover-border-color: #0b52c2;
    --bs-btn-focus-shadow-rgb: 50, 125, 245;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #0b52c2;
    --bs-btn-active-border-color: #0b4db6;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #0e66f3;
    --bs-btn-disabled-border-color: #0e66f3
}

.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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #212529;
    --bs-btn-disabled-border-color: #212529
}

.btn-outline-primary {
    --bs-btn-color: #0e66f3;
    --bs-btn-border-color: #0e66f3;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #0e66f3;
    --bs-btn-hover-border-color: #0e66f3;
    --bs-btn-focus-shadow-rgb: 14, 102, 243;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #0e66f3;
    --bs-btn-active-border-color: #0e66f3;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
    --bs-btn-disabled-color: #0e66f3;
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: #0e66f3;
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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 rgba(0, 0, 0, .125);
    --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: 50, 125, 245;
    text-decoration: underline
}

    .btn-link:focus-visible {
        color: var(--bs-btn-color)
    }

    .btn-link:hover {
        color: var(--bs-btn-hover-color)
    }

.btn-lg {
    --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 {
    --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;
    overflow: hidden;
    transition: height .35s ease
}

@media (prefers-reduced-motion: reduce) {
    .collapsing {
        transition: none
    }
}

.collapsing.collapse-horizontal {
    width: 0;
    height: auto;
    transition: width .35s ease
}

@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 {
        display: inline-block;
        margin-left: .255em;
        vertical-align: .255em;
        content: "";
        border-top: .3em solid;
        border-right: .3em solid transparent;
        border-bottom: 0;
        border-left: .3em solid transparent
    }

    .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: #0e66f3;
    --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;
    position: absolute;
    z-index: var(--bs-dropdown-zindex);
    display: none;
    min-width: var(--bs-dropdown-min-width);
    padding: var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);
    margin: 0;
    font-size: var(--bs-dropdown-font-size);
    color: var(--bs-dropdown-color);
    text-align: left;
    list-style: none;
    background-color: var(--bs-dropdown-bg);
    background-clip: padding-box;
    border: var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);
    border-radius: var(--bs-dropdown-border-radius)
}

    .dropdown-menu[data-bs-popper] {
        top: 100%;
        left: 0;
        margin-top: var(--bs-dropdown-spacer)
    }

.dropdown-menu-start {
    --bs-position: start
}

    .dropdown-menu-start[data-bs-popper] {
        right: auto;
        left: 0
    }

.dropdown-menu-end {
    --bs-position: end
}

    .dropdown-menu-end[data-bs-popper] {
        right: 0;
        left: auto
    }

@media (min-width: 576px) {
    .dropdown-menu-sm-start {
        --bs-position: start
    }

        .dropdown-menu-sm-start[data-bs-popper] {
            right: auto;
            left: 0
        }

    .dropdown-menu-sm-end {
        --bs-position: end
    }

        .dropdown-menu-sm-end[data-bs-popper] {
            right: 0;
            left: auto
        }
}

@media (min-width: 768px) {
    .dropdown-menu-md-start {
        --bs-position: start
    }

        .dropdown-menu-md-start[data-bs-popper] {
            right: auto;
            left: 0
        }

    .dropdown-menu-md-end {
        --bs-position: end
    }

        .dropdown-menu-md-end[data-bs-popper] {
            right: 0;
            left: auto
        }
}

@media (min-width: 992px) {
    .dropdown-menu-lg-start {
        --bs-position: start
    }

        .dropdown-menu-lg-start[data-bs-popper] {
            right: auto;
            left: 0
        }

    .dropdown-menu-lg-end {
        --bs-position: end
    }

        .dropdown-menu-lg-end[data-bs-popper] {
            right: 0;
            left: auto
        }
}

@media (min-width: 1150px) {
    .dropdown-menu-xl-start {
        --bs-position: start
    }

        .dropdown-menu-xl-start[data-bs-popper] {
            right: auto;
            left: 0
        }

    .dropdown-menu-xl-end {
        --bs-position: end
    }

        .dropdown-menu-xl-end[data-bs-popper] {
            right: 0;
            left: auto
        }
}

@media (min-width: 1400px) {
    .dropdown-menu-xxl-start {
        --bs-position: start
    }

        .dropdown-menu-xxl-start[data-bs-popper] {
            right: auto;
            left: 0
        }

    .dropdown-menu-xxl-end {
        --bs-position: end
    }

        .dropdown-menu-xxl-end[data-bs-popper] {
            right: 0;
            left: auto
        }
}

.dropup .dropdown-menu[data-bs-popper] {
    top: auto;
    bottom: 100%;
    margin-top: 0;
    margin-bottom: var(--bs-dropdown-spacer)
}

.dropup .dropdown-toggle:after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: 0;
    border-right: .3em solid transparent;
    border-bottom: .3em solid;
    border-left: .3em solid transparent
}

.dropup .dropdown-toggle:empty:after {
    margin-left: 0
}

.dropend .dropdown-menu[data-bs-popper] {
    top: 0;
    right: auto;
    left: 100%;
    margin-top: 0;
    margin-left: var(--bs-dropdown-spacer)
}

.dropend .dropdown-toggle:after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: "";
    border-top: .3em solid transparent;
    border-right: 0;
    border-bottom: .3em solid transparent;
    border-left: .3em solid
}

.dropend .dropdown-toggle:empty:after {
    margin-left: 0
}

.dropend .dropdown-toggle:after {
    vertical-align: 0
}

.dropstart .dropdown-menu[data-bs-popper] {
    top: 0;
    right: 100%;
    left: auto;
    margin-top: 0;
    margin-right: var(--bs-dropdown-spacer)
}

.dropstart .dropdown-toggle:after {
    display: inline-block;
    margin-left: .255em;
    vertical-align: .255em;
    content: ""
}

.dropstart .dropdown-toggle:after {
    display: none
}

.dropstart .dropdown-toggle:before {
    display: inline-block;
    margin-right: .255em;
    vertical-align: .255em;
    content: "";
    border-top: .3em solid transparent;
    border-right: .3em solid;
    border-bottom: .3em solid transparent
}

.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;
    overflow: hidden;
    border-top: 1px solid var(--bs-dropdown-divider-bg);
    opacity: 1
}

.dropdown-item {
    display: block;
    width: 100%;
    padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
    clear: both;
    font-weight: 400;
    color: var(--bs-dropdown-link-color);
    text-align: inherit;
    text-decoration: none;
    white-space: nowrap;
    background-color: transparent;
    border: 0;
    border-radius: var(--bs-dropdown-item-border-radius, 0)
}

    .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);
        text-decoration: none;
        background-color: var(--bs-dropdown-link-active-bg)
    }

    .dropdown-item.disabled, .dropdown-item:disabled {
        color: var(--bs-dropdown-link-disabled-color);
        pointer-events: none;
        background-color: transparent
    }

.dropdown-menu.show {
    display: block
}

.dropdown-header {
    display: block;
    padding: var(--bs-dropdown-header-padding-y) var(--bs-dropdown-header-padding-x);
    margin-bottom: 0;
    font-size: .875rem;
    color: var(--bs-dropdown-header-color);
    white-space: nowrap
}

.dropdown-item-text {
    display: block;
    padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
    color: var(--bs-dropdown-link-color)
}

.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: rgba(255, 255, 255, .15);
    --bs-dropdown-link-active-color: #fff;
    --bs-dropdown-link-active-bg: #0e66f3;
    --bs-dropdown-link-disabled-color: #adb5bd;
    --bs-dropdown-header-color: #adb5bd
}

.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);
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none
}

.nav-link {
    display: block;
    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);
    text-decoration: none;
    background: none;
    border: 0;
    transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out
}

@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 #0e66f340
}

.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: #0e66f3
}

    .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 {
        padding-right: 0;
        padding-left: 0;
        border-bottom: var(--bs-nav-underline-border-width) solid transparent
    }

        .nav-underline .nav-link:hover, .nav-underline .nav-link:focus {
            border-bottom-color: currentcolor
        }

        .nav-underline .nav-link.active, .nav-underline .show > .nav-link {
            font-weight: 700;
            color: var(--bs-nav-underline-link-active-color);
            border-bottom-color: currentcolor
        }

.nav-fill > .nav-link, .nav-fill .nav-item {
    flex: 1 1 auto;
    text-align: center
}

.nav-justified > .nav-link, .nav-justified .nav-item {
    flex-basis: 0;
    flex-grow: 1;
    text-align: center
}

    .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;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: var(--bs-navbar-padding-y) var(--bs-navbar-padding-x)
}

    .navbar > .container, .navbar > .container-fluid, .navbar > .container-sm, .navbar > .container-md, .navbar > .container-lg, .navbar > .container-xl, .navbar > .container-xxl {
        display: flex;
        flex-wrap: inherit;
        align-items: center;
        justify-content: space-between
    }

.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);
    text-decoration: none;
    white-space: nowrap
}

    .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);
    display: flex;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none
}

    .navbar-nav .nav-link.active, .navbar-nav .nav-link.show {
        color: var(--bs-navbar-active-color)
    }

    .navbar-nav .dropdown-menu {
        position: static
    }

.navbar-text {
    padding-top: .5rem;
    padding-bottom: .5rem;
    color: var(--bs-navbar-color)
}

    .navbar-text a, .navbar-text a:hover, .navbar-text a:focus {
        color: var(--bs-navbar-active-color)
    }

.navbar-collapse {
    flex-basis: 100%;
    flex-grow: 1;
    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);
    line-height: 1;
    color: var(--bs-navbar-color);
    background-color: transparent;
    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)
}

@media (prefers-reduced-motion: reduce) {
    .navbar-toggler {
        transition: none
    }
}

.navbar-toggler:hover {
    text-decoration: none
}

.navbar-toggler:focus {
    text-decoration: none;
    outline: 0;
    box-shadow: 0 0 0 var(--bs-navbar-toggler-focus-width)
}

.navbar-toggler-icon {
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    vertical-align: middle;
    background-image: var(--bs-navbar-toggler-icon-bg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100%
}

.navbar-nav-scroll {
    max-height: var(--bs-scroll-height, 75vh);
    overflow-y: auto
}

@media (min-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 {
            display: flex !important;
            flex-basis: auto
        }

        .navbar-expand-sm .navbar-toggler {
            display: none
        }

        .navbar-expand-sm .offcanvas {
            position: static;
            z-index: auto;
            flex-grow: 1;
            width: auto !important;
            height: auto !important;
            visibility: visible !important;
            background-color: transparent !important;
            border: 0 !important;
            transform: none !important;
            transition: none
        }

            .navbar-expand-sm .offcanvas .offcanvas-header {
                display: none
            }

            .navbar-expand-sm .offcanvas .offcanvas-body {
                display: flex;
                flex-grow: 0;
                padding: 0;
                overflow-y: visible
            }
}

@media (min-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 {
            display: flex !important;
            flex-basis: auto
        }

        .navbar-expand-md .navbar-toggler {
            display: none
        }

        .navbar-expand-md .offcanvas {
            position: static;
            z-index: auto;
            flex-grow: 1;
            width: auto !important;
            height: auto !important;
            visibility: visible !important;
            background-color: transparent !important;
            border: 0 !important;
            transform: none !important;
            transition: none
        }

            .navbar-expand-md .offcanvas .offcanvas-header {
                display: none
            }

            .navbar-expand-md .offcanvas .offcanvas-body {
                display: flex;
                flex-grow: 0;
                padding: 0;
                overflow-y: visible
            }
}

@media (min-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 {
            display: flex !important;
            flex-basis: auto
        }

        .navbar-expand-lg .navbar-toggler {
            display: none
        }

        .navbar-expand-lg .offcanvas {
            position: static;
            z-index: auto;
            flex-grow: 1;
            width: auto !important;
            height: auto !important;
            visibility: visible !important;
            background-color: transparent !important;
            border: 0 !important;
            transform: none !important;
            transition: none
        }

            .navbar-expand-lg .offcanvas .offcanvas-header {
                display: none
            }

            .navbar-expand-lg .offcanvas .offcanvas-body {
                display: flex;
                flex-grow: 0;
                padding: 0;
                overflow-y: visible
            }
}

@media (min-width: 1150px) {
    .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 {
            display: flex !important;
            flex-basis: auto
        }

        .navbar-expand-xl .navbar-toggler {
            display: none
        }

        .navbar-expand-xl .offcanvas {
            position: static;
            z-index: auto;
            flex-grow: 1;
            width: auto !important;
            height: auto !important;
            visibility: visible !important;
            background-color: transparent !important;
            border: 0 !important;
            transform: none !important;
            transition: none
        }

            .navbar-expand-xl .offcanvas .offcanvas-header {
                display: none
            }

            .navbar-expand-xl .offcanvas .offcanvas-body {
                display: flex;
                flex-grow: 0;
                padding: 0;
                overflow-y: visible
            }
}

@media (min-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 {
            display: flex !important;
            flex-basis: auto
        }

        .navbar-expand-xxl .navbar-toggler {
            display: none
        }

        .navbar-expand-xxl .offcanvas {
            position: static;
            z-index: auto;
            flex-grow: 1;
            width: auto !important;
            height: auto !important;
            visibility: visible !important;
            background-color: transparent !important;
            border: 0 !important;
            transform: none !important;
            transition: none
        }

            .navbar-expand-xxl .offcanvas .offcanvas-header {
                display: none
            }

            .navbar-expand-xxl .offcanvas .offcanvas-body {
                display: flex;
                flex-grow: 0;
                padding: 0;
                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 {
        display: flex !important;
        flex-basis: auto
    }

    .navbar-expand .navbar-toggler {
        display: none
    }

    .navbar-expand .offcanvas {
        position: static;
        z-index: auto;
        flex-grow: 1;
        width: auto !important;
        height: auto !important;
        visibility: visible !important;
        background-color: transparent !important;
        border: 0 !important;
        transform: none !important;
        transition: none
    }

        .navbar-expand .offcanvas .offcanvas-header {
            display: none
        }

        .navbar-expand .offcanvas .offcanvas-body {
            display: flex;
            flex-grow: 0;
            padding: 0;
            overflow-y: visible
        }

.navbar-dark, .navbar[data-bs-theme=dark] {
    --bs-navbar-color: rgba(255, 255, 255, .55);
    --bs-navbar-hover-color: rgba(255, 255, 255, .75);
    --bs-navbar-disabled-color: rgba(255, 255, 255, .25);
    --bs-navbar-active-color: #fff;
    --bs-navbar-brand-color: #fff;
    --bs-navbar-brand-hover-color: #fff;
    --bs-navbar-toggler-border-color: rgba(255, 255, 255, .1);
    --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")
}

.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='%23062961' 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 rgba(14, 102, 243, .25);
    --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 {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--bs-accordion-btn-padding-y) var(--bs-accordion-btn-padding-x);
    font-size: 1rem;
    color: var(--bs-accordion-btn-color);
    text-align: left;
    background-color: var(--bs-accordion-btn-bg);
    border: 0;
    border-radius: 0;
    overflow-anchor: none;
    transition: var(--bs-accordion-transition)
}

@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 {
    flex-shrink: 0;
    width: var(--bs-accordion-btn-icon-width);
    height: var(--bs-accordion-btn-icon-width);
    margin-left: auto;
    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)
}

@media (prefers-reduced-motion: reduce) {
    .accordion-button:after {
        transition: none
    }
}

.accordion-button:hover {
    z-index: 2
}

.accordion-button:focus {
    z-index: 3;
    outline: 0;
    box-shadow: var(--bs-accordion-btn-focus-box-shadow)
}

.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-right: 0;
    border-left: 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 {
        border-radius: 0
    }

    .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='%236ea3f8'%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='%236ea3f8'%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);
    display: flex;
    flex-wrap: wrap;
    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);
    list-style: none;
    background-color: var(--bs-breadcrumb-bg);
    border-radius: var(--bs-breadcrumb-border-radius)
}

.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 rgba(14, 102, 243, .25);
    --bs-pagination-active-color: #fff;
    --bs-pagination-active-bg: #0e66f3;
    --bs-pagination-active-border-color: #0e66f3;
    --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);
    display: flex;
    padding-left: 0;
    list-style: none
}

.page-link {
    position: relative;
    display: block;
    padding: var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);
    font-size: var(--bs-pagination-font-size);
    color: var(--bs-pagination-color);
    text-decoration: none;
    background-color: var(--bs-pagination-bg);
    border: var(--bs-pagination-border-width) solid var(--bs-pagination-border-color);
    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) {
    .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);
    outline: 0;
    box-shadow: var(--bs-pagination-focus-box-shadow)
}

.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);
    display: inline-block;
    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);
    line-height: 1;
    color: var(--bs-badge-color);
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: var(--bs-badge-border-radius)
}

    .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;
    position: relative;
    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)
}

.alert-heading {
    color: inherit
}

.alert-link {
    font-weight: 700;
    color: var(--bs-alert-link-color)
}

.alert-dismissible {
    padding-right: 3rem
}

    .alert-dismissible .btn-close {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 2;
        padding: 1.25rem 1rem
    }

.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: #0e66f3;
    --bs-progress-bar-transition: width .6s ease;
    display: flex;
    height: var(--bs-progress-height);
    overflow: hidden;
    font-size: var(--bs-progress-font-size);
    background-color: var(--bs-progress-bg);
    border-radius: var(--bs-progress-border-radius)
}

.progress-bar {
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    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)
}

@media (prefers-reduced-motion: reduce) {
    .progress-bar {
        transition: none
    }
}

.progress-bar-striped {
    background-image: linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);
    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
    }
}

.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 rgba(14, 102, 243, .25);
    --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;
    padding: .25em;
    color: var(--bs-btn-close-color);
    background: transparent var(--bs-btn-close-bg) center/1em auto no-repeat;
    border: 0;
    border-radius: .375rem;
    opacity: var(--bs-btn-close-opacity)
}

    .btn-close:hover {
        color: var(--bs-btn-close-color);
        text-decoration: none;
        opacity: var(--bs-btn-close-hover-opacity)
    }

    .btn-close:focus {
        outline: 0;
        box-shadow: var(--bs-btn-close-focus-shadow);
        opacity: var(--bs-btn-close-focus-opacity)
    }

    .btn-close:disabled, .btn-close.disabled {
        pointer-events: none;
        -webkit-user-select: 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: 28px;
    --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);
    background-clip: padding-box;
    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)
}

    .toast.showing {
        opacity: 0
    }

    .toast:not(.show) {
        display: none
    }

.toast-container {
    --bs-toast-zindex: 1090;
    position: absolute;
    z-index: var(--bs-toast-zindex);
    width: max-content;
    max-width: 100%;
    pointer-events: none
}

    .toast-container > :not(:last-child) {
        margin-bottom: var(--bs-toast-spacing)
    }

.toast-header {
    display: flex;
    align-items: center;
    padding: var(--bs-toast-padding-y) var(--bs-toast-padding-x);
    color: var(--bs-toast-header-color);
    background-color: var(--bs-toast-header-bg);
    background-clip: padding-box;
    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))
}

    .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);
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--bs-modal-zindex);
    display: none;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    outline: 0
}

.modal-dialog {
    position: relative;
    width: auto;
    margin: var(--bs-modal-margin);
    pointer-events: none
}

.modal.fade .modal-dialog {
    transition: transform .3s ease-out;
    transform: translateY(-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 {
    display: flex;
    align-items: center;
    min-height: calc(100% - var(--bs-modal-margin) * 2)
}

.modal-content {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    color: var(--bs-modal-color);
    pointer-events: auto;
    background-color: var(--bs-modal-bg);
    background-clip: padding-box;
    border: var(--bs-modal-border-width) solid var(--bs-modal-border-color);
    border-radius: var(--bs-modal-border-radius);
    outline: 0
}

.modal-backdrop {
    --bs-backdrop-zindex: 1050;
    --bs-backdrop-bg: #000;
    --bs-backdrop-opacity: .5;
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--bs-backdrop-zindex);
    width: 100vw;
    height: 100vh;
    background-color: var(--bs-backdrop-bg)
}

    .modal-backdrop.fade {
        opacity: 0
    }

    .modal-backdrop.show {
        opacity: var(--bs-backdrop-opacity)
    }

.modal-header {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    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)
}

    .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 {
    margin-bottom: 0;
    line-height: var(--bs-modal-title-line-height)
}

.modal-body {
    position: relative;
    flex: 1 1 auto;
    padding: var(--bs-modal-padding)
}

.modal-footer {
    display: flex;
    flex-shrink: 0;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    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)
}

    .modal-footer > * {
        margin: calc(var(--bs-modal-footer-gap) * .5)
    }

@media (min-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-right: auto;
        margin-left: auto
    }

    .modal-sm {
        --bs-modal-width: 300px
    }
}

@media (min-width: 992px) {
    .modal-lg, .modal-xl {
        --bs-modal-width: 800px
    }
}

@media (min-width: 1150px) {
    .modal-xl {
        --bs-modal-width: 1140px
    }
}

.modal-fullscreen {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0
}

    .modal-fullscreen .modal-content {
        height: 100%;
        border: 0;
        border-radius: 0
    }

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

    .modal-fullscreen .modal-body {
        overflow-y: auto
    }

@media (max-width: 575.98px) {
    .modal-fullscreen-sm-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0
    }

        .modal-fullscreen-sm-down .modal-content {
            height: 100%;
            border: 0;
            border-radius: 0
        }

        .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 (max-width: 767.98px) {
    .modal-fullscreen-md-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0
    }

        .modal-fullscreen-md-down .modal-content {
            height: 100%;
            border: 0;
            border-radius: 0
        }

        .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 (max-width: 991.98px) {
    .modal-fullscreen-lg-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0
    }

        .modal-fullscreen-lg-down .modal-content {
            height: 100%;
            border: 0;
            border-radius: 0
        }

        .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 (max-width: 1149.98px) {
    .modal-fullscreen-xl-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0
    }

        .modal-fullscreen-xl-down .modal-content {
            height: 100%;
            border: 0;
            border-radius: 0
        }

        .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 (max-width: 1399.98px) {
    .modal-fullscreen-xxl-down {
        width: 100vw;
        max-width: none;
        height: 100%;
        margin: 0
    }

        .modal-fullscreen-xxl-down .modal-content {
            height: 100%;
            border: 0;
            border-radius: 0
        }

        .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);
    display: block;
    margin: var(--bs-tooltip-margin);
    font-family: var(--bs-font-sans-serif);
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    text-align: start;
    text-decoration: none;
    text-shadow: none;
    text-transform: none;
    letter-spacing: normal;
    word-break: normal;
    white-space: normal;
    word-spacing: normal;
    line-break: auto;
    font-size: var(--bs-tooltip-font-size);
    word-wrap: break-word;
    opacity: 0
}

    .tooltip.show {
        opacity: var(--bs-tooltip-opacity)
    }

    .tooltip .tooltip-arrow {
        display: block;
        width: var(--bs-tooltip-arrow-width);
        height: var(--bs-tooltip-arrow-height)
    }

        .tooltip .tooltip-arrow:before {
            position: absolute;
            content: "";
            border-color: transparent;
            border-style: solid
        }

.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 {
        top: -1px;
        border-width: var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;
        border-top-color: var(--bs-tooltip-bg)
    }

.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 {
        right: -1px;
        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)
    }

.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 {
        bottom: -1px;
        border-width: 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);
        border-bottom-color: var(--bs-tooltip-bg)
    }

.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 {
        left: -1px;
        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)
    }

.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)
}

.carousel {
    position: relative
}

    .carousel.pointer-event {
        touch-action: pan-y
    }

.carousel-inner {
    position: relative;
    width: 100%;
    overflow: hidden
}

    .carousel-inner:after {
        display: block;
        clear: both;
        content: ""
    }

.carousel-item {
    position: relative;
    display: none;
    float: left;
    width: 100%;
    margin-right: -100%;
    backface-visibility: hidden;
    transition: transform .6s ease-in-out
}

@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: translate(100%)
    }

    .carousel-item-prev:not(.carousel-item-end), .active.carousel-item-start {
        transform: translate(-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 {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 15%;
    padding: 0;
    color: #fff;
    text-align: center;
    background: none;
    border: 0;
    opacity: .5;
    transition: opacity .15s ease
}

@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;
    text-decoration: none;
    outline: 0;
    opacity: .9
}

.carousel-control-prev {
    left: 0
}

.carousel-control-next {
    right: 0
}

.carousel-control-prev-icon, .carousel-control-next-icon {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    background-repeat: no-repeat;
    background-position: 50%;
    background-size: 100% 100%
}

.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 {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
    display: flex;
    justify-content: center;
    padding: 0;
    margin-right: 15%;
    margin-bottom: 1rem;
    margin-left: 15%
}

    .carousel-indicators [data-bs-target] {
        box-sizing: content-box;
        flex: 0 1 auto;
        width: 30px;
        height: 3px;
        padding: 0;
        margin-right: 3px;
        margin-left: 3px;
        text-indent: -999px;
        cursor: pointer;
        background-color: #fff;
        background-clip: padding-box;
        border: 0;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
        opacity: .5;
        transition: opacity .6s ease
    }

@media (prefers-reduced-motion: reduce) {
    .carousel-indicators [data-bs-target] {
        transition: none
    }
}

.carousel-indicators .active {
    opacity: 1
}

.carousel-caption {
    position: absolute;
    right: 15%;
    bottom: 1.25rem;
    left: 15%;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    color: #fff;
    text-align: center
}

.carousel-dark .carousel-control-prev-icon, .carousel-dark .carousel-control-next-icon {
    filter: invert(1) 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(1) 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 {
    display: inline-block;
    width: var(--bs-spinner-width);
    height: var(--bs-spinner-height);
    vertical-align: var(--bs-spinner-vertical-align);
    border-radius: 50%;
    animation: var(--bs-spinner-animation-speed) linear infinite var(--bs-spinner-animation-name)
}

@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: transparent
}

.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;
    background-color: currentcolor;
    opacity: 0
}

.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
    }
}

.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: translate(-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 {
    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 {
    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: 1 1 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 {
    margin-right: 0 !important;
    margin-left: 0 !important
}

.mx-1 {
    margin-right: .25rem !important;
    margin-left: .25rem !important
}

.mx-2 {
    margin-right: .5rem !important;
    margin-left: .5rem !important
}

.mx-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important
}

.mx-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important
}

.mx-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important
}

.mx-auto {
    margin-right: auto !important;
    margin-left: 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 {
    margin-bottom: 1rem !important
}

.mb-4 {
    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 {
    padding: 1rem !important
}

.p-4 {
    padding: 1.5rem !important
}

.p-5 {
    padding: 3rem !important
}

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

.px-1 {
    padding-right: .25rem !important;
    padding-left: .25rem !important
}

.px-2 {
    padding-right: .5rem !important;
    padding-left: .5rem !important
}

.px-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important
}

.px-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important
}

.px-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important
}

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

.py-1 {
    padding-top: .25rem !important;
    padding-bottom: .25rem !important
}

.py-2 {
    padding-top: .5rem !important;
    padding-bottom: .5rem !important
}

.py-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important
}

.py-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important
}

.py-5 {
    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: transparent !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 {
    -webkit-user-select: all !important;
    user-select: all !important
}

.user-select-auto {
    -webkit-user-select: auto !important;
    user-select: auto !important
}

.user-select-none {
    -webkit-user-select: none !important;
    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-bottom-left-radius: 0 !important;
    border-top-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-bottom-left-radius: 50% !important;
    border-top-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 (min-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: 1 1 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-right: 0 !important;
        margin-left: 0 !important
    }

    .mx-sm-1 {
        margin-right: .25rem !important;
        margin-left: .25rem !important
    }

    .mx-sm-2 {
        margin-right: .5rem !important;
        margin-left: .5rem !important
    }

    .mx-sm-3 {
        margin-right: 1rem !important;
        margin-left: 1rem !important
    }

    .mx-sm-4 {
        margin-right: 1.5rem !important;
        margin-left: 1.5rem !important
    }

    .mx-sm-5 {
        margin-right: 3rem !important;
        margin-left: 3rem !important
    }

    .mx-sm-auto {
        margin-right: auto !important;
        margin-left: 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-right: 0 !important;
        padding-left: 0 !important
    }

    .px-sm-1 {
        padding-right: .25rem !important;
        padding-left: .25rem !important
    }

    .px-sm-2 {
        padding-right: .5rem !important;
        padding-left: .5rem !important
    }

    .px-sm-3 {
        padding-right: 1rem !important;
        padding-left: 1rem !important
    }

    .px-sm-4 {
        padding-right: 1.5rem !important;
        padding-left: 1.5rem !important
    }

    .px-sm-5 {
        padding-right: 3rem !important;
        padding-left: 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 (min-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: 1 1 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-right: 0 !important;
        margin-left: 0 !important
    }

    .mx-md-1 {
        margin-right: .25rem !important;
        margin-left: .25rem !important
    }

    .mx-md-2 {
        margin-right: .5rem !important;
        margin-left: .5rem !important
    }

    .mx-md-3 {
        margin-right: 1rem !important;
        margin-left: 1rem !important
    }

    .mx-md-4 {
        margin-right: 1.5rem !important;
        margin-left: 1.5rem !important
    }

    .mx-md-5 {
        margin-right: 3rem !important;
        margin-left: 3rem !important
    }

    .mx-md-auto {
        margin-right: auto !important;
        margin-left: 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-right: 0 !important;
        padding-left: 0 !important
    }

    .px-md-1 {
        padding-right: .25rem !important;
        padding-left: .25rem !important
    }

    .px-md-2 {
        padding-right: .5rem !important;
        padding-left: .5rem !important
    }

    .px-md-3 {
        padding-right: 1rem !important;
        padding-left: 1rem !important
    }

    .px-md-4 {
        padding-right: 1.5rem !important;
        padding-left: 1.5rem !important
    }

    .px-md-5 {
        padding-right: 3rem !important;
        padding-left: 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 (min-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: 1 1 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-right: 0 !important;
        margin-left: 0 !important
    }

    .mx-lg-1 {
        margin-right: .25rem !important;
        margin-left: .25rem !important
    }

    .mx-lg-2 {
        margin-right: .5rem !important;
        margin-left: .5rem !important
    }

    .mx-lg-3 {
        margin-right: 1rem !important;
        margin-left: 1rem !important
    }

    .mx-lg-4 {
        margin-right: 1.5rem !important;
        margin-left: 1.5rem !important
    }

    .mx-lg-5 {
        margin-right: 3rem !important;
        margin-left: 3rem !important
    }

    .mx-lg-auto {
        margin-right: auto !important;
        margin-left: 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-right: 0 !important;
        padding-left: 0 !important
    }

    .px-lg-1 {
        padding-right: .25rem !important;
        padding-left: .25rem !important
    }

    .px-lg-2 {
        padding-right: .5rem !important;
        padding-left: .5rem !important
    }

    .px-lg-3 {
        padding-right: 1rem !important;
        padding-left: 1rem !important
    }

    .px-lg-4 {
        padding-right: 1.5rem !important;
        padding-left: 1.5rem !important
    }

    .px-lg-5 {
        padding-right: 3rem !important;
        padding-left: 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 (min-width: 1150px) {
    .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: 1 1 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-right: 0 !important;
        margin-left: 0 !important
    }

    .mx-xl-1 {
        margin-right: .25rem !important;
        margin-left: .25rem !important
    }

    .mx-xl-2 {
        margin-right: .5rem !important;
        margin-left: .5rem !important
    }

    .mx-xl-3 {
        margin-right: 1rem !important;
        margin-left: 1rem !important
    }

    .mx-xl-4 {
        margin-right: 1.5rem !important;
        margin-left: 1.5rem !important
    }

    .mx-xl-5 {
        margin-right: 3rem !important;
        margin-left: 3rem !important
    }

    .mx-xl-auto {
        margin-right: auto !important;
        margin-left: 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-right: 0 !important;
        padding-left: 0 !important
    }

    .px-xl-1 {
        padding-right: .25rem !important;
        padding-left: .25rem !important
    }

    .px-xl-2 {
        padding-right: .5rem !important;
        padding-left: .5rem !important
    }

    .px-xl-3 {
        padding-right: 1rem !important;
        padding-left: 1rem !important
    }

    .px-xl-4 {
        padding-right: 1.5rem !important;
        padding-left: 1.5rem !important
    }

    .px-xl-5 {
        padding-right: 3rem !important;
        padding-left: 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 (min-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: 1 1 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-right: 0 !important;
        margin-left: 0 !important
    }

    .mx-xxl-1 {
        margin-right: .25rem !important;
        margin-left: .25rem !important
    }

    .mx-xxl-2 {
        margin-right: .5rem !important;
        margin-left: .5rem !important
    }

    .mx-xxl-3 {
        margin-right: 1rem !important;
        margin-left: 1rem !important
    }

    .mx-xxl-4 {
        margin-right: 1.5rem !important;
        margin-left: 1.5rem !important
    }

    .mx-xxl-5 {
        margin-right: 3rem !important;
        margin-left: 3rem !important
    }

    .mx-xxl-auto {
        margin-right: auto !important;
        margin-left: 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-right: 0 !important;
        padding-left: 0 !important
    }

    .px-xxl-1 {
        padding-right: .25rem !important;
        padding-left: .25rem !important
    }

    .px-xxl-2 {
        padding-right: .5rem !important;
        padding-left: .5rem !important
    }

    .px-xxl-3 {
        padding-right: 1rem !important;
        padding-left: 1rem !important
    }

    .px-xxl-4 {
        padding-right: 1.5rem !important;
        padding-left: 1.5rem !important
    }

    .px-xxl-5 {
        padding-right: 3rem !important;
        padding-left: 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 (min-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 {
    --ss-primary-color: #5897fb;
    --ss-bg-color: #ffffff;
    --ss-font-color: #4d4d4d;
    --ss-font-placeholder-color: #8d8d8d;
    --ss-disabled-color: #dcdee2;
    --ss-border-color: #dcdee2;
    --ss-highlight-color: #fffb8c;
    --ss-success-color: #00b755;
    --ss-error-color: #dc3545;
    --ss-focus-color: #5897fb;
    --ss-main-height: 30px;
    --ss-content-height: 300px;
    --ss-spacing-l: 7px;
    --ss-spacing-m: 5px;
    --ss-spacing-s: 3px;
    --ss-animation-timing: .2s;
    --ss-border-radius: 4px
}

@keyframes ss-valueIn {
    0% {
        transform: scale(0);
        opacity: 0
    }

    to {
        transform: scale(1);
        opacity: 1
    }
}

@keyframes ss-valueOut {
    0% {
        transform: scale(1);
        opacity: 1
    }

    to {
        transform: scale(0);
        opacity: 0
    }
}

.ss-hide {
    display: none !important
}

select.ss-main {
    color: transparent;
    -moz-appearance: none;
    -webkit-appearance: none
}

.ss-main {
    display: flex;
    flex-direction: row;
    position: relative;
    -webkit-user-select: none;
    user-select: none;
    border: 1px solid var(--color-border-light);
    cursor: pointer;
    background-color: var(--form-control-background);
    outline: 0;
    box-sizing: border-box;
    overflow: hidden;
    width: 100%;
    outline: none;
    border-radius: 6px;
    padding: 12px 20px 14px 12px;
    max-height: 40px;
    box-shadow: none;
    color: var(--color-primary-text);
    font-weight: 400;
    font-size: 16px;
    height: 40px
}

    .ss-main::placeholder {
        color: gray;
        font-weight: 300;
        font-size: 16px
    }

    .ss-main.is-invalid {
        border: 1px solid var(--bs-form-invalid-border-color);
        background-image: none
    }

    .ss-main:focus {
        box-shadow: none
    }

    .ss-main.ss-disabled {
        background-color: var(--ss-disabled-color);
        cursor: not-allowed
    }

        .ss-main.ss-disabled .ss-values .ss-disabled {
            color: var(--ss-font-color)
        }

        .ss-main.ss-disabled .ss-values .ss-value .ss-value-delete {
            cursor: not-allowed
        }

    .ss-main.ss-open-above {
        border-top-left-radius: 0;
        border-top-right-radius: 0
    }

    .ss-main.ss-open-below {
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0
    }

    .ss-main .ss-values {
        display: inline-flex;
        flex-wrap: wrap;
        gap: var(--ss-spacing-m);
        flex: 1 1 100%
    }

        .ss-main .ss-values .ss-single {
            margin-top: -6px
        }

        .ss-main .ss-values .ss-placeholder {
            display: flex;
            margin: auto 0;
            line-height: 1em;
            align-items: center;
            width: 100%;
            color: var(--ss-font-placeholder-color);
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap
        }

        .ss-main .ss-values .ss-max {
            display: flex;
            -webkit-user-select: none;
            user-select: none;
            align-items: center;
            width: fit-content;
            font-size: 12px;
            color: var(--ss-bg-color);
            line-height: 1;
            padding: var(--ss-spacing-s) var(--ss-spacing-m);
            background-color: var(--ss-primary-color);
            border-radius: var(--ss-border-radius)
        }

        .ss-main .ss-values .ss-single {
            display: flex
        }

        .ss-main .ss-values .ss-value {
            display: flex;
            -webkit-user-select: none;
            user-select: none;
            align-items: center;
            width: fit-content;
            background-color: var(--ss-primary-color);
            border-radius: var(--ss-border-radius);
            animation-name: ss-valueIn;
            animation-duration: var(--ss-animation-timing);
            animation-timing-function: ease-out;
            animation-fill-mode: both
        }

            .ss-main .ss-values .ss-value.ss-value-out {
                animation-name: ss-valueOut;
                animation-duration: var(--ss-animation-timing);
                animation-timing-function: ease-out
            }

            .ss-main .ss-values .ss-value .ss-value-text {
                font-size: 12px;
                color: var(--ss-bg-color);
                line-height: 1;
                padding: var(--ss-spacing-s) var(--ss-spacing-m)
            }

            .ss-main .ss-values .ss-value .ss-value-delete {
                display: flex;
                align-items: center;
                height: var(--ss-spacing-l);
                width: var(--ss-spacing-l);
                padding: var(--ss-spacing-s) var(--ss-spacing-m);
                cursor: pointer;
                border-left: solid 1px var(--ss-bg-color);
                box-sizing: content-box
            }

                .ss-main .ss-values .ss-value .ss-value-delete svg {
                    height: var(--ss-spacing-l);
                    width: var(--ss-spacing-l)
                }

                    .ss-main .ss-values .ss-value .ss-value-delete svg path {
                        fill: none;
                        stroke: var(--ss-bg-color);
                        stroke-width: 18;
                        stroke-linecap: round;
                        stroke-linejoin: round
                    }

    .ss-main .ss-deselect {
        flex: 0 1 auto;
        display: flex;
        align-items: center;
        justify-content: center;
        width: fit-content;
        height: auto;
        padding: 0 var(--ss-spacing-m) 0 var(--ss-spacing-m)
    }

        .ss-main .ss-deselect svg {
            width: 8px;
            height: 8px
        }

            .ss-main .ss-deselect svg path {
                fill: none;
                stroke: var(--ss-font-color);
                stroke-width: 20;
                stroke-linecap: round;
                stroke-linejoin: round
            }

    .ss-main .ss-arrow {
        display: none
    }

.ss-content {
    position: absolute;
    display: flex;
    height: auto;
    flex-direction: column;
    width: auto;
    max-height: var(--ss-content-height);
    box-sizing: border-box;
    border: none;
    background-color: var(--ss-bg-color);
    transition: transform var(--ss-animation-timing),opacity var(--ss-animation-timing);
    opacity: 0;
    transform: scaleY(0);
    transform-origin: center top;
    overflow: hidden;
    z-index: 10000;
    box-shadow: 0 4px 10px #00000026
}

    .ss-content.ss-relative {
        position: relative;
        height: 100%
    }

    .ss-content.ss-fixed {
        position: fixed
    }

    .ss-content.ss-open-above {
        flex-direction: column-reverse;
        opacity: 1;
        transform: scaleY(1);
        transform-origin: center bottom;
        border-top-left-radius: var(--ss-border-radius);
        border-top-right-radius: var(--ss-border-radius)
    }

    .ss-content.ss-open-below {
        opacity: 1;
        transform: scaleY(1);
        transform-origin: center top;
        border-bottom-left-radius: var(--ss-border-radius);
        border-bottom-right-radius: var(--ss-border-radius)
    }

    .ss-content .ss-search {
        flex: 0 1 auto;
        display: flex;
        flex-direction: row;
        padding: var(--ss-spacing-l) var(--ss-spacing-l) var(--ss-spacing-m) var(--ss-spacing-l)
    }

        .ss-content .ss-search input {
            display: inline-flex;
            font-size: inherit;
            line-height: inherit;
            flex: 1 1 auto;
            width: 100%;
            min-width: 0px;
            padding: 12px;
            margin: 0;
            border: 1px solid var(--ss-border-color);
            border-radius: var(--ss-border-radius);
            background-color: var(--ss-bg-color);
            outline: 0;
            text-align: left;
            box-sizing: border-box
        }

            .ss-content .ss-search input::placeholder {
                color: var(--ss-font-placeholder-color);
                vertical-align: middle
            }

            .ss-content .ss-search input:focus {
                box-shadow: none
            }

        .ss-content .ss-search .ss-addable {
            display: inline-flex;
            justify-content: center;
            align-items: center;
            cursor: pointer;
            flex: 0 0 auto;
            height: auto;
            margin: 0 0 0 var(--ss-spacing-m);
            border: 1px solid var(--ss-border-color);
            border-radius: var(--ss-border-radius)
        }

            .ss-content .ss-search .ss-addable svg {
                display: flex;
                align-items: center;
                justify-content: flex-end;
                flex: 0 1 auto;
                width: 12px;
                height: 12px;
                margin: auto var(--ss-spacing-m) auto var(--ss-spacing-m)
            }

                .ss-content .ss-search .ss-addable svg path {
                    fill: none;
                    stroke: var(--ss-font-color);
                    stroke-width: 18;
                    stroke-linecap: round;
                    stroke-linejoin: round
                }

    .ss-content .ss-list {
        flex: 1 1 auto;
        height: auto;
        overflow-x: hidden;
        overflow-y: auto;
        border: none;
        scrollbar-width: thin
    }

        .ss-content .ss-list .ss-error {
            color: var(--ss-error-color);
            padding: var(--ss-spacing-l)
        }

        .ss-content .ss-list .ss-searching {
            color: var(--ss-font-color);
            padding: var(--ss-spacing-l)
        }

        .ss-content .ss-list .ss-optgroup.ss-close .ss-option {
            display: none !important
        }

        .ss-content .ss-list .ss-optgroup .ss-optgroup-label {
            display: flex;
            flex-direction: row;
            align-items: center;
            justify-content: space-between;
            padding: var(--ss-spacing-m) var(--ss-spacing-l) var(--ss-spacing-m) var(--ss-spacing-l)
        }

            .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-label-text {
                flex: 1 1 auto;
                font-weight: 700;
                color: var(--ss-font-color)
            }

            .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions {
                flex: 0 1 auto;
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: center;
                gap: var(--ss-spacing-m)
            }

                .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall {
                    flex: 0 0 auto;
                    display: flex;
                    flex-direction: row;
                    cursor: pointer
                }

                    .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall:hover {
                        opacity: .5
                    }

                    .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall.ss-selected svg path {
                        stroke: var(--ss-error-color)
                    }

                    .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall span {
                        flex: 0 1 auto;
                        display: flex;
                        align-items: center;
                        justify-content: center;
                        font-size: 60%;
                        text-align: center;
                        padding: 0 var(--ss-spacing-s) 0 0
                    }

                    .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall svg {
                        flex: 0 1 auto;
                        width: 13px;
                        height: 13px
                    }

                        .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall svg path {
                            fill: none;
                            stroke: var(--ss-success-color);
                            stroke-linecap: round;
                            stroke-linejoin: round
                        }

                        .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall svg:first-child {
                            stroke-width: 5
                        }

                        .ss-content .ss-list .ss-optgroup .ss-optgroup-label .ss-optgroup-actions .ss-selectall svg:last-child {
                            stroke-width: 11
                        }

        .ss-content .ss-list .ss-optgroup .ss-option {
            padding: 12px 20px 14px
        }

        .ss-content .ss-list .ss-option {
            display: block;
            padding: 12px 20px 14px;
            white-space: normal;
            color: var(--ss-font-color);
            cursor: pointer;
            -webkit-user-select: none;
            user-select: none
        }

            .ss-content .ss-list .ss-option:hover {
                color: var(--ss-bg-color);
                background-color: var(--color-primary)
            }

            .ss-content .ss-list .ss-option.ss-highlighted, .ss-content .ss-list .ss-option:not(.ss-disabled).ss-selected {
                color: var(--ss-bg-color);
                background-color: var(--color-primary)
            }

            .ss-content .ss-list .ss-option.ss-disabled {
                cursor: not-allowed;
                background-color: var(--ss-disabled-color)
            }

                .ss-content .ss-list .ss-option.ss-disabled:hover {
                    color: var(--ss-font-color)
                }

            .ss-content .ss-list .ss-option .ss-search-highlight {
                display: inline-block;
                background-color: var(--ss-highlight-color)
            }

select.ss-main {
    pointer-events: none
}

.ss-main.ss-open-below:after, .ss-main.ss-open-above:after {
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg)
}

.ss-main:after {
    position: absolute;
    background-image: url(./images/ico-dropdown-menu.svg);
    background-repeat: no-repeat;
    background-position: center;
    content: "";
    width: 29px;
    height: 16px;
    right: 10px;
    border: 6px solid transparent;
    transition: all .2s ease-out;
    transform: translateY(-50%);
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    top: calc(50% - 8px)
}

.flatpickr-calendar {
    font-family: var(--font-family-primary);
    background: transparent;
    opacity: 0;
    display: none;
    text-align: center;
    visibility: hidden;
    padding: 0;
    -webkit-animation: none;
    animation: none;
    direction: ltr;
    border: 0;
    font-size: 14px;
    line-height: 24px;
    border-radius: 5px;
    position: absolute;
    width: 307.875px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    background: #fff;
    -webkit-box-shadow: 1px 0 0 #e6e6e6,-1px 0 0 #e6e6e6,0 1px 0 #e6e6e6,0 -1px 0 #e6e6e6,0 3px 13px rgba(0,0,0,.08);
    box-shadow: 1px 0 #e6e6e6,-1px 0 #e6e6e6,0 1px #e6e6e6,0 -1px #e6e6e6,0 3px 13px #00000014
}

    .flatpickr-calendar.open, .flatpickr-calendar.inline {
        opacity: 1;
        max-height: 640px;
        visibility: visible
    }

    .flatpickr-calendar.open {
        display: inline-block;
        z-index: 99999
    }

    .flatpickr-calendar.animate.open {
        -webkit-animation: fpFadeInDown .3s cubic-bezier(.23,1,.32,1);
        animation: fpFadeInDown .3s cubic-bezier(.23,1,.32,1)
    }

    .flatpickr-calendar.inline {
        display: block;
        position: relative;
        top: 2px
    }

    .flatpickr-calendar.static {
        position: absolute;
        top: calc(100% + 2px)
    }

        .flatpickr-calendar.static.open {
            z-index: 999;
            display: block
        }

    .flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
        -webkit-box-shadow: none !important;
        box-shadow: none !important
    }

    .flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
        -webkit-box-shadow: -2px 0 0 #e6e6e6,5px 0 0 #e6e6e6;
        box-shadow: -2px 0 #e6e6e6,5px 0 #e6e6e6
    }

    .flatpickr-calendar .hasWeeks .dayContainer, .flatpickr-calendar .hasTime .dayContainer {
        border-bottom: 0;
        border-bottom-right-radius: 0;
        border-bottom-left-radius: 0
    }

    .flatpickr-calendar .hasWeeks .dayContainer {
        border-left: 0
    }

    .flatpickr-calendar.hasTime .flatpickr-time {
        height: 40px;
        border-top: 1px solid #e6e6e6
    }

    .flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
        height: auto
    }

    .flatpickr-calendar:before, .flatpickr-calendar:after {
        position: absolute;
        display: block;
        pointer-events: none;
        border: solid transparent;
        content: "";
        height: 0;
        width: 0;
        left: 22px
    }

    .flatpickr-calendar.rightMost:before, .flatpickr-calendar.arrowRight:before, .flatpickr-calendar.rightMost:after, .flatpickr-calendar.arrowRight:after {
        left: auto;
        right: 22px
    }

    .flatpickr-calendar.arrowCenter:before, .flatpickr-calendar.arrowCenter:after {
        left: 50%;
        right: 50%
    }

    .flatpickr-calendar:before {
        border-width: 5px;
        margin: 0 -5px
    }

    .flatpickr-calendar:after {
        border-width: 4px;
        margin: 0 -4px
    }

    .flatpickr-calendar.arrowTop:before, .flatpickr-calendar.arrowTop:after {
        bottom: 100%
    }

    .flatpickr-calendar.arrowTop:before {
        border-bottom-color: #e6e6e6
    }

    .flatpickr-calendar.arrowTop:after {
        border-bottom-color: #fff
    }

    .flatpickr-calendar.arrowBottom:before, .flatpickr-calendar.arrowBottom:after {
        top: 100%
    }

    .flatpickr-calendar.arrowBottom:before {
        border-top-color: #e6e6e6
    }

    .flatpickr-calendar.arrowBottom:after {
        border-top-color: #fff
    }

    .flatpickr-calendar:focus {
        outline: 0
    }

.flatpickr-wrapper {
    position: relative;
    display: inline-block
}

.flatpickr-months {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

    .flatpickr-months .flatpickr-month {
        background: transparent;
        color: #000000e6;
        fill: #000000e6;
        height: 34px;
        line-height: 1;
        text-align: center;
        position: relative;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        overflow: hidden;
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1
    }

    .flatpickr-months .flatpickr-prev-month, .flatpickr-months .flatpickr-next-month {
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        text-decoration: none;
        cursor: pointer;
        position: absolute;
        top: 0;
        height: 34px;
        padding: 10px;
        z-index: 3;
        color: #000000e6;
        fill: #000000e6
    }

        .flatpickr-months .flatpickr-prev-month.flatpickr-disabled, .flatpickr-months .flatpickr-next-month.flatpickr-disabled {
            display: none
        }

        .flatpickr-months .flatpickr-prev-month i, .flatpickr-months .flatpickr-next-month i {
            position: relative
        }

        .flatpickr-months .flatpickr-prev-month.flatpickr-prev-month, .flatpickr-months .flatpickr-next-month.flatpickr-prev-month {
            left: 0
        }

        .flatpickr-months .flatpickr-prev-month.flatpickr-next-month, .flatpickr-months .flatpickr-next-month.flatpickr-next-month {
            right: 0
        }

        .flatpickr-months .flatpickr-prev-month:hover, .flatpickr-months .flatpickr-next-month:hover {
            color: #959ea9
        }

            .flatpickr-months .flatpickr-prev-month:hover svg, .flatpickr-months .flatpickr-next-month:hover svg {
                fill: #f64747
            }

        .flatpickr-months .flatpickr-prev-month svg, .flatpickr-months .flatpickr-next-month svg {
            width: 14px;
            height: 14px
        }

            .flatpickr-months .flatpickr-prev-month svg path, .flatpickr-months .flatpickr-next-month svg path {
                -webkit-transition: fill .1s;
                transition: fill .1s;
                fill: inherit
            }

.numInputWrapper {
    position: relative;
    height: auto
}

    .numInputWrapper input, .numInputWrapper span {
        display: inline-block
    }

    .numInputWrapper input {
        width: 100%
    }

        .numInputWrapper input::-ms-clear {
            display: none
        }

        .numInputWrapper input::-webkit-outer-spin-button, .numInputWrapper input::-webkit-inner-spin-button {
            margin: 0;
            -webkit-appearance: none
        }

    .numInputWrapper span {
        position: absolute;
        right: 0;
        width: 14px;
        padding: 0 4px 0 2px;
        height: 50%;
        line-height: 50%;
        opacity: 0;
        cursor: pointer;
        border: 1px solid rgba(57,57,57,.15);
        -webkit-box-sizing: border-box;
        box-sizing: border-box
    }

        .numInputWrapper span:hover {
            background: #0000001a
        }

        .numInputWrapper span:active {
            background: #0003
        }

        .numInputWrapper span:after {
            display: block;
            content: "";
            position: absolute
        }

        .numInputWrapper span.arrowUp {
            top: 0;
            border-bottom: 0
        }

            .numInputWrapper span.arrowUp:after {
                border-left: 4px solid transparent;
                border-right: 4px solid transparent;
                border-bottom: 4px solid rgba(57,57,57,.6);
                top: 26%
            }

        .numInputWrapper span.arrowDown {
            top: 50%
        }

            .numInputWrapper span.arrowDown:after {
                border-left: 4px solid transparent;
                border-right: 4px solid transparent;
                border-top: 4px solid rgba(57,57,57,.6);
                top: 40%
            }

        .numInputWrapper span svg {
            width: inherit;
            height: auto
        }

            .numInputWrapper span svg path {
                fill: #00000080
            }

    .numInputWrapper:hover {
        background: #0000000d
    }

        .numInputWrapper:hover span {
            opacity: 1
        }

.flatpickr-current-month {
    font-size: 135%;
    line-height: inherit;
    font-weight: 300;
    color: inherit;
    position: absolute;
    width: 75%;
    left: 12.5%;
    padding: 7.48px 0 0;
    line-height: 1;
    height: 34px;
    display: inline-block;
    text-align: center;
    -webkit-transform: translate3d(0px,0px,0px);
    transform: translateZ(0)
}

    .flatpickr-current-month span.cur-month {
        font-family: inherit;
        font-weight: 700;
        color: inherit;
        display: inline-block;
        margin-left: .5ch;
        padding: 0
    }

        .flatpickr-current-month span.cur-month:hover {
            background: #0000000d
        }

    .flatpickr-current-month .numInputWrapper {
        width: 6ch;
        width: 7ch�;
        display: inline-block
    }

        .flatpickr-current-month .numInputWrapper span.arrowUp:after {
            border-bottom-color: #000000e6
        }

        .flatpickr-current-month .numInputWrapper span.arrowDown:after {
            border-top-color: #000000e6
        }

    .flatpickr-current-month input.cur-year {
        background: transparent;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        color: inherit;
        cursor: text;
        padding: 0 0 0 .5ch;
        margin: 0;
        display: inline-block;
        font-size: inherit;
        font-family: inherit;
        font-weight: 300;
        line-height: inherit;
        height: auto;
        border: 0;
        border-radius: 0;
        vertical-align: initial;
        -webkit-appearance: textfield;
        -moz-appearance: textfield;
        appearance: textfield
    }

        .flatpickr-current-month input.cur-year:focus {
            outline: 0
        }

        .flatpickr-current-month input.cur-year[disabled], .flatpickr-current-month input.cur-year[disabled]:hover {
            font-size: 100%;
            color: #00000080;
            background: transparent;
            pointer-events: none
        }

    .flatpickr-current-month .flatpickr-monthDropdown-months {
        appearance: menulist;
        background: transparent;
        border: none;
        border-radius: 0;
        box-sizing: border-box;
        color: inherit;
        cursor: pointer;
        font-size: inherit;
        font-family: inherit;
        font-weight: 300;
        height: auto;
        line-height: inherit;
        margin: -1px 0 0;
        outline: none;
        padding: 0 0 0 .5ch;
        position: relative;
        vertical-align: initial;
        -webkit-box-sizing: border-box;
        -webkit-appearance: menulist;
        -moz-appearance: menulist;
        width: auto
    }

        .flatpickr-current-month .flatpickr-monthDropdown-months:focus, .flatpickr-current-month .flatpickr-monthDropdown-months:active {
            outline: none
        }

        .flatpickr-current-month .flatpickr-monthDropdown-months:hover {
            background: #0000000d
        }

        .flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
            background-color: transparent;
            outline: none;
            padding: 0
        }

.flatpickr-weekdays {
    background: transparent;
    text-align: center;
    overflow: hidden;
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    height: 28px
}

    .flatpickr-weekdays .flatpickr-weekdaycontainer {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1
    }

span.flatpickr-weekday {
    cursor: default;
    font-size: 90%;
    background: transparent;
    color: #0000008a;
    line-height: 1;
    margin: 0;
    text-align: center;
    display: block;
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
    font-weight: bolder
}

.dayContainer, .flatpickr-weeks {
    padding: 1px 0 0
}

.flatpickr-days {
    position: relative;
    overflow: hidden;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
    width: 307.875px
}

    .flatpickr-days:focus {
        outline: 0
    }

.dayContainer {
    padding: 0;
    outline: 0;
    text-align: left;
    width: 307.875px;
    min-width: 307.875px;
    max-width: 307.875px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: inline-block;
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-around;
    justify-content: space-around;
    -webkit-transform: translate3d(0px,0px,0px);
    transform: translateZ(0);
    opacity: 1
}

    .dayContainer + .dayContainer {
        -webkit-box-shadow: -1px 0 0 #e6e6e6;
        box-shadow: -1px 0 #e6e6e6
    }

.flatpickr-day {
    background: none;
    border: 1px solid transparent;
    border-radius: 150px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: #393939;
    cursor: pointer;
    font-weight: 400;
    width: 14.2857143%;
    -webkit-flex-basis: 14.2857143%;
    -ms-flex-preferred-size: 14.2857143%;
    flex-basis: 14.2857143%;
    max-width: 39px;
    height: 39px;
    line-height: 39px;
    margin: 0;
    display: inline-block;
    position: relative;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center
}

    .flatpickr-day.inRange, .flatpickr-day.prevMonthDay.inRange, .flatpickr-day.nextMonthDay.inRange, .flatpickr-day.today.inRange, .flatpickr-day.prevMonthDay.today.inRange, .flatpickr-day.nextMonthDay.today.inRange, .flatpickr-day:hover, .flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover, .flatpickr-day:focus, .flatpickr-day.prevMonthDay:focus, .flatpickr-day.nextMonthDay:focus {
        cursor: pointer;
        outline: 0;
        background: #e6e6e6;
        border-color: #e6e6e6
    }

    .flatpickr-day.today {
        border-color: #959ea9
    }

        .flatpickr-day.today:hover, .flatpickr-day.today:focus {
            border-color: #959ea9;
            background: #959ea9;
            color: #fff
        }

    .flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange, .flatpickr-day.selected.inRange, .flatpickr-day.startRange.inRange, .flatpickr-day.endRange.inRange, .flatpickr-day.selected:focus, .flatpickr-day.startRange:focus, .flatpickr-day.endRange:focus, .flatpickr-day.selected:hover, .flatpickr-day.startRange:hover, .flatpickr-day.endRange:hover, .flatpickr-day.selected.prevMonthDay, .flatpickr-day.startRange.prevMonthDay, .flatpickr-day.endRange.prevMonthDay, .flatpickr-day.selected.nextMonthDay, .flatpickr-day.startRange.nextMonthDay, .flatpickr-day.endRange.nextMonthDay {
        background: #569ff7;
        -webkit-box-shadow: none;
        box-shadow: none;
        color: #fff;
        border-color: #569ff7
    }

        .flatpickr-day.selected.startRange, .flatpickr-day.startRange.startRange, .flatpickr-day.endRange.startRange {
            border-radius: 50px 0 0 50px
        }

        .flatpickr-day.selected.endRange, .flatpickr-day.startRange.endRange, .flatpickr-day.endRange.endRange {
            border-radius: 0 50px 50px 0
        }

        .flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
            -webkit-box-shadow: -10px 0 0 #569ff7;
            box-shadow: -10px 0 #569ff7
        }

        .flatpickr-day.selected.startRange.endRange, .flatpickr-day.startRange.startRange.endRange, .flatpickr-day.endRange.startRange.endRange {
            border-radius: 50px
        }

    .flatpickr-day.inRange {
        border-radius: 0;
        -webkit-box-shadow: -5px 0 0 #e6e6e6,5px 0 0 #e6e6e6;
        box-shadow: -5px 0 #e6e6e6,5px 0 #e6e6e6
    }

    .flatpickr-day.flatpickr-disabled, .flatpickr-day.flatpickr-disabled:hover, .flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay, .flatpickr-day.notAllowed, .flatpickr-day.notAllowed.prevMonthDay, .flatpickr-day.notAllowed.nextMonthDay {
        color: #3939394d;
        background: transparent;
        border-color: transparent;
        cursor: default
    }

        .flatpickr-day.flatpickr-disabled, .flatpickr-day.flatpickr-disabled:hover {
            cursor: not-allowed;
            color: #3939391a
        }

    .flatpickr-day.week.selected {
        border-radius: 0;
        -webkit-box-shadow: -5px 0 0 #569ff7,5px 0 0 #569ff7;
        box-shadow: -5px 0 #569ff7,5px 0 #569ff7
    }

    .flatpickr-day.hidden {
        visibility: hidden
    }

.rangeMode .flatpickr-day {
    margin-top: 1px
}

.flatpickr-weekwrapper {
    float: left
}

    .flatpickr-weekwrapper .flatpickr-weeks {
        padding: 0 12px;
        -webkit-box-shadow: 1px 0 0 #e6e6e6;
        box-shadow: 1px 0 #e6e6e6
    }

    .flatpickr-weekwrapper .flatpickr-weekday {
        float: none;
        width: 100%;
        line-height: 28px
    }

    .flatpickr-weekwrapper span.flatpickr-day, .flatpickr-weekwrapper span.flatpickr-day:hover {
        display: block;
        width: 100%;
        max-width: none;
        color: #3939394d;
        background: transparent;
        cursor: default;
        border: none
    }

.flatpickr-innerContainer {
    display: block;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden
}

.flatpickr-rContainer {
    display: inline-block;
    padding: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

.flatpickr-time {
    text-align: center;
    outline: 0;
    display: block;
    height: 0;
    line-height: 40px;
    max-height: 40px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow: hidden;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex
}

    .flatpickr-time:after {
        content: "";
        display: table;
        clear: both
    }

    .flatpickr-time .numInputWrapper {
        -webkit-box-flex: 1;
        -webkit-flex: 1;
        -ms-flex: 1;
        flex: 1;
        width: 40%;
        height: 40px;
        float: left
    }

        .flatpickr-time .numInputWrapper span.arrowUp:after {
            border-bottom-color: #393939
        }

        .flatpickr-time .numInputWrapper span.arrowDown:after {
            border-top-color: #393939
        }

    .flatpickr-time.hasSeconds .numInputWrapper {
        width: 26%
    }

    .flatpickr-time.time24hr .numInputWrapper {
        width: 49%
    }

    .flatpickr-time input {
        background: transparent;
        -webkit-box-shadow: none;
        box-shadow: none;
        border: 0;
        border-radius: 0;
        text-align: center;
        margin: 0;
        padding: 0;
        height: inherit;
        line-height: inherit;
        color: #393939;
        font-size: 14px;
        position: relative;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        -webkit-appearance: textfield;
        -moz-appearance: textfield;
        appearance: textfield
    }

        .flatpickr-time input.flatpickr-hour {
            font-weight: 700
        }

        .flatpickr-time input.flatpickr-minute, .flatpickr-time input.flatpickr-second {
            font-weight: 400
        }

        .flatpickr-time input:focus {
            outline: 0;
            border: 0
        }

    .flatpickr-time .flatpickr-time-separator, .flatpickr-time .flatpickr-am-pm {
        height: inherit;
        float: left;
        line-height: inherit;
        color: #393939;
        font-weight: 700;
        width: 2%;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        -webkit-align-self: center;
        -ms-flex-item-align: center;
        align-self: center
    }

    .flatpickr-time .flatpickr-am-pm {
        outline: 0;
        width: 18%;
        cursor: pointer;
        text-align: center;
        font-weight: 400
    }

        .flatpickr-time input:hover, .flatpickr-time .flatpickr-am-pm:hover, .flatpickr-time input:focus, .flatpickr-time .flatpickr-am-pm:focus {
            background: #eee
        }

.flatpickr-input[readonly] {
    cursor: pointer
}

@-webkit-keyframes fpFadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0,-20px,0);
        transform: translate3d(0,-20px,0)
    }

    to {
        opacity: 1;
        -webkit-transform: translate3d(0,0,0);
        transform: translateZ(0)
    }
}

@keyframes fpFadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0,-20px,0);
        transform: translate3d(0,-20px,0)
    }

    to {
        opacity: 1;
        -webkit-transform: translate3d(0,0,0);
        transform: translateZ(0)
    }
}

:root {
    --direction: ltr;
    --disabled-opacity: .3;
    --base-height-multiplier: 8;
    --base-horizontal-spacing-multiplier: 3;
    --density: 0;
    --design-unit: 4;
    --control-corner-radius: 4;
    --layer-corner-radius: 8;
    --stroke-width: 1;
    --focus-stroke-width: 2;
    --body-font: "Segoe UI Variable", "Segoe UI", sans-serif;
    --font-weight: 400;
    --type-ramp-base-font-size: 14px;
    --type-ramp-base-line-height: 20px;
    --type-ramp-base-font-variations: "wght" 400, "opsz" 10.5;
    --type-ramp-minus-1-font-size: 12px;
    --type-ramp-minus-1-line-height: 16px;
    --type-ramp-minus-1-font-variations: "wght" 400, "opsz" 8;
    --type-ramp-minus-2-font-size: 10px;
    --type-ramp-minus-2-line-height: 14px;
    --type-ramp-minus-2-font-variations: "wght" 400, "opsz" 8;
    --type-ramp-plus-1-font-size: 16px;
    --type-ramp-plus-1-line-height: 22px;
    --type-ramp-plus-1-font-variations: "wght" 400, "opsz" 10.5;
    --type-ramp-plus-2-font-size: 20px;
    --type-ramp-plus-2-line-height: 26px;
    --type-ramp-plus-2-font-variations: "wght" 400, "opsz" 10.5;
    --type-ramp-plus-3-font-size: 24px;
    --type-ramp-plus-3-line-height: 32px;
    --type-ramp-plus-3-font-variations: "wght" 400, "opsz" 10.5;
    --type-ramp-plus-4-font-size: 28px;
    --type-ramp-plus-4-line-height: 36px;
    --type-ramp-plus-4-font-variations: "wght" 400, "opsz" 36;
    --type-ramp-plus-5-font-size: 32px;
    --type-ramp-plus-5-line-height: 40px;
    --type-ramp-plus-5-font-variations: "wght" 400, "opsz" 36;
    --type-ramp-plus-6-font-size: 40px;
    --type-ramp-plus-6-line-height: 52px;
    --type-ramp-plus-6-font-variations: "wght" 400, "opsz" 36;
    --base-layer-luminance: .98;
    --neutral-base-color: #808080;
    --accent-base-color: #0078d4;
    --neutral-layer-card-container: #f3f3f3;
    --neutral-layer-floating: #ffffff;
    --neutral-layer-1: #fbfbfb;
    --neutral-layer-2: #f3f3f3;
    --neutral-layer-3: #ebebeb;
    --neutral-layer-4: #e0e0e0;
    --fill-color: #fbfbfb;
    --accent-fill-rest: #ffffff;
    --accent-fill-hover: #0473ce;
    --accent-fill-active: #0481e0;
    --accent-fill-focus: #036ac4;
    --foreground-on-accent-rest: #000000;
    --foreground-on-accent-hover: #ffffff;
    --foreground-on-accent-active: #ffffff;
    --foreground-on-accent-focus: #ffffff;
    --accent-foreground-rest: #023b8f;
    --accent-foreground-hover: #012e7f;
    --accent-foreground-active: #0360b9;
    --accent-foreground-focus: #023b8f;
    --accent-stroke-control-rest: linear-gradient(#1c79ca 90%, #024885 100%);
    --accent-stroke-control-hover: linear-gradient(#1b80d2 90%, #035292 100%);
    --accent-stroke-control-active: #1b8ce3;
    --accent-stroke-control-focus: linear-gradient(#1c79ca 90%, #024885 100%);
    --neutral-fill-rest: #ffffff;
    --neutral-fill-hover: #f7f7f7;
    --neutral-fill-active: #fbfbfb;
    --neutral-fill-focus: #fbfbfb;
    --neutral-fill-input-rest: #ffffff;
    --neutral-fill-input-hover: #f7f7f7;
    --neutral-fill-input-active: #fbfbfb;
    --neutral-fill-input-focus: #ffffff;
    --neutral-fill-input-alt-rest: #f3f3f3;
    --neutral-fill-input-alt-hover: #ebebeb;
    --neutral-fill-input-alt-active: #e0e0e0;
    --neutral-fill-input-alt-focus: #f3f3f3;
    --neutral-fill-layer-rest: #ffffff;
    --neutral-fill-layer-hover: #ffffff;
    --neutral-fill-layer-active: #ffffff;
    --neutral-fill-layer-alt-rest: #ffffff;
    --neutral-fill-secondary-rest: #efefef;
    --neutral-fill-secondary-hover: #f3f3f3;
    --neutral-fill-secondary-active: #f7f7f7;
    --neutral-fill-secondary-focus: #efefef;
    --neutral-fill-stealth-rest: #fbfbfb;
    --neutral-fill-stealth-hover: #efefef;
    --neutral-fill-stealth-active: #f3f3f3;
    --neutral-fill-stealth-focus: #fbfbfb;
    --neutral-fill-strong-rest: #717171;
    --neutral-fill-strong-hover: #4b4b4b;
    --neutral-fill-strong-active: #868686;
    --neutral-fill-strong-focus: #717171;
    --neutral-foreground-rest: #1a1a1a;
    --neutral-foreground-hover: #7a7a7a;
    --neutral-foreground-active: #a8a8a8;
    --neutral-foreground-focus: #1a1a1a;
    --neutral-foreground-hint: #717171;
    --neutral-stroke-rest: #d6d6d6;
    --neutral-stroke-hover: #c6c6c6;
    --neutral-stroke-active: #e0e0e0;
    --neutral-stroke-focus: #d6d6d6;
    --neutral-stroke-control-rest: linear-gradient(#efefef 90%, #d6d6d6 100%);
    --neutral-stroke-control-hover: linear-gradient(#e5e5e5 90%, #cecece 100%);
    --neutral-stroke-control-active: #e5e5e5;
    --neutral-stroke-control-focus: linear-gradient(#e5e5e5 90%, #cecece 100%);
    --neutral-stroke-divider-rest: #ebebeb;
    --neutral-stroke-input-rest: linear-gradient(#efefef calc(100% - 1px), #929292 calc(100% - 1px), #929292);
    --neutral-stroke-input-hover: linear-gradient(#e5e5e5 calc(100% - 1px), #8a8a8a calc(100% - 1px), #8a8a8a);
    --neutral-stroke-input-active: #e5e5e5;
    --neutral-stroke-input-focus: linear-gradient(#e5e5e5 calc(100% - 1px), #8a8a8a calc(100% - 1px), #8a8a8a);
    --neutral-stroke-layer-rest: #efefef;
    --neutral-stroke-layer-hover: #efefef;
    --neutral-stroke-layer-active: #efefef;
    --neutral-stroke-strong-rest: #636363;
    --neutral-stroke-strong-hover: #636363;
    --neutral-stroke-strong-active: #636363;
    --neutral-stroke-strong-focus: #636363;
    --focus-stroke-outer: #000000;
    --focus-stroke-inner: #ffffff;
    --foreground-on-accent-rest-large: #ffffff;
    --foreground-on-accent-hover-large: #ffffff;
    --foreground-on-accent-active-large: #ffffff;
    --foreground-on-accent-focus-large: #ffffff;
    --neutral-fill-inverse-rest-delta: 0;
    --neutral-fill-inverse-hover-delta: -3;
    --neutral-fill-inverse-active-delta: 7;
    --neutral-fill-inverse-focus-delta: 0;
    --neutral-fill-inverse-rest: #131313;
    --neutral-fill-inverse-hover: #272727;
    --neutral-fill-inverse-active: #000000;
    --neutral-fill-inverse-focus: #131313;
    --neutral-fill-stealth-rest-on-neutral-fill-layer-rest: #ffffff;
    --neutral-fill-stealth-hover-on-neutral-fill-layer-rest: #f3f3f3;
    --neutral-fill-stealth-active-on-neutral-fill-layer-rest: #f7f7f7;
    --elevation-shadow-card-rest-size: 4;
    --elevation-shadow-card-hover-size: 8;
    --elevation-shadow-card-active-size: 0;
    --elevation-shadow-card-focus-size: 8;
    --elevation-shadow-card-rest: 0 0 2px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .14);
    --elevation-shadow-card-hover: 0 0 2px rgba(0, 0, 0, .12), 0 4px 8px rgba(0, 0, 0, .14);
    --elevation-shadow-card-active: 0 0 2px rgba(0, 0, 0, .12), 0 0px 0px rgba(0, 0, 0, .14);
    --elevation-shadow-card-focus: 0 0 2px rgba(0, 0, 0, .12), 0 4px 8px rgba(0, 0, 0, .14);
    --elevation-shadow-tooltip-size: 16;
    --elevation-shadow-tooltip: 0 0 2px rgba(0, 0, 0, .12), 0 8px 16px rgba(0, 0, 0, .14);
    --elevation-shadow-flyout-size: 32;
    --elevation-shadow-flyout: 0 0 2px rgba(0, 0, 0, .2), 0 16px 32px rgba(0, 0, 0, .24);
    --elevation-shadow-dialog-size: 128;
    --elevation-shadow-dialog: 0 0 2px rgba(0, 0, 0, .2), 0 64px 128px rgba(0, 0, 0, .24);
    --input-placeholder-rest: #767676;
    --input-placeholder-hover: #717171;
    --input-filled-placeholder-rest: #6c6c6c;
    --input-filled-placeholder-hover: #6c6c6c;
    --clear-button-hover: #f3f3f3;
    --clear-button-active: #f7f7f7;
    --tree-item-expand-collapse-hover: #e0e0e0;
    --tree-item-expand-collapse-selected-hover: #e0e0e0;
    --body-page-player-pb: 80px;
}

.fluent-calendar {
    font-family: var(--font-family-primary)
}

.inline-calendar {
    font-family: var(--font-family-primary);
    background-color: var(--bg-color-primary);
    padding: 28px 20px 60px;
    border-radius: 12px
}

    .inline-calendar h5, .inline-calendar .h5 {
        padding-bottom: 4px;
        color: var(--color-secondary-text);
        font-size: 16px;
        font-style: normal;
        font-weight: 600;
        margin-bottom: 0;
        text-transform: uppercase;
        line-height: 13px;
        letter-spacing: 1.28px
    }

    .inline-calendar .fluent-calendar.inline {
        font-family: var(--font-family-primary);
        width: 100%
    }

        .inline-calendar .fluent-calendar.inline .title {
            padding-left: 0;
            margin-bottom: 12px;
            min-height: 40px;
            position: relative
        }

            .inline-calendar .fluent-calendar.inline .title .label {
                position: absolute;
                transform: translate(-50%);
                left: 50%;
                width: fit-content;
                white-space: nowrap;
                padding-top: 3px
            }

            .inline-calendar .fluent-calendar.inline .title .previous {
                position: absolute;
                left: 0
            }

            .inline-calendar .fluent-calendar.inline .title .next, .inline-calendar .fluent-calendar.inline .title .next:hover {
                position: absolute;
                right: 0;
                background-image: url(./images/ico-calendar-arrow-right.svg);
                background-repeat: no-repeat;
                background-position: center center;
                margin-left: 0
            }

                .inline-calendar .fluent-calendar.inline .title .next svg, .inline-calendar .fluent-calendar.inline .title .next:hover svg {
                    display: none
                }

            .inline-calendar .fluent-calendar.inline .title .previous, .inline-calendar .fluent-calendar.inline .title .previous:hover {
                position: absolute;
                right: 0;
                background-image: url(./images/ico-calendar-arrow-left.svg);
                background-repeat: no-repeat;
                background-position: center center;
                margin-left: 0
            }

                .inline-calendar .fluent-calendar.inline .title .previous svg, .inline-calendar .fluent-calendar.inline .title .previous:hover svg {
                    display: none
                }

        .inline-calendar .fluent-calendar.inline .day:not([selected]):not([multi-day])[today] {
            border-radius: 4px
        }

        .inline-calendar .fluent-calendar.inline .change-period > .next:not([disabled]):hover, .inline-calendar .fluent-calendar.inline .change-period {
            background-color: transparent;
            background-image: url(./images/ico-calendar-arrow-right.svg);
            background-repeat: no-repeat;
            background-position: center center;
            margin-left: 0
        }

            .inline-calendar .fluent-calendar.inline .change-period > .previous:not([disabled]):hover, .inline-calendar .fluent-calendar.inline .change-period {
                background-color: transparent;
                background-image: url(./images/ico-calendar-arrow-left.svg);
                background-repeat: no-repeat;
                background-position: center center
            }

        .inline-calendar .fluent-calendar.inline .day {
            margin-bottom: 4px;
            font-weight: 500;
            font-size: 11px
        }

        .inline-calendar .fluent-calendar.inline .week-day {
            font-weight: 500;
            font-size: 11px;
            color: #8d8b8b
        }

        .inline-calendar .fluent-calendar.inline .day:has(.has-events):not([disabled]):not([today]):hover {
            background: var(--color-primary);
            color: #fff
        }

        .inline-calendar .fluent-calendar.inline .day:has(.has-events):not([disabled]):not([today]) {
            background-color: var(--color-primary);
            color: #fff
        }

        .inline-calendar .fluent-calendar.inline .day:not([selected]):not([multi-day])[today] {
            color: #000;
            background-color: #fff;
            border-radius: 50%;
            outline: 1px solid #ededed
        }

        .inline-calendar .fluent-calendar.inline:not([readonly]) .day:not([disabled]):not([inactive]):not([today]):hover {
            background: #ededed;
            border-radius: 50%;
            transition: .2s ease-in-out
        }

        .inline-calendar .fluent-calendar.inline:not([readonly]) .day:has(.has-events):not([disabled]):not([inactive]):not([today]):hover {
            background: var(--color-primary);
            border-radius: 4px;
            transition: .2s ease-in-out
        }

.filter-tabs {
    flex-wrap: nowrap;
    overflow-x: auto
}

.nav.nav-tabs.filter-tabs {
    position: static;
    flex-wrap: nowrap;
    overflow-x: auto;
    margin-left: -16px;
    margin-right: -16px;
    padding-left: 16px;
    padding-right: 16px;
    min-height: 68px;
    border-bottom: 1px solid var(--color-border-dark)
}

@media (min-width: 768px) {
    .nav.nav-tabs.filter-tabs {
        margin-left: 0;
        margin-right: 0
    }
}

:root {
    --color-primary: #3c56ff;
    --color-primary-dark: color-mix(in srgb, var(--color-primary) 80%, #000000);
    --color-primary-light: color-mix(in srgb, var(--color-primary) 10%, #ffffff);
    --color-secondary: #00ebb3;
    --color-secondary-dark: color-mix(in srgb, var(--color-secondary) 70%, #000000);
    --color-secondary-light: color-mix(in srgb, var(--color-secondary) 10%, #ffffff);
    --color-primary-text: #000000;
    --color-secondary-text: #787878;
    --bg-color-primary: #ffffff;
    --bg-color-secondary: #f5f5f5;
    --bg-color-teritary: #f8f8f8;
    --color-border-light: #efefef;
    --color-border-dark: #d4d4d4;
    --color-neutral-rest: #c9c9c9;
    --color-neutral-disabled: #e5e5e5;
    --color-neutral-disabled-dark: #c0c0c0;
    --color-neutral-hover: #f5f5f5;
    --color-neutral-selected: #ebebeb;
    --color-review-star: #ffae00;
    --color-favorite: #fa5053;
    --color-danger: #dc3545;
    --color-warning: #ff8b25;
    --color-success: #50cc71;
    --bs-body-font-family: var(--font-family-primary);
    --text-color-on-dark-bg: var(--bs-white);
    --font-family-primary: "Barlow", sans-serif;
    --hero-title-font-size: clamp(2rem, 1.6961rem + 1.2966vw, 2.5rem);
    --hero-title-font-weight: 700;
    --page-title-font-size: clamp(1.75rem, 1.4461rem + 1.2966vw, 2.25rem);
    --page-title-font-weight: 700;
    --subtitle-font-size: clamp(1.5rem, 1.3481rem + .6483vw, 1.75rem);
    --subtitle-font-weight: 600;
    --heading-font-size: clamp(1.25rem, 1.0981rem + .6483vw, 1.5rem);
    --heading-font-weight: 600;
    --heading-s-font-size: 18px;
    --heading-s-font-weight: 600;
    --paragraph-l-font-size: 18px;
    --paragraph-l-font-weight: 400;
    --paragraph-l-semibold-font-size: 18px;
    --paragraph-l-semibold-font-weight: 600;
    --paragraph-font-size: 16px;
    --paragraph-font-weight: 400;
    --paragraph-semibold-font-size: 16px;
    --paragraph-semibold-font-weight: 600;
    --paragraph-s-font-size: 14px;
    --paragraph-s-font-weight: 400;
    --paragraph-s-semibold-font-size: 14px;
    --paragraph-s-semibold-font-weight: 600;
    --paragraph-xs-font-size: 12px;
    --paragraph-xs-font-weight: 400;
    --paragraph-xs-semibold-font-size: 12px;
    --paragraph-xs-semibold-font-weight: 600;
    --informative-font-size: 14px;
    --informative-font-weight: 400;
    --cap-label-l-font-size: 16px;
    --cap-label-l-font-weight: 600;
    --cap-label-s-font-size: 12px;
    --cap-label-s-font-weight: 500;
    --label-1-font-size: 16px;
    --label-1-font-weight: 600;
    --label-2-font-size: 16px;
    --label-2-font-weight: 500;
    --label-3-font-size: 14px;
    --label-3-font-weight: 500;
    --bs-nav-link-font-size: 16px;
    --bs-nav-link-font-weight: 500;
    --border-radius-s: 4px;
    --border-radius-m: 8px;
    --border-radius-l: 12px;
    --border-radius-xl: 16px;
    --border-radius-xxl: 24px;
    --bs-form-switch-bg: url('data:image/svg+xml,<%3Fxml version="1.0" encoding="utf-8"%3F><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="18px" height="18px" viewBox="0 0 18 18" enable-background="new 0 0 18 18" xml:space="preserve"><path fill="%230E66F3" d="M14.005,0h-10c-2.209,0-4,1.791-4,4v10c0,2.209,1.791,4,4,4h10c2.209,0,4-1.791,4-4V4C18.005,1.791,16.214,0,14.005,0z M13.038,9.342L10.05,12.33l-0.332,0.332l-0.664-0.664l0.332-0.332l2.188-2.188H5.108H4.64V8.541h0.469h6.465L9.386,6.334L9.054,6.002l0.664-0.664L10.05,5.67l2.988,3.008L13.37,9.01L13.038,9.342z"/></svg>')
}

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

    body h1, body .h1 {
        font-size: var(--hero-title-font-size);
        font-weight: var(--hero-title-font-weight);
        line-height: 1.3
    }

    body h2, body .h2 {
        font-size: var(--page-title-font-size);
        font-weight: var(--page-title-font-weight)
    }

@media (min-width: 992px) {
    body .py-lg-6 {
        padding-top: var(--spacer-lg-y) !important;
        padding-bottom: var(--spacer-lg-y) !important
    }
}

body .bg-primary h2, body .bg-primary .h2 {
    color: #fff;
    text-transform: uppercase
}

body .bg-light-gray {
    background-color: var(--color-sand-25)
}

body .container {
    --bs-gutter-x: 1rem
}

body .container-fluid, body .container-sm, body .container-md, body .container-lg, body .container-xl, body .container-xxl {
    --bs-gutter-x: 2rem
}

body .header {
    font-size: var(--font-size-header);
    line-height: var(--line-height-header)
}

body .image-cover-container {
    display: flex;
    align-items: center;
    justify-content: center
}

    body .image-cover-container picture, body .image-cover-container img {
        width: 100%;
        height: 100%;
        object-fit: cover
    }

body .image-cover-container-header {
    display: flex;
    align-items: center;
    justify-content: center
}

    body .image-cover-container-header picture, body .image-cover-container-header img {
        width: 100%
    }

@media (max-width: 991px) {
    body .image-cover-container-header picture, body .image-cover-container-header img {
        object-fit: cover;
        height: 100%
    }
}

@media (min-width: 992px) {
    body .image-cover-container-header picture, body .image-cover-container-header img {
        object-fit: cover;
        max-height: 420px;
        width: auto
    }
}

body .bg-node {
    background: url(./images/img-n.svg) top 10px left 10px no-repeat,url(./images/img-o.svg) top 10px right 10px no-repeat,url(./images/img-e.svg) bottom 10px right 10px no-repeat,url(./images/img-d.svg) bottom 10px left 10px no-repeat;
    background-size: 88px;
    background-color: var(--color-sand-25)
}

@media (min-width: 992px) {
    body .bg-node {
        background-size: 160px
    }
}

body .bg-node .bg-node-content {
    margin-top: 193px;
    margin-bottom: 200px
}

    body .bg-node .bg-node-content h3, body .bg-node .bg-node-content .h3 {
        font-size: clamp(1.75rem,1.1804rem + 2.5316vw,3rem);
        line-height: 1.3
    }

body .container-fluid, body .container-sm, body .container-md, body .container-lg, body .container-xl, body .container-xxl {
    max-width: 1312px
}

body b, body strong {
    font-weight: 700
}

.color-black-undeline p a, .color-black-undeline a {
    color: #000;
    text-decoration: underline
}

.italic {
    font-style: italic
}

.fs-16 {
    font-size: 16px
}

.main-text-link a {
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none
}

.main-text-link.fs-14 {
    font-size: 14px
}

.photo-info {
    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    display: flex;
    align-items: center
}

.small-text {
    color: var(--text-color);
    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

    .small-text.info-text {
        color: var(--color-info)
    }

.sorry {
    display: flex;
    justify-content: center;
    padding-top: 40px;
    padding-bottom: 40px;
    flex-direction: column
}

    .sorry picture {
        display: flex;
        justify-content: center;
        margin-bottom: 40px
    }

    .sorry p {
        text-align: center;
        font-size: clamp(1.5rem,1.1582rem + 1.519vw,2.25rem);
        font-style: normal;
        font-weight: 500;
        line-height: 1.3;
        margin-bottom: 0
    }

    .sorry .btn {
        margin-top: 40px
    }

.congrats {
    display: flex;
    justify-content: center;
    padding-top: 40px;
    padding-bottom: 40px;
    flex-direction: column
}

    .congrats picture {
        display: flex;
        justify-content: center;
        margin-bottom: 40px
    }

    .congrats h3, .congrats .h3 {
        text-align: center;
        font-size: 28px;
        font-style: normal;
        font-weight: 500;
        line-height: 38px;
        margin-bottom: 16px
    }

    .congrats .btn {
        margin-top: 40px
    }

    .congrats p, .congrats a {
        text-align: center;
        font-size: 18px;
        font-style: normal;
        font-weight: 400;
        line-height: 28px;
        margin-bottom: 0
    }

    .congrats a {
        color: var(--color-primary);
        text-decoration: none
    }

.col-painter-cat {
    margin-bottom: 48px;
    display: flex
}

    .col-painter-cat img {
        width: 100%;
        height: auto;
        max-width: 600px;
        margin-left: auto;
        margin-right: auto
    }

@media (min-width: 1150px) {
    .col-painter-cat {
        display: none
    }
}

.col-cat {
    background: url(./images/cat.svg) bottom 0px right 40px no-repeat;
    background-size: 80px;
    display: none
}

@media (min-width: 1150px) {
    .col-cat {
        display: block
    }
}

.col-painter {
    display: flex
}

@media (min-width: 1150px) {
    .col-painter {
        background: url(./images/404_painter.svg) top left 13px no-repeat;
        background-size: contain;
        min-height: 460px
    }
}

.error-info {
    margin-top: auto
}

@media (min-width: 1150px) {
    .error-info {
        max-width: 58%;
        padding-top: 255px
    }
}

.error-info a {
    margin-top: 32px
}

.error-info p {
    font-size: clamp(1rem,.9395rem + .2581vw,1.125rem);
    font-style: normal;
    font-weight: 500;
    line-height: 1.4
}

.circular-progress {
    position: relative;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px
}

.progress-ring {
    transform: rotate(-90deg)
}

.progress-ring__bg {
    fill: none;
    stroke: #e0e0e0;
    stroke-width: 2
}

.progress-ring__bar {
    fill: none;
    stroke: #007bff;
    stroke-width: 3;
    transition: stroke-dashoffset .35s
}

.circle-progress-check {
    position: absolute;
    opacity: 0
}

.circular-progress.completed .circle-progress-check {
    opacity: 1
}

.bg-color-primary {
    background-color: var(--color-primary)
}

.bg-color-primary-dark {
    background-color: var(--color-primary-dark)
}

.bg-color-primary-light {
    background-color: var(--color-primary-light)
}

.bg-color-secondary {
    background-color: var(--color-secondary)
}

.bg-color-secondary-dark {
    background-color: var(--color-secondary-dark)
}

.bg-color-secondary-light {
    background-color: var(--color-secondary-light)
}

.w-h-40 {
    width: 40px;
    height: 40px
}

.bg-color-teritary, .bg-white .course-details-box {
    background-color: var(--bg-color-teritary)
}

.page-player .course-details-box .details-items .item {
    border-top: 1px solid var(--color-border-dark)
}

    .page-player .course-details-box .details-items .item:last-child {
        border-bottom: 1px solid var(--color-border-dark)
    }

.course-details-box {
    background-color: var(--bg-color-primary);
    border-radius: var(--border-radius-l);
    padding: 20px
}

    .course-details-box h2, .course-details-box .h2 {
        font-size: var(--subtitle-font-size);
        font-weight: var(--subtitle-font-weight);
        margin-bottom: 20px
    }

    .course-details-box .details-items .item {
        border-top: 1px solid var(--color-border-light);
        display: flex;
        padding-top: 12px;
        padding-bottom: 12px
    }

        .course-details-box .details-items .item:last-child {
            border-bottom: 1px solid var(--color-border-light)
        }

        .course-details-box .details-items .item p {
            margin-bottom: 0;
            font-size: var(--paragraph-semibold-font-size);
            font-weight: 500;
            line-height: 1.3
        }

        .course-details-box .details-items .item span {
            font-size: var(--paragraph-font-size);
            font-weight: var(--paragraph-font-weight);
            margin-bottom: 0;
            display: block;
            line-height: 1.3
        }

        .course-details-box .details-items .item .ico-course-details {
            display: flex;
            align-items: center;
            min-width: 160px;
            width: 140px;
            padding-right: 6px
        }

            .course-details-box .details-items .item .ico-course-details .ico-container {
                font-size: 16px;
                display: flex;
                align-items: center;
                margin-right: 8px;
                color: var(--color-secondary)
            }

.price-description span {
    font-size: 18px;
    font-weight: 600;
    line-height: 24px
}

.color-primary {
    color: var(--color-primary)
}

.bg-color-teritary {
    background-color: var(--bg-color-teritary)
}

@media (min-width: 992px) {
    .slope-header {
        --p: 57px;
        aspect-ratio: 3/2;
        clip-path: polygon(var(--p) 0,101% 0,calc(114% - var(--p)) 100%,0 100%)
    }
}

.add-to-favorites {
    width: 40px;
    height: 40px;
    border-radius: var(--border-radius-m);
    background-image: url(./images/ico-add-to-favorite-border.svg);
    background-size: 24px 24px;
    background-position: top 9px center;
    background-repeat: no-repeat;
    background-color: var(--color-primary);
    background-size: 20px 20px
}

    .add-to-favorites.active {
        background-image: url(./images/ico-add-to-favorite.svg);
        background-color: var(--color-primary)
    }

.radius-12 {
    border-radius: var(--border-radius-l)
}

.bg-white {
    background-color: var(--bs-white)
}

.px-40 {
    padding-left: 24px;
    padding-right: 24px
}

@media (min-width: 1150px) {
    .px-40 {
        padding-left: 40px;
        padding-right: 40px
    }
}

.p-40 {
    padding: 24px
}

@media (min-width: 768px) {
    .p-40 {
        padding: 40px
    }
}

.price-l {
    display: flex;
    align-items: end
}

    .price-l span {
        font-size: var(--hero-title-font-size);
        font-weight: 600;
        margin-bottom: -3px;
        display: inline-flex;
        align-items: end
    }

        .price-l span small, .price-l span .small {
            font-size: var(--paragraph-semibold-font-size);
            font-weight: 500;
            padding-left: 6px;
            margin-bottom: 9px
        }

.price-m {
    display: flex;
    align-items: end
}

    .price-m span {
        font-size: var(--subtitle-font-size);
        font-weight: 600;
        margin-bottom: 0;
        display: inline-flex;
        align-items: end
    }

    .price-m small, .price-m .small {
        font-size: 14px;
        font-style: normal;
        font-weight: 500;
        line-height: 14px;
        padding-left: 6px;
        text-decoration: none;
        margin-bottom: 9px
    }

    .price-m.previous {
        color: var(--color-secondary-text)
    }

        .price-m.previous span {
            text-decoration: line-through;
            font-size: var(--heading-font-size);
            font-weight: 500
        }

            .price-m.previous span small, .price-m.previous span .small {
                text-decoration: none;
                display: inline-flex
            }

.price-info h5, .price-info .h5 {
    font-size: var(--heading-s-font-size);
    font-weight: var(--heading-s-font-weight);
    margin-bottom: 0
}

.ico-info-l {
    display: flex;
    margin-bottom: 40px
}

    .ico-info-l .ico-container {
        width: 80px;
        height: 80px;
        min-width: 80px;
        margin-right: 24px
    }

    .ico-info-l .info-container h3, .ico-info-l .info-container .h3 {
        font-weight: var(--heading-font-weight);
        font-size: var(--heading-font-size)
    }

    .ico-info-l .info-container p {
        font-size: var(--paragraph-l-font-size);
        font-weight: var(--paragraph-l-font-weight)
    }

.my-profile-photo {
    width: 85px;
    height: 85px;
    border-radius: 50%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    margin-right: 24px;
    min-width: 85px
}

.score-container {
    display: flex;
    align-items: center
}

    .score-container p {
        margin-bottom: 0;
        margin-right: 8px;
        width: 24px
    }

    .score-container .score i {
        font-size: 14px;
        margin-right: 4px;
        display: flex;
        align-items: center;
        color: var(--color-review-star)
    }

    .score-container .score.disabled i {
        color: var(--color-neutral-disabled-dark)
    }

.standard-text h1, .standard-text .h1 {
    font-size: var(--hero-title-font-siz);
    font-weight: var(--hero-title-font-weight)
}

.standard-text h2, .standard-text .h2 {
    font-size: var(--page-title-font-size);
    font-weight: var(--page-title-font-size)
}

.standard-text h3, .standard-text .h3 {
    font-size: var(--subtitle-font-size);
    font-weight: var(--subtitle-font-weight)
}

.standard-text h4, .standard-text .h4 {
    font-size: var(--heading-font-size);
    font-weight: var(--heading-font-weight)
}

.standard-text .tab-pane h4, .standard-text .tab-pane .h4 {
    font-size: var(--subtitle-font-size);
    font-weight: var(--subtitle-font-weight)
}

.standard-text h5, .standard-text .h5 {
    font-size: var(--heading-s-font-size);
    font-weight: var(--heading-s-font-weight)
}

.standard-text p {
    font-size: var(--paragraph-font-size);
    font-weight: var(--paragraph-font-weight)
}

.ratio-2x1 {
    aspect-ratio: 2/1
}

.ratio-3x2 {
    aspect-ratio: 3/2
}

.me-20px {
    margin-right: 20px
}

.ms-20px {
    margin-left: 20px
}

.mb-50px {
    margin-bottom: 50px
}

.mb-60px {
    margin-bottom: 60px
}

.mt-32px {
    margin-top: 32px
}

.dropdown-menu .modal-content-scrollable {
    padding-right: 0
}

    .dropdown-menu .modal-content-scrollable .simplebar-content {
        padding: 0
    }

.simplebar-track.simplebar-vertical {
    top: 0;
    width: 7px
}

.form-filter-element .simplebar-track {
    right: -2px
}

.simplebar-track {
    right: 3px
}

.session-schedule-modal .simplebar-track {
    right: 0
}

.radius-l {
    border-radius: var(--border-radius-l)
}

.bg-img {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat
}

.about-instructor {
    display: flex
}

    .about-instructor .img-container {
        width: 80px;
        height: 80px;
        min-width: 80px;
        border-radius: var(--border-radius-m);
        margin-right: 24px
    }

        .about-instructor .img-container .bg-img {
            border-radius: var(--border-radius-m)
        }

@media (min-width: 576px) {
    .about-instructor .img-container {
        width: 140px;
        height: 140px;
        min-width: 140px;
        border-radius: var(--border-radius-m);
        margin-right: 38px
    }
}

.about-instructor h5, .about-instructor .h5 {
    margin-bottom: 0
}

.color-secondary-text {
    color: var(--color-secondary-text)
}

.h-lg-100 {
    height: 100%
}

:root {
    --top-bar-bg: var(--color-primary);
    --top-bar-font-size: 20px;
    --top-bar-close-font-size: 28px;
    --top-bar-font-family: var(--font-family-primary) --top-bar-color-text: var(--text-color-on-dark-bg)
}

.top-bar {
    background: var(--color-primary);
    text-align: start;
    position: absolute;
    padding-right: 60px;
    padding-left: 16px;
    top: 0;
    width: 100%;
    color: #fff
}

@media (min-width: 992px) {
    .top-bar {
        text-align: center;
        padding-right: 60px;
        padding-left: 60px
    }
}

.top-bar a {
    color: var(--top-bar-color-text);
    font-size: var(--top-bar-font-size);
    font-weight: 500;
    text-decoration: none;
    line-height: 1.1;
    padding-right: 40px;
    padding-top: 15px;
    padding-bottom: 15px;
    display: block
}

.top-bar .close {
    color: var(--top-bar-color-text);
    cursor: pointer;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    padding: 0 16px;
    font-weight: 200
}

body {
    position: relative;
    transition: padding-top .3s ease-out;
    padding-top: 80px
}

@media (min-width: 1150px) {
    body {
        padding-top: 80px
    }
}

body.has-top-banner {
    padding-top: 132px
}

@media (min-width: 1150px) {
    body.has-top-banner {
        padding-top: 132px
    }
}

body.has-top-banner #topnav:not(.is-fixed) {
    top: 52px
}

#topnav {
    --top-menu-bg: var(--bs-white);
    --top-menu-dropdown-shadow: 3px 3px 0px 4px #000;
    --top-menu-dropdown--border-radius: 0
}

    #topnav .dropdown-menu {
        --bs-dropdown-border-radius: var(--top-menu-dropdown--border-radius);
        --bs-dropdown-border-bottom: var(--color-sand)
    }

    #topnav .navbar {
        --bs-navbar-color: var(--bs-black);
        font-size: clamp(.9375rem,.1875rem + 1vw,1.125rem);
        font-family: var(--font-family-primary);
        width: 100%;
        height: 80px
    }

        #topnav .navbar .dropdown-menu {
            --bs-dropdown-font-size: 1.125rem;
            --dropdown-font-weight: 400
        }

#topnav {
    background: var(--top-menu-bg);
    box-shadow: 0 0 4px #00000014;
    height: 80px;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    position: absolute;
    top: 0;
    z-index: 5;
    transition: top .3s ease-out
}

@media (min-width: 1150px) {
    #topnav {
        height: 80px
    }
}

#topnav.is-fixed {
    position: fixed;
    top: -100px
}

    #topnav.is-fixed.is-at-top {
        transition: top 0s
    }

    #topnav.is-fixed.is-visible {
        top: 0
    }

#topnav .navbar-nav {
    margin-right: auto
}

    #topnav .navbar-nav .nav-item {
        padding: 0;
        margin: 0 1vw
    }

        #topnav .navbar-nav .nav-item .nav-link {
            white-space: nowrap;
            position: relative;
            padding: 0;
            line-height: 1.6;
            font-weight: 500;
            font-size: 17px
        }

            #topnav .navbar-nav .nav-item .nav-link.dropdown-toggle.active {
                color: var(--color-primary)
            }

                #topnav .navbar-nav .nav-item .nav-link.dropdown-toggle.active:after {
                    width: calc(100% + 24px);
                    left: -12px
                }

@media (min-width: 1260px) {
    #topnav .navbar-nav .nav-item .nav-link.dropdown-toggle.active:after {
        width: calc(100% + 34px);
        left: -20px
    }
}

#topnav .navbar-nav .nav-item .nav-link:after {
    content: "";
    position: absolute;
    left: -8px;
    bottom: -26px;
    width: 0;
    border-bottom: 3px solid var(--color-primary);
    transition: width .15s ease
}

@media (min-width: 1260px) {
    #topnav .navbar-nav .nav-item .nav-link:after {
        left: -16px
    }
}

@media (min-width: 1400px) {
    #topnav .navbar-nav .nav-item .nav-link:after {
        bottom: -26px
    }
}

#topnav .navbar-nav .nav-item .nav-link.active {
    color: var(--color-primary)
}

    #topnav .navbar-nav .nav-item .nav-link.active:after {
        width: calc(100% + 16px)
    }

@media (min-width: 1260px) {
    #topnav .navbar-nav .nav-item .nav-link.active:after {
        width: calc(100% + 32px)
    }
}

#topnav .navbar-nav .nav-item .nav-link:hover {
    color: var(--color-primary-dark)
}

#topnav ul.dropdown-menu {
    background: var(--top-menu-bg);
    padding: 20px;
    opacity: 0;
    transition: opacity .2s ease;
    margin-top: 13px;
    left: -7px;
    width: fit-content;
    border-radius: var(--border-radius-m)
}

    #topnav ul.dropdown-menu li .dropdown-item {
        margin-bottom: 8px;
        padding: 6px 12px;
        font-size: 16px;
        font-weight: var(--dropdown-font-weight);
        color: var(--bs-black);
        border-radius: var(--top-menu-dropdown--border-radius);
        transition: transform .2s ease,color .5s ease
    }

        #topnav ul.dropdown-menu li .dropdown-item.active, #topnav ul.dropdown-menu li .dropdown-item:hover {
            color: #000;
            background: var(--color-neutral-hover);
            border-radius: var(--border-radius-s)
        }

    #topnav ul.dropdown-menu li:not(:last-child) {
        border-bottom: 1px solid var(--bs-dropdown-border-bottom)
    }

    #topnav ul.dropdown-menu.show {
        animation-name: fadeIn;
        animation-duration: .2s;
        opacity: 1
    }

@media (min-width: 1260px) {
    #topnav .navbar-nav .nav-item {
        margin: 0 28px
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.navbar-brand {
    height: 62px;
    max-height: 62px;
    margin-right: 12px;
    display: flex;
    align-items: center;
    padding: 0
}

@media (min-width: 576px) {
    .navbar-brand {
        margin-right: 52px
    }
}

@media (min-width: 1150px) {
    .navbar-brand {
        height: 62px;
        max-height: 62px
    }
}

.navbar-brand img.logo {
    height: 34px
}

@media (min-width: 576px) {
    .navbar-brand img.logo {
        height: 46px
    }
}

.dropdown-toggle:after {
    border-top: none;
    border-left: none;
    border-bottom: none;
    border-right: none
}

.nav-link.dropdown-toggle {
    padding-right: 10px !important
}

    .nav-link.dropdown-toggle:before {
        content: url(./images/ico-dropdown-menu.svg);
        position: absolute;
        background-repeat: no-repeat;
        top: -2px;
        right: -10px;
        background-size: 18px 18px;
        transition: all .2s ease-in-out
    }

    .nav-link.dropdown-toggle[aria-expanded=true]:before {
        -webkit-transform: rotate(180deg);
        -moz-transform: rotate(180deg);
        top: 2px
    }

.dropdown-menu {
    box-shadow: none;
    box-shadow: 0 4px 10px #00000026;
    border: none;
    top: 20px
}

    .dropdown-menu a {
        text-decoration: none
    }

body:before {
    background-color: #fff0;
    transition: all .3s ease-in-out;
    content: "";
    height: 100vh;
    position: fixed;
    z-index: 16;
    opacity: 0
}

@media (min-width: 1150px) {
    body:before {
        display: none
    }
}

body.mobile-menu-show:before {
    background-color: #0000004b;
    transition: all .3s ease-in-out;
    opacity: 1;
    width: 100%;
    top: 0
}

.logged-top-nav {
    display: flex;
    align-items: center;
    width: fit-content
}

    .logged-top-nav .dropdown-toggle:before {
        content: none
    }

    .logged-top-nav .favorite-top-nav {
        position: relative;
        width: 36px;
        height: 36px;
        display: inline-flex;
        margin-left: 10px;
        text-decoration: none;
        justify-content: center;
        align-items: center
    }

@media (min-width: 380px) {
    .logged-top-nav .favorite-top-nav {
        margin-left: 20px
    }
}

.logged-top-nav .favorite-top-nav i {
    font-size: 20px;
    font-style: normal;
    font-weight: 300;
    color: var(--color-primary-text)
}

.logged-top-nav .favorite-top-nav.active i {
    font-weight: 600
}

.logged-top-nav .basket-top-nav {
    position: relative;
    width: 36px;
    height: 36px;
    display: inline-flex;
    margin-left: 10px;
    text-decoration: none;
    justify-content: center;
    align-items: center
}

@media (min-width: 380px) {
    .logged-top-nav .basket-top-nav {
        margin-left: 20px
    }
}

.logged-top-nav .basket-top-nav i {
    font-size: 20px;
    font-style: normal;
    font-weight: 300;
    color: var(--color-primary-text)
}

.logged-top-nav .basket-top-nav.active i {
    font-weight: 600
}

.logged-top-nav .badge {
    background-color: var(--color-primary);
    border-radius: 20px;
    position: absolute;
    height: 16px;
    min-width: 16px;
    display: flex;
    justify-content: center;
    align-items: center;
    right: 0;
    padding-left: 2px;
    padding-right: 2px;
    top: 0
}

    .logged-top-nav .badge span {
        font-size: 11px;
        color: #fff;
        padding-left: 2px;
        padding-right: 2px;
        font-family: var(--font-family-primary);
        margin-bottom: 1px;
        font-weight: 500
    }

.badge:has([data-counter-value="0"]) {
    display: none
}

[data-counter-value]:after {
    content: attr(data-counter-value)
}

.my-profile {
    height: 36px;
    width: 36px;
    min-height: 36px;
    min-width: 36px;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    border-radius: 20px;
    margin-left: 20px
}

.course-heading .my-profile {
    height: 32px;
    width: 32px
}

.dropdown .my-profile {
    outline: 2px solid transparent;
    transition: .2s ease-in-out
}

    .dropdown .my-profile:hover {
        outline: 2px solid var(--color-primary)
    }

.my-profile-menu {
    height: 36px;
    width: 36px;
    min-height: 36px;
    min-width: 36px;
    background-size: cover;
    background-position: center center;
    border-radius: 25px;
    margin-right: 16px
}

.my-profile-menu-container {
    display: flex;
    padding-bottom: 16px
}

    .my-profile-menu-container .datas {
        display: -webkit-box;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis
    }

    .my-profile-menu-container p {
        font-family: var(--font-family-primary);
        font-size: 16px;
        font-style: normal;
        font-weight: 600;
        line-height: 18px;
        margin-bottom: 2px;
        text-decoration: none;
        color: var(--color-primary-text)
    }

    .my-profile-menu-container span {
        color: #707070;
        font-family: var(--font-family-primary);
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 18px;
        display: block;
        text-decoration: none;
        display: -webkit-box;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis
    }

.dropdown-menu[data-bs-popper] {
    right: 0
}

ul.dropdown-menu.logged {
    left: auto !important;
    max-width: 332px
}

#topnav ul.dropdown-menu li:last-child .dropdown-item {
    margin-bottom: 0
}

.ico-nav-item-menu {
    display: flex;
    align-items: center
}

    .ico-nav-item-menu p {
        margin-bottom: 0;
        margin-left: 6px
    }

.mobile-menu .my-profile-menu-container {
    padding-top: 0;
    padding-bottom: 0
}

.dropdown-item.icon {
    display: flex;
    align-items: center
}

    .dropdown-item.icon .ico-nav-menu-container {
        width: 28px;
        min-width: 28px;
        padding-bottom: 2px
    }

ul.dropdown-menu.logged-my-profile {
    padding: 0 24px;
    opacity: 0;
    transition: opacity .2s ease;
    margin-top: 13px;
    left: -7px;
    width: fit-content;
    background-color: var(--bg-color-primary);
    height: fit-content;
    position: fixed;
    transform: 0
}

    ul.dropdown-menu.logged-my-profile li {
        padding-right: 20px
    }

        ul.dropdown-menu.logged-my-profile li .dropdown-item {
            padding: 20px 0;
            margin: 0;
            font-size: 16px;
            font-weight: var(--dropdown-font-weight);
            color: var(--bs-black);
            border-radius: var(--top-menu-dropdown--border-radius);
            transition: transform .2s ease,color .5s ease
        }

            ul.dropdown-menu.logged-my-profile li .dropdown-item.active, ul.dropdown-menu.logged-my-profile li .dropdown-item:hover {
                transform: translate(8px);
                color: #000;
                background: initial
            }

        ul.dropdown-menu.logged-my-profile li:not(:last-child) {
            border-bottom: 1px solid #e9e9e9
        }

    ul.dropdown-menu.logged-my-profile.show {
        animation-name: fadeIn;
        animation-duration: .2s;
        opacity: 1
    }

:root {
    --bs-border-radius: var(--border-radius-m);
    --bs-btn-disabled-opacity: 1
}

.btn {
    font-family: var(--font-family-primary);
    display: inline-flex;
    min-height: 40px;
    padding: 8px 24px;
    justify-content: center;
    align-items: center;
    text-wrap: nowrap;
    height: fit-content
}

    .btn span {
        font-weight: var(--bs-btn-font-weight);
        line-height: 1;
        font-size: 16px;
        font-weight: 500
    }

    .btn i {
        font-size: 16px
    }

    .btn.btn-primary {
        background-color: var(--color-primary);
        border: 1px solid var(--color-primary);
        color: #fff
    }

        .btn.btn-primary:hover {
            background-color: var(--color-primary-dark);
            border: 1px solid var(--color-primary-dark)
        }

        .btn.btn-primary.disabled {
            background-color: var(--color-neutral-disabled);
            border: 1px solid var(--color-neutral-disabled);
            color: var(--color-neutral-disabled-dark);
            opacity: 1
        }

    .btn.btn-secondary {
        background-color: transparent;
        border: 1px solid var(--color-primary);
        color: var(--color-primary)
    }

        .btn.btn-secondary:hover {
            background-color: var(--color-primary-dark);
            border: 1px solid var(--color-primary-dark)
        }

            .btn.btn-secondary:hover span, .btn.btn-secondary:hover i {
                color: #fff
            }

        .btn.btn-secondary.disabled {
            background-color: transparent;
            border: 1px solid var(--color-neutral-disabled);
            color: var(--color-neutral-disabled);
            opacity: 1
        }

        .btn.btn-secondary .filter-counter {
            background-color: var(--color-primary);
            border-radius: var(--border-radius-xl);
            display: flex;
            justify-content: center;
            align-items: center;
            margin-left: 8px
        }

            .btn.btn-secondary .filter-counter p {
                font-size: 11px;
                font-style: normal;
                font-weight: 600;
                line-height: 16px;
                color: #fff;
                margin-bottom: 0;
                height: 16px;
                min-width: 16px
            }

@media (min-width: 768px) {
    .btn.btn-secondary .filter-counter {
        display: none
    }
}

.btn.btn-teritary {
    background-color: var(--bg-color-primary);
    border: 1px solid var(--color-primary-text);
    color: var(--color-primary-text)
}

    .btn.btn-teritary:hover {
        background-color: var(--color-neutral-hover);
        border: 1px solid var(--color-primary-text)
    }

        .btn.btn-teritary:hover span, .btn.btn-teritary:hover i {
            color: var(--color-primary-text)
        }

    .btn.btn-teritary.disabled {
        background-color: transparent;
        border: 1px solid var(--color-neutral-disabled);
        color: var(--color-neutral-disabled);
        opacity: 1
    }

.btn.btn-ghost {
    background-color: transparent;
    color: var(--color-primary)
}

    .btn.btn-ghost:hover {
        background-color: var(--color-neutral-hover);
        border: 1px solid var(--color-neutral-hover)
    }

        .btn.btn-ghost:hover span, .btn.btn-ghost:hover i {
            color: var(--color-primary)
        }

    .btn.btn-ghost.disabled {
        background-color: transparent;
        border: 1px solid transparent;
        color: var(--color-neutral-disabled);
        opacity: 1
    }

.btn.icon-left i {
    margin-right: 12px
}

.btn.icon-right i {
    margin-left: 12px
}

.btn.icon-bars-filter i {
    margin-right: 12px
}

.btn.short {
    padding: 2px 16px;
    min-height: 24px;
    border-radius: var(--border-radius-s)
}

    .btn.short span {
        font-weight: var(--bs-btn-font-weight);
        line-height: 1.2;
        font-size: 14px;
        font-weight: 600;
        margin-top: 1px
    }

    .btn.short i {
        font-size: 14px
    }

@media (max-width: 575px) {
    .btn.mobile-full-wide {
        width: 100%
    }
}

.btn.full-wide {
    width: 100%
}

.btn.add-to-list {
    width: 40px;
    height: 40px;
    padding: 0;
    min-width: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none
}

    .btn.add-to-list i {
        font-size: 16px
    }

    .btn.add-to-list.btn-primary {
        background-color: var(--color-primary);
        border: 1px solid var(--color-primary);
        color: var(--bg-color-primary)
    }

        .btn.add-to-list.btn-primary:hover {
            background-color: var(--color-primary-dark);
            border: 1px solid var(--color-primary-dark)
        }

        .btn.add-to-list.btn-primary.disabled {
            background-color: var(--color-neutral-disabled);
            border: 1px solid var(--color-neutral-disabled);
            opacity: 1
        }

            .btn.add-to-list.btn-primary.disabled i {
                color: var(--color-neutral-disabled-dark)
            }

        .btn.add-to-list.btn-primary.checked {
            background-color: var(--color-primary);
            border: 1px solid var(--color-primary)
        }

            .btn.add-to-list.btn-primary.checked i {
                color: var(--bg-color-primary);
                --fa-style: 900
            }

            .btn.add-to-list.btn-primary.checked:hover {
                background-color: var(--color-primary-dark);
                border: 1px solid var(--color-primary-dark)
            }

                .btn.add-to-list.btn-primary.checked:hover i {
                    color: var(--bg-color-primary)
                }

    .btn.add-to-list.btn-secondary {
        background-color: transparent;
        border: 1px solid var(--color-primary)
    }

        .btn.add-to-list.btn-secondary:hover {
            background-color: var(--color-primary-dark);
            border: 1px solid var(--color-primary-dark)
        }

            .btn.add-to-list.btn-secondary:hover i {
                color: var(--bg-color-primary)
            }

        .btn.add-to-list.btn-secondary.disabled {
            background-color: transparent;
            border: 1px solid var(--color-neutral-disabled);
            opacity: 1
        }

            .btn.add-to-list.btn-secondary.disabled i {
                color: var(--color-neutral-disabled)
            }

        .btn.add-to-list.btn-secondary.checked {
            background-color: transparent;
            border: 1px solid var(--color-primary)
        }

            .btn.add-to-list.btn-secondary.checked i {
                color: var(--color-primary);
                --fa-style: 900
            }

            .btn.add-to-list.btn-secondary.checked:hover {
                background-color: transparent;
                border: 1px solid var(--color-primary-dark)
            }

                .btn.add-to-list.btn-secondary.checked:hover i {
                    color: var(--color-primary-dark)
                }

    .btn.add-to-list.btn-ghost {
        background-color: transparent;
        border: 1px solid transparent
    }

        .btn.add-to-list.btn-ghost i {
            color: var(--color-secondary-text);
            font-size: 14px
        }

        .btn.add-to-list.btn-ghost:hover {
            background-color: transparent;
            border: 1px solid transparent
        }

            .btn.add-to-list.btn-ghost:hover i {
                color: var(--color-favorite)
            }

        .btn.add-to-list.btn-ghost.disabled {
            background-color: transparent;
            border: 1px solid transparent;
            opacity: 1
        }

            .btn.add-to-list.btn-ghost.disabled i {
                color: var(--color-neutral-disabled)
            }

        .btn.add-to-list.btn-ghost.checked {
            background-color: transparent;
            border: 1px solid transparent
        }

            .btn.add-to-list.btn-ghost.checked i {
                color: var(--color-favorite);
                --fa-style: 900
            }

            .btn.add-to-list.btn-ghost.checked:hover {
                background-color: transparent;
                border: 1px solid transparent
            }

                .btn.add-to-list.btn-ghost.checked:hover i {
                    color: color-mix(in srgb,var(--color-favorite) 85%,#000000)
                }

.page-player .player-bottom-bar-menu .btn span {
    text-wrap: nowrap
}

.btn-product-fav:not(.active) .add {
    display: block
}

.btn-product-fav:not(.active) .remove {
    display: none
}

.btn-product-fav.active .add {
    display: none
}

.btn-product-fav.active .remove {
    display: block
}

.in-progress {
    position: relative
}

    .in-progress:before {
        content: "";
        position: absolute;
        z-index: 100001;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        opacity: .2
    }

    .in-progress.show-spinner:after {
        font-family: "Font Awesome 7 Pro",serif;
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        margin-top: -7px;
        margin-left: -21px;
        z-index: 100002;
        font-size: 45px;
        color: var(--app-color-brand);
        animation: fa-spin .75s linear infinite
    }

.btn.in-progress {
    pointer-events: none
}

    .btn.in-progress.show-spinner:after {
        color: inherit;
        margin: 0;
        top: calc(50% - 8px);
        left: calc(50% - 13px);
        font-size: 26px;
        line-height: 16px
    }

@media (max-width: 576px) {
    .w-100-xs-sm {
        width: 100%
    }
}

.nav.nav-tabs {
    border-bottom: none;
    display: flex;
    align-items: end
}

@media (min-width: 992px) {
    .nav.nav-tabs {
        position: absolute
    }
}

.nav.nav-tabs p {
    margin-bottom: 0;
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    white-space: nowrap
}

.nav.nav-tabs button.nav-link {
    display: flex;
    text-align: left;
    border: 0;
    background: var(--bg-default);
    border-radius: 0;
    font-size: 1.1rem;
    position: relative;
    color: var(--text-color);
    padding: 13px 12px;
    z-index: 2;
    margin-bottom: 0;
    transition: all .2s ease-out
}

@media (min-width: 568px) {
    .nav.nav-tabs button.nav-link {
        min-width: 152px;
        padding: 13px 16px
    }
}

.nav.nav-tabs button.nav-link span {
    display: block;
    font-size: clamp(.875rem,.875rem + 0vw,.875rem);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    color: var(--text-color-lighter)
}

@media (min-width: 568px) {
    .nav.nav-tabs button.nav-link .nav.nav-tabs .button.nav-link {
        min-width: 152px
    }
}

.nav.nav-tabs button.nav-link.active {
    z-index: 1;
    border-radius: 0;
    box-shadow: 0 3px 0 0 var(--color-primary);
    transition: all .2s ease-out
}

.nav.nav-tabs button.nav-link:focus-visible {
    outline: none
}

.nav.nav-tabs button.nav-link:not(.active):hover:before {
    width: 100%
}

.nav.nav-tabs button.nav-link:not(.active):hover p {
    color: var(--color-primary-dark)
}

.nav.nav-tabs button.nav-link .quanity {
    border-radius: var(--border-radius-s);
    background-color: var(--bg-color-primary);
    padding: 2px 6px;
    margin-left: 8px;
    border: 1px solid var(--color-border-light)
}

    .nav.nav-tabs button.nav-link .quanity span {
        font-size: var(--paragraph-xs-font-size);
        font-weight: var(--paragraph-xs-font-weight);
        color: var(--color-secondary-text)
    }

.nav.nav-tabs .nav-item:not(:last-child) .nav-link {
    margin-right: 8px
}

@media (min-width: 992px) {
    .nav.nav-tabs .nav-item:not(:last-child) .nav-link {
        margin-right: 18px
    }
}

.tab-content {
    background: transparent
}

    .tab-content .tab-content-left-column {
        align-items: start;
        display: flex;
        flex-direction: column
    }

@media (min-width: 992px) {
    .tab-content .tab-content-left-column {
        padding-top: 136px;
        min-height: 416px
    }
}

.tab-content-left-column .header {
    font-size: clamp(1.75rem,1.4082rem + 1.519vw,2.5rem);
    font-weight: 400;
    line-height: 1.3
}

.tab-banner-container {
    position: relative;
    margin-top: 32px;
    margin-bottom: 36px
}

.bgr-mobile-header {
    background-size: cover;
    background-position: center center;
    width: 100%;
    height: 100%;
    border-radius: var(--border-radius-l)
}

.nav.nav-tabs {
    position: inherit;
    flex-wrap: nowrap;
    overflow-x: auto;
    margin-left: -16px;
    margin-right: -16px;
    padding-left: 16px;
    padding-right: 16px;
    padding-bottom: 3px
}

    .nav.nav-tabs .nav-item:first-child {
        margin-left: 9px
    }

    .nav.nav-tabs .nav-item:last-child {
        margin-right: 9px
    }

    .nav.nav-tabs.tabs-in-element {
        margin-left: 0;
        margin-right: 0
    }

@media (min-width: 568px) {
    .nav.nav-tabs button.nav-link {
        min-width: fit-content;
        padding: 13px 16px
    }
}

.box-info-video {
    background-color: var(--color-primary);
    display: flex;
    padding: 18px 24px 18px 29px;
    align-items: center;
    gap: 29px;
    flex-shrink: 0;
    border-radius: var(--border-radius-l);
    color: #fff;
    font-size: var(--font-size-course)
}

    .box-info-video p:last-child {
        margin-bottom: 0
    }

.tab-content {
    border-top: 1px solid var(--color-border-light)
}

    .tab-content .content a, .tab-content .content a:hover {
        color: var(--color-primary);
        cursor: pointer
    }

    .tab-content .content blockquote, .tab-content .content .quote {
        margin: 32px 0 !important
    }

@media (min-width: 768px) {
    .tab-content .content blockquote, .tab-content .content .quote {
        padding: 0 48px !important
    }
}

.tab-content .content blockquote .author, .tab-content .content .quote .author {
    text-align: end
}

    .tab-content .content blockquote .author p, .tab-content .content .quote .author p {
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 22px;
        margin-bottom: 0
    }

    .tab-content .content blockquote .author a, .tab-content .content blockquote .author a:hover, .tab-content .content .quote .author a, .tab-content .content .quote .author a:hover {
        color: var(--color-primary);
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 22px;
        cursor: pointer
    }

.tab-content .content blockquote p, .tab-content .content .quote p {
    font-style: italic;
    font-weight: 300
}

.tab-content .content.description-tab h3, .tab-content .content.description-tab .h3 {
    font-size: 28px;
    font-style: normal;
    font-weight: 500;
    line-height: 38px;
    letter-spacing: 2.8px;
    margin-bottom: 20px
}

.tab-content .content.description-tab .img {
    max-width: 100%;
    height: auto
}

.nav-link p {
    color: var(--color-secondary-text);
    font-size: var(--label-2-font-size);
    font-weight: var(--label-2-font-weight)
}

.nav-link.active p {
    color: var(--color-primary)
}

.tab-content {
    padding-top: 48px
}

.tabs-certificates .tab-content {
    padding-top: 12px
}

.tabs-certificates .table-heading {
    margin-bottom: 32px
}

@media (min-width: 768px) {
    .tabs-certificates .table-heading {
        margin-bottom: 40px
    }
}

.table {
    margin-bottom: 12px
}

    .table .label p {
        font-weight: 600;
        line-height: 1.6
    }

    .table p {
        margin-bottom: 0
    }

    .table.fs-16 .label p {
        font-weight: 600
    }

    .table.fs-16 .data p {
        font-weight: 300
    }

    .table.fs-16 p, .table.fs-16 a {
        font-size: 16px
    }

@media (min-width: 1150px) {
    .tabs-course {
        height: 100%
    }
}

.col-course-details .nav-tabs {
    margin-left: -16px;
    margin-right: -16px
}

@media (min-width: 768px) {
    .col-course-details .nav-tabs {
        margin-left: -32px;
        margin-right: -32px
    }
}

@media (min-width: 992px) {
    .col-course-details .nav-tabs {
        border-bottom: 1px solid var(--color-border-light);
        margin-bottom: -1px
    }
}

@media (min-width: 1150px) {
    .col-course-details .nav-tabs {
        margin-right: -4px
    }
}

:root {
    --course-card-font-size: 1.25rem;
    --text-font-weight: 300
}

.card.course {
    min-height: 387px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    font-weight: var(--text-font-weight);
    background-color: var(--bs-primary);
    border-radius: var(--border-radius-l);
    color: #fff
}

    .card.course .image-cover-container {
        height: 222px;
        transition-timing-function: cubic-bezier(.5,.05,1,.5);
        transition: height .2s;
        position: relative
    }

    .card.course .btn.btn-gray {
        position: absolute;
        z-index: 2;
        opacity: 0;
        transition: all .3s ease-out
    }

    .card.course:hover .image-cover-container {
        transition: all .3s ease-out
    }

@media (min-width: 992px) {
    .card.course:hover .image-cover-container picture {
        -webkit-filter: brightness(.7);
        filter: brightness(.7)
    }
}

@media (min-width: 992px) {
    .card.course:hover .btn.btn-gray {
        transition: all .3s ease-out;
        opacity: 1
    }
}

.card.course .course-info {
    height: calc(100% - 168px);
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 10px
}

    .card.course .course-info h3, .card.course .course-info .h3 {
        font-size: clamp(1.25rem,1.193rem + .2532vw,1.375rem);
        line-height: 1.4;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
        max-height: 4.2em;
        font-weight: 500;
        margin-bottom: 0
    }

    .card.course .course-info .course-link {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        transform: translateY(100%)
    }

.card.course .course-enrol-info {
    background-color: var(--color-sand);
    color: #000;
    padding: 8px 24px;
    border-radius: var(--border-radius-m);
    text-transform: uppercase;
    font-family: var(--font-family-primary);
    font-size: 14px;
    font-weight: 500;
    height: 47px;
    display: flex;
    align-items: center
}

.card.course .course-card-heading {
    min-height: 175px;
    padding: 0 12px
}

@media (min-width: 992px) {
    .card.course .course-card-heading {
        padding: 0 22px
    }
}

.card.course .course-card-heading-title {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-weight: 500
}

.card.course .course-card-heading-date {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-weight: 200;
    text-transform: uppercase
}

.course-card {
    background-color: var(--bg-color-primary);
    border-radius: var(--border-radius-l);
    width: 100%;
    transition: .2s ease-in-out;
    padding: 8px;
    display: flex;
    flex-direction: column
}

    .course-card .bg-img-header {
        background-size: cover;
        background-position: center center;
        border-radius: var(--border-radius-m)
    }

    .course-card .data-container {
        padding: 12px;
        display: flex;
        flex-direction: column;
        height: 100%;
        flex-grow: 1
    }

        .course-card .data-container a.btn {
            position: relative;
            z-index: 1
        }

    .course-card .type p {
        color: var(--color-secondary-text);
        font-size: 12px;
        font-style: normal;
        font-weight: 500;
        line-height: 13px;
        letter-spacing: .48px;
        margin-bottom: 12px;
        margin-top: 7px;
        text-transform: uppercase;
        display: -webkit-box;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis
    }

    .course-card .title p {
        color: var(--color-primary-text);
        font-size: 18px;
        font-style: normal;
        font-weight: 600;
        line-height: 24px;
        margin-bottom: 12px;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis
    }

    .course-card .description p {
        font-size: var(--paragraph-s-font-size);
        font-weight: var(--paragraph-s-font-weight);
        display: -webkit-box;
        -webkit-line-clamp: 7;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis
    }

    .course-card .bottom-info-container .bottom-info {
        background-color: var(--bg-color-secondary);
        padding: 8px;
        border-radius: var(--border-radius-m);
        width: 100%
    }

    .course-card .bottom-info-container .bottom-add-to-list {
        background-color: var(--bg-color-secondary);
        border-radius: var(--border-radius-m);
        margin-left: 8px
    }

    .course-card .bottom-info-container {
        display: flex
    }

        .course-card .bottom-info-container .bottom-info {
            justify-content: space-between;
            display: flex
        }

            .course-card .bottom-info-container .bottom-info .ico-element {
                display: flex;
                align-items: center
            }

                .course-card .bottom-info-container .bottom-info .ico-element.score i {
                    color: var(--color-review-star)
                }

                .course-card .bottom-info-container .bottom-info .ico-element.disabled i {
                    color: var(--color-neutral-disabled-dark)
                }

                .course-card .bottom-info-container .bottom-info .ico-element i {
                    width: 20px;
                    height: 20px;
                    margin-right: 4px;
                    color: var(--color-secondary-text);
                    display: flex;
                    align-items: center;
                    font-size: 14px
                }

                .course-card .bottom-info-container .bottom-info .ico-element p {
                    margin-bottom: 0;
                    font-size: 14px;
                    font-style: normal;
                    font-weight: 400;
                    line-height: 18px;
                    color: var(--color-secondary-text)
                }

    .course-card .hover-container {
        border-radius: var(--border-radius-m);
        position: relative;
        overflow: hidden;
        display: flex;
        flex-direction: column;
        height: 100%
    }

        .course-card .hover-container .hover-description {
            background-color: var(--bg-color-secondary);
            height: calc(100% - 8px);
            width: 100%;
            position: absolute;
            z-index: 1;
            border-radius: var(--border-radius-m);
            top: -100%;
            transition: .3s ease-in-out
        }

    .course-card:hover {
        box-shadow: 0 4px 8px #00000014,0 0 4px #00000014
    }

        .course-card:hover .hover-description {
            top: 0
        }

    .course-card .table-course {
        margin-top: auto
    }

        .course-card .table-course .table-element {
            display: flex;
            border-bottom: 1px solid var(--color-border-light);
            padding-top: 5px;
            padding-bottom: 8px;
            color: var(--color-primary-text)
        }

            .course-card .table-course .table-element:first-child {
                border-top: 1px solid var(--color-border-light)
            }

            .course-card .table-course .table-element .label {
                width: 88px;
                min-width: 88px
            }

                .course-card .table-course .table-element .label p {
                    font-family: var(--font-family-primary);
                    font-size: 14px;
                    font-style: normal;
                    font-weight: 500;
                    line-height: 21px;
                    color: var(--color-primary-text);
                    opacity: 1;
                    text-transform: none;
                    letter-spacing: normal;
                    margin-bottom: 0;
                    padding-bottom: 0
                }

            .course-card .table-course .table-element .data p {
                font-family: var(--font-family-primary);
                font-size: 14px;
                font-style: normal;
                font-weight: 400;
                line-height: 21px;
                color: var(--color-primary-text);
                opacity: 1;
                text-transform: none;
                letter-spacing: normal;
                margin-bottom: 0;
                padding-bottom: 0
            }

            .course-card .table-course .table-element .data .status {
                display: flex;
                align-items: center
            }

                .course-card .table-course .table-element .data .status .dot {
                    border-radius: var(--border-radius-l);
                    width: 13px;
                    height: 13px;
                    border: 2px solid var(--color-border-light);
                    margin-right: 8px
                }

                    .course-card .table-course .table-element .data .status .dot.dot-not-started {
                        background-color: var(--color-neutral-rest)
                    }

                    .course-card .table-course .table-element .data .status .dot.dot-overdue {
                        background-color: var(--color-danger)
                    }

                    .course-card .table-course .table-element .data .status .dot.dot-in-progress {
                        background-color: var(--color-warning)
                    }

                    .course-card .table-course .table-element .data .status .dot.dot-completed {
                        background-color: var(--color-success)
                    }

            .course-card .table-course .table-element.certificates {
                margin-top: 8px
            }

                .course-card .table-course .table-element.certificates:last-of-type {
                    border-top: 1px solid rgba(255,255,255,.3411764706);
                    border-bottom: none
                }

.carousel-control-prev:enabled, .carousel-control-prev:hover, .carousel-control-prev:focus, .carousel-control-next:enabled, .carousel-control-next:hover, .carousel-control-next:focus {
    color: var(--text-color) !important;
    font-size: 3.6rem;
    opacity: 1
}

.carousel-quotations .carousel-indicators {
    margin-bottom: 0
}

.carousel-indicators [data-bs-target] {
    background-color: var(--color-neutral-rest);
    height: 8px;
    min-height: 8px;
    min-width: 8px;
    width: 8px;
    border-radius: var(--border-radius-l);
    border-bottom: 0;
    margin-left: 4px;
    margin-right: 4px;
    margin-top: 12px;
    opacity: 1;
    border: none
}

.carousel-indicators {
    flex-wrap: wrap;
    bottom: -40px
}

    .carousel-indicators .active {
        border-radius: var(--border-radius-l);
        width: 24px;
        background-color: var(--color-primary)
    }

.carousel-quote-text {
    font-size: clamp(1.25rem,.9082rem + 1.519vw,2rem);
    font-weight: 400;
    line-height: 1.55;
    font-style: italic
}

:root {
    --quote-icon-opacity: .1;
    --quote-icon-color: var(--text-color);
    --quote-icon-size: 100px;
    --quote-icon-style: italic;
    --quote-line-height: 1.3
}

.quote-container {
    position: relative;
    min-height: 100px;
    padding: 2rem;
    line-height: var(--quote-line-height)
}

    .quote-container .quote-body {
        width: 100%
    }

.container > .quote-container {
    max-width: 1140px;
    min-height: 400px
}

.carousel-quotations {
    margin-bottom: 100px;
    margin-top: 60px
}

@media (min-width: 1150px) {
    .carousel-quotations {
        margin-bottom: 120px;
        margin-top: 60px
    }
}

@media (min-width: 1600px) {
    .carousel-quotations {
        margin-bottom: 120px;
        margin-top: 0
    }
}

.card-lottie {
    background: var(--color-sand);
    transition: box-shadow .3s;
    border-radius: var(--border-radius-l);
    width: 100%;
    position: relative;
    padding: 24px;
    cursor: pointer
}

@media (min-width: 992px) {
    .card-lottie {
        padding: 27px
    }
}

.card-lottie h3, .card-lottie .h3 {
    font-size: clamp(2.5rem,2.3576rem + .6329vw,2.8125rem);
    font-weight: 400;
    line-height: 1.1
}

.card-lottie p {
    font-size: clamp(1.125rem,1.068rem + .2532vw,1.25rem);
    font-weight: 400;
    margin-bottom: 0;
    margin-top: auto
}

@keyframes swing {
    80% {
        transform: scaleX(-.02)
    }

    to {
        transform: scaleX(.02)
    }
}

.promo-mid-header {
    background-color: var(--color-primary);
    min-height: 80px;
    color: #fff;
    display: flex;
    align-items: center
}

    .promo-mid-header .header {
        font-size: clamp(1.25rem,1.0222rem + 1.0127vw,1.75rem);
        display: flex;
        justify-content: center;
        margin-bottom: 2px;
        font-weight: 600
    }

@media (min-width: 992px) {
    .promo-mid-header .header {
        padding-right: 40px
    }
}

.promo-mid-header .header p {
    margin-bottom: 0
}

    .promo-mid-header .header p span {
        font-weight: 400 !important
    }

footer {
    background-color: var(--color-primary-text);
    padding-top: 60px;
    padding-bottom: 60px;
    color: var(--bg-color-primary)
}

    footer .form-check label {
        font-size: 14px;
        color: var(--color-secondary-text);
        font-weight: 400;
        line-height: 18px;
        padding-top: 10px
    }

    footer .col-left {
        margin-bottom: 60px
    }

    footer .col-right {
        margin-bottom: 60px
    }

    footer a {
        color: var(--bg-color-primary);
        text-decoration: none
    }

    footer h3, footer .h3 {
        font-size: var(--subtitle-font-size);
        font-weight: 600;
        margin-bottom: 12px
    }

    footer p {
        font-size: var(--paragraph-l-font-size);
        font-weight: var(--paragraph-l-font-weight);
        margin-bottom: 40px;
        line-height: 26px
    }

    footer .spacing {
        background-color: var(--bg-color-primary);
        opacity: .2;
        width: 100%;
        height: 1px
    }

    footer .contact {
        font-size: 12px;
        padding-top: 32px
    }

        footer .contact a, footer .contact p {
            color: var(--bg-color-primary);
            text-decoration: none;
            margin-bottom: 0;
            font-size: 12px;
            font-weight: 500
        }

        footer .contact p {
            opacity: .6
        }

    footer .menu-footer {
        margin-bottom: 12px;
        display: flex;
        margin-top: 36px;
        flex-wrap: wrap
    }

@media (min-width: 768px) {
    footer .menu-footer {
        display: flex;
        flex-direction: row
    }
}

footer .menu-footer .nav-item {
    margin-bottom: 22px;
    margin-right: 24px;
    word-break: none
}

    footer .menu-footer .nav-item a {
        text-wrap: nowrap
    }

@media (min-width: 768px) {
    footer .menu-footer .nav-item {
        margin-right: 56px
    }
}

footer .social {
    margin-bottom: 36px
}

    footer .social a {
        margin-right: 20px
    }

    footer .social i {
        font-size: 20px;
        color: var(--bg-color-primary)
    }

@media (min-width: 992px) {
    footer .social {
        text-align: right
    }

        footer .social a {
            margin-right: 0;
            margin-left: 20px
        }
}

footer .address {
    margin-bottom: 32px
}

@media (min-width: 992px) {
    footer .address {
        text-align: right;
        margin-top: 36px
    }
}

footer .address h4, footer .address .h4 {
    color: var(--color-secondary-text);
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: 24px;
    margin-bottom: 0
}

footer .address p {
    color: var(--color-secondary-text);
    font-size: 16px;
    font-weight: 400;
    line-height: 24px
}

.footer-margin {
    margin-bottom: 56px
}

@media (min-width: 768px) {
    .footer-margin {
        margin-bottom: 50px
    }
}

@media (min-width: 1150px) {
    .footer-margin {
        margin-bottom: 64px
    }
}

.swiper-slider .swiper-wrapper .swiper-slide {
    min-width: 300px
}

.swiper-slider {
    padding-right: 0;
    padding-left: 0;
    margin-left: -16px;
    margin-right: -16px
}

@media (min-width: 992px) {
    .swiper-slider {
        margin-left: -8px;
        margin-right: -4px
    }
}

.swiper-button-prev:after, .swiper-button-next:after {
    content: ""
}

.card-swiper-button-prev i, .card-swiper-button-next i {
    color: var(--color-primary-text);
    opacity: 1;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    border-radius: var(--border-radius-m);
    background: var(--bg-color-primary);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 2.2px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .2s ease
}

    .card-swiper-button-prev i:hover, .card-swiper-button-next i:hover {
        color: var(--color-primary);
        background: var(--color-neutral-hover)
    }

.card-swiper-button-prev {
    position: absolute;
    z-index: 2;
    left: 0;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    top: 50%;
    background-color: #fff;
    border-radius: var(--border-radius-m);
    box-shadow: 0 0 12px #00000014,0 0 4px #0000000a
}

.card-swiper-button-next {
    position: absolute;
    z-index: 2;
    right: 6px;
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%);
    top: 50%;
    background-color: #fff;
    border-radius: var(--border-radius-m);
    box-shadow: 0 0 12px #00000014,0 0 4px #0000000a
}

.card.logo {
    display: flex;
    justify-content: center
}

    .card.logo .logo-conainer {
        height: 80px;
        width: fit-content;
        max-height: 80px;
        display: flex;
        mix-blend-mode: multiply
    }

        .card.logo .logo-conainer picture, .card.logo .logo-conainer img {
            margin-top: auto;
            margin-bottom: auto;
            mix-blend-mode: multiply;
            max-width: 110px;
            max-height: 60px
        }

@media (min-width: 1150px) {
    .card.logo .logo-conainer picture, .card.logo .logo-conainer img {
        max-width: 150px;
        max-height: 70px
    }
}

.swiper-network .swiper-wrapper {
    -webkit-transition-timing-function: linear !important;
    -o-transition-timing-function: linear !important;
    transition-timing-function: linear !important
}

    .swiper-network .swiper-wrapper .swiper-slide {
        max-height: 50px;
        max-width: 150px
    }

.container-swiper-arrows {
    position: relative
}

    .container-swiper-arrows .card-swiper-button-prev, .container-swiper-arrows .card-swiper-button-next {
        display: none
    }

@media (min-width: 992px) {
    .container-swiper-arrows .card-swiper-button-prev, .container-swiper-arrows .card-swiper-button-next {
        display: block
    }
}

.swiper-slide {
    height: auto;
    display: flex;
    padding: 8px
}

@media (max-width: 991px) {
    .swiper-slide {
        max-width: 302px
    }
}

.ico-hamburger {
    cursor: pointer;
    margin-left: 16px
}

@media (min-width: 380px) {
    .ico-hamburger {
        margin-left: 20px
    }
}

.mobile-menu {
    background-color: var(--bg-color-primary);
    font-family: var(--font-family-primary);
    height: 100vh;
    width: 100%;
    right: -100%;
    position: fixed;
    z-index: 21;
    opacity: 1;
    flex-direction: column;
    transition: all .3s ease-in-out;
    top: 0;
    display: flex
}

    .mobile-menu .overflow-content {
        overflow-y: auto;
        height: 100%;
        padding-bottom: 24px;
        display: flex;
        flex-direction: column
    }

.mobile-menu-show .mobile-menu {
    background-color: var(--bg-color-primary);
    height: 100vh;
    width: 100%;
    right: 0;
    position: fixed;
    z-index: 21;
    transition: all .3s ease-in-out;
    padding-left: 20px;
    padding-right: 20px;
    opacity: 1;
    display: flex;
    top: 0
}

@media (min-width: 768px) {
    .mobile-menu-show .mobile-menu {
        width: 50%
    }
}

.mobile-menu-show {
    overflow: hidden;
    overflow-x: hidden
}

.ico-hamburger {
    cursor: pointer
}

.mobile-menu-element {
    padding: 20px;
    width: 100%;
    text-decoration: none;
    color: #000;
    font-size: 18px;
    cursor: pointer;
    border-top: 1px solid var(--color-border-light)
}

    .mobile-menu-element:last-of-type {
        border-bottom: 1px solid var(--color-border-light)
    }

    .mobile-menu-element p {
        margin-bottom: 0;
        font-size: 16px;
        font-weight: 500
    }

    .mobile-menu-element a {
        width: 100%;
        font-size: 16px;
        font-weight: 500
    }

.ico-more-mobile-menu {
    height: 16px;
    padding-left: 10px
}

body[data-nested-mobile-menu-visible] [data-nested-mobile-menu-default] {
    display: none
}

[data-nested-mobile-menu-container] {
    background-color: var(--bg-color-primary);
    font-family: var(--font-family-primary);
    width: 0;
    right: 0;
    z-index: 1;
    opacity: 1;
    display: flex;
    flex-direction: column;
    display: none;
    transition: all .3s ease-in-out
}

    [data-nested-mobile-menu-container] .mobile-menu-show {
        right: 0;
        z-index: 12;
        opacity: 1
    }

    [data-nested-mobile-menu-container].visible {
        background-color: var(--bg-color-primary);
        width: 100%;
        right: 0;
        z-index: 12;
        transition: all .3s ease-in-out;
        display: block;
        opacity: 1
    }

.mobile-menu-element-nav {
    border-top: 1px solid var(--color-border-light);
    padding-top: 27px;
    padding-bottom: 27px;
    width: 100%;
    text-decoration: none;
    color: var(--color-primary-text);
    font-size: 18px
}

    .mobile-menu-element-nav a {
        color: var(--color-primary-text);
        display: flex;
        justify-content: start;
        align-items: center;
        text-decoration: none;
        font-size: 24px;
        font-weight: 600
    }

[data-nested-mobile-menu-close] {
    cursor: pointer;
    width: fit-content
}

.ico-social-footer {
    color: var(--colo-primary-text);
    font-size: 32px
}

.ico-social-footer-container {
    display: flex;
    justify-content: space-evenly;
    margin-bottom: 30px;
    margin-top: auto
}

.standard-component {
    font-size: clamp(1.0625rem,.9821rem + .3571vw,1.25rem);
    line-height: 1.6
}

    .standard-component p {
        font-weight: 300
    }

        .standard-component p span {
            font-weight: 500
        }

    .standard-component a {
        text-decoration: none;
        color: var(--color-primary)
    }

        .standard-component a.course-link {
            text-decoration: underline;
            color: var(--color-black)
        }

    .standard-component h6, .standard-component .h6 {
        font-size: var(--paragraph-l-semibold-font-size);
        font-weight: var(--paragraph-l-semibold-font-weight)
    }

    .standard-component .description {
        font-size: clamp(1.375rem,1.2041rem + .7595vw,1.75rem);
        line-height: 1.35;
        font-weight: 500
    }

        .standard-component .description p {
            margin-bottom: 0;
            font-weight: 500
        }

        .standard-component .description h3, .standard-component .description .h3 {
            font-size: clamp(1.75rem,1.2658rem + 2.1519vw,2.8125rem);
            font-weight: 400;
            line-height: 1.32
        }

    .standard-component h4, .standard-component .h4 {
        font-size: clamp(2rem,1.8861rem + .5063vw,2.25rem);
        font-style: normal;
        font-weight: 500
    }

    .standard-component .disclaimer {
        font-size: 14px;
        font-weight: 300
    }

    .standard-component.low-heading h1, .standard-component.low-heading .h1 {
        margin-top: 12px;
        margin-bottom: 14px
    }

@media (min-width: 768px) {
    .standard-component.low-heading h1, .standard-component.low-heading .h1 {
        margin-top: 4px;
        margin-bottom: 32px
    }
}

.standard-component.low-heading h2, .standard-component.low-heading .h2 {
    margin-top: 12px;
    margin-bottom: 14px
}

@media (min-width: 768px) {
    .standard-component.low-heading h2, .standard-component.low-heading .h2 {
        margin-top: 4px;
        margin-bottom: 32px
    }
}

@media (min-width: 768px) {
    .standard-component.mid-low-heading {
        margin-bottom: 40px
    }
}

@media (min-width: 992px) {
    .standard-component.mid-low-heading {
        margin-bottom: 97px
    }
}

.standard-component.mid-low-heading h1, .standard-component.mid-low-heading .h1 {
    margin-top: 12px;
    margin-bottom: 45px
}

@media (min-width: 768px) {
    .standard-component.mid-low-heading h1, .standard-component.mid-low-heading .h1 {
        margin-top: 45px;
        margin-bottom: 43px
    }
}

.standard-component .price-l {
    display: flex;
    align-items: end
}

    .standard-component .price-l span {
        font-size: var(--hero-title-font-size);
        font-weight: 600;
        margin-bottom: 0
    }

        .standard-component .price-l span small, .standard-component .price-l span .small {
            margin-bottom: 0;
            font-size: var(--paragraph-semibold-font-size);
            font-weight: 500;
            padding-left: 6px
        }

.big-icon {
    display: flex;
    align-items: center
}

    .big-icon p {
        font-size: clamp(2rem,1.3571rem + 2.8571vw,3.5rem);
        line-height: 1.2;
        margin-bottom: 0
    }

    .big-icon .big-icon-container {
        height: 70px;
        width: 70px;
        min-width: 70px;
        display: flex;
        align-items: center
    }

@media (min-width: 992px) {
    .big-icon .big-icon-container {
        height: 80px;
        width: 80px;
        min-width: 80px
    }
}

.big-icon .big-icon-container img {
    width: 100%;
    height: auto
}

.max-w-444 {
    max-width: 444px;
    width: 100%;
    height: auto
}

.video-square-444 {
    object-fit: cover
}

@media (min-width: 768px) {
    .video-square-444 {
        width: 444px;
        height: 444px
    }
}

.team-profile-box {
    font-size: clamp(1rem,.8861rem + .5063vw,1.25rem);
    line-height: 1.4;
    margin-bottom: 48px
}

    .team-profile-box .ratio {
        margin-bottom: 20px
    }

    .team-profile-box p {
        font-weight: 600;
        margin-bottom: 0
    }

    .team-profile-box span {
        font-weight: 400;
        line-height: 1.1
    }

.box-container-white-rounded {
    padding: 32px 20px;
    border-radius: var(--border-radius-l);
    background: #fff
}

@media (min-width: 768px) {
    .box-container-white-rounded {
        padding: 40px
    }
}

@media (min-width: 1150px) {
    .min-h-600px {
        min-height: 600px
    }
}

.breadcrumb-item + .breadcrumb-item:before {
    background-image: url(./images/arrow-breadcrumb.svg);
    background-repeat: no-repeat;
    background-size: 11px 7px;
    padding-right: 32px;
    content: "";
    display: inline-block;
    height: 22px;
    background-position: center center
}

.breadcrumb-item {
    padding-left: 0 !important
}

    .breadcrumb-item a {
        font-size: 14px;
        font-weight: 300;
        color: #000;
        text-decoration: none;
        padding-left: 0
    }

.breadcrumb-container {
    overflow-x: auto;
    margin-left: -16px;
    margin-right: -16px
}

.breadcrumb {
    font-size: 14px;
    margin-top: 20px;
    margin-bottom: 20px;
    flex-wrap: nowrap;
    overflow-x: auto
}

    .breadcrumb:first-child {
        padding-left: 16px
    }

    .breadcrumb:last-child {
        padding-right: 16px
    }

    .breadcrumb .breadcrumb-item {
        white-space: nowrap;
        min-width: fit-content
    }

    .breadcrumb .active {
        color: #00000080;
        padding-left: 0
    }

    .breadcrumb img {
        margin-bottom: 2px
    }

body.bg-sand-25, body.bg-sand-25 .section-breadcrumb {
    background-color: var(--color-sand-25)
}

.banner-header {
    position: relative
}

    .banner-header .banner-header-top {
        border-radius: var(--border-radius-l);
        background: #fff;
        border: 8px solid #fff
    }

@media (min-width: 992px) {
    .banner-header .banner-header-top {
        min-height: 390px;
        height: 390px
    }
}

.banner-header .banner-header-top .title {
    width: 100%;
    padding: 12px;
    display: flex;
    flex-direction: column;
    margin-top: 21px;
    min-height: 376px;
    height: 376px
}

@media (min-width: 768px) {
    .banner-header .banner-header-top .title {
        padding: 27px 32px 34px
    }
}

@media (min-width: 992px) {
    .banner-header .banner-header-top .title {
        margin-top: 0;
        height: 100%
    }
}

@media (min-width: 992px) {
    .banner-header .banner-header-top .title .btn {
        margin-bottom: 0 !important
    }
}

.banner-header .banner-header-top .title .price-m {
    margin-top: 20px
}

.banner-header .banner-header-top .title .fully-booked-container {
    display: flex;
    align-items: center;
    flex-wrap: wrap
}

.banner-header .banner-header-top .title .fully-booked {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
    margin-right: 32px;
    flex-wrap: nowrap
}

    .banner-header .banner-header-top .title .fully-booked p {
        color: var(--Node-Red, #ff6033);
        font-size: 20px;
        font-style: normal;
        font-weight: 600;
        line-height: 28px;
        text-transform: uppercase;
        margin-bottom: 0;
        margin-left: 12px;
        white-space: nowrap;
        padding-top: 2px
    }

.banner-header .banner-header-top .title .type {
    color: var(--color-secondary);
    text-transform: uppercase;
    font-size: var(--paragraph-semibold-font-size);
    font-weight: var(--paragraph-semibold-font-weight);
    display: flex;
    align-items: center;
    width: fit-content;
    letter-spacing: 1.4px;
    margin-bottom: 5px
}

    .banner-header .banner-header-top .title .type span {
        margin-bottom: 0;
        display: block
    }

.banner-header .banner-header-top .title h3, .banner-header .banner-header-top .title .h3 {
    font-size: var(--hero-title-font-size);
    font-weight: var(--hero-title-font-weight);
    line-height: 1.12;
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    padding-bottom: 4px
}

@media (min-width: 768px) {
    .banner-header .banner-header-top .title h3, .banner-header .banner-header-top .title .h3 {
        -webkit-line-clamp: 2;
        min-height: fit-content
    }
}

.banner-header .banner-header-top .title p {
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: -9px
}

@media (min-width: 768px) {
    .banner-header .banner-header-top .title p {
        -webkit-line-clamp: 3
    }
}

.banner-header .banner-header-top .title .btn {
    margin-bottom: 12px
}

.banner-header .banner-header-top .bg-img {
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    border-radius: var(--border-radius-m)
}

@media (min-width: 992px) {
    .banner-header .banner-header-top .bg-img {
        border-radius: 0px var(--border-radius-m) var(--border-radius-m) 0px
    }
}

@media (max-width: 991px) {
    .banner-header .banner-header-top .ratio-banner-header {
        --bs-aspect-ratio: 53%
    }
}

@media (min-width: 992px) {
    .banner-header .banner-header-top .ratio-banner-header {
        height: 100%
    }
}

.banner-header .banner-header-bottom {
    border-radius: 0 0 12px 12px;
    background: #fff;
    background-color: var(--color-primary);
    flex-wrap: wrap;
    display: flex;
    padding-top: 16px
}

@media (min-width: 576px) {
    .banner-header .banner-header-bottom {
        padding-top: 20px
    }
}

@media (min-width: 1150px) {
    .banner-header .banner-header-bottom {
        padding-top: 28px;
        padding-bottom: 8px
    }
}

@media (min-width: 1150px) {
    .banner-header .banner-header-bottom {
        justify-content: start
    }
}

.banner-header .banner-header-bottom .element {
    padding-left: 16px;
    padding-right: 16px;
    width: 100%;
    margin-bottom: 14px;
    color: #fff;
    flex-wrap: nowrap
}

@media (min-width: 576px) {
    .banner-header .banner-header-bottom .element {
        width: 50%;
        min-width: 50%;
        margin-bottom: 24px
    }
}

@media (min-width: 768px) {
    .banner-header .banner-header-bottom .element {
        width: 33%;
        min-width: 33%
    }
}

@media (min-width: 992px) {
    .banner-header .banner-header-bottom .element {
        padding-left: 24px;
        padding-right: 24px;
        width: 25%;
        min-width: 25%
    }
}

@media (min-width: 1150px) {
    .banner-header .banner-header-bottom .element {
        margin-bottom: 20px;
        width: 20%;
        min-width: auto;
        flex-grow: 1
    }
}

@media (min-width: 1440px) {
    .banner-header .banner-header-bottom .element {
        margin-bottom: 20px
    }
}

@media (max-width: 575px) {
    .banner-header .banner-header-bottom .element:last-child {
        margin-bottom: 0
    }
}

@media (max-width: 575px) {
    .banner-header .banner-header-bottom .element:last-child .content {
        border-bottom: none
    }
}

.banner-header .banner-header-bottom .element:first-child {
    margin-top: 0
}

.banner-header .banner-header-bottom .element .content {
    border-bottom: 1px solid rgba(245,243,240,.2862745098);
    flex-wrap: wrap
}

@media (min-width: 576px) {
    .banner-header .banner-header-bottom .element .content {
        border-bottom: none
    }
}

.banner-header .banner-header-bottom .element .content .label {
    display: flex;
    align-items: center
}

.banner-header .banner-header-bottom .element .content .datas {
    margin-top: 6px;
    padding-bottom: 12px
}

@media (min-width: 576px) {
    .banner-header .banner-header-bottom .element .content .datas {
        padding-bottom: 0
    }
}

@media (min-width: 576px) {
    .banner-header .banner-header-bottom .element {
        border-left: 1px solid rgba(245,243,240,.2862745098);
        width: auto
    }

        .banner-header .banner-header-bottom .element:first-child {
            border-left: none
        }
}

@media (min-width: 1150px) {
    .banner-header .banner-header-bottom .element {
        padding-left: 24px;
        padding-right: 24px
    }
}

.banner-header .banner-header-bottom .element .ico-container {
    width: 24px;
    display: flex;
    align-items: start;
    justify-content: center;
    min-width: 24px;
    margin-right: 6px
}

.banner-header .banner-header-bottom .element p {
    margin-bottom: 0;
    padding-left: 4px;
    font-size: clamp(1rem,.425rem + .8vw,1.125rem);
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

.banner-header .banner-header-bottom .element span {
    font-size: clamp(1rem,.425rem + .8vw,1.125rem);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    display: block
}

.lecturers-card {
    border-radius: var(--border-radius-l);
    background: var(--color-sand-50);
    display: flex;
    flex-direction: column;
    width: 100%;
    flex-grow: 1
}

    .lecturers-card .more-info {
        margin-top: auto
    }

        .lecturers-card .more-info a, .lecturers-card .more-info a:hover {
            color: var(--color-primary);
            font-size: 14px;
            font-style: normal;
            font-weight: 500;
            line-height: normal;
            text-decoration: none
        }

            .lecturers-card .more-info a .bgr-arrow-blue, .lecturers-card .more-info a:hover .bgr-arrow-blue {
                width: 8px;
                height: 8px;
                margin-bottom: 2px;
                margin-left: 4px
            }

    .lecturers-card .ratio-3x2 {
        --bs-aspect-ratio: 66%
    }

    .lecturers-card .img-header {
        background-size: cover;
        background-position: center center;
        width: 100%;
        height: 100%;
        border-radius: var(--border-radius-l) var(--border-radius-l) 0px 0px
    }

    .lecturers-card .content {
        padding: 20px 16px 14px;
        flex-grow: 1;
        display: flex;
        flex-direction: column
    }

    .lecturers-card .name {
        font-size: 18px;
        font-style: normal;
        font-weight: 500;
        line-height: normal;
        overflow: hidden;
        text-overflow: ellipsis;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        margin-bottom: 6px
    }

        .lecturers-card .name p {
            margin-bottom: 0
        }

    .lecturers-card .profession {
        font-size: 14px;
        font-style: normal;
        font-weight: 300;
        line-height: normal;
        margin-bottom: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        min-height: 36px
    }

        .lecturers-card .profession p {
            margin-bottom: 0
        }

.community-card {
    display: flex;
    background-color: #fff;
    border-radius: var(--border-radius-l);
    width: 100%;
    position: relative
}

    .community-card .ratio {
        max-width: 40%
    }

    .community-card .img {
        border-radius: var(--border-radius-l) 0px 0px var(--border-radius-l);
        background-size: cover;
        background-position: center center;
        width: 100%;
        height: 100%;
        display: flex;
        justify-content: center;
        align-items: center
    }

    .community-card .content {
        padding: 12px 24px;
        width: 60%;
        display: flex;
        align-items: center
    }

    .community-card p {
        font-size: 18px;
        font-style: normal;
        font-weight: 500;
        margin-bottom: 6px;
        line-height: 1.2;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis
    }

    .community-card span {
        font-size: 14px;
        font-style: normal;
        font-weight: 300;
        line-height: 1.2;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
        margin-bottom: 6px
    }

    .community-card .ratio {
        transition-timing-function: cubic-bezier(.5,.05,1,.5);
        transition: height .2s;
        position: relative
    }

    .community-card:hover .ratio .img {
        transition: all .3s ease-out
    }

@media (min-width: 992px) {
    .community-card:hover .ratio .img {
        -webkit-filter: brightness(.7);
        filter: brightness(.7)
    }
}

@media (min-width: 992px) {
    .community-card:hover .btn.btn-gray {
        transition: all .3s ease-out;
        opacity: 1
    }
}

.community-card .btn.btn-gray {
    position: absolute;
    z-index: 666;
    opacity: 0;
    transition: all .3s ease-out;
    width: max-content;
    top: calc(50% - 24px);
    left: 50%;
    transform: translate(-50%);
    height: 47px
}

    .community-card .btn.btn-gray span {
        font-size: 18px;
        letter-spacing: 1.8px;
        font-weight: 400;
        color: var(--color-primary-text);
        text-transform: uppercase;
        padding-top: 4px;
        padding-left: 16px;
        padding-right: 16px
    }

    .community-card .btn.btn-gray i {
        right: 14px
    }

.community-card .courses-ended-container {
    flex-grow: 1
}

.country-container {
    display: flex;
    align-items: start;
    margin-bottom: 10px
}

    .country-container p {
        font-size: 14px;
        font-style: normal;
        font-weight: 300;
        margin-bottom: 0;
        padding-left: 8px;
        line-height: 1.3
    }

    .country-container img {
        padding-top: 2px;
        height: 18px
    }

.modal-content h3, .modal-content .h3 {
    margin-bottom: 12px
}

.modal-content .country-container {
    display: flex;
    align-items: start;
    margin-bottom: 4px
}

    .modal-content .country-container p {
        padding-left: 11px
    }

    .modal-content .country-container img {
        margin-top: 2px;
        height: 18px
    }

.ico-card-community {
    min-width: 20px;
    height: 20px;
    display: flex;
    margin-top: 12px;
    margin-right: 10px;
    z-index: 1
}

.ico-card-community-numbering {
    margin-right: 10px;
    min-width: 20px;
    height: 20px;
    background-color: var(--color-primary);
    border-radius: var(--border-radius-s);
    display: flex;
    justify-content: center;
    align-items: center
}

    .ico-card-community-numbering p {
        font-size: 12px;
        font-weight: 300;
        padding: 0 4px;
        color: #fffb;
        margin-bottom: 0;
        text-align: center;
        min-width: 20px
    }

.ico-container-ended {
    border-top: 1px solid var(--color-sand);
    margin-top: 4px;
    flex-wrap: wrap
}

.modal-body .ico-container-ended {
    border-top: none;
    margin-top: 0;
    flex-wrap: wrap;
    padding-left: 24px
}

@media (min-width: 768px) {
    .modal-body .ico-container-ended {
        padding-left: 0;
        padding-top: 12px
    }
}

.modal-body .ico-card-community {
    min-width: 20px;
    height: 20px;
    display: flex;
    margin-top: 0;
    margin-bottom: 12px;
    margin-right: 10px;
    z-index: 1
}

@media (min-width: 768px) {
    .modal-body .ico-card-community {
        min-width: 20px;
        height: 20px;
        display: flex;
        margin-top: 12px;
        margin-right: 10px;
        z-index: 1
    }
}

.form-element-1, .form-element-1:focus-visible {
    width: 100%;
    border: none;
    outline: none;
    border-radius: 6px;
    background: #fff;
    padding: 12px 20px 14px;
    max-height: 40px
}

    .form-element-1::placeholder, .form-element-1:focus-visible::placeholder {
        color: gray;
        font-weight: 300;
        font-size: 16px
    }

.placeholder {
    color: gray;
    font-weight: 300;
    font-size: 16px
}

.form-control-root {
    display: contents
}

.form-control:disabled {
    opacity: .5
}

.form-control, .form-control:focus {
    width: 100%;
    border: none;
    outline: none;
    border-radius: 6px;
    background: #fff;
    padding: 12px 20px 14px;
    max-height: 40px;
    box-shadow: none;
    color: var(--color-primary-text);
    font-weight: 400;
    font-size: 16px;
    border: 1px solid var(--color-border-light)
}

    .form-control::placeholder, .form-control:focus::placeholder {
        color: gray;
        font-weight: 300;
        font-size: 16px
    }

    .form-control.is-invalid, .form-control:focus.is-invalid {
        border: 1px solid var(--bs-form-invalid-border-color);
        background-image: none
    }

    .form-control, .form-control:focus {
        background: var(--bg-color-primary)
    }

.form-control-root.is-invalid .ss-main {
    border: 1px solid var(--bs-form-invalid-border-color)
}

.form-control-root.is-invalid .invalid-feedback {
    display: block
}

.bg-white .form-control, .bg-white .form-control:focus {
    background-color: var(--bg-color-teritary)
}

.form-control, .form-control:focus {
    height: 40px;
    padding: 12px;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    border-radius: var(--border-radius-m)
}

.form-control-root .form-control:focus {
    border: 1px solid var(--color-secondary)
}

.form-control-root a.form-label {
    color: var(--color-primary);
    text-align: end
}

.form-control-root .form-label {
    color: var(--color-primary-text);
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

    .form-control-root .form-label small, .form-control-root .form-label .small {
        color: var(--color-secondary-text);
        font-size: 14px;
        font-style: normal;
        font-weight: 400
    }

.invalid-feedback {
    color: var(--bs-form-invalid-color);
    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%
}

.text-area {
    background: var(--bg-color-teritary);
    width: 100%;
    border: 1px solid var(--color-border-light);
    outline: none;
    border-radius: 6px;
    padding: 12px 20px 14px;
    box-shadow: none;
    color: var(--color-primary-text);
    font-weight: 400;
    font-size: 16px;
    min-height: 142px
}

    .text-area::placeholder {
        color: gray;
        font-weight: 300;
        font-size: 16px
    }

    .text-area.is-invalid {
        border: 1px solid var(--bs-form-invalid-border-color)
    }

.form-control {
    background: var(--form-control-background, #fff)
}

.bg-white {
    --form-control-background: var(--bg-color-teritary)
}

.row-filers {
    width: -webkit-fill-available
}

@media (min-width: 1250px) {
    .col-xl-20proc {
        width: 20%
    }
}

.checkbox-filter-container {
    width: 100%
}

    .checkbox-filter-container .dropdown-menu {
        width: calc(200% + 28px);
        padding: 4px;
        box-shadow: 0 4px 10px #00000026;
        border-radius: var(--border-radius-s);
        top: -5px
    }

@media (min-width: 768px) {
    .checkbox-filter-container .dropdown-menu {
        width: 100%;
        max-width: 100%
    }
}

.checkbox-filter-container .dropdown-menu button, .checkbox-filter-container .dropdown-menu button:active {
    display: flex;
    width: 100%;
    height: 40px;
    padding: 12px 24px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
    border-radius: var(--border-radius-m);
    background: var(--color-sand);
    margin-top: 24px;
    text-transform: uppercase;
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    letter-spacing: 1.6px;
    border: none
}

.dropdown-toggle.checkbox-filter {
    width: 100%;
    border: none;
    outline: none;
    background: #fff;
    max-height: 40px;
    text-align: left;
    color: var(--color-primary-text);
    font-weight: 400;
    font-size: 16px;
    font-family: var(--font-family-primary);
    border: 1px solid var(--color-border-light);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    padding-right: 30px
}

    .dropdown-toggle.checkbox-filter.show:after {
        -webkit-transform: rotate(180deg);
        -moz-transform: rotate(180deg)
    }

    .dropdown-toggle.checkbox-filter:after {
        position: absolute;
        background-image: url(./images/ico-dropdown-menu.svg);
        background-repeat: no-repeat;
        background-position: center;
        content: "";
        width: 29px;
        height: 16px;
        right: 8px;
        border: 6px solid transparent;
        transition: all .2s ease-out;
        transform: translateY(-50%);
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        top: calc(50% - 8px);
        background-size: 12px
    }

    .dropdown-toggle.checkbox-filter.sort-by:after {
        background-image: none
    }

    .dropdown-toggle.checkbox-filter.sort-by i {
        margin-left: auto;
        padding-top: 2px;
        position: absolute;
        background-repeat: no-repeat;
        background-position: center;
        content: "";
        width: 29px;
        height: 16px;
        right: 8px
    }

    .dropdown-toggle.checkbox-filter:active {
        background-color: var(--bg-color-primary);
        border: 1px solid var(--color-border-light)
    }

    .dropdown-toggle.checkbox-filter.btn {
        align-items: start;
        justify-content: start;
        padding: 8px 30px 8px 12px
    }

    .dropdown-toggle.checkbox-filter:hover {
        outline: 1px solid var(--color-secondary);
        box-shadow: none
    }

    .dropdown-toggle.checkbox-filter.show {
        outline: 1px solid var(--color-secondary)
    }

.form-filter-element {
    margin-bottom: 16px;
    border-radius: var(--border-radius-m);
    min-height: 40px;
    max-height: 40px
}

    .form-filter-element:focus-visible, .form-filter-element:hover {
        box-shadow: none;
        outline: none
    }

.search-element {
    position: relative;
    margin-bottom: 16px;
    width: 100%
}

    .search-element input {
        border: 1px solid var(--color-border-light);
        border-radius: var(--border-radius-m);
        min-height: 40px;
        max-height: 40px;
        padding: 8px 40px 8px 12px;
        width: 100%
    }

        .search-element input:hover, .search-element input:focus-visible {
            outline: 1px solid var(--color-secondary)
        }

    .search-element button {
        border: none;
        position: absolute;
        top: 50%;
        right: 8px;
        background-color: transparent;
        transform: translateY(-50%)
    }

        .search-element button i {
            color: var(--color-primary-text);
            font-size: 16px
        }

.dropdown-menu .filter-options.modal-content-scrollable {
    max-height: 340px;
    padding-right: 0
}

.dropdown-menu .filter-options ul {
    list-style: none;
    padding-left: 0
}

.dropdown-menu .filter-options li {
    list-style: none;
    margin-bottom: 4px;
    cursor: pointer
}

    .dropdown-menu .filter-options li span {
        color: var(--color-primary-text);
        line-height: 1.5
    }

.form-check-input[type=checkbox], .form-check-input[type=radio] {
    border-color: #787878
}

.form-check-input[type=checkbox] {
    height: 16px;
    width: 16px;
    border: 1px solid #787878;
    margin-top: 10px;
    border-radius: 2px
}

.form-check-input:checked[type=radio] {
    border: 1px solid var(--color-primary)
}

.form-check-input:checked, form-check-input:focus {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    box-shadow: none !important
}

.form-check {
    padding-left: 28px;
    margin-bottom: 4px
}

    .form-check .form-check-input {
        margin-left: -28px
    }

    .form-check label {
        font-size: 16px;
        font-style: normal;
        font-weight: 400;
        line-height: 24px;
        padding-top: 6px
    }

    .form-check .form-check-input:focus {
        box-shadow: none
    }

.btn.filters-clear, .btn.filters-clear:active {
    color: var(--color-primary);
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: 20px;
    border: none;
    margin-bottom: 0;
    padding: 2px 12px
}

.applied-filters-col {
    margin-bottom: 24px
}

    .applied-filters-col .btn.badge {
        display: inline-flex;
        padding: 2px 12px;
        align-items: center;
        gap: 8px;
        border-radius: 20px;
        border: 1px solid #e2e2e2;
        background: #fff;
        color: var(--color-primary-text);
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 18px;
        font-family: var(--font-family-primary);
        margin-right: 10px;
        margin-bottom: 10px;
        min-height: 24px
    }

        .applied-filters-col .btn.badge .btn-close {
            height: 7px;
            width: 7px;
            --bs-btn-close-bg: url(./images/ico-close-small.svg)
        }

.footer1 input.form-control, .footer1 input.form-control:focus {
    border-radius: var(--border-radius-l)
}

.alert-danger {
    padding: 16px;
    margin-bottom: 0
}

    .alert-danger span, .alert-danger li {
        color: var(--bs-danger-text-emphasis);
        font-size: 12px;
        font-style: normal;
        font-weight: 400;
        line-height: 1.3
    }

    .alert-danger li {
        margin-bottom: 4px
    }

    .alert-danger .ico-alert-validation {
        width: 14px;
        height: 14px;
        display: flex;
        align-items: start;
        margin-top: 1px;
        margin-right: 12px
    }

    .alert-danger ul {
        padding-left: 42px;
        margin-bottom: 0
    }

.form-check-input[type=radio] {
    width: 16px;
    height: 16px;
    margin-top: 10px
}

.form-check-label {
    font-size: 16px
}

.form-check-input.is-invalid, .form-check-input.is-invalid .form-check-input[type=checkbox], .form-check-input.is-invalid .form-check-input[type=radio] {
    border: 1px solid var(--bs-form-invalid-border-color)
}

.footer1 .form-check {
    padding-left: 28px
}

    .footer1 .form-check .form-check-input {
        margin-left: -28px
    }

.alert-primary {
    border-radius: 6px;
    border: 1px solid #96b3fa;
    background: #ccdafd;
    color: #0245af;
    font-family: var(--font-family-primary);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    background-image: url(./images/ico-alert-blue.svg);
    background-repeat: no-repeat;
    background-position: top 17px left 16px;
    padding: 16px 16px 16px 40px
}

.filter-panel {
    display: flex;
    flex-wrap: wrap
}

@media (min-width: 768px) {
    .filter-panel a {
        margin-right: 24px
    }
}

.side-menu-filters {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    position: fixed;
    right: -100%;
    top: 0;
    background-color: var(--bg-color-primary);
    z-index: 19;
    transition: .3s ease-in-out
}

@media (min-width: 768px) {
    .side-menu-filters {
        width: 500px;
        right: -500px
    }
}

.side-menu-filters.active {
    right: 0
}

.side-menu-filters .filters {
    padding-left: 24px;
    padding-right: 24px;
    position: relative;
    overflow-y: auto;
    scrollbar-width: thin
}

@media (min-width: 768px) {
    .side-menu-filters .filters {
        padding-right: 32px;
        padding-left: 32px
    }
}

.side-menu-filters .heading {
    padding: 20px 24px 24px;
    position: sticky;
    top: 0;
    width: 100%;
    z-index: 4;
    background-color: #fff;
    box-shadow: 0 0 12px #00000014,0 0 4px #0000000a;
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid var(--color-border-light)
}

@media (min-width: 768px) {
    .side-menu-filters .heading {
        padding: 32px
    }
}

.side-menu-filters .heading h6, .side-menu-filters .heading .h6 {
    font-size: var(--subtitle-font-size);
    font-weight: var(--subtitle-font-weight);
    --subtitle-font-weight: 600;
    padding-right: 24px;
    margin-bottom: 0
}

.side-menu-filters .heading .close {
    height: 24px;
    width: 24px;
    margin-top: 6px
}

.side-menu-filters .heading a i {
    color: var(--color-primary-text);
    font-size: 20px
}

.side-menu-filters .footer {
    display: flex;
    justify-content: space-between;
    margin-top: auto;
    padding: 20px 24px;
    position: sticky;
    bottom: 0;
    background-color: #fff;
    box-shadow: 0 0 12px #00000014,0 0 4px #0000000a
}

@media (min-width: 768px) {
    .side-menu-filters .footer {
        padding: 32px
    }
}

.side-menu-filters .accordion {
    border-bottom: 1px solid var(--color-border-light)
}

    .side-menu-filters .accordion:last-child {
        border-bottom: none
    }

    .side-menu-filters .accordion .accordion-button:not(.collapsed) {
        color: var(--color-primary-text);
        background-color: var(--bg-color-primary);
        box-shadow: none
    }

    .side-menu-filters .accordion .accordion-button {
        font-size: var(--heading-font-size);
        font-weight: var(--heading-font-weight);
        padding-left: 0;
        padding-right: 0
    }

        .side-menu-filters .accordion .accordion-button:focus {
            box-shadow: none
        }

    .side-menu-filters .accordion .accordion-body {
        padding-left: 0;
        padding-right: 0;
        padding-top: 0
    }

    .side-menu-filters .accordion ul {
        list-style-type: none;
        padding-left: 0
    }

        .side-menu-filters .accordion ul li .form-check {
            margin-bottom: 6px
        }

    .side-menu-filters .accordion .accordion-body {
        padding-left: 16px
    }

body.side-menu-filters-show {
    overflow-y: hidden
}

    body.side-menu-filters-show:before {
        background-color: #0000004b;
        transition: all .3s ease-in-out;
        opacity: 1;
        width: 100%;
        top: 0
    }

@media (min-width: 1150px) {
    body.side-menu-filters-show:before {
        display: block
    }
}

@media (min-width: 768px) {
    .btn#side-menu-filters-open {
        min-width: 208px
    }
}

.custom.form-check.custom:has(input:checked) .check {
    display: block !important
}

.custom.form-check.custom:has(input:checked) span {
    padding-right: 0
}

.custom.form-check.custom:has(input:checked) label {
    background-color: var(--color-neutral-selected)
}

.form-check.custom {
    margin-bottom: 0;
    padding-left: 0;
    display: flex
}

    .form-check.custom .form-check-label {
        padding: 6px 8px 6px 10px;
        border-radius: var(--border-radius-s)
    }

        .form-check.custom .form-check-label:hover {
            background-color: var(--color-neutral-hover)
        }

    .form-check.custom label {
        display: flex;
        align-items: center;
        width: 100%;
        cursor: pointer
    }

    .form-check.custom .form-check-input {
        display: none
    }

        .form-check.custom .form-check-input:hover {
            background-color: red
        }

    .form-check.custom .check {
        margin-left: auto
    }

        .form-check.custom .check i {
            font-size: 16px;
            font-style: normal;
            font-weight: 400;
            color: var(--color-secondary-dark)
        }

    .form-check.custom span {
        padding-right: 24px
    }

@media (min-width: 1400px) {
    .col-xxl-20proc {
        width: calc(20% - 17px)
    }
}

.form-control-root .recaptcha-terms {
    color: var(--recaptcha-color, var(--color-secondary-text));
    font-size: var(--recaptcha-font-size, 12px);
    line-height: var(--recaptcha-line-height, 16px);
    margin: var(--recaptcha-margin, 0 0 5px 0)
}

body:not(.recaptcha-visible) .grecaptcha-badge {
    display: none !important
}

.pagination {
    padding-top: 40px;
    padding-bottom: 40px;
    display: flex;
    justify-content: center
}

    .pagination .page-link.has-icon i {
        font-size: 14px
    }

    .pagination .page-item {
        background-color: #fff;
        border-radius: var(--border-radius-m);
        margin-left: 4px;
        margin-right: 4px;
        padding: 0;
        font-size: 16px;
        font-weight: 500
    }

        .pagination .page-item a {
            color: var(--color-primary-text);
            font-weight: 500;
            font-size: 16px
        }

@media (max-width: 767px) {
    .pagination .page-item a {
        padding-left: 6px;
        padding-right: 6px
    }
}

@media (min-width: 992px) {
    .pagination .page-item {
        margin-left: 6px;
        margin-right: 6px;
        padding: 0 3px
    }
}

.pagination .page-item.nav {
    background-color: transparent
}

.pagination .page-item.disabled {
    opacity: 1
}

    .pagination .page-item.disabled .page-link {
        color: var(--color-primary-text)
    }

.pagination .page-item.active {
    background-color: var(--bg-color-primary);
    border-radius: var(--border-radius-m);
    border: 1px solid var(--color-primary)
}

    .pagination .page-item.active a {
        color: var(--color-primary)
    }

.pagination .page-item .page-link {
    font-size: 16px;
    font-weight: 500;
    display: flex;
    align-items: center
}

@media (min-width: 992px) {
    .pagination .page-item .page-link {
        font-size: 16px
    }
}

.pagination .page-item .page-link span {
    display: none
}

@media (min-width: 576px) {
    .pagination .page-item .page-link span {
        display: block
    }
}

@media (max-width: 767px) {
    .pagination .page-item.page-item-prev-n-2, .pagination .page-item.page-item-prev-n-1, .pagination .page-item.page-item-next-n-1, .pagination .page-item.page-item-next-n-2 {
        display: none
    }
}

.pagination .page-link, .pagination page-link:focus {
    border: none;
    background: transparent;
    color: var(--color-primary);
    box-shadow: none
}

    .pagination .page-link i, .pagination page-link:focus i {
        padding-top: 2px
    }

.pagination .page-item.disabled a {
    color: var(--color-primary-text)
}

.main-blue-card {
    min-height: 387px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background-color: var(--bs-primary);
    border-radius: var(--border-radius-l);
    color: #fff;
    width: 100%
}

    .main-blue-card .image-cover-container {
        position: relative
    }

    .main-blue-card .like {
        top: 12px;
        right: 12px;
        border-radius: 50px;
        background: #fff;
        width: 40px;
        height: 40px;
        background-image: url(./images/ico-heart.svg);
        background-size: 24px 24px;
        background-position: top 9px center;
        background-repeat: no-repeat;
        cursor: pointer;
        margin-left: auto
    }

@media (min-width: 992px) {
    .main-blue-card .like {
        top: 16px;
        right: 16px
    }
}

.main-blue-card .like.active {
    background-image: url(./images/ico-heart-active.svg)
}

.main-blue-card.slim-card .image-cover-container {
    --bs-aspect-ratio: 48%
}

    .main-blue-card.slim-card .image-cover-container a, .main-blue-card.slim-card .stretched-link {
        display: none
    }

.main-blue-card.slim-card .content {
    padding: 12px 20px;
    display: flex;
    flex-direction: column;
    flex-grow: 1
}

@media (min-width: 992px) {
    .main-blue-card.slim-card .content {
        padding: 16px 20px
    }
}

.main-blue-card.slim-card h3, .main-blue-card.slim-card .h3 {
    font-size: clamp(1.125rem,1.068rem + .2532vw,1.25rem);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    max-height: 4.2em;
    font-weight: 500;
    margin-bottom: 12px
}

.main-blue-card.slim-card p {
    font-size: 14px;
    font-style: normal;
    font-weight: 300;
    line-height: 22px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    font-family: var(--font-family-primary);
    margin-bottom: 0;
    opacity: .75
}

.main-blue-card.slim-card .footer {
    padding: 0 20px 20px
}

    .main-blue-card.slim-card .footer .footer-bar {
        background-color: var(--color-sand);
        color: #000;
        padding: 8px 24px;
        border-radius: var(--border-radius-m);
        text-transform: uppercase;
        font-family: var(--font-family-primary);
        font-size: 14px;
        font-weight: 500;
        height: 47px;
        display: flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        transition: .2s ease-in-out
    }

        .main-blue-card.slim-card .footer .footer-bar:hover {
            background-color: #f3f0e8
        }

    .main-blue-card.slim-card .footer i {
        font-weight: 300;
        margin-left: 12px;
        font-size: 18px;
        padding-bottom: 1px
    }

.main-blue-card.wide-card:hover .image-cover-container {
    transition: all .3s ease-out
}

@media (min-width: 992px) {
    .main-blue-card.wide-card:hover .image-cover-container picture {
        -webkit-filter: brightness(.7);
        filter: brightness(.7)
    }
}

@media (min-width: 992px) {
    .main-blue-card.wide-card:hover .btn.btn-gray {
        transition: all .3s ease-out;
        opacity: 1;
        width: max-content;
        top: calc(50% - 24px);
        left: 50%;
        transform: translate(-50%)
    }
}

.main-blue-card.wide-card .image-cover-container {
    --bs-aspect-ratio: 52%
}

.main-blue-card.wide-card .card-body {
    display: flex;
    flex-direction: column
}

    .main-blue-card.wide-card .card-body .image-cover-container {
        display: flex;
        align-items: center;
        justify-content: center
    }

        .main-blue-card.wide-card .card-body .image-cover-container picture, .main-blue-card.wide-card .card-body .image-cover-container img {
            width: 100%;
            height: 100%;
            object-fit: cover
        }

.main-blue-card.wide-card .content {
    padding: 12px 24px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    min-height: 164px
}

@media (min-width: 992px) {
    .main-blue-card.wide-card .content {
        padding: 20px 32px 10px;
        min-height: 176px
    }
}

.main-blue-card.wide-card .footer {
    padding: 0 10px 10px;
    margin-top: auto
}

    .main-blue-card.wide-card .footer .footer-bar {
        background-color: var(--color-sand);
        color: #000;
        padding: 8px 24px;
        border-radius: var(--border-radius-m);
        text-transform: uppercase;
        font-family: var(--font-family-primary);
        font-size: 14px;
        font-weight: 500;
        height: 47px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        text-decoration: none
    }

.main-blue-card.wide-card h3, .main-blue-card.wide-card .h3 {
    font-size: clamp(1.25rem,1.193rem + .2532vw,1.375rem);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    max-height: 4.2em;
    font-weight: 500;
    margin-bottom: 12px
}

.main-blue-card.wide-card p {
    font-size: 14px;
    font-style: normal;
    font-weight: 300;
    line-height: 22px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    font-family: var(--font-family-primary);
    margin-bottom: 10px;
    opacity: .75;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis
}

.main-blue-card .btn.btn-gray {
    position: absolute;
    z-index: 2;
    opacity: 0;
    transition: all .3s ease-out;
    width: max-content;
    top: calc(50% - 24px);
    left: 50%;
    transform: translate(-50%);
    height: 47px
}

.main-blue-card .table-course {
    margin-top: auto
}

    .main-blue-card .table-course .table-element {
        display: flex;
        border-bottom: 1px solid rgba(255,255,255,.3411764706);
        padding-top: 5px;
        padding-bottom: 8px
    }

        .main-blue-card .table-course .table-element:last-of-type {
            border: none
        }

        .main-blue-card .table-course .table-element .label {
            width: 120px;
            min-width: 120px
        }

        .main-blue-card .table-course .table-element .data p {
            font-family: var(--font-family-primary);
            font-size: 14px;
            font-style: normal;
            font-weight: 400;
            line-height: 21px;
            color: #fff;
            opacity: 1;
            text-transform: none;
            letter-spacing: normal;
            margin-bottom: 0;
            padding-bottom: 0
        }

        .main-blue-card .table-course .table-element .data .status {
            display: flex;
            align-items: center
        }

            .main-blue-card .table-course .table-element .data .status .dot {
                border-radius: var(--border-radius-l);
                width: 13px;
                height: 13px;
                border: 2px solid #fff;
                margin-right: 8px
            }

                .main-blue-card .table-course .table-element .data .status .dot.dot-not-started {
                    background-color: #b6b6b6
                }

                .main-blue-card .table-course .table-element .data .status .dot.dot-in-progress {
                    background-color: #ff9d00
                }

                .main-blue-card .table-course .table-element .data .status .dot.dot-completed {
                    background-color: #67cd00
                }

        .main-blue-card .table-course .table-element.certificates {
            margin-top: 8px
        }

            .main-blue-card .table-course .table-element.certificates:last-of-type {
                border-top: 1px solid rgba(255,255,255,.3411764706);
                border-bottom: none
            }

@media (max-width: 767px) {
    .universal-modal .ratio {
        max-width: 120px
    }
}

.universal-modal .btn-close {
    background-size: 16px;
    border: none;
    background-color: #fff;
    padding: 6px;
    height: 24px;
    width: 24px;
    opacity: 1
}

    .universal-modal .btn-close i {
        color: #000;
        text-align: center;
        font-size: 24px;
        font-style: normal;
        font-weight: 300;
        line-height: normal;
        opacity: 1
    }

.universal-modal .modal-header {
    border: none;
    padding: 0;
    height: 36px
}

.universal-modal .img-header-modal {
    background-size: cover;
    background-position: center center;
    border-radius: var(--border-radius-l);
    width: 284px
}

.universal-modal.modal-dialog {
    max-width: 912px;
    margin-left: 15px;
    margin-right: 15px
}

@media (min-width: 942px) {
    .universal-modal.modal-dialog {
        margin-left: auto;
        margin-right: auto
    }
}

.universal-modal .modal-body {
    padding: 7px 14px 32px 32px
}

    .universal-modal .modal-body .heading {
        padding-bottom: 18px
    }

        .universal-modal .modal-body .heading h3, .universal-modal .modal-body .heading .h3 {
            font-size: clamp(1.5rem,1.3576rem + .6329vw,1.75rem);
            font-style: normal;
            font-weight: 500;
            line-height: 1.3;
            margin-bottom: 8px;
            margin-top: 24px
        }

@media (min-width: 768px) {
    .universal-modal .modal-body .heading h3, .universal-modal .modal-body .heading .h3 {
        margin-top: 0
    }
}

.universal-modal .modal-body h4, .universal-modal .modal-body .h4 {
    font-size: 20px;
    font-style: normal;
    font-weight: 500;
    line-height: 28px;
    margin-bottom: 24px;
    margin-top: 24px
}

.universal-modal .modal-body .link-container {
    margin-bottom: 6px;
    display: flex;
    align-items: center
}

    .universal-modal .modal-body .link-container .ico-container {
        width: 18px;
        min-width: 18px;
        margin-right: 8px;
        display: flex;
        justify-content: center
    }

        .universal-modal .modal-body .link-container .ico-container img {
            height: 16px
        }

    .universal-modal .modal-body .link-container a, .universal-modal .modal-body .link-container a:hover {
        font-size: 16px;
        font-style: normal;
        font-weight: 300;
        line-height: 24px;
        display: block;
        color: var(--color-primary);
        cursor: pointer;
        text-decoration: none
    }

.universal-modal .modal-body p {
    font-family: var(--font-family-primary);
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: 24px;
    margin-bottom: 0
}

.universal-modal .modal-body ul {
    padding-left: 24px
}

    .universal-modal .modal-body ul li {
        margin-bottom: 12px
    }

    .universal-modal .modal-body ul a, .universal-modal .modal-body ul a:hover {
        color: #000;
        font-size: 16px;
        font-style: normal;
        font-weight: 300;
        line-height: normal;
        text-decoration: underline
    }

.universal-modal .ico-datas {
    margin-bottom: 24px
}

.universal-modal .modal-content-scrollable {
    overflow-y: auto;
    max-height: 56vh;
    padding-right: 24px
}

@media (min-width: 768px) {
    .universal-modal .modal-content-scrollable {
        max-height: 58vh
    }
}

.universal-modal .courses-ended {
    margin-top: 0;
    padding-left: 12px;
    display: flex;
    flex-wrap: wrap
}

@media (min-width: 768px) {
    .universal-modal .courses-ended {
        margin-top: 12px;
        padding-left: 0
    }
}

.simple-modal .modal-dialog {
    display: flex;
    justify-content: center
}

.simple-modal .modal-content {
    max-width: 678px
}

.simple-modal .modal-body {
    padding: 0 14px 32px 32px
}

@media (min-width: 768px) {
    .simple-modal .modal-body {
        padding: 5px 14px 40px 48px
    }
}

.simple-modal .modal-content-scrollable {
    padding-right: 34px
}

.simple-modal .footer {
    display: flex;
    margin-right: 19px;
    flex-wrap: wrap
}

@media (min-width: 768px) {
    .simple-modal .footer {
        margin-right: 35px
    }
}

@media (max-width: 575px) {
    .simple-modal .footer .btn {
        width: 100%
    }
}

.simple-modal .footer.one-button {
    justify-content: center
}

.simple-modal .footer.two-buttons {
    justify-content: end
}

.simple-modal .universal-modal .modal-body .heading {
    padding-bottom: 4px
}

    .simple-modal .universal-modal .modal-body .heading h3, .simple-modal .universal-modal .modal-body .heading .h3 {
        font-size: 20px;
        margin-top: 0;
        margin-bottom: 0;
        padding-bottom: 0
    }

.course-modal .img-container {
    width: 180px;
    min-width: 180px;
    height: 180px
}

@media (min-width: 768px) {
    .course-modal .img-container {
        margin-right: 32px
    }
}

.course-modal .universal-modal .modal-body .heading {
    padding-bottom: 0
}

    .course-modal .universal-modal .modal-body .heading h3, .course-modal .universal-modal .modal-body .heading .h3 {
        margin-top: 16px;
        margin-bottom: 16px
    }

@media (min-width: 768px) {
    .course-modal .universal-modal .modal-body .heading h3, .course-modal .universal-modal .modal-body .heading .h3 {
        margin-top: 0
    }
}

.course-modal .ico-element {
    display: flex;
    margin-bottom: 16px
}

    .course-modal .ico-element p {
        color: var(--color-secondary-text);
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 20px;
        margin-bottom: 0;
        margin-right: 8px
    }

    .course-modal .ico-element span {
        color: var(--color-primary-text);
        font-size: 14px;
        font-style: normal;
        font-weight: 500;
        line-height: 20px;
        margin-bottom: 0
    }

    .course-modal .ico-element img {
        width: 20px;
        min-width: 20px;
        margin-right: 16px
    }

.course-modal .modal-item {
    padding-top: 26px;
    margin-top: 26px;
    border-top: 1px solid #e2e2e2
}

    .course-modal .modal-item:first-child {
        padding-top: 0;
        margin-top: 0;
        border-top: none
    }

.simplebar-scrollbar:before {
    background-color: var(--color-border-dark);
    right: 0
}

.purchase-using-subscription-plan-modal .modal-dialog, .pay-what-modal .modal-dialog {
    display: flex;
    justify-content: center
}

.purchase-using-subscription-plan-modal .modal-content, .pay-what-modal .modal-content {
    max-width: 519px;
    border-radius: var(--border-radius-l)
}

.purchase-using-subscription-plan-modal .modal-body, .pay-what-modal .modal-body {
    border-radius: var(--border-radius-l);
    padding: 0 32px 32px
}

@media (min-width: 768px) {
    .purchase-using-subscription-plan-modal .modal-body, .pay-what-modal .modal-body {
        padding: 5px 48px 40px
    }
}

.purchase-using-subscription-plan-modal .modal-content-scrollable, .pay-what-modal .modal-content-scrollable {
    padding-right: 34px
}

.purchase-using-subscription-plan-modal .btn, .pay-what-modal .btn {
    width: 100%
}

.purchase-using-subscription-plan-modal .universal-modal .modal-body .heading, .pay-what-modal .universal-modal .modal-body .heading {
    padding-bottom: 4px
}

    .purchase-using-subscription-plan-modal .universal-modal .modal-body .heading h3, .purchase-using-subscription-plan-modal .universal-modal .modal-body .heading .h3, .pay-what-modal .universal-modal .modal-body .heading h3, .pay-what-modal .universal-modal .modal-body .heading .h3 {
        font-size: 20px;
        margin-top: 0;
        margin-bottom: 0;
        padding-bottom: 0
    }

.modal-content-scrollable, .session-schedule-modal .modal-content-scrollable {
    overflow-x: hidden
}

@media (min-width: 942px) {
    .session-schedule-modal .modal-dialog {
        max-width: 738px
    }
}

.session-schedule-modal .ico-session {
    position: absolute;
    left: -36px;
    width: 20px;
    height: 20px;
    min-width: 20px;
    top: -7px
}

.session-schedule-modal .modal-body {
    padding: 24px 14px 24px 24px
}

@media (min-width: 768px) {
    .session-schedule-modal .modal-body {
        padding: 24px 14px 24px 40px
    }
}

.session-schedule-modal .modal-body .heading {
    position: relative;
    padding-right: 40px
}

    .session-schedule-modal .modal-body .heading .btn-close {
        position: absolute;
        top: 0;
        right: 0
    }

.session-schedule-modal .simplebar-content-wrapper {
    padding-left: 36px
}

@media (min-width: 768px) {
    .session-schedule-modal .simplebar-content-wrapper {
        padding-left: 36px
    }
}

.session-schedule-modal .simplebar-content-wrapper .modal-item {
    padding-top: 12px;
    margin-top: 7px;
    border-top: 1px solid #e2e2e2;
    position: relative
}

    .session-schedule-modal .simplebar-content-wrapper .modal-item .heading-secondary .ico-session {
        position: absolute;
        background-size: 20px 20px;
        left: -36px;
        top: -4px
    }

@media (min-width: 768px) {
    .session-schedule-modal .simplebar-content-wrapper .modal-item .heading-secondary .ico-session {
        left: -36px;
        top: -8px
    }
}

.session-schedule-modal .simplebar-content-wrapper .modal-item .heading-secondary .ico-session svg {
    background-color: var(--bg-color-primary)
}

    .session-schedule-modal .simplebar-content-wrapper .modal-item .heading-secondary .ico-session svg path, .session-schedule-modal .simplebar-content-wrapper .modal-item .heading-secondary .ico-session svg polygon {
        fill: var(--color-primary)
    }

.session-schedule-modal .simplebar-content-wrapper .modal-item.finished .ico-finished {
    display: block
}

.session-schedule-modal .simplebar-content-wrapper .modal-item.finished .ico-present, .session-schedule-modal .simplebar-content-wrapper .modal-item.finished .ico-future, .session-schedule-modal .simplebar-content-wrapper .modal-item.present .ico-finished {
    display: none
}

.session-schedule-modal .simplebar-content-wrapper .modal-item.present .ico-present {
    display: block
}

.session-schedule-modal .simplebar-content-wrapper .modal-item.present .ico-future, .session-schedule-modal .simplebar-content-wrapper .modal-item.future .ico-finished, .session-schedule-modal .simplebar-content-wrapper .modal-item.future .ico-present {
    display: none
}

.session-schedule-modal .simplebar-content-wrapper .modal-item.future .ico-future {
    display: block
}

.session-schedule-modal .simplebar-content-wrapper .modal-item:first-child {
    padding-top: 0;
    margin-top: 0;
    border-top: none
}

.session-schedule-modal .simplebar-content-wrapper .modal-item:not(:first-child) :after {
    position: absolute;
    width: 2px;
    height: calc(100% + 0px);
    background-color: var(--color-primary);
    z-index: -1;
    bottom: 85%;
    content: "";
    left: -27px
}

@media (min-width: 768px) {
    .session-schedule-modal .simplebar-content-wrapper .modal-item:not(:first-child) :after {
        left: -27px
    }
}

.session-schedule-modal .universal-modal .modal-body .heading {
    padding-bottom: 0
}

    .session-schedule-modal .universal-modal .modal-body .heading h3, .session-schedule-modal .universal-modal .modal-body .heading .h3 {
        margin-top: 0;
        margin-bottom: 16px;
        font-weight: 700
    }

@media (min-width: 768px) {
    .session-schedule-modal .universal-modal .modal-body .heading h3, .session-schedule-modal .universal-modal .modal-body .heading .h3 {
        margin-bottom: 24px
    }
}

.session-schedule-modal .heading-secondary {
    position: relative
}

    .session-schedule-modal .heading-secondary p {
        font-size: 18px;
        font-style: normal;
        font-weight: 600;
        margin-bottom: 10px;
        line-height: 24px
    }

@media (min-width: 768px) {
    .session-schedule-modal .ico-element-container {
        display: flex
    }
}

.session-schedule-modal .ico-element-container .no-ico-element {
    margin-bottom: 6px
}

    .session-schedule-modal .ico-element-container .no-ico-element p {
        color: var(--color-secondary-text);
        font-size: 12px;
        font-style: normal;
        font-weight: 400;
        line-height: 20px;
        margin-bottom: 0;
        margin-right: 8px
    }

    .session-schedule-modal .ico-element-container .no-ico-element span {
        color: var(--color-primary-text);
        font-size: 12px;
        font-style: normal;
        font-weight: 400;
        line-height: 20px;
        margin-bottom: 0
    }

.session-schedule-modal .ico-element-container .ico-element {
    display: flex;
    margin-bottom: 4px
}

@media (min-width: 768px) {
    .session-schedule-modal .ico-element-container .ico-element {
        margin-left: 40px
    }

        .session-schedule-modal .ico-element-container .ico-element:first-child {
            margin-left: 0
        }
}

.session-schedule-modal .ico-element-container .ico-element p {
    color: var(--color-secondary-text);
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
    margin-bottom: 0;
    margin-right: 8px
}

.session-schedule-modal .ico-element-container .ico-element span {
    color: var(--color-primary-text);
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
    margin-bottom: 0
}

.session-schedule-modal .ico-element-container .ico-element img {
    width: 20px;
    min-width: 20px;
    margin-right: 10px;
    height: 20px
}

.session-schedule-modal .ico-element-container .ico-element i {
    color: var(--color-secondary-text);
    font-size: 16px;
    font-weight: 300;
    margin-right: 6px;
    margin-top: 1px
}

.modal-content {
    border: none
}

.modal-backdrop {
    background-color: #00000063
}

.universal-modal .modal-body {
    padding: 24px 14px 24px 24px
}

@media (min-width: 768px) {
    .universal-modal .modal-body {
        padding: 24px 14px 24px 40px
    }
}

.universal-modal .modal-body .heading {
    position: relative;
    padding-right: 40px
}

    .universal-modal .modal-body .heading .btn-close {
        position: absolute;
        top: 0;
        right: 0
    }

.accordion-mid-arrow .accordion-button.collapsed {
    border-radius: var(--border-radius-l)
}

.accordion-mid-arrow .accordion-button:focus {
    box-shadow: none
}

.accordion-mid-arrow .accordion-button:not(.collapsed) {
    color: var(--color-primary-text);
    background-color: var(--bg-color-primary);
    box-shadow: none
}

.accordion-mid-arrow .accordion-button {
    font-size: clamp(1.75rem,1.5222rem + 1.0127vw,2.25rem);
    font-style: normal;
    font-weight: 500;
    line-height: 1.4
}

.accordion-mid-arrow .accordion-item {
    margin-bottom: 28px;
    border: none;
    border-radius: var(--border-radius-l)
}

.accordion-mid-arrow .accordion-button {
    border-radius: var(--border-radius-l);
    padding: 20px
}

@media (min-width: 768px) {
    .accordion-mid-arrow .accordion-button {
        padding: 25px 32px
    }
}

.accordion-mid-arrow .accordion-item .accordion-button {
    border-radius: var(--border-radius-l)
}

.accordion-mid-arrow .accordion-body {
    padding: 0 20px 20px
}

@media (min-width: 768px) {
    .accordion-mid-arrow .accordion-body {
        padding: 0 32px 25px
    }
}

.accordion-mid-arrow .accordion-button:after {
    content: "";
    background-image: url(./images/ico-arrow-mid-down.svg);
    background-repeat: no-repeat;
    background-size: 16px auto;
    background-position: center center;
    position: relative;
    height: 32px
}

@media (min-width: 768px) {
    .accordion-mid-arrow .accordion-button:after {
        background-size: 19px auto
    }
}

.accordion-mid-arrow.accordion-certificates .accordion-body {
    padding-bottom: 40px
}

.accordion-mid-arrow.accordion-certificates .accordion-button:after {
    right: 32px;
    margin-left: 16px;
    position: absolute;
    top: 22px
}

@media (min-width: 768px) {
    .accordion-mid-arrow.accordion-certificates .accordion-button:after {
        top: 28px
    }
}

@media (min-width: 1150px) {
    .accordion-mid-arrow.accordion-certificates .col-right {
        padding-left: 48px
    }
}

.accordion-mid-arrow.accordion-certificates .accordion-button {
    padding-right: 78px;
    font-size: clamp(1.25rem,1.0081rem + 1.0323vw,1.75rem);
    border-radius: var(--border-radius-l);
    display: block
}

@media (min-width: 768px) {
    .accordion-mid-arrow.accordion-certificates .accordion-button {
        display: flex
    }
}

.accordion-mid-arrow.accordion-certificates .accordion-item:first-of-type > .accordion-header .accordion-button {
    border-top-left-radius: 12px;
    border-top-right-radius: 12px
}

.accordion-mid-arrow.accordion-certificates .accordion-item:last-of-type > .accordion-header .accordion-button.collapsed {
    border-bottom-right-radius: 12px;
    border-bottom-left-radius: 12px
}

.accordion-mid-arrow.accordion-certificates .progress-completed {
    margin-left: auto;
    margin-top: 8px;
    height: 24px;
    display: flex;
    align-items: center
}

@media (min-width: 768px) {
    .accordion-mid-arrow.accordion-certificates .progress-completed {
        padding-right: 24px;
        margin-top: 0;
        border-right: 1px solid #e2e2e2
    }
}

.accordion-mid-arrow.accordion-certificates .progress-completed p {
    color: var(--color-primary-text);
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    font-family: var(--font-family-primary);
    margin-bottom: -2px
}

    .accordion-mid-arrow.accordion-certificates .progress-completed p span {
        color: #707070;
        text-transform: uppercase;
        margin-left: 5px;
        margin-right: 5px;
        font-weight: 400
    }

.accordion-mid-arrow.accordion-certificates .small-badge-container {
    display: flex;
    flex-wrap: wrap
}

    .accordion-mid-arrow.accordion-certificates .small-badge-container img {
        margin-right: 14px;
        margin-bottom: 16px;
        width: 47px;
        max-width: 47px
    }

@media (min-width: 768px) {
    .accordion-mid-arrow.accordion-certificates .small-badge-container img {
        width: 52px;
        max-width: 52px;
        margin-right: 22px
    }
}

.accordion-mid-arrow.accordion-certificates .small-badge-container img.not-finished {
    filter: grayscale(1);
    opacity: .2
}

.accordion-mid-arrow.accordion-certificates .main-badge-container {
    margin-top: 20px;
    margin-bottom: 20px;
    display: flex;
    align-items: center
}

    .accordion-mid-arrow.accordion-certificates .main-badge-container img {
        width: 130px;
        max-width: 130px;
        margin-right: 32px
    }

    .accordion-mid-arrow.accordion-certificates .main-badge-container p {
        font-size: 12px;
        font-style: normal;
        font-weight: 300;
        margin-bottom: 0;
        line-height: 1.7
    }

    .accordion-mid-arrow.accordion-certificates .main-badge-container a {
        font-size: 12px;
        font-weight: 300;
        line-height: 1.7;
        text-decoration-line: underline;
        color: var(--color-primary-text);
        display: block
    }

.accordion-mid-arrow.accordion-certificates label {
    font-family: var(--font-family-primary);
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 18px;
    color: #707070;
    text-transform: uppercase;
    letter-spacing: 1.2px
}

.accordion-mid-arrow.accordion-certificates .not-finished img, img.table-2-badge-not-finished {
    filter: grayscale(1);
    opacity: .2
}

.accordion-faq-heading {
    font-size: clamp(2rem,1.7722rem + 1.0127vw,2.5rem);
    font-style: normal;
    font-weight: 400;
    line-height: 48px;
    font-family: var(--font-family-primary);
    margin-bottom: 20px
}

.accordion-faq {
    border-bottom: 1px solid #e2e2e2
}

    .accordion-faq .accordion-button:focus {
        box-shadow: none
    }

    .accordion-faq .accordion-button:not(.collapsed) {
        color: var(--color-primary-text);
        background-color: var(--bg-color-primary);
        box-shadow: none
    }

    .accordion-faq .accordion-button {
        font-size: clamp(1.75rem,1.5222rem + 1.0127vw,2.25rem);
        font-style: normal;
        font-weight: 500;
        line-height: 1.4
    }

    .accordion-faq .accordion-item {
        border: none;
        border-radius: none
    }

        .accordion-faq .accordion-item:first-of-type > .accordion-header .accordion-button {
            border-radius: 0
        }

        .accordion-faq .accordion-item:first-of-type {
            border-radius: 0
        }

    .accordion-faq .accordion-button {
        padding: 28px 0;
        font-size: 20px;
        font-style: normal;
        font-weight: 500;
        line-height: 28px;
        border-top: 1px solid #e2e2e2
    }

    .accordion-faq .accordion-body {
        padding-left: 0;
        padding-right: 0;
        padding-bottom: 20px
    }

        .accordion-faq .accordion-body p {
            font-size: 16px;
            font-style: normal;
            font-weight: 300;
            line-height: 24px
        }

        .accordion-faq .accordion-body a {
            font-size: 16px;
            font-style: normal;
            font-weight: 300;
            line-height: 24px;
            color: var(--color-primary);
            text-decoration: underline
        }

    .accordion-faq .accordion-button:after {
        content: "";
        background-image: url(./images/ico-arrow-down-blue.svg);
        background-repeat: no-repeat;
        background-size: 16px auto;
        background-position: center center;
        position: relative;
        height: 32px;
        padding-left: 16px
    }

@media (min-width: 768px) {
    .accordion-faq .accordion-button:after {
        background-size: 19px auto
    }
}

.timeline-blue-container {
    margin-top: 40px;
    margin-bottom: 40px;
    display: flex;
    align-items: start;
    justify-content: space-between
}

    .timeline-blue-container .timeline-element-container {
        display: flex;
        align-items: center;
        padding-bottom: 40px;
        padding-top: 40px;
        position: relative
    }

        .timeline-blue-container .timeline-element-container:first-child:after {
            height: 50%;
            bottom: 0
        }

@media (min-width: 768px) {
    .timeline-blue-container .timeline-element-container:first-child:after {
        height: 5px;
        width: 50%;
        left: 50%
    }
}

.timeline-blue-container .timeline-element-container:last-child:after {
    height: 50%;
    top: 0
}

@media (min-width: 768px) {
    .timeline-blue-container .timeline-element-container:last-child:after {
        height: 5px;
        width: 50%;
        left: 0;
        top: 53px
    }
}

@media (min-width: 992px) {
    .timeline-blue-container .timeline-element-container:last-child:after {
        top: 60px
    }
}

.timeline-blue-container .timeline-element-container:after {
    content: "";
    position: absolute;
    left: 28px;
    width: 5px;
    height: 100%;
    background-color: var(--color-primary)
}

@media (min-width: 768px) {
    .timeline-blue-container .timeline-element-container:after {
        left: 0;
        width: 100%;
        height: 5px;
        top: 53px
    }
}

@media (min-width: 992px) {
    .timeline-blue-container .timeline-element-container:after {
        top: 60px
    }
}

@media (min-width: 768px) {
    .timeline-blue-container .timeline-element-container {
        display: flex;
        flex-direction: column;
        align-items: center
    }
}

.timeline-blue-container .timeline-element-container p {
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: 28px;
    text-align: start;
    margin-bottom: 0
}

@media (min-width: 768px) {
    .timeline-blue-container .timeline-element-container p {
        text-align: center
    }
}

@media (min-width: 1150px) {
    .timeline-blue-container .timeline-element-container p {
        padding-left: 20px;
        padding-right: 20px
    }
}

.timeline-blue-container .timeline-element-container .timeline-element {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: var(--border-radius-m);
    background: var(--color-primary);
    margin-right: 26px
}

@media (min-width: 768px) {
    .timeline-blue-container .timeline-element-container .timeline-element {
        margin-bottom: 36px;
        margin-right: 0
    }
}

@media (min-width: 992px) {
    .timeline-blue-container .timeline-element-container .timeline-element {
        width: 47px;
        min-width: 47px;
        height: 47px;
        border-radius: var(--border-radius-l)
    }
}

.content-wysiwyg h3, .content-wysiwyg .h3, .cms-content h3, .cms-content .h3 {
    font-size: 28px;
    font-style: normal;
    font-weight: 500;
    line-height: 38px
}

.content-wysiwyg h4, .content-wysiwyg .h4, .cms-content h4, .cms-content .h4 {
    font-size: 20px;
    font-style: normal;
    font-weight: 500;
    line-height: 28px;
    padding-top: 20px;
    padding-bottom: 20px
}

.content-wysiwyg h5, .content-wysiwyg .h5, .cms-content h5, .cms-content .h5 {
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 24px
}

.content-wysiwyg p, .cms-content p {
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: 24px
}

.content-wysiwyg a, .cms-content a {
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: 24px;
    text-decoration: underline;
    word-break: break-all
}

.content-wysiwyg ul, .cms-content ul {
    padding-left: 20px
}

.content-wysiwyg li, .cms-content li {
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: 24px;
    margin-bottom: 10px
}

    .content-wysiwyg li a, .cms-content li a {
        font-size: 16px;
        font-style: normal;
        font-weight: 300;
        line-height: 24px;
        text-decoration: underline;
        word-break: break-all
    }

.content-wysiwyg h1, .content-wysiwyg .h1 {
    letter-spacing: normal
}

.cms-content h3, .cms-content .h3 {
    margin-top: 26px;
    margin-bottom: 20px;
    border-top: 1px solid #e2e2e2;
    padding-top: 20px
}

    .cms-content h3:first-child, .cms-content .h3:first-child {
        margin-top: 0;
        border-top: none;
        padding-top: 0
    }

table.table th {
    font-family: var(--font-family-primary);
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 14px;
    padding: 17px 24px 16px;
    background-color: var(--bg-color-secondary)
}

    table.table th:first-child {
        border-top-left-radius: 8px
    }

    table.table th:last-child {
        border-top-right-radius: 8px
    }

@media (max-width: 1149px) {
    table.table th {
        max-width: 120px;
        max-width: 180px;
        padding: 8px 24px 8px 0;
        background-color: transparent;
        border: none
    }
}

@media (max-width: 1149px) {
    table.table tbody {
        border-bottom: 1px solid var(--color-border-light)
    }

        table.table tbody:first-child {
            border-top: 1px solid var(--color-border-light)
        }
}

table.table tbody td {
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    padding: 20px 24px
}

@media (max-width: 1149px) {
    table.table tbody td {
        padding: 8px 24px 8px 0;
        border: none
    }
}

@media (max-width: 1149px) {
    table.table tr:last-child th, table.table tr:last-child td {
        padding-bottom: 24px
    }

    table.table tr:first-child th, table.table tr:first-child td {
        padding-top: 24px
    }
}

table.table2 {
    width: 100%
}

    table.table2 th {
        font-family: var(--font-family-primary);
        font-size: 12px;
        font-style: normal;
        font-weight: 500;
        line-height: 18px;
        color: #707070;
        text-transform: uppercase;
        padding: 11px 12px 8px 0;
        text-wrap: nowrap;
        letter-spacing: 1.2px;
        border-bottom: 1px solid #e2e2e2
    }

@media (max-width: 1149px) {
    table.table2 th {
        max-width: 120px;
        max-width: 180px;
        padding: 8px 24px 8px 0;
        background-color: transparent;
        border: none
    }
}

table.table2 tbody td {
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
    padding: 20px 16px 20px 0
}

@media (max-width: 1149px) {
    table.table2 tbody td {
        padding: 8px 24px 8px 0;
        border: none
    }
}

table.table2 tbody td span {
    font-size: 16px;
    font-weight: 300
}

@media (min-width: 1150px) {
    table.table2 tbody tr {
        border-bottom: 1px solid #e2e2e2
    }
}

.table2-mobile {
    padding-top: 12px;
    padding-bottom: 16px;
    display: flex;
    border-bottom: 1px solid #e2e2e2
}

    .table2-mobile:first-child {
        border-top: 1px solid #e2e2e2;
        margin-top: 16px
    }

    .table2-mobile label {
        font-family: var(--font-family-primary);
        font-size: 12px;
        font-style: normal;
        font-weight: 500;
        line-height: 18px;
        color: #707070
    }

    .table2-mobile p {
        font-size: 16px;
        font-style: normal;
        font-weight: 500;
        line-height: 24px;
        margin-bottom: 8px
    }

    .table2-mobile span {
        font-size: 16px;
        font-style: normal;
        font-weight: 300;
        line-height: 24px
    }

    .table2-mobile .col-small {
        margin-right: 17px
    }

        .table2-mobile .col-small label {
            margin-bottom: 14px;
            letter-spacing: 1.2px
        }

    .table2-mobile .col-big {
        margin-right: 17px
    }

        .table2-mobile .col-big label {
            margin-bottom: 4px;
            letter-spacing: 1.2px
        }

.course-player-container:has(.course-player) .loader {
    display: none
}

.course-heading {
    border-radius: var(--border-radius-l);
    background: #fff;
    position: relative;
    border-bottom: 1px solid var(--color-border-light)
}

@media (min-width: 992px) {
    .course-heading {
        display: flex;
        align-items: center;
        min-height: 100px;
        height: 100%
    }
}

.course-heading h3, .course-heading .h3 {
    padding: 20px;
    margin-bottom: 0;
    font-size: var(--heading-font-size);
    font-weight: var(--heading-font-weight)
}

@media (min-width: 992px) {
    .course-heading h3, .course-heading .h3 {
        padding: 24px 24px 24px 40px
    }
}

.course-heading .photo {
    width: 144px;
    min-width: 144px;
    height: 100%
}

    .course-heading .photo .img {
        border-radius: var(--border-radius-l) 0px 0px var(--border-radius-l);
        background-size: cover;
        background-position: center center;
        width: 100%;
        height: 100%;
        display: flex;
        justify-content: center;
        align-items: center;
        border: 2px solid var(--bg-color-primary)
    }

.course-heading .leading {
    min-width: 220px;
    border-top: 1px solid var(--color-border-light);
    padding: 20px 0;
    margin-left: 20px;
    margin-right: 20px
}

@media (min-width: 992px) {
    .course-heading .leading {
        border-left: 1px solid var(--color-border-light);
        border-top: none;
        padding: 12px 0 12px 20px;
        margin: 24px 24px 24px auto
    }
}

.course-heading .leading p {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.3;
    margin-bottom: 0;
    padding-left: 14px
}

.course-heading .leading .my-profile {
    margin-left: 0
}

.course-heading .leading .leader {
    display: flex;
    align-items: center;
    margin-top: 20px
}

    .course-heading .leading .leader:first-child {
        margin-top: 0
    }

.course-heading .btn-collapse, .course-heading .btn-collapse:active {
    height: 24px;
    position: absolute;
    bottom: -13px;
    left: 50%;
    right: 50%;
    transform: translate(-50%);
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 12px;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    display: inline-flex;
    padding: 4px 24px 5px 12px;
    justify-content: center;
    align-items: flex-start;
    gap: 8px;
    border-radius: var(--border-radius-s);
    border: 1px solid var(--color-border-light);
    transition: all 0s ease-in-out
}

    .course-heading .btn-collapse[aria-expanded=false], .course-heading .btn-collapse:active[aria-expanded=false] {
        width: 147px;
        color: var(--color-primary-text);
        background-color: var(--bg-color-primary);
        border: 1px solid var(--color-border-light)
    }

        .course-heading .btn-collapse[aria-expanded=false]:before, .course-heading .btn-collapse:active[aria-expanded=false]:before {
            content: attr(data-text-open);
            position: absolute;
            top: 4px;
            left: 12px;
            padding-right: 25px;
            white-space: nowrap
        }

        .course-heading .btn-collapse[aria-expanded=false]:after, .course-heading .btn-collapse:active[aria-expanded=false]:after {
            background-image: url(./images/ico-dropdown-menu.svg);
            content: "";
            position: absolute;
            background-repeat: no-repeat;
            top: 5px;
            right: 0;
            padding-right: 26px;
            background-size: 11px 11px;
            background-position: top 1px right 8px;
            height: 10px;
            background-position-x: 50%;
            background-position-y: 50%
        }

    .course-heading .btn-collapse[aria-expanded=true], .course-heading .btn-collapse:active[aria-expanded=true] {
        width: 147px;
        border: 1px solid var(--color-primary);
        background-color: var(--bg-color-primary)
    }

        .course-heading .btn-collapse[aria-expanded=true]:before, .course-heading .btn-collapse:active[aria-expanded=true]:before {
            content: attr(data-text-close);
            position: absolute;
            top: 4px;
            left: 12px;
            padding-right: 25px;
            white-space: nowrap
        }

        .course-heading .btn-collapse[aria-expanded=true]:after, .course-heading .btn-collapse:active[aria-expanded=true]:after {
            background-image: url(./images/ico-dropdown-menu.svg);
            content: "";
            position: absolute;
            background-repeat: no-repeat;
            top: 5px;
            right: 0;
            padding-right: 24px;
            background-size: 11px 11px;
            background-position: top 1px right 8px;
            height: 10px;
            transform: rotate(180deg);
            background-position-x: 50%;
            background-position-y: 50%
        }

.col-course-details {
    margin-top: -12px
}

.course-details {
    border-radius: 0 0 12px 12px
}

@media (min-width: 992px) {
    .course-details {
        padding: 16px
    }
}

.player-main-box {
    background-color: var(--bg-color-primary);
    border-radius: var(--border-radius-l);
    min-height: 560px;
    display: flex;
    flex-flow: column
}

    .player-main-box .heading, .player-main-box .footer {
        padding: 14px 20px;
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        justify-content: space-between
    }

@media (min-width: 576px) {
    .player-main-box .heading, .player-main-box .footer {
        justify-content: space-between
    }
}

@media (min-width: 992px) {
    .player-main-box .heading, .player-main-box .footer {
        padding: 24px 40px
    }
}

.player-main-box .heading {
    border-bottom: 1px solid var(--color-border-light)
}

.player-main-box .footer {
    border-top: 1px solid var(--color-border-light)
}

.player-main-box .content {
    padding: 14px 20px;
    display: flex;
    flex-flow: column;
    flex-grow: 1
}

@media (min-width: 992px) {
    .player-main-box .content {
        padding: 24px 40px
    }
}

.player-main-box .content img, .player-main-box .content picture {
    max-width: 100%
}

.player-main-box .content h6, .player-main-box .content .h6 {
    color: var(--color-secondary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 13px;
    letter-spacing: 1.28px;
    text-transform: uppercase;
    margin-bottom: 16px
}

.player-main-box .ico-element {
    display: flex;
    align-items: center
}

    .player-main-box .ico-element .ico-container {
        width: 20px;
        max-width: 20px;
        display: inline-flex;
        margin-right: 4px
    }

        .player-main-box .ico-element .ico-container i {
            font-size: 16px;
            font-style: normal;
            font-weight: 400;
            color: var(--color-secondary-text)
        }

        .player-main-box .ico-element .ico-container img {
            max-width: 20px;
            height: auto;
            max-height: 20px
        }

        .player-main-box .ico-element .ico-container.mobile-display-none {
            display: none
        }

@media (min-width: 992px) {
    .player-main-box .ico-element .ico-container.mobile-display-none {
        display: flex
    }
}

.player-main-box .ico-element span.accent, .player-main-box .ico-element p {
    font-size: clamp(.75rem,.5981rem + .6483vw,1rem);
    color: var(--color-secondary-text);
    font-weight: 400;
    line-height: 1.4
}

.player-main-box .ico-element p {
    margin-right: 4px;
    margin-left: 4px;
    margin-bottom: 0
}

.player-main-box .ico-element span {
    font-size: clamp(.75rem,.5981rem + .6483vw,1rem);
    color: var(--color-primary-text);
    font-weight: 500;
    margin-bottom: 0;
    line-height: 1.4
}

.player-main-box .ico-element a, .player-main-box .ico-element a:hover {
    font-size: clamp(.75rem,.6788rem + .3165vw,.875rem);
    color: var(--color-primary-text);
    font-weight: 500;
    text-decoration: underline;
    cursor: pointer;
    line-height: 1.4
}

.player-main-box .downloads {
    margin-top: auto
}

    .player-main-box .downloads .ico-element {
        margin-bottom: 12px
    }

        .player-main-box .downloads .ico-element img {
            display: block
        }

.forum h3, .forum .h3 {
    color: var(--color-primary-text);
    font-size: clamp(1.5rem,1.2152rem + 1.2658vw,2rem);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 3.2px;
    text-transform: uppercase;
    margin-top: 40px;
    margin-bottom: 40px
}

.forum .my-profile {
    margin-left: 0
}

.forum .ico-element a, .forum .ico-element a:hover {
    font-size: clamp(.75rem,.6788rem + .3165vw,.875rem);
    color: var(--color-primary-text);
    font-weight: 500;
    text-decoration: underline;
    cursor: pointer;
    line-height: 1.4
}

@media (min-width: 1150px) {
    body.topnav-is-visible .side-menu-player {
        top: 102px
    }
}

.side-menu-player {
    background-color: var(--bg-color-primary);
    border-radius: var(--border-radius-l);
    transition: .2s ease-in-out
}

@media (min-width: 1150px) {
    .side-menu-player {
        position: sticky;
        top: 16px
    }
}

@media (min-width: 1150px) {
    .side-menu-player .collapse.main-collapse:not(.show) {
        display: block
    }
}

.side-menu-player .menu-block {
    border-bottom: 1px solid var(--color-border-light)
}

    .side-menu-player .menu-block:first-child {
        border-top: 1px solid var(--color-border-light);
        transition: 0s
    }

    .side-menu-player .menu-block .collapse-element {
        position: relative;
        transition: .2s ease-in-out
    }

        .side-menu-player .menu-block .collapse-element:after {
            background-image: url(./images/ico-dropdown-menu.svg);
            content: "";
            position: absolute;
            background-repeat: no-repeat;
            top: calc(50% - 5px);
            right: 11px;
            padding-right: 31px;
            background-size: 13px;
            height: 10px;
            background-position-x: 50%;
            background-position-y: 50%;
            transition: .2s ease-in-out
        }

        .side-menu-player .menu-block .collapse-element[aria-expanded=true]:after {
            transform: rotate(180deg)
        }

        .side-menu-player .menu-block .collapse-element p {
            padding-right: 22px
        }

    .side-menu-player .menu-block .sub-element {
        padding-left: 46px;
        border-bottom: 1px solid var(--color-border-light)
    }

    .side-menu-player .menu-block .form-check.form-switch {
        display: none
    }

@media (min-width: 1150px) {
    .side-menu-player .menu-block .form-check.form-switch {
        display: flex
    }
}

.side-menu-player .menu-block.switch {
    display: flex;
    align-items: center;
    width: 100%;
    border: none
}

.side-menu-player .menu-block-content {
    padding: 12px 20px;
    display: flex;
    align-items: center
}

    .side-menu-player .menu-block-content.time-restricted:after {
        display: none
    }

    .side-menu-player .menu-block-content.time-restricted p {
        opacity: .5
    }

    .side-menu-player .menu-block-content.header {
        background-color: var(--bg-color-primary);
        padding-top: 16px;
        padding-bottom: 16px;
        border-radius: var(--border-radius-l)
    }

        .side-menu-player .menu-block-content.header:hover, .side-menu-player .menu-block-content.header.active {
            background-color: var(--bg-color-primary)
        }

    .side-menu-player .menu-block-content:hover {
        background-color: var(--color-neutral-hover)
    }

    .side-menu-player .menu-block-content.active {
        background-color: var(--color-neutral-selected)
    }

    .side-menu-player .menu-block-content[role=button]:hover {
        background-color: var(--color-neutral-hover)
    }

        .side-menu-player .menu-block-content[role=button]:hover .menu-check {
            border: 1px solid var(--color-neutral-rest)
        }

            .side-menu-player .menu-block-content[role=button]:hover .menu-check.finished {
                border: 1px solid var(--color-primary)
            }

    .side-menu-player .menu-block-content[role=button].active {
        background-color: var(--color-neutral-selected)
    }

        .side-menu-player .menu-block-content[role=button].active .menu-check {
            border: 1px solid #ffffff
        }

            .side-menu-player .menu-block-content[role=button].active .menu-check.finished {
                border: 1px solid var(--color-primary)
            }

    .side-menu-player .menu-block-content .menu-check {
        border: 1px solid var(--color-neutral-rest);
        background-color: transparent;
        width: 18px;
        height: 18px;
        min-width: 18px;
        border-radius: var(--border-radius-l);
        margin-right: 8px
    }

        .side-menu-player .menu-block-content .menu-check.finished {
            border: 1px solid var(--color-primary);
            background-color: var(--color-primary);
            background-image: url(./images/ico-checked-finished.svg);
            background-size: 10px;
            background-repeat: no-repeat;
            background-position: center center
        }

    .side-menu-player .menu-block-content h4, .side-menu-player .menu-block-content .h4 {
        color: var(--color-secondary-text);
        font-size: 16px;
        font-style: normal;
        font-weight: 600;
        margin-bottom: 0;
        text-transform: uppercase;
        line-height: 13px;
        letter-spacing: 1.28px
    }

.side-menu-player p, .side-menu-player a {
    margin-bottom: -1px;
    color: var(--color-primary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    display: block;
    text-decoration: none;
    width: 100%;
    transition: .2s ease-in-out
}

.side-menu-player .inline-calendar h5, .side-menu-player .inline-calendar .h5 {
    padding-left: 0
}

.side-menu-player .menu-player-scrollable {
    overflow-y: auto;
    padding-right: 12px
}

.player-bottom-bar-menu-mobile {
    z-index: 14;
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    padding: 16px 20px;
    background-color: var(--bg-color-primary);
    align-items: center;
    display: flex
}

@media (min-width: 1150px) {
    .player-bottom-bar-menu-mobile {
        display: none
    }
}

.collapse.bottom-bar-collapse.show .player-bottom-bar-menu {
    bottom: 34px
}

@media (min-width: 768px) {
    .collapse.bottom-bar-collapse.show .player-bottom-bar-menu {
        bottom: 56px
    }
}

@media (min-width: 1150px) {
    .collapse.bottom-bar-collapse.show .player-bottom-bar-menu {
        bottom: 0
    }
}

.bottom-bar-collapse.collapsing .player-bottom-bar-menu {
    bottom: 34px
}

@media (min-width: 768px) {
    .bottom-bar-collapse.collapsing .player-bottom-bar-menu {
        bottom: 56px
    }
}

.collapse.bottom-bar-collapse .player-bottom-bar-menu {
    bottom: -206px;
    transition: .2s ease-in-out;
    display: flex
}

@media (min-width: 768px) {
    .collapse.bottom-bar-collapse .player-bottom-bar-menu {
        bottom: -182px
    }
}

.collapse.bottom-bar-collapse:not(.show) {
    display: flex
}

@media (min-width: 768px) {
    .collapse.bottom-bar-collapse:not(.show) {
        display: flex
    }

        .collapse.bottom-bar-collapse:not(.show) .player-bottom-bar-menu {
            bottom: -122px
        }
}

@media (min-width: 1150px) {
    .collapse.bottom-bar-collapse:not(.show) .player-bottom-bar-menu {
        bottom: 0
    }
}

.player-bottom-bar-menu {
    z-index: 12;
    position: fixed;
    left: 0;
    width: 100%;
    padding: 12px 20px;
    background-color: var(--bg-color-primary);
    box-shadow: -4px 4px 16px #00000029;
    display: flex;
    min-height: 80px
}

@media (min-width: 1150px) {
    .player-bottom-bar-menu {
        bottom: 0;
        padding-top: 16px
    }
}

.player-bottom-bar-menu .info-content {
    width: 100%
}

@media (min-width: 768px) {
    .player-bottom-bar-menu .info-content {
        display: flex;
        justify-content: space-between
    }
}

.player-bottom-bar-menu .bar-info {
    display: flex;
    justify-content: center;
    flex-direction: column;
    margin-bottom: 6px;
    padding-bottom: 6px;
    border-bottom: 1px solid #e9e9e9;
    width: 100%
}

    .player-bottom-bar-menu .bar-info:last-child {
        border-bottom: none
    }

@media (max-width: 767px) {
    .player-bottom-bar-menu .bar-info:first-child {
        height: 66px
    }
}

@media (min-width: 768px) {
    .player-bottom-bar-menu .bar-info {
        padding-left: 20px;
        padding-right: 20px;
        border-left: 1px solid #e9e9e9;
        border-bottom: none;
        margin-bottom: 0;
        padding-bottom: 0
    }
}

.player-bottom-bar-menu .bar-info:first-child {
    border-left: none;
    padding-left: 0
}

.player-bottom-bar-menu .bar-info h4, .player-bottom-bar-menu .bar-info .h4 {
    color: var(--color-primary-text);
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 1.3;
    margin-bottom: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis
}

.player-bottom-bar-menu .bar-info span {
    color: #707070;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    margin-bottom: 4px;
    display: block;
    white-space: nowrap
}

.player-bottom-bar-menu .bar-info p {
    margin-bottom: 0;
    color: var(--color-primary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
    line-height: 1.3;
    white-space: nowrap
}

.player-bottom-bar-menu .bar-info.bar {
    display: flex;
    flex-direction: row;
    width: 100%
}

    .player-bottom-bar-menu .bar-info.bar .btn-session-schedule-container {
        position: relative
    }

.player-bottom-bar-menu .stage {
    background-image: url(./images/arrow-breadcrumb.svg);
    background-repeat: no-repeat;
    background-size: 13px 11px;
    content: "";
    display: inline-block;
    height: 22px;
    background-position: left 11px center;
    padding-left: 32px
}

    .player-bottom-bar-menu .stage:first-child {
        background-image: none;
        padding-left: 0
    }

.form-check.form-switch {
    margin-left: auto;
    margin-right: 18px
}

.form-switch .form-check-input {
    margin-left: auto;
    width: 40px;
    background-position: right center;
    border-radius: var(--border-radius-s);
    transition: background-position .15s ease-in-out;
    background-color: var(--bg-color-secondary);
    border: none;
    height: 20px;
    cursor: pointer
}

    .form-switch .form-check-input:active {
        filter: brightness(100%)
    }

    .form-switch .form-check-input:checked[type=checkbox] {
        background-color: #e9e9e9;
        background-position: left center
    }

.btn-collapse-player-menu-mobile {
    background-color: transparent;
    position: relative;
    border: none;
    width: 24px;
    height: 24px;
    padding: 0;
    margin-right: 28px;
    margin-left: auto;
    color: var(--color-primary)
}

    .btn-collapse-player-menu-mobile i {
        transition: all .2s ease-in-out
    }

@media (min-width: 1150px) {
    .btn-collapse-player-menu-mobile {
        display: none
    }
}

.btn-collapse-player-menu-mobile.collapsed i {
    transform: rotate(180deg);
    transition: all .2s ease-in-out
}

.btn-collapse-player-menu-mobile[aria-expanded=false] i {
    transform: rotate(180deg)
}

.btn-collapse-bottombar-menu-mobile {
    background-color: transparent;
    position: relative;
    border: none;
    width: 24px;
    height: 24px;
    padding: 0;
    margin-right: auto;
    color: var(--color-primary)
}

    .btn-collapse-bottombar-menu-mobile i {
        transition: all .2s ease-in-out
    }

@media (min-width: 1150px) {
    .btn-collapse-bottombar-menu-mobile {
        display: none
    }
}

.btn-collapse-bottombar-menu-mobile.collapsed i {
    transform: rotate(180deg);
    transition: all .2s ease-in-out
}

.btn-collapse-bottombar-menu-mobile[aria-expanded=false] i {
    transform: rotate(180deg)
}

.progress, .progress-stacked {
    --bs-progress-height: 10px;
    --bs-progress-font-size: .75rem;
    --bs-progress-bg: #fff;
    --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: #0e66f3;
    --bs-progress-bar-transition: width .6s ease;
    display: flex;
    height: var(--bs-progress-height);
    overflow: hidden;
    font-size: var(--bs-progress-font-size);
    background-color: var(--bg-color-primary);
    align-items: center;
    padding-left: 1px;
    padding-right: 1px;
    border-radius: var(--border-radius-s);
    border: 1px solid var(--Light-Grey-3, #b6b6b6);
    margin-top: 6px
}

.progress-bar {
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    color: var(--bs-progress-bar-color);
    text-align: center;
    white-space: nowrap;
    background-color: var(--color-primary);
    transition: var(--bs-progress-bar-transition);
    width: 75%;
    height: 6px;
    border-radius: var(--border-radius-s)
}

@media (min-width: 1150px) {
    body.has-top-banner .course-content-menu.to-left {
        top: 133px
    }
}

@media (min-width: 1150px) {
    body.topnav-is-visible .course-content-menu.to-left {
        top: 80px
    }
}

@media (min-width: 1150px) {
    body.topnav-is-visible.topnav-is-fixed .course-content-menu.to-left {
        top: 80px
    }
}

@media (min-width: 1150px) {
    body.topnav-is-fixed .course-content-menu.to-left {
        top: 0
    }

        body.topnav-is-fixed .course-content-menu.to-left.show {
            position: fixed
        }
}

@media (min-width: 1150px) {
    body:not(.is-at-top) .course-content-menu.to-left {
        transition: .2s ease-in-out opacity,.3s ease-out top
    }
}

.course-content-menu.will-animate {
    transition: .3s ease-in-out width,.3s ease-in-out opacity,.3s ease-in-out padding;
    position: relative
}

    .course-content-menu.will-animate .side-menu-player {
        transition: .3s ease-in-out transform
    }

    .course-content-menu.will-animate.is-animating {
        width: 0;
        padding: 0;
        opacity: 0
    }

        .course-content-menu.will-animate.is-animating .side-menu-player {
            transform: translate(-100%)
        }

@media (min-width: 1150px) {
    .course-content-menu.to-left {
        opacity: 0;
        width: 326px;
        position: fixed;
        z-index: 4;
        left: -14px
    }

        .course-content-menu.to-left .side-menu-player {
            border-radius: 0;
            height: 100vh;
            box-shadow: 6px 5px 16px #00000029
        }

        .course-content-menu.to-left:not(.show) {
            visibility: hidden
        }

        .course-content-menu.to-left.show {
            left: -14px;
            opacity: 1;
            transition: .2s ease-in-out opacity,0s ease-out top;
            position: absolute;
            border-radius: 0;
            top: 80px;
            z-index: 4;
            width: 326px
        }

            .course-content-menu.to-left.show .form-check.form-switch svg {
                rotate: 180deg;
                left: 0
            }
}

.col-player {
    transition: width .5s ease-in-out
}

.col-course-content, .col-course-content.col-12 {
    transition: all .3s ease-in-out
}

.learning-item-content-container iframe {
    max-width: 100%
}

.learning-item-content-container .content-element {
    margin-bottom: 1rem
}

.learning-item-content-container .content-learning-item-title {
    font-size: 28px;
    font-style: normal;
    font-weight: 500;
    line-height: 38px
}

.learning-item-content-container .content-live-session {
    display: flex;
    flex-flow: column;
    align-items: center;
    margin-top: 24px
}

    .learning-item-content-container .content-live-session img {
        margin-bottom: 24px
    }

    .learning-item-content-container .content-live-session p {
        font-size: 1rem;
        font-weight: 300;
        margin-bottom: 24px
    }

.col-course-content:has(.content-scorm) .player-main-box {
    height: calc(100vh - 114px);
    max-height: calc(100vh - 114px)
}

    .col-course-content:has(.content-scorm) .player-main-box .content, .col-course-content:has(.content-scorm) .player-main-box .content-inner, .col-course-content:has(.content-scorm) .player-main-box .learning-item-content-container, .col-course-content:has(.content-scorm) .player-main-box .content-scorm, .col-course-content:has(.content-scorm) .player-main-box iframe {
        height: 100%
    }

    .col-course-content:has(.content-scorm) .player-main-box .content-learning-item-title {
        display: none
    }

    .col-course-content:has(.content-scorm) .player-main-box .content-inner {
        margin-top: 0 !important;
        margin-bottom: 0 !important
    }

        .col-course-content:has(.content-scorm) .player-main-box .content-inner + .downloads {
            margin-top: 3rem
        }

    .col-course-content:has(.content-scorm) .player-main-box .content-scorm {
        margin: 0
    }

        .col-course-content:has(.content-scorm) .player-main-box .content-scorm > iframe {
            width: 100%;
            height: 100%
        }

.popover-player-menu {
    position: absolute;
    background-color: var(--color-secondary);
    border-radius: 6px;
    width: 241px;
    padding: 16px 16px 16px 20px;
    left: -11px;
    top: -102px;
    box-shadow: -4px 4px 16px #00000029
}

    .popover-player-menu .content {
        width: 100%;
        display: flex
    }

    .popover-player-menu p {
        color: var(--color-primary-text);
        font-size: var(--paragraph-font-weight);
        font-style: normal;
        font-weight: var(--paragraph-font-weight);
        line-height: 1.3;
        margin-bottom: 0
    }

    .popover-player-menu .close {
        width: 24px;
        height: 20px;
        color: var(--color-primary-text);
        background-repeat: no-repeat;
        background-color: transparent;
        border: none;
        margin-left: auto
    }

        .popover-player-menu .close i {
            width: 20px;
            height: 20px;
            color: var(--color-primary-text);
            font-size: 20px
        }

    .popover-player-menu .down-arrow {
        border-color: var(--color-secondary) transparent;
        border-style: solid;
        border-width: 12px 11px 0px 11px;
        height: 12px;
        width: 12px;
        position: absolute;
        bottom: -11px
    }

.btn-collapse-player-menu-mobile:after, .btn-collapse-bottombar-menu-mobile:after {
    background-image: var(--collapse-arrow-bg)
}

.form-check.form-switch label div svg path {
    fill: var(--color-primary)
}

.side-menu-player .form-check label {
    padding-top: 0;
    height: 20px;
    max-height: 20px;
    width: 40px;
    background-color: var(--bg-color-secondary);
    border-radius: var(--border-radius-s);
    position: relative
}

.side-menu-player .form-check.form-switch {
    display: flex;
    align-items: center;
    margin-bottom: 0
}

    .side-menu-player .form-check.form-switch svg {
        position: absolute;
        top: 0;
        height: 20px;
        right: 0
    }

label.bottombar-switch:has(input:checked) .right {
    display: none
}

label.bottombar-switch:has(input:checked) .left {
    display: block
}

label.bottombar-switch:has(input:not(:checked)) .left {
    display: none
}

.form-check.bottombar-switch-left-menu {
    margin-bottom: 0
}

    .form-check.bottombar-switch-left-menu label {
        padding-top: 0;
        cursor: pointer;
        display: flex;
        align-items: center
    }

        .form-check.bottombar-switch-left-menu label svg path, .form-check.bottombar-switch-left-menu label polygon {
            fill: var(--color-primary)
        }

        .form-check.bottombar-switch-left-menu label:hover svg path, .form-check.bottombar-switch-left-menu label:hover polygon {
            fill: var(--color-primary-dark)
        }

.page-player .tabs-course {
    margin-top: 26px
}

.popover-player-session-schedule {
    position: absolute;
    background-color: var(--color-secondary);
    border-radius: 6px;
    min-width: 241px;
    max-width: 320px;
    padding: 16px 16px 16px 20px;
    left: -16px;
    bottom: 52px;
    box-shadow: -4px 4px 16px #00000029
}

    .popover-player-session-schedule .content {
        width: 100%;
        display: flex
    }

        .popover-player-session-schedule .content p {
            color: var(--color-primary-text);
            font-size: var(--paragraph-font-weight);
            font-style: normal;
            font-weight: var(--paragraph-font-weight);
            line-height: 1.3;
            margin-bottom: 0;
            text-wrap: wrap
        }

    .popover-player-session-schedule p {
        color: var(--color-primary-text);
        font-size: var(--paragraph-font-weight);
        font-style: normal;
        font-weight: var(--paragraph-font-weight);
        line-height: 1.3;
        margin-bottom: 0
    }

    .popover-player-session-schedule .close {
        width: 24px;
        height: 20px;
        color: var(--color-primary-text);
        background-repeat: no-repeat;
        background-color: transparent;
        border: none;
        margin-left: auto
    }

        .popover-player-session-schedule .close i {
            width: 20px;
            height: 20px;
            color: var(--color-primary-text);
            font-size: 20px
        }

    .popover-player-session-schedule .down-arrow {
        border-color: var(--color-secondary) transparent;
        border-style: solid;
        border-width: 12px 11px 0px 11px;
        height: 12px;
        width: 12px;
        position: absolute;
        bottom: -11px
    }

button.btn-session-schedule svg path {
    fill: var(--color-primary)
}

button.btn-session-schedule:hover svg path {
    fill: var(--color-primary-dark)
}

.btn-session-schedule {
    margin: 13px 20px 13px 0;
    padding-left: 0;
    padding-right: 0;
    border: none;
    background: transparent
}

    .btn-session-schedule:focus-visible {
        outline: none
    }

.btn-bottombar-sidemenu-container {
    position: relative;
    width: 51px;
    min-width: 51px;
    min-width: 60px;
    justify-content: center;
    align-items: center;
    border-right: 1px solid #e9e9e9;
    padding-right: 20px;
    margin-right: 20px;
    background-color: transparent;
    display: none
}

    .btn-bottombar-sidemenu-container.show {
        display: flex
    }

@media (max-width: 1149px) {
    .btn-bottombar-sidemenu-container {
        display: none !important
    }
}

.col-course-content {
    min-height: calc(100dvh - 120px)
}

@media (min-width: 1150px) {
    .col-course-content {
        min-height: calc(100dvh - 160px)
    }
}

.main-collapse.collapse.show {
    padding-bottom: 20px
}

@media (min-width: 1150px) {
    .main-collapse.collapse {
        padding-bottom: 20px
    }
}

body.page-player {
    padding-top: 0;
    padding-bottom: var(--body-page-player-pb);
}

.page-player footer{
    display:none;
}

    body.page-player #topnav {
        position: static
    }

    body.page-player.has-top-banner {
        padding-top: 52px
    }

    body.page-player .side-menu-player {
        top: 9px
    }

    body.page-player.topnav-is-visible.topnav-is-fixed .course-content-menu .menu-player-scrollable.to-left, body.page-player.topnav-is-fixed .course-content-menu .menu-player-scrollable.to-left {
        max-height: calc(100vh - 140px)
    }

@media (max-width: 1149px) {
    body.page-player.topnav-is-visible.topnav-is-fixed .course-content-menu .menu-player-scrollable, body.page-player.topnav-is-fixed .course-content-menu .menu-player-scrollable {
        max-height: 360px
    }
}

@media (max-width: 1149px) {
    body.page-player .menu-player-scrollable {
        max-height: 360px
    }
}

@media (min-width: 1150px) {
    body.page-player .course-content-menu .menu-player-scrollable {
        transition: all .3s ease-in-out;
        max-height: calc(100vh - 179px)
    }
}

body.has-top-banner .course-content-menu.to-left .menu-player-scrollable {
    max-height: calc(100vh - 280px)
}

body .course-content-menu.to-left .menu-player-scrollable {
    max-height: calc(100vh - 230px)
}

@media (max-width: 1149px) {
    body .course-content-menu.to-left .menu-player-scrollable {
        max-height: 360px
    }
}

@media (min-width: 1150px) {
    body.topnav-is-fixed .course-content-menu.to-left .menu-player-scrollable {
        max-height: calc(100vh - 140px)
    }
}

@media (min-width: 1150px) {
    body.topnav-is-visible .course-content-menu.to-left {
        top: 98px
    }
}

@media (min-width: 1150px) {
    body.topnav-is-visible.topnav-is-fixed .course-content-menu.to-left {
        top: 0
    }
}

.course-content-menu {
    margin-bottom: 1.5rem
}

@media (min-width: 1150px) {
    .course-content-menu {
        margin-bottom: 20px
    }
}

.forum .content h4, .forum .content .h4 {
    color: var(--color-primary-text);
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 16px
}

.forum .content .write-comment {
    display: flex
}

.forum .comment {
    display: flex;
    padding-top: 16px;
    margin-top: 16px;
    border-top: 1px solid #e9e9e9;
    margin-left: 52px
}

    .forum .comment:first-child {
        padding: 0;
        border: none;
        margin-left: 0
    }

    .forum .comment.comment-removed .removed-status {
        font-size: 12px;
        font-style: normal;
        font-weight: 400;
        line-height: 16px;
        color: var(--forum-comment-deleted-status)
    }

        .forum .comment.comment-removed .removed-status svg {
            fill: var(--forum-comment-deleted-status) !important;
            margin-bottom: .25rem;
            margin-left: .125rem
        }

.forum .forum-content-container {
    padding-left: 16px;
    width: 100%
}

    .forum .forum-content-container .name p {
        color: var(--color-primary-text);
        font-size: 14px;
        font-style: normal;
        font-weight: 600;
        line-height: 18px;
        margin-bottom: 4px
    }

    .forum .forum-content-container .date {
        color: #707070;
        font-size: 12px;
        font-style: normal;
        font-weight: 400;
        line-height: 16px
    }

    .forum .forum-content-container .body-txt p, .forum .forum-content-container .body-txt a {
        color: var(--color-primary-text);
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 22px
    }

.forum .write-comment .downloads .ico-element a {
    max-width: 360px;
    width: 100%
}

.forum .downloads h6, .forum .downloads .h6 {
    color: var(--color-secondary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 13px;
    letter-spacing: 1.28px;
    text-transform: uppercase;
    margin-bottom: 12px
}

.forum .ico-element {
    display: flex;
    align-items: start;
    margin-bottom: 8px
}

    .forum .ico-element a, .forum .ico-element a:hover {
        text-decoration: underline
    }

    .forum .ico-element .ico-container {
        margin-right: 12px;
        width: 20px;
        max-width: 20px;
        display: inline-flex
    }

        .forum .ico-element .ico-container img {
            max-width: 20px;
            height: auto;
            max-height: 20px
        }

        .forum .ico-element .ico-container.mobile-display-none {
            display: none
        }

@media (min-width: 992px) {
    .forum .ico-element .ico-container.mobile-display-none {
        display: block
    }
}

.forum-box {
    padding: 24px 20px;
    border-radius: var(--border-radius-l);
    margin-bottom: 20px
}

@media (min-width: 1150px) {
    .forum-box {
        padding: 24px
    }
}

.modal-content .forum-box {
    padding: 24px 20px 0;
    margin-bottom: 12px
}

.btn-bar {
    margin-top: 20px
}

    .btn-bar .replies {
        display: flex
    }

        .btn-bar .replies p {
            color: var(--color-primary-text);
            font-size: 14px;
            font-style: normal;
            font-weight: 600;
            line-height: 20px;
            margin-bottom: 0
        }

        .btn-bar .replies img {
            width: 25px;
            height: 20px;
            margin-right: 8px
        }

.steps-blue-container {
    margin-bottom: 40px;
    display: flex;
    align-items: start;
    justify-content: space-between
}

    .steps-blue-container .steps-element-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: relative;
        padding-left: 4px;
        padding-right: 4px;
        text-decoration: none
    }

        .steps-blue-container .steps-element-container:first-child:after {
            height: 1px;
            width: 50%;
            left: 50%
        }

        .steps-blue-container .steps-element-container:last-child:after {
            height: 1px;
            width: 50%;
            left: 0;
            top: 24px
        }

        .steps-blue-container .steps-element-container:after {
            content: "";
            position: absolute;
            left: 0;
            width: 100%;
            height: 1px;
            top: 24px;
            background-color: var(--color-neutral-rest)
        }

        .steps-blue-container .steps-element-container p, .steps-blue-container .steps-element-container a {
            font-size: 13px;
            font-style: normal;
            font-weight: var(--paragraph-semibold-font-weight);
            line-height: 1.3;
            text-align: center;
            margin-bottom: 0;
            margin-top: 12px;
            text-decoration: none
        }

@media (min-width: 568px) {
    .steps-blue-container .steps-element-container p, .steps-blue-container .steps-element-container a {
        font-size: 14px
    }
}

@media (min-width: 768px) {
    .steps-blue-container .steps-element-container p, .steps-blue-container .steps-element-container a {
        margin-top: 16px;
        font-size: 16px
    }
}

.steps-blue-container .steps-element-container .steps-element {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: var(--border-radius-xxl);
    background: var(--bg-color-primary);
    z-index: 1;
    font-size: 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--color-secondary-text);
    border: 2px solid var(--color-secondary-text);
    outline: 6px solid var(--bg-color-primary);
    position: relative
}

    .steps-blue-container .steps-element-container .steps-element.active {
        background: var(--bg-color-primary);
        border: 2px solid var(--color-primary);
        color: var(--color-primary)
    }

    .steps-blue-container .steps-element-container .steps-element.checked {
        background: var(--color-primary);
        border: 2px solid var(--color-primary);
        color: var(--bg-color-primary)
    }

        .steps-blue-container .steps-element-container .steps-element.checked .step-checked {
            position: absolute;
            bottom: -5px;
            right: -5px;
            width: 17px;
            height: 17px;
            min-width: 17px;
            background-color: var(--color-secondary);
            color: var(--bg-color-primary);
            display: flex;
            justify-content: center;
            align-items: center;
            font-size: 7px;
            border-radius: var(--border-radius-xl);
            border: 2px solid var(--bg-color-primary)
        }

.payment-component {
    margin-top: 32px;
    padding: 20px;
    border-radius: var(--border-radius-l)
}

@media (min-width: 768px) {
    .payment-component {
        padding: 32px
    }
}

.payment-component.small {
    padding: 32px 20px
}

.payment-component p {
    color: var(--color-primary-text);
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

.payment-component h3, .payment-component .h3 {
    color: var(--color-primary-text);
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: 28px
}

.payment-component .sub-info span {
    color: var(--color-primary-text);
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-bottom: 12px;
    display: block
}

.payment-component .sub-info p {
    color: var(--color-primary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    margin-bottom: 0
}

.payment-component .sub-info a {
    color: var(--color-primary);
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-decoration: underline
}

.payment-component .sub-info.text-black a {
    color: var(--color-primary-text)
}

.payment-component .details-element {
    padding-top: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border-light)
}

    .payment-component .details-element:first-child {
        border-top: 1px solid var(--color-border-light)
    }

@media (min-width: 768px) {
    .payment-component .details-element {
        display: flex
    }
}

.payment-component .details-element span {
    color: var(--color-primary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    display: block;
    margin-bottom: 2px
}

@media (min-width: 768px) {
    .payment-component .details-element span {
        margin-bottom: 0
    }
}

.payment-component .details-element p {
    color: var(--color-primary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 24px;
    margin-bottom: 0;
    display: flex
}

    .payment-component .details-element p span {
        color: var(--color-primary-text);
        font-size: 16px;
        font-style: normal;
        font-weight: 600;
        line-height: 24px
    }

@media (min-width: 768px) {
    .payment-component .details-element p {
        text-align: end;
        margin-left: auto
    }
}

.payment-component .details-element small, .payment-component .details-element .small {
    color: var(--color-primary-text);
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    margin-bottom: 0
}

@media (min-width: 992px) {
    body.topnav-is-visible .payment-component.small {
        top: 102px
    }
}

.payment-component.small {
    transition: .2s ease-in-out
}

@media (min-width: 992px) {
    .payment-component.small {
        position: sticky;
        top: 16px
    }
}

.product-container {
    padding-top: 20px;
    padding-bottom: 20px;
    display: flex;
    border-bottom: 1px solid var(--color-border-light)
}

    .product-container:first-child {
        border-top: 1px solid var(--color-border-light)
    }

.buy-prod-bg-img {
    width: 48px;
    min-width: 48px;
    height: 48px;
    border-radius: var(--border-radius-m);
    background-size: cover;
    background-position: center center;
    margin-right: 16px
}

@media (min-width: 768px) {
    .buy-prod-bg-img {
        width: 64px;
        height: 64px;
        min-width: 64px;
        margin-right: 24px
    }
}

.prod-info-container {
    width: 100%
}

@media (min-width: 768px) {
    .prod-info-container {
        display: flex
    }
}

.prod-info-container .txt-1 p {
    color: var(--color-primary-text);
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-bottom: 6px
}

@media (min-width: 768px) {
    .prod-info-container .txt-1 p {
        font-size: 16px
    }
}

@media (min-width: 576px) {
    .prod-info-container .txt-2 {
        display: flex
    }
}

.prod-info-container .txt-2 p {
    color: var(--color-secondary-text);
    font-family: var(--font-family-primary);
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    margin-bottom: 0
}

@media (min-width: 768px) {
    .prod-info-container .txt-2 p {
        font-size: 14px
    }
}

.prod-info-container .txt-3 {
    margin-left: auto
}

    .prod-info-container .txt-3 p {
        color: var(--color-primary-text);
        text-align: right;
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 18px;
        margin-bottom: 0;
        white-space: nowrap;
        padding-top: 16px
    }

@media (min-width: 768px) {
    .prod-info-container .txt-3 p {
        font-size: 16px;
        padding-top: 3px;
        padding-left: 32px;
        margin-left: auto
    }
}

@media (min-width: 1150px) {
    .prod-info-container .txt-3 p {
        padding-left: 48px
    }
}

.bin-prod {
    width: 56px;
    display: flex;
    justify-content: end;
    margin-left: auto
}

.buy-promo-code .form {
    margin-bottom: 20px
}

@media (min-width: 576px) {
    .buy-promo-code {
        display: flex
    }

        .buy-promo-code .form {
            width: 293px;
            margin-right: 28px;
            margin-bottom: 0
        }
}

.pay-calc-btn, .calc-element {
    display: flex
}

    .calc-element p {
        color: var(--color-primary-text);
        font-size: 18px;
        font-weight: 400;
        line-height: normal;
        margin-bottom: 12px
    }

    .calc-element span {
        white-space: nowrap;
        margin-left: auto;
        font-size: 18px;
        font-weight: 600;
        color: var(--color-primary-text);
        line-height: normal
    }

    .calc-element.plan {
        margin-top: 16px
    }

    .calc-element.total {
        border-top: 1px solid var(--color-border-light);
        padding-top: 12px
    }

    .calc-element.tax {
        padding-left: 20px
    }

        .calc-element.tax p {
            font-size: 14px;
            font-style: normal;
            font-weight: 400;
            line-height: 22px;
            color: var(--color-primary-text)
        }

        .calc-element.tax span {
            font-size: 14px;
            font-style: normal;
            font-weight: 400;
            line-height: 22px;
            white-space: nowrap;
            margin-left: auto;
            color: var(--color-primary-text)
        }

.summary-element {
    display: flex;
    border-top: 1px solid var(--color-border-light);
    margin-top: 22px;
    padding-top: 16px;
    margin-bottom: 24px
}

    .summary-element p {
        color: var(--color-primary-text);
        font-size: 24px;
        font-style: normal;
        font-weight: 600;
        line-height: normal
    }

@media (min-width: 768px) {
    .summary-element p {
        font-size: 24px
    }
}

.summary-element span {
    color: var(--color-primary-text);
    font-size: 24px;
    font-style: normal;
    font-weight: 600;
    line-height: normal
}

@media (min-width: 768px) {
    .summary-element span {
        font-size: 28px
    }
}

.summary-element span {
    white-space: nowrap;
    margin-left: auto
}

.footer-payment-logos {
    border-top: 1px solid var(--color-border-light);
    margin-top: 60px;
    padding-top: 20px;
    display: flex;
    margin-bottom: 20px;
    align-items: start
}

    .footer-payment-logos img {
        padding-right: 14px
    }

.single-order-summary .braintree-payment {
    width: 100%;
    padding-top: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    flex-flow: column
}

    .single-order-summary .braintree-payment .btn-braintree-submit {
        margin-top: 16px
    }

.terms-of-service-form .other-payment-options-text {
    margin-top: 4px
}

    .terms-of-service-form .other-payment-options-text a, .terms-of-service-form .form-check label a {
        color: currentColor
    }

.feature-box .content {
    overflow: hidden
}

    .feature-box .content h3, .feature-box .content .h3 {
        height: 2.5em;
        overflow: hidden
    }
