/* ==========================================================================
   DirectionsTravel Widget — Anreise (Auto, ÖPNV, Flug, Taxi)
   Premium Card: Hover-Lift, Icon-Kreise, Container Queries, Scroll-Reveal
   ========================================================================== */

/* --- 1. Custom Properties --- */
.kw-directions-travel {
	--kwl-travel-card-bg: var(--kwl-bg, #ffffff);
	--kwl-travel-card-border: var(--kwl-border, #e2e8f0);
	--kwl-travel-card-accent: var(--kwl-accent, #BD9B5C);
	--kwl-travel-card-radius: var(--kwl-radius-lg, 12px);
	--kwl-travel-heading-color: var(--kwl-text, #1a202c);
	--kwl-travel-section-heading-color: var(--kwl-text, #1a202c);
	--kwl-travel-body-color: var(--kwl-text, #1a202c);
	--kwl-travel-icon-color: var(--kwl-accent, #BD9B5C);
	--kwl-travel-icon-size: 24px;
	--kwl-travel-btn-bg: var(--kwl-primary, #00315d);
	--kwl-travel-btn-color: var(--kwl-btn-text, #ffffff);
	--kwl-travel-btn-radius: var(--kwl-radius-md, 8px);
}

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

/* --- 2. Card Container --- */
.kw-directions-travel {
	padding: var(--kwl-space-lg, 1.5rem);
	color: var(--kwl-travel-body-color);
}

/* --- 3. Titel --- */
.kw-directions-travel__title {
	color: var(--kwl-travel-heading-color);
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h2, 1.5rem);
	margin: 0 0 var(--kwl-space-md, 1rem);
	line-height: var(--kwl-lh-snug);
}

/* --- 3b. Intro --- */
.kw-directions-travel__intro {
	margin-bottom: var(--kwl-space-md, 1rem);
	line-height: var(--kwl-lh-prose);
}

/* --- 4. Section --- */
.kw-directions-travel__section {
	border-bottom: 1px solid var(--kwl-travel-card-border);
	padding: var(--kwl-space-md, 1rem) 0;
}

.kw-directions-travel__section:last-of-type {
	border-bottom: none;
	padding-bottom: 0;
}

.kw-directions-travel__section-header {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	margin-bottom: var(--kwl-space-sm, 0.5rem);
}

.kw-directions-travel__section-heading {
	color: var(--kwl-travel-section-heading-color);
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-h4, 1.1rem);
	font-weight: var(--kwl-fw-semibold);
	margin: 0;
	line-height: var(--kwl-lh-snug);
}

/* --- 5. Section Body --- */
.kw-directions-travel__section-body {
	padding: 0;
	container-type: inline-size;
	container-name: travel-section;
}

.kw-directions-travel__section-intro {
	margin: 0 0 var(--kwl-space-lg, 1.5rem);
	color: var(--kwl-text-muted, #718096);
	line-height: var(--kwl-lh-prose);
}

/* --- 6. Icon-Circle Bridge: Widget → Shared [data-kwl-icon-circle] --- */
.kw-directions-travel [data-kwl-icon-circle] {
	--kwl-icon-color: var(--kwl-travel-icon-color, var(--kwl-accent, #BD9B5C));
	--kwl-icon-svg-size: var(--kwl-travel-icon-size, 24px);
}

.kw-directions-travel__section-icon--inline {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	color: var(--kwl-travel-icon-color);
	background: color-mix(in srgb, var(--kwl-travel-icon-color) 8%, transparent);
	border-radius: var(--kwl-radius-full, 9999px);
	border: none;
}

.kw-directions-travel__section-icon--inline svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

/* --- 6b. Section Image (shared) --- */
.kw-directions__section-image {
	display: block;
	margin-block: var(--kwl-space-3xl, 4rem) var(--kwl-space-lg, 1.5rem);
	margin-inline: 0;
	padding: 0;
	width: fit-content;
	max-width: 100%;
}

/* Größe-Varianten (Presets) — doppelter Selektor gegen V4-Resets (0,2,0) */
.kw-directions__section-image.kw-directions__section-image--size-small {
	max-width: min(400px, 100%);
}

.kw-directions__section-image.kw-directions__section-image--size-medium {
	max-width: min(600px, 100%);
}

.kw-directions__section-image.kw-directions__section-image--size-large {
	max-width: min(800px, 100%);
}

.kw-directions__section-image.kw-directions__section-image--size-full {
	max-width: 100%;
}

/* Ausrichtungs-Varianten — doppelter Selektor gegen V4-Resets (0,2,0) */
.kw-directions__section-image.kw-directions__section-image--align-left {
	margin-inline: 0 auto;
}

.kw-directions__section-image.kw-directions__section-image--align-center {
	margin-inline: auto;
}

.kw-directions__section-image.kw-directions__section-image--align-right {
	margin-inline: auto 0;
}

.kw-directions__image-link {
	display: block;
	border-radius: var(--kwl-radius-md, 8px);
	overflow: hidden;
	transition: box-shadow var(--kwl-transition, 200ms ease);
}

.kw-directions__image {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--kwl-radius-md, 8px);
	border: 1px solid var(--kwl-border, #e2e8f0);
	transition: transform 500ms var(--kwl-ease-default);
}

@media (hover: hover) {
	.kw-directions__image-link:hover {
		box-shadow: var(--kwl-shadow-lg);
	}

	.kw-directions__image-link:hover .kw-directions__image {
		transform: scale(1.03);
	}
}

.kw-directions__image-link:active {
	opacity: 0.9;
}

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

/* --- 7. Facts (Inline für kurze Key-Value-Paare wie Taxi-Kosten) --- */
.kw-directions-travel__fact {
	display: flex;
	flex-wrap: wrap;
	gap: var(--kwl-space-xs, 0.25rem) var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-sm, 0.5rem);
	border-radius: var(--kwl-radius-sm, 4px);
}

.kw-directions-travel__fact:nth-child(even) {
	background: color-mix(in srgb, var(--kwl-text, #1a202c) 3%, var(--kwl-travel-card-bg));
}

.kw-directions-travel__fact-label {
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-text-muted, #718096);
	min-width: 10ch;
	flex-shrink: 0;
}

/* --- 7b. Fact Cards (Autobahnausfahrt, Navi-Hinweis) --- */
.kw-directions-travel__facts-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--kwl-space-sm, 0.5rem);
	margin: var(--kwl-space-md, 1rem) 0 var(--kwl-space-lg, 1.5rem);
}

.kw-directions-travel__fact-card {
	display: flex;
	align-items: flex-start;
	gap: var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-md, 1rem);
	background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 5%, var(--kwl-travel-card-bg));
	border: 1px solid color-mix(in srgb, var(--kwl-accent, #BD9B5C) 15%, var(--kwl-travel-card-border));
	border-radius: var(--kwl-radius-md, 8px);
	transition: box-shadow var(--kwl-transition, 200ms ease);
}

.kw-directions-travel__fact-card-body {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-width: 0;
}

.kw-directions-travel__fact-card-label {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	text-transform: uppercase;
	letter-spacing: var(--kwl-ls-wider);
	color: var(--kwl-text-muted, #718096);
	font-weight: var(--kwl-fw-semibold);
}

.kw-directions-travel__fact-card-value {
	line-height: var(--kwl-lh-prose);
}

/* Standalone Fact-Card (Taxi-Kosten ohne umgebenden Grid) */
.kw-directions-travel__fact-card--taxi {
	margin: var(--kwl-space-md, 1rem) 0;
}

/* --- 8. Tip Cards — Icon-Kreis + farbige Akzente --- */
.kw-directions-travel__tips {
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-md, 1rem);
	margin-top: var(--kwl-space-md, 1rem);
}

/* --- 8b. Tips Toggle (klappbare Hinweise-Gruppe) --- */
.kw-directions-travel__tips-toggle {
	interpolate-size: allow-keywords;
	margin-top: var(--kwl-space-lg, 1.5rem);
	margin-bottom: var(--kwl-space-md, 1rem);
}

.kw-directions-travel__tips-summary {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	list-style: none;
	cursor: pointer;
	min-height: 44px;
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-md, 1rem);
	border-radius: var(--kwl-radius-md, 8px);
	background: color-mix(in srgb, var(--kwl-text, #1a202c) 3%, transparent);
	border: 1px solid var(--kwl-travel-card-border);
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-text-muted, #718096);
	font-size: var(--kwl-fsize-small, 0.875rem);
	transition: background 200ms ease;
}

.kw-directions-travel__tips-summary::-webkit-details-marker {
	display: none;
}

.kw-directions-travel__tips-summary::marker {
	content: '';
}

.kw-directions-travel__tips-summary::after {
	content: '';
	display: block;
	width: 9px;
	height: 9px;
	border-right: 2px solid var(--kwl-text-muted, #718096);
	border-bottom: 2px solid var(--kwl-text-muted, #718096);
	transform: rotate(-45deg);
	transition: transform 300ms var(--kwl-ease-default);
	flex-shrink: 0;
	margin-left: auto;
}

.kw-directions-travel__tips-toggle[open] > .kw-directions-travel__tips-summary::after {
	transform: rotate(45deg);
}

.kw-directions-travel__tips-summary:focus-visible {
	outline: 3px solid var(--kwl-focus, #7B6835);
	outline-offset: 2px;
}

@media (hover: hover) {
	.kw-directions-travel__tips-summary:hover {
		background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 8%, transparent);
	}
}

.kw-directions-travel__tips-toggle::details-content {
	block-size: 0;
	overflow: hidden;
	opacity: 0;
	transition:
		block-size 400ms ease,
		opacity 400ms ease,
		content-visibility 400ms ease allow-discrete;
}

.kw-directions-travel__tips-toggle[open]::details-content {
	block-size: auto;
	opacity: 1;
}

@starting-style {
	.kw-directions-travel__tips-toggle[open]::details-content {
		block-size: 0;
		opacity: 0;
	}
}

.kw-directions-travel__tips-toggle[open] > .kw-directions-travel__tips-summary {
	margin-bottom: var(--kwl-space-sm, 0.5rem);
}

.kw-directions-travel__tip {
	display: flex;
	align-items: flex-start;
	gap: var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-md, 1rem);
	border-radius: var(--kwl-radius-md, 8px);
	background: var(--kwl-bg-alt, #f7fafc);
	border: 1px solid var(--kwl-travel-card-border);
	border-left: 3px solid var(--kwl-travel-card-border);
	transition: box-shadow var(--kwl-transition, 200ms ease);
}

.kw-directions-travel__tip--info {
	border-left-color: var(--kwl-primary, #00315d);
	background: color-mix(in srgb, var(--kwl-primary, #00315d) 4%, var(--kwl-travel-card-bg));
}

.kw-directions-travel__tip--warning {
	border-left-color: var(--kwl-warning, #c05621);
	background: color-mix(in srgb, var(--kwl-warning, #c05621) 4%, var(--kwl-travel-card-bg));
}

.kw-directions-travel__tip--tip {
	border-left-color: var(--kwl-accent, #BD9B5C);
	background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 6%, var(--kwl-travel-card-bg));
}

.kw-directions-travel__tip-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	flex-shrink: 0;
	margin-top: 1px;
	border-radius: var(--kwl-radius-full, 9999px);
}

.kw-directions-travel__tip-icon svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

.kw-directions-travel__tip--info .kw-directions-travel__tip-icon {
	color: var(--kwl-primary, #00315d);
	background: color-mix(in srgb, var(--kwl-primary, #00315d) 12%, transparent);
}

.kw-directions-travel__tip--warning .kw-directions-travel__tip-icon {
	color: var(--kwl-warning, #c05621);
	background: color-mix(in srgb, var(--kwl-warning, #c05621) 12%, transparent);
}

.kw-directions-travel__tip--tip .kw-directions-travel__tip-icon {
	color: var(--kwl-accent, #BD9B5C);
	background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 12%, transparent);
}

.kw-directions-travel__tip-label {
	font-weight: var(--kwl-fw-semibold);
	white-space: nowrap;
}

/* --- 9. Station Cards — Glassmorphism Mini-Cards --- */
.kw-directions-travel__station-card {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-md, 1rem);
	background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 5%, var(--kwl-travel-card-bg));
	border-radius: var(--kwl-radius-md, 8px);
	border: 1px solid color-mix(in srgb, var(--kwl-accent, #BD9B5C) 15%, var(--kwl-travel-card-border));
	margin-bottom: var(--kwl-space-sm, 0.5rem);
	transition: box-shadow var(--kwl-transition, 200ms ease);
}

@media (hover: hover) {
	.kw-directions-travel__station-card:hover {
		box-shadow: var(--kwl-shadow-md);
	}
}

.kw-directions-travel__station-info {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-width: 0;
}

.kw-directions-travel__station-label {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	text-transform: uppercase;
	letter-spacing: var(--kwl-ls-wider);
	color: var(--kwl-text-muted, #718096);
	font-weight: var(--kwl-fw-semibold);
}

.kw-directions-travel__station-name {
	font-weight: var(--kwl-fw-semibold);
}

.kw-directions-travel__station-distance {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 2px;
	flex-shrink: 0;
}

.kw-directions-travel__iata-badge {
	display: inline-flex;
	align-items: center;
	font-size: var(--kwl-fsize-caption, 0.75rem);
	font-weight: var(--kwl-fw-bold);
	padding: 2px 8px;
	border-radius: var(--kwl-radius-sm, 4px);
	background: color-mix(in srgb, var(--kwl-travel-btn-bg) 12%, transparent);
	color: var(--kwl-travel-btn-bg);
	letter-spacing: var(--kwl-ls-wider);
}

/* --- 10. Distance Badge --- */
.kw-directions-travel__distance-badge {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	font-size: var(--kwl-fsize-small, 0.875rem);
	font-weight: var(--kwl-fw-semibold);
	font-variant-numeric: tabular-nums;
	padding: 2px 10px;
	border-radius: var(--kwl-radius-full, 9999px);
	background: color-mix(in srgb, var(--kwl-text-muted, #718096) 12%, transparent);
	color: var(--kwl-text-muted, #718096);
	white-space: nowrap;
}

.kw-directions-travel__walking-time {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	color: var(--kwl-text-muted, #718096);
	white-space: nowrap;
}

/* --- 11. Hint / Pickup --- */
.kw-directions-travel__hint {
	margin-top: var(--kwl-space-sm, 0.5rem);
}

.kw-directions-travel__hint-label {
	display: block;
	font-weight: var(--kwl-fw-semibold);
	font-size: var(--kwl-fsize-small, 0.875rem);
	color: var(--kwl-text-muted, #718096);
	margin-bottom: var(--kwl-space-xs, 0.25rem);
}

.kw-directions-travel__hint-text {
	margin: 0;
	line-height: var(--kwl-lh-prose);
}

.kw-directions-travel__pickup {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	margin-top: var(--kwl-space-sm, 0.5rem);
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-md, 1rem);
	background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 10%, transparent);
	border-radius: var(--kwl-radius-md, 8px);
	border: 1px solid color-mix(in srgb, var(--kwl-accent, #BD9B5C) 20%, transparent);
}

.kw-directions-travel__pickup-badge {
	font-weight: var(--kwl-fw-bold);
	font-size: var(--kwl-fsize-small, 0.875rem);
	color: var(--kwl-travel-icon-color);
	white-space: nowrap;
}

/* --- 12. Taxi Button — delegiert an [data-kwl-btn="gradient"] --- */
.kw-directions-travel [data-kwl-btn="gradient"] {
	--kwl-btn-bg: var(--kwl-travel-btn-bg, var(--kwl-accent, #BD9B5C));
	--kwl-btn-color: var(--kwl-travel-btn-color, var(--kwl-btn-text, #ffffff));
}

.kw-directions-travel__taxi-btn {
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-lg, 1.5rem);
	min-height: 44px;
	margin-bottom: var(--kwl-space-sm, 0.5rem);
	font-size: var(--kwl-fsize-body, 1rem);
}

.kw-directions-travel__taxi-btn svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

/* --- 13. Focus --- */
.kw-directions-travel__station-card:focus-within {
	outline: 3px solid var(--kwl-focus, #7B6835);
	outline-offset: 2px;
}

/* --- 14. Delight — Micro-Interactions --- */

/* Section-Icon Gold-Glow: dezenter Puls bei Header-Hover */
@keyframes kwl-travel-icon-glow {
	0%, 100% {
		box-shadow: 0 0 0 0 rgba(189, 155, 92, 0);
	}

	50% {
		box-shadow: 0 0 10px 2px rgba(189, 155, 92, 0.25);
	}
}

@media (hover: hover) {
	.kw-directions-travel__section-header:hover [data-kwl-icon-circle] {
		animation: kwl-travel-icon-glow 800ms ease;
	}

	/* Station-Card Gold-Glow auf Hover */
	.kw-directions-travel__station-card:hover {
		box-shadow: var(--kwl-shadow-md), 0 0 12px 0 rgba(189, 155, 92, 0.12);
	}

	/* Tip-Card Border-Slide: 3px → 4px mit Transition */
	.kw-directions-travel__tip {
		transition: box-shadow var(--kwl-transition, 200ms ease), border-left-width 200ms ease;
	}

	.kw-directions-travel__tip:hover {
		border-left-width: 4px;
	}

	/* Taxi-Icon dezente Rotation bei Button-Hover */
	.kw-directions-travel__taxi-btn:hover svg {
		transform: rotate(8deg) scale(1.05);
		transition: transform 250ms ease;
	}

	.kw-directions-travel__taxi-btn svg {
		transition: transform 250ms ease;
	}

	/* Distance-Badge Gold-Shift bei Station-Card-Hover */
	.kw-directions-travel__station-card:hover .kw-directions-travel__distance-badge {
		background: color-mix(in srgb, var(--kwl-accent, #BD9B5C) 15%, transparent);
		color: var(--kwl-accent, #BD9B5C);
		transition: background 300ms ease, color 300ms ease;
	}
}

/* Gold-Gradient auf Section-Trennlinien */
.kw-directions-travel__section {
	border-image: linear-gradient(to right, var(--kwl-accent, #BD9B5C) 0%, transparent 100%) 1;
	border-image-width: 0 0 1px 0;
}

.kw-directions-travel__section:last-of-type {
	border-image: none;
}

/* --- 15. Collapsible Sections (§316) --- */

.kw-directions-travel__collapsible {
	interpolate-size: allow-keywords;
}

.kw-directions-travel__collapsible > summary {
	list-style: none;
	cursor: pointer;
	min-height: 44px;
	border-radius: var(--kwl-radius-md, 8px);
	padding: var(--kwl-space-xs, 0.25rem);
	transition: background 200ms ease;
}

.kw-directions-travel__collapsible > summary::-webkit-details-marker {
	display: none;
}

.kw-directions-travel__collapsible > summary::marker {
	content: '';
}

.kw-directions-travel__collapsible > summary::after {
	content: '';
	display: block;
	width: 10px;
	height: 10px;
	border-right: 2px solid var(--kwl-text-muted, #718096);
	border-bottom: 2px solid var(--kwl-text-muted, #718096);
	transform: rotate(-45deg);
	transition: transform 300ms var(--kwl-ease-default);
	flex-shrink: 0;
	margin-left: auto;
}

.kw-directions-travel__collapsible[open] > summary::after {
	transform: rotate(45deg);
}

.kw-directions-travel__collapsible > summary:focus-visible {
	outline: 3px solid var(--kwl-focus, #7B6835);
	outline-offset: 2px;
}

@media (hover: hover) {
	.kw-directions-travel__collapsible > summary:hover {
		background: color-mix(in srgb, var(--kwl-text, #1a202c) 4%, transparent);
	}
}

.kw-directions-travel__collapsible:not([open]) > summary {
	margin-bottom: 0;
}

.kw-directions-travel__collapsible::details-content {
	block-size: 0;
	overflow: hidden;
	opacity: 0;
	transition:
		block-size 400ms ease,
		opacity 400ms ease,
		content-visibility 400ms ease allow-discrete;
}

.kw-directions-travel__collapsible[open]::details-content {
	block-size: auto;
	opacity: 1;
}

@starting-style {
	.kw-directions-travel__collapsible[open]::details-content {
		block-size: 0;
		opacity: 0;
	}
}

/* --- 16. Dark Mode --- */
@media (prefers-color-scheme: dark) {
	.kw-directions-travel {
		--kwl-travel-icon-color: var(--kwl-accent, #d4b87a);
		--kwl-travel-btn-bg: var(--kwl-primary, #63b3ed);
	}

	.kw-directions-travel__tip {
		border-color: color-mix(in srgb, var(--kwl-border, #4a5568) 60%, transparent);
	}

	.kw-directions-travel__tip--info {
		background: color-mix(in srgb, var(--kwl-primary, #63b3ed) 6%, var(--kwl-bg, #1a202c));
		border-left-color: var(--kwl-primary, #63b3ed);
	}

	.kw-directions-travel__tip--warning {
		background: color-mix(in srgb, var(--kwl-warning, #c05621) 6%, var(--kwl-bg, #1a202c));
	}

	.kw-directions-travel__tip--tip {
		background: color-mix(in srgb, var(--kwl-accent, #d4b87a) 6%, var(--kwl-bg, #1a202c));
	}

	.kw-directions-travel__station-card,
	.kw-directions-travel__fact-card {
		background: color-mix(in srgb, var(--kwl-accent, #d4b87a) 5%, var(--kwl-bg, #1a202c));
		border-color: color-mix(in srgb, var(--kwl-accent, #d4b87a) 12%, var(--kwl-border, #4a5568));
	}

	.kw-directions-travel__distance-badge {
		background: color-mix(in srgb, var(--kwl-bg-alt, #2d3748) 60%, transparent);
	}

	.kw-directions-travel__fact:nth-child(even) {
		background: color-mix(in srgb, var(--kwl-text, #f7fafc) 3%, var(--kwl-bg, #1a202c));
	}

	.kw-directions__image-link:focus-visible {
		outline-color: var(--kwl-focus, #c9a84c);
	}

	.kw-directions-travel__collapsible > summary::after {
		border-color: var(--kwl-text-muted, #a0aec0);
	}

	.kw-directions-travel__collapsible > summary:focus-visible {
		outline-color: var(--kwl-focus, #c9a84c);
	}

	.kw-directions-travel__tips-summary {
		border-color: var(--kwl-border, #4a5568);
		background: color-mix(in srgb, var(--kwl-bg-alt, #2d3748) 60%, transparent);
		color: var(--kwl-text-muted, #a0aec0);
	}

	.kw-directions-travel__tips-summary::after {
		border-color: var(--kwl-text-muted, #a0aec0);
	}

	.kw-directions-travel__tips-summary:focus-visible {
		outline-color: var(--kwl-focus, #c9a84c);
	}
}

/* --- 16. Scroll-Reveal (shared keyframe aus frontend.css) --- */
@supports (animation-timeline: view()) {
	.kw-directions-travel__section {
		animation: kwl-reveal-up-subtle linear both;
		animation-timeline: view();
		animation-range: entry 10% entry 60%;
	}
}

/* --- 17. Reduced Motion --- */
@media (prefers-reduced-motion: reduce) {
	.kw-directions-travel__station-card,
	.kw-directions-travel__fact-card,
	.kw-directions-travel__tip,
	.kw-directions__image-link,
	.kw-directions__image,
	.kw-directions-travel__taxi-btn svg {
		transition: none;
	}

	.kw-directions__image-link:hover .kw-directions__image {
		transform: none;
	}

	.kw-directions-travel__section-header:hover [data-kwl-icon-circle] {
		animation: none;
	}

	.kw-directions-travel__taxi-btn:hover svg {
		transform: none;
	}

	@supports (animation-timeline: view()) {
		.kw-directions-travel__section {
			animation: none;
		}
	}

	.kw-directions-travel__collapsible > summary,
	.kw-directions-travel__collapsible > summary::after {
		transition: none;
	}

	.kw-directions-travel__collapsible::details-content {
		transition: none;
	}

	.kw-directions-travel__tips-summary,
	.kw-directions-travel__tips-summary::after {
		transition: none;
	}

	.kw-directions-travel__tips-toggle::details-content {
		transition: none;
	}
}

/* --- 18. Container Queries --- */
@container travel-section (min-width: 420px) {
	.kw-directions-travel__fact {
		display: grid;
		grid-template-columns: 12ch 1fr;
	}
}

@container travel-section (min-width: 560px) {
	.kw-directions-travel__facts-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
