/*
Theme Name: Index Master
Version: 2.3.1
Text Domain: index-master
*/

/* ─── Tokens — Jerusalem brand ─── */
:root {
	--im-radius: 8px;
	--im-radius-lg: 12px;
	--im-shadow: 0 2px 16px rgba(27, 58, 92, 0.06);
	--im-shadow-lg: 0 8px 28px rgba(27, 58, 92, 0.1);
	--im-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--im-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
	--im-section-pad: clamp(4rem, 9vw, 6.5rem);
	--im-section-pad-tight: clamp(2.5rem, 6vw, 4rem);
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	margin: 0;
	-webkit-font-smoothing: antialiased;
	font-family: "Assistant", "Rubik", sans-serif;
	background: var(--im-stone, #F5F2ED);
	color: var(--im-text, #2D2D2D);
}

/* Flush layout — no gap between header, hero, footer */
.wp-site-blocks > * {
	margin-block: 0 !important;
}

header.wp-block-template-part,
.wp-block-template-part:has(.index-header) {
	position: sticky;
	top: 0;
	z-index: 300;
	margin-block-end: 0 !important;
}

main.wp-block-group {
	margin: 0;
	padding: 0;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* ─── Scroll reveal — subtle ─── */
.index-reveal {
	opacity: 0;
	transform: translateY(12px);
	transition: opacity 0.4s ease, transform 0.4s ease;
}

.index-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	.index-reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* ─── Eyebrow labels ─── */
.index-eyebrow {
	display: block;
	width: fit-content;
	max-width: 100%;
	margin-block: 0 0.75rem;
	margin-inline: auto;
	padding: 0.35rem 0.85rem;
	font-family: "Assistant", "Rubik", sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-align: center;
	color: var(--im-primary, #1B3A5C);
	background: rgba(176, 190, 197, 0.25);
	border-radius: 100px;
	border: 1px solid rgba(176, 190, 197, 0.5);
}

.index-section__title--start {
	text-align: start !important;
}

/* ─── Header ─── */
.index-header {
	position: relative;
	z-index: 300;
	margin-block-end: 0;
	background: var(--im-primary, #1B3A5C);
	border-bottom: 1px solid rgba(176, 190, 197, 0.35);
	transition: box-shadow 0.3s var(--im-ease);
}

.index-header.is-scrolled {
	box-shadow: 0 4px 20px rgba(27, 58, 92, 0.2);
}

.index-header__shell {
	max-width: min(1440px, 94vw);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2.5rem);
}

.index-header__inner {
	padding-block: 0.9rem;
	gap: 1rem;
}

.index-header__brand-wrap {
	gap: 0.65rem;
	align-items: center;
}

.index-logo {
	display: inline-flex;
	text-decoration: none;
	flex-shrink: 0;
}

.index-logo__mark {
	display: block;
	width: 42px;
	height: 42px;
	border-radius: 8px;
	background: linear-gradient(145deg, #d4dce2 0%, var(--im-aluminum, #B0BEC5) 45%, #8a9aa3 100%);
	position: relative;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45), 0 2px 8px rgba(0, 0, 0, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.25);
}

.index-logo__mark::before {
	content: "";
	position: absolute;
	inset: 8px;
	border: 2px solid var(--im-primary, #1B3A5C);
	border-radius: 3px;
	opacity: 0.85;
}

.index-logo__mark::after {
	content: "";
	position: absolute;
	inset: 14px 10px;
	background: repeating-linear-gradient(
		to bottom,
		var(--im-secondary, #0f172a) 0,
		var(--im-secondary, #0f172a) 2px,
		transparent 2px,
		transparent 5px
	);
}

.index-header.is-scrolled {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}

.index-header__inner {
	padding-block: 0.9rem;
}

.index-header .wp-block-site-title a {
	color: #fff !important;
	text-decoration: none;
	font-family: "Heebo", sans-serif;
	font-size: clamp(1.05rem, 2.5vw, 1.3rem);
	font-weight: 700;
}

.index-header__nav .wp-block-navigation-item__content {
	color: rgba(255, 255, 255, 0.85) !important;
	text-decoration: none;
	font-weight: 500;
	font-size: 0.95rem;
	position: relative;
	transition: color 0.2s;
}

.index-header__nav .wp-block-navigation-item__content:hover {
	color: var(--im-accent, #d4a853) !important;
}

.index-header__cta .wp-block-button__link {
	background: transparent !important;
	color: #fff !important;
	padding: 0.5rem 1rem !important;
	font-weight: 600;
	border-radius: 8px;
	border: 1.5px solid rgba(255, 255, 255, 0.45) !important;
	white-space: nowrap;
	transition: border-color 0.2s, color 0.2s;
}

.index-header__cta .wp-block-button__link:hover {
	border-color: var(--im-accent, #D4A843) !important;
	color: var(--im-accent, #D4A843) !important;
	transform: none;
	box-shadow: none;
}

.index-header-actions {
	gap: 1.25rem;
	align-items: center;
}

.index-header__nav .wp-block-navigation__responsive-container-open {
	color: #fff;
	background: rgba(255, 255, 255, 0.08);
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: 6px;
	padding: 0.45rem;
}

.index-header__nav .wp-block-navigation__responsive-container-open:hover {
	border-color: var(--im-accent, #d4a853);
	color: var(--im-accent, #d4a853);
}

.index-header__nav .wp-block-navigation__responsive-container-close {
	color: #fff;
}

/* Mobile overlay: WP defaults to light bg; header links are white → invisible */
.index-header__nav.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open,
.index-header__nav.wp-block-navigation .wp-block-navigation__responsive-dialog,
.index-header__nav .wp-block-navigation__responsive-container.is-menu-open {
	background-color: var(--im-primary-dark, #152d47) !important;
	color: #fff !important;
}

.index-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
	padding: 1.5rem 1.25rem 2rem;
}

.index-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content,
.index-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content {
	color: #fff !important;
	font-size: 1.15rem;
	padding: 0.65rem 0;
}

.index-header__nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover {
	color: var(--im-accent, #D4A843) !important;
}

.index-header__nav .wp-block-navigation__responsive-container-close svg {
	fill: #fff;
}

.has-modal-open .index-header__nav .wp-block-navigation__responsive-container {
	background-color: var(--im-primary-dark, #152d47) !important;
}

/* ─── Hero — full-width image + Ken Burns overlay ─── */
.index-hero {
	position: relative;
	min-height: clamp(560px, 85vh, 900px);
	display: flex;
	align-items: flex-end;
	margin-block: 0;
	padding-block: clamp(5rem, 14vw, 9rem);
	background-color: var(--im-primary, #1B3A5C);
	background-image: linear-gradient(180deg, rgba(15, 30, 50, 0.72) 0%, rgba(15, 30, 50, 0.82) 100%);
	color: #fff;
	overflow: hidden;
}

.index-hero::before {
	content: "";
	position: absolute;
	inset: -6%;
	background-image: var(--im-hero-image, linear-gradient(135deg, #1B3A5C, #2A5480));
	background-size: cover;
	background-position: center;
	z-index: 0;
	animation: index-ken-burns 22s ease-in-out alternate infinite;
}

@keyframes index-ken-burns {
	from { transform: scale(1); }
	to   { transform: scale(1.08); }
}

@media (prefers-reduced-motion: reduce) {
	.index-hero::before { animation: none; }
}

.index-hero__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: min(1200px, 92vw);
	margin-inline: auto;
	padding-inline: clamp(1.25rem, 4vw, 3rem);
}

.index-hero__eyebrow {
	margin: 0 0 1.25rem;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--im-accent, #D4A843);
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.75), 0 2px 10px rgba(0, 0, 0, 0.45);
}

.index-hero__title {
	margin-block: 0 1.25rem;
	font-family: "Heebo", sans-serif;
	font-size: clamp(2.75rem, 6.5vw, 4.5rem);
	line-height: 1.08;
	font-weight: 800;
	color: #fff;
	max-width: 16ch;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.25);
}

.index-hero__title::after {
	content: "";
	display: block;
	width: 3.5rem;
	height: 3px;
	background: var(--im-accent, #D4A843);
	margin-block-start: 1.25rem;
}

.index-hero__subtitle {
	margin-block: 0 2rem;
	font-size: clamp(1.05rem, 2vw, 1.25rem);
	line-height: 1.75;
	color: #ffffff;
	max-width: 42ch;
	font-weight: 400;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.7), 0 2px 14px rgba(0, 0, 0, 0.4);
}

.index-hero__cta-link {
	margin: 0;
}

.index-hero__cta-link a {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.9rem 2.25rem;
	background: var(--im-accent, #D4A843);
	color: var(--im-primary, #1B3A5C) !important;
	font-weight: 700;
	font-size: 1.05rem;
	text-decoration: none;
	border-radius: 50px;
	border-bottom: none;
	box-shadow: 0 4px 24px rgba(212, 168, 67, 0.45);
	transition: transform 0.22s var(--im-ease), box-shadow 0.22s, background 0.22s;
	position: relative;
	overflow: hidden;
}

.index-hero__cta-link a::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.18) 50%, transparent 100%);
	transform: translateX(-100%);
	transition: transform 0.5s var(--im-ease);
}

.index-hero__cta-link a:hover {
	transform: translateY(-3px);
	box-shadow: 0 10px 36px rgba(212, 168, 67, 0.6);
	background: #e8b93e;
}

.index-hero__cta-link a:hover::before {
	transform: translateX(100%);
}

.index-hero__cta-link a::after {
	content: "←";
	font-size: 1.1rem;
	transition: transform 0.22s var(--im-ease);
}

.index-hero__cta-link a:hover::after {
	transform: translateX(-4px);
}

/* Gold-underline links */
.index-link-cta {
	margin: 1rem 0 0;
}

.index-link-cta a {
	color: var(--im-primary, #1B3A5C);
	font-weight: 600;
	text-decoration: none;
	padding-block-end: 0.2rem;
	border-bottom: 2px solid transparent;
	transition: border-color 0.25s ease;
}

.index-link-cta a:hover {
	border-bottom-color: var(--im-accent, #D4A843);
}

.index-header__nav .wp-block-navigation-item__content:hover {
	color: var(--im-accent, #D4A843) !important;
}

@keyframes index-fade-up {
	from {
		opacity: 0;
		transform: translateY(24px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes index-bounce {
	0%, 100% { transform: translateX(-50%) translateY(0); }
	50% { transform: translateX(-50%) translateY(6px); }
}

/* ─── Trust bar ─── */
.index-trust {
	background: var(--im-stone, #F5F2ED);
	color: var(--im-text, #2D2D2D);
	margin-block: 0;
	padding-block: 2rem;
	position: relative;
	border-block: 1px solid rgba(176, 190, 197, 0.45);
}

.index-trust::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--im-aluminum, #B0BEC5), transparent);
}

.index-trust__shell {
	max-width: min(1440px, 94vw);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2.5rem);
}

.index-trust__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
	align-items: center;
}

.index-trust__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	text-align: center;
}

.index-trust__value {
	display: block;
	font-family: "Heebo", sans-serif;
	font-size: 1.5rem;
	color: var(--im-primary, #1B3A5C);
	line-height: 1.2;
	font-weight: 700;
}

.index-trust__label {
	display: block;
	font-size: 0.82rem;
	color: #6B7280;
	line-height: 1.35;
}

/* ─── Sections — alternating light / dark ─── */
.index-section {
	padding-block: var(--im-section-pad);
	margin-block: 0;
}

.index-hero + .index-section {
	padding-block-start: var(--im-section-pad-tight);
}

.index-section + .index-section {
	padding-block-start: var(--im-section-pad-tight);
}

.index-section + .index-trust {
	padding-block: 2rem;
}

.index-trust + .index-section,
.index-trust + .index-cta {
	padding-block-start: var(--im-section-pad-tight);
}

.index-section--light {
	background: var(--im-stone, #F5F2ED);
	color: var(--im-text, #2D2D2D);
}

.index-section--dark {
	background: var(--im-primary, #1B3A5C);
	color: #fff;
}

.index-section--dark .index-section__title {
	color: #fff;
}

.index-section--dark .index-section__subtitle {
	color: rgba(255, 255, 255, 0.82);
}

.index-section--dark .index-eyebrow {
	color: var(--im-aluminum, #B0BEC5);
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(176, 190, 197, 0.35);
}

.index-section--dark .index-link-cta a {
	color: #fff;
}

.index-section--dark .index-link-cta a:hover {
	border-bottom-color: var(--im-accent, #D4A843);
}

.index-section--stone {
	background: var(--im-stone, #F5F2ED);
}

.index-section--gallery {
	background: var(--im-stone, #F5F2ED);
}

.index-section--surface::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 20% 50%, rgba(12, 74, 110, 0.03) 0%, transparent 50%);
	pointer-events: none;
}

.index-section__title {
	text-align: center;
	margin-block: 0 0.5rem;
	font-family: "Heebo", sans-serif;
	font-size: clamp(1.85rem, 3.5vw, 2.5rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--im-primary, #1B3A5C);
}

.index-section__subtitle {
	text-align: center;
	color: #6B7280;
	max-width: 44ch;
	margin-inline: auto;
	margin-block: 0 3rem;
	font-size: 1.05rem;
	line-height: 1.65;
}

/* ─── Service cards (brand) ─── */
.index-services-row {
	gap: 1.5rem !important;
}

.index-service-card {
	border-radius: var(--im-radius-lg);
	overflow: hidden;
	border: 1px solid rgba(176, 190, 197, 0.45);
	background: #fff;
	height: 100%;
	box-shadow: var(--im-shadow);
	transition: transform 0.3s var(--im-ease), box-shadow 0.3s;
}

.index-service-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--im-shadow-lg);
}

.index-service-card__head {
	padding: 1.5rem 1.5rem 1.25rem;
	background: linear-gradient(135deg, var(--im-primary, #1B3A5C) 0%, #2A5480 100%);
	color: #fff;
	min-height: 7.5rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background-size: cover;
	background-position: center;
	position: relative;
}

.index-service-card__head::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(27, 58, 92, 0.88) 0%, rgba(42, 84, 128, 0.75) 100%);
}

.index-service-card--windows .index-service-card__head {
	background-image: var(--im-service-windows, none);
}

.index-service-card--doors .index-service-card__head {
	background-image: var(--im-service-doors, var(--im-service-railings, none));
}

.index-service-card--grilles .index-service-card__head {
	background-image: var(--im-service-grilles, var(--im-service-blinds, none));
}

.index-service-card__title,
.index-service-card__tagline {
	position: relative;
	z-index: 1;
}

.index-service-card__title {
	margin: 0 0 0.25rem;
	font-family: "Heebo", sans-serif;
	font-size: 1.2rem;
	font-weight: 700;
	color: #fff;
}

.index-service-card__tagline {
	margin: 0;
	font-size: 0.85rem;
	color: var(--im-aluminum, #B0BEC5);
}

.index-service-card__body {
	padding: 1.35rem 1.5rem 1.5rem;
}

.index-service-card__body p {
	margin: 0 0 0.75rem;
	color: #4B5563;
	line-height: 1.7;
	font-size: 0.95rem;
}

.index-service-card__price {
	margin-block-start: 1rem !important;
	font-size: 0.9rem !important;
	color: var(--im-primary, #1B3A5C) !important;
}

.index-service-card__price strong {
	font-weight: 700;
	color: var(--im-primary, #1B3A5C);
}

/* ─── Service cards ─── */
.index-card {
	position: relative;
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: var(--im-radius-lg);
	padding: 2rem 1.75rem;
	height: 100%;
	box-shadow: var(--im-shadow);
	transition:
		transform 0.3s var(--im-ease),
		box-shadow 0.3s var(--im-ease),
		border-color 0.3s;
	overflow: hidden;
}

.index-card--with-image {
	padding: 0;
	display: flex;
	flex-direction: column;
}

.index-card__thumb {
	margin: 0;
	aspect-ratio: 16 / 10;
	background-size: cover;
	background-position: center;
	transition: transform 0.5s var(--im-ease);
}

.index-card--service-blinds .index-card__thumb {
	background-image:
		linear-gradient(135deg, rgba(12, 74, 110, 0.35), rgba(15, 23, 42, 0.2)),
		var(--im-service-blinds, linear-gradient(135deg, #1e3a5f, #0f172a));
}

.index-card--service-windows .index-card__thumb {
	background-image:
		linear-gradient(135deg, rgba(12, 74, 110, 0.35), rgba(15, 23, 42, 0.2)),
		var(--im-service-windows, linear-gradient(135deg, #334155, #0c4a6e));
}

.index-card--service-railings .index-card__thumb {
	background-image:
		linear-gradient(135deg, rgba(12, 74, 110, 0.35), rgba(15, 23, 42, 0.2)),
		var(--im-service-railings, linear-gradient(135deg, #475569, #1e293b));
}

.index-card--service-repairs .index-card__thumb {
	background-image:
		linear-gradient(135deg, rgba(12, 74, 110, 0.35), rgba(15, 23, 42, 0.2)),
		var(--im-service-repairs, linear-gradient(135deg, #0c4a6e, #082f49));
}

.index-card--with-image:hover .index-card__thumb {
	transform: scale(1.04);
}

.index-card__body {
	padding: 1.5rem 1.75rem 2rem;
	flex: 1;
}

.index-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--im-accent, #d4a853), var(--im-primary, #0c4a6e));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.35s var(--im-ease);
}

body.rtl .index-card::before {
	transform-origin: right;
}

.index-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--im-shadow-lg);
	border-color: rgba(176, 190, 197, 0.6);
}

.index-card:hover::before {
	transform: scaleX(1);
}

.index-card__icon {
	width: 48px;
	height: 48px;
	border-radius: 8px;
	background: linear-gradient(135deg, var(--im-secondary, #0f172a), var(--im-primary, #0c4a6e));
	color: var(--im-accent, #d4a853);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: "Heebo", sans-serif;
	font-size: 0.95rem;
	margin-bottom: 1.25rem;
}

.index-card h3 {
	margin-block: 0 0.6rem;
	font-family: "Heebo", sans-serif;
	font-size: 1.2rem;
	font-weight: 400;
}

.index-card p:last-child {
	margin-bottom: 0;
	color: #64748b;
	line-height: 1.7;
}

/* ─── Why us ─── */
.index-why {
	background: #fff;
}

.index-why__lead {
	margin: 0;
	font-size: 1.15rem;
	line-height: 1.75;
	color: #475569;
}

.index-why__cards {
	margin-block-start: 2.5rem;
	gap: 1.25rem;
}

.index-why-card {
	padding: 1.75rem;
	border-radius: var(--im-radius-lg);
	background: linear-gradient(145deg, #f8fafc, #fff);
	border: 1px solid #e2e8f0;
	height: 100%;
	transition: transform 0.3s var(--im-ease), box-shadow 0.3s;
}

.index-why-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--im-shadow);
}

.index-why-card__num {
	margin: 0 0 1rem;
	font-family: "Heebo", sans-serif;
	font-size: 2rem;
	line-height: 1;
	color: var(--im-accent, #d4a853);
	opacity: 0.9;
}

.index-why-card h3 {
	margin-block: 0 0.5rem;
	font-family: "Heebo", sans-serif;
	font-size: 1.15rem;
	font-weight: 400;
}

.index-why-card p {
	margin: 0;
	color: #64748b;
	line-height: 1.65;
}

/* ─── Projects ─── */
.index-project-card {
	background: #fff;
	border-radius: var(--im-radius-lg);
	overflow: hidden;
	box-shadow: var(--im-shadow);
	border: 1px solid #e2e8f0;
	height: 100%;
	transition: transform 0.35s var(--im-ease), box-shadow 0.35s;
}

.index-project-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--im-shadow-lg);
}

.index-project-card__image {
	margin: 0;
	aspect-ratio: 4/3;
	overflow: hidden;
}

.index-project-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s var(--im-ease);
}

.index-project-card:hover .index-project-card__image img {
	transform: scale(1.07);
}

.index-project-card__body {
	padding: 1.25rem 1.5rem 1.5rem;
}

.index-project-card__tag {
	display: inline-block;
	margin: 0 0 0.5rem;
	padding: 0.2rem 0.65rem;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--im-primary, #0c4a6e);
	background: rgba(12, 74, 110, 0.08);
	border-radius: 4px;
}

.index-project-card h4 {
	margin: 0 0 0.35rem;
	font-family: "Heebo", sans-serif;
	font-weight: 400;
	font-size: 1.1rem;
}

.index-project-card__body > p {
	margin: 0;
}

/* ─── Testimonials ─── */
.index-testimonial {
	border-inline-start: none;
}

.index-testimonial p:first-child {
	font-size: 1.05rem;
	line-height: 1.75;
	color: #334155;
}

/* ─── FAQ ─── */
.index-faq details {
	border: 1px solid #e2e8f0;
	border-radius: var(--im-radius);
	padding: 0;
	margin-bottom: 0.75rem;
	background: #fff;
	overflow: hidden;
	transition: box-shadow 0.25s;
}

.index-faq details:hover {
	box-shadow: 0 4px 16px rgba(8, 47, 73, 0.06);
}

.index-faq details[open] {
	border-color: rgba(12, 74, 110, 0.25);
	box-shadow: var(--im-shadow);
}

.index-faq summary {
	cursor: pointer;
	font-weight: 600;
	list-style: none;
	padding: 1.1rem 1.35rem;
	padding-inline-end: 2.75rem;
	position: relative;
	transition: color 0.2s, background 0.2s;
}

.index-faq summary::-webkit-details-marker {
	display: none;
}

.index-faq summary::after {
	content: "+";
	position: absolute;
	inset-inline-end: 1.25rem;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.35rem;
	font-weight: 400;
	color: var(--im-accent, #d4a853);
	transition: transform 0.25s var(--im-ease);
}

.index-faq details[open] summary {
	color: var(--im-primary, #0c4a6e);
	background: rgba(12, 74, 110, 0.04);
}

.index-faq details[open] summary::after {
	content: "−";
}

.index-faq details > p {
	margin: 0;
	padding: 0 1.35rem 1.1rem;
	color: #64748b;
	line-height: 1.7;
}

/* ─── CTA ─── */
.index-cta {
	text-align: center;
	margin-block-end: 0;
	padding-block: var(--im-section-pad);
	background: var(--im-primary, #1B3A5C);
	color: #fff;
	position: relative;
}

.index-cta h2 {
	margin-block: 0 0.75rem;
	font-family: "Heebo", sans-serif;
	font-weight: 700;
	font-size: clamp(1.75rem, 3.5vw, 2.35rem);
	color: #fff;
}

.index-cta p {
	color: rgba(255, 255, 255, 0.85);
	margin-block: 0 1.75rem;
	font-size: 1.05rem;
}

.index-cta .index-btn--primary .wp-block-button__link {
	background: transparent !important;
	color: #fff !important;
	border: none !important;
	border-bottom: 2px solid var(--im-accent, #D4A843) !important;
	border-radius: 0 !important;
	padding: 0.5rem 0 !important;
	box-shadow: none !important;
}

.index-cta .index-btn--ghost .wp-block-button__link {
	background: transparent !important;
	color: rgba(255, 255, 255, 0.9) !important;
	border: 1.5px solid rgba(255, 255, 255, 0.4) !important;
	border-radius: 8px !important;
}

.index-cta--light {
	background: var(--im-stone, #F5F2ED);
	color: var(--im-text, #2D2D2D);
}

.index-cta--light h2 {
	color: var(--im-primary, #1B3A5C);
}

.index-cta--light p {
	color: #6B7280;
}

.index-cta--light .index-btn--primary .wp-block-button__link {
	color: var(--im-primary, #1B3A5C) !important;
	border-bottom-color: var(--im-accent, #D4A843) !important;
}

.index-cta--light .index-btn--ghost .wp-block-button__link {
	color: var(--im-primary, #1B3A5C) !important;
	border-color: rgba(27, 58, 92, 0.35) !important;
}

.index-section--dark .index-blog-teaser__head {
	align-items: center;
	justify-content: center;
	flex-direction: column;
	text-align: center;
}

.index-section--dark .index-blog-teaser__head .wp-block-buttons {
	margin-block-start: 1rem;
}

.index-section--dark .index-blog-teaser__head .wp-block-button.is-style-outline .wp-block-button__link {
	color: #fff !important;
	border-color: rgba(255, 255, 255, 0.45) !important;
}

/* ─── Inner pages ─── */
.index-page-hero {
	padding-block: clamp(3rem, 8vw, 4.5rem);
	background:
		linear-gradient(135deg, var(--im-secondary, #0f172a), var(--im-primary, #0c4a6e));
	color: #fff;
	text-align: center;
	margin-block-end: 0;
}

.index-page-hero__title {
	margin: 0;
	font-family: "Heebo", sans-serif;
	font-size: clamp(1.85rem, 4.5vw, 2.75rem);
	font-weight: 400;
	color: #fff;
}

.index-page-hero__sub {
	margin: 0.75rem 0 0;
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.82);
	max-width: 52ch;
	margin-inline: auto;
}

.index-page-hero__inner {
	max-width: min(1440px, 94vw);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2.5rem);
}

.index-page-content {
	padding-block: clamp(2.5rem, 5vw, 4rem);
	max-width: min(1200px, 94vw);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2.5rem);
}

/* ─── Contact ─── */
.index-contact-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.25rem;
	margin-block: 2rem;
}

.index-contact-card {
	background: #f8fafc;
	border-radius: var(--im-radius-lg);
	padding: 1.5rem;
	border-inline-start: 4px solid var(--im-accent, #d4a853);
	transition: transform 0.25s var(--im-ease);
}

.index-contact-card:hover {
	transform: translateY(-3px);
}

.index-contact-card h3 {
	margin-block: 0 0.35rem;
	font-size: 0.8rem;
	color: #64748b;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.index-contact-card p {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 600;
}

.index-contact-card a {
	color: var(--im-primary, #0c4a6e);
	text-decoration: none;
}

.index-contact-form {
	margin-block: 2rem;
	padding: 2rem;
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: var(--im-radius-lg);
	box-shadow: var(--im-shadow);
}

.index-cf7 p {
	margin-block: 0 1.25rem;
}

.index-cf7 label {
	display: block;
	font-weight: 500;
	margin-bottom: 0.4rem;
}

.index-cf7 input[type="text"],
.index-cf7 input[type="tel"],
.index-cf7 input[type="email"],
.index-cf7 select,
.index-cf7 textarea {
	width: 100%;
	padding: 0.8rem 1rem;
	border: 1px solid #d1d5db;
	border-radius: var(--im-radius);
	font-family: inherit;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.index-cf7 input:focus,
.index-cf7 select:focus,
.index-cf7 textarea:focus {
	outline: none;
	border-color: var(--im-primary, #0c4a6e);
	box-shadow: 0 0 0 3px rgba(12, 74, 110, 0.12);
}

.index-cf7 input[type="submit"] {
	background: var(--im-accent, #d4a853);
	color: var(--im-secondary, #0f172a);
	border: none;
	padding: 0.9rem 2.25rem;
	font-weight: 700;
	cursor: pointer;
	border-radius: 4px;
	transition: transform 0.2s, box-shadow 0.2s;
}

.index-cf7 input[type="submit"]:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(212, 168, 83, 0.35);
}

/* ─── Blog ─── */
.index-blog-teaser__head {
	margin-block-end: 2.5rem;
	gap: 1.5rem;
	align-items: flex-end;
}

.index-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

.index-blog-query > .wp-block-post-template,
.index-blog-query .wp-block-post-template.index-blog-grid {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

.index-blog-card {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: var(--im-radius-lg);
	overflow: hidden;
	height: 100%;
	box-shadow: var(--im-shadow);
	transition: transform 0.3s var(--im-ease), box-shadow 0.3s;
	display: flex;
	flex-direction: column;
}

.index-blog-card__image {
	margin: 0;
	position: relative;
	background: linear-gradient(135deg, #e2e8f0, #cbd5e1);
}

.index-blog-card__image::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 55%, rgba(15, 23, 42, 0.35));
	pointer-events: none;
}

.index-blog-card__body {
	padding: 0 1.25rem 1.35rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.index-blog-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--im-shadow-lg);
}

.index-blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 16 / 9;
	transition: transform 0.45s var(--im-ease);
}

.index-blog-card:hover .index-blog-card__image img {
	transform: scale(1.05);
}

.index-blog-card__date {
	margin: 1rem 1.25rem 0;
	font-size: 0.8rem !important;
	color: #94a3b8 !important;
}

.index-blog-card__title {
	margin: 0.35rem 1.25rem 0;
	font-family: "Heebo", sans-serif;
	font-size: 1.15rem;
	font-weight: 400;
	line-height: 1.35;
}

.index-blog-card__title a {
	color: var(--im-secondary, #0f172a);
	text-decoration: none;
	transition: color 0.2s;
}

.index-blog-card__title a:hover {
	color: var(--im-primary, #0c4a6e);
}

.index-blog-card .wp-block-post-excerpt {
	margin: 0.5rem 1.25rem 1.25rem;
	color: #64748b;
	font-size: 0.95rem;
	line-height: 1.65;
}

.index-blog-card .wp-block-post-excerpt__more-link {
	color: var(--im-primary, #0c4a6e);
	font-weight: 600;
	text-decoration: none;
}

.index-blog-pagination {
	margin-block-start: 2.5rem;
	gap: 0.5rem;
}

.index-blog-pagination .page-numbers {
	padding: 0.5rem 0.85rem;
	border-radius: 4px;
	text-decoration: none;
	color: var(--im-primary, #0c4a6e);
	border: 1px solid #e2e8f0;
}

.index-blog-pagination .page-numbers.current {
	background: var(--im-primary, #0c4a6e);
	color: #fff;
	border-color: var(--im-primary, #0c4a6e);
}

.index-blog-single-hero {
	padding-block: clamp(2.5rem, 6vw, 4rem);
	background:
		linear-gradient(135deg, var(--im-secondary, #0f172a) 0%, var(--im-primary, #0c4a6e) 100%);
	color: #fff;
}

.index-blog-single-hero__inner {
	max-width: min(900px, 92vw);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2rem);
	text-align: center;
}

.index-blog-back {
	margin: 0 0 1.25rem;
	font-size: 0.9rem;
}

.index-blog-back a {
	color: rgba(255, 255, 255, 0.75);
	text-decoration: none;
	transition: color 0.2s;
}

.index-blog-back a:hover {
	color: var(--im-accent, #d4a853);
}

.index-blog-single-hero__title {
	margin: 0;
	font-family: "Heebo", sans-serif;
	font-size: clamp(1.85rem, 4.5vw, 2.85rem);
	line-height: 1.15;
	font-weight: 400;
	color: #fff;
}

.index-blog-meta--single {
	justify-content: center;
	margin-block-start: 1rem;
}

.index-blog-meta__date {
	color: rgba(255, 255, 255, 0.72) !important;
	font-size: 0.9rem;
}

.index-blog-single-layout {
	max-width: min(1200px, 94vw);
	margin-inline: auto;
	padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 3vw, 2rem);
	display: grid;
	grid-template-columns: minmax(0, 1fr) 300px;
	gap: clamp(2rem, 4vw, 3rem);
	align-items: start;
}

.index-blog-single-article {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: var(--im-radius-lg);
	box-shadow: var(--im-shadow);
	overflow: hidden;
}

.index-blog-single__image {
	margin: 0;
}

.index-blog-single__image img {
	width: 100%;
	height: auto;
	display: block;
}

.index-blog-single__content {
	padding: clamp(1.75rem, 4vw, 2.75rem);
}

.index-blog-single__content > *:first-child {
	margin-block-start: 0;
}

.index-blog-single__content h2 {
	font-family: "Heebo", sans-serif;
	font-size: 1.45rem;
	font-weight: 400;
	color: var(--im-secondary, #0f172a);
	margin-block: 2.25rem 0.85rem;
	padding-block-end: 0.5rem;
	border-bottom: 2px solid rgba(212, 168, 83, 0.35);
}

.index-blog-single__content h2:first-of-type {
	margin-block-start: 0;
}

.index-blog-single__content p {
	font-size: 1.0625rem;
	line-height: 1.85;
	color: #334155;
	margin-block: 0 1.25rem;
}

.index-blog-single__content ul,
.index-blog-single__content ol {
	margin-block: 0 1.5rem;
	padding-inline-start: 1.35rem;
	color: #334155;
	line-height: 1.8;
}

.index-blog-single__content li {
	margin-bottom: 0.5rem;
}

.index-blog-single__content li::marker {
	color: var(--im-accent, #d4a853);
}

.index-blog-single__content a {
	color: var(--im-primary, #0c4a6e);
	font-weight: 600;
}

.index-blog-single__content table {
	width: 100%;
	border-collapse: collapse;
	margin-block: 1.5rem 2rem;
	font-size: 0.95rem;
}

.index-blog-single__content th,
.index-blog-single__content td {
	border: 1px solid #e2e8f0;
	padding: 0.75rem 1rem;
	text-align: start;
}

.index-blog-single__content th {
	background: #f8fafc;
	font-weight: 600;
	color: var(--im-secondary, #0f172a);
}

.index-blog-single-aside {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	position: sticky;
	top: 5.5rem;
}

.index-blog-aside-card {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: var(--im-radius-lg);
	padding: 1.5rem;
	box-shadow: var(--im-shadow);
}

.index-blog-aside-card h3 {
	margin: 0 0 0.75rem;
	font-family: "Heebo", sans-serif;
	font-size: 1.1rem;
	font-weight: 400;
}

.index-blog-aside-card p {
	margin: 0 0 1rem;
	color: #64748b;
	line-height: 1.65;
	font-size: 0.95rem;
}

.index-blog-aside-card--muted {
	background: linear-gradient(180deg, #f8fafc, #fff);
}

.index-blog-latest {
	margin: 0;
	padding: 0;
	list-style: none;
}

.index-blog-latest li {
	margin: 0 0 0.85rem;
	padding-block-end: 0.85rem;
	border-bottom: 1px solid #e2e8f0;
}

.index-blog-latest li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}

.index-blog-latest a {
	color: var(--im-secondary, #0f172a);
	text-decoration: none;
	font-weight: 500;
	line-height: 1.45;
	transition: color 0.2s;
}

.index-blog-latest a:hover {
	color: var(--im-primary, #0c4a6e);
}

.index-blog-meta {
	justify-content: center;
	gap: 1rem;
	margin-block-start: 0.75rem;
	color: rgba(255, 255, 255, 0.75);
	font-size: 0.9rem;
}

/* ─── Footer ─── */
.index-footer {
	margin-block-start: 0;
	background: var(--im-primary, #1B3A5C);
	color: rgba(255, 255, 255, 0.88);
	padding-block: 3.5rem 2rem;
}

.index-footer__shell {
	max-width: min(1440px, 94vw);
	margin-inline: auto;
	padding-inline: clamp(1rem, 3vw, 2.5rem);
}

.index-footer h4,
.index-footer .wp-block-site-title a {
	color: #fff;
	font-family: "Heebo", sans-serif;
	font-weight: 400;
}

.index-footer a {
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	transition: color 0.2s;
}

.index-footer a:hover {
	color: var(--im-accent, #d4a853);
}

.index-footer__sep {
	border: none !important;
	border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
	margin-block: 2rem 1.25rem;
}

.index-footer__legal {
	gap: 0.5rem 1.5rem;
	text-align: center;
}

.index-footer__legal p {
	margin: 0;
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.875rem;
}

/* ─── Typography (inner content) ─── */
main h1,
.index-page-content h1,
main h2,
.index-page-content h2 {
	font-family: "Heebo", sans-serif;
	font-weight: 700;
}

main p,
main li,
.index-page-content p,
.index-page-content li {
	line-height: 1.8;
	color: #334155;
}

main ol,
.index-page-content ol {
	padding-inline-start: 1.25rem;
}

body.index-master-rtl .index-hero__subtitle,
.rtl .index-hero__subtitle {
	margin-inline-start: 0;
	margin-inline-end: auto;
}

:focus-visible {
	outline: 2px solid var(--im-accent, #d4a853);
	outline-offset: 3px;
}

/* ─── Responsive ─── */
@media (max-width: 900px) {
	.index-hero__grid {
		flex-direction: column;
	}

	.index-hero__grid > .wp-block-column {
		flex-basis: 100% !important;
	}

	.index-hero__title {
		max-width: none;
	}

	.index-hero__panel {
		margin-block-start: 1.5rem;
	}

	.index-hero__scroll {
		display: none;
	}

	.index-blog-grid,
	.index-blog-grid--archive,
	.index-blog-query > .wp-block-post-template,
	.index-blog-query .wp-block-post-template.index-blog-grid {
		grid-template-columns: 1fr;
	}

	.index-blog-teaser__head {
		flex-direction: column;
		align-items: flex-start;
	}

	.index-trust__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.index-blog-single-layout {
		grid-template-columns: 1fr;
	}

	.index-blog-single-aside {
		position: static;
	}

	.index-why__intro {
		flex-direction: column;
	}

	.index-why__intro > .wp-block-column {
		flex-basis: 100% !important;
	}

	.index-section__title--start {
		text-align: center !important;
	}

	.index-why__lead {
		text-align: center;
	}

	.index-eyebrow {
		margin-inline: auto;
	}
}

@media (max-width: 781px) {
	.index-header__inner {
		flex-wrap: nowrap;
	}

	.index-header-actions {
		width: auto;
		margin-block-start: 0;
		flex-shrink: 0;
		gap: 0.5rem;
	}

	.index-header__cta .wp-block-button__link {
		padding: 0.5rem 0.75rem !important;
		font-size: 0.8rem !important;
	}

	.index-header__nav {
		width: auto;
	}

	body {
		padding-block-end: 4.25rem;
	}
}

.index-mobile-bar {
	display: none;
}

@media (max-width: 781px) {
	.index-mobile-bar {
		display: flex;
		position: fixed;
		inset-inline: 0;
		bottom: 0;
		z-index: 250;
		background: var(--im-secondary, #0f172a);
		border-top: 2px solid var(--im-accent, #d4a853);
		padding: 0.65rem 1rem calc(0.65rem + env(safe-area-inset-bottom));
		gap: 0.65rem;
		box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.25);
	}

	.index-mobile-bar__call,
	.index-mobile-bar__contact {
		flex: 1;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 0.85rem 1rem;
		border-radius: 6px;
		font-weight: 700;
		text-decoration: none;
		font-size: 0.95rem;
	}

	.index-mobile-bar__call {
		background: var(--im-accent, #d4a853);
		color: var(--im-secondary, #0f172a);
	}

	.index-mobile-bar__contact {
		background: rgba(255, 255, 255, 0.1);
		color: #fff;
		border: 1px solid rgba(255, 255, 255, 0.25);
	}

	.index-mobile-bar__contact--full {
		flex: 1;
		background: var(--im-accent, #d4a853);
		color: var(--im-secondary, #0f172a);
		border: none;
		font-weight: 700;
	}
}

@media (min-width: 782px) and (max-width: 1100px) {
	.index-blog-grid,
	.index-blog-grid--archive,
	.index-blog-query > .wp-block-post-template,
	.index-blog-query .wp-block-post-template.index-blog-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ─── Page hero — upgraded ─── */
.index-page-hero {
	padding-block: clamp(3.5rem, 9vw, 5.5rem);
	background:
		linear-gradient(135deg, rgba(27, 58, 92, 0.96) 0%, rgba(15, 30, 50, 0.98) 100%),
		var(--im-hero-image, none);
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
}

.index-page-hero::before {
	content: "";
	position: absolute;
	inset-inline-end: -5%;
	top: -20%;
	width: 55%;
	height: 140%;
	background: radial-gradient(ellipse at center, rgba(212, 168, 67, 0.07) 0%, transparent 70%);
	pointer-events: none;
}

.index-page-hero__title {
	font-family: "Heebo", sans-serif !important;
	font-weight: 800 !important;
	font-size: clamp(2rem, 5vw, 3.25rem) !important;
}

.index-page-hero__title::after {
	content: "";
	display: block;
	width: 75%;
	max-width: 100%;
	height: 3px;
	background: var(--im-accent, #D4A843);
	margin-block-start: 1rem;
	margin-inline: auto;
}

/* ─── Page body (post-content) — better prose ─── */
.index-page-body {
	padding-block: clamp(2.5rem, 5vw, 4rem);
}

.index-page-body h2,
.index-page-content h2 {
	color: var(--im-primary, #1B3A5C);
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin-block: 2.5rem 0.75rem;
	padding-block-end: 0.5rem;
	border-bottom: 2px solid rgba(176, 190, 197, 0.3);
}

.index-page-body h2:first-child,
.index-page-content h2:first-child {
	margin-block-start: 0;
}

.index-page-body ul,
.index-page-body ol,
.index-page-content ul,
.index-page-content ol {
	margin-block: 0.5rem 1.25rem;
}

.index-page-body li,
.index-page-content li {
	margin-block-end: 0.35rem;
}

.index-page-body strong,
.index-page-content strong {
	color: var(--im-primary, #1B3A5C);
}

.index-page-body p,
.index-page-body li {
	line-height: 1.8;
	color: #334155;
}

/* ═══════════════════════════════════════════════
   DESIGN UPGRADE — v2.2.0
   ═══════════════════════════════════════════════ */

/* ─── Stagger reveal — cards reveal one by one ─── */
.wp-block-columns .wp-block-column:nth-child(1) .index-reveal { transition-delay: 0ms; }
.wp-block-columns .wp-block-column:nth-child(2) .index-reveal { transition-delay: 120ms; }
.wp-block-columns .wp-block-column:nth-child(3) .index-reveal { transition-delay: 240ms; }
.wp-block-columns .wp-block-column:nth-child(4) .index-reveal { transition-delay: 360ms; }

/* ─── Testimonials — stars + quote mark ─── */
.index-testimonial {
	position: relative;
	border-inline-start: none;
	padding-top: 1.5rem;
	overflow: hidden;
}

.index-testimonial::before {
	content: "\201C";
	position: absolute;
	inset-inline-end: 1rem;
	top: -0.75rem;
	font-family: "Heebo", sans-serif;
	font-size: 6rem;
	font-weight: 800;
	line-height: 1;
	color: var(--im-accent, #D4A843);
	opacity: 0.12;
	pointer-events: none;
	user-select: none;
}

.index-testimonial p:first-child::before {
	content: "★★★★★";
	display: block;
	color: var(--im-accent, #D4A843);
	font-size: 0.85rem;
	letter-spacing: 0.15em;
	margin-block-end: 0.65rem;
}

/* ─── Why-us — watermark number ─── */
.index-why-card {
	position: relative;
	overflow: hidden;
	isolation: isolate;
}

.index-why-card__num {
	position: absolute;
	inset-inline-end: 0.5rem;
	top: -0.75rem;
	font-size: 5.5rem;
	font-family: "Heebo", sans-serif;
	font-weight: 900;
	line-height: 1;
	color: var(--im-accent, #D4A843);
	opacity: 0.08;
	pointer-events: none;
	user-select: none;
	margin: 0;
	z-index: 0;
}

.index-why-card > *:not(.index-why-card__num) {
	position: relative;
	z-index: 1;
}

/* ─── Project card — hover image overlay ─── */
.index-project-card__image {
	position: relative;
}

.index-project-card__image::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 35%, rgba(15, 30, 50, 0.72) 100%);
	opacity: 0;
	transition: opacity 0.35s var(--im-ease);
}

.index-project-card:hover .index-project-card__image::after {
	opacity: 1;
}

/* ─── Service card head — hover zoom ─── */
.index-service-card__head {
	transition: filter 0.4s var(--im-ease);
}

.index-service-card:hover .index-service-card__head {
	filter: brightness(1.12);
}

/* ─── Trust bar — counter values ─── */
.index-trust__value[data-count] {
	display: inline-block;
	transition: transform 0.3s var(--im-ease);
}

/* ─── CTA section — shimmer on button ─── */
.index-cta .wp-block-button__link {
	position: relative;
	overflow: hidden;
}

.index-cta .wp-block-button__link::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.15) 50%, transparent 100%);
	transform: translateX(-120%);
	animation: index-btn-shimmer 3.5s ease-in-out 1.5s infinite;
}

@keyframes index-btn-shimmer {
	0%   { transform: translateX(-120%); }
	40%  { transform: translateX(120%); }
	100% { transform: translateX(120%); }
}

@media (prefers-reduced-motion: reduce) {
	.index-cta .wp-block-button__link::after { animation: none; }
}

/* ─── Hero inner z-index fix ─── */
.index-hero__inner {
	z-index: 2;
}

.index-hero__eyebrow,
.index-hero__title,
.index-hero__subtitle,
.index-hero__cta-link {
	position: relative;
	z-index: 2;
}
