#loader {
    position: fixed;
    width: 100%;
    height: 100vh;
    z-index: 999999;
    overflow: visible;
    background: #fff;
}

#loader img {
    width: 100%;
    height: 100%;
    max-width: 150px;
    max-height: 150px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}

.auth-logo img {
    width: 100%;
    height: 100%;
    max-width: 200px;
    object-fit: cover;
}

.auth-pass-inputgroup input~button {
    border-radius: var(--bs-border-radius) !important;
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.auth-pass-inputgroup input.is-invalid~button {
    border-color: var(--bs-form-invalid-border-color);
    border-left: none;
}

#toastContainer .toast-header .btn-close{
    background: none;
    line-height: 20px;
}

#toastContainer .toast-header{
    border-radius: 5px;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

#toastContainer .toast-body{
    border-radius: 5px;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

@media (max-width:480px) {
    #toastContainer {
        width:100%;
    }
}

.logo img {
    width: 100%;
    max-width: 180px;
    height: auto;
}

.logo img.logo-icon{
    display: none !important;
}

.navbar-brand-box{
    display: flex;
    align-items: center;
}

#page-header-user-dropdown~.dropdown-menu{
    margin-right: 10px !important;
}

@media (min-width:991px) {
    body.sidebar-enable:not(.full-sidebar) .logo img:not(.logo-icon){
        display: none !important;
    }

    body.sidebar-enable:not([data-bs-theme="dark"]):not(.full-sidebar) .logo.logo-dark img.logo-icon{
        display: block !important;
        padding: 0;
    }

    body.sidebar-enable[data-bs-theme="dark"]:not(.full-sidebar) .logo.logo-light img.logo-icon{
        display: block !important;
        padding: 0;
    }
}


@media (max-width:991px) {
    .logo img {
        max-width: 201px;
    }
}

@media (max-width:768px) {
    body .logo img:not(.logo-icon){
        display: none !important;
    }

    body:not([data-bs-theme="dark"]) .logo.logo-dark img.logo-icon{
        display: block !important;
        padding: 0;
    }

    body[data-bs-theme="dark"] .logo.logo-light img.logo-icon{
        display: block !important;
    }

    img.logo-icon {
        width: 100%;
        height: 100%;
        max-width: 70px;
    }
    .navbar-brand-box{
        padding: 0 10px;
    }
}

.form-footer .btn {
    min-width: 100px;
}

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

.select2-container.select2-container--open{
    z-index: 1111;
}

select~.select2-container .select2-selection {
    border: 1px solid var(--bs-border-color);
}

select~.select2-container .select2-selection .select2-selection__rendered {
    color: var(--bs-body-color);
}

select~.select2-container .select2-selection {
    background-color: var(--bs-tertiary-bg);
}
select~.select2-container .select2-selection .select2-selection__arrow {
    top: 0px;
    right: 5px;
}

select~.select2-container .select2-selection.select2-selection--single .select2-selection__rendered {
    height: 38px;
    line-height: 38px;
    padding-left: 12px;
}

select~.select2-container .select2-selection.select2-selection--single {
    min-height: 38px;
}
select~.select2-container .select2-selection.select2-selection--single .select2-selection__arrow {
    height: 38px;
}

.select2-container .select2-selection--multiple .select2-search--inline .select2-search__field {
    margin-top: 9px;
}

.select2-container--default .select2-selection--multiple{
    min-height: 38px;
}

.select2-container--default.select2-container--focus .select2-selection--multiple{
    border: 1px solid var(--bs-border-color);
}

.select2-container .select2-search .select2-search__field:focus-visible {
    outline: none !important;
}

.select2-container .select2-dropdown{
    background: var(--bs-tertiary-bg);
}

.radio-group {
    min-height: 35px;
    align-items: center;
}

.radio-group.is-invalid .form-check-input,
select.is-invalid~.select2-container .select2-selection{
    border-color: var(--bs-form-invalid-border-color);
}

