/**
 * Living Building Art — site overrides (construction theme).
 * Featured service cards match live elartedelmundodelaconstruccion.com.
 */

/* --------------------------------------------------------------------------
   Compact spacing system (public site — scoped to main.main)
   -------------------------------------------------------------------------- */
:root {
	--ea-section-py: 2.5rem;
	--ea-section-py-lg: 3rem;
	--ea-block-gap: 1.25rem;
	--ea-paragraph-mb: 0.85rem;
	--ea-heading-mb: 0.65rem;
	--ea-image-my: 1rem;
	--ea-section-title-pb: 1.75rem;
}

@media (max-width: 767.98px) {
	:root {
		--ea-section-py: 2rem;
		--ea-section-py-lg: 2.5rem;
		--ea-block-gap: 1rem;
		--ea-paragraph-mb: 0.75rem;
		--ea-section-title-pb: 1.35rem;
	}
}

main.main section,
main.main .section {
	padding-top: var(--ea-section-py);
	padding-bottom: var(--ea-section-py);
}

main.main section.ea-inquiry,
main.main section.ea-lead-section {
	padding-top: var(--ea-section-py-lg);
	padding-bottom: max(var(--ea-section-py-lg), calc(2.5rem + env(safe-area-inset-bottom, 0px)));
}

main.main .section-title {
	padding-bottom: var(--ea-section-title-pb);
}

main.main .section-title h2 {
	margin-bottom: 0.75rem;
	padding-bottom: 0.75rem;
}

main.main .page-title .heading,
main.main .page-title .ea-page-banner {
	padding-top: clamp(2.25rem, 5vw, 3.25rem);
	padding-bottom: clamp(2.25rem, 5vw, 3.25rem);
}

main.main .page-title .heading h1,
main.main .page-title .heading .heading-title {
	letter-spacing: normal;
	line-height: 1.2;
	margin-bottom: 0.65rem;
	font-weight: 700;
}

/* “Building” wordmark — blue B with nested ARC (#004279) */
.ea-brand-heading {
	color: #ffffff;
}

.ea-brand-heading .ea-brand-b {
	position: relative;
	display: inline-block;
	color: #004279;
	font-weight: 700;
	vertical-align: baseline;
	line-height: 0.92;
	padding-right: 0.02em;
}

.ea-brand-heading .ea-brand-arc {
	position: absolute;
	left: 50%;
	bottom: 0.08em;
	transform: translateX(-50%);
	font-size: 0.26em;
	font-weight: 700;
	letter-spacing: -0.05em;
	line-height: 1;
	color: #004279;
	white-space: nowrap;
	pointer-events: none;
}

/* Home / light sections: brand blue on default heading color */
#about .ea-brand-heading,
.section-title.ea-brand-heading {
	color: inherit;
}

#about .ea-brand-heading .ea-brand-b,
#about .ea-brand-heading .ea-brand-arc,
.section-title .ea-brand-heading .ea-brand-b,
.section-title .ea-brand-heading .ea-brand-arc {
	color: #004279;
}

main.main .page-title .heading p {
	letter-spacing: normal;
	word-spacing: normal;
	line-height: 1.55;
	max-width: 42rem;
	margin-left: auto;
	margin-right: auto;
}

main.main .page-title nav {
	padding-top: 0.85rem;
	padding-bottom: 0.85rem;
	letter-spacing: normal;
}

/* Banner → intro → inquiry: avoid triple vertical gaps */
main.main .page-title + .ea-contact-intro.section,
main.main .page-title + .ea-page-lead.section {
	padding-top: 0;
	padding-bottom: 0;
}

main.main .page-title ~ .ea-inquiry,
main.main .page-title ~ .ea-lead-section.ea-inquiry {
	padding-top: var(--ea-section-py);
}

main.main .page-title ~ .ea-inquiry .ea-inquiry__header.section-title {
	padding-bottom: 0.85rem;
}

