.vedic-hero-block {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	min-height: 100dvh;
	background: var(--kdm-charcoal);
	color: var(--kdm-text-on-dark);
	overflow: hidden;
}

.vedic-hero-block__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.vedic-hero-block__media {
	position: absolute;
	inset: 0;
	display: block;
}

.vedic-hero-block__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.vedic-hero-block__media--mobile {
	display: none;
}

.vedic-hero-block__overlay {
	position: absolute;
	inset: 0;
	background: var(--kdm-gradient-hero-overlay);
}

.vedic-hero-block__top-link-wrap {
	position: fixed;
	right: clamp(1rem, 2vw, 2rem);
	top: 0;
	z-index: 999;
}

.vedic-hero-block__top-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 58px;
	height: 58px;
	border-radius: 999px;
	text-decoration: none;
	color: #f4f6ed;
	background: var(--kdm-gradient-gold);
	color: var(--kdm-brown);
	box-shadow:
		0 14px 30px rgba(0, 0, 0, 0.35),
		inset 0 1px 0 rgba(255, 255, 255, 0.28);
	border: 1px solid var(--kdm-border-gold);
	outline: none;
}

.vedic-hero-block__top-link::before,
.vedic-hero-block__top-link::after {
	content: "";
	position: absolute;
	inset: -6px;
	border-radius: 999px;
	border: 1px dashed rgba(255, 255, 255, 0.35);
	opacity: 0.48;
	pointer-events: none;
}

.vedic-hero-block__top-link::after {
	inset: -13px;
	opacity: 0.24;
	border-style: solid;
}

.vedic-hero-block__top-link-icon {
	display: inline-flex;
	line-height: 0;
}

.vedic-hero-block__top-link-icon svg {
	display: block;
}

.vedic-hero-block__top-link:hover,
.vedic-hero-block__top-link:focus-visible {
	filter: brightness(1.08);
	transform: translateY(-1px);
}

.vedic-hero-block__editor-preview {
	min-height: 420px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	background: linear-gradient(180deg, var(--kdm-forest) 0%, var(--kdm-charcoal) 100%);
	padding: 2rem 1rem;
	color: var(--kdm-text-on-dark);
}

.vedic-hero-block__preview-label {
	margin-bottom: 1rem;
	font-size: 0.8rem;
	opacity: 0.85;
	letter-spacing: 0.08em;
	color: var(--kdm-text-on-dark-muted);
}

@media (max-width: 768px) {
	.vedic-hero-block__video--desktop {
		display: none;
	}

	.vedic-hero-block__media--mobile {
		display: block;
	}

	.vedic-hero-block__top-link-wrap {
		right: 0.75rem;
		top: 0;
	}
}

/* Keep editor preview behavior stable in wp-admin. */
.wp-admin .vedic-hero-block__top-link-wrap {
	position: absolute;
	z-index: 3;
}
