/**
 * Frontend-Styling für „WOBtalk Zahlen".
 *
 * Farb-Variablen (--wbz-*) kommen zur Laufzeit aus den Einstellungen (inline-Block).
 * Hier: Bühne/Rahmen, Layout (Titel + Stat-Zeilen links, Karte rechts), die 7
 * Darstellungsstile (Akzent links neben der Zahl) und die Karte.
 *
 * Animation: das JS treibt pro Kennzahl nur --wbz-fortschritt (0..1); jeder Stil
 * leitet seine Füllung daraus ab. Standard 1 (voll) → ohne JS / reduced-motion fertig.
 *
 * Schrift: Open Sans (Theme-Font, kein externer Aufruf, DSGVO).
 */

.wbz-zahlen {
	--wbz-font: "Open Sans", "Helvetica Neue", Arial, sans-serif;
	font-family: var(--wbz-font);
	color: var(--wbz-dunkel, #3a3a3a);
	padding: clamp(1rem, 3vw, 2.5rem);
	box-sizing: border-box;
}

.wbz-zahlen *,
.wbz-zahlen *::before,
.wbz-zahlen *::after {
	box-sizing: border-box;
}

/* ---- Bühne: rahmt Kennzahlen + Karte als eine Einheit ---- */

.wbz-zahlen__inner {
	max-width: 1280px;
	margin-inline: auto;
	display: grid;
	grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
	gap: clamp(1.5rem, 3.5vw, 3.5rem);
	align-items: stretch;
}

.wbz-zahlen__haupt {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: clamp(1.5rem, 3vw, 2.4rem);
}

.wbz-zahlen__titel {
	margin: 0;
	font-size: clamp(1.9rem, 3.2vw, 2.8rem);
	font-weight: 800;
	letter-spacing: -0.01em;
	line-height: 1.05;
}

.wbz-zahlen__akzent {
	color: var(--wbz-blau, #0a64b4);
}

.wbz-zahlen__karte {
	display: flex;
	align-items: center;
}

.wbz-zahlen__karte > .wbz-karte {
	width: 100%;
}

.wbz-zahlen__kennzahlen {
	display: flex;
	flex-direction: column;
	gap: clamp(1.1rem, 2.4vw, 1.9rem);
}

@media (max-width: 860px) {
	.wbz-zahlen__inner {
		grid-template-columns: 1fr;
	}

	/* Mobil: Überschrift und die 3 Kennzahlen über der Karte zentrieren. */
	.wbz-zahlen__haupt {
		text-align: center;
	}

	.wbz-zahlen__kennzahlen {
		align-self: stretch;
	}

	.wbz-kennzahl {
		justify-content: center;
	}
}

/* ---- Eine Kennzahl als Stat-Zeile: Akzent links, Zahl + Label rechts ---- */

.wbz-kennzahl {
	--wbz-fortschritt: 1;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: clamp(0.9rem, 2vw, 1.4rem);
	text-align: left;
}

.wbz-zahlen__kennzahlen .wbz-kennzahl + .wbz-kennzahl {
	border-top: 1px solid color-mix(in srgb, var(--wbz-dunkel, #3a3a3a) 12%, transparent);
	padding-top: clamp(1.1rem, 2.4vw, 1.9rem);
}

.wbz-kennzahl__grafik {
	position: relative;
	flex: 0 0 auto;
	width: 60px;
	height: 60px;
	display: grid;
	place-items: center;
}

/* Säulen-Akzente (pur/balken/digital) sind schmal → enger an die Zahl rücken. */
.wbz-kennzahl__grafik:has(.wbz-kennzahl__saeule) {
	width: 22px;
}

.wbz-kennzahl__text {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.wbz-kennzahl__praefix {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wbz-dunkel, #3a3a3a);
	opacity: 0.5;
	margin-bottom: 0.15rem;
}

.wbz-kennzahl__wert {
	font-size: clamp(2.1rem, 3.4vw, 3rem);
	font-weight: 800;
	line-height: 1;
	color: var(--wbz-dunkel, #3a3a3a);
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.wbz-kennzahl__label {
	margin-top: 0.2rem;
	font-weight: 800;
	font-size: clamp(0.9rem, 1.3vw, 1.05rem);
	color: var(--wbz-blau, #0a64b4);
}

/* ---- Akzent: Säule (pur / balken / digital) ---- */

.wbz-kennzahl__saeule {
	position: relative;
	width: 10px;
	height: 56px;
	border-radius: 6px;
	overflow: hidden;
	background: color-mix(in srgb, var(--wbz-dunkel, #3a3a3a) 12%, transparent);
}

.wbz-kennzahl__saeule-fill {
	position: absolute;
	inset: 0;
	background: var(--wbz-blau, #0a64b4);
	transform: scaleY(var(--wbz-fortschritt));
	transform-origin: bottom;
}

.wbz-kennzahl__saeule--duenn {
	width: 5px;
}

.wbz-kennzahl__saeule--digital .wbz-kennzahl__saeule-fill {
	background: linear-gradient(0deg, var(--wbz-blau, #0a64b4), color-mix(in srgb, var(--wbz-blau, #0a64b4) 55%, #fff));
	box-shadow: 0 0 8px color-mix(in srgb, var(--wbz-blau, #0a64b4) 55%, transparent);
}

.wbz-kennzahl__saeule--digital::after {
	content: "";
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(0deg, transparent 0 7px, rgba(255, 255, 255, 0.85) 7px 9px);
	pointer-events: none;
}

/* ---- Akzent: RING / ORBIT ---- */

.wbz-kennzahl__ring-svg {
	width: 100%;
	height: 100%;
	transform: rotate(-90deg);
}

.wbz-kennzahl__ring-track,
.wbz-kennzahl__ring-fill {
	fill: none;
	stroke-width: 8;
}

.wbz-kennzahl__ring-track {
	stroke: var(--wbz-dunkel, #3a3a3a);
	opacity: 0.12;
}

.wbz-kennzahl__ring-fill {
	stroke: var(--wbz-blau, #0a64b4);
	stroke-linecap: round;
	stroke-dasharray: 339.292;
	stroke-dashoffset: calc(339.292px * (1 - var(--wbz-fortschritt)));
}

.wbz-kennzahl__orbit-bahn {
	position: absolute;
	inset: 0;
	animation: wbz-orbit 6s linear infinite;
}

.wbz-kennzahl__orbit-dot {
	position: absolute;
	top: -2px;
	left: 50%;
	width: 10px;
	height: 10px;
	margin-left: -5px;
	border-radius: 50%;
	background: var(--wbz-pin, #d4242a);
	box-shadow: 0 0 8px var(--wbz-pin, #d4242a);
}

@keyframes wbz-orbit {
	to {
		transform: rotate(360deg);
	}
}

/* ---- Akzent: TACHO ---- */

.wbz-kennzahl__tacho-svg {
	width: 100%;
	height: auto;
}

.wbz-kennzahl__tacho-track,
.wbz-kennzahl__tacho-fill {
	fill: none;
	stroke-width: 10;
	stroke-linecap: round;
}

.wbz-kennzahl__tacho-track {
	stroke: var(--wbz-dunkel, #3a3a3a);
	opacity: 0.12;
}

.wbz-kennzahl__tacho-fill {
	stroke: var(--wbz-blau, #0a64b4);
	stroke-dasharray: 163.363;
	stroke-dashoffset: calc(163.363px * (1 - var(--wbz-fortschritt)));
}

/* ---- Akzent: SIGNAL ---- */

.wbz-kennzahl__signal {
	display: flex;
	align-items: flex-end;
	gap: 5px;
	height: 56px;
}

.wbz-kennzahl__signal-bar {
	--d: calc(var(--wbz-stufe) * 0.15);
	width: 8px;
	border-radius: 3px;
	background: var(--wbz-blau, #0a64b4);
	transform: scaleY( clamp(0, calc( (var(--wbz-fortschritt) - var(--d)) / (1 - var(--d)) ), 1) );
	transform-origin: bottom;
}

.wbz-kennzahl__signal-bar:nth-child(1) { height: 32%; }
.wbz-kennzahl__signal-bar:nth-child(2) { height: 49%; }
.wbz-kennzahl__signal-bar:nth-child(3) { height: 66%; }
.wbz-kennzahl__signal-bar:nth-child(4) { height: 83%; }
.wbz-kennzahl__signal-bar:nth-child(5) { height: 100%; }

@media (prefers-reduced-motion: reduce) {
	.wbz-kennzahl__orbit-bahn {
		animation: none;
	}
}

/* ---- Eintritts-Animation ---- */

@media (prefers-reduced-motion: no-preference) {
	.wbz-kennzahl {
		opacity: 0;
		transform: translateY(14px);
		transition: opacity 0.6s ease, transform 0.6s ease;
		transition-delay: calc(var(--wbz-index, 0) * 130ms);
	}

	.wbz-kennzahl.wbz-sichtbar {
		opacity: 1;
		transform: none;
	}
}

.wbz-zahlen__leer {
	color: var(--wbz-dunkel, #3a3a3a);
	opacity: 0.7;
}

/* ---- Karten-Platzhalter ---- */

.wbz-karte-platzhalter {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 260px;
	border: 2px dashed color-mix(in srgb, var(--wbz-dunkel, #3a3a3a) 20%, transparent);
	border-radius: 14px;
	color: var(--wbz-dunkel, #3a3a3a);
	opacity: 0.7;
	text-align: center;
	padding: 1rem;
}

.wbz-karte-platzhalter__icon {
	font-size: 2.4rem;
	color: var(--wbz-pin, #d4242a);
	line-height: 1;
}

.wbz-karte-platzhalter__text {
	font-weight: 700;
	font-size: 0.95rem;
}

/* ============================ Standortkarte ============================ */

.wbz-karte__buehne {
	position: relative;
	width: 100%;
	/* Feste Höhe aus dem SVG-Seitenverhältnis → der Rahmen umschließt die Karte zuverlässig. */
	aspect-ratio: 1151.6 / 1000;
}

.wbz-karte__svg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: visible;
}

.wbz-karte__land {
	fill: var(--wbz-karte, #d9d9d9);
	stroke: color-mix(in srgb, var(--wbz-dunkel, #3a3a3a) 45%, transparent);
	stroke-width: 1;
	stroke-linejoin: round;
	filter: drop-shadow(6px 10px 10px rgba(0, 0, 0, 0.18));
}

.wbz-karte__pins {
	position: absolute;
	inset: 0;
}

.wbz-karte__pin {
	position: absolute;
}

.wbz-karte__punkt {
	position: absolute;
	transform: translate(-50%, -50%);
	width: 12px;
	height: 12px;
	padding: 0;
	border: 2px solid #fff;
	border-radius: 50%;
	background: var(--wbz-pin, #d4242a);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
	cursor: pointer;
	transition: transform 0.15s ease;
}

.wbz-karte__pin:hover .wbz-karte__punkt,
.wbz-karte__pin:focus-within .wbz-karte__punkt {
	transform: translate(-50%, -50%) scale(1.45);
}

/* Hervorgehobene Städte (Backend: „hervorheben"): größerer Pin, Label bevorzugt. */
.wbz-karte__pin--wichtig .wbz-karte__punkt {
	width: 16px;
	height: 16px;
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--wbz-pin, #d4242a) 25%, transparent), 0 1px 3px rgba(0, 0, 0, 0.35);
}

.wbz-karte__label {
	position: absolute;
	left: 10px;
	top: -0.7em;
	z-index: 2;
	white-space: nowrap;
	font-size: clamp(8px, 0.8vw, 12px);
	font-weight: 700;
	color: var(--wbz-dunkel, #3a3a3a);
	pointer-events: none;
	text-shadow: 0 1px 2px rgba(255, 255, 255, 0.9), 0 0 2px rgba(255, 255, 255, 0.9), 0 0 4px rgba(255, 255, 255, 0.9);
}

.wbz-karte__pin--wichtig .wbz-karte__label {
	font-size: clamp(10px, 0.95vw, 14px);
	font-weight: 800;
	color: var(--wbz-blau, #0a64b4);
}

/* Im Cluster überlappende Labels ausblenden; bei Hover/Fokus zeigen. */
.wbz-karte__label--versteckt {
	opacity: 0;
	visibility: hidden;
}

.wbz-karte__pin:hover .wbz-karte__label--versteckt,
.wbz-karte__pin:focus-within .wbz-karte__label--versteckt {
	opacity: 1;
	visibility: visible;
}

.wbz-karte__tooltip {
	position: absolute;
	left: 12px;
	bottom: 14px;
	z-index: 5;
	min-width: 180px;
	max-width: min(260px, 72vw);
	padding: 0.7rem 0.85rem;
	background: #fff;
	border-radius: 10px;
	border-top: 3px solid var(--wbz-blau, #0a64b4);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.22);
	opacity: 0;
	visibility: hidden;
	transform: translateY(4px);
	transition: opacity 0.15s ease, transform 0.15s ease;
	text-align: left;
}

.wbz-karte__pin:hover .wbz-karte__tooltip,
.wbz-karte__pin:focus-within .wbz-karte__tooltip {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* Tooltip am Rand nach innen öffnen (kein Abschneiden). */
.wbz-karte__pin--rechts .wbz-karte__tooltip {
	left: auto;
	right: 12px;
}

.wbz-karte__pin--oben .wbz-karte__tooltip {
	bottom: auto;
	top: 14px;
}

/* Touch-Geräte: größeres, unsichtbares Tap-Ziel je Pin. */
@media (hover: none) {
	.wbz-karte__punkt::after {
		content: "";
		position: absolute;
		left: 50%;
		top: 50%;
		width: 40px;
		height: 40px;
		transform: translate(-50%, -50%);
		border-radius: 50%;
	}
}

/* Mobile-Optimierung */
@media (max-width: 600px) {
	.wbz-zahlen {
		padding: clamp(0.75rem, 3vw, 1.25rem);
	}

	.wbz-karte__punkt {
		width: 14px;
		height: 14px;
	}

	.wbz-karte__pin--wichtig .wbz-karte__punkt {
		width: 18px;
		height: 18px;
	}

	.wbz-karte__label {
		font-size: 10px;
	}

	/* Auf kleinen Karten nur hervorgehobene Städte dauerhaft beschriften; Rest auf Tipp. */
	.wbz-karte__pin:not(.wbz-karte__pin--wichtig) .wbz-karte__label {
		opacity: 0;
		visibility: hidden;
	}

	.wbz-karte__pin:not(.wbz-karte__pin--wichtig):focus-within .wbz-karte__label {
		opacity: 1;
		visibility: visible;
	}

	/* Tooltip mobil als feste, zentrierte Info-Karte unten – ragt nie aus dem Bild. */
	.wbz-karte__tooltip,
	.wbz-karte__pin--rechts .wbz-karte__tooltip,
	.wbz-karte__pin--oben .wbz-karte__tooltip {
		position: fixed;
		left: 50%;
		right: auto;
		top: auto;
		bottom: 16px;
		width: min(92vw, 340px);
		min-width: 0;
		max-width: none;
		z-index: 1000;
		transform: translate(-50%, 8px);
	}

	.wbz-karte__pin:hover .wbz-karte__tooltip,
	.wbz-karte__pin:focus-within .wbz-karte__tooltip {
		transform: translate(-50%, 0);
	}
}

.wbz-karte__pin:hover,
.wbz-karte__pin:focus-within {
	z-index: 10;
}

.wbz-karte__tooltip-ort {
	display: block;
	font-size: 0.95rem;
	color: var(--wbz-blau, #0a64b4);
	margin-bottom: 0.4rem;
}

.wbz-karte__tooltip-liste {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.55rem;
	max-height: 260px;
	overflow: auto;
}

.wbz-karte__tooltip-shop {
	display: grid;
	font-size: 0.8rem;
	line-height: 1.35;
	color: var(--wbz-dunkel, #3a3a3a);
}

.wbz-karte__tooltip-name {
	font-weight: 700;
}

.wbz-karte__tooltip-tel {
	opacity: 0.75;
}
