/* /booking-system/assets/event-calendar.css */

.ev-header { 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    margin-bottom: var(--booking-gap); 
}

.ev-nav { 
    cursor: pointer;
    background-color: transparent
}

.ev-title { 
    font-weight: 500; 
    font-size: var(--booking-font-size-large); 
    text-transform: capitalize; 
    color: #000
}

.ev-grid { 
    display: grid; 
    grid-template-columns: repeat(7, 1fr); 
    gap: 5px; 
    margin-top: var(--booking-gap); 
}

.ev-head { 
    text-align: center; 
    font-weight: bold; 
    font-size: var(--booking-font-size-label); 
    padding: 5px; 
    color: #777; 
}

.ev-day { 
    aspect-ratio: 1/1; 
    border: 1px solid var(--booking-border); 
    border-radius: var(--booking-border-radius-pill); 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    cursor: pointer; 
    font-weight: 600; 
    position: relative; 
    transition: 0.2s;
    font-size: var(--booking-font-size-base);
}

.ev-day.empty { 
    border: 0; 
    cursor: default; 
}

.ev-day:hover:not(.empty):not(.reserved):not(.occupied):not(.weekday):not(.selected) { 
    background-color: #f0f0f0; 
}

#ev-selected-dates-visual {
    gap: 5px;
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
    align-items: start;
}

/* Statusy Dni */
.ev-day.available { background: #fff; }
.ev-day.selected { 
    background: #FCF57D; 
    color: #000; 
}
.ev-day.reserved { 
    background: var(--booking-event-reserved-bg); 
    color: var(--booking-event-reserved-text); 
    cursor: not-allowed; 
    opacity: 0.7; 
}
.ev-day.occupied { 
    background: #dbdbdb; 
    color: gray; 
    cursor: not-allowed; 
    text-decoration: line-through; 
}
.ev-day.weekday { 
    background: var(--booking-event-weekday-bg); 
    color: var(--booking-event-weekday-text); 
    cursor: not-allowed; 
}

.ev-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.ev-tag {
    background: var(--booking-primary);
    color: #fff;
    padding: 2px 8px;
    border-radius: var(--booking-border-radius-pill);
    font-size: var(--booking-font-size-small);
}

.cbf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }