/* ==========================================================================
   DirectionsParking Widget — Parken & Parkplätze
   Premium Card: Hover-Lift, Icon-Kreise, Container Queries, Scroll-Reveal
   ========================================================================== */

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

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

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

/* --- 3. Titel --- */
.kw-directions-parking__title {
	color: var(--kwl-parking-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);
}

.kw-directions-parking__intro {
	margin-bottom: var(--kwl-space-md, 1rem);
	line-height: var(--kwl-lh-prose);
}

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

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

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

.kw-directions-parking__section-heading {
	color: var(--kwl-parking-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);
}

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

.kw-directions-parking__section-body {
	container-type: inline-size;
	container-name: parking-section;
}

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

.kw-directions-parking__section-icon--inline {
	--kwl-icon-size: 28px;
	--kwl-icon-svg-size: 16px;
}

/* --- 6. Parking Grid — Icon-Card-Layout --- */
.kw-directions-parking__directions {
	margin: 0 0 var(--kwl-space-lg, 1.5rem);
	color: var(--kwl-text-muted, #718096);
	line-height: var(--kwl-lh-prose);
}

.kw-directions-parking__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--kwl-space-sm, 0.5rem);
}

.kw-directions-parking__item {
	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-parking-card-bg));
	border: 1px solid color-mix(in srgb, var(--kwl-accent, #BD9B5C) 15%, var(--kwl-parking-card-border));
	border-radius: var(--kwl-radius-md, 8px);
	min-height: 44px;
	transition: box-shadow var(--kwl-transition, 200ms ease);
}

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

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

.kw-directions-parking__item-value {
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-parking-heading-color);
}

.kw-directions-parking__ev-badge {
	font-size: var(--kwl-fsize-small, 0.875rem);
	color: var(--kwl-text-muted, #718096);
}

/* --- 7. Public Parking Cards --- */
.kw-directions-parking__public-list {
	display: flex;
	flex-direction: column;
	gap: var(--kwl-space-sm, 0.5rem);
}

.kw-directions-parking__public-card {
	padding: var(--kwl-space-sm, 0.5rem) var(--kwl-space-md, 1rem);
	background: var(--kwl-bg-alt, #f7fafc);
	border-radius: var(--kwl-radius-md, 8px);
	border: 1px solid var(--kwl-parking-card-border);
	transition: box-shadow var(--kwl-transition, 200ms ease), transform var(--kwl-transition, 200ms ease);
}

@media (hover: hover) {
	.kw-directions-parking__public-card:hover {
		box-shadow: var(--kwl-shadow-md);
		transform: translateY(-2px);
	}
}

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

.kw-directions-parking__public-card-name {
	--kwl-link-color: var(--kwl-primary, #00315d);
	--kwl-link-hover-color: var(--kwl-primary, #00315d);
	font-weight: var(--kwl-fw-semibold);
}

@media (hover: hover) {
	a.kw-directions-parking__public-card-name:hover {
		text-decoration: underline;
		text-underline-offset: 2px;
	}
}

a.kw-directions-parking__public-card-name:focus-visible {
	outline: 3px solid var(--kwl-focus, #7B6835);
	outline-offset: 2px;
	border-radius: 2px;
}

.kw-directions-parking__type-badge {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	font-size: var(--kwl-fsize-caption, 0.75rem);
	padding: 2px 10px;
	border-radius: var(--kwl-radius-full, 9999px);
	background: color-mix(in srgb, var(--kwl-parking-icon-color) 15%, transparent);
	color: var(--kwl-parking-icon-color);
	font-weight: var(--kwl-fw-semibold);
}

.kw-directions-parking__public-card-body {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	margin-top: var(--kwl-space-xs, 0.25rem);
	font-size: var(--kwl-fsize-small, 0.875rem);
	color: var(--kwl-text-muted, #718096);
}

/* --- 8. Distance Badge --- */
.kw-directions-parking__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;
}

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

/* Section-Icon Gold-Glow */
@keyframes kwl-parking-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-parking__section-header:hover [data-kwl-icon-circle] {
		animation: kwl-parking-icon-glow 800ms ease;
	}

	/* Parking-Item Gold border-top auf Hover */
	.kw-directions-parking__item {
		border-top: 2px solid transparent;
		transition: box-shadow var(--kwl-transition, 200ms ease), border-top-color 250ms ease;
	}

	.kw-directions-parking__item:hover {
		border-top-color: var(--kwl-accent, #BD9B5C);
	}

	/* Public-Card Gold-Glow */
	.kw-directions-parking__public-card:hover {
		box-shadow: var(--kwl-shadow-md), 0 0 12px 0 rgba(189, 155, 92, 0.1);
	}
}

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

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

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

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

.kw-directions-parking__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-parking__collapsible > summary::-webkit-details-marker {
	display: none;
}

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

.kw-directions-parking__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-parking__collapsible[open] > summary::after {
	transform: rotate(45deg);
}

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

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

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

.kw-directions-parking__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-parking__collapsible[open]::details-content {
	block-size: auto;
	opacity: 1;
}

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

/* --- 11. Dark Mode --- */
@media (prefers-color-scheme: dark) {
	.kw-directions-parking {
		--kwl-parking-icon-color: var(--kwl-accent, #d4b87a);
	}

	.kw-directions-parking__item {
		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-parking__public-card {
		background: color-mix(in srgb, var(--kwl-bg-alt, #2d3748) 80%, transparent);
	}

	.kw-directions-parking__public-card-name {
		--kwl-link-color: var(--kwl-primary, #63b3ed);
		--kwl-link-hover-color: var(--kwl-primary, #63b3ed);
	}

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

	a.kw-directions-parking__public-card-name:focus-visible {
		outline-color: var(--kwl-focus, #c9a84c);
	}

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

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

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

/* --- 12. Reduced Motion --- */
@media (prefers-reduced-motion: reduce) {
	.kw-directions-parking__item,
	.kw-directions-parking__public-card {
		transition: none;
	}

	.kw-directions-parking__public-card:hover {
		transform: none;
	}

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

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

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

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

/* --- 13. Hotel-Layout (Kosten + Bild nebeneinander) --- */
.kw-directions-parking__hotel-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--kwl-space-lg, 1.5rem);
	margin-top: var(--kwl-space-lg, 1.5rem);
}

.kw-directions-parking__hotel-info {
	min-width: 0;
}

.kw-directions-parking__hotel-media {
	min-width: 0;
}

/* Entferne das globale Section-Image-Margin, wenn in Hotel-Layout eingebettet */
.kw-directions-parking__hotel-media .kw-directions__section-image {
	margin: 0;
	width: 100%;
	max-width: none;
}

/* --- 14. Container Queries --- */
@container parking-section (min-width: 400px) {
	.kw-directions-parking__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@container parking-section (min-width: 640px) {
	.kw-directions-parking__hotel-layout {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		align-items: start;
	}

	.kw-directions-parking__hotel-layout .kw-directions-parking__grid {
		grid-template-columns: 1fr;
	}
}

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