:root {
	--m4k-map-sea: #087ea4;
	--m4k-map-sea-deep: #075b78;
	--m4k-map-green: #4c8a4b;
	--m4k-map-gold: #d99b2b;
	--m4k-map-ink: #173241;
	--m4k-map-muted: #617483;
	--m4k-map-line: rgba(8, 126, 164, 0.16);
}

.m4k-webcam-map-panel {
	position: relative;
	overflow: hidden;
	margin: 32px 0;
	padding: clamp(20px, 3vw, 34px);
	border: 1px solid rgba(255, 255, 255, 0.82);
	border-radius: 30px;
	background:
		radial-gradient(circle at 12% 0%, rgba(255, 221, 143, 0.46), transparent 32%),
		radial-gradient(circle at 100% 18%, rgba(8, 126, 164, 0.16), transparent 30%),
		linear-gradient(135deg, rgba(255, 253, 244, 0.98), rgba(237, 250, 255, 0.96) 56%, rgba(245, 255, 237, 0.92));
	box-shadow: 0 22px 54px rgba(7, 91, 120, 0.14);
	color: var(--m4k-map-ink);
}

.m4k-webcam-map-head {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	justify-content: space-between;
	margin-bottom: 20px;
}

.m4k-webcam-map-kicker {
	margin: 0 0 8px;
	color: var(--m4k-map-sea);
	font-size: 0.75rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.m4k-webcam-map-head h3 {
	margin: 0;
	color: var(--m4k-map-ink);
	font-size: clamp(1.55rem, 3vw, 2.35rem);
	line-height: 1.04;
}

.m4k-webcam-map-head p:last-child {
	max-width: 780px;
	margin: 10px 0 0;
	color: var(--m4k-map-muted);
	font-size: 1rem;
	line-height: 1.65;
}

.m4k-webcam-map-count {
	display: inline-flex;
	flex: 0 0 auto;
	align-items: center;
	min-height: 42px;
	padding: 0 15px;
	border: 1px solid rgba(217, 155, 43, 0.34);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.72);
	color: var(--m4k-map-sea-deep);
	font-size: 0.9rem;
	font-weight: 900;
}

.m4k-webcam-map {
	width: 100%;
	height: var(--m4k-map-height, 560px);
	min-height: 320px;
	overflow: hidden;
	border: 1px solid rgba(8, 126, 164, 0.18);
	border-radius: 26px;
	background: #dff4f8;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55), 0 18px 42px rgba(7, 91, 120, 0.12);
}

.m4k-webcam-map .leaflet-control-zoom a {
	border: 0;
	color: var(--m4k-map-sea-deep);
	font-weight: 900;
}

.m4k-webcam-map .leaflet-control-attribution {
	border-radius: 999px 0 0 0;
	background: rgba(255, 255, 255, 0.82);
	font-size: 0.68rem;
}

.m4k-map-marker {
	background: transparent;
	border: 0;
}

.m4k-map-marker-ring {
	position: relative;
	display: grid;
	width: 42px;
	height: 42px;
	place-items: center;
	border: 3px solid rgba(255, 255, 255, 0.92);
	border-radius: 999px;
	background: linear-gradient(135deg, var(--m4k-map-sea), var(--m4k-map-green));
	box-shadow: 0 14px 30px rgba(7, 91, 120, 0.34), 0 0 0 7px rgba(8, 126, 164, 0.14);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.m4k-map-marker-ring::before {
	position: absolute;
	inset: -9px;
	border: 1px solid rgba(217, 155, 43, 0.36);
	border-radius: inherit;
	content: "";
}

.m4k-map-marker:hover .m4k-map-marker-ring {
	box-shadow: 0 18px 38px rgba(7, 91, 120, 0.42), 0 0 0 10px rgba(217, 155, 43, 0.18);
	transform: scale(1.08);
}

.m4k-map-marker--maintenance .m4k-map-marker-ring {
	background: linear-gradient(135deg, #d99b2b, #b86f1c);
}

.m4k-map-marker--soon .m4k-map-marker-ring {
	background: linear-gradient(135deg, #7e95a0, #617483);
}

.m4k-map-marker-play {
	width: 0;
	height: 0;
	margin-left: 3px;
	border-top: 8px solid transparent;
	border-bottom: 8px solid transparent;
	border-left: 13px solid #fff;
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.22));
}

.m4k-map-leaflet-popup .leaflet-popup-content-wrapper {
	overflow: hidden;
	padding: 0;
	border-radius: 22px;
	background: rgba(255, 255, 255, 0.96);
	box-shadow: 0 18px 46px rgba(7, 91, 120, 0.18);
}

.m4k-map-leaflet-popup .leaflet-popup-content {
	width: 292px !important;
	margin: 0;
}

.m4k-map-leaflet-popup .leaflet-popup-tip {
	background: rgba(255, 255, 255, 0.96);
}

.m4k-map-popup {
	margin: 0;
}

.m4k-map-popup-media {
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #082633;
}

.m4k-map-popup-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.25s ease;
}

