@import url(https://fonts.googleapis.com/earlyaccess/nanumgothic.css);

/* -- ROOT -- */
.root {
    display: grid;
    gap: 0 0;
    grid-template-columns: min-content 1fr;
    grid-template-rows: min-content 1fr;
    min-height: 100vh;
    width: 100%;
}

body {
    font-family: 'Nanum Gothic', sans-serif !important;
    overflow-x: hidden;
    position: relative;
    background-size: cover;
    background-attachment: fixed;
    font-size: 0.8rem;
}

:root {
    --nf-backdrop-bg: rgba(26, 29, 33, 0.75);
    --nf-content-title-size: 2.25rem;
    --nf-content-title-color: var(--bs-primary);
    --nf-content-title-weight: 500;
}



/* -- ROOT -- */
.root {
    display: grid;
    gap: 0 0;
    grid-template-columns: min-content 1fr;
    grid-template-rows: min-content 1fr;
    min-height: 100vh;
    width: 100%;
}

body {
    overflow-x: hidden;
    position: relative;
    background-size: cover;
    background-attachment: fixed;
}

:root {
    --nf-backdrop-bg: rgba(26, 29, 33, 0.75);
    --nf-content-title-size: 2.25rem;
    --nf-content-title-color: var(--bs-primary);
    --nf-content-title-weight: 500;
}



/* -- REBOOT -- */
/* -- Scrollbar -- */
@supports (-moz-appearance: none) {
    .scrollable-content {
        scrollbar-color: rgba(0, 0, 0, 0.25) transparent;
        scrollbar-width: auto;
    }
}

html[data-overlayscrollbars]>body::-webkit-scrollbar {
    width: 0 !important;
    visibility: hidden;
}

::-webkit-scrollbar {
    width: 0.35rem;
    height: 0.35rem;
}

::-webkit-scrollbar-track {
    background-color: transparent;
}

::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.25);
    border-radius: 1rem;
}

::-webkit-scrollbar-thumb:hover {
    width: 2rem;
    background: rgba(0, 0, 0, 0.5);
}

@supports (-moz-appearance: none) {
    [data-bs-theme=dark] .scrollable-content {
        scrollbar-color: rgba(255, 255, 255, 0.25) transparent;
    }
}

[data-bs-theme=dark] ::-webkit-scrollbar-track {
    background-color: transparent;
}

[data-bs-theme=dark] ::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.25);
}

[data-bs-theme=dark] ::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.5);
}

[data-bs-theme=dark] {

    --bs-primary-rgb: 8, 103, 194;
    --bs-secondary-rgb: 255, 255, 255;
    --bs-success-rgb: 40, 175, 105;
    --bs-info-rgb: 27, 154, 170;
    --bs-warning-rgb: 255, 222, 155;
    --bs-danger-rgb: 255, 111, 111;
    --bs-light-rgb: 236, 243, 250;
    --bs-dark-rgb: 0, 0, 0;
    --bs-teal-rgb: 34, 118, 110;
    --bs-indigo-rgb: 66, 77, 138;
    --bs-purple-rgb: 146, 67, 158;
    --bs-pink-rgb: 135, 54, 81;
    --bs-lime-rgb: 139, 148, 57;
    --bs-white-rgb: 255, 255, 255;
    --bs-black-rgb: 0, 0, 0;
    --bs-body-color-rgb: 33, 37, 41;
    --bs-body-bg-rgb: 255, 255, 255;
    --bs-emphasis-color-rgb: 0, 0, 0;
    --bs-secondary-color-rgb: 33, 37, 41;
    --bs-secondary-bg-rgb: 233, 236, 239;
    --bs-tertiary-color-rgb: 33, 37, 41;
    --bs-tertiary-bg-rgb: 248, 249, 250;
}

/* Fix for modal form elements in dark mode */
[data-bs-theme=dark] .modal .form-control,
[data-bs-theme=dark] .modal input[type="text"],
[data-bs-theme=dark] .modal input[type="password"],
[data-bs-theme=dark] .modal input[type="email"],
[data-bs-theme=dark] .modal input[type="number"],
[data-bs-theme=dark] .modal input[type="tel"],
[data-bs-theme=dark] .modal input[type="url"],
[data-bs-theme=dark] .modal input[type="search"],
[data-bs-theme=dark] .modal input[type="date"],
[data-bs-theme=dark] .modal textarea {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
}

