:root {
    --app-light: #f8fafb;
    --app-darklight: #ebf0f2;
    --app-primary: #0464dc;
    --app-primary-light: #e8f6ff;
    --app-secondary: #f0f2f2;
    --app-success: #0cbd8c;
    --app-danger: #e02a2a;
    --app-warning: #f6842b;
    --app-info: #2799f2;
    --app-color-secondary: #a1a8b5;
    --app-muted: #96a6b4;
    --app-darkmuted: #7f8e99;
    --app-bg-menu: #11388c;
    --app-bg-light-menu: #0f3b99;
    --app-focus: #0464dc;
    --app-left-on: 230px;
    --app-left-off: 0;
    --app-border: #e1e6eb;
}

body {
    font-family: "Plus Jakarta Sans", sans-serif;
    background-color: var(--app-darklight);
    color: #060606;
}
.t-10 {
    font-size: 10px !important;
}
.t-11 {
    font-size: 11px !important;
}
.t-12 {
    font-size: 12px !important;
}
.t-13 {
    font-size: 13px !important;
}
.t-14 {
    font-size: 14px !important;
}
.t-15 {
    font-size: 15px !important;
}
.t-16 {
    font-size: 16px !important;
}
.t-17 {
    font-size: 17px !important;
}
.t-18 {
    font-size: 18px !important;
}
.t-19 {
    font-size: 19px !important;
}
.t-20 {
    font-size: 20px !important;
}
/* ============ */
.t-100 {
    font-weight: 100 !important;
}
.t-200 {
    font-weight: 200 !important;
}
.t-300 {
    font-weight: 300 !important;
}
.t-400 {
    font-weight: 400 !important;
}
.t-500 {
    font-weight: 500 !important;
}
.t-600 {
    font-weight: 600 !important;
}
.t-700 {
    font-weight: 700 !important;
}
.t-800 {
    font-weight: 800 !important;
}
.t-900 {
    font-weight: 900 !important;
}
/* ============ */
.color-muted {
    color: var(--app-darkmuted) !important;
}
.color-primary {
    color: var(--app-primary) !important;
}
.color-success {
    color: var(--app-success) !important;
}
.color-text {
    color: #060606 !important;
}
.text-bg-success {
    background-color: var(--app-success) !important;
}
.text-bg-danger {
    background-color: var(--app-danger) !important;
}
/* ============ */
.bg-muted {
    background-color: var(--app-darkmuted) !important;
}
.bg-primary {
    background-color: var(--app-primary) !important;
}
.bg-success {
    background-color: var(--app-success) !important;
}
/* ============ */
.ui-rounded {
    border-radius: 12px;
}
.ui-shadow {
    box-shadow: rgba(0, 0, 0, 0.05) 0px 1px 2px 0px;
}
/* ============ */
/* CARDS */
.card {
    border: 0;
    box-shadow: rgba(0, 0, 0, 0.05) 0px 1px 2px 0px;
}
.b-top {
    border-top: 1px solid #eff1f7;
}
.b-bottom {
    border-bottom: 1px solid #eff1f7;
}
.b-start {
    border-right: 1px solid #eff1f7;
}
.b-end {
    border-left: 1px solid #eff1f7;
}
.b-1 {
    border: 1px solid #eff1f7;
}
.b-2 {
    border: 2px solid #eff1f7;
}
.b-3 {
    border: 3px solid #eff1f7;
}
/* ============ */
/* INPUT */
.form-control {
    border: 2px solid #eff1f7;
    background-color: #f7f8fb;
}
.form-control:focus {
    border-color: var(--app-focus);
    box-shadow: none;
}
.form-control:disabled {
    background-color: #eff1f7;
}
.ui-form {
    position: relative;
    display: flex;
    align-items: center;
}
.ui-form label {
    position: absolute;
    left: 0.75rem;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    color: var(--app-muted);
    top: 4px;
}
.ui-form:focus-within label {
    color: var(--app-focus);
}
.ui-form .form-control {
    padding: 15px 10px 2px;
}

