/* ==========================================
   UBUD ADVENTURES PREMIUM CALENDAR
========================================== */

:root {
    --calendar-primary: #f4b400;
    --calendar-primary-dark: #e7a400;

    --calendar-primary: #e5484d;
    --calendar-primary-bg: #fff5f5;

    --calendar-primary: #3b82f6;

    --calendar-text: #1f2937;
    --calendar-muted: #6b7280;

    --calendar-bg: #ffffff;

    --calendar-shadow:
        0 12px 40px rgba(15, 23, 42, .06);

    --calendar-border: #edf1f5;

    --calendar-shadow:
        0 12px 40px rgba(15, 23, 42, .06);

}

/* ================= CARD ================= */

.ua-calendar {

    background: #fff;

    border-radius: 30px;

    overflow: hidden;

    margin-bottom: 13px;

    border: 1px solid #eef2f6;

    box-shadow: var(--calendar-shadow);

}

/* ================= HEADER ================= */

.ua-calendar-header {

    display: flex;

    align-items: center;

    gap: 21px;

    padding: 13px 13px;

}

.ua-calendar-icon {

    flex-shrink: 0;

    background:
        linear-gradient(145deg,
            #fff8df,
            #fff1b5);

    display: flex;

    justify-content: center;

    align-items: center;

    color: var(--calendar-primary);

    box-shadow:
        0 10px 30px rgba(244, 180, 0, .18);

    width: 34px;

    height: 34px;

    border-radius: 13px;

    font-size: 24px;

}

.ua-calendar-title {

    flex: 1;

}

.ua-calendar-title h2 {

    margin: 0;

    font-size: 1.2rem;

    font-weight: 800;

    color: var(--calendar-text);

}

.ua-calendar-title p {

    margin-top: 8px;

    margin-bottom: 0;

    color: var(--calendar-muted);

    font-size: .8rem;

    line-height: 1.5;

}

.ua-calendar-divider {

    height: 1px;

    background: #edf1f5;

}

/* ================= TOOLBAR ================= */

.ua-calendar-toolbar {

    display: grid;

    grid-template-columns: 55px 1fr 55px;

    align-items: center;

    padding: 5px 30px 3px;

}

.ua-calendar-toolbar h4 {

    margin: 0;

    text-align: center;

    font-size: 1rem;

    font-weight: 800;

    color: #111827;

}

.ua-calendar-nav {

    width: 34px;

    height: 34px;

    border: none;

    border-radius: 50%;

    background: #fff;

    color: var(--calendar-primary);

    font-size: 18px;

    box-shadow:
        0 8px 20px rgba(0, 0, 0, .08);

    transition: .25s;

}

.ua-calendar-nav:hover {

    transform: translateY(-2px);

    background: #fffdf6;

}

.ua-calendar-nav:active {

    transform: scale(.95);

}

/* ================= WEEKDAYS ================= */

.ua-calendar-weekdays {

    display: grid;

    grid-template-columns: repeat(7, 1fr);

    gap: 8px;

    padding: 0 21px;

    margin: 13px 0 11px;

}

.ua-calendar-weekdays span {

    text-align: center;

    font-size: .7rem;

    font-weight: 700;

    letter-spacing: 1px;

    text-transform: uppercase;

    color: #6b7280;
    gap: 2px;
    background: #fafafa;

    border-radius: 12px;

    padding: 9px 0;

}

/* ================= GRID ================= */

.ua-calendar-grid {

    display: grid;

    grid-template-columns: repeat(7, minmax(0, 1fr));
    justify-content: space-between;
    gap: 4px;

    width: 100%;

    padding: 3px 21px 0px;

}

.ua-calendar-empty {

    .ua-calendar-empty {
        aspect-ratio: 1;
        background: none;
        border: none;
        box-shadow: none;
    }

}

/* ================= DAY ================= */

.ua-calendar-day {

    width: 38px;
    height: 38px;
    aspect-ratio: auto;
    position: relative;

    background: #fff;

    border: 1px solid #edf1f5;

    border-radius: 13px;

    display: flex;

    flex-direction: column;

    justify-content: center;

    align-items: center;

    cursor: pointer;

    transition: .25s;

    box-shadow:
        0 8px 18px rgba(15, 23, 42, .04);

}

.ua-calendar-day:hover {

    transform: translateY(-4px);

    box-shadow:
        0 16px 32px rgba(15, 23, 42, .10);

}

.ua-day-number {

    font-size: 1rem;

    font-weight: 800;

    color: #1f2937;

}

.ua-calendar-empty {

    background: none;

    border: none;

    box-shadow: none;

}

/* ================= BOOKED ================= */

.ua-calendar-day.booked {

    background: #fff5f5;

    border: 2px solid #f2b1b1;

}

.ua-calendar-day.booked .ua-day-number {

    color: #dc2626;

}

.ua-day-x {

    position: absolute;

    top: 5px;

    left: 50%;

    transform: translateX(-50%);

    width: 25px;

    height: 25px;

    border-radius: 50%;

    border: 2px solid #dc2626;

    display: flex;

    justify-content: center;

    align-items: center;

    color: #dc2626;

    background: #fff;

    font-size: 13px;

}

/* ================= SELECTED ================= */

.ua-calendar-day.selected {

    background:

        linear-gradient(180deg,
            #ffd86d,
            #f4b400);

    border: none;

}

.ua-calendar-day.selected .ua-day-number {

    color: #fff;

}

.ua-day-check {

    position: absolute;

    bottom: 12px;

    left: 50%;

    transform: translateX(-50%);

    width: 21px;

    height: 21px;

    border-radius: 50%;

    background: #fff;

    color: #f4b400;

    display: flex;

    justify-content: center;

    align-items: center;

    font-size: 13px;

}

/* ================= TODAY ================= */

.ua-calendar-day.today {

    border: 2px solid #3b82f6;

}

.ua-calendar-day.today .ua-day-bottom {
    margin-bottom: 3px;
    font-size: .5rem;

    font-weight: 800;

    color: #3b82f6;

}

/* ================= LEGEND ================= */

.ua-calendar-legend {

    display: flex;

    justify-content: center;

    align-items: center;

    flex-wrap: wrap;

    gap: 21px;

    margin-top: 21px;

    padding: 13px 13px;

    border-top: 1px solid #edf1f5;

}

.ua-legend-item {

    display: flex;

    align-items: center;

    gap: 8px;

    font-size: .95rem;

    font-weight: 600;

    color: #4b5563;

}

.ua-legend-color {

    width: 16px;

    height: 16px;

    border-radius: 50%;

    flex-shrink: 0;

}

/* Available */

.ua-legend-color.available {

    background: #ffffff;

    border: 2px solid #d8dee8;

}


.ua-calendar-day.disabled {

    opacity: .45;

    cursor: not-allowed;

    pointer-events: none;

    background: #f8fafc;

    color: #94a3b8;

    border-color: #e5e7eb;

}

.ua-calendar-day.disabled:hover {

    transform: none;

    box-shadow: none;

}

/* Selected */

.ua-legend-color.selected {

    background:

        linear-gradient(135deg,
            #ffd45c,
            #f4b400);

    border: none;

}

/* Fully booked */

.ua-legend-color.booked {

    background: #e53935;

    border: none;

}

/* ================= MOBILE ================= */

@media (max-width:768px) {

    .ua-calendar {

        padding: 5px;

        border-radius: 20px;

    }

    /* Header */

    .ua-calendar-header {

        gap: 9px;

        padding: 8px;

    }

    .ua-calendar-icon {

        width: 45px;

        height: 45px;

        font-size: 18px;

    }

    .ua-calendar-title h2 {

        font-size: 1.2rem;

        margin-bottom: 3px;

    }

    .ua-calendar-title p {

        font-size: .8rem;

        line-height: 1.3;

    }

    /* Month */

    .ua-calendar-toolbar {

        margin: 8px 0;

    }

    .ua-calendar-toolbar h4 {

        font-size: 1rem;

    }

    .ua-calendar-nav {

        width: 34px;

        height: 34px;

        font-size: 13px;
        margin-left: 8px;
        margin-right: 8px;
    }

    /* Week */

    .ua-calendar-weekdays {

        margin-bottom: 8px;

    }

    .ua-calendar-weekdays span {

        font-size: .72rem;

    }

    /* Grid */

    .ua-calendar-grid {
        gap: 3px;
        padding: 0px 5px 0px;
    }

    /* Day */

    .ua-calendar-day {

        width: 38px;
        height: 38px;

        min-height: 28px;

        border-radius: 8px;

        padding: 3px;

    }

    .ua-day-number {

        font-size: 13px;

        font-weight: 600;

    }

    .ua-day-top {

        height: 12px;

    }

    .ua-day-bottom {

        height: 10px;

        font-size: 9px;

    }

    @media (max-width:768px) {

        .ua-day-x {

            position: absolute;

            top: 42%;

            left: 50%;

            transform: translate(-50%, -50%);

            width: auto;
            height: auto;

            background: transparent;
            border: none;
            border-radius: 0;
            box-shadow: none;

            color: #dc2626;

            font-size: 13px;

            font-weight: 700;

            z-index: 20;

            line-height: 1;

        }

        .ua-day-number {

            position: relative;

            z-index: 1;

        }

    }

    /* Legend */

    .ua-calendar-legend {

        margin-top: 8px;

        gap: 8px;

        font-size: .72rem;

    }

    .ua-legend-color {

        width: 12px;

        height: 12px;

    }

    .ua-calendar-legend {

        gap: 13px;

        margin-top: 13px;

        padding-top: 13px;

    }

    .ua-legend-item {

        font-size: .8rem;

    }

    .ua-legend-color {

        width: 12px;

        height: 12px;

    }

}