/* Fix for modal select elements in dark mode */
[data-bs-theme=dark] .modal .form-select {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

/* Fix for modal select options in dark mode */
[data-bs-theme=dark] .modal .form-select option {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
}

/* Fix for modal input groups in dark mode */
[data-bs-theme=dark] .modal .input-group-text {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
}

/* Fix for modal checkboxes and radio buttons in dark mode */
[data-bs-theme=dark] .modal .form-check-input {
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
}

[data-bs-theme=dark] .form-check-input:checked {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

[data-bs-theme=dark] .form-check-label {
    color: #fff;
}

/* Range inputs */
[data-bs-theme=dark] .form-range::-webkit-slider-thumb {
    background-color: var(--bs-primary);
}

[data-bs-theme=dark] .form-range::-moz-range-thumb {
    background-color: var(--bs-primary);
}

/* Input groups */
[data-bs-theme=dark] .input-group-text {
    color: #fff;
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
}

/* Disabled form controls */
[data-bs-theme=dark] .form-control:disabled,
[data-bs-theme=dark] .form-control[readonly],
[data-bs-theme=dark] .form-select:disabled {
    color: rgba(255, 255, 255, 0.5);
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
}

/* File input */
[data-bs-theme=dark] .form-control[type="file"]::file-selector-button {
    color: #fff;
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
}

[data-bs-theme=dark] .form-control[type="file"]::-webkit-file-upload-button {
    color: #fff;
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
}

/* Color input */
[data-bs-theme=dark] .form-control[type="color"] {
    border-color: var(--bs-border-color);
}

/* Validation states */
[data-bs-theme=dark] .was-validated .form-control:valid,
[data-bs-theme=dark] .form-control.is-valid {
    border-color: var(--bs-success);
    background-color: var(--bs-dark);
}

[data-bs-theme=dark] .was-validated .form-control:invalid,
[data-bs-theme=dark] .form-control.is-invalid {
    border-color: var(--bs-danger);
    background-color: var(--bs-dark);
}

/* Datalists */
[data-bs-theme=dark] datalist {
    background-color: var(--bs-dark);
    color: #fff;
}

[data-bs-theme=dark] .form-select:focus {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-primary);
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Dark mode styling for select elements */
[data-bs-theme=dark] .form-select {
    color: #fff;
    /* White text color for dark mode */
    background-color: var(--bs-dark);
    /* Dark background */
    border-color: var(--bs-border-color);
    /* Proper border color for dark mode */
}

/* Styling for select options in dark mode */
[data-bs-theme=dark] .form-select option {
    color: #fff;
    /* White text for options */
    background-color: var(--bs-dark);
    /* Dark background for options */
}

/* Fix for select dropdown in dark mode */
[data-bs-theme=dark] .form-select option:checked,
[data-bs-theme=dark] .form-select option:hover,
[data-bs-theme=dark] .form-select option:focus,
[data-bs-theme=dark] .form-select option:active {
    background-color: var(--bs-primary);
    /* Use primary color for selected items */
    color: #fff;
}

/* Fix for Firefox which has different behavior */
[data-bs-theme=dark] .form-select:-moz-focusring {
    color: #fff;
    text-shadow: none;
}

/* Styling for select when focused/active in dark mode */
[data-bs-theme=dark] .form-select:focus {
    border-color: var(--bs-primary);
    /* Primary color border when focused */
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
    /* Focus shadow */
}

[data-bs-theme=dark] .form-select:focus {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-primary);
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Dark mode override for select focus style */
[data-bs-theme=dark] .form-control:focus {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-primary);
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

[data-bs-theme=dark] .form-control {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
    /* Change this to match form-select */
}

/* Fix for input-group-text in dark mode to match date inputs */
[data-bs-theme=dark] .input-group-text {
    color: #fff;
    background-color: var(--bs-dark);
    border-color: var(--bs-border-color);
}

/* Ensure consistent border color with other form elements */
[data-bs-theme=dark] .input-group>.input-group-text {
    border-color: var(--bs-border-color);
}

/* Ensure input groups with date inputs have consistent styling */
[data-bs-theme=dark] .input-group:has(input[type="date"]) .input-group-text {
    border-color: var(--bs-border-color) !important;
}


/* Dark mode styling for custom color selector */
[data-bs-theme=dark] .custom-color-selector .color-select-box {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
}

[data-bs-theme=dark] .custom-color-selector .color-dropdown-menu {
    color: #fff !important;
    background-color: var(--bs-dark) !important;
    border-color: var(--bs-border-color);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.5);
}

[data-bs-theme=dark] .custom-color-selector .color-option {
    color: #fff !important;
}

[data-bs-theme=dark] .custom-color-selector .color-option:hover {
    background-color: rgba(255, 255, 255, 0.1);
    color: #fff !important;
}

[data-bs-theme=dark] .custom-color-selector .dropdown-arrow {
    border-color: #fff transparent transparent transparent;
}

[data-bs-theme=dark] .custom-color-selector .color-label {
    color: #fff;
}


[data-bs-theme=dark] .custom-color-selector .color-block {
    border: 1px solid rgba(255, 255, 255, 0.2);
}


[data-bs-theme=dark] .custom-color-selector .color-block[style*="background-color: #000000"] {
    border: 1px solid rgba(255, 255, 255, 0.5);
}

[data-bs-theme=dark] .color-option[data-value="none"] .color-option-label {
    color: #fff !important;
}

[data-bs-theme=dark] .color-option {
    background-color: rgba(255, 255, 255, 0.1);
}

[data-bs-theme=dark] .color-option:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

[data-bs-theme=dark] .btn-outline-primary {
    color: #ffffff;
    border-color: #6c757d;
}

[data-bs-theme=dark] .btn-outline-primary:hover {
    background-color: rgba(108, 117, 125, 0.2);
    color: #ffffff;
}


[data-bs-theme=dark] .form-control.border-light {
    border-color: #6c757d !important;
}


[data-bs-theme=dark] .text-success {
    color: #4eff8b !important;
    font-weight: 700;
}

[data-bs-theme=dark] .text-danger {
    color: #ff6f6f !important;
    font-weight: 700;
}

.front-container {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    grid-auto-columns: 1fr;
    grid-template-columns: 1fr;
    grid-template-rows: min-content 1fr min-content;
}

.front-container .header {
    grid-area: 1/1/2/2;
}

.front-container .content {
    background-color: transparent;
    color: inherit;
    grid-area: 2/1/3/2;
}

.front-container .footer {
    grid-area: 3/1/4/2;
}

body[style*=background]:not(.boxed-layout)>.front-container,
.bg-img:not(.boxed-layout)>.front-container {
    background-color: rgba(var(--bs-body-bg-rgb), 0.5);
    background-attachment: fixed;
    background-blend-mode: screen;
}

.root:not(.hd--expanded) .content__header>.content__wrap {
    padding-bottom: 0 !important;
}

.content {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    display: flex;
    flex-direction: column;
    grid-area: 2/2/3/3;
    width: 100%;
    min-width: 0;
    max-width: 100vw;
}

.content .page-title {
    color: var(--nf-content-title-color);
    font-size: var(--nf-content-title-size);
    font-weight: var(--nf-content-title-weight);
    text-transform: capitalize;
}

.content__wrap {
    padding: 1rem 1rem;
}

@media (min-width: 768px) {
    .content__wrap {
        padding-inline: 1.5rem;
    }
}

@media (min-width: 992px) {
    .content__wrap {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1200px) {
    .content__wrap {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1400px) {
    .content__wrap {
        padding-inline: 2.5rem;
    }
}

.content-full-page {
    position: fixed;
    inset: 0;
    z-index: 999999;
    border-radius: 0 !important;
}

.body-sc>.root {
    position: relative;
    height: 100vh;
    overflow: hidden;
    z-index: 999999;
}

.body-sc .sidebar,
.body-sc .header,
.body-sc .content__header:after {
    z-index: 0 !important;
}

.single-content {
    display: flex;
    min-height: 0 !important;
    flex: 1 1 0;
}

@media (min-width: 576px) {
    .single-content-sm {
        display: flex;
        min-height: 0 !important;
        flex: 1 1 0;
    }
}

@media (min-width: 768px) {
    .single-content-md {
        display: flex;
        min-height: 0 !important;
        flex: 1 1 0;
    }
}

@media (min-width: 992px) {
    .single-content-lg {
        display: flex;
        min-height: 0 !important;
        flex: 1 1 0;
    }
}

@media (min-width: 1200px) {
    .single-content-xl {
        display: flex;
        min-height: 0 !important;
        flex: 1 1 0;
    }
}

@media (min-width: 1400px) {
    .single-content-xxl {
        display: flex;
        min-height: 0 !important;
        flex: 1 1 0;
    }
}

.searchbox {
    --nf-search-focus-bg: rgba(0, 0, 0, 0.15);
    --nf-search-collapsed-width: 20vw;
    --nf-search-expanded-width: 35vw;
    --nf-search-transition-duration: 0.35s;
    --nf-search-transition-delay: 0.15s;
    --nf-search-transition-timing: ease;
    width: auto;
}

.searchbox .searchbox__input {
    padding-right: calc(1ex + 2rem);
    transition: width var(--nf-search-transition-duration) var(--nf-search-transition-timing) var(--nf-search-transition-delay), background-color var(--nf-search-transition-duration) var(--nf-search-transition-timing) var(--nf-search-transition-delay);
}

.searchbox .searchbox__input:focus {
    transition: width var(--nf-search-transition-duration) var(--nf-search-transition-timing) var(--nf-search-transition-delay), background-color var(--nf-search-transition-duration) var(--nf-search-transition-timing) var(--nf-search-transition-delay);
}

.searchbox .searchbox__input.bg-transparent {
    background-color: transparent !important;
    border: 0;
    box-shadow: none !important;
    color: inherit;
}

.searchbox .searchbox__input.bg-transparent:focus {
    background-color: var(--nf-search-focus-bg) !important;
}

.searchbox.input-group:not(.has-validation)>.searchbox__input:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu) {
    border-radius: var(--bs-border-radius);
}

.searchbox .searchbox__btn {
    font-size: 1rem;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    transition: opacity var(--nf-search-transition-duration) var(--nf-search-transition-timing) var(--nf-search-transition-delay), visibility var(--nf-search-transition-duration) var(--nf-search-transition-timing) var(--nf-search-transition-delay);
    z-index: 5;
}

.searchbox.searchbox--auto-expand .searchbox__input {
    width: var(--nf-search-collapsed-width);
}

.searchbox.searchbox--auto-expand .searchbox__input:focus {
    width: var(--nf-search-expanded-width);
}

.searchbox.searchbox--hide-btn .searchbox__btn {
    opacity: 0;
    visibility: hidden;
}

.searchbox.searchbox--hide-btn .searchbox__input:focus~.searchbox__btn,
.searchbox.searchbox--hide-btn .searchbox__input:focus~div>.searchbox__btn {
    opacity: 1;
    transition: opacity var(--nf-search-transition-duration) var(--nf-search-transition-timing), visibility var(--nf-search-transition-duration) var(--nf-search-transition-timing);
    visibility: visible;
}

.scroll-container {
    --nf-btn-scroll-bg: var(--bs-primary);
    --nf-btn-scroll-color: var(--bs-primary-color);
    --nf-btn-scroll-border: 3px solid var(--bs-body-bg);
    --nf-btn-scroll-border-radius: 50%;
    --nf-btn-scroll-size: 4em;
    --nf-btn-scroll-right-margin: 1rem;
    --nf-btn-scroll-bottom-margin: 1rem;
    min-height: var(--nf-btn-scroll-size);
    pointer-events: none;
    position: absolute;
    right: var(--nf-btn-scroll-right-margin);
    top: min(100% - var(--nf-btn-scroll-size), 120vh);
    bottom: var(--nf-btn-scroll-size);
    clip-path: inset(0 0 0 0);
    z-index: 999;
}

.scroll-page {
    align-items: center;
    background-color: var(--nf-btn-scroll-bg);
    border: var(--nf-btn-scroll-border);
    border-radius: var(--nf-btn-scroll-border-radius);
    color: var(--nf-btn-scroll-color) !important;
    cursor: pointer;
    display: flex;
    justify-content: center;
    pointer-events: visible;
    position: sticky;
    right: var(--nf-btn-scroll-right-margin);
    text-decoration: none;
    top: calc(100vh - var(--nf-btn-scroll-size) - var(--nf-btn-scroll-bottom-margin));
    width: var(--nf-btn-scroll-size);
    z-index: 99999;
}

.scroll-page:after {
    border-style: solid;
    border-width: 3px 3px 0 0;
    content: "";
    display: inline-block;
    height: 30%;
    left: 35%;
    pointer-events: none;
    position: absolute;
    top: 43%;
    transform-origin: center center;
    transform: rotate(-45deg);
    width: 30%;
}

.root:before {
    background-color: var(--nf-backdrop-bg);
    content: "";
    display: block;
    inset: 0;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    visibility: hidden;
    z-index: -1;
}

.root.mn--show:before,
.root.sb--show:before {
    cursor: pointer;
    opacity: 1;
    pointer-events: visible;
    visibility: visible;
    z-index: 9998;
}

.timeline {
    --nf-timeline-line-color: var(--bs-primary);
    --nf-timeline-line-style: solid;
    --nf-timeline-line-width: 2px;
    --nf-timeline-point-color: var(--bs-primary);
    --nf-timeline-point-gap: 0.25rem;
    --nf-timeline-point-size: 0.5rem;
    --nf-timeline-point-media-size: 2.25rem;
    --nf-timeline-entry-gap-x: 0.75rem;
    --nf-timeline-entry-gap-y: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: var(--nf-timeline-entry-gap-y);
}

.timeline .tl-time:not(:empty) {
    min-width: 7rem;
    text-align: end;
}

.timeline .tl-time .tl-date {
    font-size: 90%;
}

.timeline .tl-time .tl-time {
    color: var(--bs-heading-color);
    font-weight: 700;
}

.timeline .tl-entry {
    display: flex;
    gap: var(--nf-timeline-entry-gap-x);
}

.timeline .tl-point:before {
    background-color: var(--nf-timeline-point-color);
    border-radius: 50%;
    content: "";
    display: block;
    height: var(--nf-timeline-point-size);
    transform: translateY(0.75ex);
    width: var(--nf-timeline-point-size);
}

.timeline .tl-point:after {
    border-inline-start: var(--nf-timeline-line-width) var(--nf-timeline-line-style) var(--nf-timeline-line-color);
    content: "";
    display: block;
    height: calc(100% - var(--nf-timeline-point-size) - var(--nf-timeline-point-gap) * 2 + var(--nf-timeline-entry-gap-y));
    inset: calc(0.75ex + var(--nf-timeline-point-gap)) auto auto calc(50% - var(--nf-timeline-line-width) / 2);
    position: relative;
}

.timeline .tl-media {
    flex: 0 0 var(--nf-timeline-point-media-size);
}

.timeline .tl-media i {
    align-items: center;
    display: flex;
    justify-content: center;
}

.timeline .tl-media:after {
    border-inline-start: var(--nf-timeline-line-width) var(--nf-timeline-line-style) var(--nf-timeline-line-color);
    content: "";
    display: block;
    height: calc(100% - var(--nf-timeline-point-media-size) - var(--nf-timeline-point-gap) * 2 + var(--nf-timeline-entry-gap-y));
    inset: var(--nf-timeline-point-gap) auto auto calc(50% - var(--nf-timeline-line-width) / 2);
    position: relative;
}

.timeline .tl-entry.active .tl-icon .ratio {
    box-shadow: 0 0 0 var(--nf-timeline-line-width), 0 0 0 calc(var(--nf-timeline-line-width) * 2) var(--nf-timeline-line-color);
}

.timeline .tl-entry.active .tl-point:before {
    background-color: transparent;
    box-shadow: 0 0 0 var(--nf-timeline-line-width) var(--nf-timeline-point-color);
}

.timeline .tl-entry.active .tl-point:after {
    height: calc(100% - var(--nf-timeline-line-width) - var(--nf-timeline-point-size) - var(--nf-timeline-point-gap) * 2 + var(--nf-timeline-entry-gap-y));
    top: calc(0.75ex + var(--nf-timeline-point-gap) + var(--nf-timeline-line-width));
}

.timeline .tl-entry:last-child .tl-point:after,
.timeline .tl-entry:last-child .tl-media:after {
    border-color: var(--bs-secondary);
    border-inline-start-style: dotted;
}

.timeline-two-column .tl-entry>.tl-time,
.timeline-two-column .tl-content {
    width: 50%;
}

.timeline-two-column .tl-content>* {
    display: inline-flex;
    flex-direction: column;
}

.timeline-two-column .tl-entry-start {
    flex-direction: row-reverse;
}

.timeline-two-column .tl-entry-start .tl-time {
    text-align: start;
}

.timeline-two-column .tl-entry-start .tl-content {
    align-items: flex-end;
    display: inline-flex;
    flex-direction: column;
    justify-content: end;
}

/* -- SPEECH BUBBLE -- */
.bubble {
    --nf-bubble-border-radius: 1.5rem;
    --nf-bubble-max-width: min(400px, 80%);
    --nf-bubble-primary-bg: var(--bs-primary);
    --nf-bubble-primary-color: var(--bs-primary-color);
    --nf-bubble-secondary-bg: var(--bs-white);
    --nf-bubble-secondary-color: var(--bs-dark);
    --nf-bubble-padding-x: 1rem;
    --nf-bubble-padding-y: 0.75rem;
    background-color: var(--nf-bubble-secondary-bg);
    border-radius: var(--nf-bubble-border-radius);
    border-end-start-radius: 0;
    color: var(--nf-bubble-secondary-color);
    display: inline-flex;
    flex-direction: column;
    max-width: var(--nf-bubble-max-width);
    padding: var(--nf-bubble-padding-y) var(--nf-bubble-padding-x);
    position: relative;
}

.bubble:after {
    border-color: transparent transparent var(--nf-bubble-secondary-bg) transparent;
    border-style: solid;
    border-width: 0 0 5px 7px;
    bottom: 0;
    content: "";
    display: block;
    left: -7px;
    position: absolute;
    width: 0;
    z-index: 1;
}

.bubble.bubble-primary,
.bubble-primary .bubble {
    background-color: var(--nf-bubble-primary-bg);
    border-radius: var(--nf-bubble-border-radius);
    border-end-end-radius: 0;
    color: var(--nf-bubble-primary-color);
}

.bubble.bubble-primary:after,
.bubble-primary .bubble:after {
    border-color: transparent transparent transparent var(--nf-bubble-primary-bg);
    border-width: 5px 0 0 7px;
    left: auto;
    right: -7px;
}

/* -- HEADER -- */
.root {
    --nf-header-bg: var(--bs-component-bg);
    --nf-header-color: var(--bs-component-color);
    --nf-header-secondary-color: var(--bs-secondary-color);
    --nf-header-border-color: var(--bs-border-color);
    --nf-header-height: 3.125rem;
    --nf-header-shadow: var(--bs-box-shadow-sm);
    --nf-header-btn-hover-bg: rgba(var(--bs-body-color-rgb), 0.1);
    --nf-header-btn-hover-color: var(--bs-heading-color);
    --nf-header-btn-border-radius: calc(var(--bs-border-radius) * 2);
    --nf-header-transition-duration: 0.35s;
    --nf-header-transition-timing: ease;
}

.header {
    background-color: var(--nf-header-bg);
    box-shadow: var(--nf-header-shadow);
    color: var(--nf-header-color);
    grid-area: 1/1/2/3;
}

.header__inner {
    align-items: center;
    display: flex;
    height: var(--nf-header-height);
    padding-inline: 1rem;
    height: 100px;
}

.root {
    --nf-brand-bg: transparent;
    --nf-brand-color: var(--nf-header-color);
    --nf-brand-size: 16px;
    --nf-brand-img-margin: 0.475rem 0.5rem;
    --nf-brand-font-size: 1.25rem;
    --nf-brand-font-weight: 500;
    --nf-brand-font-family: Ubuntu, sans-serif;
}

.header__brand {
    align-items: center;
    background-color: var(--nf-brand-bg);
    color: var(--nf-brand-color);
    display: flex;
    height: 100%;
    margin-inline-end: 0.5rem;
}

.brand-wrap {
    align-items: center;
    display: flex;
    position: relative;
}

.brand-wrap:hover .brand-title {
    box-shadow: 0 4px 0 -2px;
}

.brand-img {
    text-align: center;
    width: auto;
}

.brand-img img {
    width: var(--nf-brand-size);
    height: var(--nf-brand-size);
}

.brand-title {
    display: none;
}

.header__content {
    align-items: center;
    display: flex;
    flex-grow: 1;
    height: 100%;
    justify-content: space-between;
}

.header__content-start {
    flex-grow: 1;
}

.header__content-start,
.header__content-end {
    align-items: center;
    display: flex;
    gap: 0.3rem;
}

.header__content-start>*,
.header__content-end>* {
    margin: 0 -0.1rem;
}

.header__content-start>.vr,
.header__content-end>.vr {
    background-color: color-mix(in srgb, currentColor 50%, transparent);
}

.header__btn {
    -webkit-appearance: none;
    appearance: none;
    border-radius: var(--nf-header-btn-border-radius);
    border-color: transparent !important;
    box-shadow: none !important;
    color: inherit;
    font-size: 0.8rem;
}

.header__btn.show,
.header__btn:hover,
.header__btn:focus,
.header__btn:active {
    background-color: var(--nf-header-btn-hover-bg);
    color: var(--nf-header-btn-hover-color);
}

.header-searchbox {
    position: relative;
    margin-left: auto;
}

.header-searchbox .searchbox__input::placeholder {
    color: var(--nf-header-secondary-color);
}

.searchbox__backdrop {
    position: relative;
}

.hd--sticky .header {
    position: sticky;
    top: 0;
    z-index: 1000;
}

.hd--sticky.mn--sticky.mn--max .mainnav .mainnav__inner {
    height: calc(100vh - var(--nf-header-height));
    top: var(--nf-header-height);
}

@media (max-width: 767.98px) {
    .header__content .searchbox {
        background-color: var(--nf-header-bg);
        left: 0;
        padding-left: var(--bs-gutter-x, 0.75rem);
        padding-right: var(--bs-gutter-x, 0.75rem);
        position: fixed;
        top: 0;
        width: 100vw;
        z-index: 9999;
    }

    .header__content .searchbox .searchbox__input {
        position: fixed;
        top: -99rem;
    }

    .header__content .searchbox .searchbox__input,
    .header__content .searchbox .searchbox__input:focus~.searchbox__backdrop {
        margin: 1rem 0;
    }

    .header__content .searchbox .searchbox__input,
    .header__content .searchbox .searchbox__btn {
        transition-duration: 0s;
    }

    @supports (-webkit-overflow-scrolling: touch) {
        .header__content .searchbox .searchbox__input {
            font-size: 16px;
        }
    }

    .header__content .searchbox .searchbox__input:focus {
        background-color: var(--nf-header-btn-hover-bg) !important;
        position: static;
    }

    .header__content .searchbox .searchbox__input:focus~.searchbox__backdrop:after {
        background-color: var(--nf-backdrop-bg);
        bottom: 0;
        content: "";
        display: block;
        left: 0;
        position: fixed;
        right: 0;
        top: calc(3.1rem + calc(var(--bs-body-line-height) * var(--bs-body-font-size)));
    }

    .header__content .dropdown-menu {
        width: 100vw;
    }

    .hd--sticky .header__content .dropdown-menu {
        max-height: calc(100vh - (var(--nf-header-height)));
        overflow-x: hidden;
    }
}

@media (min-width: 768px) {

    .brand-img,
    .header-searchbox {
        margin: 0;
    }

    .brand-title {
        color: var(--nf-brand-color) !important;
        display: block;
        font-family: var(--nf-brand-font-family);
        font-size: var(--nf-brand-font-size);
        font-weight: var(--nf-brand-font-weight);
        line-height: var(--nf-brand-font-size);
        margin-inline: var(--nf-brand-img-margin);
        text-decoration: none !important;
    }

    .header .searchbox .searchbox__input.bg-transparent {
        border-radius: calc(var(--bs-border-radius) * 2) !important;
    }

    .header .searchbox .searchbox__input.bg-transparent:focus {
        background-color: var(--nf-header-btn-hover-bg) !important;
    }

    .searchbox__backdrop {
        height: 100%;
        margin: 0 !important;
        position: absolute;
        right: 0;
        top: 0;
    }
}

@media (min-width: 992px) {
    .mn--max .header__brand {
        transition: max-width var(--nf-header-transition-duration) var(--nf-header-transition-timing);
        width: 100%;
    }
}

@media (min-width: 768px) {
    .header__inner {
        padding-inline: 1.5rem;
    }
}

@media (min-width: 992px) {
    .header__inner {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1200px) {
    .header__inner {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1400px) {
    .header__inner {
        padding-inline: 2.5rem;
    }
}

@media (min-width: 992px) {

    .mn--min .header__brand,
    .mn--max .header__brand {
        margin-inline-end: 0;
    }
}

/* -- MAINNAV MENU LINK -- */
.mainnav__caption {
    color: var(--nf-mainnav-heading-color);
    padding-inline: calc(calc(var(--nf-mainnav-submenu-indent) - var(--nf-mainnav-submenu-dashed-margin)) + var(--nf-mainnav-link-padding-x));
}

.mainnav__inner .list-group-item,
.mainnav__inner .px-m {
    padding-inline: calc(calc(var(--nf-mainnav-submenu-indent) - var(--nf-mainnav-submenu-dashed-margin)) + var(--nf-mainnav-link-padding-x));
}

.root .mainnav__inner .mainnav__menu .nav-link:not(.active):not(:hover):not(:active) .nav-label:where(.fw-medium, .fw-semibold, .fw-bold, .fw-bolder),
.mn--min .mainnav__inner .mainnav__menu .nav-link .nav-label:where(.fw-medium, .fw-semibold, .fw-bold, .fw-bolder) {
    color: var(--nf-mainnav-heading-color);
}

.mainnav__inner .mainnav__menu .nav-link {
    padding: var(--nf-mainnav-link-padding-y) var(--nf-mainnav-link-padding-x);
}

.mainnav__inner .mainnav__menu>.nav-item>.nav-link {
    display: flex;
}

.mainnav__inner .mainnav__menu>.nav-item>.nav-link.active {
    background-color: var(--nf-mainnav-submenu-active-bg);
    border-radius: var(--nf-mainnav-submenu-border-radius);
    box-shadow: var(--nf-mainnav-submenu-active-shadow);
    color: var(--nf-mainnav-submenu-active-color);
    font-weight: 600;
}

.mainnav__inner .mainnav__menu>.nav-item>.nav-link.active i,
.mainnav__inner .mainnav__menu>.nav-item>.nav-link.active .nav-icon {
    color: inherit !important;
}

.root.mn--min .nav-item:not(.has-sub) .nav-link.active>.nav-label {
    color: var(--nf-mainnav-link-active);
    text-decoration: var(--nf-mainnav-link-active-underline) var(--nf-mainnav-link-active-underline-color);
    text-underline-offset: 5px;
}

.root.mn--min .nav-item:not(.has-sub) .nav-link.active>.nav-label:hover {
    color: var(--nf-mainnav-link-hover);
    text-decoration-color: currentColor;
}

.root .mainnav__inner .nav-link {
    color: var(--nf-mainnav-link-color);
}

.root .mainnav__inner .nav-link.disabled {
    opacity: 0.4;
}

.root .mainnav__inner .nav-link:hover {
    color: var(--nf-mainnav-link-hover);
}

.root .mainnav__inner .nav-link.active~.nav .active {
    color: var(--nf-mainnav-link-active);
    text-decoration: var(--nf-mainnav-link-active-underline) var(--nf-mainnav-link-active-underline-color);
    text-underline-offset: 5px;
}

.root .mainnav__inner .nav-link.active~.nav .active:hover {
    color: var(--nf-mainnav-link-hover);
    text-decoration-color: currentColor;
}

.root .mainnav__inner .nav-link i,
.root .mainnav__inner .nav-link .nav-icon {
    color: var(--nf-mainnav-icon-color) !important;
}

.mainnav__menu .mininav-content {
    flex-direction: column;
    flex-wrap: nowrap;
}

.mainnav__menu .mininav-toggle {
    align-items: center;
    display: flex;
}

.mainnav__menu .mininav-toggle>.nav-label,
.mainnav__menu .mininav-toggle .nav-icon,
.mainnav__menu .mininav-toggle i {
    pointer-events: none;
}

.mainnav__menu .mininav-toggle .nav-label {
    display: inline-block;
}

.mainnav__menu .mininav-toggle>.nav-label.mininav-content {
    height: auto !important;
}

.mainnav__menu .has-sub>.mininav-toggle:not(.has-badge):after {
    border-style: solid;
    border-width: 0.15em 0.15em 0 0;
    content: "";
    display: inline-block;
    height: 0.55em;
    margin-left: auto;
    transform: rotate(135deg);
    transition: transform calc(var(--nf-mainnav-transition-duration) / 2);
    width: 0.55em;
}

.mainnav__menu .has-sub>.mininav-toggle.collapsed:after {
    transform: rotate(45deg);
}

.root:not(.mn--min) .mainnav__menu .has-sub:not(.opened) .mininav-toggle.active:not(.collapsed)+.mininav-content {
    display: block;
}

@media (max-width: 991.98px) {
    .root .mininav-content {
        position: static !important;
        transform: none !important;
    }

    .root .mainnav__menu>.nav-item.has-sub .has-sub>.mininav-content {
        border-inline-start: 1px dashed var(--nf-mainnav-submenu-dashed-color);
        border-radius: 0;
        margin-inline-start: calc(calc(var(--nf-mainnav-submenu-indent-lv2) - 0.5em) + var(--nf-mainnav-link-padding-x)) !important;
        padding-inline-start: 0.5rem;
    }

    .root .mainnav__menu>.nav-item.has-sub .has-sub>.mininav-content>.nav-item>.nav-link {
        padding-inline: 0.75em;
    }

    .root .mainnav__menu>.nav-item.has-sub>.mininav-content {
        border-inline-start: 1px dashed var(--nf-mainnav-submenu-dashed-color);
        margin-inline-start: var(--nf-mainnav-submenu-dashed-margin) !important;
    }

    .root .mainnav__menu>.nav-item.has-sub>.mininav-content>.nav-item>.nav-link {
        padding-inline-start: calc(calc(var(--nf-mainnav-submenu-indent) - var(--nf-mainnav-submenu-dashed-margin)) + var(--nf-mainnav-link-padding-x));
    }
}

@media (min-width: 992px) {
    .root:not(.mn--min) .mininav-content {
        position: static !important;
        transform: none !important;
    }

    .root:not(.mn--min) .mainnav__menu>.nav-item.has-sub .has-sub>.mininav-content {
        border-inline-start: 1px dashed var(--nf-mainnav-submenu-dashed-color);
        margin-inline-start: calc(0.25em + var(--nf-mainnav-link-padding-x)) !important;
        padding-inline-start: 0.5rem;
    }

    .root:not(.mn--min) .mainnav__menu>.nav-item.has-sub .has-sub>.mininav-content>.nav-item>.nav-link {
        padding-inline: 0.75em;
    }

    .root:not(.mn--min) .mainnav__menu>.nav-item.has-sub>.mininav-content {
        border-inline-start: 1px dashed var(--nf-mainnav-submenu-dashed-color);
        margin-inline-start: var(--nf-mainnav-submenu-dashed-margin) !important;
    }

    .root:not(.mn--min) .mainnav__menu>.nav-item.has-sub>.mininav-content>.nav-item>.nav-link {
        padding-inline-start: calc(calc(var(--nf-mainnav-submenu-indent) - var(--nf-mainnav-submenu-dashed-margin)) + var(--nf-mainnav-link-padding-x));
    }
}

/* -- MAIN NAVIGATION - MINI / COLLAPSED MODE -- */
@media (min-width: 992px) {
    .mn--min {
        --nf-mainnav-min-icon-color: var(--bs-primary-text-emphasis);
        --nf-mainnav-min-icon-active-color: var(--bs-primary-color);
        --nf-mainnav-min-submenu-padding-x: 0.5rem;
        --nf-mainnav-min-submenu-padding-y: 0.5rem;
        --nf-mainnav-min-submenu-active-bg: var(--bs-primary);
        --nf-mainnav-min-submenu-active-color: var(--bs-primary-color);
        --nf-mainnav-min-shadow: var(--bs-box-shadow-lg);
        --nf-mainnav-min-submenu-link-padding-x: 0.75rem;
        --nf-mainnav-min-submenu-link-padding-y: 0.7rem;
        padding: 0 !important;
    }

    .mn--min .mainnav {
        max-width: var(--nf-mainnav-min-width);
        transition: max-width var(--nf-mainnav-min-transition-duration) var(--nf-mainnav-min-transition-timing);
        z-index: 1000;
    }

    .mn--min .mainnav__inner .mainnav__menu>.nav-item>.nav-link {
        padding: 0.59rem;
    }

    .mn--min .mainnav__bottom-content,
    .mn--min .mainnav__top-content {
        padding-inline: calc((var(--nf-mainnav-min-width) - calc(var(--bs-body-font-size) + 1.5rem)) / 2);
    }

    .mn--min .header__inner {
        padding-left: 0;
    }

    .mn--min .header__brand {
        justify-content: center;
        max-width: var(--nf-mainnav-min-width);
        padding-inline-start: 0;
        transition: max-width var(--nf-mainnav-min-transition-duration) var(--nf-mainnav-min-transition-timing);
        width: 100%;
    }

    .mn--min.mn--sticky.hd--expanded .content__header::before {
        z-index: 100;
    }

    .mn--min.mn--sticky.hd--expanded .mainnav {
        z-index: 99;
    }

    .mn--min.hd--sticky .mainnav__inner {
        top: var(--nf-header-height);
        z-index: auto;
    }

    .mn--sticky.mn--min.hd--sticky .mainnav__inner {
        height: calc(100vh - var(--nf-header-height));
    }

    .mn--min .mainnav__caption {
        display: block;
        max-height: 0;
        overflow: hidden;
        visibility: hidden;
    }

    .mn--min .mainnav__widget .mininav-content {
        min-width: 13rem;
    }

    .mn--min .mainnav__widget .mininav-content .mainnav-widget-toggle[data-bs-toggle=collapse] {
        pointer-events: none;
    }

    .mn--min .mainnav__widget .mininav-content .nav {
        display: block !important;
    }

    .mn--min .mainnav__avatar {
        height: auto;
        width: 2rem;
    }

    .mn--min .mainnav__categoriy {
        border-bottom: 1px solid var(--nf-mainnav-border-color);
    }

    .mn--min .d-mn-min {
        display: block;
    }

    .mn--min .d-mn-max,
    .mn--min .d-mn-max:not(.show),
    .mn--min .brand-title,
    .mn--min .mainnav__menu>.has-sub>.nav-link:after,
    .mn--min .mainnav__menu>.nav-item>.nav-link .nav-label:not(.show) {
        display: none;
    }

    .mn--min .mainnav__menu>.nav-item>.nav-link {
        justify-content: center;
    }

    .mn--min .mainnav__menu>.nav-item>.nav-link i,
    .mn--min .mainnav__menu>.nav-item>.nav-link .nav-icon {
        color: var(--nf-mainnav-min-icon-color) !important;
    }

    .mn--min .mainnav__menu>.nav-item>.nav-link.active {
        background-color: var(--nf-mainnav-min-submenu-active-bg);
        color: var(--nf-mainnav-min-submenu-active-color);
    }

    .mn--min .mainnav__menu>.nav-item>.nav-link.active i,
    .mn--min .mainnav__menu>.nav-item>.nav-link.active .nav-icon {
        color: var(--nf-mainnav-min-icon-active-color) !important;
    }

    .mn--min .mainnav__menu>.nav-item,
    .mn--min .mainnav__menu>.nav-item>.nav-link i {
        margin: 0 !important;
    }

    .mn--min .mainnav__menu>.nav-item {
        margin-bottom: 0.25rem !important;
        width: 100%;
    }

    .mn--min .mainnav__menu>.has-sub .has-sub>.nav-link {
        gap: 2.5rem;
    }

    .mn--min .mininav-toggle {
        cursor: pointer;
    }

    .mn--min .mininav-toggle .nav-label {
        color: var(--nf-mainnav-color);
    }

    .mn--min .mininav-content {
        background-color: var(--nf-mainnav-bg);
        border-radius: var(--nf-mainnav-submenu-border-radius);
        box-shadow: var(--nf-mainnav-min-shadow);
        margin-inline-start: calc((var(--nf-mainnav-min-width) - calc(var(--bs-body-font-size) + 1.5rem)) / 2) !important;
        max-width: 19rem;
        min-width: 11rem;
        padding: var(--nf-mainnav-min-submenu-padding-y) var(--nf-mainnav-min-submenu-padding-x);
        white-space: nowrap;
    }

    .mn--min .mininav-content .nav-link {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        padding: var(--nf-mainnav-min-submenu-link-padding-y) var(--nf-mainnav-min-submenu-link-padding-x);
    }

    .mn--min .mininav-content:not(.show) {
        display: none;
    }

    .mn--min .mininav-content.show {
        position: fixed;
        top: -100rem;
        z-index: 100;
    }

    .mn--min .mininav-content .arrow {
        position: absolute;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 7px 7px 7px 0;
        border-color: transparent var(--nf-mainnav-bg) transparent transparent;
        left: -6px;
    }

    .mn--min .mininav-content:not(.nav) {
        padding: 0.75rem 0.25rem;
    }

    .mn--min .mininav-content.nav-label {
        padding: 0.75rem var(--bs-nav-link-padding-x);
    }

    .mn--min .mininav-content.collapsing {
        transition: 0s !important;
    }

    .mn--min .mainnav__top-content {
        flex: 1 1 0;
        min-height: 0 !important;
    }

    .mn--min .mainnav__bottom-content {
        z-index: 100;
    }
}

/* -- MAIN NAVIGATION - MAX / EXPANDED MODE -- */
@media (min-width: 992px) {
    .mn--max .mainnav {
        position: relative;
    }

    .mn--max .mainnav__inner {
        position: absolute;
    }

    .mn--max .mainnav {
        transition: max-width var(--nf-mainnav-max-transition-duration) var(--nf-mainnav-max-transition-timing);
        will-change: max-width;
    }

    .mn--max .mainnav__widget .mininav-content {
        height: max-content;
    }

    .mn--max .mainnav__caption {
        display: block;
        overflow: hidden;
        max-height: 3rem;
        transition: max-height var(--nf-mainnav-max-transition-duration) calc(var(--nf-mainnav-max-transition-duration) * 1.5);
    }

    .mn--max .header__inner {
        padding-inline-start: 0;
    }
}

@media (min-width: 992px) and (min-width: 992px) {

    .mn--max .header__content,
    .mn--min .header__content {
        top: 1.25rem;
        padding-inline-start: 1.25rem;
    }
}

@media (min-width: 992px) and (min-width: 1200px) {

    .mn--max .header__content,
    .mn--min .header__content {
        top: 1.25rem;
        padding-inline-start: 1.25rem;
    }
}

@media (min-width: 992px) and (min-width: 1400px) {

    .mn--max .header__content,
    .mn--min .header__content {
        top: 2.5rem;
        padding-inline-start: 2.5rem;
    }
}

@media (min-width: 992px) {
    .mn--max .header__brand {
        padding-inline-start: calc(0.625rem + var(--nf-mainnav-link-padding-x));
        max-width: var(--nf-mainnav-max-width);
        width: var(--nf-mainnav-max-width);
        will-change: max-width;
    }
}

/* -- DEFAULT MAIN NAVIGATION -- */
.root {
    --nf-mainnav-bg: var(--bs-component-bg);
    --nf-mainnav-color: var(--bs-body-color);
    --nf-mainnav-secondary-color: var(--bs-secondary-color);
    --nf-mainnav-link-color: var(--bs-body-color);
    --nf-mainnav-link-hover: var(--bs-link-hover-color);
    --nf-mainnav-link-active: var(--bs-heading-color);
    --nf-mainnav-link-active-underline: underline dotted;
    --nf-mainnav-link-active-underline-color: rgba(var(--bs-body-color-rgb), 0.5);
    --nf-mainnav-link-padding-x: 1.25rem;
    --nf-mainnav-link-padding-y: 0.59rem;
    --nf-mainnav-icon-color: var(--bs-primary-text-emphasis);
    --nf-mainnav-heading-color: var(--bs-heading-color);
    --nf-mainnav-border-color: var(--bs-border-color);
    --nf-mainnav-padding: 0.75rem;
    --nf-mainnav-transition-duration: 0.35s;
    --nf-mainnav-transition-timing: ease;
    --nf-mainnav-submenu-active-bg: var(--bs-primary);
    --nf-mainnav-submenu-active-color: var(--bs-primary-color);
    --nf-mainnav-submenu-active-shadow: none;
    --nf-mainnav-submenu-indent: 2.25em;
    --nf-mainnav-submenu-indent-lv2: 0.75em;
    --nf-mainnav-submenu-border-radius: var(--bs-border-radius);
    --nf-mainnav-submenu-dashed-margin: 2.25em;
    --nf-mainnav-submenu-dashed-color: var(--bs-primary-border-subtle);
}

.mn--max,
.mn--min {
    --nf-mainnav-max-width: 13.75rem;
    --nf-mainnav-max-transition-duration: 0.35s;
    --nf-mainnav-max-transition-timing: ease;
    --nf-mainnav-min-width: 0;
    --nf-mainnav-min-transition-duration: 0.35s;
    --nf-mainnav-min-transition-timing: ease;
}

.mainnav {
    --bs-secondary-color: var(--nf-mainnav-secondary-color);
    display: flex;
    grid-area: 2/1/3/2;
    max-width: var(--nf-mainnav-max-width);
    width: min(75vw, var(--nf-mainnav-max-width));
}

.mainnav__inner {
    background-color: var(--nf-mainnav-bg);
    color: var(--nf-mainnav-color);
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
}

.mainnav__inner :where(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6):not(.mainnav__caption) {
    color: var(--nf-mainnav-heading-color);
}

.mainnav__inner :where(.border-top, .border-end, .border-bottom, .border-start) {
    border-color: var(--nf-mainnav-border-color) !important;
}

.mainnav__inner .dropdown-toggle:after {
    color: var(--nf-mainnav-heading-color);
}

.d-mn-max,
.d-mn-max.collapse {
    display: block;
}

.d-mn-min {
    display: none;
}

.nav-label {
    white-space: nowrap;
}

.mainnav__avatar.border {
    padding: 0.1rem;
}

.mainnav__top-content {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: auto;
    width: 100%;
}

.mainnav__top-content.os-host-overflow {
    overflow: visible;
}

.mainnav__bottom-content {
    background-color: var(--nf-mainnav-bg);
    bottom: 0;
    margin-top: auto;
    position: sticky;
}

.mainnav__top-content,
.mainnav__bottom-content {
    padding-inline: var(--nf-mainnav-padding);
}

.mn--show .mainnav {
    transform: translateX(0);
    z-index: 9999;
}

.mn--show .mainnav,
.mainnav {
    transition: transform var(--nf-mainnav-transition-duration) var(--nf-mainnav-transition-timing);
}

.mn--sticky .mainnav__inner {
    height: 100vh;
    position: sticky;
    top: 0;
}

.root:not(.mn--max):not(.mn--min) .mainnav {
    position: absolute;
    inset: 0 auto;
}

.root:not(.mn--max):not(.mn--min):not(.mn--show) .mainnav {
    z-index: 1002;
}

@media (max-width: 991.98px) {
    .mainnav__menu .mininav-toggle .nav-label {
        position: static !important;
        transform: none !important;
    }

    .mn--min .mainnav {
        inset: 0 auto;
        position: absolute;
    }

    .mn--min:not(.mn--show) .mainnav {
        transform: translateX(max(-75vw, calc(var(--nf-mainnav-max-width) * -1 - 0.0625rem)));
        z-index: 1002;
    }
}

@media (max-width: 991.98px) {
    .mn--max .mainnav {
        inset: 0 auto;
        position: absolute;
    }

    .mn--max:not(.mn--show) .mainnav {
        transform: translateX(calc(var(--nf-mainnav-max-width) * -1 - 0.0625rem));
        z-index: 1002;
    }
}

/* -- MAIN NAVIGATION - OFF CANVAS / SLIDE MODE -- */
.mn--slide {
    --nf-mainnav-slide-width: 13.75rem;
    --nf-mainnav-slide-transition-duration: 0.35s;
    --nf-mainnav-slide-transition-timing: ease;
}

.mn--slide .mainnav {
    max-width: 75vw;
    width: var(--nf-mainnav-slide-width);
    transform: translateX(max(-75vw, calc(var(--nf-mainnav-slide-width) * -1) - 0.0625rem));
}

.mn--slide .mainnav,
.mn--slide.mn--show .mainnav {
    transition: transform var(--nf-mainnav-slide-transition-duration) var(--nf-mainnav-slide-transition-timing);
}

.mn--slide.mn--show .mainnav {
    transform: translateX(0);
}

/* -- MAIN NAVIGATION - OFF CANVAS / PUSH MODE -- */
.mn--push {
    --nf-mainnav-push-width: 13.75rem;
    --nf-mainnav-push-transition-duration: 0.35s;
    --nf-mainnav-push-transition-timing: ease;
}

.mn--push .mainnav {
    max-width: 75vw;
    width: var(--nf-mainnav-push-width);
    transform: translateX(max(-75vw, calc(var(--nf-mainnav-push-width) * -1) - 0.0625rem));
}

.mn--push .mainnav,
.mn--push .content,
.mn--push .header,
.mn--push.mn--show .mainnav,
.mn--push.mn--show .content,
.mn--push.mn--show .header {
    transition: transform var(--nf-mainnav-push-transition-duration) var(--nf-mainnav-push-transition-timing);
}

.mn--push.mn--show .mainnav {
    transform: translateX(0);
    z-index: 9999;
}

.mn--push.mn--show .content,
.mn--push.mn--show .header {
    transform: translateX(min(75vw, var(--nf-mainnav-push-width)));
}

.mn--push.mn--show.sb--show.sb--pinned .sidebar {
    transform: translateX(min(75vw, var(--nf-mainnav-push-width)));
}

/* -- MAIN NAVIGATION - OFF CANVAS / REVEAL MODE -- */
.mn--reveal {
    --nf-mainnav-reveal-width: 13.75rem;
    --nf-mainnav-reveal-transition-duration: 0.35s;
    --nf-mainnav-reveal-transition-timing: ease;
}

.mn--reveal .mainnav {
    max-width: 75vw;
    pointer-events: none;
    transform: translateX(max(-75vw, calc(var(--nf-mainnav-reveal-width) * -1) - 0.0625rem));
    transform: translateX(0) !important;
    width: var(--nf-mainnav-reveal-width);
    z-index: 5 !important;
}

.mn--reveal .header {
    z-index: 12;
}

.mn--reveal .content,
.mn--reveal .sidebar {
    z-index: 10;
}

.mn--reveal.sb--pinned .sidebar {
    z-index: 11;
}

.mn--reveal .content,
.mn--reveal .header,
.mn--reveal.mn--show .content,
.mn--reveal.mn--show .header {
    transition: transform var(--nf-mainnav-reveal-transition-duration) var(--nf-mainnav-reveal-transition-timing);
    will-change: transform;
}

.mn--reveal.mn--show .mainnav {
    pointer-events: visible;
}

.mn--reveal.mn--show:before,
.mn--reveal.mn--show .content,
.mn--reveal.mn--show .header {
    transform: translateX(min(75vw, var(--nf-mainnav-reveal-width)));
}

.mn--reveal.mn--show:before {
    transition: opacity var(--nf-mainnav-reveal-transition-duration), var(--nf-mainnav-reveal-transition-duration) !important;
}

.mn--reveal.mn--show.sb--show.sb--pinned .sidebar {
    transform: translateX(min(75vw, var(--nf-mainnav-reveal-width)));
}

/* -- SIDEBARS -- */
.root {
    --nf-sidebar-bg: var(--bs-component-bg);
    --nf-sidebar-color: var(--bs-body-color);
    --nf-sidebar-width: 17.1875rem;
    --nf-sidebar-shadow: var(--bs-box-shadow-lg);
    --nf-sidebar-padding-x: 0.75rem;
    --nf-sidebar-padding-y: 1rem;
    --nf-sidebar-transition-duration: 0.35s;
    --nf-sidebar-transition-timing: ease;
}

.sidebar {
    align-items: stretch;
    background-color: var(--nf-sidebar-bg);
    box-sizing: content-box;
    color: var(--nf-sidebar-color);
    display: flex;
    flex-direction: column;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    transform: translateX(var(--nf-sidebar-width));
    visibility: hidden;
    width: 0;
    z-index: 1002;
}

.sidebar .scrollable-content {
    scrollbar-width: none;
}

.sidebar__inner {
    height: 100vh;
    overflow-x: hidden;
    padding-block: var(--nf-sidebar-padding-y);
    position: sticky;
    top: 0;
}

.sidebar__wrap {
    padding-inline: var(--nf-sidebar-padding-x);
}

.sb--show .sidebar {
    overflow: visible;
    transform: translateX(0);
    visibility: visible;
    width: var(--nf-sidebar-width);
    z-index: 9999;
}

.sidebar {
    transition: visibility var(--nf-sidebar-transition-duration), width 0s linear var(--nf-sidebar-transition-duration), padding var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing), transform var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing);
}

.sb--show .sidebar {
    transition: visibility var(--nf-sidebar-transition-duration), padding var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing), transform var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing);
}

