﻿/* =========================================================
   Reservation (clean)
   Sections:
   0) Page scope & brand
   1) Helpers
   3) Courts (cards)
   4) Dates (chips)
   5) Time slots (Kendo ListView buttons)
   6) Duration chips
   7) Sticky summary
   8) Rows: mobile swipe / desktop grid
   9) Optional: dark mode border softening
   10) Micro spacing
   ========================================================= */

/* 0) Page scope & brand ----------------------------------*/
.reservation-page {
    --bs-primary: var(--brand-blue);
    --bs-primary-rgb: 30,144,255;
}

/* 1) Helpers ---------------------------------------------*/
.bg-cover {
    background-size: cover;
    background-position: center;
}

.hover-lift {
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

    .hover-lift:hover {
        transform: translateY(-2px); 
    }

/* 1) Courts ---------------------------------------------*/
.court-tile {
    display: block;
    border-radius: 1rem;
    overflow: hidden;
    background: var(--bs-body-bg);
    border: 1px solid rgba(125,125,125,.16);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

    .court-tile:hover {
        transform: translateY(-2px);
        box-shadow: 0 10px 22px rgba(0,0,0,.14);
    }
    /* selected = soft brand-blue glow (no size jump) */
    .court-tile.active-court {
        border-color: transparent;
        box-shadow: 0 12px 28px rgba(0,0,0,.20), 0 0 0 3px rgba(var(--bs-primary-rgb), .55);
        transform: translateY(-2px);
    }

    /* image polish */
    .court-tile .ratio {
        border-radius: 1rem;
        overflow: hidden;
    }

        .court-tile .ratio img {
            display: block;
            object-fit: cover;
        }

/* ----- GOLD PRICE BADGE (bottom-left) ----- */
/* Bootstrap .ratio makes direct children 100%—undo that for the badge */
.ratio .price-badge {
    top: auto !important;
    right: auto !important;
    width: auto !important;
    height: auto !important;
    padding: .35rem .6rem;
    font-weight: 700;
    font-size: .875rem;
    line-height: 1;
    background: var(--brand-yellow);
    color: #111; 
    box-shadow: 0 2px 8px rgba(0,0,0,.25);
}

.border-ribbon-en {
    border-top-right-radius: .375rem;
    border-bottom-right-radius: .375rem;
}

.border-ribbon-ar {
    border-top-left-radius: .375rem;
    border-bottom-left-radius: .375rem;
}

/* name under the card */
.court-name {
    color: var(--bs-body-color);
}

/* MOBILE: fixed width so the scroller feels consistent */
#courtsStrip > [class*="col-"] {
    flex: 0 0 auto;
    width: 240px; /* pick your card width */
}

/* DESKTOP (>= md): wrap into a tidy grid and remove scrollbar */
@media (min-width:768px) {
    #courtsStrip {
        overflow: visible; /* kill the scroll track */
    }

        #courtsStrip > [class*="col-"] {
            flex: 0 0 25% !important; /* 4-up grid */
            width: 25% !important;
        }
}


/* ---- Hide scrollbar on MOBILE only ---- */
@media (max-width: 767.98px) {
    #courtsStrip {
        -ms-overflow-style: none; /* IE/Edge */
        scrollbar-width: none; /* Firefox */
    }

        #courtsStrip::-webkit-scrollbar {
            display: none; /* Chrome/Safari */
            height: 0;
        }
}

/* ---- Show/customize scrollbar on DESKTOP ---- */
@media (min-width: 768px) {
    #courtsStrip {
        scrollbar-width: thin;
        scrollbar-color: rgba(30,144,255,.35) transparent;
    }

        #courtsStrip::-webkit-scrollbar {
            height: 8px;
        }

        #courtsStrip::-webkit-scrollbar-thumb {
            background-color: rgba(var(--bs-primary-rgb), .35);
            border-radius: 8px;
        }
}
 
/* 3) Dates (chips) ---------------------------------------*/
.selectable-date {
    background: var(--bs-body-bg) !important;
    border: 1px solid rgba(125,125,125,.18) !important;
    color: var(--bs-body-color);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}

    .selectable-date:hover {
        transform: translateY(-2px);
    }

    .selectable-date.active-date {
        border-color: rgba(var(--bs-primary-rgb), .55) !important;
        background: rgba(var(--bs-primary-rgb), .08) !important;
        box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), .18) inset !important;
        transform: translateY(-2px);
    }

/* DESKTOP (>= md): wrap into a tidy grid and remove scrollbar */
@media (min-width:768px) {
    #datesStrip {
        overflow: visible; /* kill the scroll track */
    } 
}


/* ---- Hide scrollbar on MOBILE only ---- */
@media (max-width: 767.98px) {
    #datesStrip {
        -ms-overflow-style: none; /* IE/Edge */
        scrollbar-width: none; /* Firefox */
    }

        #datesStrip::-webkit-scrollbar {
            display: none; /* Chrome/Safari */
            height: 0;
        }
}

/* ---- Show/customize scrollbar on DESKTOP ---- */
@media (min-width: 768px) {
    #datesStrip {
        scrollbar-width: thin;
        scrollbar-color: rgba(30,144,255,.35) transparent;
    }

        #datesStrip::-webkit-scrollbar {
            height: 8px;
        }

        #datesStrip::-webkit-scrollbar-thumb {
            background-color: rgba(var(--bs-primary-rgb), .35);
            border-radius: 8px;
        }
}

