.calendarBS {
    width: calc(100% - 40px);
    margin: 20px auto !important;
    max-width: 1100px;
}
.calendarBS.noclickable, .calendarBS.noclickable *, .calendarBS .wc-calendar-view-container .noclickable * {
    pointer-events: none !important;
    touch-action: none !important;
}

/* .calendarBS .wc-calendar-view-container {
    overflow-y: auto !important;
} */
.calendarBS, .calendarBS * {
    cursor: default !important;
}
.calendarBS .row.wc-calendar-content {
    flex: 0 1 auto !important;
}
.calendarBS .row.wc-calendar-content [data-month-date]:last-child {
    border-right: 0 !important;
}
/* .calendarBS .row.wc-calendar-content:last-child [data-month-date].border-bottom {
    border-bottom: none !important;
} */
.calendarBS [data-appointment="true"] {
    padding: 0 !important;
    display: flex;
    align-items: stretch;
    max-width: calc(100% - 10px);
    margin-left: 5px;
    margin-right: 5px;
    height: auto;
    border-bottom: 1px solid #fff;
}
.calendarBS [data-appointment="true"].notAllowed {
    pointer-events: none !important;
    cursor: pointer !important;
}
.calendarBS [data-appointment="true"] > div {
    padding: 0 5px !important;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
} 
.calendarBS [data-appointment="true"] .reserved {
    background: #d7d7d7;
    /* cursor: not-allowed; */
    pointer-events: none;
    cursor: pointer;
    /* height: 30px; */
}
.calendarBS [data-appointment="true"] .notReserved {
    background: rgb(41, 92, 143);
    cursor: pointer !important;
    /* height: 30px; */
}
.calendarBS [data-appointment="true"] .notReserved *,
.calendarBS [data-appointment="true"] .yourDate * {
    cursor: pointer !important;
}
.calendarBS [data-appointment="true"] .notReserved:hover {
    background: rgba(41, 92, 143, 0.8);
}
.calendarBS [data-appointment="true"] .yourDate {
    background: rgba(48, 114, 22, 1);
    cursor: pointer !important;
    /* height: 30px; */
}
/* .calendarBS [data-appointment="true"] .multi {
    height: 45px;
} */
.calendarBS [data-appointment="true"] .yourDate:hover {
    background: rgba(48, 114, 22, 0.8);
}
.calendarBS [data-appointment="true"] .appointmentShow {
    background:rgba(0, 132, 235, 0.8);
}
.calendarBS [data-appointment="true"] .appointmentShow:hover {
    background:rgba(0, 132, 235, 1);
}
.calendarBS [data-appointment="true"] h5 {
    font: 16px/1 "Font Bold";
    color: #fff;
    margin-bottom: 0;
}
.calendarBS [data-appointment="true"] h5 span {
    font: 14px/1 "Font Regular";
    color: #fff;
}
.calendarBS [data-appointment="true"] .reserved h5,
.calendarBS [data-appointment="true"] .reserved h5 span {
    color: #666;
}
.calendarBS [data-appointment="true"] .past {
    background: #f4f4f4;
    cursor: not-allowed;
    height: 30px;
}
.calendarBS [data-appointment="true"] .past h5,
.calendarBS [data-appointment="true"] .past h5 span {
    color: #999;
}
.calendarBS .current-time-indicator {
    display: none !important;
}
.calendarBS [data-month-date] {
    height: auto !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-items: flex-start !important;
    align-content: flex-start !important;
    min-height: 110px;
}
/* .calendarBS .wc-calendar-view-container.monthView {
    padding-bottom: 0 !important;
}*/
.calendarBS .wc-calendar-view-container.monthView .wc-calendar-content:last-child > div {
    border-bottom: 1px solid #dee2e6!important;
} 
.calendarBS .wc-calendar-view-container {
    
    height: auto !important;
}
.calendarBS [data-month-date] [data-date] {
    width: 100%;
    display: block;
    pointer-events: none;
}
.calendarBS [data-month-date] [data-eventdate-id] {
    height: auto;
    min-height: 30px;
    padding-top: 3px;
    padding-bottom: 3px;
}
.calendarBS [data-month-date] [data-eventdate-id].multi {
    min-height: 45px;
}
.calendarBS [data-role="day-wrapper"] {
    /* height: auto !important; */
    overflow: hidden !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-self: flex-start;
    align-content: flex-start;
    max-height: calc(100% - 35px);
}
.calendarBS .wc-calendar-view-container > .position-relative > .d-flex:first-child {
    pointer-events: none;
}
.signoutEventDate {
    cursor: pointer;
}
#wcCalendarInfoWindowModal .modal-dialog {
    width: 500px;
    min-height: 200px;
    max-width: calc(100vw - 20px);
}
#wcCalendarInfoWindowModal .imgLoader {
    height: 100px;
}
#wcCalendarInfoWindowModal .modal-dialog .modal-content {
    min-height: 200px;
}
.calendarBS button[data-add-appointment], .calendarBS .wc-calendar-left-nav, .calendarBS button[data-bs-toggle], 
.calendarBS .wc-select-calendar-view .dropdown-menu li:nth-child(4),
#wcCalendarInfoWindowModal .modal-dialog [data-modal-options] [data-remove], #wcCalendarInfoWindowModal .modal-dialog [data-modal-options] [data-edit] {
    display: none !important;
}
#wcCalendarInfoWindowModal .modal-dialog .eventCheckRodo {
    color: red;
}
#wcCalendarInfoWindowModal .btn-default {
    cursor: pointer;
}
.calendarBS .wc-day-week-view,
.calendarBS .wc-calendar-view-container .flex-grow-1.d-flex.flex-column:not(.hourStickyHeaderSlots) {
    min-width: 100px;
}
.calendarBS .wc-calendar-view-container .position-relative {
    max-width: 100%;
    overflow-x: auto !important;
}
.calendarBS .wc-calendar-view-container .position-relative {
    width: auto !important;
}
#eventCheckRodo, #eventCheckRodo * {
    color: red;
    font-size: 14px;
    text-align: left !important;
}
.calendarForm {
    width: 1000px !important;
    max-width: calc(100vw - 20px);
    margin: 0 auto;
}
.redirectToPay {
    cursor: pointer;
}
.calendarBS [data-today], .calendarBS .wc-select-calendar-view ul.dropdown-menu li:nth-child(3), .calendarBS .wc-calendar-top-nav .col-auto:first-child {
    display: none !important;
}