@media (min-width: 1195px) {
    .sb--pinned .sidebar {
        overflow: visible;
        transform: translateX(0);
        visibility: visible;
        width: var(--nf-sidebar-width);
        z-index: 9999;
    }

    .sidebar {
        transition: visibility var(--nf-sidebar-transition-duration), width 0s linear var(--nf-sidebar-transition-duration), padding var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing), transform var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing);
    }

    .sb--pinned .sidebar {
        transition: visibility var(--nf-sidebar-transition-duration), padding var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing), transform var(--nf-sidebar-transition-duration) var(--nf-sidebar-transition-timing);
    }
}

.sidebar__stuck {
    display: none;
}

/* -- DISABLE THE SIDEBAR BACKDROP -- */
.sb--bd-0.sb--show:before {
    opacity: 0;
}

.sb--bd-0.sb--show .sidebar {
    box-shadow: var(--nf-sidebar-shadow);
}

/* -- SIDEBAR - STATIC POSITION */
.sb--static .sidebar__inner {
    overflow: visible;
    position: static;
}

/* -- SIDEBAR - STUCK -- */
.sidebar__stuck {
    display: none;
}

.sb--stuck.sb--show:before {
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
}

.sb--stuck.sb--show:not(.sb--pinned) .sidebar {
    box-shadow: var(--nf-sidebar-shadow);
}

