.leonlab-hotspots {
	--leonlab-accent: #6d28d9;
	border: 1px solid rgba(148, 163, 184, 0.18);
	background: rgba(255, 255, 255, 0.4);
	border-radius: 16px;
	padding: 18px;
}

.leonlab-hotspots__headline {
	margin: 0 0 6px;
	font-size: 24px;
	font-weight: 950;
}

.leonlab-hotspots__text {
	margin: 0 0 14px;
	opacity: 0.85;
}

.leonlab-hotspots__mediaRow {
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

.leonlab-hotspots__tip {
	font-size: 12px;
	opacity: 0.7;
}

.leonlab-hotspots__stage {
	position: relative;
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid rgba(148, 163, 184, 0.2);
	background: rgba(2, 6, 23, 0.04);
	min-height: 320px;
}

.leonlab-hotspots__img {
	display: block;
	width: 100%;
	height: auto;
}

.leonlab-hotspots__placeholder {
	padding: 18px;
	opacity: 0.8;
}

.leonlab-hotspots__dot {
	position: absolute;
	transform: translate(-50%, -50%);
	width: 34px;
	height: 34px;
	border-radius: 999px;
	border: 2px solid rgba(255, 255, 255, 0.95);
	background: var(--leonlab-accent);
	color: #fff;
	font-weight: 950;
	box-shadow: 0 10px 24px rgba(2, 6, 23, 0.25);
	cursor: pointer;
}

.leonlab-hotspots__dot.is-active,
.leonlab-hotspots__dot:focus {
	outline: 3px solid rgba(109, 40, 217, 0.35);
	outline-offset: 2px;
}

.leonlab-hotspots__marker {
	position: absolute;
	transform: translate(-50%, -50%);
}

.leonlab-hotspots__marker .leonlab-hotspots__dot {
	position: static;
	transform: none;
}

.leonlab-hotspots__tooltip {
	position: absolute;
	left: 50%;
	top: calc(100% + 10px);
	transform: translateX(-50%);
	min-width: 220px;
	max-width: min(320px, 80vw);
	padding: 12px;
	border-radius: 14px;
	background: rgba(15, 23, 42, 0.92);
	color: #fff;
	border: 1px solid rgba(148, 163, 184, 0.2);
	box-shadow: 0 18px 45px rgba(2, 6, 23, 0.35);
	opacity: 0;
	pointer-events: none;
	transition: opacity 120ms ease, transform 120ms ease;
}

.leonlab-hotspots__marker.is-open .leonlab-hotspots__tooltip {
	opacity: 1;
	pointer-events: auto;
	transform: translateX(-50%) translateY(0);
}

.leonlab-hotspots__tooltipTitle {
	font-weight: 950;
	margin-bottom: 6px;
}

.leonlab-hotspots__tooltipText {
	font-size: 13px;
	opacity: 0.92;
}

.leonlab-hotspots__toolbar {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

.leonlab-hotspots__colorRow {
	margin-top: 10px;
}

.leonlab-hotspots__colorLabel {
	font-size: 12px;
	font-weight: 800;
	margin-bottom: 8px;
}

.leonlab-hotspots__editorNote {
	margin-top: 10px;
	font-size: 12px;
	opacity: 0.65;
}
