:root {
    --default-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
        Ubuntu, "Helvetica Neue", Helvetica, Arial, "PingFang SC",
        "Hiragino Sans GB", "Microsoft Yahei UI", "Microsoft Yahei",
        "Source Han Sans CN", sans-serif;



    --theme-layout-margin: 40px;
    --default-color: #D61B44;
    --body-background-color: #F8F8F8;
    --background-color: #ffffff;
    --hover-color: #c6c5c5;
    --color-light-green-10: #6DC24B1A;
    --color-light-green-40: #75f599;
    --color-light-red-100: #ff0000;
    --color-light-red-50: #FFD6DF;
    --color-light-gray-10: #667080;
    --color-light-gray-40: #EFEFEF;
    --color-dark-gray: #303030;
    --default-color-100: #bc032b;
    --default-color-30: #d34564;
    --table-header-bg: #F9FAFB;

    /* border color */
    --input-border-color: #e5e5e5;
    --cart-btn-border-color: #EBEBEB;
    /* border color */

    /* font colors */
    --font-color-default: #B3B4BA;
    --font-color-white: #ffffff;
    --font-color-black: #000000;
    --font-color-gray-40: #707070;

    /* font sizes */
    --font-size-12: 12px;
    --font-size-14: 14px;
    --font-size-15: 15px;
    --font-size-16: 16px;
    --font-size-18: 18px;
    --font-size-20: 20px;
    --font-size-22: 22px;
    --font-size-30: 30px;
    --font-size-66: 66px;

    /* sidebar */
    --logistic-sidebar-width: 250px;
}

.logistics-sidebar {
    max-width: var(--logistic-sidebar-width);
}

.category-box {
    height: 150px;
    width: 200px;
    cursor: pointer
}

.product-box {
    height: 100px;
    width: 200px;
    cursor: pointer
}

.category-box.active {
    background-color: var(--color-light-red-50) !important;
    border: 3px solid var(--default-color) !important;
}

.product-box.active {
    background-color: var(--color-light-red-50) !important;
    border: 2px solid var(--default-color) !important;
}

.quantity-add {
    background-color: var(--color-light-red-50) !important;
    border: 1px solid var(--default-color) !important;
}

.card-width {
    height: 200px;
    width: 200px;
    max-width: 200px;
    overflow: hidden;
    box-sizing: border-box;
}

.product-card {
    border: 1px solid #C6C5C5;
    border-radius: 7px;
}

.product-card .description {
    color: var(--font-color-gray-40);
}

.product-card .bi-clipboard::before {
    font-weight: bolder !important;
}

.product-card .option-text {
    color: var(--color-dark-gray);
    opacity: 50%;
}

.product-card .option-text.active {
    color: var(--color-dark-gray);
    opacity: 100%;
}

.cart-option {
    color: var(--color-dark-gray);
    opacity: 50%;
}

.cart-option.active {
    color: var(--color-dark-gray);
    opacity: 100%;
}