.sb--stuck .sidebar__stuck {
    display: flex;
}

/* -- SIDEBAR UNITE -- */
.root {
    --nf-sidebar-unite-bg: var(--nf-header-bg);
    --nf-sidebar-unite-color: var(--nf-header-color);
    --nf-sidebar-unite-secondary-color: var(--nf-header-secondary-color);
    --nf-sidebar-unite-active-bg: var(--nf-header-btn-hover-bg);
    --nf-sidebar-unite-active-color: var(--nf-header-btn-hover-color);
    --nf-sidebar-unite-border-color: var(--nf-header-border-color);
    --nf-sidebar-unite-outer-border-radius: calc(var(--bs-border-radius) * 1.5);
}

.sb--unite .sidebar {
    --bs-border-color: var(--nf-sidebar-unite-border-color);
    --bs-secondary-color: var(--nf-sidebar-unite-secondary-color);
    --bs-emphasis-color: var(--nf-sidebar-unite-active-color);
    background-color: var(--nf-sidebar-unite-bg);
    color: var(--nf-sidebar-unite-color);
}

.sb--unite .sidebar .nav-link.active,
.sb--unite .sidebar .nav-link:hover,
.sb--unite .sidebar .nav-link:focus,
.sb--unite .sidebar :where(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6) {
    color: var(--nf-sidebar-unite-active-color);
}

.sb--unite .sidebar .btn-primary,
.sb--unite .sidebar .form-check-input:checked {
    background-color: rgba(0, 0, 0, 0.25);
    border-color: rgba(0, 0, 0, 0.25);
}

.sb--unite .sidebar .btn-link {
    color: inherit;
}

.sb--unite .sidebar .nav-link {
    color: var(--nf-sidebar-unite-color);
}

.sb--unite .sidebar .nav-link i,
.sb--unite .sidebar .nav-link .nav-icon {
    color: rgba(var(--nf-sidebar-unite-color), 0.65) !important;
}

.sb--unite .sidebar .list-group-item-action,
.sb--unite .sidebar .list-group-item {
    color: var(--nf-sidebar-unite-color);
}

.sb--unite .sidebar .list-group-item-action:hover,
.sb--unite .sidebar .list-group-item-action:focus {
    background-color: var(--nf-sidebar-unite-active-bg);
    color: var(--nf-sidebar-unite-active-color);
}