main.main .page-title ~ .ea-inquiry .ea-inquiry__header h2 {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

main.main .page-title ~ .ea-inquiry .ea-inquiry__header h2::after {
	display: none;
}

main.main .content,
main.main .content p {
	letter-spacing: normal;
	word-spacing: normal;
	line-height: 1.6;
}

main.main .py-5 {
	padding-top: var(--ea-section-py) !important;
	padding-bottom: var(--ea-section-py) !important;
}

main.main .py-4 {
	padding-top: calc(var(--ea-section-py) * 0.9) !important;
	padding-bottom: calc(var(--ea-section-py) * 0.9) !important;
}

main.main .my-5 {
	margin-top: var(--ea-block-gap) !important;
	margin-bottom: var(--ea-block-gap) !important;
}

main.main .my-4 {
	margin-top: calc(var(--ea-block-gap) * 0.85) !important;
	margin-bottom: calc(var(--ea-block-gap) * 0.85) !important;
}

main.main .mb-5 {
	margin-bottom: var(--ea-block-gap) !important;
}

main.main .mb-4 {
	margin-bottom: calc(var(--ea-block-gap) * 0.85) !important;
}

main.main .gy-4 {
	--bs-gutter-y: var(--ea-block-gap);
}

main.main .gy-5 {
	--bs-gutter-y: calc(var(--ea-block-gap) * 1.15);
}

/* Hero carousel — frosted caption panel (Lindanovia-style blur + brand tint) */
main.main .hero.section {
	padding-top: 0;
	padding-bottom: 0;
}

main.main #hero-carousel .carousel-item .ea-hero-caption {
	position: relative;
	z-index: 3;
	max-width: 52rem;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: clamp(1.25rem, 4vw, 3rem);
	padding: clamp(1.25rem, 3vw, 1.85rem) clamp(1.15rem, 4vw, 2.25rem);
	border-radius: clamp(14px, 2.5vw, 22px);
	text-align: center;
	background: color-mix(in srgb, #004279 78%, transparent);
	background: rgba(0, 66, 121, 0.78);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border: 1px solid rgba(255, 255, 255, 0.14);
	box-shadow:
		0 0 0 1px rgba(0, 0, 0, 0.06),
		0 12px 32px rgba(0, 20, 40, 0.35);
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
	main.main #hero-carousel .carousel-item .ea-hero-caption {
		background: rgba(0, 66, 121, 0.92);
	}
}

main.main #hero-carousel .ea-hero-caption h2 {
	margin-bottom: 0.85rem;
	color: #ffffff;
	font-weight: 700;
	line-height: 1.25;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

main.main #hero-carousel .ea-hero-caption .btn-get-started {
	margin-top: 0.15rem;
	margin-bottom: 0;
	color: var(--contrast-color, #ffffff);
	background: var(--accent-color, #004279);
	border: 1px solid rgba(255, 255, 255, 0.22);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

main.main #hero-carousel .ea-hero-caption .btn-get-started:hover,
main.main #hero-carousel .ea-hero-caption .btn-get-started:focus-visible {
	color: var(--contrast-color, #ffffff);
	background: color-mix(in srgb, var(--accent-color, #004279) 85%, #ffffff 15%);
}

main.main #hero-carousel .ea-hero-caption p:empty {
	display: none;
	margin: 0;
	padding: 0;
}

@media (max-width: 1199.98px) {
	main.main #hero-carousel .carousel-item .ea-hero-caption {
		margin-left: clamp(0.75rem, 3vw, 2.5rem);
		margin-right: clamp(0.75rem, 3vw, 2.5rem);
	}
}

@media (max-width: 767.98px) {
	main.main #hero-carousel .carousel-item .ea-hero-caption {
		margin-left: max(0.65rem, env(safe-area-inset-left, 0px));
		margin-right: max(0.65rem, env(safe-area-inset-right, 0px));
		margin-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
		padding: 1.15rem 1rem 1.2rem;
		border-radius: 14px;
		backdrop-filter: blur(14px);
		-webkit-backdrop-filter: blur(14px);
	}

	main.main #hero-carousel .ea-hero-caption h2 {
		font-size: clamp(1.35rem, 5.2vw, 1.75rem);
		margin-bottom: 0.65rem;
	}

	main.main #hero-carousel .ea-hero-caption .btn-get-started {
		display: inline-block;
		padding: 0.55rem 1.35rem;
		font-size: 0.8125rem;
	}
}

