body {
    font-family: "Roboto", sans-serif;
}

:root {
    --mainColor: #36f;
    --lightBg: #eef1f9;
    --hoverColor: #36f;
    --borderColor: #e8e8e8;
    --lightText: #aab3cc
}

.error {
    color: rgb(249, 52, 52);
}

.app-header .user-link-box {
    width: 44px;
    height: 44px;
    border-radius: 44px;
    overflow: hidden;
    border: 2px solid #d1d1d1;
}

.app-header .user-link-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gap-5 {
    gap: 20px;
}

.gap-4 {
    gap: 16px;
}

.gap-3 {
    gap: 12px;
}

.gap-2 {
    gap: 8px;
}

.google-setting-alert .alert.alert-warning {
    font-size: 14px;
    margin-bottom: 0 !important;
}

.custom-table.table,
.custom-table.table th,
.custom-table.table td {
    border-color: var(--borderColor) !important;
}

table.custom-table thead tr th {
    background-color: var(--lightBg) !important;
}

table.custom-table tr th {
    color: #0b0b0b !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 27px;
    white-space: nowrap;
}

table.custom-table tbody td {
    color: #333;
    /* font-family: "SF Pro Display"; */
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    word-break: break-all;
}

table.custom-table {
    border-radius: 6px;
    width: 100% !important;
}

.custom-table.table th:first-child {
    border-radius: 6px 0 0 6px;
}

.custom-table.table th:last-child {
    border-radius: 0 6px 6px 0px;
}

.card .table-responsive-data .table thead th {
    padding: 10px 37px 10px 20px !important;
}

.card .table-responsive-data .table td,
.card .table-responsive-data .table tbody td {
    padding: 10px 24px 10px 20px !important;
}

.custom-table.table td .action-btns1 .text-info {
    color: #1497fa !important;
}

.custom-table.table td .action-btns1 .text-primary {
    color: #7b92ff !important;
}

.custom-table.table td .action-btns1 .text-danger {
    color: #ef3956 !important;
}

.pagination {
    flex-wrap: wrap;
}

.pagination .paginate_button .page-link {
    color: #898787;
    /* font-family: "SF Pro Display"; */
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px;
}

.pagination .page-item.active .page-link {
    color: #fff;
}

.table-responsive-data .col-sm-12 {
    overflow: auto;
}

.swal2-container .swal2-popup {
    border-radius: 12px;
    padding: 32px;
}

.swal2-container .swal2-popup .swal2-title {
    color: #333;
    font-size: 28px;
    line-height: 42px;
    margin-bottom: 6px;
}

.swal2-container .swal2-popup .swal2-html-container {
    color: #898787;
    font-size: 18px;
    font-weight: 400;
    line-height: 27px;
}

.swal2-container .swal2-popup .swal2-actions {
    margin-top: 30px;
    padding: 0;
    gap: 16px;
}

.swal2-actions .swal2-cancel,
.swal2-actions .swal2-deny,
.swal2-actions .swal2-confirm {
    padding: 15px 22px;
    color: #fff;
    text-align: center;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 24px;
    margin: 0;
}

.swal2-container .swal2-popup .swal2-actions .swal2-confirm {
    background-color: var(--mainColor);
}

.swal2-container .swal2-popup .swal2-actions .swal2-cancel {
    background: #aaa;
}

.form-control::placeholder,
.number-select input::placeholder {
    color: #898787 !important;
    font-size: 16px;
    font-weight: 400;
}

.number-select input {
    border-left: 1px solid #d1d1d1 !important;
    padding-left: 12px;
}

.ct-btn-w {
    min-width: 130px;
}

.card .fill-header-bg {
    border-radius: 12px !important;
    background: #f8f9fa !important;
}

.card-table-title {
    color: #333;
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: 27px;
}

div.dataTables_wrapper div.dataTables_length select {
    height: 36px !important;
    padding: 0 5px;
    text-align: center;
}

div.dataTables_wrapper div.dataTables_filter input {
    padding: 6px 15px;
}

.removeSocialMedia,
.removeExternalLink {
    background-color: transparent;
    padding: 0;
    border: 0;
    text-align: center;
    width: 100%;
}