.btn-add {
    width: 28.26px;
    height: 28.26px;
    border: 1px solid var(--cart-btn-border-color) !important;
    background: var(--background-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: var(--font-size-16);
    line-height: 1;
}

.product-card .border-input {
    border: 1px solid var(--cart-btn-border-color) !important;
    background: var(--background-color);
    border-radius: 6px;
}

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

.truncate-text-4 {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.offcanvas-backdrop.fade {
    opacity: 0 !important;
}

.form-control.note {
    height: 156px;
}

.bg-theme {
    background-color: var(--body-background-color) !important;
    color: var(--font-color-black) !important;
}

.react-select__control {
    border-color: var(--input-border-color) !important;
}

/* React Select Dropdown Menu Styles */
.react-select__menu {
    z-index: 9999 !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin-top: 4px !important;
    background: white !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 4px !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06) !important;
    max-height: 200px !important;
    overflow-y: auto !important;
}

.react-select__menu-list {
    padding: 4px 0 !important;
    max-height: 192px !important;
    overflow-y: auto !important;
}

.react-select__option {
    padding: 8px 12px !important;
    cursor: pointer !important;
    color: #333 !important;
    background: white !important;
    border: none !important;
}

.react-select__option:hover {
    background-color: #f8f9fa !important;
    color: #333 !important;
}

.react-select__option--is-focused {
    background-color: #e3f2fd !important;
    color: #1976d2 !important;
}

.react-select__option--is-selected {
    background-color: var(--default-color) !important;
    color: white !important;
}

.react-select__placeholder {
    color: var(--font-color-default) !important;
    font-size: var(--font-size-14) !important;
}

.react-select__single-value {
    color: #333 !important;
    font-size: var(--font-size-14) !important;
}

.react-select__indicator-separator {
    background-color: #e5e5e5 !important;
}

.react-select__dropdown-indicator {
    color: #666 !important;
}

.react-select__dropdown-indicator:hover {
    color: #333 !important;
}

/* Ensure dropdown containers don't clip the menu */
.react-select__menu-portal {
    z-index: 9999 !important;
}

/* Fix for dropdowns in scrollable containers */
.react-select__menu {
    position: fixed !important;
    z-index: 9999 !important;
}

/* Ensure proper positioning in different contexts */
.react-select-container {
    position: relative !important;
}

/* Mobile responsiveness for dropdowns */
@media (max-width: 768px) {
    .react-select__menu {
        max-height: 150px !important;
    }
    
    .react-select__menu-list {
        max-height: 142px !important;
    }
    
    .react-select__option {
        padding: 10px 12px !important;
        font-size: 16px !important; /* Prevents zoom on iOS */
    }
}

.form-control::placeholder {
    font-size: var(--font-size-14) !important;
    color: var(--font-color-default);
}

.image-input {
    background-color: var(--background-color);
    width: 366px;
    height: 126px;
    align-content: center;
}

.filter-pill {
    min-width: 163px;
    min-height: 67px;
    background-color: var(--background-color);
    border: 1px solid #C6C5C5;
    border-radius: 20px;
    text-align: center;
    align-content: center;
    cursor: pointer;
}

.filter-pill:hover {
    background-color: var(--hover-color);
    cursor: pointer;
}

.filter-pill.active {
    background-color: var(--default-color);
    color: var(--font-color-white);
    cursor: pointer;
}

.btn-primary {
    background-color: var(--default-color) !important;
    color: var(--font-color-white) !important;
    border: 1px solid var(--default-color) !important;
}

.btn-primary:disabled {
    background-color: var(--default-color-30) !important;
    color: var(--font-color-white) !important;
    border: 1px solid var(--default-color) !important;
}

.btn-primary:hover {
    background-color: var(--default-color-100) !important;
    color: var(--font-color-white) !important;
    border: 1px solid var(--default-color-100) !important;
}

.layout-margin {
    padding-top: var(--theme-layout-margin);
    height: 100%;
}

.cursor-pointer {
    cursor: pointer;
}

.bg-primary {
    background: var(--default-color) !important;
    color: var(--font-color-white);


}

.bg-white {
    background: var(--background-color) !important;
    color: var(--font-color-black);
}

.bg-gray-40 {
    background: var(--color-light-gray-40) !important;
    color: var(--font-color-black);
}


.upload-font {
    font-size: var(--font-size-20);
    background-color: var(--body-background-color);
    width: 40px;
    height: 40px;
    align-content: center;
    border-radius: 50%;
    justify-self: center;
}

.img-preview {
    width: 120px;
    height: 120px;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
}

.text-primary {
    color: var(--default-color) !important;
}


.fs-30 {
    font-size: var(--font-size-30);
}

.fs-22 {
    font-size: var(--font-size-22) !important;
}

.fs-20 {
    font-size: var(--font-size-20);
}

.fs-18 {
    font-size: var(--font-size-18) !important;
}

.fs-16 {
    font-size: var(--font-size-16) !important;
}

.fs-15 {
    font-size: var(--font-size-15);
}

.fs-14 {
    font-size: var(--font-size-14);
}

.fs-12 {
    font-size: var(--font-size-12);
}

.text-lightgray {
    color: var(--color-light-gray-10);
}

/* forgot password section */
.input-group-text {
    border-right: none !important;
}

.border-left-none {
    border-left: none !important;

}

.form-control.forgot {
    min-height: 47px;
}

.form-control.searchbar {
    min-height: 43px;
    max-width: 310px;
}

.form-control.email {
    min-height: 42px;
}

.keyhole-cicle {
    background-color: var(--color-light-green-10);
    width: 83px;
    height: 83px;
    border-radius: 50%;
    margin-inline: auto;
}

.error {
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
    border-color: var(--color-light-red-100);
    outline: 0;
    box-shadow: 0 0 0 .15rem rgba(255, 21, 21, 0.25);
}

.forgot.error:focus {
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
    border-color: var(--color-light-red-100);
    outline: 0;
    box-shadow: 0 0 0 .15rem rgba(255, 21, 21, 0.25);
}

.nav-pills .nav-link.active {
    background-color: var(--default-color);
    color: var(--font-color-white);
}

.nav-pills .nav-link.active i {
    background-color: var(--default-color);
    color: var(--font-color-white);
}

.nav-pills .nav-link i {
    background-color: transparent;
    color: var(--font-color-default);
}

.nav-pills .nav-link {
    background-color: var(--background-color);
    color: var(--font-color-black);
}

.nav-link:hover {
    color: var(--font-color-black);
}

.nav-link:focus {
    color: var(--font-color-black);
}

.navbar-nav .nav-link.show {
    color: var(--font-color-black);
}

.notyIconStyle {
    position: relative;
    display: inline
}

.notyNumStyle {
    position: absolute;
    right: -3px;
    background-color: var(--default-color);
    font-size: 11px;
    color: white;
    display: inline;
    padding: 3px 8px;
    border-radius: 20px
}

/* sidebar  */


#search {
    outline: 0;
    box-shadow: none !important;
    border-color: none !important;
}