.ui-form .form-select {
    padding: 15px 10px 2px;
    border: 2px solid #eff1f7;
    background-color: #f7f8fb;
    box-shadow: none !important;
}
.ui-form .form-control,
.ui-form .form-select {
    font-size: 15px;
}
.ui-form .form-select:focus {
    border-color: var(--app-focus);
    box-shadow: none;
}
.ui-form .form-select.is-invalid {
    border-color: var(--bs-form-invalid-border-color);
}
[data-autocomplete-loader] {
    position: absolute;
    right: 4px;
    top: 4px;
    bottom: 4px;
    display: flex;
    align-items: center;
    padding: 0 0.25rem;
    background-color: transparent;
}
[data-autocomplete-loader] .np-spinner {
    width: 1.2rem;
    height: 1.2rem;
    color: var(--np-muted);
}
/* =========== */
.btn,
button {
    position: relative;
    font-size: 15px;
    line-height: 1;
    padding: 6px 12px;
}

.btn:active,
.btn-check:checked + .btn,
.btn.active,
.btn.show,
.btn:first-child:active,
:not(.btn-check) + .btn:active {
    border-color: #fff;
}
.btn-primary {
    --bs-btn-font-weight: 500 !important;
    --bs-btn-color: var(--bs-white);
    --bs-btn-bg: var(--app-primary);
    --bs-btn-hover-color: var(--bs-white);
    --bs-btn-border-color: var(--app-primary);
    --bs-btn-hover-bg: var(--app-primary);
    --bs-btn-hover-border-color: var(--app-primary);
    --bs-btn-focus-shadow-rgb: var(--app-primary);
    --bs-btn-active-color: var(--bs-white);
    --bs-btn-active-bg: var(--app-primary);
}
.btn-success {
    --bs-btn-font-weight: 500 !important;
    --bs-btn-color: var(--bs-white);
    --bs-btn-bg: var(--app-success);
    --bs-btn-hover-color: var(--bs-white);
    --bs-btn-border-color: var(--app-success);
    --bs-btn-hover-bg: var(--app-success);
    --bs-btn-hover-border-color: var(--app-success);
    --bs-btn-focus-shadow-rgb: var(--app-success);
    --bs-btn-active-color: var(--bs-white);
    --bs-btn-active-bg: var(--app-success);
}
.btn-secondary {
    --bs-btn-font-weight: 500 !important;
    --bs-btn-color: var(--app-color-secondary);
    --bs-btn-bg: var(--app-secondary);
    --bs-btn-hover-color: var(--app-color-secondary);
    --bs-btn-border-color: var(--app-secondary);
    --bs-btn-hover-bg: var(--app-secondary);
    --bs-btn-hover-border-color: var(--app-secondary);
    --bs-btn-focus-shadow-rgb: var(--app-secondary);
    --bs-btn-active-color: var(--app-color-secondary);
    --bs-btn-active-bg: var(--app-secondary);
}

.btn-primary:active,
.btn-check:checked + .btn-primary,
.btn-primary.active,
.btn-primary.show,
.btn-primary:first-child:active,
:not(.btn-check) + .btn-primary:active {
    border-color: var(--app-primary) !important;
}

.btn-group-sm > .btn,
.btn-sm {
    --bs-btn-font-size: 13px;
}
.btn.btn-primary .disabled,
.btn.btn-primary:disabled {
    border-color: var(--app-primary);
}

.btn-icon {
    font-size: 13px;
    font-weight: 500;
    background-color: transparent;
    border-radius: 6px;
    padding: 6px 8px;
    border: 0 !important;
}
.btn-icon:hover {
    background-color: var(--app-light);
}

