.zen-portfolio-map {
	position: relative;
	width: 100%;
}

.zen-portfolio-map__canvas {
	width: 100%;
	height: var(--zen-portfolio-map-height, 560px);
	min-height: 280px;
	overflow: hidden;
	background: #dce6eb;
	border-radius: 0;
}

.zen-portfolio-map__fallback {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	text-align: center;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.88));
	color: #1b1f23;
	font-size: 14px;
	line-height: 1.5;
	z-index: 2;
}

.zen-portfolio-map--error .zen-portfolio-map__fallback,
.zen-portfolio-map--empty .zen-portfolio-map__fallback {
	position: static;
	min-height: 240px;
}

.zen-portfolio-map__marker {
	width: 18px;
	height: 18px;
	padding: 0;
	border: 2px solid #fff;
	border-radius: 999px;
	background: #006ba0;
	box-shadow: 0 3px 12px rgba(0, 0, 0, 0.2);
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.zen-portfolio-map__marker:hover,
.zen-portfolio-map__marker:focus-visible {
	transform: scale(1.15);
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
	outline: none;
}

.zen-portfolio-map__popup .mapboxgl-popup-content {
	padding: 12px 14px;
	border-radius: 12px;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.zen-portfolio-map__popup-inner {
	min-width: 140px;
}

.zen-portfolio-map__popup-title {
	display: block;
	font-size: 14px;
	line-height: 1.35;
	font-weight: 700;
	color: #111;
}

.zen-portfolio-map__popup-subtitle {
	margin-top: 2px;
	font-size: 12px;
	line-height: 1.35;
	font-weight: 600;
	color: #006ba0;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.zen-portfolio-map__popup-hint {
	margin-top: 4px;
	font-size: 12px;
	line-height: 1.4;
	color: #4a5560;
}
