/**
 * KW Lobby — JobsList Widget Styles.
 * Nutzt Shared Components (data-kwl-card, data-kwl-btn, data-kwl-link-scope,
 * data-kwl-separator) aus kwl-shared-components.css und Globale Tokens aus
 * frontend.css. Keine hardcodierten Farben/Schatten.
 */

.kw-jobs-list {
	--kw-jobs-gap: var(--kwl-space-lg, 24px);
	--kw-jobs-card-radius: var(--kwl-radius-lg, 16px);

	display: flex;
	flex-direction: column;
	gap: var(--kw-jobs-gap);
	container-type: inline-size;
}

/* ── Header ──────────────────────────────────────────────────────────── */

.kw-jobs-list__head {
	text-align: center;
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 8px);
}

.kw-jobs-list__heading {
	margin: 0;
	color: var(--kwl-text, currentColor);
	font-family: var(--kwl-font-heading, inherit);
}

.kw-jobs-list__sub {
	margin: 0;
	max-width: 60ch;
	margin-inline: auto;
	color: var(--kwl-text-muted, currentColor);
	font-size: var(--kwl-fsize-lead, 1.05rem);
	line-height: var(--kwl-lh-relaxed, 1.5);
}

/* ── Grid ─────────────────────────────────────────────────────────────── */

.kw-jobs-list__grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: var(--kw-jobs-gap);
	grid-template-columns: minmax(0, 1fr);
}

@container (min-width: 560px) {
	.kw-jobs-list__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@container (min-width: 900px) {
	.kw-jobs-list__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.kw-jobs-list__item {
	display: flex;
}

/* ── Card ─────────────────────────────────────────────────────────────── */

.kw-jobs-list__card {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100%;
	background: var(--kwl-bg, #fff);
	border-radius: var(--kw-jobs-card-radius);
	overflow: hidden;
	transition: transform 250ms var(--kwl-ease-default, ease), box-shadow 250ms var(--kwl-ease-default, ease);
}

.kw-jobs-list__card:hover {
	transform: translateY(-3px);
	box-shadow: var(--kwl-shadow-hover, 0 12px 32px rgba(0, 0, 0, 0.12));
}

@media (prefers-reduced-motion: reduce) {
	.kw-jobs-list__card {
		transition: none;
	}
	.kw-jobs-list__card:hover {
		transform: none;
	}
}

.kw-jobs-list__card-image {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--kwl-bg-alt, #f7fafc);
}

.kw-jobs-list__card-image .kw-jobs-list__card-img {
	width: 100%;
	height: 100%;
	display: block;
}

.kw-jobs-list__card .kw-jobs-list__card-image .kw-jobs-list__card-img {
	object-fit: cover;
}

.kw-jobs-list__card-body {
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 8px);
	padding: var(--kwl-space-md, 16px) var(--kwl-space-md, 16px) var(--kwl-space-lg, 20px);
	flex: 1 1 auto;
}

.kw-jobs-list__card-title {
	margin: 0;
	font-family: var(--kwl-font-heading, inherit);
	font-size: var(--kwl-fsize-h4, 1.25rem);
	line-height: var(--kwl-lh-snug, 1.3);
	color: var(--kwl-text, currentColor);
}

.kw-jobs-list__card-title a {
	color: inherit;
}

.kw-jobs-list__meta {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.kw-jobs-list__meta-chip {
	display: inline-flex;
	align-items: center;
	padding: 2px 10px;
	border-radius: 999px;
	background: color-mix(in oklab, var(--kwl-accent, #BD9B5C) 12%, transparent);
	color: var(--kwl-text, currentColor);
	font-size: var(--kwl-fsize-small, 0.85rem);
	line-height: var(--kwl-lh-snug, 1.3);
	font-variant-numeric: tabular-nums;
}

@media (prefers-color-scheme: dark) {
	.kw-jobs-list__meta-chip {
		background: rgba(189, 155, 92, 0.2);
	}
}

.kw-jobs-list__card-intro {
	margin: 0;
	color: var(--kwl-text-muted, currentColor);
	font-size: var(--kwl-fsize-body, 1rem);
	line-height: var(--kwl-lh-body, 1.55);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	line-clamp: 3;
	overflow: hidden;
}

.kw-jobs-list__card-cta {
	align-self: flex-start;
	margin-top: auto;
}

/* ── Empty state ─────────────────────────────────────────────────────── */

.kw-jobs-list__empty {
	text-align: center;
	padding: var(--kwl-space-xl, 32px) var(--kwl-space-lg, 24px);
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 12px);
	align-items: center;
}

.kw-jobs-list__empty-heading {
	margin: 0;
	font-family: var(--kwl-font-heading, inherit);
	font-size: var(--kwl-fsize-h4, 1.25rem);
	color: var(--kwl-text, currentColor);
}

.kw-jobs-list__empty-body {
	margin: 0;
	max-width: 50ch;
	color: var(--kwl-text-muted, currentColor);
}

.kw-jobs-list__empty-cta {
	margin-top: var(--kwl-space-sm, 8px);
}

/* ── V4 Elementor Reset: Titel-Link + CTA nicht pink ────────────────── */

.kw-jobs-list [data-kwl-link] {
	text-decoration: none;
}

.kw-jobs-list__card-title a:focus-visible {
	outline: 2px solid var(--kwl-focus, var(--kwl-accent, #7B6835));
	outline-offset: 3px;
	border-radius: 2px;
}
