/* --- EventCalendar Widget (#51) — Einladungskarten-Design --- */
/* --- Mobile First | Dark Mode | Reduced Motion | hover:hover | BFSG --- */

/* --- Tokens --- */

.kw-event-calendar {
	--kwl-ec-card-bg: var(--kwl-primary, #00315d);
	--kwl-ec-card-radius: var(--kwl-radius-lg, 12px);
	--kwl-ec-title-color: var(--kwl-btn-text, #ffffff);
	--kwl-ec-meta-color: rgba(255, 255, 255, 0.7);
	--kwl-ec-offer-bg: rgba(255, 255, 255, 0.1);
	--kwl-ec-offer-border: rgba(255, 255, 255, 0.14);
	--kwl-ec-img-size: clamp(80px, 18vw, 120px);
	--kwl-ec-img-border: var(--kwl-accent, #bd9b5c);
	--kwl-ec-badge-free-bg: var(--kwl-success, #2f855a);
	--kwl-ec-badge-cancelled-bg: var(--kwl-error, #c53030);

	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-lg, 1.5rem);
}

/* --- Heading --- */

.kw-event-calendar__heading {
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h2);
	font-weight: var(--kwl-fw-bold, 700);
	line-height: var(--kwl-lh-heading, 1.2);
	font-kerning: normal;
	color: var(--kwl-text, #1a202c);
	margin: 0;
}

/* --- Month Separator --- */

.kw-event-calendar__month {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-xs, 0.25rem) 0;
}

.kw-event-calendar__month-line {
	flex: 1;
}

.kw-event-calendar__month-label {
	font-family: var(--kwl-font-body);
	font-size: var(--kwl-fsize-caption, 0.75rem);
	font-weight: var(--kwl-fw-semibold, 600);
	letter-spacing: var(--kwl-ls-wider, 0.06em);
	text-transform: uppercase;
	color: var(--kwl-accent, #bd9b5c);
	white-space: nowrap;
	flex-shrink: 0;
}

/* --- Card --- */

.kw-event-calendar__card {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--kwl-space-md, 1rem);
	padding: var(--kwl-space-lg, 1.5rem);
	background: var(--kwl-ec-card-bg);
	border-radius: var(--kwl-ec-card-radius);
	box-shadow: var(--kwl-shadow-md);
	color: var(--kwl-ec-title-color);
	transition: box-shadow var(--kwl-transition, 200ms ease);
}

@media (min-width: 480px) {
	.kw-event-calendar__card {
		grid-template-columns: var(--kwl-ec-img-size) 1fr;
		align-items: start;
	}
}

/* --- Scroll Reveal --- */

.kw-event-calendar__card--pending {
	opacity: 0;
	transform: translateY(24px);
}

.kw-event-calendar__card--visible {
	animation: kwl-reveal-up 0.6s var(--kwl-ease-entrance, ease) both;
}

@media (prefers-reduced-motion: reduce) {
	.kw-event-calendar__card--pending {
		opacity: 1;
		transform: none;
	}

	.kw-event-calendar__card--visible {
		animation: none;
	}
}

/* --- Hover --- */

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
	.kw-event-calendar__card:hover {
		box-shadow: var(--kwl-shadow-hover);
	}
}

/* --- Image --- */

.kw-event-calendar__img-wrap {
	width: var(--kwl-ec-img-size);
	height: var(--kwl-ec-img-size);
	overflow: hidden;
	border: 3px solid var(--kwl-ec-img-border);
	flex-shrink: 0;
	justify-self: center;
}

.kw-event-calendar__img-wrap.is-circle {
	border-radius: var(--kwl-radius-full, 50%);
}

.kw-event-calendar__img-wrap.is-rounded {
	border-radius: var(--kwl-ec-card-radius);
	height: calc(var(--kwl-ec-img-size) * 1.2);
}

.kw-event-calendar__img-wrap .kw-event-calendar__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* --- Body --- */

.kw-event-calendar__body {
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 0.5rem);
	min-width: 0;
}

/* --- Title --- */

.kw-event-calendar__title {
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h4, 1.125rem);
	font-weight: var(--kwl-fw-bold, 700);
	line-height: var(--kwl-lh-heading, 1.2);
	font-kerning: normal;
	color: var(--kwl-ec-title-color);
	margin: 0;
}

.kw-event-calendar__title a {
	color: var(--kwl-ec-title-color);
	text-decoration: none;
}

@media (hover: hover) {
	.kw-event-calendar__title a:hover {
		text-decoration: underline;
		text-underline-offset: 3px;
	}
}

/* --- Meta --- */

.kw-event-calendar__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--kwl-space-xs, 0.25rem) var(--kwl-space-md, 1rem);
	color: var(--kwl-ec-meta-color);
	font-size: var(--kwl-fsize-small, 0.875rem);
	line-height: var(--kwl-lh-body, 1.5);
}