/* ==================== */
.bg-shape {
    display: flex;
    position: absolute;
    z-index: -1;
    max-width: 720px;
}
@media (max-width: 720px) {
    .bg-shape {
        width: 100%;
    }
}
@media (max-width: 520px) {
    .bg-shape {
        padding-bottom: 20%;
    }
}
/* ==================== */
.icon-login {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 120px;
}
/* LAYOUT */
/* ==================== */
.app-root .main {
    position: relative;
    overflow: hidden;
    scrollbar-gutter: stable;
}

.app-root .main .wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    padding-left: 0;
    transition: all 0.3s ease-in-out;
}

.app-root .wrapper .header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: var(--app-primary);
    padding: 0 0.5rem;
    /* border-bottom: 1px solid #e1e6eb; */
    z-index: 1020;
    transition: all 0.3s ease-in-out;
}

.app-root .wrapper .header .header-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 45px;
}

.app-root .wrapper .header .header-container .header-left,
.app-root .wrapper .header .header-container .header-right {
    display: flex;
}
/* ================================== */
.app-root .main .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: var(--app-left-on);
    bottom: 0;
    display: flex;
    flex-direction: column;
    max-width: 100%;
    background-color: #fff;
    background-clip: padding-box;
    outline: 0;
    transform: translateX(-100%);
    z-index: 1040;
    box-shadow: rgba(0, 0, 0, 0.05) 0px 0px 16px -6px;
    border: 0;
    transition: all 0.3s ease-in-out;
}

.app-root .main .sidebar .sidebar-brand {
    padding: 0.25rem;
}

.app-root .main .sidebar .sidebar-content {
    flex-grow: 1;
    padding: 0.75rem;
    overflow-y: auto;
}

.app-root .menu {
    padding: 0;
    margin: 0;
}

.app-root .menu li {
    padding: 2px 0;
    list-style: none;
}

.app-root .menu li a {
    position: relative;
    display: flex;
    align-items: center;
    padding: 13px 8px;
    font-size: 15px;
    color: #758088;
    font-weight: 500;
    text-decoration: none;
    line-height: 1;
    border-radius: 6px;
    gap: 10px;
    /* transition: all 0.1s ease-out; */
}

.app-root .menu li a i {
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 20px;
}

.app-root .menu li a:hover:not(.active),
.app-root .menu.sub-menu li a:hover:not(.active) {
    background-color: var(--app-primary);
    color: #fff;
}

.app-root .menu li a.active {
    background-color: var(--app-primary);
    color: #fff;
}

.app-root .wrapper .content {
    display: flex;
    flex-grow: 1;
    padding: 54px 0.5rem 0.5rem;
    font-weight: 400;
    align-items: flex-start;
}

.app-root .menu li a[data-bs-toggle="collapse"] {
    padding-right: 12px;
}

.app-root .menu li a[data-bs-toggle="collapse"]::after {
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23212529' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e");
    --bs-accordion-btn-icon-width: 14px;
    --bs-accordion-btn-icon-transform: rotate(-90deg);
    --bs-accordion-btn-icon-transition: transform 0.2s ease-in-out;

    flex-shrink: 0;
    width: var(--bs-accordion-btn-icon-width);
    height: var(--bs-accordion-btn-icon-width);
    margin-left: auto;
    content: "";
    background-image: var(--bs-accordion-btn-icon);
    background-repeat: no-repeat;
    background-size: var(--bs-accordion-btn-icon-width);
    transform: var(--bs-accordion-btn-icon-transform);
    transition: var(--bs-accordion-btn-icon-transition);
    opacity: 0.4;
}

.app-root .menu li a[aria-expanded="true"] {
    background-color: var(--app-secondary);
}

.app-root .menu li a[aria-expanded="true"]::after {
    --bs-accordion-btn-icon-transform: rotate(0);
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23052c65' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M2 5L8 11L14 5'/%3e%3c/svg%3e");

    background-image: var(--bs-accordion-btn-active-icon);
    transform: var(--bs-accordion-btn-icon-transform);
}

