.wp-block-brandspeak-service-hero {
	position: relative;
	min-height: 70vh;
	display: flex;
	align-items: flex-end;
	padding: 140px 28px 40px;
	background-size: cover;
	background-position: center;
	color: #ffffff;
	overflow: hidden;
}

.wp-block-brandspeak-service-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.service-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 1400px;
	margin: 0 auto;
	width: 100%;
}

.service-hero__title {
	font-size: clamp(2.4rem, 4vw, 3rem);
	line-height: 1.2;
	margin: 0 0 1.25rem;
	color: #fff;
	text-align: left;
}

.service-hero__description {
	color: rgba(255, 255, 255, 0.92);
	font-size: 1.05rem;
	line-height: 1.65;
}

.service-hero__description p {
	margin: 0 0 1rem;
}

/* Editor styles */
.brandspeak-service-hero-editor {
	position: relative;
	min-height: 70vh;
	display: flex;
	align-items: flex-end;
	padding: 140px 28px 40px;
	background-size: cover;
	background-position: center;
	color: #ffffff;
	overflow: hidden;
	border-radius: 8px;
}

.brandspeak-service-hero-editor::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
}

.brandspeak-service-hero-editor .service-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 1400px;
	margin: 0 auto;
	width: 100%;
}

.brandspeak-service-hero-editor .service-hero__title {
	font-size: clamp(2.4rem, 4vw, 3rem) !important;
	line-height: 1.2 !important;
	margin: 0 0 1.25rem !important;
	color: #fff !important;
	text-align: left !important;
}

.brandspeak-service-hero-editor .service-hero__description {
	color: rgba(255, 255, 255, 0.92) !important;
	font-size: 1.05rem !important;
	line-height: 1.65 !important;
}

.brandspeak-service-hero-editor .service-hero__description * {
	color: rgba(255, 255, 255, 0.92) !important;
}

.brandspeak-service-hero-editor .service-hero__description p {
	margin: 0 0 1rem;
}

.brandspeak-service-hero-editor .service-hero__description [contenteditable] {
	outline: 1px dashed rgba(255, 255, 255, 0.3);
	outline-offset: 4px;
	min-height: 1.65em;
}

.brandspeak-service-hero-editor .service-hero__description [contenteditable]:focus {
	outline: 1px dashed rgba(255, 255, 255, 0.6);
}

@media (max-width: 768px) {
	.wp-block-brandspeak-service-hero {
		min-height: 50vh;
		padding: 110px 20px 110px;
	}

	.service-hero__title {
		font-size: clamp(2rem, 5vw, 2.5rem);
	}

	.service-hero__description {
		font-size: 1rem;
	}
}