.kw-event-calendar__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
}

.kw-event-calendar__meta-item svg {
	width: 1em;
	height: 1em;
	flex-shrink: 0;
	opacity: 0.8;
}

/* --- Tickets --- */

.kw-event-calendar__tickets {
	padding-top: var(--kwl-space-xs, 0.25rem);
}

.kw-event-calendar__badge {
	display: inline-block;
	padding: 0.2em 0.7em;
	border-radius: var(--kwl-radius-sm, 4px);
	font-size: var(--kwl-fsize-caption, 0.75rem);
	font-weight: var(--kwl-fw-semibold, 600);
	letter-spacing: var(--kwl-ls-wide, 0.04em);
	text-transform: uppercase;
	color: var(--kwl-btn-text, #ffffff);
}

.kw-event-calendar__badge--free {
	background: var(--kwl-ec-badge-free-bg);
}

.kw-event-calendar__badge--cancelled {
	background: var(--kwl-ec-badge-cancelled-bg);
}

.kw-event-calendar__badge--seasonal {
	background: var(--kwl-accent, #bd9b5c);
	color: var(--kwl-accent-contrast, #00315d);
}

.kw-event-calendar__ticket-link {
	--kwl-link-color: var(--kwl-accent, #bd9b5c);
	--kwl-link-hover-color: var(--kwl-accent, #bd9b5c);
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: var(--kwl-space-xs, 0.25rem) var(--kwl-space-sm, 0.5rem);
	font-size: var(--kwl-fsize-small, 0.875rem);
	font-weight: var(--kwl-fw-medium, 500);
	border-radius: var(--kwl-radius-sm, 4px);
}

@media (hover: hover) {
	.kw-event-calendar__ticket-link:hover {
		text-decoration: underline;
	}
}

/* --- Offers --- */

.kw-event-calendar__offers {
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 0.5rem);
	margin-top: var(--kwl-space-sm, 0.5rem);
	padding-top: var(--kwl-space-sm, 0.5rem);
	border-top: 1px solid var(--kwl-ec-offer-border);
}

.kw-event-calendar__offers-label {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	font-weight: var(--kwl-fw-semibold, 600);
	letter-spacing: var(--kwl-ls-wide, 0.04em);
	text-transform: uppercase;
	color: var(--kwl-accent, #bd9b5c);
}

.kw-event-calendar__offer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--kwl-space-xs, 0.25rem) var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-md, 1rem);
	background: var(--kwl-ec-offer-bg);
	border-radius: var(--kwl-radius-sm, 4px);
}

.kw-event-calendar__offer-name {
	font-weight: var(--kwl-fw-medium, 500);
	font-size: var(--kwl-fsize-body, 1rem);
	color: var(--kwl-ec-title-color);
	flex: 1 1 auto;
	min-width: 0;
}

.kw-event-calendar__offer-price {
	font-size: var(--kwl-fsize-small, 0.875rem);
	font-weight: var(--kwl-fw-semibold, 600);
	color: var(--kwl-accent, #bd9b5c);
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.kw-event-calendar__cta {
	flex-shrink: 0;
	font-size: var(--kwl-fsize-small, 0.875rem);
	min-height: 44px;
	display: inline-flex;
	align-items: center;
}

/* --- Empty State --- */

.kw-event-calendar__empty {
	font-size: var(--kwl-fsize-body, 1rem);
	color: var(--kwl-text-muted, #64748b);
	text-align: center;
	padding: var(--kwl-space-lg, 1.5rem);
	margin: 0;
}

/* --- Focus --- */

.kw-event-calendar__title a:focus-visible,
.kw-event-calendar__ticket-link:focus-visible,
.kw-event-calendar__cta:focus-visible {
	outline: 3px solid var(--kwl-focus, #7b6835);
	outline-offset: 2px;
	border-radius: var(--kwl-radius-sm, 4px);
}

/* --- Dark Mode --- */

@media (prefers-color-scheme: dark) {
	.kw-event-calendar {
		--kwl-ec-card-bg: #1e3a5f;
		--kwl-ec-title-color: #ffffff;
		--kwl-ec-meta-color: rgba(255, 255, 255, 0.6);
		--kwl-ec-offer-bg: rgba(255, 255, 255, 0.08);
		--kwl-ec-offer-border: rgba(255, 255, 255, 0.1);
		--kwl-ec-badge-free-bg: #276749;
		--kwl-ec-badge-cancelled-bg: #9b2c2c;
	}

	.kw-event-calendar__badge--free,
	.kw-event-calendar__badge--cancelled {
		color: #ffffff;
	}
}

/* V4 Pink-Reset: zentral via [data-kwl-link] / [data-kwl-link-scope] auf .kw-event-calendar (§281) */