/* 5) Time slots (Kendo ListView) -------------------------*/
.k-listview-content {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(115px,1fr));
    gap: .5rem !important;
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
}

.time-slot {
    border: 1px solid rgba(125,125,125,.25) !important;
    background: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
    border-radius: 999px !important;
    padding: .75rem .75rem !important;
    line-height: 1 !important;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
}

    .time-slot:hover {
        transform: translateY(-2px);
    }

    .time-slot:disabled {
        opacity: .45;
    }

.selectable-btn.active-btn {
    border-color: rgba(var(--bs-primary-rgb), .55) !important;
    background: rgba(var(--bs-primary-rgb), .08) !important;
    transform: translateY(-2px);
}
 

/* 6) Duration chips --------------------------------------*/
.duration-chip {
    border-radius: 999px;
}

    .duration-chip.active {
        background: var(--bs-primary);
        color: #fff;
        border-color: var(--bs-primary);
    }

/* 7) Sticky summary --------------------------------------*/
.reservation-sticky {
    bottom: 0;
    z-index: 1030;
    background: color-mix(in oklab, var(--bs-body-bg) 92%, transparent);
    backdrop-filter: saturate(1.2) blur(6px);
    border: 1px solid rgba(125,125,125,.18);
}

/* 8) Rows: mobile swipe / desktop grid -------------------*/
#courtsStrip, #datesStrip {
    scroll-snap-type: x mandatory;
}

    #courtsStrip > [class*="col-"], #datesStrip > [class*="col-"] {
        scroll-snap-align: start;
    }

@media (max-width: 767.98px) {
    /* hide scrollbar thumb on mobile for cleaner look */
    .overflow-auto::-webkit-scrollbar {
        height: 0;
    }

    .overflow-auto {
        scrollbar-width: none;
    }
}

@media (min-width: 768px) {
    /* on desktop use real grid, no horizontal scrolling */
    #courtsStrip, #datesStrip {
        flex-wrap: wrap;
        overflow: visible;
    }
} 
/* 10) Micro spacing --------------------------------------*/
.content-heading {
    font-weight: 600;
    letter-spacing: .2px;
    font-size: 18px !important;
}
 
/* Kendo loading tint tweak */
.k-loading-color {
    opacity: .3 !important;
}
 
/* Dark-specific tuning */
[data-bs-theme="dark"] .k-loading-color {
    background-color: #191D24 !important;
}


/* Neutralize Kendo borders/backgrounds */
.k-listview, .k-listview-bordered {
    border-color: transparent !important;
    background: transparent !important;
    border-width: 0 !important;
    color: inherit !important;
}



/* Glass chip group container */
.glass-chips {
    --chip-gap: .5rem;
    --chip-pad-y: .55rem;
    --chip-pad-x: 1rem;
    --chip-radius: 999px;
    --chip-border: rgba(255,255,255,.25);
    --chip-bg: rgba(255,255,255,.35);
    --chip-bg-hover: rgba(255,255,255,.55);
    --chip-text: #212529;
    --chip-active-text: #fff;
    display: inline-grid;
    grid-auto-flow: column;
    gap: var(--chip-gap);
    position: relative;
    padding: .4rem;
    border-radius: calc(var(--chip-radius) + .5rem);
    /*background: linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.08));*/
    backdrop-filter: blur(10px);
    /*border: 1px solid var(--chip-border);*/
    /*box-shadow: inset 0 0 0 1px rgba(255,255,255,.05), 0 10px 25px rgba(0,0,0,.06);*/
}

    /* Each chip label (paired with btn-check) */
    .glass-chips .chip {
        position: relative;
        display: inline-flex;
        align-items: center;
        gap: .5rem;
        padding: var(--chip-pad-y) var(--chip-pad-x);
        border-radius: var(--chip-radius);
        border: 1px solid rgba(125, 125, 125, .18) !important;
        /*background: var(--chip-bg);*/
        background: var(--bs-body-bg) !important;
        /*color: var(--chip-text);*/
        font-weight: 500;
        line-height: 1;
        user-select: none;
        cursor: pointer;
        transition: transform .12s ease, background .2s ease, border-color .2s ease, color .2s ease, box-shadow .2s ease;
        box-shadow: 0 2px 6px rgba(0,0,0,.05);
    }

        /* Hover/focus feels responsive */
        .glass-chips .chip:hover,
        .glass-chips .chip:focus-visible {
            background: var(--chip-bg-hover);
            border-color: rgba(0,0,0,.08);
            transform: translateY(-1px);
            outline: none;
        }

    /* Icon stays subtle */
    .glass-chips .chip-icon {
        opacity: .85;
    }  

    .glass-chips .chip-glow {
        position: absolute;
        top: 0;
        left: 0;
        border-radius: 999px;
        pointer-events: none;
        transition: transform .25s cubic-bezier(.2,.7,.2,1), width .25s cubic-bezier(.2,.7,.2,1), height .25s cubic-bezier(.2,.7,.2,1);

        border-color: rgba(var(--bs-primary-rgb), .55) !important;
        background: rgba(var(--bs-primary-rgb), .08) !important;
        box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), .18) inset !important;
    }
     

/* Make the glow width match each chip dynamically (JS sets transform) */
.glass-chips {
    isolation: isolate;
}

/* Small screens wrap nicely */
@media (max-width: 420px) {
    .glass-chips {
        grid-auto-flow: row;
        grid-template-columns: repeat(3, minmax(0,1fr));
    }

}