.timing-box {
    box-shadow: 1px 2px 4px 0 rgba(34, 41, 47, 0.1);
    border-radius: 10px;
    border-left: 4px solid #5156be !important;
}
@media (min-width:768px) {
    .time-delete {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}

.bullet-info{
    list-style-type: none;
    padding: 0;
    margin: 0 !important;
}

.gslide .gslide-title{
    margin-bottom: 0;
}

.text-justify{
    text-align: justify !important;
}

.cleaner-availability {
    border-radius: 5px;
    padding: 10px;
    margin-bottom: 10px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;
}

#sidebar-menu ul li ul.sub-menu li a {
    padding-left: 2rem;
}

.page-title-box h4 {
    text-transform: capitalize;
}

span.tox-statusbar__branding,
.tox .tox-promotion {
    display: none;
}

.tox-tinymce {
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: var(--bs-border-radius) !important;
}

textarea.form-control.is-invalid~.tox-tinymce {
    border: 1px solid #ff3f3f !important;
}

#sidebar-menu ul li ul.sub-menu li a.sub-active {
    color: var(--bs-sidebar-menu-item-active-color);
}

.task-assign{
    background-color: #17A2B8 !important;
    border-color: #17A2B8 !important;
}

.task-process{
    background-color: #6F42C1 !important;
    border-color: #6F42C1 !important;
}

.task-complete{
    background-color: #28A745 !important;
    border-color: #28A745 !important;
}

.task-cancel{
    background-color: #DC3545 !important;
    border-color: #DC3545 !important;
}

.task-reschedule{
    background-color: #FFC107 !important;
    border-color: #FFC107 !important;
}

#calendar .fc-event {
    cursor: pointer;
    transition: .5s;
}

#calendar .fc-event:hover {
    opacity: .7;
}

#calendar .fc-view:not(.fc-list) .fc-event {
    display: block;
}

#calendar .fc-button {
    text-transform: capitalize;
}

#calendar.fc .fc-list-event:hover td {
    background-color: inherit !important;
    opacity: .8;
    transition: .2s;
}

.holiday {
    font-weight: bold;
    color: #b30000 !important;
    border: 1px solid #d9534f;
    background: repeating-linear-gradient(
    45deg,
    #ffffff,
    #ffffff 10px,
    #ffe6e6 10px,
    #ffe6e6 20px
  );
    text-shadow: 1px 1px 2px #fff;
}

.holiday .fc-event-main {
    color: #b30000 !important;
    font-size: 10px;
}

#calendar .fc-event ul{
    list-style: none;
    text-align: left;
    text-wrap: auto;
    padding: 0;
    margin: 0;
    font-size: 10px;
}

.export-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

#progressContent .tab-pane img {
    width: 100%;
    height: 100%;
    max-height: 200px;
}

.calendar-status .badge {
    font-size: 8px;
    padding: 5px;
    color: #fff;
}

.notification-item:not(:last-child) .d-flex,.notification-title {
    border-bottom: 1px solid var(--bs-border-color);
}

.point-item .input-group input {
    border-top-right-radius: var(--bs-border-radius) !important;
    border-bottom-right-radius: var(--bs-border-radius)  !important;
}

.input-group:has(.is-invalid) .input-group-text {
    border-color: var(--bs-form-invalid-border-color);
}

fieldset.recurrence-section {
  border: 1px solid #ddd;
  border-radius: 4px;
  margin-bottom: 20px;
  padding: 15px;
}

.recurrence-section legend {
    font-size: 16px;
    color: #333;
    font-weight: bold;
    float: unset;
    width: auto;
    padding: 0 5px;
}

.radio-button-container {
    color: rgba(0,0,0,0.75);
    display: block;
    align-items: center;
    position: relative;
    padding-left: 30px;
    line-height: 18px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: 14px;
    font-weight: normal;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/* Hide the browser's default radio button */
.radio-button-container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

/* Create a custom radio button */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 18px;
    width: 18px;
    background-color: rgba(0,0,0,0);
    border-radius: 50%;
    border: 1px solid rgba(0,0,0,0.25);
    transition: all 0.5s;
}