#search:focus {
    outline: 0;
    box-shadow: none !important;
    border-color: #dee2e6 !important;
}

/* settings page */

.nav-pills .setting-pills.nav-link.active {
    border-radius: 6px;
    border: 1px solid var(--default-color);
    color: var(--font-color-black);
    background-color: var(--color-light-red-50) !important;
}

.custom-phone-input {
    width: 100%;
    padding: 0.375rem 0.75rem;
    /* Adjust padding as needed */
    border-radius: 0.25rem;
    min-height: 42px !important;
    /* Adjust border radius as needed */
}

.react-tel-input .flag-dropdown .flag {
    display: none;
}

.react-tel-input .flag-dropdown {
    z-index: auto !important;
    position: absolute;
    top: 0;
    bottom: 0;
    padding: 0;
    border-right-width: white;
    background-color: #f5f5f5;
    border: 1px solid #cacaca;
    border-right-color: white !important;
    border-radius: 5px 0 0 5px !important;
}

.react-tel-input .form-control {
    padding-left: 65px !important;
}

.selected-flag.country {
    position: relative;
    top: -33px;
    left: 12px;
}

.form-control.price-field {
    padding-left: 40px !important;
}

.react-tel-input .selected-flag {
    width: 55px !important;
    background: var(--background-color);
}

/* password toggle start */
.password-section {
    position: relative;
    display: inline-block;
}

.password-section .bi-eye {
    position: absolute;
    top: 50%;
    right: 30px;
    /* Adjust this value to control the icon's position */
    transform: translateY(-50%);
    cursor: pointer;
}

.password-section .bi-eye-slash {
    position: absolute;
    top: 50%;
    right: 30px;
    /* Adjust this value to control the icon's position */
    transform: translateY(-50%);
    cursor: pointer;
}

.password-signin {
    position: relative;
}

.password-signin .bi-eye {
    position: absolute;
    top: 70%;
    right: 30px;
    /* Adjust this value to control the icon's position */
    transform: translateY(-50%);
    cursor: pointer;
}

.password-signin .bi-eye-slash {
    position: absolute;
    top: 70%;
    right: 30px;
    /* Adjust this value to control the icon's position */
    transform: translateY(-50%);
    cursor: pointer;
}

/* password toggle end */

/* bootstrap next table */