.app-root .menu.sub-menu li a {
    padding: 0.75rem 0.75rem 0.75rem 45px;
    background-color: #fff;
}
.app-root .menu.sub-menu li a.active {
    background-color: #f47a00;
    color: #fff;
}
.app-root .menu.sub-menu li a::before {
    content: "";
    position: absolute;
    left: 1.4375rem;
    width: 0.375rem;
    height: 0.375rem;
    border-radius: 50%;
    background-color: #b4bdc6;
}
.app-root .menu.sub-menu li a.active::before {
    background-color: #fff;
}

.app-root .header .btn-dropdown {
    color: #c9daff;
    background-color: rgba(255, 255, 255, 0.1);
    font-size: 14px;
    font-weight: 500;
    border: 0 !important;
}
.app-root .header .btn-dropdown:active,
.app-root .header .btn-dropdown:focus {
    color: #fff;
    background-color: rgba(255, 255, 255, 0.125);
}
/* ============= [data-menu-toggle="sidebar"] */
.app-root .main.sidebar-toggle .wrapper .header {
    left: var(--app-left-on);
}

.app-root .main.sidebar-toggle .sidebar {
    transform: translateX(0);
}

@media (min-width: 1200px) {
    .app-root .main .wrapper {
        padding-left: var(--app-left-on);
    }

    .app-root .wrapper .header {
        left: var(--app-left-on);
    }

    .app-root .main .sidebar {
        transform: translateX(0);
        box-shadow: none;
        border: 1px solid var(--app-border);
    }
    /* ============= [data-menu-toggle="sidebar"] */
    .app-root .main.sidebar-toggle .wrapper {
        padding-left: var(--app-left-off);
    }

    .app-root .main.sidebar-toggle .wrapper .header {
        left: var(--app-left-off);
    }

    .app-root .main.sidebar-toggle .sidebar {
        transform: translateX(-100%);
    }
}
/* ==================== */
.toolbar-crumbs h5 {
    font-size: 14px;
    font-weight: 500;
    color: var(--app-muted);
    margin: 0;
    padding: 0 0.5rem;
}
/* ==================== */
.modal {
    --bs-modal-border-radius: 18px;
    --bs-modal-border-width: 0px;
    --bs-modal-header-border-color: #f0f3f5;
    --bs-modal-footer-border-color: #f0f3f5;
    --bs-modal-color: #717e8d;
}
.modal-backdrop {
    --bs-backdrop-opacity: 0.25;
}
.modal .btn {
    --bs-btn-font-size: 15px;
    --bs-btn-border-radius: 6px;
    padding: 10px 12px;
    font-weight: 400;
}
.modal-title {
    color: #2a3a4d;
    font-weight: 600;
    font-size: 16px;
}
.min-content {
    min-height: 420px;
}
@media (max-width: 992px) {
    .modal-lg,
    .modal-xl {
        --bs-modal-width: 720px;
    }
}
@media (max-width: 750px) {
    .modal-lg,
    .modal-xl {
        --bs-modal-width: 96%;
    }
}