.removeSocialMedia i,
.removeExternalLink i {
    font-size: 22px;
    color: #f7284a;
}

.card-max-width {
    max-width: 837px;
    width: 100%;
}

.list-product-table table tr td .objectContain,
.showList-product-img {
    width: 100px;
    height: 80px;
    object-fit: cover;
    border-radius: 4px;
}

.list-product-table table tr td .objectContain,
.showList-occasion-img {
    width: 100px;
    height: 80px;
    object-fit: contain;
    border-radius: 4px;
}

.product-img-ct {
    width: 180px;
    height: 180px;
    object-fit: contain;
    border-radius: 12px;
}

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

select.form-control:not([size]):not([multiple]) {
    height: auto !important;
}

.ct-select-border .select2-container--default .select2-selection--multiple {
    border: 1px solid #d1d1d1 !important;
    border-radius: 6px;
    padding: 5px 30px 5px 16px;
}

.select-arrow-be::before {
    content: "";
    right: 14px;
    top: 20px;
    border-color: #888 transparent transparent transparent;
    border-style: solid;
    border-width: 5px 5px 0 5px;
    width: 6px;
    height: 6px;
    position: absolute;
    z-index: 7;
}

.select-arrow-be select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.select2-container .select2-search--inline .select2-search__field {
    font-size: 16px !important;
}

.multiple-select-width .select2-container {
    width: 100% !important;
}

.was-validated .form-control:invalid,
.form-control.is-invalid {
    background-position: right calc(0.375em + 1.1875rem) center;
}

.logo-width-table {
    width: 59px;
    height: 53px;
    border-radius: 4px;
    object-fit: cover;
}

.user-data-dropdown .user {
    color: #0b0b0b;
    font-size: 18px;
    font-weight: 400;
    line-height: 27px;
}

.user-data-dropdown .border-bottom {
    border-bottom: 1px solid #e8e8e8 !important;
}

.user-data-dropdown .dropdown-item {
    color: #333;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
}