/* -- PINNED SIDEBAR */
@media (min-width: 1195px) {
    .sb--pinned:not(.mn--show):before {
        opacity: 0;
        pointer-events: none;
        visibility: hidden;
    }

    .sb--pinned.hd--sticky .sidebar__inner {
        top: var(--nf-header-height);
    }

    .sb--pinned .content__boxed {
        padding-right: var(--nf-sidebar-width);
    }

    .sb--pinned:not(.mn--push):not(.mn--reveal) .sidebar {
        transition-duration: 0s !important;
    }

    .sb--pinned:not(.sb--unite) .sidebar {
        background-color: transparent;
    }

    .sb--pinned:not(.sb--unite) .sidebar .sidebar__inner {
        background-color: var(--bs-body-bg);
        color: var(--bs-body-color);
    }

    .sb--pinned:not(.sb--static) .sidebar .sidebar__inner {
        height: calc(100vh - var(--nf-header-height));
        overflow-x: hidden;
    }

    .sb--pinned .sidebar {
        height: calc(100% - var(--nf-header-height));
        top: var(--nf-header-height);
        z-index: 999;
    }

    .sb--pinned .sidebar .sidebar__inner {
        border-top-left-radius: var(--nf-sidebar-unite-outer-border-radius);
    }

    .sb--pinned.root.mn--push .sidebar,
    .sb--pinned.root.mn--push.mn--show .sidebar {
        transition-duration: var(--nf-mainnav-push-transition-duration);
    }

    .sb--pinned.root.mn--push.mn--show .sidebar {
        transform: translateX(var(--nf-mainnav-push-width));
    }

    .sb--pinned.root.mn--reveal .sidebar,
    .sb--pinned.root.mn--reveal.mn--show .sidebar {
        transition-duration: var(--nf-mainnav-reveal-transition-duration);
    }

    .sb--pinned.root.mn--reveal.mn--show .sidebar {
        transform: translateX(var(--nf-mainnav-reveal-width));
    }

    .sb--pinned.sb--unite {
        --nf-header-shadow: none;
    }

    .sb--pinned.sb--unite .sidebar {
        content-visibility: visible;
    }

    .sb--pinned.sb--unite .sidebar__inner {
        border-radius: 0;
    }

    .sb--pinned.sb--unite.tm--primary-mn .header__content {
        box-shadow: none;
    }

    .sb--pinned.sb--unite .sidebar:after {
        background-color: var(--nf-sidebar-unite-bg);
        content: "";
        display: block;
        height: var(--nf-sidebar-unite-outer-border-radius);
        margin-left: calc(var(--nf-sidebar-unite-outer-border-radius) * -1);
        margin-top: -100vh;
        -webkit-mask-image: radial-gradient(circle at 0 var(--nf-sidebar-unite-outer-border-radius), transparent 0, transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
        mask-image: radial-gradient(circle at 0 var(--nf-sidebar-unite-outer-border-radius), transparent 0, transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
        position: relative;
        top: var(--nf-header-height);
        width: calc(var(--nf-sidebar-unite-outer-border-radius) + 0.06125rem);
    }

    .sb--pinned.sb--unite.hd--sticky .sidebar:after {
        position: sticky;
    }

    .sb--pinned.sb--unite.tm--tall-hd .content__header:after,
    .sb--pinned.sb--unite.tm--expanded-hd .content__header:after {
        align-self: flex-end;
        background-color: var(--nf-sidebar-unite-bg);
        content: "";
        display: block;
        height: calc(var(--nf-sidebar-unite-outer-border-radius) + 0.0625rem);
        -webkit-mask-image: radial-gradient(circle at 0 var(--nf-sidebar-unite-outer-border-radius), transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
        mask-image: radial-gradient(circle at 0 var(--nf-sidebar-unite-outer-border-radius), transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
        position: absolute;
        top: 100%;
        transition: transform 0.35s ease;
        width: calc(var(--nf-sidebar-unite-outer-border-radius) + 0.0625rem);
        z-index: 1000;
    }

    .sb--pinned.sb--unite.tm--tall-hd .content__header,
    .sb--pinned.sb--unite.tm--expanded-hd .content__header {
        --nf-header-expand-border-radius: 0;
    }
}

/* COLORED HEADER */
.tm--full-hd,
.tm--fair-hd,
.tm--tall-hd,
.tm--expanded-hd,
.header--primary {
    --nf-header-bg: var(--bs-primary);
    --nf-header-color: rgba(var(--bs-primary-color-rgb), 0.75);
    --nf-header-secondary-color: rgba(var(--bs-primary-color-rgb), 0.35);
    --nf-header-border-color: var(--bs-primary-border);
    --nf-header-shadow: var(--bs-box-shadow-sm);
    --nf-header-btn-hover-bg: rgba(0, 0, 0, 0.2);
    --nf-header-btn-hover-color: var(--bs-primary-color);
    --nf-brand-bg: initial;
    --nf-brand-color: var(--bs-primary-color);
}

/* COLORED BRAND */
.tm--primary-brand .header__brand,
.header-brand--primary {
    --nf-brand-bg: var(--bs-primary);
    --nf-brand-color: var(--bs-primary-color);
}

/* MAINNAV COLORED */
.tm--primary-mn,
.mainnav--primary {
    --nf-mainnav-bg: var(--bs-primary);
    --nf-mainnav-color: var(--bs-primary-color);
    --nf-mainnav-secondary-color: rgba(var(--bs-primary-color-rgb), 0.4);
    --nf-mainnav-link-color: rgba(var(--bs-primary-color-rgb), 0.7);
    --nf-mainnav-link-hover: var(--bs-primary-color);
    --nf-mainnav-link-active: var(--bs-primary-color);
    --nf-mainnav-link-active-underline-color: rgba(var(--bs-primary-color-rgb), 0.3);
    --nf-mainnav-icon-color: var(--bs-primary-color);
    --nf-mainnav-heading-color: var(--bs-primary-color);
    --nf-mainnav-border-color: var(--bs-primary-border);
    --nf-mainnav-submenu-active-bg: rgba(0, 0, 0, 0.25);
    --nf-mainnav-submenu-dashed-color: var(--bs-primary-border);
    --nf-mainnav-min-icon-color: var(--bs-primary-color);
    --nf-mainnav-min-icon-active-color: var(--bs-primary-color);
    --nf-mainnav-min-submenu-active-bg: rgba(0, 0, 0, 0.25);
    --nf-mainnav-min-submenu-active-color: var(--bs-primary-color);
    --nf-mainnav-min-shadow: 0 1rem 2rem rgba(26, 29, 33, 0.5);
}

/* -- EXPANDED HEADER -- */
.tm--tall-hd,
.tm--expanded-hd {
    --nf-header-shadow: none;
    --nf-header-expand-bg: var(--bs-primary);
    --nf-header-expand-color: rgba(var(--bs-primary-color-rgb), 0.65);
    --nf-header-expand-title-color: var(--bs-primary-color);
    --nf-header-expand-headings-color: var(--nf-header-expand-title-color);
    --nf-header-expand-height: 37.5vh;
    --nf-header-expand-border-radius: 0% 0% 50% 50%/0% 0% 12vh 12vh;
}

.tm--tall-hd .content__header,
.tm--expanded-hd .content__header {
    background-color: var(--nf-header-expand-bg);
    border-radius: var(--nf-header-expand-border-radius);
    color: var(--nf-header-expand-color);
    display: flex;
    flex-direction: column;
    position: relative;
    width: 100%;
}

.tm--tall-hd .content__header :where(h1, h2, h3, h4, h5, h6),
.tm--expanded-hd .content__header :where(h1, h2, h3, h4, h5, h6) {
    color: var(--nf-header-expand-headings-color);
}

.tm--tall-hd .content__header .text-body-emphasis:not(.btn),
.tm--expanded-hd .content__header .text-body-emphasis:not(.btn) {
    color: var(--nf-header-expand-headings-color) !important;
}

.tm--tall-hd .content__header .page-title,
.tm--expanded-hd .content__header .page-title {
    color: var(--nf-header-expand-title-color);
}

.tm--tall-hd .content__header .page-title:after,
.tm--expanded-hd .content__header .page-title:after {
    background-color: var(--nf-header-expand-title-color);
}

.tm--tall-hd .content__header .btn-link,
.tm--expanded-hd .content__header .btn-link {
    color: var(--nf-header-expand-title-color);
    opacity: 0.85;
}

.tm--tall-hd .content__header .breadcrumb-item:before,
.tm--expanded-hd .content__header .breadcrumb-item:before,
.tm--tall-hd .content__header .breadcrumb-item.active,
.tm--expanded-hd .content__header .breadcrumb-item.active {
    color: var(--nf-header-expand-title-color);
}

.tm--tall-hd .content__header .breadcrumb-item>a,
.tm--expanded-hd .content__header .breadcrumb-item>a {
    color: var(--nf-header-expand-color);
}

.tm--tall-hd .content__header .breadcrumb-item>a:hover,
.tm--expanded-hd .content__header .breadcrumb-item>a:hover,
.tm--tall-hd .content__header .breadcrumb-item>a:focus,
.tm--expanded-hd .content__header .breadcrumb-item>a:focus {
    color: var(--nf-header-expand-title-color);
}

.modal-open .tm--tall-hd .content__header+.content__boxed,
.modal-open .tm--expanded-hd .content__header+.content__boxed {
    position: relative;
    z-index: auto !important;
}

body[style*=padding-right] .tm--tall-hd .content__header+.content__boxed,
body[style*=padding-right] .tm--expanded-hd .content__header+.content__boxed {
    position: relative;
    z-index: auto !important;
}

.tm--tall-hd .content__header.overlapping .content__wrap:after,
.tm--expanded-hd .content__header.overlapping .content__wrap:after {
    content: "";
    display: block;
    height: var(--nf-header-expand-height);
    width: 100%;
}

.tm--tall-hd .content__header.overlapping+.content__boxed,
.tm--expanded-hd .content__header.overlapping+.content__boxed {
    margin-top: calc((var(--nf-header-expand-height) + 1rem) * -1);
    z-index: 99;
}

.tm--tall-hd .content__header:not(.overlapping):not(.rounded-0),
.tm--expanded-hd .content__header:not(.overlapping):not(.rounded-0) {
    min-height: 10.9375rem;
    padding-bottom: 10vh;
}

.mn--max.tm--expanded-hd.mn--sticky .content__header:before,
.mn--min.tm--expanded-hd.mn--sticky .content__header:before {
    position: sticky;
    top: -0.06125rem;
}

.mn--max.tm--expanded-hd.hd--sticky .content__header:not(.rounded-0):before,
.mn--max.tm--expanded-hd.mn--sticky .content__header:not(.rounded-0):before,
.mn--min.tm--expanded-hd.hd--sticky .content__header:not(.rounded-0):before,
.mn--min.tm--expanded-hd.mn--sticky .content__header:not(.rounded-0):before {
    margin-bottom: calc(var(--nf-sidebar-unite-outer-border-radius) * 2);
}

.mn--max.tm--expanded-hd.hd--sticky .content__header.overlapping:not(.rounded-0):before,
.mn--max.tm--expanded-hd.mn--sticky .content__header.overlapping:not(.rounded-0):before,
.mn--min.tm--expanded-hd.hd--sticky .content__header.overlapping:not(.rounded-0):before,
.mn--min.tm--expanded-hd.mn--sticky .content__header.overlapping:not(.rounded-0):before {
    margin-bottom: calc(var(--nf-sidebar-unite-outer-border-radius) + 12vh);
}

.mn--max.tm--expanded-hd.hd--sticky .content__header:before,
.mn--min.tm--expanded-hd.hd--sticky .content__header:before {
    position: sticky;
    top: var(--nf-header-height);
}

.mn--max.tm--expanded-hd.hd--sticky .content__header:not(.rounded-0) .content__wrap,
.mn--max.tm--expanded-hd.mn--sticky .content__header:not(.rounded-0) .content__wrap,
.mn--min.tm--expanded-hd.hd--sticky .content__header:not(.rounded-0) .content__wrap,
.mn--min.tm--expanded-hd.mn--sticky .content__header:not(.rounded-0) .content__wrap {
    margin-top: calc((var(--nf-sidebar-unite-outer-border-radius)) * 3 * -1);
}

.mn--max.tm--expanded-hd.hd--sticky .content__header.overlapping:not(.rounded-0) .content__wrap,
.mn--max.tm--expanded-hd.mn--sticky .content__header.overlapping:not(.rounded-0) .content__wrap,
.mn--min.tm--expanded-hd.hd--sticky .content__header.overlapping:not(.rounded-0) .content__wrap,
.mn--min.tm--expanded-hd.mn--sticky .content__header.overlapping:not(.rounded-0) .content__wrap {
    margin-top: calc((var(--nf-sidebar-unite-outer-border-radius) * 2 + 12vh) * -1);
}

.mn--max.tm--expanded-hd .content__header .content__wrap,
.mn--min.tm--expanded-hd .content__header .content__wrap {
    margin-top: calc(var(--nf-sidebar-unite-outer-border-radius) * -1);
}

.mn--max.tm--expanded-hd .content__header:before,
.mn--min.tm--expanded-hd .content__header:before {
    background-color: var(--bs-primary);
    content: "";
    display: block;
    height: var(--nf-sidebar-unite-outer-border-radius);
    margin-left: 0;
    -webkit-mask-image: radial-gradient(circle at 0 var(--nf-sidebar-unite-outer-border-radius), transparent 0, transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
    mask-image: radial-gradient(circle var(--nf-sidebar-unite-outer-border-radius) at 0 var(--nf-sidebar-unite-outer-border-radius), transparent 0, transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
    position: relative;
    top: -0.06125rem;
    transform: translateX(calc(var(--nf-sidebar-unite-outer-border-radius) * -1));
    width: calc(var(--nf-sidebar-unite-outer-border-radius) + 0.06125rem);
    z-index: 1001;
}

@supports (-webkit-touch-callout: none) {

    .mn--max.tm--expanded-hd .content__header:before,
    .mn--min.tm--expanded-hd .content__header:before {
        -webkit-mask-image: radial-gradient(circle at 0 var(--nf-sidebar-unite-outer-border-radius), transparent 0, transparent var(--nf-sidebar-unite-outer-border-radius), black var(--nf-sidebar-unite-outer-border-radius));
    }
}

/* -- FAIR HEADER -- */
.tm--fair-hd,
.tm--tall-hd {
    --nf-header-shadow: none;
}

.tm--fair-hd .header__brand,
.tm--tall-hd .header__brand {
    background-color: transparent;
    color: var(--nf-brand-color);
}

.tm--fair-hd .header__brand .brand-title,
.tm--tall-hd .header__brand .brand-title {
    color: inherit !important;
}

.tm--fair-hd.tm--expanded-hd .content__header:before,
.tm--expanded-hd.tm--tall-hd .content__header:before {
    visibility: hidden;
}

@media (min-width: 992px) {

    .tm--fair-hd.mn--min .header__brand,
    .mn--min.tm--tall-hd .header__brand,
    .tm--fair-hd.mn--max .header__brand,
    .mn--max.tm--tall-hd .header__brand {
        background-color: var(--nf-mainnav-bg);
        color: var(--nf-mainnav-link-active);
    }
}

/* -- CENTERED LAYOUT -- */
@media (min-width: 900px) {

    .centered-layout .tm--fair-hd .header__brand,
    .centered-layout .tm--tall-hd .header__brand {
        padding-inline: 1.25rem;
    }

    .centered-layout .tm--fair-hd.mn--min .header__inner,
    .centered-layout .mn--min.tm--tall-hd .header__inner,
    .centered-layout .tm--fair-hd.mn--max .header__inner,
    .centered-layout .mn--max.tm--tall-hd .header__inner {
        max-width: none !important;
    }

    .centered-layout .tm--fair-hd.mn--min .header__brand,
    .centered-layout .mn--min.tm--tall-hd .header__brand {
        width: 100%;
        max-width: var(--nf-mainnav-min-width);
        justify-content: center;
        padding: 0;
        margin-inline-end: 0 !important;
    }

    .centered-layout .tm--fair-hd.mn--min .header__brand .brand-title,
    .centered-layout .mn--min.tm--tall-hd .header__brand .brand-title {
        display: none;
    }

    .centered-layout .tm--fair-hd.mn--max .header__brand,
    .centered-layout .mn--max.tm--tall-hd .header__brand {
        width: var(--nf-mainnav-max-width);
    }
}

@media (min-width: 1120px) {

    .centered-layout .tm--fair-hd.mn--max .header__brand,
    .centered-layout .mn--max.tm--tall-hd .header__brand {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1200px) {

    .centered-layout .tm--fair-hd.mn--max .header__brand,
    .centered-layout .mn--max.tm--tall-hd .header__brand {
        padding-inline: 1.25rem;
    }
}

/* -- FULL HEADER -- */
.tm--full-hd {
    --bs-box-shadow-alpha-sm: .5;
    --nf-header-shadow: 0 0.125rem 0.25rem rgba(var(--bs-box-shadow-color), var(--bs-box-shadow-alpha-sm));
}

[data-bs-theme=dark] .tm--full-hd .header {
    --bs-box-shadow-alpha-sm: .1;
}

/* -- MAINNAV PRIMARY -- */
.tm--primary-mn {
    --nf-header-shadow: var(--bs-box-shadow-sm);
}

@media (min-width: 992px) {
    .tm--primary-mn:where(.mn--min, .mn--max) {
        --nf-brand-bg: var(--bs-primary);
        --nf-brand-color: var(--bs-primary-color);
    }

    .tm--primary-mn:where(.mn--min, .mn--max) .header__content {
        box-shadow: var(--nf-header-shadow);
    }
}

.tm--primary-mn.mn--reveal {
    background-color: black;
}

.tm--primary-mn.mn--reveal:before {
    outline: 1px solid var(--bs-primary);
}

.tm--primary-mn.mn--reveal .content {
    background-color: var(--bs-body-bg);
}

/* -- PRIMARY BRAND -- */
.tm--primary-brand {
    --nf-header-shadow: var(--bs-box-shadow-sm);
}

.tm--primary-brand .header__inner {
    padding-inline-start: 0;
}

.tm--primary-brand .header__brand {
    padding-inline: 1rem;
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .tm--primary-brand .header__brand {
        padding-inline: 1.5rem;
    }
}

@media (min-width: 992px) and (max-width: 1199.98px) {
    .tm--primary-brand .tm--primary-brand:not(.mn--min):not(.mn--max) .header__brand {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1200px) and (max-width: 1399.98px) {
    .tm--primary-brand .tm--primary-brand:not(.mn--min):not(.mn--max) .header__brand {
        padding-inline: 1.25rem;
    }
}

@media (min-width: 1400px) {
    .tm--primary-brand .tm--primary-brand:not(.mn--min):not(.mn--max) .header__brand {
        padding-inline: 2.5rem;
    }
}

@media (min-width: 992px) {

    .tm--primary-brand.mn--min .header__brand,
    .tm--primary-brand.mn--max .header__brand {
        border-radius: 0;
    }

    .tm--primary-brand.mn--max .header__brand {
        padding-inline: calc(0.625rem + var(--nf-mainnav-link-padding-x)) 0;
    }
}

/* -- TALL HEADER -- */
/* -- TRANSITION TIMING FUNCTIONS -- */
.in-quart.centered-layout .content__header:before,
.in-quart .mn--reveal.mn--show:before,
.in-quart :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0.755, 0.045, 0.915, 0.135) !important;
}

.out-quart.centered-layout .content__header:before,
.out-quart .mn--reveal.mn--show:before,
.out-quart :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0.015, 0.77, 0.04, 0.985) !important;
}

.in-back.centered-layout .content__header:before,
.in-back .mn--reveal.mn--show:before,
.in-back :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0.705, -0.155, 0.735, 0.045) !important;
}

.out-back.centered-layout .content__header:before,
.out-back .mn--reveal.mn--show:before,
.out-back :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0.28, 1.02, 0.36, 1.145) !important;
}