.m4k-map-popup-media:hover img {
	transform: scale(1.04);
}

.m4k-map-popup-badge {
	position: absolute;
	top: 10px;
	left: 10px;
	padding: 5px 9px;
	border-radius: 999px;
	background: rgba(12, 119, 89, 0.92);
	color: #fff;
	font-size: 0.7rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.m4k-map-popup-badge--maintenance {
	background: rgba(184, 111, 28, 0.94);
}

.m4k-map-popup-badge--soon {
	background: rgba(97, 116, 131, 0.94);
}

.m4k-map-popup-body {
	padding: 15px;
}

.m4k-map-popup-body h4 {
	margin: 0;
	color: var(--m4k-map-ink);
	font-size: 1.1rem;
}

.m4k-map-popup-location,
.m4k-map-popup-address {
	margin: 5px 0 0;
	color: var(--m4k-map-muted);
	font-size: 0.9rem;
	line-height: 1.35;
}

.m4k-map-popup-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 40px;
	margin-top: 13px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--m4k-map-sea), var(--m4k-map-green));
	color: #fff;
	font-weight: 900;
	text-decoration: none;
}

.m4k-map-popup-button:hover,
.m4k-map-popup-button:focus-visible {
	color: #fff;
	text-decoration: none;
	filter: brightness(1.05);
}

.m4k-webcam-map-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
	gap: 10px;
	margin-top: 16px;
}

.m4k-webcam-map-list a {
	display: flex;
	gap: 10px;
	align-items: center;
	padding: 11px 12px;
	border: 1px solid var(--m4k-map-line);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.66);
	color: var(--m4k-map-ink);
	text-decoration: none;
	transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.m4k-webcam-map-list a:hover,
.m4k-webcam-map-list a:focus-visible {
	border-color: rgba(217, 155, 43, 0.48);
	background: rgba(255, 255, 255, 0.9);
	text-decoration: none;
	transform: translateY(-2px);
}

.m4k-webcam-map-list-dot {
	display: block;
	flex: 0 0 auto;
	width: 12px;
	height: 12px;
	border-radius: 999px;
	background: var(--m4k-map-green);
	box-shadow: 0 0 0 5px rgba(76, 138, 75, 0.14);
}

.m4k-webcam-map-list-dot--maintenance {
	background: var(--m4k-map-gold);
	box-shadow: 0 0 0 5px rgba(217, 155, 43, 0.14);
}

.m4k-webcam-map-list-dot--soon {
	background: var(--m4k-map-muted);
	box-shadow: 0 0 0 5px rgba(97, 116, 131, 0.14);
}

.m4k-webcam-map-list strong,
.m4k-webcam-map-list small {
	display: block;
}

.m4k-webcam-map-list small {
	margin-top: 2px;
	color: var(--m4k-map-muted);
}

@media (max-width: 720px) {
	.m4k-webcam-map-head {
		display: grid;
	}

	.m4k-webcam-map-count {
		justify-self: flex-start;
	}

	.m4k-webcam-map {
		height: min(var(--m4k-map-height, 560px), 470px);
		border-radius: 22px;
	}
}
