:root {
    --calendar-month-bg-color: #fff;
    --calendar-month-border-color: rgb(199, 199, 199);

    --calendar-monthday-bg-color-open: #91c03c;
    --calendar-monthday-text-color-open: white;

    --calendar-monthday-bg-color-closed: #a70c1c;
    --calendar-monthday-text-color-closed: white;

    --calendar-monthday-bg-color-dayHasBeen: rgb(199, 199, 199);
    --calendar-monthday-text-color-dayHasBeen: black;

    --calendar-pagination-buttons-bg-color: #f26b38;
    --calendar-pagination-buttons-icon-color: white;
}

.loaderCalendar {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 10px 0;
}

.loader {
    width: 60px;
    aspect-ratio: 2;
    --_g: no-repeat radial-gradient(circle closest-side,#000 90%,#0000);
    background:
            var(--_g) 0%   50%,
            var(--_g) 50%  50%,
            var(--_g) 100% 50%;
    background-size: calc(100%/3) 50%;
    animation: l3 1s infinite linear;
}

@keyframes l3 {
    20%{background-position:0%   0%, 50%  50%,100%  50%}
    40%{background-position:0% 100%, 50%   0%,100%  50%}
    60%{background-position:0%  50%, 50% 100%,100%   0%}
    80%{background-position:0%  50%, 50%  50%,100% 100%}
}

.swiperCalendar .swiper-slide .monthSlide * {
    margin: 0;
}

.swiperCalendar .swiper-slide .monthSlide {
    background-color: var(--calendar-month-bg-color);
    border: 1px solid var(--calendar-month-border-color);
    border-radius: 12px;
    padding: 15px;
}

.swiperCalendar .swiper-slide .monthSlide table {
    width: 100%;
    table-layout: fixed;
    border-collapse: separate;
    border-spacing: 5px;
    text-align: center;
}

.swiperCalendar .swiper-slide .monthSlide table tbody tr:first-child {
    font-weight: 600;
}

.swiperCalendar .swiper-slide .monthSlide table td,
.swiperCalendar .swiper-slide .monthSlide table th {
    position: relative;
    width: calc(100% / 7);
    border-radius: 100%;
}

.swiperCalendar .swiper-slide .monthSlide table td::before,
.swiperCalendar .swiper-slide .monthSlide table th::before {
    content: "";
    display: block;
    padding-top: 100%;
}

.swiperCalendar .swiper-slide .monthSlide table td span,
.swiperCalendar .swiper-slide .monthSlide table th span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.swiperCalendar .swiper-slide .monthSlide table td.open {
    background-color: var(--calendar-monthday-bg-color-open);
    color: var(--calendar-monthday-text-color-open);
    cursor: pointer;
}

.swiperCalendar .swiper-slide .monthSlide table td.closed {
    background-color: var(--calendar-monthday-bg-color-closed);
    color: var(--calendar-monthday-text-color-closed);
    cursor: pointer;
}

.swiperCalendar .swiper-slide .monthSlide table td.dayHasBeen {
    background-color: var(--calendar-monthday-bg-color-dayHasBeen);
    color: var(--calendar-monthday-text-color-dayHasBeen);
}

.swiperCalendar .dayDetails {
    padding: 12px;
    background: #bdbdbd;
    margin-top: 20px !important;
    border-radius: 8px;
}

.calendar-pagination-container {
    margin-top: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.calendar-pagination-container button {
    width: 50px;
    aspect-ratio: 1/1;
    border-radius: 100%;
    border: none;
    background-color: var(--calendar-pagination-buttons-bg-color);
    color: var(--calendar-pagination-buttons-icon-color);
    transition: 0.2s ease-in-out;
    cursor: pointer;
}

.calendar-pagination-container button:hover {
    transform: scale(1.05);
}