.calendarBS .wc-week-view .hourStickySlots, .calendarBS .wc-week-view .hourStickySlots .wc-day-view-time-slots,
.calendarBS .d-flex.flex-nowrap.flex-fill.w-100 .hourStickyHeaderSlots {
    width: 40px !important;
    max-width: 40px !important;
    min-width: 40px !important;
    position: sticky !important;
    left: 0;
    top: 0;
    overflow: visible !important;
    z-index: 200;
}
.calendarBS .d-flex.flex-nowrap.flex-fill.w-100 {
    padding-left: 0 !important;
    min-width: fit-content;
}
.calendarBS .wc-week-view .hourStickySlots .wc-day-view-time-slots > .d-flex,
.calendarBS .d-flex.flex-nowrap.flex-fill.w-100 .hourStickyHeaderSlots {
    background: #fff;
    width: 39px !important;
}
.calendarBS .wc-week-view {
    padding-left: 0 !important;
    min-width: fit-content;
}
.calendarBS .wc-week-view .hourStickySlots, .calendarBS .wc-week-view .hourStickySlots .wc-day-view-time-slots .wc-time-label {
    transform: none !important;
    top: 0 !important;
    left: 0 !important;
    padding-left: 0 !important;
    font-size: 14px !important;
}

@media screen and (max-width: 992px) {
    .calendarBS .wc-calendar-view-container .position-relative.px-1.px-lg-5 {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    .calendarBS .wc-day-week-view, .calendarBS .wc-calendar-view-container .flex-grow-1.d-flex.flex-column:not(.hourStickyHeaderSlots):not(.hourStickySlots) {
        min-width: 110px;
    }
    #wcCalendarInfoWindowModal .modal-fullscreen-sm-down {
        height: auto;
        left: auto;
        right: auto;
        margin-left: auto;
        margin-right: auto;
        position:relative !important;
    }
}
@media screen and (max-width: 768px) {
    .calendarBS .wc-calendar-view-container:not(.monthView) {
        padding-left: 5px !important;
        padding-right: 5px !important;
    }
}
@media screen and (max-width: 520px) {
    #wcCalendarInfoWindowModal .modal-fullscreen-sm-down {
        margin-left: 10px;
    }
    
}
@media screen and (max-width: 450px) {
    .calendarBS .wc-calendar-top-nav .col-auto:last-child {
        flex-wrap: wrap !important;
    }
    .calendarBS .wc-calendar-top-nav .col-auto:last-child .wc-select-calendar-view {
        display: none !important;
    }
}