/* Kulturkalender v5.2.1 - Simplifiziert */

.kk-list-view { margin: 20px 0; }
.kk-day-block { margin-bottom: 30px; }
.kk-day-date { font-size: 18px; font-weight: bold; padding: 15px 0; color: #333; border-bottom: 2px solid #0073aa; }
.kk-day-events { margin-top: 15px; display: flex; flex-direction: column; gap: 15px; }
.kk-event-box { padding: 15px; background: white; border: 1px solid #ddd; border-left: 5px solid #0073aa; border-radius: 4px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
.kk-event-box:hover { box-shadow: 0 4px 8px rgba(0,0,0,0.15); transform: translateX(5px); }
.kk-event-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 10px; gap: 10px; }
.kk-event-title { margin: 0; font-size: 24px; font-weight: bold; color: #333; flex: 1; word-wrap: break-word; }
.kk-category-badge { display: inline-block; padding: 5px 12px; color: white; border-radius: 20px; font-size: 12px; font-weight: bold; white-space: nowrap; flex-shrink: 0; }
.kk-subtitle { color: #666; font-style: italic; margin: 8px 0; }
.kk-time, .kk-location, .kk-ticket { margin: 8px 0; color: #555; }
.kk-description { margin: 12px 0; padding: 12px; background: #f9f9f9; border-left: 3px solid #0073aa; line-height: 1.6; }
.kk-link a { display: inline-block; padding: 8px 15px; background: #0073aa; color: white; text-decoration: none; border-radius: 4px; margin-top: 10px; }
.kk-link a:hover { background: #005a87; }
.kk-info { margin-top: 12px; padding: 12px; background: white; border-left: 3px solid #333; line-height: 1.6; }

.kk-calendar-view { margin: 20px 0; }
.kk-calendar-month { margin-bottom: 40px; }
.kk-calendar-month h3 { background: #0073aa; color: white; padding: 15px; margin: 0 0 15px 0; }
.kk-calendar-grid { width: 100%; border-collapse: collapse; border: 1px solid #ddd; }
.kk-calendar-grid th { background: #f0f0f0; padding: 10px; text-align: center; font-weight: bold; border: 1px solid #ddd; }
.kk-calendar-grid td { border: 1px solid #ddd; height: auto; min-height: 80px; vertical-align: top; padding: 5px; background: white; }
.kk-calendar-grid td.kk-other-month { background: #f9f9f9; }
.kk-calendar-grid td.kk-has-events { background: #f5f5f5; }
.kk-day-number { font-weight: bold; padding: 5px 0; border-bottom: 1px solid #ddd; margin-bottom: 5px; }
.kk-day-events-calendar { font-size: 12px; display: flex; flex-direction: column; gap: 3px; }
.kk-cal-event { padding: 5px 6px; border-radius: 3px; color: white; cursor: pointer; white-space: normal; word-wrap: break-word; font-weight: bold; transition: all 0.2s; line-height: 1.3; min-height: 30px; display: flex; align-items: center; }
.kk-cal-event:hover { transform: scale(1.02); box-shadow: 0 2px 6px rgba(0,0,0,0.3); }

.kk-modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); overflow-y: auto; }
.kk-modal-content { background-color: white; margin: 50px auto; padding: 30px; border: 1px solid #888; border-radius: 8px; width: 90%; max-width: 600px; box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
.kk-close { color: #aaa; float: right; font-size: 28px; font-weight: bold; cursor: pointer; line-height: 1; }
.kk-close:hover { color: black; }
.kk-modal-desc, .kk-modal-info { margin: 15px 0; padding: 12px; background: #f9f9f9; border-left: 3px solid #0073aa; line-height: 1.6; }

@media (max-width: 768px) {
    .kk-event-header { flex-direction: column; }
    .kk-event-title { font-size: 20px; }
    .kk-cal-event { font-size: 11px; padding: 3px 4px; }
    .kk-modal-content { width: 95%; margin: 20% auto; }
}
