/* Calendar Styles with Event Text */
.calendar-day {
    min-height: 80px !important;
    position: relative;
    padding: 5px !important;
    font-size: 12px !important;
}

.day-number {
    font-weight: bold;
    margin-bottom: 5px;
}

.event-text {
    font-size: 10px;
    line-height: 1.2;
    color: #333;
    margin-top: 5px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.event-text .event-name {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 2px 4px;
    margin: 2px 0;
    border-radius: 3px;
    font-size: 9px;
}

.event-text .konzert-event {
    background: #ffe0e0;
    color: #d32f2f;
}

.event-text .sport-event {
    background: #e8f5e9;
    color: #2e7d32;
}

.event-text .festival-event {
    background: #fff3e0;
    color: #e65100;
}

.event-text .markt-event {
    background: #e3f2fd;
    color: #1565c0;
}

.event-text .comedy-event {
    background: #f3e5f5;
    color: #6a1b9a;
}

.calendar-day.has-events {
    background: #fafafa;
    cursor: pointer;
}

.calendar-day.has-events:hover {
    background: #f0f0f0;
    transform: scale(1.02);
}

@media (max-width: 768px) {
    .calendar-day {
        min-height: 60px !important;
    }
    
    .event-text {
        display: none;
    }
    
    .event-indicators {
        display: flex !important;
    }
}