.user-profile-img {
    max-width: 290px;
    max-height: 290px;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.logo-img {
    max-width: 150px;
    max-height: 150px;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.fav-icon-img {
    max-width: 150px;
    max-height: 150px;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.object-cover{
object-fit: cover;
}
.round-12{
border-radius: 12px;
}
.login-card-width {
    max-width: 550px;
    width: 100%;
    border-radius: 12px;
    margin: 0 auto;
    padding: 44px;
}

.login-card-width .logo-name-text {
    margin: 35px 0;
}

.login-card-width .login-logo img {
    width: 180px;
    height: auto;
    object-fit: contain;
}

.login-card-width .login-title {
    color: #1a4598;
    /* font-family: "SF Pro Display"; */
    font-size: 40px;
    font-weight: 700;
    line-height: 60px;
}

.login-card-width .text {
    color: #000;
    /* font-family: "SF Pro Display"; */
    font-size: 22px;
    font-weight: 400;
    line-height: 27px;
    margin-bottom: 0px;
}

.login-card-width .form-label {
    /* font-family: "SF Pro Display"; */
    font-size: 16px;
    line-height: 27px;
}

.login-card-width .btn-block {
    margin-top: 54px;
}

.login-card-width .custom-control-label:after,
.login-card-width .custom-control-label:before {
    height: 20px;
    width: 20px;
}

.login-card-width .custom-control-label:before {
    border: 1px solid #d1d1d1;
}

.login-card-width .custom-control.custom-checkbox .custom-control-label {
    padding-left: 10px;
}

.login-card-width .ct-btn-w {
    width: fit-content;
    margin: 50px auto 0 auto;
    border-radius: 12px;
    padding: 12px;
}

#back-to-top .feather-chevrons-up {
    font-size: 26px;
    line-height: 47px;
}

.fs-20 .view-eye-btn {
    width: 50px !important;
    height: 40px !important;
    border-radius: 9px;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
    white-space: normal;
    text-overflow: ellipsis;
    word-break: break-all;
}

.card-text {
    font-size: 16px;
    font-weight: 500;
    line-height: 26px;
    color: #898787;
}

.card-text strong {
    color: #333;
}

.card-header .arrow-btn {
    transition: all 0.5s ease;
}

/* .card-header .arrow-btn:not(.collapsed){
    transform: scaleY(-1);
} */
.card-header .arrow-btn[aria-expanded="true"] {
    transform: scaleY(-1);
}

.rounded-3 {
    border-radius: 6px;
}

.text-16 {
    font-weight: 400;
    font-size: 16px !important;
    line-height: 28px;
}

.icons-logo {
    display: none;
    width: 40px;
    height: 40px;
    object-fit: contain;
}

.sidebar-mini .full-logo {
    max-width: 78px;
    width: 100%;
    object-fit: contain;
}

.sidebar-mini.sidenav-toggled .full-logo,
.sidebar-mini.sidenav-toggled.sidenav-toggled1 .icons-logo {
    display: none;
}

.sidebar-mini.sidenav-toggled .icons-logo,
.sidebar-mini.sidenav-toggled.sidenav-toggled1 .full-logo {
    display: block;
}

.login-logo-ct {
    max-width: 140px;
    width: 100%;
    margin-bottom: 15px;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

.breadcrumb1 {
    background-color: transparent !important;
}

.ct-check-btn-l .form-check {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0;
}

.ct-check-btn-l .form-check .form-check-input {
    width: 16px;
    height: 17px;
    position: relative;
    margin: 0;
}
.ct-check-btn-l .form-check .form-check-label{
    font-size: 16px;
    line-height: normal;
    margin: 0;
}
.main-product-img  {
    width: 100%;
    max-width: 100%;
    max-height: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 8px;
}
.gallery-img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 5px;
    margin: 5px;
}
.gallery-item {
    position: relative;
    display: inline-block;
    margin: 5px;
}
.gallery-delete-btn {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 20px;
    height: 20px;
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}
.gallery-delete-btn:hover {
    background: #c82333;
}

.main-image-item {
    position: relative;
    display: inline-block;
}
.main-delete-btn {
    position: absolute;
    top: 5px;
    right: 5px;
    width: 25px;
    height: 25px;
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}
.main-delete-btn:hover {
    background: #c82333;
}
.addon-row td {
    vertical-align: middle;
}
.existing-gallery-img {
    position: relative;
    display: inline-block;
    margin: 5px;
}
.existing-delete-btn {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 20px;
    height: 20px;
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
}
.existing-delete-btn:hover {
    background: #c82333;
}

.addon-item {
    border: 1px solid #ddd;
    padding: 10px;
    margin: 5px 0;
    border-radius: 5px;
    background: #f9f9f9;
}
.remove-addon {
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 3px;
    padding: 2px 8px;
    cursor: pointer;
}
.image-preview-container {
    text-align: center;
    margin-top: 20px;
}

.select-items{
    width: 80%;
}

.select-predefined-items,.select-edit-predefined-items{
    width: 100% !important;
}

.select-items .select2-container {
    width: 100% !important;
}
.select-items .select2-container--default .select2-selection--single,
.select-items .select2-container--default .select2-selection--multiple {
    height: 43px;
    line-height: 36px;
    border: 1px solid #ced4da;
    border-radius: 0.25rem;
}

.select-items .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 12px;
    color: #495057;
    line-height: 31px !important
}

.select-items.select-predefined-items .select2-container--default .select2-selection--multiple .select2-selection__rendered{
    color: #495057;
    line-height: 31px !important
}

.select-predefined-items .select2-container .select2-search--inline .select2-search__field{
    height: 100%;
}

.select-items .select2-container--default .select2-selection--single .select2-selection__clear,
.select-items .select2-container--default .select2-selection--multiple .select2-selection__clear{
    display: none;
}

.addon-select-option {
    padding: 8px 12px;
}

.addon-name {
    font-weight: 600;
    color: #333;
}

.addon-price {
    color: #28a745;
    font-weight: 500;
}

.addon-category {
    color: #6c757d;
    font-size: 0.875em;
}

.select-predefined-items .select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: #a3a4a5 !important;
}

.select-predefined-items .select2-selection__choice__remove{
    display: none;
}