/* Home sections */
main.main #featured-services.section {
	padding-top: calc(var(--ea-section-py) * 0.85);
	padding-bottom: calc(var(--ea-section-py) * 0.85);
}

main.main #about .content h3 {
	margin-bottom: var(--ea-heading-mb);
}

main.main #about .content p {
	margin-bottom: var(--ea-paragraph-mb);
}

main.main #about .content ul li {
	padding-top: 0.35rem;
}

main.main .call-to-action {
	padding-top: var(--ea-section-py-lg);
	padding-bottom: var(--ea-section-py-lg);
}

main.main .content > p {
	margin-bottom: var(--ea-paragraph-mb);
}

main.main .content > p:last-child {
	margin-bottom: 0;
}

/* Migrated Wow Coder / inner page HTML */
.ea-page-body {
	color: var(--default-color, #444);
	line-height: 1.6;
	letter-spacing: normal;
	word-spacing: normal;
}

.ea-page-body p,
.ea-page-body li,
.page-content p,
.page-content li {
	letter-spacing: normal;
	word-spacing: normal;
	line-height: 1.6;
}

.ea-page-body [style*="letter-spacing"],
.page-content [style*="letter-spacing"] {
	letter-spacing: normal !important;
}

.ea-page-body [style*="word-spacing"],
.page-content [style*="word-spacing"] {
	word-spacing: normal !important;
}

.ea-page-body > section:first-child,
.ea-page-body > .section:first-child {
	margin-top: 0;
}

.ea-page-body section,
.ea-page-body .section {
	padding-top: var(--ea-section-py);
	padding-bottom: var(--ea-section-py);
}

.ea-page-body .section-title {
	padding-bottom: var(--ea-section-title-pb);
}

.ea-page-body .container.py-5,
.ea-page-body .container.py-4 {
	padding-top: calc(var(--ea-section-py) * 0.65) !important;
	padding-bottom: calc(var(--ea-section-py) * 0.65) !important;
}

.ea-page-body p {
	margin-bottom: var(--ea-paragraph-mb);
}

.ea-page-body p[style*="margin"] {
	margin-bottom: var(--ea-paragraph-mb) !important;
}

.ea-page-body p[style*="margin-top"] {
	margin-top: var(--ea-paragraph-mb) !important;
}

.ea-page-body h1,
.ea-page-body h2,
.ea-page-body h3,
.ea-page-body h4,
.ea-page-body h5,
.ea-page-body h6 {
	margin-top: 1.15rem;
	margin-bottom: var(--ea-heading-mb);
	color: var(--heading-color, #555);
	letter-spacing: normal;
	line-height: 1.25;
}

.ea-page-body h1 {
	line-height: 1.15;
}

.ea-page-body h2,
.ea-page-body h3 {
	line-height: 1.22;
}

.ea-page-body > h1:first-child,
.ea-page-body > h2:first-child,
.ea-page-body > section:first-child h1:first-child,
.ea-page-body > section:first-child h2:first-child {
	margin-top: 0;
}

.ea-page-body img,
.page-content img {
	max-width: 100%;
	height: auto;
	display: block;
	margin: var(--ea-image-my) auto;
}

.ea-page-body img[style*="margin"],
.page-content img[style*="margin"] {
	margin-top: var(--ea-image-my) !important;
	margin-bottom: var(--ea-image-my) !important;
}

.ea-page-body ul,
.ea-page-body ol {
	margin-bottom: var(--ea-paragraph-mb);
	padding-left: 1.25rem;
}

.ea-page-body li + li {
	margin-top: 0.25rem;
}

.ea-page-body .row {
	--bs-gutter-y: var(--ea-block-gap);
}

.ea-page-body [data-aos] {
	margin-bottom: 0;
}

#featured-services .row.gy-4 {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

#featured-services .ea-service-col {
	flex: 1 1 280px;
	max-width: 350px;
	text-align: center;
	position: relative;
}

.service-img-link {
	display: block;
	position: relative;
	text-decoration: none;
}

.service-img {
	width: 100%;
	height: 280px;
	border-radius: 10px;
	background-size: cover;
	background-position: center;
	transition: 0.3s ease;
}

.service-img-link:hover .service-img {
	box-shadow: 0 0 20px rgba(0, 66, 121, 0.55);
	filter: brightness(0.85);
}

.hover-text {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	background: rgba(0, 66, 121, 0.9);
	padding: 6px 12px;
	border-radius: 6px;
	opacity: 0;
	transition: opacity 0.3s ease;
	pointer-events: none;
}

.service-img-link:hover .hover-text {
	opacity: 1;
}

#featured-services h4 {
	margin-top: 10px;
	font-size: 16px;
}

