/* ==========================================================================
	PriceList Widget (#27) — Premium Design 2026
	Zwei Skins: detailed (Tabelle) / open (Typografisch)
	========================================================================== */

/* --- 1. Custom Properties (Kaskade: Elementor → --kwl-pl-* → --kwl-*) --- */
.kw-pl-wrapper {
	--kwl-pl-card-bg: var(--kwl-bg, #ffffff);
	--kwl-pl-card-border: var(--kwl-border, #e2e8f0);
	--kwl-pl-card-radius: var(--kwl-radius-lg, 12px);
	--kwl-pl-card-padding: var(--kwl-space-lg, 1.5rem);
	--kwl-pl-section-gap: var(--kwl-space-lg, 1.5rem);
	--kwl-pl-accent: var(--kwl-accent, #BD9B5C);

	--kwl-pl-header-bg: var(--kwl-primary, #00315d);
	--kwl-pl-header-gradient-end: var(--kwl-primary-hover, #1e3a5f);
	--kwl-pl-header-color: var(--kwl-btn-text, #ffffff);

	--kwl-pl-row-bg: var(--kwl-bg, #ffffff);
	--kwl-pl-stripe-bg: var(--kwl-bg-alt, #f7fafc);
	--kwl-pl-hover-bg: color-mix(in srgb, var(--kwl-primary, #00315d) 5%, transparent);
	--kwl-pl-cell-border: var(--kwl-border, #e2e8f0);

	--kwl-pl-price-color: var(--kwl-primary, #00315d);
	--kwl-pl-badge-bg: color-mix(in srgb, var(--kwl-primary, #00315d) 8%, transparent);
	--kwl-pl-na-color: var(--kwl-text-muted, #718096);

	--kwl-pl-disc-bg: var(--kwl-bg-alt, #f7fafc);
	--kwl-pl-disc-color: var(--kwl-text-muted, #718096);

	--kwl-pl-heading-color: var(--kwl-text, #1a202c);
}

/* --- 2. Wrapper & Layout (Card-Container via [data-kwl-card]) --- */

/* Bridge: Widget-Tokens → Shared Card-Component */
.kw-pl-wrapper[data-kwl-card] {
	--kwl-card-accent: var(--kwl-pl-accent, var(--kwl-accent, #BD9B5C));
	--kwl-card-bg: var(--kwl-pl-card-bg, var(--kwl-bg, #ffffff));
	--kwl-card-border: var(--kwl-pl-card-border, var(--kwl-border, #e2e8f0));
}

.kw-pl-wrapper {
	display: flex;
	flex-direction: column;
	gap: var(--kwl-pl-section-gap);
	max-width: 100%;
	font-family: var(--kwl-font-body);
	color: var(--kwl-text, #1a202c);
	padding: var(--kwl-pl-card-padding);
}

/* --- 3. Header (Heading + Print-Button) --- */
.kw-pl-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--kwl-space-sm, 0.5rem);
	flex-wrap: wrap;
}

.kw-pl-wrapper .kw-pl-heading {
	margin: 0;
	flex: 1;
	font-family: var(--kwl-font-heading);
	font-weight: var(--kwl-fw-bold);
	color: var(--kwl-pl-heading-color);
	line-height: var(--kwl-lh-snug);
	padding-bottom: var(--kwl-space-sm, 0.5rem);
	--kwl-separator-height: 3px;
}

/* Separator folgt Textausrichtung */
.kw-pl-heading[data-kwl-separator="gold"]::after {
	width: 60%;
	right: auto;
}

/* Leere Überschrift: Separator ausblenden */
.kw-pl-heading:empty {
	display: none;
}

/* Zentrierte Überschrift: Symmetrischer Gold-Separator */
.kw-pl-heading[style*="text-align: center"][data-kwl-separator="gold"]::after,
.kw-pl-heading[style*="text-align:center"][data-kwl-separator="gold"]::after {
	left: 50%;
	transform: translateX(-50%);
	right: auto;
	width: 100%;
	max-width: var(--kwl-separator-max-width, 120px);
	background: linear-gradient(to right,
		transparent,
		color-mix(in srgb, var(--kwl-accent, #BD9B5C) 40%, transparent) 20%,
		var(--kwl-accent, #BD9B5C) 50%,
		color-mix(in srgb, var(--kwl-accent, #BD9B5C) 40%, transparent) 80%,
		transparent
	);
}

/* --- 4. Print Button — Pill-Override auf Shared data-kwl-btn="outline" --- */
.kw-pl-wrapper .kw-pl-print-btn {
	border-radius: var(--kwl-radius-full, 9999px);
	padding: 0.5rem;
	gap: 0.375rem;
	flex-shrink: 0;
	font-size: var(--kwl-fsize-small, 0.875rem);
}

.kw-pl-wrapper .kw-pl-print-btn svg {
	flex-shrink: 0;
}

/* Desktop: Label sichtbar, mehr Padding */
@media (min-width: 481px) {
	.kw-pl-wrapper .kw-pl-print-btn {
		padding: 0.5rem 1rem 0.5rem 0.75rem;
	}
}

/* Mobile: Nur Icon, kein Text */
@media (max-width: 480px) {
	.kw-pl-print-label {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip-path: inset(50%);
		border: 0;
	}
}

/* --- 5. Sektions-Header (Überschrift + optionaler Print-Button) --- */
.kw-pl-section-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--kwl-space-sm, 0.5rem);
}

.kw-pl-section-header .kw-pl-section-heading {
	flex: 1;
}

/* --- 5b. Sektions-Überschriften (Zimmerpreise / Sonstige Leistungen) --- */
.kw-pl-section-heading {
	margin: 0 0 var(--kwl-space-md, 1rem);
	padding-bottom: var(--kwl-space-sm, 0.5rem);
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h3, 1.5rem);
	font-weight: var(--kwl-fw-bold);
	color: var(--kwl-pl-heading-color);
	line-height: var(--kwl-lh-snug);
	--kwl-separator-height: 2px;
}

/* Abstand vor zweiter Sektion */
.kw-pl-section-header:not(:first-of-type),
.kw-pl-section-heading:not(:first-of-type) {
	margin-top: var(--kwl-space-xl, 2rem);
}

/* Abstand zwischen letztem Zimmer und nächster Sektions-Überschrift */
.kw-pl-room + .kw-pl-section-header,
.kw-pl-room + .kw-pl-section-heading {
	margin-top: var(--kwl-space-xl, 2rem);
}

/* --- 7. Room Cards (Detailed Skin) --- */
.kw-pl-room {
	background: var(--kwl-pl-card-bg);
	border: 1px solid var(--kwl-pl-card-border);
	border-radius: var(--kwl-pl-card-radius);
	border-top: 3px solid var(--kwl-pl-accent);
	overflow: hidden;
	box-shadow: var(--kwl-pl-card-shadow);
	transition: box-shadow var(--kwl-transition, 200ms ease), transform var(--kwl-transition, 200ms ease);
}

@media (hover: hover) {
	.kw-pl-room:hover {
		box-shadow: var(--kwl-pl-card-shadow-hover);
		transform: translateY(-3px);
	}
}

.kw-pl-room__header {
	padding: 0.75rem var(--kwl-pl-card-padding);
	background: linear-gradient(135deg, var(--kwl-pl-header-bg), var(--kwl-pl-header-gradient-end));
	color: var(--kwl-pl-header-color);
}

.kw-pl-room__title {
	margin: 0;
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h4, 1.25rem);
	color: var(--kwl-pl-header-color);
}

.kw-pl-room__title a {
	--kwl-link-color: var(--kwl-pl-header-color);
	--kwl-link-hover-color: var(--kwl-pl-header-color);
}

.kw-pl-room__inner {
	container-type: inline-size;
	padding: var(--kwl-space-sm, 0.5rem);
}

@media (min-width: 481px) {
	.kw-pl-room__inner {
		padding: var(--kwl-pl-card-padding);
	}
}

/* --- 8. Non-Room Sections (flach innerhalb Gruppen-Container) --- */

/* --- 9. Table (Detailed Skin) --- */
.kw-pl-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--kwl-fsize-body, 1rem);
}

.kw-pl-wrapper .kw-pl-table thead th {
	padding: 0.75rem 1rem;
	text-align: left;
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-pl-heading-color);
	background-color: var(--kwl-pl-stripe-bg);
	border-bottom: 2px solid var(--kwl-pl-accent);
	white-space: nowrap;
}

.kw-pl-table tbody th,
.kw-pl-table tbody td {
	padding: 0.75rem 1rem;
	border-bottom: 1px solid var(--kwl-pl-cell-border);
	vertical-align: middle;
}

.kw-pl-table tbody th {
	font-weight: var(--kwl-fw-medium);
	text-align: left;
}

.kw-pl-class-cell {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
}

.kw-pt-bed-dimensions,
.kw-pt-room-size {
	display: block;
	font-size: var(--kwl-fsize-caption);
	color: var(--kwl-text-muted);
	line-height: var(--kwl-lh-tight);
	letter-spacing: var(--kwl-ls-wide);
	margin-top: var(--kwl-space-xs, 0.25rem);
}

.kw-pl-table tbody tr:nth-child(even) {
	background: var(--kwl-pl-stripe-bg);
}

@media (hover: hover) {
	.kw-pl-table tbody tr:hover {
		background: var(--kwl-pl-hover-bg);
	}
}

/* --- 10. DL-Struktur (Surcharges + Services) --- */
.kw-pl-dl {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin: 0;
}

.kw-pl-dl__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	padding: 0.75rem 0.75rem;
	border-bottom: 1px solid var(--kwl-pl-cell-border);
}

.kw-pl-dl__row:last-child {
	border-bottom: none;
}

.kw-pl-dl__row:nth-child(even) {
	background: var(--kwl-pl-stripe-bg);
	border-radius: var(--kwl-radius-sm, 4px);
}

@media (hover: hover) {
	.kw-pl-dl .kw-pl-dl__row:hover {
		background: var(--kwl-pl-hover-bg);
	}
}

/* Kinder-Staffelung: eingerückt mit dezenter linker Akzentlinie */
.kw-pl-dl__row--child {
	padding-left: 1.5rem;
	border-left: 2px solid var(--kwl-accent, #BD9B5C);
	margin-left: 0.75rem;
}

.kw-pl-dl__row--child dt {
	font-weight: var(--kwl-fw-regular);
	font-size: var(--kwl-fsize-small, 0.875rem);
}

/* Abstand nach letztem Kind-Eintrag vor nächster regulärer Zeile */
.kw-pl-dl__row--child + .kw-pl-dl__row:not(.kw-pl-dl__row--child) {
	margin-top: var(--kwl-space-sm, 0.5rem);
}

.kw-pl-dl dt {
	margin: 0;
	font-weight: var(--kwl-fw-medium);
	color: var(--kwl-text, #1a202c);
	display: flex;
	align-items: center;
	gap: 0.375rem;
}

.kw-pl-dl dd {
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.125rem;
	flex-shrink: 0;
}

/* --- 11. Price Badges --- */
.kw-pl-price {
	font-weight: var(--kwl-fw-bold);
	color: var(--kwl-pl-price-color);
	background: var(--kwl-pl-badge-bg);
	padding: 0.25rem 0.75rem;
	border-radius: var(--kwl-radius-sm, 4px);
	border: 1px solid color-mix(in srgb, var(--kwl-primary, #00315d) 12%, transparent);
	font-size: 0.95em;
	font-variant-numeric: tabular-nums;
	min-width: 7rem;
	text-align: center;
}

.kw-pl-price--free,
.kw-pl-badge--free {
	color: var(--kwl-accent, #BD9B5C);
	background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 10%, transparent);
	border-color: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 20%, transparent);
	font-weight: var(--kwl-fw-bold);
	padding: 0.25rem 0.75rem;
	border-radius: var(--kwl-radius-sm, 4px);
	border-style: solid;
	border-width: 1px;
	font-size: 0.95em;
	min-width: 7rem;
	text-align: center;
}

.kw-pl-unit {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	color: var(--kwl-text-muted, #718096);
	text-align: center;
	align-self: flex-end;
}

.kw-pl-text {
	font-style: italic;
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-text-muted, #718096);
	background: color-mix(in srgb, var(--kwl-text-muted, #718096) 6%, transparent);
	padding: 0.25rem 0.75rem;
	border-radius: var(--kwl-radius-sm, 4px);
	border: 1px solid color-mix(in srgb, var(--kwl-text-muted, #718096) 10%, transparent);
	min-width: 7rem;
	text-align: center;
	font-size: 0.95em;
}

.kw-pl-na {
	color: var(--kwl-pl-na-color);
}

/* --- 12. Extra Bed Icon — Glassmorphism-Kreis --- */
.kw-pl-extra-bed-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	color: var(--kwl-pl-accent);
	background: color-mix(in srgb, var(--kwl-pl-accent) 12%, transparent);
	border-radius: var(--kwl-radius-full, 9999px);
	border: 1px solid color-mix(in srgb, var(--kwl-pl-accent) 20%, transparent);
	vertical-align: middle;
	flex-shrink: 0;
}

/* --- 13. Disclaimer --- */
.kw-pl-disclaimer {
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-md, 1rem);
	background: var(--kwl-pl-disc-bg);
	color: var(--kwl-pl-disc-color);
	border-left: 3px solid var(--kwl-pl-accent);
	border-radius: 0 var(--kwl-radius-sm, 4px) var(--kwl-radius-sm, 4px) 0;
	font-size: var(--kwl-fsize-small, 0.875rem);
	line-height: var(--kwl-lh-prose);
}

.kw-pl-nowrap {
	white-space: nowrap;
}

.kw-pl-disclaimer {
	--kwl-link-color: var(--kwl-primary, #00315d);
	--kwl-link-hover-color: var(--kwl-primary-hover, #1e3a5f);
}

.kw-pl-disclaimer a {
	text-decoration: underline;
	text-underline-offset: 2px;
}

.kw-pl-disclaimer a:active {
	color: var(--kwl-primary-hover, #1e3a5f);
	opacity: 0.8;
}

.kw-pl-disclaimer a:focus-visible {
	outline: 3px solid var(--kwl-focus, #7B6835);
	outline-offset: 2px;
}

@media (hover: hover) {
	.kw-pl-disclaimer a:hover {
		color: var(--kwl-primary-hover, #1e3a5f);
	}

	.kw-pl-room__title a:hover {
		text-decoration: underline;
		text-underline-offset: 2px;
	}
}

/* --- 14. Last Modified --- */
.kw-pl-last-modified {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	color: var(--kwl-text-muted, #718096);
	text-align: right;
}

/* --- 15. Focus Visible --- */
.kw-pl-room__title a:focus-visible {
	outline: 3px solid var(--kwl-focus, #7B6835);
	outline-offset: 2px;
}

/* --- 16. Container Query (Detailed Skin: Table → Card-Stack) --- */
@container (max-width: 600px) {
	.kw-pl-table thead {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip-path: inset(50%);
		white-space: nowrap;
		border: 0;
	}

	.kw-pl-table tbody tr {
		display: flex;
		flex-direction: column;
		padding: 0.75rem 0;
		border-bottom: 1px solid var(--kwl-pl-cell-border);
	}

	.kw-pl-table tbody th,
	.kw-pl-table tbody td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0.375rem 0.5rem;
		border-bottom: none;
		text-align: right;
	}

	.kw-pl-table tbody th::before,
	.kw-pl-table tbody td::before {
		content: attr(data-label);
		font-weight: var(--kwl-fw-semibold);
		color: var(--kwl-pl-heading-color);
		text-align: left;
		margin-right: auto;
	}

	.kw-pl-table tbody th {
		font-weight: var(--kwl-fw-bold);
		border-bottom: 1px solid var(--kwl-pl-cell-border);
	}

	.kw-pl-table tbody th::before {
		display: none;
	}
}

/* --- 17. Responsive --- */

/* Mobile: Kompaktere Badges + Einheiten */
@media (max-width: 480px) {
	.kw-pl-unit {
		font-size: var(--kwl-fsize-caption, 0.7rem);
	}

	.kw-pl-price,
	.kw-pl-price--free,
	.kw-pl-badge--free,
	.kw-pl-text {
		min-width: 5.5rem;
		font-size: 0.875em;
	}
}

/* ==========================================================================
   OPEN SKIN — Typografisch, ohne Card-Wrapper
   Kein data-kwl-card, Zimmer als eigenständige Blöcke auf Seitenhintergrund.
   Preise als Typografie statt Badges, Inklusive/Optional-Split, tabular-nums.
   ========================================================================== */

/* --- O1. Wrapper: Kein Card-Chrome --- */
.kw-pl-wrapper--open {
	background: none;
	border: none;
	box-shadow: none;
	border-radius: 0;
	padding: 0;
}

/* --- O2. Room-Blöcke: Separator statt Card --- */
.kw-pl-wrapper--open .kw-pl-room--open {
	background: none;
	border: none;
	box-shadow: none;
	border-radius: 0;
	overflow: visible;
	padding-bottom: var(--kwl-space-lg, 1.5rem);
	margin-bottom: var(--kwl-space-lg, 1.5rem);
	border-bottom: 1px solid var(--kwl-pl-cell-border);
	transition: none;
}

.kw-pl-wrapper--open .kw-pl-room--open:last-of-type {
	border-bottom: none;
	margin-bottom: 0;
}

@media (hover: hover) {
	.kw-pl-wrapper--open .kw-pl-room--open:hover {
		box-shadow: none;
		transform: none;
	}
}

/* --- O3. Room-Header: Name links, Ab-Preis rechts, kein Gradient --- */
.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__header {
	background: none;
	padding: 0 0 var(--kwl-space-sm, 0.5rem);
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: var(--kwl-space-md, 1rem);
	color: var(--kwl-text, #1a202c);
	border-bottom: 2px solid var(--kwl-pl-accent);
	margin-bottom: var(--kwl-space-md, 1rem);
}

.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title {
	color: var(--kwl-text, #1a202c);
}

.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title a {
	--kwl-link-color: var(--kwl-primary, #00315d);
	--kwl-link-hover-color: var(--kwl-primary-hover, #1e3a5f);
	position: relative;
}

/* Underline-Animation auf Hover (wie PriceTable) */
.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--kwl-pl-accent);
	transition: width 300ms ease;
}

@media (hover: hover) {
	.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title a:hover::after {
		width: 100%;
	}
}

/* Ab-Preis im Header */
.kw-pl-room__starting-price {
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h4, 1.25rem);
	font-weight: var(--kwl-fw-bold);
	font-variant-numeric: lining-nums tabular-nums;
	color: var(--kwl-pl-price-color);
	white-space: nowrap;
	flex-shrink: 0;
	letter-spacing: var(--kwl-ls-tighter);
}

/* --- O4. Room-Inner: Kein Card-Padding --- */
.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__inner {
	padding: 0;
}

/* --- O5. Typografische Preise (kein Badge-Background) --- */
.kw-pl-price-typo {
	font-family: var(--kwl-font-heading);
	font-weight: var(--kwl-fw-bold);
	font-variant-numeric: lining-nums tabular-nums;
	color: var(--kwl-pl-price-color);
	white-space: nowrap;
	letter-spacing: var(--kwl-ls-tight);
}

.kw-pl-unit-inline {
	font-family: var(--kwl-font-body);
	font-weight: var(--kwl-fw-regular);
	font-size: 0.8em;
	color: var(--kwl-text-muted, #718096);
	letter-spacing: 0;
}

/* --- O6. Tabelle im Open-Skin --- */
.kw-pl-table--open {
	font-variant-numeric: lining-nums tabular-nums;
}

/* Kein Zebra-Striping */
.kw-pl-wrapper--open .kw-pl-table--open tbody tr:nth-child(even) {
	background: none;
}

/* Dezenter Hover statt Zebra */
@media (hover: hover) {
	.kw-pl-wrapper--open .kw-pl-table--open tbody tr:hover {
		background: color-mix(in srgb, var(--kwl-primary, #00315d) 3%, transparent);
	}
}

/* Preiszellen rechts ausrichten */
.kw-pl-wrapper--open .kw-pl-table--open td {
	text-align: right;
}

/* Tabellen-Header: etwas mehr Padding für Lesbarkeit */
.kw-pl-wrapper--open .kw-pl-table--open tbody th,
.kw-pl-wrapper--open .kw-pl-table--open tbody td {
	padding: 0.875rem 1rem;
}

/* --- O7. Check-Icon für "inklusive" --- */
.kw-pl-check-free {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	color: var(--kwl-accent, #BD9B5C);
	font-weight: var(--kwl-fw-semibold);
	font-size: var(--kwl-fsize-body, 1rem);
}

.kw-pl-check-free svg {
	flex-shrink: 0;
}

/* --- O8. Service-Gruppen mit Sub-Headings --- */
.kw-pl-service-group {
	padding-top: var(--kwl-space-md, 1rem);
}

.kw-pl-service-group + .kw-pl-service-group {
	margin-top: var(--kwl-space-md, 1rem);
	border-top: 1px solid var(--kwl-pl-cell-border);
}

.kw-pl-service-group__header {
	margin-bottom: var(--kwl-space-sm, 0.5rem);
}

.kw-pl-service-group__title {
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h5, 1.125rem);
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-text, #1a202c);
}

.kw-pl-service-group__link {
	--kwl-link-color: var(--kwl-primary, #00315d);
	--kwl-link-hover-color: var(--kwl-primary-hover, #1e3a5f);
	display: inline-flex;
	align-items: baseline;
	gap: 0.375rem;
	position: relative;
}

.kw-pl-service-group__link .kw-pl-service-group__title {
	color: var(--kwl-primary, #00315d);
}

.kw-pl-service-group__arrow {
	font-size: 0.85em;
	opacity: 0;
	transform: translateX(-4px);
	transition: opacity 250ms ease, transform 250ms ease;
}

@media (hover: hover) {
	.kw-pl-service-group__link:hover .kw-pl-service-group__title {
		color: var(--kwl-primary-hover, #1e3a5f);
	}

	.kw-pl-service-group__link:hover .kw-pl-service-group__arrow {
		opacity: 1;
		transform: translateX(0);
	}
}

.kw-pl-service-group__link:active {
	opacity: 0.8;
}

/* Kein Zebra in Open-DLs */
.kw-pl-dl--open .kw-pl-dl__row:nth-child(even) {
	background: none;
}

@media (hover: hover) {
	.kw-pl-dl--open .kw-pl-dl__row:hover {
		background: color-mix(in srgb, var(--kwl-primary, #00315d) 3%, transparent);
	}
}

/* Etwas mehr Padding in Open-DL-Zeilen */
.kw-pl-dl--open .kw-pl-dl__row {
	padding: 0.875rem 0.75rem;
}

/* --- O9. Container Query: Open-Skin Tabelle → Card-Stack --- */
@container (max-width: 600px) {
	.kw-pl-table--open thead {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip-path: inset(50%);
		white-space: nowrap;
		border: 0;
	}

	.kw-pl-table--open tbody tr {
		display: flex;
		flex-direction: column;
		padding: 0.75rem 0;
		border-bottom: 1px solid var(--kwl-pl-cell-border);
	}

	.kw-pl-table--open tbody th,
	.kw-pl-table--open tbody td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0.375rem 0;
		border-bottom: none;
		text-align: right;
	}

	.kw-pl-table--open tbody th::before,
	.kw-pl-table--open tbody td::before {
		content: attr(data-label);
		font-weight: var(--kwl-fw-semibold);
		color: var(--kwl-pl-heading-color);
		text-align: left;
		margin-right: auto;
	}

	.kw-pl-table--open tbody th {
		font-weight: var(--kwl-fw-bold);
		border-bottom: 1px solid var(--kwl-pl-cell-border);
	}

	.kw-pl-table--open tbody th::before {
		display: none;
	}

	/* Einheiten stacken auf Mobile */
	.kw-pl-price-typo {
		display: flex;
		flex-direction: column;
		align-items: flex-end;
		gap: 0.125rem;
	}
}

/* Mobile: Room-Header wrap */
@media (max-width: 480px) {
	.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__header {
		flex-wrap: wrap;
	}

	.kw-pl-room__starting-price {
		font-size: var(--kwl-fsize-h5, 1.125rem);
	}
}

/* --- 18. Dark Mode --- */
@media (prefers-color-scheme: dark) {
	.kw-pl-wrapper {
		--kwl-pl-card-bg: var(--kwl-bg, #1a202c);
		--kwl-pl-card-border: var(--kwl-border, #4a5568);
		--kwl-pl-accent: var(--kwl-accent, #d4b87a);
		--kwl-pl-header-bg: color-mix(in srgb, var(--kwl-primary, #63b3ed) 25%, var(--kwl-bg, #1a202c));
		--kwl-pl-header-gradient-end: color-mix(in srgb, var(--kwl-primary, #63b3ed) 15%, var(--kwl-bg, #1a202c));
		--kwl-pl-header-color: var(--kwl-text, #f7fafc);
		--kwl-pl-hover-bg: rgba(255, 255, 255, 0.05);
		--kwl-pl-badge-bg: rgba(255, 255, 255, 0.08);
		--kwl-pl-price-color: var(--kwl-primary, #63b3ed);
		--kwl-pl-stripe-bg: var(--kwl-bg-alt, #2d3748);
		--kwl-pl-cell-border: var(--kwl-border, #4a5568);
		--kwl-pl-disc-bg: var(--kwl-bg-alt, #2d3748);
		--kwl-pl-disc-color: var(--kwl-text-muted, #a0aec0);
		--kwl-pl-na-color: var(--kwl-text-muted, #a0aec0);
		--kwl-pl-heading-color: var(--kwl-text, #f7fafc);
		color: var(--kwl-text, #f7fafc);
	}

	.kw-pl-heading[data-kwl-separator="gold"]::after {
		background: linear-gradient(to right, var(--kwl-accent, #d4b87a), color-mix(in srgb, var(--kwl-accent, #d4b87a) 30%, transparent), transparent);
	}

	.kw-pl-heading[style*="text-align: center"][data-kwl-separator="gold"]::after,
	.kw-pl-heading[style*="text-align:center"][data-kwl-separator="gold"]::after {
		background: linear-gradient(to right,
			transparent,
			color-mix(in srgb, var(--kwl-accent, #d4b87a) 40%, transparent) 20%,
			var(--kwl-accent, #d4b87a) 50%,
			color-mix(in srgb, var(--kwl-accent, #d4b87a) 40%, transparent) 80%,
			transparent
		);
	}

	.kw-pl-dl dt {
		color: var(--kwl-text, #f7fafc);
	}

	.kw-pl-price {
		border-color: rgba(255, 255, 255, 0.1);
	}

	.kw-pl-text {
		color: var(--kwl-text-muted, #a0aec0);
		background: rgba(255, 255, 255, 0.05);
		border-color: rgba(255, 255, 255, 0.08);
	}

	.kw-pl-price--free,
	.kw-pl-badge--free {
		color: var(--kwl-accent, #d4b87a);
		background: rgba(189, 155, 92, 0.12);
		border-color: rgba(189, 155, 92, 0.25);
	}

	.kw-pl-dl__row--child {
		border-left-color: var(--kwl-accent, #BD9B5C);
	}

	.kw-pl-extra-bed-icon {
		background: color-mix(in srgb, var(--kwl-pl-accent) 15%, transparent);
		border-color: color-mix(in srgb, var(--kwl-pl-accent) 25%, transparent);
	}

	.kw-pl-disclaimer a {
		color: var(--kwl-primary, #63b3ed);
	}

	/* Open Skin: Dark Mode */
	.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__header {
		border-bottom-color: var(--kwl-accent, #d4b87a);
		color: var(--kwl-text, #f7fafc);
	}

	.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title {
		color: var(--kwl-text, #f7fafc);
	}

	.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title a {
		--kwl-link-color: var(--kwl-primary, #63b3ed);
		--kwl-link-hover-color: var(--kwl-primary, #63b3ed);
	}

	.kw-pl-room__starting-price {
		color: var(--kwl-primary, #63b3ed);
	}

	.kw-pl-price-typo {
		color: var(--kwl-primary, #63b3ed);
	}

	.kw-pl-check-free {
		color: var(--kwl-accent, #d4b87a);
	}

	.kw-pl-wrapper--open .kw-pl-room--open {
		border-bottom-color: var(--kwl-border, #4a5568);
	}

	.kw-pl-service-group + .kw-pl-service-group {
		border-top-color: var(--kwl-border, #4a5568);
	}

	.kw-pl-service-group__title {
		color: var(--kwl-text, #f7fafc);
	}

	.kw-pl-service-group__link {
		--kwl-link-color: var(--kwl-primary, #63b3ed);
		--kwl-link-hover-color: var(--kwl-primary, #63b3ed);
	}

	.kw-pl-disclaimer a:focus-visible {
		outline-color: var(--kwl-focus, #c9a84c);
	}

	@media (hover: hover) {
		.kw-pl-wrapper--open .kw-pl-table--open tbody tr:hover {
			background: rgba(255, 255, 255, 0.04);
		}
	}
}

/* --- 19. Reduced Motion --- */
@media (prefers-reduced-motion: reduce) {
	.kw-pl-room,
	.kw-pl-disclaimer a {
		transition: none;
	}

	@media (hover: hover) {
		.kw-pl-room:hover {
			transform: none;
		}
	}

	.kw-pl-wrapper--open .kw-pl-room--open .kw-pl-room__title a::after,
	.kw-pl-service-group__arrow {
		transition: none;
	}
}

/* --- 20. Print --- */
@media print {
	.kw-pl-wrapper .kw-pl-print-btn {
		display: none;
	}

	.kw-pl-wrapper--open .kw-pl-room--open {
		break-inside: avoid;
	}
}

/* V4 Pink-Reset: zentral in kwl-shared-components.css via [data-kwl-link] / [data-kwl-link-scope] (§281) */