.in-out-back.centered-layout .content__header:before,
.in-out-back .mn--reveal.mn--show:before,
.in-out-back :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(1, -0.28, 0, 1.275) !important;
}

.steps.centered-layout .content__header:before,
.steps .mn--reveal.mn--show:before,
.steps :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0, 0.955, 1, 0.045) !important;
}

.jumping.centered-layout .content__header:before,
.jumping .mn--reveal.mn--show:before,
.jumping :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0.96, 0.005, 0, 1.075) !important;
}

.rubber.centered-layout .content__header:before,
.rubber .mn--reveal.mn--show:before,
.rubber :where(.mainnav, .content, .header, .header__brand, .sidebar, .offcanvas, .collapsing, .searchbox__input, .dropdown-menu, .mininav-toggle:after, .sb--pinned .content__boxed) {
    transition-timing-function: cubic-bezier(0.135, 1.525, 0, 0.9) !important;
}

/* -- OPTIMIZE -- */
.offcanvas-body,
.dropdown-menu,
.sidebar {
    content-visibility: auto;
}

.sidebar img[loading=lazy],
.dropdown-menu img[loading=lazy],
.offcanvas img[loading=lazy] {
    display: none;
}

.sb--show .sidebar img[loading=lazy],
.dropdown-menu.show img[loading=lazy],
.offcanvas.show img[loading=lazy] {
    display: unset;
}

@media (min-width: 1195px) {
    .sb--pinned .sidebar img[loading=lazy] {
        display: unset;
    }
}

/* -- MEDIA PRINT -- */
@media print {

    html,
    body,
    #root,
    .content {
        background-color: transparent;
    }

    #root {
        background-color: #fff;
        color: #555e69;
        display: block;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    .h1,
    .h2,
    .h3,
    .h4,
    .h5,
    .h6 {
        color: #30353b;
    }

    .content {
        color: inherit !important;
    }

    .badge,
    .btn {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    .card {
        background-color: transparent;
        box-shadow: none;
    }

    .bg-light {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
        background-color: #ecf1f4 !important;
    }

    .text-muted,
    .text-body-secondary {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
        color: #727e8c !important;
    }

    .table {
        border-color: #ecf1f4 !important;
        color: #30353b !important;
    }

    .table thead tr,
    .table thead th {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
        background-color: transparent !important;
        color: #30353b !important;
    }

    .table tbody tr,
    .table tbody td {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
        border-color: #ecf1f4;
        color: #30353b !important;
    }

    .table tbody td {
        background-color: transparent;
        box-shadow: none;
    }

    .table.table-striped tbody tr:nth-child(odd) td {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
        background-color: #ecf1f4;
    }

    .header,
    .sidebar,
    #mainnav-container,
    .content__header,
    footer,
    .scroll-container,
    #_dm-settingsToggler {
        display: none !important;
    }

    .content__header.overlapping+.content__boxed {
        margin-top: 0 !important;
    }

    .d-md-flex,
    .d-lg-flex,
    .d-xl-flex {
        display: flex !important;
    }
}

/* -- RIBBON -- */
.ribbon {
    height: 75px;
    overflow: hidden;
    position: absolute;
    right: -5px;
    text-align: right;
    top: -5px;
    width: 75px;
    z-index: 1;
}

.ribbon span {
    background: #e53f50;
    box-shadow: 0 3px 10px -3px rgba(var(--bs-box-shadow-color), 1);
    color: #fff;
    display: block;
    font-size: 10px;
    font-weight: bold;
    line-height: 20px;
    position: absolute;
    right: -21px;
    text-align: center;
    text-transform: uppercase;
    top: 19px;
    transform: rotate(45deg);
    width: 100px;
}

.ribbon span:before {
    border-bottom: 3px solid transparent;
    border-left: 3px solid #e53f50;
    border-right: 3px solid transparent;
    border-top: 3px solid #e53f50;
    content: "";
    left: 0px;
    position: absolute;
    top: 100%;
    z-index: -1;
}

.ribbon span:after {
    border-bottom: 3px solid transparent;
    border-left: 3px solid transparent;
    border-right: 3px solid #e53f50;
    border-top: 3px solid #e53f50;
    content: "";
    position: absolute;
    right: 0px;
    top: 100%;
    z-index: -1;
}

/* -- ERROR CODE -- */
.error-code {
    font-size: 9rem !important;
    font-weight: 400;
    line-height: 1;
}

/* -- HOVER EFFECTS -- */
.hv-grow,
.hv-grow-parent .hv-gc,
.hv-grow:hover,
.hv-grow-parent:hover .hv-gc {
    transition: transform var(--nf-hv-transition-duration) var(--nf-hv-transition-timing);
}

.hv-outline:hover,
.hv-outline-parent:hover .hv-oc,
.hv-outline,
.hv-outline-parent .hv-oc {
    transition: outline var(--nf-hv-transition-duration) var(--nf-hv-transition-timing), outline-offset var(--nf-hv-transition-duration) var(--nf-hv-transition-timing), transform var(--nf-hv-transition-duration) var(--nf-hv-transition-timing);
}

.hv-grow:hover,
.hv-grow-parent:hover .hv-gc {
    backface-visibility: hidden;
    transform: scale(var(--nf-hv-grow-scale)) translateZ(0);
}

.hv-grow,
.hv-grow-parent,
.hv-outline,
.hv-outline-parent {
    --nf-hv-transition-duration: 0.35s;
    --nf-hv-transition-timing: ease;
}

.hv-grow,
.hv-grow-parent {
    --nf-hv-grow-scale: 1.07;
}

.hv-outline,
.hv-outline-parent {
    --nf-hv-outline-width: 0.125rem;
    --nf-hv-outline-offset: 0.3125rem;
    --nf-hv-outline-color: rgba(var(--bs-link-hover-color-rgb), 0);
    --nf-hv-outline-color-active: rgba(var(--bs-link-hover-color-rgb), 1);
}

.hv-outline,
.hv-outline-parent .hv-oc {
    outline: var(--nf-hv-outline-width) solid var(--nf-hv-outline-color);
    outline-offset: 0;
}

.hv-outline:hover,
.hv-outline-parent:hover .hv-oc {
    outline: var(--nf-hv-outline-width) solid;
    outline-color: var(--nf-hv-outline-color-active);
    outline-offset: var(--nf-hv-outline-offset);
}

.hv-outline.hv-outline-inherit,
.hv-outline-parent.hv-outline-inherit {
    --nf-hv-outline-color-active: inherit;
}

/* -- BOXED LAYOUT -- */
@media (min-width: max(1024px, 1200px)) {
    .boxed-layout {
        --nf-boxed-layout-bg: rgba(var(--bs-primary-rgb), 0.7);
        --nf-boxed-layout-bg-repeat: no-repeat;
        --nf-boxed-layout-bg-image: none;
        --nf-boxed-layout-bg-size: cover;
        --nf-boxed-layout-bg-attachment: fixed;
        --nf-boxed-layout-padding-y: 2rem;
        --nf-boxed-layout-max-width: 1200px;
        --nf-boxed-layout-border-radius: 0.75rem;
        background-attachment: var(--nf-boxed-layout-bg-attachment);
        background-color: var(--nf-boxed-layout-bg);
        background-image: var(--nf-boxed-layout-bg-image);
        background-repeat: var(--nf-boxed-layout-bg-repeat);
        background-size: var(--nf-boxed-layout-bg-size);
        background-blend-mode: exclusion;
        margin: 0 auto;
        max-width: var(--nf-boxed-layout-max-width);
        padding-block: var(--nf-boxed-layout-padding-y);
        padding-inline-end: 0 !important;
    }

    .boxed-layout:not(.solid-bg):after {
        content: "";
        position: fixed;
        inset: 0;
        background: linear-gradient(180deg, rgba(var(--bs-dark-rgb), 0.79) 29%, rgba(var(--bs-dark-rgb), 0.4) 75%);
        pointer-events: none;
        touch-action: none;
        z-index: -1;
    }

    .boxed-layout .root {
        -webkit-clip-path: inset(0 0 0 0 round var(--nf-boxed-layout-border-radius));
        clip-path: inset(0 0 0 0 round var(--nf-boxed-layout-border-radius));
    }

    .boxed-layout>.mn--reveal.mn--show:before {
        max-width: var(--nf-boxed-layout-max-width);
        margin: 0 auto;
        transition: transform var(--nf-mainnav-reveal-transition-duration) var(--nf-mainnav-reveal-transition-timing) !important;
        transform: translateX(calc(100% - var(--nf-boxed-layout-max-width) + var(--nf-mainnav-max-width)));
    }

    .boxed-layout .mega-dropdown {
        max-width: calc(75 * var(--nf-boxed-layout-max-width) / 100);
    }

    .boxed-layout .sidebar {
        top: var(--nf-boxed-layout-padding-y);
    }

    .boxed-layout .searchbox.searchbox--auto-expand .searchbox__input {
        max-width: calc(var(--nf-boxed-layout-max-width) / 2.2);
    }

    .boxed-layout>.sb--pinned .sidebar {
        top: calc(var(--nf-boxed-layout-padding-y) + var(--nf-header-height) + 0.0625rem);
    }

    .boxed-layout>.hd--sticky .header {
        outline: 1px solid var(--nf-header-bg);
    }
}

/* -- CENTERED LAYOUT -- */
@media (min-width: 900px) {
    .centered-layout>.root:not(.mn--max):not(.mn--min)>.mainnav {
        position: absolute;
        inset: 0 auto auto 0;
        height: 100%;
        min-height: 100vh;
    }

    .centered-layout>.root:not(.mn--max):not(.mn--min) .content__header>.content__wrap,
    .centered-layout>.root:not(.mn--max):not(.mn--min) .content__boxed:not(.content__header) {
        width: 900px;
        margin-inline: auto;
    }
}

@media (min-width: 1195px) {
    .centered-layout .sb--pinned .sidebar {
        transition-duration: 0s;
    }

    .centered-layout .sb--pinned:not(.mn--max):not(.mn--min).sb--unite .content__header:after {
        right: var(--nf-sidebar-width);
    }

    .centered-layout .sb--pinned:not(.mn--max):not(.mn--min) .content__header {
        padding: 0;
    }

    .centered-layout .sb--pinned:not(.mn--max):not(.mn--min) .content__boxed:not(.content__header),
    .centered-layout .sb--pinned:not(.mn--max):not(.mn--min) .content__header>.content__wrap {
        padding-right: calc(17.1875rem - (100vw - 900px) / 2);
    }
}

@media (min-width: 1300px) {
    .centered-layout .mainnav {
        position: absolute;
        inset: var(--nf-header-height) auto auto 0;
        height: calc(100% - var(--nf-header-height));
        min-height: 100vh;
    }

    .centered-layout .content__header>.content__wrap,
    .centered-layout .content__boxed:not(.content__header) {
        width: 900px;
        margin-inline: auto;
    }

    .centered-layout .mn--min.tm--expanded-hd .content__header:before {
        left: calc(var(--nf-mainnav-min-width) - var(--nf-sidebar-unite-outer-border-radius));
        transform: none;
        transition: left var(--nf-mainnav-min-transition-duration) var(--nf-mainnav-min-transition-timing);
    }

    .centered-layout .mn--max.tm--expanded-hd .content__header:before {
        left: calc(var(--nf-mainnav-max-width) - var(--nf-sidebar-unite-outer-border-radius));
        transform: none;
        transition: left var(--nf-mainnav-max-transition-duration) var(--nf-mainnav-max-transition-timing);
    }

    .centered-layout .sb--pinned.sb--unite .content__header:after {
        right: var(--nf-sidebar-width);
    }

    .centered-layout .sb--pinned .content__header {
        padding: 0;
    }

    .centered-layout .sb--pinned .content__boxed:not(.content__header),
    .centered-layout .sb--pinned .content__header>.content__wrap {
        padding-right: calc(17.1875rem - (100vw - 900px) / 2);
    }
}

[data-bs-theme=dark][data-scheme=gray] {
    --nf-content-title-ratio: 1.668129681;
    --nf-content-title-color: #697487;
}

[data-bs-theme=dark][data-scheme=navy] {
    --nf-content-title-ratio: 1.4020701145;
    --nf-content-title-color: #506999;
}


[data-bs-theme="dark"] .modal .card.bg-light {
    background-color: #23272b !important;
    border-color: #222 !important;
}

[data-bs-theme="dark"] .modal .card.bg-light #questionTitle,
[data-bs-theme="dark"] .modal .card.bg-light #questionContent {
    color: #fff !important;
}

[data-bs-theme=dark][data-scheme=ocean] {
    --nf-content-title-ratio: 2.0750737159;
    --nf-content-title-color: var(--bs-primary);
}

[data-bs-theme=dark][data-scheme=lime] {
    --nf-content-title-ratio: 3.3518191288;
    --nf-content-title-color: var(--bs-primary);
}

[data-bs-theme=dark][data-scheme=violet] {
    --nf-content-title-ratio: 1.5001083291;
    --nf-content-title-color: #895998;
}

[data-bs-theme=dark][data-scheme=orange] {
    --nf-content-title-ratio: 4.7836786022;
    --nf-content-title-color: var(--bs-primary);
}

/* teal color scheme */
[data-bs-theme=dark][data-scheme=teal] {
    --nf-content-title-ratio: 1.8525037737;
    --nf-content-title-color: #337f95;
}

[data-scheme=corn] {
    --nf-content-title-color: #b6a20a;
}

[data-bs-theme=dark][data-scheme=corn] {
    --nf-content-title-ratio: 8.1370717413;
    --nf-content-title-color: var(--bs-primary);
}