.react-bootstrap-table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: -ms-autohiding-scrollbar;
    background-color: #fff;
    margin-bottom: 30px;
    border-radius: 15px;
    box-shadow: 0 9px 20px rgba(46, 35, 94, 0.07);
    padding: 0px;
}

.react-bootstrap-table table {
    border: 0;
    margin-bottom: 0;
}

.font-20 {
    font-size: 20px !important;
}

.table td,
.table th {
    border-bottom: 1px solid #dee2e6 !important;
    border-top: 0 !important;
}

.table-bordered th {
    border-bottom: 0 !important;
}

.table tbody+tbody {
    border-top: 1px solid #dee2e6 !important;
}

.table td,
.table th {
    vertical-align: middle !important;
    padding: 1.3rem 0.75rem !important;
}

.react-bootstrap-table thead>tr>th,
.react-bootstrap-table tbody>tr>td {
    position: relative;
    font-weight: 600;
    text-align: start;
    border-bottom: 1px solid #f0f0f0;
    transition: all 0.2s ease;
    padding: 20px 15px !important;
}

.react-bootstrap-table tbody>tr>td {
    color: #455560;
    font-weight: 400;
}

.react-bootstrap-table thead>tr>th {
    font-weight: 500 !important;
    color: #2f2f3b !important;
    background: #6e859f !important;
    color: #fff !important;
    line-height: 1;
}

.react-bootstrap-table .filter.form-control {
    font-weight: 400 !important;
    font-size: 14px !important;
    padding: 8px 15px !important;
}

.table-btns .text-info {
    color: #17a2b8 !important;
    background-color: #c0e9f0 !important;
}

.table-btns .text-primary {
    color: #007bff !important;
    background-color: #bfdeff !important;
}

.table-btns .text-success {
    color: #28a745 !important;
    background-color: #c7ffd3 !important;
}

.table-btns .text-danger {
    color: #dc3545 !important;
    background: #ffdee1 !important;
}

.table-btns .text-warning {
    color: #ffc107 !important;
    background: #fff2cc !important;
}

.table-btns .text-purple {
    color: #a66ffe !important;
    background: #ece1ff !important;
}

.table-btns .text-blue {
    background: #ccd2ff !important;
    color: #001eff !important;
}

.table-btns .text-orange {
    color: #ff9738 !important;
    background: #ffe3ca !important;
}

.react-bootstrap-table .table-bordered td,
.react-bootstrap-table .table-bordered th {
    border-bottom: 1px solid #dee2e6 !important;
}

.react-bootstrap-table-pagination {
    align-items: center;
}

#pageDropDown {
    background-color: transparent;
    border-color: #d1d4d7;
    color: #6c757d;
    font-size: 15px;
    font-weight: 400;
    padding: 6px 13px;
    line-height: 1;
}

#pageDropDown.dropdown-toggle::after {
    vertical-align: 0.2em;
}

.react-bootstrap-table table {
    table-layout: auto !important;
}

.user-table .table-bordered {
    border: white !important;
}

.user-table .react-bootstrap-table thead>tr>th {

    background: var(--table-header-bg) !important;
    color: var(--font-color-black) !important;
    line-height: 1;
    border-color: var(--table-header-bg) !important;
}

.filter-label .sr-only {
    display: none !important;
}

.ck-editor__editable {
    border-radius: 5px !important;
    min-height: 128px !important;
}

.ck .ck-dropdown__button {
    background-color: white !important;
    border-radius: 5px !important;
    padding: 5px 15px 5px 15px !important;
    border: 1px solid rgb(202, 201, 201) !important;
    font-weight: 500 !important;
}

.ck.ck-icon {
    font-size: var(--font-size-16) !important;
    font-weight: 500 !important;
}

.ck .ck-powered-by {
    display: none !important;

}

.ck .ck-button__label {
    font-size: var(--font-size-16) !important;
    font-weight: 500 !important;
}

.ck.ck-editor__top .ck-sticky-panel .ck-sticky-panel__content {
    border: none !important;
    background-color: transparent !important;
}

.ck .ck-toolbar .ck-toolbar_grouping {
    background-color: transparent !important;
}

.ck .ck-toolbar {
    background-color: transparent !important;
}

