.tp-calendar-widget {
	position: relative;
}

.tp-calendar-shell {
	transition: opacity 0.18s ease;
}

.tp-calendar-widget.is-loading .tp-calendar-shell {
	opacity: 0.55;
}

.tp-calendar {
	--tp-border: #d9e0e7;
	--tp-bg: #f5f7fa;
	--tp-card-bg: #ffffff;
	--tp-text: #1f2933;
	--tp-muted: #52606d;
	--tp-accent: #245b8a;
	--tp-category-accent: #7a8793;
	--tp-danger: #b42318;
	--tp-warning: #9a6700;
	display: grid;
	gap: 1.25rem;
	color: var(--tp-text);
}

.tp-calendar__nav {
	display: flex;
	gap: 0.9rem;
	align-items: center;
	justify-content: space-between;
	padding: 0.15rem 0;
}

.tp-calendar__nav-arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.4rem;
	height: 2.4rem;
	border: 1px solid var(--tp-border);
	border-radius: 999px;
	background: #fff;
	color: var(--tp-text);
	font-size: 1.3rem;
	font-weight: 600;
	text-decoration: none;
	flex: 0 0 auto;
}

.tp-calendar__nav-center {
	display: grid;
	gap: 0.18rem;
	text-align: center;
	flex: 1 1 auto;
	min-width: 0;
}

.tp-calendar__range {
	margin: 0;
	font-size: 1.08rem;
	line-height: 1.25;
	font-weight: 750;
	letter-spacing: -0.01em;
}

.tp-calendar__today {
	color: var(--tp-muted);
	font-size: 0.88rem;
	line-height: 1.3;
	text-decoration: none;
}

.tp-week {
	background: var(--tp-bg);
	border: 1px solid var(--tp-border);
	border-radius: 20px;
	padding: 1.35rem;
}

.tp-week__header {
	margin-bottom: 1.1rem;
}

.tp-week__title {
	margin: 0;
	font-size: 1.32rem;
	line-height: 1.25;
	font-weight: 800;
	letter-spacing: -0.01em;
	color: var(--tp-text);
}

.tp-events {
	display: grid;
	gap: 1rem;
}

.tp-card {
	background: var(--tp-card-bg);
	border: 1px solid var(--tp-border);
	border-radius: 16px;
	padding: 1.1rem 1.15rem;
	box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
	border-left: 4px solid var(--tp-category-accent);
}

.tp-card__top {
	display: grid;
	gap: 0.7rem;
}

.tp-card__heading {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
	justify-content: space-between;
}

.tp-card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.tp-card__title,
.tp-card__datetime,
.tp-card__location,
.tp-card__meta,
.tp-card__note,
.tp-card__description,
.tp-status,
.tp-empty p {
	margin: 0;
}

.tp-card__title {
	font-size: 1.18rem;
	line-height: 1.3;
	font-weight: 800;
	letter-spacing: -0.01em;
}

.tp-card__datetime,
.tp-card__location,
.tp-card__meta,
.tp-card__note,
.tp-card__description {
	margin-top: 0.5rem;
	font-size: 1rem;
	line-height: 1.6;
}

.tp-card__datetime {
	color: var(--tp-text);
	font-weight: 700;
}

.tp-card__location,
.tp-card__meta,
.tp-card__note,
.tp-card__description {
	color: var(--tp-muted);
}

.tp-card__description {
	margin-top: 0.85rem;
	padding-top: 0.8rem;
	border-top: 1px solid rgba(31, 41, 51, 0.08);
}

.tp-card__description p:first-child {
	margin-top: 0;
}

.tp-card__description p:last-child {
	margin-bottom: 0;
}

.tp-card__description a {
	color: var(--tp-accent);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
}

.tp-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.26rem 0.68rem;
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 700;
}

