:root {
	--cal-background: var(--enfold-main-color-bg);
	--cal-border: #e0e0e0;
	--cal-hover: var(--enfold-main-color-button-border);
}

.calendar-container {
	width: 100%;
}

.calendar-toolbar {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
	padding: 10px;
	background: var(--cal-background);
	border-radius: 5px;
	flex-wrap: wrap;
}

.btn-nav {
	padding: 8px 16px;
	border: 1px solid var(--cal-border);
	background: white;
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.2s;
}

.btn-nav:hover {
	background: var(--cal-hover);
	border: 1px solid var(--cal-hover);
}

.current-month {
	margin: 0;
	margin-left: auto;
	font-size: 2em !important;
}

.custom-calendar {
	border: 1px solid var(--cal-border);
	border-radius: 5px;
	overflow: hidden;
	background: white;
}

.custom-calendar .calendar-header {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	background: color-mix(in srgb, var(--cal-background) 80%, white 10%);
	font-weight: bold;
	text-align: center;
}

.calendar-header > div {
	padding: 10px 5px;
	border-right: 1px solid var(--cal-border);
}

.calendar-header > div:last-child {
	border-right: none;
}

.custom-calendar .calendar-body {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
}

.calendar-day {
	min-height: 100px;
	border-right: 1px solid var(--cal-border);
	border-bottom: 1px solid var(--cal-border);
	padding: 8px;
	position: relative;
	background: color-mix(in srgb, var(--cal-background) 80%, #828282 20%);
	overflow: visible;
}

.calendar-day:nth-child(7n) {
	border-right: none;
}

.calendar-day.other-month {
	background: var(--cal-background);
	color: white;
}

.calendar-day.today {
	background: color-mix(in srgb, var(--cal-background) 70%, white 30%);
}

.day-number {
	font-weight: bold;
	margin-bottom: 5px;
	position: relative;
	z-index: 1;
}

.event-container {
	position: relative;
	margin-top: 5px;
	width: 100%;
}

.event-item {
	padding: 2px 5px;
	margin: 2px 0;
	border-radius: 3px;
	cursor: pointer;
	font-size: 0.85em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	transition: opacity 0.2s;
	position: relative;
}

.event-item.multi-day {
	position: absolute;
	z-index: 10;
	min-height: 20px;
	left: 0;
	margin-right: -1px; /* Kompensiere Border für nahtlose Verbindung */
}

.event-item.start {
	border-radius: 3px 0 0 3px;
	padding-left: 5px;
}

.event-item.middle {
	border-radius: 0;
	background-color: inherit !important;
}

.event-item.end {
	border-radius: 0 3px 3px 0;
}

.event-item.single {
	border-radius: 3px;
}

.event-spacer {
	height: 24px;
	margin: 2px 0;
}

.event-item:hover {
	opacity: 0.8;
	z-index: 20;
}

.nav-month {
	margin: 0 5px;
}

.btn-nav {
	display: flex;
	align-items: center;
}

/* Hide Weekend */
.custom-calendar.hide-weekends .calendar-header, .custom-calendar.hide-weekends .calendar-body {
	grid-template-columns: repeat(5, 1fr);
}
.custom-calendar.hide-weekends .calendar-day:nth-child(7n) {
	border-right: 1px solid var(--cal-border);
}
.custom-calendar.hide-weekends .calendar-day:nth-child(5n) {
	border-right: none;
}

@media (max-width: 768px) {
	.calendar-day {
		min-height: 90px;
		font-size: 0.8em;
		padding: 4px;
	}

	.event-item {
		font-size: 0.75em;
		padding: 1px 3px;
	}

	.current-month {
		font-size: 1.2em;
	}

	.btn-nav {
		padding: 6px 12px;
		font-size: 0.9em;
	}
}

@media (max-width: 480px) {
	.calendar-header > div {
		font-size: 0.85em;
		padding: 8px 2px;
	}

	.calendar-day {
		min-height: 50px;
	}

	.event-item {
		font-size: 0.65em;
		padding: 1px 2px;
	}
}