#featured-services h4 a {
	text-decoration: none;
	color: var(--heading-color, #555);
}

#featured-services h4 a:hover {
	color: var(--accent-color, #004279);
}

.topbar a {
	color: inherit;
	font-weight: 600;
}

.topbar a:hover {
	color: var(--accent-color, #004279);
}

/* --------------------------------------------------------------------------
   Project inquiry — lead form (home, project inquiry page, contact, get-started)
   -------------------------------------------------------------------------- */
.ea-inquiry {
	--ea-inquiry-accent: var(--accent-color, #004279);
	--ea-inquiry-border: color-mix(in srgb, var(--ea-inquiry-accent), #fff 82%);
	--ea-inquiry-muted: color-mix(in srgb, var(--default-color, #444), transparent 35%);
	--ea-inquiry-surface: #f7f9fc;
	scroll-margin-top: calc(5.5rem + env(safe-area-inset-top, 0px));
	background: var(--background-color, #fff);
	padding-top: var(--ea-section-py-lg);
	padding-bottom: max(var(--ea-section-py-lg), calc(2.5rem + env(safe-area-inset-bottom, 0px)));
}

.ea-inquiry__header.section-title {
	padding-bottom: var(--ea-section-title-pb);
}

.ea-inquiry__header h2 {
	color: var(--heading-color, #2c4964);
	letter-spacing: normal;
	line-height: 1.22;
}

.ea-inquiry__intro {
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
	font-size: 1rem;
	line-height: 1.55;
	letter-spacing: normal;
	word-spacing: normal;
	color: var(--ea-inquiry-muted);
}

main.main .section-title p {
	letter-spacing: normal;
	line-height: 1.55;
}

.ea-inquiry__card {
	margin-top: 0.25rem;
	padding: clamp(1.25rem, 3vw, 2rem) clamp(1.15rem, 3vw, 2rem) clamp(1.35rem, 3vw, 2.1rem);
	background: #fff;
	border: 1px solid var(--ea-inquiry-border);
	border-radius: 12px;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.9) inset,
		0 12px 36px rgba(0, 66, 121, 0.08);
}

.ea-inquiry__form,
.ea-inquiry__fields {
	display: grid;
	gap: 1.25rem;
}

.ea-inquiry__field {
	min-width: 0;
	margin: 0;
}

.ea-inquiry__grid2 {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

@media (min-width: 576px) {
	.ea-inquiry__grid2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.ea-inquiry__label,
.ea-inquiry .ln-contact-form__label {
	display: block;
	margin: 0 0 0.4rem;
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: normal;
	color: var(--heading-color, #2c4964);
}

.ea-inquiry,
.ea-inquiry p,
.ea-inquiry .ln-contact-form__consent-text {
	letter-spacing: normal;
	word-spacing: normal;
}

.ea-inquiry__input,
.ea-inquiry__textarea,
.ea-inquiry__select,
.ea-inquiry .ln-contact-form__input,
.ea-inquiry .ln-contact-form__textarea,
.ea-inquiry .ln-contact-form__select {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: 48px;
	padding: 0.7rem 0.9rem;
	font-family: var(--default-font);
	font-size: 16px;
	line-height: 1.45;
	color: var(--default-color, #444);
	background: var(--ea-inquiry-surface);
	border: 1px solid color-mix(in srgb, var(--ea-inquiry-accent), #fff 70%);
	border-radius: 8px;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
	-webkit-tap-highlight-color: transparent;
}

.ea-inquiry__select,
.ea-inquiry .ln-contact-form__select {
	padding-right: 2.35rem;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath fill='none' stroke='%23004279' stroke-width='2' stroke-linecap='round' d='M1 1.5l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: calc(100% - 0.9rem) 50%;
	background-size: 14px 9px;
}

.ea-inquiry__textarea,
.ea-inquiry .ln-contact-form__textarea {
	min-height: 9rem;
	height: auto;
	resize: vertical;
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}

.ea-inquiry__input::placeholder,
.ea-inquiry__textarea::placeholder,
.ea-inquiry .ln-contact-form__input::placeholder,
.ea-inquiry .ln-contact-form__textarea::placeholder {
	color: color-mix(in srgb, var(--default-color, #444), transparent 55%);
}

.ea-inquiry__input:focus,
.ea-inquiry__textarea:focus,
.ea-inquiry__select:focus,
.ea-inquiry .ln-contact-form__input:focus,
.ea-inquiry .ln-contact-form__textarea:focus,
.ea-inquiry .ln-contact-form__select:focus {
	border-color: var(--ea-inquiry-accent);
	background: #fff;
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ea-inquiry-accent), transparent 82%);
}

.ea-inquiry__category-detail,
.ea-inquiry .ln-contact-form__category-detail {
	margin-top: 0.75rem;
	padding: 0.9rem 1rem;
	text-align: left;
	border-radius: 8px;
	background: color-mix(in srgb, var(--ea-inquiry-accent), #fff 92%);
	border: 1px solid color-mix(in srgb, var(--ea-inquiry-accent), #fff 78%);
}

.ea-inquiry__category-detail .ln-contact-form__category-detail__name,
.ea-inquiry .ln-contact-form__category-detail__name {
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: var(--ea-inquiry-accent) !important;
	line-height: 1.3 !important;
}

.ea-inquiry__category-detail .ln-contact-form__category-detail__types,
.ea-inquiry .ln-contact-form__category-detail__types {
	font-size: 0.9rem !important;
	font-weight: 500 !important;
	color: var(--default-color, #444) !important;
	line-height: 1.45 !important;
}

.ea-inquiry__consent .ln-contact-form__consent-label {
	align-items: flex-start;
	gap: 0.65rem;
	margin: 0;
	cursor: pointer;
	font-size: 0.875rem;
	line-height: 1.5;
	color: var(--default-color, #444);
}

.ea-inquiry__consent .ln-contact-form__consent-input {
	width: 1.125rem;
	height: 1.125rem;
	margin: 0.15rem 0 0;
	flex-shrink: 0;
	accent-color: var(--ea-inquiry-accent);
	cursor: pointer;
}

.ea-inquiry__submit,
.ea-inquiry .ln-contact-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 48px;
	margin-top: 0.25rem;
	padding: 0.85rem 1.5rem;
	font-family: var(--heading-font);
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--contrast-color, #fff);
	background: var(--ea-inquiry-accent);
	border: 0;
	border-radius: 8px;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
	box-shadow: 0 4px 14px color-mix(in srgb, var(--ea-inquiry-accent), transparent 70%);
}

@media (min-width: 576px) {
	.ea-inquiry__submit,
	.ea-inquiry .ln-contact-form__submit {
		width: auto;
		min-width: 12rem;
	}
}

.ea-inquiry__submit:hover:not(:disabled),
.ea-inquiry .ln-contact-form__submit:hover:not(:disabled) {
	background: color-mix(in srgb, var(--ea-inquiry-accent), #000 10%);
	box-shadow: 0 6px 18px color-mix(in srgb, var(--ea-inquiry-accent), transparent 62%);
}

.ea-inquiry__submit:focus-visible,
.ea-inquiry .ln-contact-form__submit:focus-visible {
	outline: 2px solid var(--ea-inquiry-accent);
	outline-offset: 3px;
}

.ea-inquiry__submit:disabled,
.ea-inquiry .ln-contact-form__submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	box-shadow: none;
	transform: none;
}

.ea-inquiry__notice,
.ea-inquiry .ln-contact-form__notice {
	margin: 0.75rem 0 0;
	padding: 0.85rem 1rem;
	border-radius: 8px;
	font-size: 0.9375rem;
	line-height: 1.5;
}

.ea-inquiry__notice--success,
.ea-inquiry .ln-contact-form__notice--success {
	background: color-mix(in srgb, #059652, #fff 90%);
	color: #0b5a36;
	border: 1px solid color-mix(in srgb, #059652, #fff 70%);
}

.ea-inquiry__notice--error,
.ea-inquiry .ln-contact-form__notice--error {
	background: color-mix(in srgb, #df1529, #fff 92%);
	color: #8b1220;
	border: 1px solid color-mix(in srgb, #df1529, #fff 75%);
}

.ea-inquiry .lead-form-error:not([hidden]),
.ea-inquiry .lead-form-success:not([hidden]) {
	display: block;
}

@media (max-width: 575.98px) {
	.ea-inquiry {
		padding-top: var(--ea-section-py);
		padding-bottom: max(var(--ea-section-py-lg), calc(2.5rem + env(safe-area-inset-bottom, 0px)));
	}

	.ea-inquiry .container {
		padding-left: max(1rem, env(safe-area-inset-left, 0px));
		padding-right: max(1rem, env(safe-area-inset-right, 0px));
	}

	.ea-inquiry__header.section-title {
		padding-bottom: var(--ea-section-title-pb);
	}

	.ea-inquiry__header h2 {
		font-size: clamp(1.35rem, 5.5vw, 1.85rem);
	}

	.ea-inquiry__card {
		border-radius: 10px;
		box-shadow: 0 8px 28px rgba(0, 66, 121, 0.07);
	}
}

/* Legacy alias */
.ea-lead-section {
	background: var(--background-color, #fff);
}

.ea-contact-intro {
	padding-top: 0;
	padding-bottom: 0;
}

main.main .ea-contact-intro:empty,
main.main .ea-contact-intro:not(:has(p)) {
	display: none;
}

.ea-contact-intro .content p {
	margin-bottom: 0.75rem;
	color: color-mix(in srgb, var(--default-color, #444), transparent 20%);
	line-height: 1.6;
}

.ea-contact-intro .content a {
	color: var(--accent-color, #004279);
	font-weight: 600;
	text-decoration: none;
}

.ea-contact-intro .content a:hover {
	text-decoration: underline;
}

.ea-float-contact {
	position: fixed;
	right: 16px;
	bottom: 16px;
	z-index: 999;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.ea-float-contact a {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 1rem;
	border-radius: 50px;
	font-weight: 600;
	font-size: 0.9rem;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
	text-decoration: none;
}

.ea-float-contact__call {
	background: #fff;
	color: var(--accent-color, #004279);
	border: 2px solid var(--accent-color, #004279);
}

.ea-float-contact__adu {
	background: var(--accent-color, #004279);
	color: #fff;
}

.page-title .heading,
.page-title .ea-page-banner {
	background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), var(--ea-page-banner-image);
	background-size: cover;
	background-position: center;
	position: relative;
}

/* Migrated body_html may still embed a duplicate banner block */
.ea-page-body > .page-title:first-child .heading,
.ea-page-body > .heading:first-child {
	background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), var(--ea-page-banner-image, none);
	background-size: cover;
	background-position: center;
	padding-top: clamp(2.25rem, 5vw, 3.25rem) !important;
	padding-bottom: clamp(2.25rem, 5vw, 3.25rem) !important;
}

/* --------------------------------------------------------------------------
   Mobile compatibility (Bootstrap 5: lg 991.98 · md 767.98 · sm 575.98)
   -------------------------------------------------------------------------- */
html {
	overflow-x: clip;
}

body {
	overflow-x: clip;
	max-width: 100%;
}

main.main,
.header,
.footer {
	max-width: 100%;
}

/* Header topbar + branding */
.header .ea-topbar .ea-topbar__phone-label {
	margin-right: 0.25rem;
}

.header .ea-topbar .ea-topbar__phone-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0.35rem 0.5rem;
	font-weight: 600;
	color: inherit;
	text-decoration: none;
	-webkit-tap-highlight-color: transparent;
}

.header .ea-topbar .ea-topbar__phone-link:hover,
.header .ea-topbar .ea-topbar__phone-link:focus-visible {
	color: var(--contrast-color, #fff);
	text-decoration: underline;
}

.ea-page-body {
	overflow-wrap: anywhere;
	max-width: 100%;
}

.ea-page-body table {
	display: block;
	width: 100%;
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ea-page-body iframe,
.ea-page-body video,
.ea-page-body embed,
.ea-page-body object {
	max-width: 100%;
	height: auto;
}

.ea-page-body pre {
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

@media (max-width: 991.98px) {
	.header .topbar.ea-topbar {
		height: auto;
		min-height: 40px;
		padding: 0.35rem 0;
	}

	.header .ea-topbar .container {
		row-gap: 0.15rem;
		font-size: 0.8125rem;
		line-height: 1.35;
		text-align: center;
	}

	.header .branding .ea-branding-row {
		row-gap: 0.35rem;
	}

	.header .cta-btn {
		order: 4;
		flex: 1 1 100%;
		width: 100%;
		margin: 0.35rem 0 0;
		min-height: 44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		text-align: center;
	}

	.mobile-nav-toggle {
		min-width: 44px;
		min-height: 44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		margin-right: 0;
	}

	.navmenu a,
	.navmenu a:focus {
		min-height: 44px;
	}

	main.main #hero-carousel .carousel-item .container.ea-hero-caption {
		margin-left: max(0.75rem, env(safe-area-inset-left, 0px));
		margin-right: max(0.75rem, env(safe-area-inset-right, 0px));
		width: auto;
		max-width: calc(100% - 1.5rem);
		background: rgba(0, 66, 121, 0.78);
	}

	main.main .page-title .heading h1,
	main.main .page-title .heading .heading-title {
		font-size: clamp(1.5rem, 4.5vw, 2rem);
		overflow-wrap: anywhere;
	}

	main.main .page-title .heading,
	main.main .page-title .ea-page-banner {
		padding-top: clamp(1.75rem, 4vw, 2.5rem);
		padding-bottom: clamp(1.75rem, 4vw, 2.5rem);
	}
}

@media (max-width: 767.98px) {
	.header .ea-topbar .ea-topbar__phone-label {
		display: none;
	}

	.header .ea-topbar .ea-topbar__phone-link {
		padding-left: 0.65rem;
		padding-right: 0.65rem;
	}

	main.main .hero .carousel,
	main.main #hero-carousel.carousel {
		min-height: clamp(380px, 68vh, 560px);
	}

	main.main #hero-carousel .carousel-item {
		padding-left: 2.75rem;
		padding-right: 2.75rem;
		padding-bottom: 2.75rem;
	}

	main.main #hero-carousel .carousel-control-prev,
	main.main #hero-carousel .carousel-control-next {
		width: 2.75rem;
		opacity: 0.75;
	}

	main.main #hero-carousel .carousel-control-prev-icon,
	main.main #hero-carousel .carousel-control-next-icon {
		width: 44px;
		height: 44px;
		font-size: 22px;
	}

	main.main .page-title nav ol {
		font-size: 0.875rem;
		row-gap: 0.25rem;
	}

	main.main .page-title .heading p {
		font-size: 0.9375rem;
		padding-left: 0.25rem;
		padding-right: 0.25rem;
	}

	#featured-services .row.gy-4 {
		gap: 0.85rem;
	}

	#featured-services .ea-service-col {
		flex: 1 1 100%;
		max-width: 100%;
	}

	.ea-inquiry__card,
	.ea-inquiry__form,
	.ea-inquiry__fields {
		max-width: 100%;
		overflow-x: clip;
	}

	.ea-page-body .row > [class*="col-"] {
		flex: 0 0 100%;
		max-width: 100%;
	}

	.ea-page-body > .page-title:first-child .heading h1,
	.ea-page-body > .heading:first-child h1 {
		font-size: clamp(1.35rem, 5vw, 1.85rem);
		overflow-wrap: anywhere;
	}

	.ea-brand-heading .ea-brand-arc {
		font-size: 0.22em;
		letter-spacing: -0.06em;
	}

	.ea-inquiry__submit,
	.ea-inquiry .ln-contact-form__submit {
		width: 100%;
		min-height: 48px;
	}

	main.main #hero-carousel .ea-hero-caption .btn-get-started {
		min-height: 44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	.footer .footer-top {
		padding-top: 2.25rem;
	}

	.footer .footer-links,
	.footer .footer-about {
		text-align: center;
	}

	.footer .social-links {
		justify-content: center;
	}

	.ea-float-contact {
		left: max(12px, env(safe-area-inset-left, 0px));
		right: max(12px, env(safe-area-inset-right, 0px));
		bottom: max(4.75rem, calc(3.25rem + env(safe-area-inset-bottom, 0px)));
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: flex-end;
		align-items: stretch;
		max-width: calc(100% - 1.5rem);
		gap: 6px;
	}

	.ea-float-contact a {
		min-height: 44px;
		padding: 0.55rem 0.85rem;
		font-size: 0.8125rem;
	}

	.scroll-top {
		bottom: max(12px, env(safe-area-inset-bottom, 0px));
		width: 44px;
		height: 44px;
	}
}

@media (max-width: 575.98px) {
	.header .ea-topbar .container {
		font-size: 0.75rem;
	}

	main.main #hero-carousel .carousel-item {
		padding-left: 2.35rem;
		padding-right: 2.35rem;
	}

	main.main .page-title .heading h1,
	main.main .page-title .heading .heading-title {
		font-size: clamp(1.3rem, 6.5vw, 1.65rem);
	}

	#featured-services .service-img {
		height: clamp(200px, 52vw, 260px);
	}

	.ea-float-contact__tel-text {
		display: none;
	}

	.ea-float-contact__call::after {
		content: "Call";
	}

	.ea-inquiry__consent .ln-contact-form__consent-label {
		min-height: 44px;
		padding-top: 0.35rem;
		padding-bottom: 0.35rem;
	}

	.ea-inquiry__consent .ln-contact-form__consent-input {
		width: 1.25rem;
		height: 1.25rem;
		margin-top: 0.65rem;
	}
}