/* ==================== */
.dropdown-menu {
    /* --bs-dropdown-min-width: ; */
    /* --bs-dropdown-padding-x: 0; */
    /* --bs-dropdown-padding-y: ; */
    /* --bs-dropdown-divider-bg: ;*/
    /* --bs-dropdown-divider-margin-y: ;*/
    /* --bs-dropdown-link-hover-color: ;*/
    /* --bs-dropdown-link-hover-bg: ;*/
    /* --bs-dropdown-link-active-color: ;*/
    /* --bs-dropdown-link-active-bg: ;*/
    /* --bs-dropdown-item-padding-y: ;*/
    /* --bs-dropdown-header-padding-x: ;*/
    /* --bs-dropdown-header-padding-y: ;*/
    --bs-dropdown-color: var(--app-darkmuted);
    --bs-dropdown-border-color: var(--app-darklight);
    --bs-dropdown-border-radius: 12px;
    --bs-dropdown-box-shadow: rgba(0, 0, 0, 0.05) 0px 1px 2px 0px;
    --bs-dropdown-link-color: var(--app-darkmuted);
    --bs-dropdown-item-padding-x: 8px;
    text-transform: uppercase;
}
.dropdown-item {
    font-size: 13px;
    font-weight: 500;
}
/* ================ */
.dropdown-autocomplete {
    min-width: 100% !important;
    max-height: var(--bs-scroll-height, 45vh);
    overflow-y: auto;
    scrollbar-gutter: auto;
}
.dropdown-autocomplete.dropdown-menu > li > a {
    display: flex;
    align-items: center;
    white-space: normal !important;
    line-height: 1 !important;
    color: var(--np-gray-dark);
    border-bottom: 1px solid var(--app-darklight);
    min-height: 32px;
}
.dropdown-autocomplete.dropdown-menu > li:last-child > a {
    border-bottom: 0;
}
/* ================ */
.nav-tabs {
    --bs-nav-tabs-border-color: #f0f3f5;
}
.nav-tabs .nav-link {
    position: relative;
    padding: 3px 15px;
    border-bottom: 2px solid transparent !important;
    border-top-width: 0px;
    border-left-width: 0px;
    border-right-width: 0px;
    color: var(--app-muted);
    font-size: 15px;
}
.nav-tabs .nav-item.show .nav-link,
.nav-tabs .nav-link.active {
    color: #283039;
    border-bottom-color: var(--app-primary) !important;
}
.tab-pane {
    padding: 12px;
}
/* ====================== */
.bootstrap-table .bottom-table-toolbar {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.25rem;
}
.bootstrap-table .bottom-table-toolbar .pagination-detail,
.bootstrap-table .bottom-table-toolbar .fixed-table-toolbar .columns {
    margin: 0;
}
.bootstrap-table .fixed-table-container .table thead th,
.bootstrap-table .fixed-table-container.fixed-height .table thead th {
    color: #fff;
    font-size: 13px;
    font-weight: 500;
    background-color: #222f3f;
}
.bootstrap-table .fixed-table-container .table thead th .th-inner {
    padding: 0.5rem 0.25rem;
}
.ui-table {
    table-layout: fixed;
}
.ui-table tbody tr {
    border-color: var(--app-darklight);
}
.ui-table tbody td {
    color: #182944;
    font-size: 15px;
    font-weight: 400;
    text-overflow: ellipsis;
    vertical-align: middle;
    white-space: nowrap;
    overflow: hidden;
    padding: 0.25rem !important;
}
.ui-table > tbody > tr:hover > * {
    --bs-table-accent-bg: #fcfdfd !important;
}
.bottom-table-toolbar .fixed-table-pagination {
    display: flex;
    line-height: 1 !important;
    gap: 0.25rem;
}
.bootstrap-table .bottom-table-toolbar .pagination-detail {
    display: flex;
    font-size: 13px;
    font-weight: 500;
    line-height: 1 !important;
    align-items: center;
    gap: 0.25rem;
}
.bootstrap-table .bottom-table-toolbar .pagination-detail .pagination-info,
.bootstrap-table .bottom-table-toolbar .pagination-detail .page-list {
    display: flex;
    line-height: 1 !important;
    align-items: center;
    gap: 0.25rem;
}
.bootstrap-table
    .bottom-table-toolbar
    .pagination-detail
    .page-list
    .dropdown-toggle {
    padding: 5px 10px;
    line-height: 1;
}
.bootstrap-table.bootstrap5 .float-right {
    margin: 0;
}
.bootstrap-table.bootstrap5 .float-right .page-link {
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 500;
}
button[name="refresh"] {
    padding: 6px 10px;
}
/* ================== */
.container-loader {
    overflow: hidden;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.container-loader [data-usercontrol="loader"] {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
.container-loader i {
    opacity: 0;
}
/* ==================== */
.tab-menu {
    display: flex;
    min-width: 240px;
    padding: 1rem;
    border-radius: 12px;
    background-color: #fff;
    box-shadow: 0 0.075rem 0.275rem rgba(0, 0, 0, 0.075);

    position: relative;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-gutter: stable;
}
.tab-menu.tab-vertical {
    flex-direction: column;
    min-height: 100%;
}

.tab-menu .nav-link {
    display: flex;
    padding: 0.5rem 0px;
    align-items: center;
    justify-content: space-between;
    color: var(--app-text-dark);
    border-bottom: 1px solid var(--app-border-light);
    border-radius: 0;
}
.tab-menu.tab-vertical .nav-link {
    min-height: 52px;
}
.tab-menu.tab-outline .nav-link {
    border-bottom: 2px solid transparent !important;
    font-size: 15px;
    font-weight: 500;
}
.tab-menu.tab-outline .nav-link.active {
    border-bottom: 2px solid #212529 !important;
}
.tab-menu .nav-link:last-child {
    border-bottom-width: 0;
}

.tab-menu .nav-link .actions {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    z-index: 5;
}
.tab-menu .nav-link .actions .btn {
    padding: 3px 6px !important;
}
/* ==================== */
.progress-circle {
    position: relative;
    width: 180px;
    height: 180px;
}

.progress-circle svg {
    transform: rotate(-90deg);
}

.progress-circle circle {
    fill: none;
    stroke-width: 3%;
}

.progress-circle .background {
    stroke: #eff1f7;
}

.progress-circle .progress {
    stroke: var(--app-success);
    stroke-dasharray: 283; /* Circunferencia del círculo (2 * π * r) */
    stroke-dashoffset: calc(283 - (50 / 100 * 283));
    transition: stroke-dashoffset 0.5s;
}

.progress-circle .counter-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.progress-circle .counter-text .text {
    text-align: center;
}
/* ============= */
/* PAGINATE ITEMS */
/* .container-paginate .paginate-footer */
.container-paginate .paginate-content {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 230px);
    box-sizing: border-box;
}
.container-paginate .paginate-content .list-group {
    flex: 1;
    overflow-y: auto;
}
.container-paginate .paginate-content .list-group .list-group-item {
    border-color: #eff1f7;
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}
.container-paginate .paginate-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid #eff1f7;
}
.container-paginate .paginate-footer .paginate-info {
    font-weight: 500;
    color: #758088;
    font-size: 13px;
}
.container-paginate .paginate-footer .pagination {
    justify-content: flex-end;
    margin: 0;
    gap: 0.25rem;
}
.container-paginate .paginate-footer .pagination .page-link {
    font-size: 13px;
    font-weight: 500;
    padding: 0.25rem;
    line-height: 1;
    color: var(--app-muted);
    box-shadow: none;
    width: 35px;
    height: 35px;
    border-radius: 10px;
    cursor: pointer;
    border-color: #eff1f7;
}
.container-paginate .paginate-footer .pagination .page-link.active {
    color: #fff;
    border-color: var(--bs-pagination-active-bg);
}
/* ============================== */
/* COMPONENT-AUTOCOMPLETE */
.component-autocomplete {
    position: relative;
    display: flex;
    align-items: center;
}