/* On mouse-over, add a grey background color */
.radio-button-container:hover input ~ .checkmark {
  border-color: rgba(0,0,0,0.5);
}

/* When the radio button is checked */
.radio-button-container input:checked ~ .checkmark {
  background-color: rgba(0,0,0,0);
  border-color: #5156be;
}


/* Create the indicator (the dot/circle - hidden when not checked) */
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

/* Show the indicator (dot/circle) when checked */
.radio-button-container input:checked ~ .checkmark:after {
  display: block;
}

/* Style the indicator (dot/circle) */
.radio-button-container .checkmark:after {
    top: 2px;
    left: 2px;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: #5156be;
}

fieldset.weekdays-section {
  border: 1px solid #ddd;
  border-radius: 4px;
  margin-bottom: 20px;
  padding: 15px;
}

.weekdays-section legend {
    font-size: 14px;
    color: #333;
    font-weight: bold;
    float: unset;
    width: auto;
    padding: 0 5px;
}

.weekdays-content {
  display: flex;
  flex-wrap: wrap; /* allows wrapping on small screens */
  gap: 10px;       /* spacing between items */
}

.weekdays-content .form-group {
  display: flex;
  align-items: center;
}

.weekdays-content .form-group input {
  display: none;
}

.weekdays-content .form-group label {
    position: relative;
    cursor: pointer;
    text-transform: capitalize;
    font-size: 14px;
    font-weight: normal;
    margin: 0;
}

.weekdays-content .form-group label:before {
    content: '';
    -webkit-appearance: none;
    background-color: transparent;
    border: 1px solid #0079bf;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
    padding: 8px;
    display: inline-block;
    position: relative;
    vertical-align: middle;
    cursor: pointer;
    margin-right: 5px;
}

.weekdays-content.is-invalid .form-group label:before{
    border-color: var(--bs-form-invalid-border-color);
}

.weekdays-content  .form-group input:checked ~ label:after {
    content: '';
    display: block;
    position: absolute;
    top: 5px;
    left: 6px;
    width: 5px;
    height: 11px;
    border: solid #0079bf;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

@media (max-width: 991px) {
  .weekdays-content {
    justify-content: space-between;
  }
  .weekdays-content .form-group {
    flex: 1 1 25%;
    }
}

@media (max-width: 768px) {
  .weekdays-content .form-group {
    flex: 1 1 30%; /* 3 per row */
  }
}

/* Mobiles */
@media (max-width: 480px) {
  .weekdays-content .form-group {
    flex: 1 1 45%; /* 2 per row */
  }
}

/* Extra small (≈350px) */
@media (max-width: 360px) {
  .weekdays-content .form-group {
    flex: 1 1 100%; /* stack vertically */
  }
}


.ordinals-content {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}

.ordinals-content .form-group {
  display: flex;
  align-items: center;
}

.ordinals-content .form-group input {
  display: none;
}

.ordinals-content .form-group label {
  position: relative;
  cursor: pointer;
  text-transform: capitalize;
  font-size: 14px;
  font-weight: normal;
  margin: 0;
}

/* Radio circle */
.ordinals-content .form-group label:before {
  content: '';
  -webkit-appearance: none;
  background-color: transparent;
  border: 1px solid #0079bf;
  border-radius: 50%; /* circle instead of square */
  padding: 8px;
  display: inline-block;
  position: relative;
  vertical-align: middle;
  cursor: pointer;
  margin-right: 5px;
}

.ordinals-content.is-invalid .form-group label:before{
    border-color: var(--bs-form-invalid-border-color);
}

/* Radio checked (dot in circle) */
.ordinals-content .form-group input:checked ~ label:after {
    content: '';
    display: block;
    position: absolute;
    top: 7.2px;
    left: 4.2px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #0079bf;
}

@media (max-width: 480px) {
    .ordinals-content {
        justify-content: space-between;
    }
  .ordinals-content .form-group {
    flex: 1 1 45%;
  }
}

@media (max-width: 360px) {
  .ordinals-content .form-group {
    flex: 1 1 100%;
  }
}