.predefined-show-section .info-card {
    background: white;
    border-radius: 0.5rem;
    padding: 20px;
    margin-bottom: 20px;
    border: 1px solid #e9ecef;
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

.predefined-show-section .info-card h5 {
    color: #495057;
    font-weight: 600;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid #e9ecef;
}

.predefined-show-section .info-item {
    display: flex;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid #f8f9fa;
}

.predefined-show-section .info-item:last-child {
    border-bottom: none;
}

.predefined-show-section .info-label {
    font-weight: 600;
    color: #6c757d;
    min-width: 100px;
    margin-right: 15px;
}

.predefined-show-section .info-value {
    flex: 1;
}

.predefined-show-section .item-image {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: 8px;
    margin-right: 15px;
}

.predefined-show-section .product-info, .predefined-show-section .addon-info {
    display: flex;
    align-items: center;
}

.predefined-show-section .item-details h6 {
    margin: 0 0 5px 0;
    font-weight: 600;
}

.predefined-show-section .item-details small {
    color: #6c757d;
}

.predefined-show-section .summary-card {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    border-radius: 0.75rem;
    padding: 25px;
    margin-bottom: 20px;
}

.predefined-show-section .summary-card h5 {
    color: white;
    margin-bottom: 20px;
    font-weight: 600;
}

.predefined-show-section .summary-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

.predefined-show-section .summary-item:last-child {
    border-bottom: none;
}

.predefined-show-section .summary-label {
    font-weight: 500;
    opacity: 0.9;
}

.predefined-show-section .summary-value {
    font-weight: 600;
}

.predefined-show-section .status-indicator {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.predefined-show-section .status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.predefined-show-section .status-dot.active {
    background-color: #28a745;
}

.predefined-show-section .status-dot.inactive {
    background-color: #dc3545;
}

.predefined-show-section .action-buttons {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.page-predefined-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

.toggle-password{
    position: absolute;
    right: 11px;
    top: 46px;
    cursor: pointer;
    font-size: 16px;
}

.text-black{
    color: black;
}

.daterangepicker .drp-buttons {
    display: flex !important;
    justify-content: flex-end;
    align-items: center;
}

.app-sidebar__logo .full-logo{
    max-height: 60px;
    height: 100%;
    object-fit: contain;
}

/* @media =========
=================== */

@media (max-width: 1200px) {
    .select-items{
        width: 100%;
    }
}

@media (max-width: 1540px) and (min-width: 1200px) {
    .select-items{
        width: 70%;
    }
}

@media (max-width: 980px) {
    .table-responsive-data .dataTables_wrapper .col-md-6 {
        flex: 0 0 100%;
        max-width: 100%;
    }

    div.dataTables_wrapper div.dataTables_filter label {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .page-predefined-actions {
        margin-top: 15px;
        justify-content: flex-start;
    }

    .predefined-show-section .action-buttons {
        justify-content: flex-start;
    }
}

@media (max-width: 600px) {
    .page-header {
        align-items: flex-start;
    }

    .breadcrumb1 .breadcrumb-item1 {
        font-size: 14px;
        line-height: 22px;
    }

    .breadcrumb-item1+.breadcrumb-item1:before {
        padding-left: 9px;
        padding-right: 9px;
    }

    .btn {
        padding: 8px 15px;
    }

    .breadcrumb1 {
        margin-top: 8px;
    }

    .swal2-container .swal2-popup {
        padding: 20px;
    }

    .ct-btn-w {
        min-width: 79px;
    }

    .card-body {
        padding: 20px;
    }

    .card-header {
        padding: 16px 20px 0 30px;
    }

    .list-product-table table tr td .objectContain,
    .showList-product-img {
        width: 80px;
        height: 60px;
    }

    .product-img-ct {
        width: 100%;
        height: auto;
    }

    .login-card-width {
        padding: 20px;
    }

    .login-card-width .login-title {
        font-size: 31px;
        line-height: 41px;
    }

    .login-card-width .logo-name-text {
        margin: 21px 0;
    }

    .login-card-width .btn-block {
        margin-top: 30px;
    }
}

@media (max-width: 500px) {
    .predefined-show-section .item-image {
        width: 40px;
        height: 40px;
    }
}