.tp-badge--category {
	color: var(--tp-category-accent);
	background: color-mix(in srgb, var(--tp-category-accent) 10%, #ffffff);
	border: 1px solid color-mix(in srgb, var(--tp-category-accent) 30%, #d9e0e7);
}

.tp-status {
	display: inline-flex;
	align-items: center;
	padding: 0.2rem 0.6rem;
	border-radius: 999px;
	border: 1px solid currentColor;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.tp-status--entfaellt {
	color: var(--tp-danger);
}

.tp-status--verschoben {
	color: var(--tp-warning);
}

.tp-empty {
	background: var(--tp-bg);
	border: 1px dashed var(--tp-border);
	border-radius: 16px;
	padding: 1rem 1.2rem;
}

.tp-calendar--compact .tp-week {
	padding: 1rem;
}

.tp-calendar--homepage {
	gap: 1rem;
}

.tp-home-list {
	display: grid;
	gap: 0.8rem;
}

.tp-home-item {
	display: grid;
	grid-template-columns: 4.5rem minmax(0, 1fr);
	gap: 0.95rem;
	align-items: start;
	padding: 0.95rem 1rem;
	background: var(--tp-card-bg);
	border: 1px solid var(--tp-border);
	border-left: 4px solid var(--tp-category-accent);
	border-radius: 16px;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.tp-home-item__date {
	display: grid;
	align-content: center;
	justify-items: center;
	gap: 0.1rem;
	padding: 0.55rem 0.35rem;
	border-radius: 12px;
	background: var(--tp-bg);
	border: 1px solid rgba(31, 41, 51, 0.06);
}

.tp-home-item__day {
	font-size: 1.3rem;
	line-height: 1;
	font-weight: 800;
	color: var(--tp-text);
}

.tp-home-item__month {
	font-size: 0.78rem;
	line-height: 1.2;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--tp-muted);
}

.tp-home-item__body {
	min-width: 0;
}

.tp-home-item__top {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	align-items: center;
	justify-content: space-between;
}

.tp-home-item__time,
.tp-home-item__title,
.tp-home-item__date-label,
.tp-home-item__location,
.tp-home-item__note {
	margin: 0;
}

.tp-home-item__time {
	font-size: 0.92rem;
	font-weight: 700;
	color: var(--tp-text);
}

.tp-home-item__title {
	margin-top: 0.3rem;
	font-size: 1.04rem;
	line-height: 1.35;
	font-weight: 780;
	letter-spacing: -0.01em;
	color: var(--tp-text);
}

.tp-home-item__date-label,
.tp-home-item__location {
	margin-top: 0.22rem;
	font-size: 0.94rem;
	line-height: 1.45;
	color: var(--tp-muted);
}

.tp-home-item__note {
	margin-top: 0.35rem;
	font-size: 0.9rem;
	line-height: 1.45;
	color: var(--tp-muted);
}

.tp-home-footer {
	padding-top: 0.15rem;
}

.tp-home-footer__link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.2rem 0;
	color: var(--tp-accent);
	font-size: 0.95rem;
	font-weight: 700;
	text-decoration: none;
}

.tp-compact-list {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 0.8rem;
}

.tp-compact-list__item {
	background: var(--tp-card-bg);
	border: 1px solid var(--tp-border);
	border-left: 4px solid var(--tp-category-accent);
	border-radius: 14px;
	padding: 0.9rem 1rem;
	display: grid;
	gap: 0.35rem;
}

.tp-compact-list__item span {
	color: var(--tp-muted);
}

@media (max-width: 640px) {
	.tp-week {
		padding: 1rem;
	}

	.tp-card {
		padding: 0.95rem;
	}

	.tp-card__heading {
		flex-direction: column;
		align-items: flex-start;
	}

	.tp-calendar__nav {
		gap: 0.65rem;
	}

	.tp-calendar__range {
		font-size: 1rem;
	}

	.tp-home-item {
		grid-template-columns: 1fr;
	}

	.tp-home-item__date {
		justify-items: start;
		grid-auto-flow: column;
		justify-content: start;
		gap: 0.45rem;
		padding: 0;
		background: transparent;
		border: 0;
	}
}