.component-autocomplete .dropdown-menu {
    /* width: 100%; */
    min-width: 100%;
    max-height: 280px;
    overflow-y: auto;
    box-shadow: rgba(0, 0, 0, 0.05) 0px 1px 2px 0px;
    padding: 0;
    /* z-index: 1080; */
}

.component-autocomplete .dropdown-menu li {
    padding: 8px 10px;
    font-size: 12px;
    font-weight: 600;
    color: #222f3f;
    list-style-type: none;
    border-bottom: 1px solid #eff1f7;
}

.component-autocomplete .dropdown-menu li:not(.no-results) {
    cursor: pointer;
}

.component-autocomplete .dropdown-menu li:last-child {
    border-bottom-width: 0;
}

.component-autocomplete .dropdown-menu li:hover,
.component-autocomplete .dropdown-menu li.selected {
    background-color: #edf3fe;
}

.component-autocomplete .spinner-border {
    position: absolute;
    right: 10px;
    width: 1.2rem;
    height: 1.2rem;
    color: var(--np-muted);
    z-index: 1001;
}
/* ========== */
.bs-table-rounded .bootstrap-table {
    border-radius: var(--bs-border-radius);
    overflow: hidden;
}
/* ========== */
/* COMPONENT-SWITCH */
.btn-switch {
    position: relative;
    display: flex;
    align-items: center;
}
.btn-switch input[type="checkbox"] {
    position: absolute;
    cursor: pointer;
    display: flex;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    border: 0;
    /* opacity: 0; */
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
    z-index: 1;
}
.btn-switch .indicator {
    position: relative;
    display: flex;
    align-items: center;
    width: 30px;
    height: 20px;
    background-color: var(--app-border);
    border-radius: 1rem;
    border: 2px solid var(--app-border);
    transition: all 0.35s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
.btn-switch .indicator::before {
    content: "";
    position: absolute;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    transform: translateX(0);
    background-color: #fff;
    box-shadow: 0 0.075rem 0.275rem rgba(0, 0, 0, 0.075);
    transition: all 0.35s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
.btn-switch input[type="checkbox"]:checked ~ .indicator {
    background-color: var(--app-primary);
    border-color: var(--app-primary);
}
.btn-switch.success input[type="checkbox"]:checked ~ .indicator {
    background-color: var(--app-success);
    border-color: var(--app-success);
}
.btn-switch.info input[type="checkbox"]:checked ~ .indicator {
    background-color: var(--app-info);
    border-color: var(--app-info);
}
.btn-switch.warning input[type="checkbox"]:checked ~ .indicator {
    background-color: var(--app-warning);
    border-color: var(--app-warning);
}
.btn-switch.danger input[type="checkbox"]:checked ~ .indicator {
    background-color: var(--app-danger);
    border-color: var(--app-danger);
}
.btn-switch input[type="checkbox"]:checked ~ .indicator::before {
    transform: translateX(10px);
}
.btn-switch.disabled {
    background-color: transparent !important;
}
.btn-switch.disabled input[type="checkbox"]:checked ~ .indicator:after {
    content: "";
    position: absolute;
    top: -2px;
    right: -2px;
    bottom: -2px;
    left: -2px;
    background-color: rgba(255, 255, 255, 0.375);
    border-radius: 1rem;
}
/* ====================== */
.container-quantity {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
}

.container-quantity input {
    text-align: center;
    width: 120px;
}

.container-quantity button {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 13px;
    font-weight: 500 !important;
    padding: 0 !important;
    line-height: 1;
    color: var(--app-muted);
    background-color: #f7f8fb;
    box-shadow: none;
    width: 35px;
    height: 35px;
    border-radius: 10px;
    cursor: pointer;
    border: 2px solid #eff1f7;
}
/* ====================== */
.toastify {
    display: flex;
    gap: 0.75rem;
    border-radius: 10px;
    padding: 12px 16px;
    font-size: 15px;
    font-weight: 400;
    transform: translateX(100%) !important;
    transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}
.toastify.on {
    transform: translateX(0) !important;
}
.toastify.success {
    background-color: var(--app-success) !important;
    background: var(--app-success) !important;
}
.toastify.primary {
    background-color: var(--app-primary) !important;
    background: var(--app-primary) !important;
}
.toastify.info {
    background-color: var(--app-info) !important;
    background: var(--app-info) !important;
}
.toastify.danger {
    background-color: var(--app-danger) !important;
    background: var(--app-danger) !important;
}
.toastify.warning {
    background-color: var(--app-warning) !important;
    background: var(--app-warning) !important;
}
/* ====================== */
.timeline {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    width: 100%;
    max-width: 520px;
    margin: auto;
}

.timeline .step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    flex: 1;
    gap: 0.25rem;
}

.timeline .step::before {
    content: "";
    position: absolute;
    display: flex;
    top: 11px;
    width: 100%;
    height: 4px;
    background: #e2e4ec;
    z-index: 0;
}

.timeline .step:first-child:before {
    top: 11px;
    right: 0;
    width: 50%;
}

.timeline .step:last-child:before {
    top: 11px;
    left: 0;
    width: 50%;
}

.timeline .step .circle {
    width: 25px;
    height: 25px;
    border-radius: 50%;
    background-color: #e2e4ec;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    transition: background-color 0.2s, border-color 0.2s;
    z-index: 1;
}

.timeline .step .label {
    font-size: 11px;
    font-weight: 600;
    color: var(--app-darkmuted);
    text-transform: uppercase;
}

.timeline .step.completed .circle {
    background-color: var(--app-success);
    border: 2px solid var(--app-success);
}

.timeline .step.active .circle {
    background-color: #fff;
    color: var(--app-primary);
    border: 2px solid var(--app-primary);
}
/* ====================== */
label.radio-card {
    cursor: pointer;
    display: flex;
    flex: 1;
}

label.radio-card .card-content-wrapper {
    position: relative;
    width: 100%;
    transition: all 0.2s linear;
}

label.radio-card .check-icon {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    width: 20px;
    height: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: solid 2px #e3e3e3;
    border-radius: 50%;
    transition: all 0.2s linear;
}

label.radio-card .check-icon::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0.93552 4.58423C0.890286 4.53718 0.854262 4.48209 0.829309 4.42179C0.779553 4.28741 0.779553 4.13965 0.829309 4.00527C0.853759 3.94471 0.889842 3.88952 0.93552 3.84283L1.68941 3.12018C1.73378 3.06821 1.7893 3.02692 1.85185 2.99939C1.91206 2.97215 1.97736 2.95796 2.04345 2.95774C2.11507 2.95635 2.18613 2.97056 2.2517 2.99939C2.31652 3.02822 2.3752 3.06922 2.42456 3.12018L4.69872 5.39851L9.58026 0.516971C9.62828 0.466328 9.68554 0.42533 9.74895 0.396182C9.81468 0.367844 9.88563 0.353653 9.95721 0.354531C10.0244 0.354903 10.0907 0.369582 10.1517 0.397592C10.2128 0.425602 10.2672 0.466298 10.3112 0.516971L11.0651 1.25003C11.1108 1.29672 11.1469 1.35191 11.1713 1.41247C11.2211 1.54686 11.2211 1.69461 11.1713 1.82899C11.1464 1.88929 11.1104 1.94439 11.0651 1.99143L5.06525 7.96007C5.02054 8.0122 4.96514 8.0541 4.90281 8.08294C4.76944 8.13802 4.61967 8.13802 4.4863 8.08294C4.42397 8.0541 4.36857 8.0122 4.32386 7.96007L0.93552 4.58423Z' fill='white'/%3E%3C/svg%3E%0A");
    background-repeat: no-repeat;
    background-size: 12px;
    background-position: center center;
    transform: scale(1.6);
    transition: 200ms linear;
    opacity: 0;
}

label.radio-card input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

label.radio-card input[type="radio"]:checked + .card-content-wrapper {
    box-shadow: 0 2px 4px 0 rgba(219, 215, 215, 0.5),
        0 0 0 2px var(--app-primary);
}

label.radio-card
    input[type="radio"]:checked
    + .card-content-wrapper
    .check-icon {
    background: var(--app-primary);
    border-color: var(--app-primary);
    transform: scale(1.2);
}

label.radio-card
    input[type="radio"]:checked
    + .card-content-wrapper
    .check-icon::before {
    transform: scale(1);
    opacity: 1;
}

label.radio-card
    input[type="radio"]:checked
    + .card-content-wrapper
    .check-icon:focus
    + .card-content-wrapper {
    transform: scale(1);
    opacity: 1;
}
