/* --- ActivitySummary (#46) — Hero-Overlay + Badge + Titel --- */

/* --- Custom Properties --- */

.kw-as {
	--kwl-as-radius: var(--kwl-radius-lg, 12px);
	overflow: hidden;
	border-radius: var(--kwl-as-radius);
}

/* --- Hero-Modus (Bild vorhanden) --- */

.kw-as--hero {
	position: relative;
}

.kw-as__hero-image {
	position: relative;
	overflow: hidden;
}

.kw-as__img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

[data-ratio="21-9"] .kw-as__img { aspect-ratio: 21 / 9; }
[data-ratio="16-9"] .kw-as__img { aspect-ratio: 16 / 9; }
[data-ratio="4-3"] .kw-as__img { aspect-ratio: 4 / 3; }

[data-ratio="16-9"] .kw-as__hero-image { min-height: 280px; }

@media (min-width: 768px) {
	[data-ratio="16-9"] .kw-as__hero-image { min-height: 360px; }
}

/* --- Hero Overlay (Gradient + Inhalt) --- */

.kw-as__hero-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 12px);
	padding: var(--kwl-space-xl, 4rem) var(--kwl-space-md, 1.5rem) var(--kwl-space-md, 1.5rem);
	background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.55) 60%, transparent 100%);
	color: #ffffff;
}

@media (min-width: 768px) {
	.kw-as__hero-overlay {
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
		padding: var(--kwl-space-xl, 4rem) var(--kwl-space-lg, 2rem) var(--kwl-space-lg, 2rem);
	}
}

.kw-as__hero-content {
	flex: 1 1 auto;
	min-width: 0;
}

/* --- Badge (auf Bild) --- */

.kw-as__badge {
	position: absolute;
	top: var(--kwl-space-sm, 12px);
	left: var(--kwl-space-sm, 12px);
	padding: 4px 14px;
	background: var(--kwl-accent, #BD9B5C);
	color: var(--kwl-accent-contrast, #00315d);
	font-family: var(--kwl-font-body, sans-serif);
	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;
	border-radius: var(--kwl-radius-sm, 6px);
	line-height: var(--kwl-lh-tight, 1.2);
	z-index: 2;
}

.kw-as__badge--inline {
	position: static;
	display: inline-block;
	margin-bottom: var(--kwl-space-xs, 8px);
}

/* --- Typ-Chip (im Overlay) --- */

.kw-as__chip {
	flex-shrink: 0;
	align-self: flex-end;
	padding: 6px 16px;
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(8px);
	color: #ffffff;
	font-size: var(--kwl-fsize-caption, 0.75rem);
	font-weight: var(--kwl-fw-medium, 500);
	border-radius: var(--kwl-radius-full, 9999px);
	line-height: var(--kwl-lh-tight, 1.2);
	border: 1px solid rgba(255, 255, 255, 0.2);
}

/* --- Titel + Beschreibung (im Overlay) --- */

.kw-as--hero .kw-as__title {
	margin: 0 0 var(--kwl-space-xs, 4px);
	font-family: var(--kwl-font-heading, serif);
	font-size: var(--kwl-fsize-h1, clamp(1.75rem, 3vw, 2.5rem));
	font-weight: var(--kwl-fw-bold, 700);
	line-height: var(--kwl-lh-heading, 1.15);
	color: #ffffff;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.kw-as--hero .kw-as__desc {
	margin: 0;
	font-size: var(--kwl-fsize-body, 1rem);
	line-height: var(--kwl-lh-body, 1.5);
	color: rgba(255, 255, 255, 0.85);
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}

/* --- Fallback-Modus (kein Bild) --- */

.kw-as__body {
	padding: var(--kwl-space-md, 24px);
}

.kw-as__body .kw-as__title {
	margin: 0 0 var(--kwl-space-xs, 8px);
	font-family: var(--kwl-font-heading, serif);
	font-size: var(--kwl-fsize-h1, clamp(1.75rem, 3vw, 2.5rem));
	font-weight: var(--kwl-fw-bold, 700);
	line-height: var(--kwl-lh-heading, 1.15);
	color: var(--kwl-text, #1a202c);
}

.kw-as__body .kw-as__desc {
	margin: 0;
	font-size: var(--kwl-fsize-body, 1rem);
	line-height: var(--kwl-lh-body, 1.5);
	color: var(--kwl-text-muted, #64748b);
}

/* --- Event Status --- */

.kw-as__status {
	padding: var(--kwl-space-xs, 8px) var(--kwl-space-sm, 12px);
	border-radius: var(--kwl-radius-sm, 6px);
	font-size: var(--kwl-fsize-small, 0.875rem);
	font-weight: var(--kwl-fw-semibold, 600);
	text-align: center;
}

.kw-as--hero .kw-as__status {
	align-self: flex-start;
}

.kw-as__status--cancelled {
	background: rgba(197, 48, 48, 0.2);
	color: #fc8181;
}

.kw-as__status--postponed {
	background: rgba(192, 86, 33, 0.2);
	color: #ed8936;
}

.kw-as__body .kw-as__status--cancelled {
	background: color-mix(in srgb, var(--kwl-error, #c53030) 10%, transparent);
	color: var(--kwl-error, #c53030);
	margin-bottom: var(--kwl-space-sm, 12px);
}

.kw-as__body .kw-as__status--postponed {
	background: color-mix(in srgb, var(--kwl-warning, #c05621) 10%, transparent);
	color: var(--kwl-warning, #c05621);
	margin-bottom: var(--kwl-space-sm, 12px);
}

/* --- Dark Mode (nur Fallback-Modus) --- */

@media (prefers-color-scheme: dark) {
	.kw-as__body .kw-as__status--cancelled {
		background: rgba(252, 129, 129, 0.15);
		color: var(--kwl-error, #fc8181);
	}

	.kw-as__body .kw-as__status--postponed {
		background: rgba(237, 137, 54, 0.15);
		color: var(--kwl-warning, #ed8936);
	}
}

/* --- Reduced Motion --- */

@media (prefers-reduced-motion: reduce) {
	.kw-as,
	.kw-as * {
		transition-duration: 0.01ms;
	}
}