[data-bs-theme=dark][data-scheme=cherry] {
    --nf-content-title-ratio: 2.9395328057;
    --nf-content-title-color: var(--bs-primary);
}

[data-bs-theme=dark][data-scheme=coffee] {
    --nf-content-title-ratio: 1.9548759143;
    --nf-content-title-color: #907664;
}

[data-bs-theme=dark][data-scheme=pear] {
    --nf-content-title-ratio: 1.9612044672;
    --nf-content-title-color: #b25c79;
}

[data-bs-theme=dark][data-scheme=night] {
    --nf-content-title-ratio: 1.1097472633;
    --nf-content-title-color: #505359;
}


[data-bs-theme="dark"] .table.table-bordered,
[data-bs-theme="dark"] .table.table-striped {
    background-color: #343a40;
    color: #fff;
}

[data-bs-theme="dark"] .table.table-bordered th,
[data-bs-theme="dark"] .table.table-bordered td,
[data-bs-theme="dark"] .table.table-striped th,
[data-bs-theme="dark"] .table.table-striped td {
    background-color: #343a40;
    color: #fff;
    border-color: #495057;
}

[data-bs-theme="dark"] .table.table-bordered thead th,
[data-bs-theme="dark"] .table.table-striped thead th {
    background-color: #212529;
    color: #fff;
}


[data-bs-theme="dark"] .calendar-table,
[data-bs-theme="dark"] .calendar-total {
    background-color: #343a40;
    color: #fff;
}

[data-bs-theme="dark"] .calendar-table th,
[data-bs-theme="dark"] .calendar-table td,
[data-bs-theme="dark"] .calendar-total th,
[data-bs-theme="dark"] .calendar-total td {
    background-color: #343a40;
    color: #fff;
    border-color: #495057;
}

[data-bs-theme="dark"] .calendar-table thead th,
[data-bs-theme="dark"] .calendar-total thead th {
    background-color: #212529;
    color: #fff;
}




.top-info-container {
    width: 100%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.top-info-btn {
    flex: 1;
    min-width: 145px;
    white-space: nowrap;
    text-align: center;
}

.sidebar-toggler {
    min-width: auto !important;
    flex: 0 0 auto !important;
}

@media (max-width: 768px) {
    .top-info-container .top-info-btn:not(.sidebar-toggler) {
        display: none !important;
    }

    .top-info-container {
        justify-content: flex-end;
    }

    .sidebar-toggler {
        margin-left: auto;
    }
}

.brand-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 5px;
}

.brand-logo img {
    width: 32px;
    height: 32px;
}

.brand-logo span {
    font-size: 24px;
    font-weight: 500;
    color: white;
}

.brand-desc {
    color: #666;
    font-size: 14px;
    margin-bottom: 20px;
}

.input-group-text {
    background-color: transparent;
    border-right: 0;
    border-color: white !important;
}


.input-group-text ion-icon {
    font-size: 1.2rem;
    color: white;
}

.form-control::placeholder {
    color: rgba(255, 255, 255, 0.7) !important;
}

.login-section {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: center;
}

.full-width-box {
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    background-image: url("../img/7.jpg");
    background-size: cover;
    background-position: center;
    position: absolute;
    height: 100%;
}

.content__wrap {
    position: relative;
    z-index: 1;
}

.login-form .input-group-text,
.login-form .form-control,
.login-form .btn-primary {
    background-color: rgba(0, 0, 0, 0.7);
    border-color: white;
    color: white;
    padding: 10px 32px;
}

.login-form .btn-primary:hover {
    background-color: rgba(0, 0, 0, 0.8);
}

.login-title {
    color: white;
    background-color: rgba(0, 0, 0, 0.7);
    border: 1px solid white;
    padding: 10px 32px;
    width: 100%;
    display: block;
    border-radius: 5px;
}

.login-page {
    background-image: url(/assets/img/bg-login.png);
}

.login-card {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.login-card-body {
    padding: 0 0 10px 0 !important;
}

.brand-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 5px;
}

.brand-logo img {
    width: 32px;
    height: 32px;
}

.brand-logo span {
    font-size: 24px;
    font-weight: 500;
    color: white;
}

.brand-desc {
    color: #666;
    font-size: 14px;
    margin-bottom: 20px;
}

.input-group-text {
    background-color: transparent;
    border-right: 0;
    border-color: white !important;
}


.input-group-text ion-icon {
    font-size: 1.2rem;
    color: white;
}

.form-control::placeholder {
    color: rgba(255, 255, 255, 0.7) !important;
}

.login-section {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: center;
}

.full-width-box {
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    background-image: url("../img/7.jpg");
    background-size: cover;
    background-position: center;
    position: absolute;
    height: 100%;
}

.content__wrap {
    position: relative;
    z-index: 1;
}

.login-form .input-group-text,
.login-form .form-control,
.login-form .btn-primary {
    background-color: rgba(0, 0, 0, 0.7);
    border-color: white;
    color: white;
    padding: 10px 32px;
}

.login-form .btn-primary:hover {
    background-color: rgba(0, 0, 0, 0.8);
}

.login-title {
    color: white;
    background-color: rgba(0, 0, 0, 0.7);
    border: 1px solid white;
    padding: 10px 32px;
    width: 100%;
    display: block;
    border-radius: 5px;
}

/* Table Cell Auto Width Style */
.table {
    width: 100%;
    table-layout: auto;
}

.table th,
.table td {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 100px;
    font-weight: 700;
}

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* 머니 레이어 스타일 */
.money-layer-wrap {
    position: absolute;
    top: 100%;
    right: 0;
    width: 300px;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    z-index: 1000;
}

.money-layer-header {
    padding: 10px 15px;
    border-bottom: 1px solid #ddd;
}

.money-layer-title {
    margin: 0;
    font-size: 16px;
}

.money-layer-body {
    padding: 15px;
}

.money-layer-footer {
    padding: 10px 15px;
    border-top: 1px solid #ddd;
    text-align: right;
    gap: 5px;
    display: flex;
    justify-content: flex-end;
}

.money-layer-footer .btn {
    min-width: 60px;
}

/* 입력 필드와 버튼 높이 통일 */
.money-layer-wrap .form-control,
.money-layer-wrap .btn {
    height: 31px;
    padding-top: 2px;
    padding-bottom: 2px;
}

.money-layer-wrap .input-group {
    flex-wrap: nowrap;
}

.money-layer-wrap textarea.form-control {
    height: auto;
}


.ps-10 {
    padding-left: 4rem !important;
}

.ps-15 {
    padding-left: 6rem !important;
}

.ps-20 {
    padding-left: 8rem !important;
}

.ps-25 {
    padding-left: 10rem !important;
}

.ps-30 {
    padding-left: 12rem !important;
}

.ps-35 {
    padding-left: 14rem !important;
}

.ps-40 {
    padding-left: 16rem !important;
}


/* 헤더 영역의 스크롤 제약 해제 */
/* .header__content-start {
overflow: visible !important;
width: 1640px !important;
max-width: 2000px !important;
} */

/* 헤더 영역의 스크롤 컨테이너 스타일 */
.header-scroll-container {
    overflow-x: scroll !important;
    scrollbar-width: thin !important;
    scrollbar-color: #000 rgba(0, 0, 0, 0.1) !important;
    display: flex;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    padding: 10px !important;

    white-space: nowrap !important;
    position: relative !important;
    z-index: 5 !important;
    -webkit-overflow-scrolling: touch !important;
    min-width: 140px !important;
}

/* FHD 이하 해상도에서 헤더 스크롤 컨테이너 너비 조정 */
@media (max-width: 1920px) {
    .header-scroll-container {
        width: 1600px !important;
    }

    /* 왼쪽 메뉴가 축소됐을 때 헤더 스크롤 컨테이너 너비 확장 */
    .mn--min .header-scroll-container {
        width: 1900px !important;
    }
}

@media (max-width: 1820px) {
    .header-scroll-container {
        width: 1493px !important;
    }

    /* 왼쪽 메뉴가 축소됐을 때 헤더 스크롤 컨테이너 너비 확장 */
    .mn--min .header-scroll-container {
        width: 1793px !important;
    }
}

@media (max-width: 1600px) {
    .header-scroll-container {
        width: 1200px !important;
    }

    /* 왼쪽 메뉴가 축소됐을 때 헤더 스크롤 컨테이너 너비 확장 */
    .mn--min .header-scroll-container {
        width: 1600px !important;
    }
}

/* 1920px 이상에서 스크롤바 숨김 */
@media (min-width: 2020px) {
    .header-scroll-container {
        overflow-x: hidden !important;
        width: 2215px !important;
    }

    /* 왼쪽 메뉴가 축소됐을 때 헤더 스크롤 컨테이너 너비 확장 */
    .mn--min .header-scroll-container {
        width: 2100px !important;
    }

    .header-scroll-container::-webkit-scrollbar {
        display: none !important;
    }

}


/* 스크롤바 스타일 */
.header-scroll-container::-webkit-scrollbar {
    height: 8px !important;
    display: block !important;
}

.header-scroll-container::-webkit-scrollbar-thumb {
    background-color: #000 !important;
    border-radius: 4px !important;
    min-height: 30px !important;
}

.header-scroll-container::-webkit-scrollbar-track {
    background-color: rgba(0, 0, 0, 0.1) !important;
    border-radius: 4px !important;
}

/* 모바일 환경 최적화 */
/* @media (max-width: 1024px) {
.header-scroll-container {
  width: calc(100vw - 80px) !important;
}
} */

.left-menu {
    display: none;
    /* 기본적으로 숨김 */
}

/* 모바일에서만 표시 (768px 이하) */
@media (max-width: 768px) {
    .left-menu {
        display: block;
    }

    .header-scroll-container {
        display: none !important;
    }
}

.left-menu .btn {
    width: 100%;
    margin-bottom: 10px;
    text-align: left;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 1rem;
}

.left-menu .btn:last-child {
    margin-bottom: 0;
}

.left-menu .btn .title {
    display: flex;
    align-items: center;
}

.left-menu .btn .value {
    font-weight: normal;
}

/* 버튼 내 요소를 세로로 정렬하는 스타일 */
.nav-component .nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
}

/* 아이콘 크기 조정 */
.nav-component .nav-link ion-icon {
    display: block;
    margin-bottom: 3px;
}

/* 헤더 내의 PERFECT 텍스트와 버튼 배치 */
.header__inner {
    position: relative;
}

.header-title-center {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 20px;
    font-weight: bold;
    z-index: 10;
}

/* 헤더 내의 PERFECT 텍스트와 버튼 배치 */
.header__inner {
    position: relative;
}

.header-title-center {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 20px;
    font-weight: bold;
    z-index: 10;
    display: none;
    /* 기본적으로 숨김 */
}

.mobile-setting-btn {
    position: absolute;
    right: 15px;
    /* Changed back to right side positioning */
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    display: none !important;
    /* 기본적으로 숨김 */
    display: flex;
    /* Keep flex display */
    flex-direction: row;
    /* Keep horizontal layout */
    align-items: center;
    /* Center items vertically */

}

/* Add spacing between the buttons */
.mobile-setting-btn .sound-btn {
    margin-right: 5px;
    /* Keep spacing between buttons */
}

/* 모바일에서만 헤더 타이틀과 설정 버튼 표시 */
@media (max-width: 768px) {

    .header-title-center,
    .mobile-setting-btn {
        display: flex !important;
        flex-wrap: nowrap !important;
    }

    .nav-toggler {
        visibility: visible !important;
    }
}

/* 배경색 없는 텍스트만 있는 뱃지 */
.badge-text {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 0.35em 0.45em !important;
    /* 패딩 감소 */
    min-width: 1.05em !important;
    /* 원래 1.5em에서 30% 감소 */
    font-size: 0.85em;
    font-weight: 700;
    line-height: 1;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    background-color: transparent !important;
    color: #212529 !important;
    border: none;
    height: 1.5em;
}


.badge-customer {
    padding-left: 0.38em !important;
    /* 기본값 0.55em에서 30% 감소 */
    padding-right: 0.38em !important;
    /* 기본값 0.55em에서 30% 감소 */
    /* transform 제거하고 직접 패딩 조절로 변경 */
}

/* 뱃지 내부 텍스트 크기 유지를 위한 추가 스타일 */
.badge>span,
.badge-text>span {
    display: inline-block;
    transform: none !important;
    /* 텍스트 크기 보존 */
    font-size: 100% !important;
    /* 텍스트 크기 보존 */
}

/* Placeholder 스타일 */
.form-control::placeholder {
    color: #6c757d !important;
    opacity: 1;
}

.form-control:-ms-input-placeholder {
    color: #6c757d !important;
}

.form-control::-ms-input-placeholder {
    color: #6c757d !important;
}

/* 입력 필드 기본 스타일 */
.form-control {
    color: #000;
}

/* 선택상자 기본 스타일 */
.form-select {
    color: #000;
}

.form-select option {
    color: #000;
}

