/* ==========================================================================
   DirectionsNearby Widget — Umgebung & Sehenswürdigkeiten
   Premium Card: Hover-Lift, Icon-Kreise, Card-Hover, Container Queries
   ========================================================================== */

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

/* --- 2. Card Container (base via [data-kwl-card]) --- */
.kw-directions-nearby[data-kwl-card] {
	--kwl-card-bg: var(--kwl-nearby-card-bg, var(--kwl-bg, #ffffff));
	--kwl-card-border: var(--kwl-nearby-card-border, var(--kwl-border, #e2e8f0));
	--kwl-card-accent: var(--kwl-nearby-card-accent, var(--kwl-accent, #BD9B5C));
}

.kw-directions-nearby {
	padding: var(--kwl-space-lg, 1.5rem);
	color: var(--kwl-text, #1a202c);
}

/* --- 3. Titel --- */
.kw-directions-nearby__title {
	color: var(--kwl-nearby-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-nearby__intro {
	margin-bottom: var(--kwl-space-lg, 1.5rem);
	line-height: var(--kwl-lh-prose);
}

/* --- 4. Waypoint Grid --- */
.kw-directions-nearby__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--kwl-space-sm, 0.5rem);
	container-type: inline-size;
	container-name: nearby-grid;
}

/* --- 4b. Category Group --- */
.kw-directions-nearby__group {
	margin-bottom: var(--kwl-space-lg, 1.5rem);
}

.kw-directions-nearby__group:last-child {
	margin-bottom: 0;
}

.kw-directions-nearby__group-heading {
	display: flex;
	align-items: center;
	gap: var(--kwl-space-sm, 0.5rem);
	font-family: var(--kwl-font-heading);
	font-size: var(--kwl-fsize-body, 1rem);
	font-weight: var(--kwl-fw-semibold);
	color: var(--kwl-text, #1a202c);
	margin: 0 0 var(--kwl-space-sm, 0.5rem);
	padding-bottom: var(--kwl-space-xs, 0.25rem);
	border-bottom: 1px solid var(--kwl-border, #e2e8f0);
}

.kw-directions-nearby__group-heading [data-kwl-icon-circle] {
	--kwl-icon-size: 28px;
	--kwl-icon-svg-size: 14px;
}

/* --- 5. Waypoint Card --- */
.kw-directions-nearby__waypoint {
	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: var(--kwl-bg-alt, #f7fafc);
	border-radius: var(--kwl-radius-md, 8px);
	border: 1px solid var(--kwl-nearby-card-border);
	min-height: 52px;
	transition: box-shadow var(--kwl-transition, 200ms ease), transform var(--kwl-transition, 200ms ease);
}

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

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

/* --- 7. Waypoint Info --- */
.kw-directions-nearby__waypoint-info {
	flex: 1;
	min-width: 0;
}

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

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

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

.kw-directions-nearby__waypoint-category {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	color: var(--kwl-text-muted, #718096);
	text-transform: uppercase;
	letter-spacing: var(--kwl-ls-wide);
	font-weight: var(--kwl-fw-medium);
}

/* --- 8. Distance --- */
.kw-directions-nearby__waypoint-distance {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 2px;
	flex-shrink: 0;
}

.kw-directions-nearby__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-nearby__walking-time {
	font-size: var(--kwl-fsize-caption, 0.75rem);
	color: var(--kwl-text-muted, #718096);
	white-space: nowrap;
}

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

@media (hover: hover) {
	/* Icon-Circle Brightening bei Waypoint-Hover */
	.kw-directions-nearby__waypoint:hover [data-kwl-icon-circle] {
		box-shadow: 0 0 10px 2px rgba(189, 155, 92, 0.2);
		transition: box-shadow 300ms ease;
	}

	/* Distance-Badge Gold-Shift bei Waypoint-Hover */
	.kw-directions-nearby__waypoint:hover .kw-directions-nearby__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;
	}

	/* Walking-Time Gold-Tint */
	.kw-directions-nearby__waypoint:hover .kw-directions-nearby__walking-time {
		color: var(--kwl-accent, #BD9B5C);
		transition: color 300ms ease;
	}
}

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

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

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

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

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

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

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

.kw-directions-nearby__collapsible:not([open]) {
	margin-bottom: var(--kwl-space-xs, 0.25rem);
}

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

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

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

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

	.kw-directions-nearby__group-heading {
		color: var(--kwl-text, #f7fafc);
		border-bottom-color: var(--kwl-border, #4a5568);
	}

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

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

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

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

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

/* --- 11. Scroll-Reveal (shared keyframe aus frontend.css) --- */
@supports (animation-timeline: view()) {
	.kw-directions-nearby__waypoint {
		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-nearby__waypoint,
	.kw-directions-nearby__waypoint [data-kwl-icon-circle],
	.kw-directions-nearby__distance-badge,
	.kw-directions-nearby__walking-time {
		transition: none;
	}

	.kw-directions-nearby__waypoint:hover {
		transform: none;
	}

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

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

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

/* --- 13. Container Queries --- */
@container nearby-grid (min-width: 480px) {
	.kw-directions-nearby__grid {
		grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	}
}

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