/* kj-map.css – Kocher-Jagst Regional · Kartenstil */

/* ── Wrapper & Loading ───────────────────────────────────────────── */
.kj-map-wrap {
	width: 100%;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(30,45,36,0.12);
}

.kj-map-loading {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 120px;
	color: var(--kj-tx2, #4a5e52);
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	gap: 10px;
}
.kj-map-loading::before {
	content: '';
	width: 20px; height: 20px;
	border: 2.5px solid var(--kj-light, #EAE6DE);
	border-top-color: var(--kj-primary, #3D6B4F);
	border-radius: 50%;
	animation: kj-spin 0.7s linear infinite;
}
@keyframes kj-spin { to { transform: rotate(360deg); } }

.kj-map-error {
	display: none;
	padding: 16px;
	background: #fff3cd;
	color: #856404;
	font-size: 13px;
	border-radius: 8px;
	margin-bottom: 12px;
}

/* ── Filter-Buttons ──────────────────────────────────────────────── */
.kj-map-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 16px 20px;
	background: #fff;
	border-bottom: 1px solid var(--kj-light, #EAE6DE);
}

.kj-map-filter {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 6px 14px;
	border-radius: 20px;
	border: 1.5px solid var(--kj-light, #EAE6DE);
	background: #fff;
	color: var(--kj-text, #1E2D24);
	font-family: var(--wp--preset--font-family--body);
	font-size: 12.5px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.15s;
	white-space: nowrap;
}

.kj-map-filter:hover {
	border-color: var(--kj-cat-color, var(--kj-primary, #3D6B4F));
	color: var(--kj-cat-color, var(--kj-primary, #3D6B4F));
	background: color-mix(in srgb, var(--kj-cat-color, var(--kj-primary, #3D6B4F)) 8%, white);
}

.kj-map-filter.is-active {
	background: var(--kj-cat-color, var(--kj-primary, #3D6B4F));
	border-color: var(--kj-cat-color, var(--kj-primary, #3D6B4F));
	color: #fff;
	font-weight: 600;
}

/* ── Leaflet Karten-Container ────────────────────────────────────── */
.kj-map-container {
	width: 100%;
	min-height: 420px;
	background: #e8f0e8;
}

/* Leaflet Override: z-index Korrekturen für Kadence */
.kj-map-container .leaflet-pane { z-index: 1; }
.kj-map-container .leaflet-control { z-index: 2; }
.kj-map-container .leaflet-top,
.kj-map-container .leaflet-bottom { z-index: 2; }

/* ── POI Marker-Pin ──────────────────────────────────────────────── */
.kj-pin {
	width: 36px;
	height: 36px;
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	background: var(--c, #3D6B4F);
	border: 2px solid rgba(255,255,255,0.9);
	box-shadow: 0 2px 8px rgba(0,0,0,0.25);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: transform 0.15s, box-shadow 0.15s;
}
.kj-pin:hover {
	box-shadow: 0 4px 16px rgba(0,0,0,0.35);
	transform: rotate(-45deg) scale(1.15);
}
/* Emoji innen wieder aufrecht drehen */
.kj-pin::before {
	content: attr(data-emoji);
}
/* Emoji-Wrapper */
.kj-pin > * { display: none; }
.kj-pin {
	font-size: 15px;
	line-height: 1;
}
/* Leaflet DivIcon braucht keinen zusätzlichen Container */
.kj-pin { transform: rotate(-45deg); }

/* ── Leaflet Popup ───────────────────────────────────────────────── */
.kj-popup-wrap .leaflet-popup-content-wrapper {
	border-radius: 10px;
	padding: 0;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(30,45,36,0.18);
	border: 1px solid var(--kj-light, #EAE6DE);
}
.kj-popup-wrap .leaflet-popup-content {
	margin: 0;
	width: 260px !important;
}
.kj-popup-wrap .leaflet-popup-tip {
	background: #fff;
}

.kj-popup {
	padding: 14px 16px 12px;
	font-family: var(--wp--preset--font-family--body, 'Inter', sans-serif);
}

.kj-popup__cats {
	margin: 0 0 6px;
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
}

.kj-popup-badge {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 10px;
	background: color-mix(in srgb, var(--c, #3D6B4F) 12%, white);
	color: var(--c, #3D6B4F);
	font-size: 10.5px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.kj-popup__title {
	display: block;
	font-size: 14px;
	font-weight: 700;
	color: var(--kj-text, #1E2D24);
	margin-bottom: 8px;
	line-height: 1.3;
}

.kj-popup__row {
	font-size: 12px;
	color: var(--kj-tx2, #4a5e52);
	margin: 0 0 4px;
	line-height: 1.5;
}
.kj-popup__row a {
	color: var(--kj-primary, #3D6B4F);
	text-decoration: none;
}
.kj-popup__row a:hover { text-decoration: underline; }

.kj-popup__cta {
	display: inline-block;
	margin-top: 10px;
	padding: 7px 14px;
	background: var(--kj-primary, #3D6B4F);
	color: #fff !important;
	border-radius: 6px;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none !important;
	transition: background 0.15s;
}
.kj-popup__cta:hover { background: var(--kj-primary-dk, #2d5039); }

/* ── Responsive ──────────────────────────────────────────────────── */
@media (max-width: 600px) {
	.kj-map-filters { padding: 12px; gap: 6px; }
	.kj-map-filter  { font-size: 11.5px; padding: 5px 10px; }
	.kj-map-container { min-height: 300px; }
}

/* ════════════════════════════════════════════════════════════════
   OSM-Integration (Unterkunfts-Karte v2.0)
   ════════════════════════════════════════════════════════════════ */

/* Zweite Filterleiste (Quelle + Bett+Bike) */
.kj-map-filters-2 {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	margin: 0 0 12px;
}
.kj-filter-sep {
	width: 1px;
	height: 24px;
	background: #d8d2c6;
	margin: 0 4px;
}

/* Quelle-Filter etwas abgesetzt */
.kj-map-filter--src.is-active {
	background: #1E2D24;
	border-color: #1E2D24;
	color: #fff;
}
.kj-map-filter--bub.is-active {
	background: #5A9A5A;
	border-color: #5A9A5A;
	color: #fff;
}

/* OSM-Status-Zeile */
.kj-map-osm-status {
	font-size: 12px;
	color: #6b7d70;
	min-height: 16px;
	margin: 0 0 10px;
}

/* ── Pin-Stile: CPT (gefüllt) vs OSM (hohl) ──────────────────────── */
.kj-pin {
	position: relative;
	width: 36px; height: 36px;
	display: flex; align-items: center; justify-content: center;
	font-size: 17px;
	border-radius: 50% 50% 50% 0;
	transform: rotate(-45deg);
	box-shadow: 0 2px 6px rgba(0,0,0,0.3);
}
.kj-pin > * { transform: rotate(45deg); }

/* CPT: gefüllt mit Kategoriefarbe */
.kj-pin--cpt {
	background: var(--c, #3D6B4F);
	border: 2px solid #fff;
}

/* OSM: hohl / weiß mit Rand */
.kj-pin--osm {
	background: #fff;
	border: 2px dashed #8a96a0;
}

/* Bett+Bike Badge am Pin */
.kj-pin__bub {
	position: absolute;
	top: -8px; right: -8px;
	font-size: 11px;
	background: #5A9A5A;
	border-radius: 50%;
	width: 18px; height: 18px;
	display: flex; align-items: center; justify-content: center;
	box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

/* ── Popup-Badges ────────────────────────────────────────────────── */
.kj-badge-osm {
	background: #eef1f4 !important;
	color: #5a6b78 !important;
	border: 1px dashed #aab4bd;
}
.kj-badge-bub {
	background: #e5f1e5 !important;
	color: #3a7a3a !important;
}