.ck.ck-dropdown .ck-button.ck-dropdown__button {
    z-index: 0 !important;
}

.signupDocuments {
    max-width: 200px;
    display: inline-block;
    vertical-align: middle
}

.rs-stack-item {
    z-index: 9999999999999999999999999999999999 !important;
    /* Adjust the value as needed */
    position: static;
    border: 1px red
}

.bg-success-light {
    background-color: var(--color-light-green-40) !important;
}

/* payment Modal Start */

.payment-key-box {
    max-width: 92%;
    min-height: 70px;
    border: 1px solid #DEDEDE;
    background: var(--body-background-color) !important;
    color: var(--color-dark-gray);
    border-radius: 4px;
    margin-inline: auto;
}

.payment-keys {
    cursor: pointer;
    min-width: 30%;
    min-height: 70px;
    background: var(--body-background-color);
    color: var(--color-dark-gray);
    border-radius: 4px;
}

.payment-price-keys {
    min-width: 45.5%;
    min-height: 70px;
    background: var(--body-background-color);
    color: var(--color-dark-gray);
    border-radius: 4px;
}

.check-icon {
    font-size: var(--font-size-66);
    color: var(--color-light-green-40);
}

.form-switch .form-check-input {
    cursor: pointer;
    width: 3.5em;
    height: 26px;
}

.form-switch .form-check-input:focus {
    --bs-form-switch-bg: url(data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='#fff'/%3e%3c/svg%3e) !important;
}

.form-check-input:checked {
    background-color: var(--default-color);
    border-color: var(--default-color);
}

.form-check-input:focus {
    border-color: var(--default-color);
    box-shadow: none;
}

.form-switch .form-check-input:hover {
    border: 2px solid #fa3e67c0;
}

.form-switch .form-check-input:focus {
    --bs-form-switch-bg: url(data: image/svg+xml, <svg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'><circle r='3' fill='%2386b7fe' /></svg>) !important;
}

/* payment Modal End */
.react-bootstrap-table {
    min-height: 300px;
}

@media only screen and (max-width: 480px) {
    .width-100 {
        width: 90vw !important;
    }
}

@media only screen and (max-width: 480px) and (min-width: 480px) {
    .width-100 {
        width: 137px !important;
    }
}

.skeleton-wrapper {
    padding: 15px;
}

.skeleton-line {
    height: 15px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 4px;
}



.skeleton-image-product {
    width: 80px;
    height: 80px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 4px;
}

.skeleton-image {
    width: 60px;
    height: 60px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 4px;
}

.w-75 {
    width: 75%;
}

.w-100 {
    width: 100%;
}

.w-50 {
    width: 50%;
}

.w-32 {
    width: 120px;
}

.h-32 {
    height: 32px;
}

@keyframes shimmer {
    0% {
        background-position: 200% 0;
    }

    100% {
        background-position: -200% 0;
    }
}

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 1rem;
}

/* Ensure table cells don't break into multiple lines */
.table td,
.table th {
    white-space: nowrap;
    vertical-align: middle;
}

/* Optional: Add horizontal padding to cells for better spacing */
.table td,
.table th {
    padding-left: 1rem;
    padding-right: 1rem;
}

/* Optional: Fix header position */
.react-bootstrap-table th {
    position: sticky;
    top: 0;
    background: white;
    z-index: 1;
}

/* Ensure filters don't overflow */
.react-bootstrap-table-filter-text {
    max-width: 100%;
}

/* Handle Select component overflow */
.react-select__control {
    min-width: 150px;
    /* Adjust based on your needs */
}

.tooltip-inner {
    background-color: #000000;
    /* Red tooltip background */
    color: white;
}

.tooltip.bs-tooltip-top .tooltip-arrow::before {
    border-top-color: #000000;
}

/* Category Grid Layout */
.category-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    width: 100%;
}

/* Fixed Order Summary */
.order-summary-fixed {
    position: fixed;
    top: 20px;
    right: 20px;
    width: calc(33.333% - 20px);
    height: calc(100vh - 40px);
    overflow-y: auto;
    max-height: calc(100vh - 40px);
    z-index: 1000;
}