/* 입력 필드 포커스 스타일 */
.form-control:focus {
    color: #000;
    background-color: #fff;
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* 선택상자 포커스 스타일 */
.form-select:focus {
    color: #000 !important;
    background-color: #fff;
    border-color: #86b7fe;
    outline: 0;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* 금액 입력 필드 우측 정렬 */
.form-control.text-end {
    text-align: right;
}

/* 모달 내부 입력 필드 스타일 */
.modal .form-control,
.modal .form-select {
    background-color: #fff;
}

/* 입력 필드 비활성화 상태 */
.form-control:disabled,
.form-control[readonly],
.form-select:disabled {
    background-color: #e9ecef;
    opacity: 1;
}

/* 입력 필드 오류 상태 */
.form-control.is-invalid {
    border-color: #dc3545;
    padding-right: calc(1.5em + 0.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(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

/* 입력 필드 유효성 검사 메시지 */
.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 0.875em;
    color: #dc3545;
}

.form-control.is-invalid~.invalid-feedback {
    display: block;
}

/* 입력 필드 그룹 스타일 */
.input-group .form-control {
    position: relative;
    flex: 1 1 auto;
    width: 1%;
    min-width: 0;
}

.input-group>.form-control:focus {
    z-index: 3;
}

/* 입력 필드 그룹 버튼 스타일 */
.input-group .btn {
    position: relative;
    z-index: 2;
}

/* 입력 필드 그룹 텍스트 스타일 */
.input-group-text {
    display: flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    text-align: center;
    white-space: nowrap;
    /* background-color: #e9ecef; */
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
}


/* 색상 선택기 스타일 */
.select2-color-option,
.select2-color-selected {
    padding: 2px;
    width: 100%;
}

.color-block {
    height: 25px;
    width: 100%;
    border-radius: 3px;
}

.select2-container--default .select2-selection--single {
    height: 31px;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 29px;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 29px;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: #f0f0f0;
    color: #000;
}

.select2-container--default .select2-results__option[aria-selected=true] {
    background-color: #e9ecef;
}

.select2-dropdown {
    border-color: #ced4da;
}

.select2-container--default .select2-selection--single {
    border-color: #ced4da;
}

/* 색상 선택없음 스타일 */
.no-color-selected .select2-selection__rendered span {
    display: inline-block;
    width: 100%;
    text-align: left;
    padding-left: 8px;
}

/* 색상 선택 뒤 선택없음 선택 시 색상블록 숨김 */
.no-color-selected .select2-selection__rendered .select2-color-selected {
    display: none !important;
}

/* 색상 선택없음 텍스트 스타일 */
.no-color-text {
    padding-left: 8px;
    line-height: 29px;
    display: block !important;
}

/* 색상 선택없음 상태일 때 배경색 제거 */
.no-color-selected .select2-selection--single {
    background-color: #fff !important;
}

/* 기존 선택된 색상 완전히 제거 */
.no-color-selected .select2-selection__rendered .color-block {
    display: none !important;
}


/* 커스텀 색상 선택기 스타일 */
.custom-color-selector {
    position: relative;
    width: 100%;
}

.color-select-box {
    display: flex;
    align-items: center;
    height: 31px;
    padding: 0 8px;
    border: 1px solid var(--bs-border-color);
    border-radius: 4px;
    background-color: #fff;
    cursor: pointer;
    position: relative;
}

.color-label {
    flex-grow: 1;
    font-size: 11px;
    position: relative;
    z-index: 1;
    color: #212529;
    font-weight: 400;
}

.color-display {
    width: 100%;
    height: 29px;
    display: none;
    position: absolute;
    left: 0;
    top: 0;
    border-radius: 3px;
}

.dropdown-arrow {
    margin-left: auto;
    font-size: 10px;
    z-index: 2;
    position: relative;
    color: #888;
    display: flex;
    align-items: center;
    height: 100%;
}

/* 화살표를 기존 선택상자와 동일하게 변경 */
.dropdown-arrow:after {
    content: '';
    display: inline-block;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%2392969c' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 16px 12px;
    width: 16px;
    height: 12px;
}

.color-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background-color: #fff;
    border: 1px solid #ced4da;
    border-radius: 4px;
    margin-top: 2px;
    z-index: 9999;
    display: none;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
    overflow: hidden;
}

.color-dropdown-menu.open {
    display: block !important;
}

.color-option {
    padding: 15px;
    cursor: pointer;
}

.color-option:hover {
    background-color: #e9e9e9;
}

.color-block {
    width: 100%;
    height: 30px;
    border-radius: 0;
}

/* 추가: 색상 선택없음 스타일 */
.color-option[data-value="none"] {
    padding: 8px 15px;
}

.color-option[data-value="none"] .color-option-label {
    font-size: 14px;
    color: #212529;
    font-weight: 400;
    line-height: 1.5;
}

@media (min-width: 992px) {
    .mn--min .header__brand {
        display: none !important;
    }
}

.last-analysis-card-body {
    padding-top: 0px !important;
}

.last-analysis-card-body .table-responsive .pt-10 {
    padding-top: 10px;
}

.list-group .w-40 {
    width: 40% !important;
}

/* ID Button styling - same as primary */
.btn-id-color {
    color: #fff;
    background-color: #0d6efd;
    border-color: #0d6efd;
}

.btn-id-color:hover {
    color: #fff;
    background-color: #0b5ed7;
    border-color: #0a58ca;
}

.btn-id-color:focus {
    color: #fff;
    background-color: #0b5ed7;
    border-color: #0a58ca;
    box-shadow: 0 0 0 0.25rem rgba(49, 132, 253, 0.5);
}

.btn-id-color:active {
    color: #fff;
    background-color: #0a58ca;
    border-color: #0a53be;
}

[data-bs-theme=dark] .btn-id-color {
    color: #fff;
    background-color: #0867c2;
    border-color: #0d6efd;
}

[data-bs-theme=dark] .btn-id-color:hover {
    color: #fff;
    background-color: #0b5ed7;
    border-color: #0a58ca;
}


.btn-id {
    --bs-btn-color: var(--bs-primary-color);
    --bs-btn-bg: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-color: var(--bs-primary-color);
    --bs-btn-hover-bg: var(--bs-btn-primary-hover-bg);
    --bs-btn-hover-border-color: var(--bs-btn-primary-hover-bg);
    --bs-btn-active-color: var(--bs-primary-color);
    --bs-btn-active-bg: var(--bs-btn-primary-active-bg);
    --bs-btn-active-border-color: var(--bs-btn-primary-active-bg);
    --bs-btn-disabled-color: var(--bs-primary-color);
    --bs-btn-disabled-bg: var(--bs-btn-bg);
    --bs-btn-disabled-border-color: var(--bs-btn-bg);
    --bs-btn-primary-hover-bg: #1f3a6c;
    --bs-btn-primary-active-bg: #193059;
}


.btn-id:hover {
    color: var(--bs-primary-color);
    background-color: var(--bs-btn-primary-hover-bg);
    border-color: var(--bs-btn-primary-hover-bg);

    box-shadow: 0 .1rem .5rem rgba(var(--bs-primary-rgb), .5), 0 .25rem 1rem rgba(var(--bs-primary-rgb), .5);

}


[data-bs-theme=dark] .btn-id:hover {
    color: var(--bs-primary-color);
    background-color: var(--bs-btn-primary-hover-bg);
    border-color: var(--bs-btn-primary-hover-bg);
}


[data-bs-theme=dark] .btn-primary {
    background-color: #24447f;
    border-color: #093a75;
}

[data-bs-theme=dark] .btn-primary:hover {
    background-color: #083366;
    border-color: #072d5c;
}

[data-bs-theme=dark] .btn-info {
    background-color: #086d80;
    border-color: #1b9aaa;
}

[data-bs-theme=dark] .btn-info:hover {
    background-color: #065a6b;
    border-color: #055161;
}

[data-bs-theme=dark] .btn-light {
    background-color: #2b3035;
    border-color: #2b3035;
    color: #e6e6e6;
}

[data-bs-theme=dark] .btn-success {
    background-color: #336d57;
    border-color: #0d422a;
    color: #fff;
}

[data-bs-theme=dark] .btn-success:hover {
    background-color: #0b3824;
    border-color: #092e1d;
}

[data-bs-theme=dark] .btn-danger {
    background-color: #7d1f28;
    border-color: #721c24;
}

[data-bs-theme=dark] .btn-danger:hover {
    background-color: #6a1a22;
    border-color: #5f171f;
}

[data-bs-theme=dark] .btn-warning {
    background-color: #8c6b04;
    border-color: #7d6004;
    color: #f8f9fa;
}

[data-bs-theme=dark] .btn-warning:hover {
    background-color: #775b03;
    border-color: #695003;
    color: #f8f9fa;
}


[data-bs-theme=dark] .btn-id {
    background-color: #24447f;
    border-color: #093a75;
}

[data-bs-theme=dark] .btn-id:hover {
    background-color: #083366;
    border-color: #072d5c;
    box-shadow: 0 .1rem .3rem rgba(8, 51, 102, .5), 0 .2rem .6rem rgba(8, 51, 102, .5);
}


[data-bs-theme=dark] .root .mainnav__inner .nav-link {
    color: #ffffff !important;
}

[data-bs-theme=dark] .list-group-item {
    color: #ffffff;
}


[data-bs-theme=dark] .list-group-item-action:hover,
[data-bs-theme=dark] .list-group-item-action:focus {
    color: #ffffff;
}

[data-bs-theme=dark] .list-group-item.active {
    color: #ffffff;
}


[data-bs-theme=dark] .badge.bg-primary {
    background-color: #24447f !important;
}

[data-bs-theme=dark] .badge.bg-info {
    background-color: #1b9aaa !important;
}

[data-bs-theme=dark] .badge.bg-success {
    background-color: #336d57 !important;
}

[data-bs-theme=dark] .badge.bg-danger {
    background-color: #7d1f28 !important;
}

[data-bs-theme=dark] .badge.bg-warning {
    background-color: #8c6b04 !important;
    color: #f8f9fa !important;
}


[data-bs-theme=dark] .badge.bg-secondary {
    background-color: #495057 !important;
}


[data-bs-theme=dark] .badge.bg-dark {
    background-color: #212529 !important;
}


[data-bs-theme=dark] .badge.bg-light {
    background-color: #343a40 !important;
    color: #f8f9fa !important;
}

[data-bs-theme=dark] .badge-text {
    color: #ffffff !important;
}

[data-bs-theme=dark] .card-header.text-bg-primary,
[data-bs-theme=dark] .text-bg-primary {
    background-color: #24447f !important;
}

[data-bs-theme=dark] .card-header.text-bg-info,
[data-bs-theme=dark] .text-bg-info {
    background-color: #1b9aaa !important;
}

[data-bs-theme=dark] .card-header.text-bg-success,
[data-bs-theme=dark] .text-bg-success {
    background-color: #336d57 !important;
}

[data-bs-theme=dark] .card-header.text-bg-danger,
[data-bs-theme=dark] .text-bg-danger {
    background-color: #7d1f28 !important;
}

[data-bs-theme=dark] .card-header.text-bg-warning,
[data-bs-theme=dark] .text-bg-warning {
    background-color: #8c6b04 !important;
    color: #f8f9fa !important;
}

[data-bs-theme=dark] .card-header.text-bg-secondary,
[data-bs-theme=dark] .text-bg-secondary {
    background-color: #495057 !important;
    color: #f8f9fa !important;
}

[data-bs-theme=dark] .card-header.text-bg-dark,
[data-bs-theme=dark] .text-bg-dark {
    background-color: #212529 !important;
}

[data-bs-theme=dark] .card-header.text-bg-light,
[data-bs-theme=dark] .text-bg-light {
    background-color: #343a40 !important;
    color: #f8f9fa !important;
}

[data-bs-theme=dark] .card-body {
    color: #ffffff;
}


[data-bs-theme=dark] .text-body,
[data-bs-theme=dark] .text-body-emphasis,
[data-bs-theme=dark] .text-body-secondary {
    color: #ffffff !important;
}


.color-scheme-container {
    margin: 10px 0;
}

.color-scheme-container h6 {
    margin-bottom: 15px;
    font-weight: 600;
}

.color-schemes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
}

.color-scheme-btn {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 2px solid #e9ecef;
    cursor: pointer;
    position: relative;
    transition: transform 0.2s;
}

.color-scheme-btn:hover {
    transform: scale(0.9);
}

.color-scheme-btn.active {
    border-color: #fff;
    box-shadow: 0 0 0 2px #000;
}

.color-scheme-btn.active::after {
    content: "✓";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-weight: bold;
    font-size: 12px;
    text-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
}

/* 기본 스타일 */
.custom-responsive-container {
    width: 100%;
}

/* 1600px 이상 2000px 이하 화면에서 적용 */
@media (min-width: 1600px) and (max-width: 2000px) {
    .custom-responsive-container {
        width: 50%;
        max-width: 800px;
    }
}

/* 2000px 이상 화면에서 적용 */
@media (min-width: 2001px) {
    .custom-responsive-container {
        width: 40%;
        max-width: 700px;
    }
}



.color-gray {
    background-color: #6c757d;
}

.color-navy {
    background-color: #2E4053;
}

.color-ocean {
    background-color: #3498DB;
}

.color-lime {
    background-color: #7CB342;
}

.color-violet {
    background-color: #9B59B6;
}

.color-orange {
    background-color: #F39C12;
}

.color-teal {
    background-color: #1ABC9C;
}

.color-corn {
    background-color: #F1C40F;
}

.color-cherry {
    background-color: #E74C3C;
}

.color-coffee {
    background-color: #D35400;
}

.color-pear {
    background-color: #27AE60;
}

.color-night {
    background-color: #34495E;
}

.btn-spacing {
    margin-right: 30px;
}

.btn-outline-white {
    color: #fff;
    background-color: transparent;
    border-color: transparent;
    transition: all 0.3s ease;
}

.btn-outline-white:hover {
    color: #fff;
    background-color: transparent;
    border-color: #fff;
}

.calendar-container {
    font-size: 12px;
}

.calendar-header th {
    font-size: 14px;
    font-weight: bold;
    text-align: center;
    padding: 5px;
    background-color: #f0f0f0;
}

.calendar-table {
    width: 100%;
    border-collapse: collapse;
}

.calendar-table td {
    border: 1px solid #ddd;
    padding: 2px;
    vertical-align: top;
    height: 120px;
    width: 14.28%;
}

.date {
    font-size: 13px;
    font-weight: bold;
    text-align: right;
    padding: 3px;
    margin-bottom: 5px;
}

.data-item {
    font-size: 11px;
    line-height: 1.2;
}

.text-danger {
    color: #ff0000 !important;
    font-weight: 700;
}

.text-primary {
    color: #0000ff !important;
    font-weight: 700;
}

.text-success {
    color: #198754 !important;
    font-weight: 700;
}

.calendar-total {
    margin-top: 20px;
    padding: 10px;
    background-color: #f8f9fa;
    border: 1px solid #ddd;
}

.empty-cell {
    background-color: #f9f9f9;
}

.search-box-end {
    justify-content: end !important;
}

[data-bs-theme="dark"] .left-side-vendor-title-blue {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: #418EFF;
}

[data-bs-theme="dark"] .left-side-vendor-title-green {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: #4eff8b;
}

[data-bs-theme="dark"] .left-side-vendor-title-yellow {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: #ffde9b;
}

[data-bs-theme="dark"] .left-side-vendor-title-red {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: #ff6f6f;
}

.left-side-vendor-title-blue {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: #0d6efd;
}

.left-side-vendor-title-green {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: var(--bs-success, #198754);
}

.left-side-vendor-title-yellow {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: var(--bs-warning, #ffc107);
}

.left-side-vendor-title-red {
    font-family: 'Nanum Gothic', sans-serif;
    font-weight: bold;
    letter-spacing: 0.7px;
    font-size: 0.9rem;
    color: #dc3545;
}

.summary-badge {
    font-size: 1em;
    padding-left: 6px;
    padding-right: 6px;
    line-height: 1.2;
}

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

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

[data-bs-theme="dark"] .left-side-vendor-title-blue {

    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: #418EFF;
}

[data-bs-theme="dark"] .left-side-vendor-title-green {

    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: #4eff8b;
}

[data-bs-theme="dark"] .left-side-vendor-title-yellow {

    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: #ffde9b;
}

[data-bs-theme="dark"] .left-side-vendor-title-red {

    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: #ff6f6f;
}

.left-side-vendor-title-blue {
    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: #0d6efd;
}

.left-side-vendor-title-green {
    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: var(--bs-success, #198754);
}

.left-side-vendor-title-yellow {
    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: var(--bs-warning, #ffc107);
}

.left-side-vendor-title-red {
    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
    color: #dc3545;
}

[data-bs-theme="dark"] .lsv-title {
    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
}


[data-bs-theme="dark"] .lsvt-blue {
    color: #418EFF;
}

[data-bs-theme="dark"] .lsvt-green {
    color: #4eff8b;
}

[data-bs-theme="dark"] .lsvt-yellow {
    color: #ffde9b;
}

[data-bs-theme="dark"] .lsvt-red {
    color: #ff6f6f;
}


.lsv-title {
    font-weight: bold;
    letter-spacing: -0.3px;
    font-size: 1.1em;
}

.lsvt-blue {
    color: var(--bs-primary, #0d6efd);
}

.lsvt-green {
    color: var(--bs-success, #198754);
}

.lsvt-yellow {
    color: var(--bs-warning, #ffc107);
}

.lsvt-red {
    color: var(--bs-danger, #dc3545);
}


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