/* Плавная прокрутка к якорям (#uslugi, #zayavka, …); уважение prefers-reduced-motion */
@media (prefers-reduced-motion: no-preference) {
	html {
		scroll-behavior: smooth;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

/* Отступ под липкую шапку при переходе по якорю */
@media (min-width: 1025px) {
	html {
		scroll-padding-top: 100px;
	}
}

@media (max-width: 1024px) {
	html {
		scroll-padding-top: 72px;
	}
}

/* Дополнения к Elementor: нативная форма заявки (сетка 4 колонки: 25+25+50, без «плывущего» flex+gap) */
.site-lead-form {
	width: 100%;
	max-width: 100%;
}

.site-lead-form .elementor-form-fields-wrapper {
	display: grid !important;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 14px 16px;
	align-items: end;
	box-sizing: border-box;
	width: 100%;
}

.site-lead-form .elementor-form-fields-wrapper > .elementor-field-group.elementor-col-25 {
	grid-column: span 1;
	margin-bottom: 0;
	min-width: 0;
}

.site-lead-form .elementor-form-fields-wrapper > .elementor-field-group.elementor-col-50 {
	grid-column: span 2;
	margin-bottom: 0;
	min-width: 0;
}

.site-lead-form .elementor-form-fields-wrapper > .elementor-field-group.elementor-col-100 {
	grid-column: 1 / -1;
	margin-bottom: 0;
	min-width: 0;
}

/* Внутри CSS-grid ячейка не должна вылезать за minmax(0,1fr) — иначе поля «слипаются» с соседями */
.site-lead-form .elementor-field-group.elementor-column[class*='elementor-col-'] {
	width: auto !important;
	max-width: 100% !important;
	min-width: 0;
}

.site-lead-form .elementor-field-group {
	display: block !important;
	flex-wrap: unset !important;
	align-items: stretch !important;
}

.site-lead-form .elementor-field,
.site-lead-form input.elementor-field,
.site-lead-form textarea.elementor-field,
.site-lead-form select.elementor-field-textual {
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0 !important;
	box-sizing: border-box;
	flex: none !important;
	flex-basis: auto !important;
}

.site-lead-form .elementor-form-fields-wrapper.elementor-labels-above .elementor-field-group > input,
.site-lead-form .elementor-form-fields-wrapper.elementor-labels-above .elementor-field-group > .elementor-select-wrapper {
	flex: none !important;
	flex-basis: auto !important;
	width: 100% !important;
	max-width: 100% !important;
}

.site-lead-form .elementor-field-type-tel.elementor-field-group {
	min-width: 0;
}

/* size="1" в старой разметке давал ширину в 1 символ — подстраховка */
.site-lead-form input[type='text'].elementor-field,
.site-lead-form input[type='tel'].elementor-field {
	min-height: 42px;
	display: block !important;
}

.site-lead-form .elementor-element-a1ee3bb .elementor-widget-container,
.site-lead-form .elementor-widget-form .elementor-widget-container {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* Виджет формы в Elementor с width:initial — ограничивает поля «капсулами» */
.elementor.elementor-88 .elementor-element.elementor-element-a1ee3bb {
	width: 100% !important;
	max-width: 1000px !important;
	--container-widget-width: 100% !important;
}

.elementor.elementor-88 .elementor-element.elementor-element-a1ee3bb > .elementor-widget-container {
	width: 100% !important;
	max-width: 100% !important;
}

.site-lead-form input.elementor-field-textual,
.site-lead-form select.elementor-field-textual,
.site-lead-form textarea.elementor-field-textual {
	border-radius: 6px !important;
	min-width: 0;
}

.site-lead-form .elementor-select-wrapper {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

.site-lead-form button.elementor-button {
	cursor: pointer;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}

/* Ответ после успешной AJAX-отправки заявки */
.site-lead-thanks {
	max-width: 42rem;
	margin: 0 auto;
	padding: 1.25rem 1.35rem;
	border-radius: 12px;
	background: linear-gradient(180deg, #f4fbf6 0%, #ecf8f0 100%);
	border: 1px solid rgba(22, 138, 61, 0.22);
	box-shadow: 0 6px 24px rgba(22, 138, 61, 0.08);
	font-family: system-ui, 'Segoe UI', Roboto, Arial, sans-serif;
	color: #0f2418;
	text-align: center;
}

.site-lead-thanks__line {
	margin: 0 0 0.65rem;
	font-size: 1rem;
	line-height: 1.5;
}

.site-lead-thanks__line:last-child {
	margin-bottom: 0;
}

.site-lead-thanks__name {
	color: #126b32;
	font-weight: 700;
}

.site-lead-thanks__service {
	font-weight: 600;
	color: #0d4d24;
}

.site-lead-thanks__muted {
	font-size: 0.95rem;
	color: #3d5345;
}

.site-lead-thanks__actions {
	margin: 1rem 0 0;
}

.site-lead-thanks__call {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.65rem 1.1rem;
	border-radius: 10px;
	font-weight: 700;
	font-size: 1rem;
	text-decoration: none;
	color: #fff;
	background: linear-gradient(180deg, #1fa34a 0%, #168a3d 100%);
	border: 1px solid rgba(255, 255, 255, 0.25);
	box-shadow: 0 2px 0 rgba(0, 0, 0, 0.08);
}

.site-lead-thanks__call:hover {
	filter: brightness(1.05);
}

.site-lead-thanks__call:focus-visible {
	outline: 3px solid #126b32;
	outline-offset: 2px;
}

@media (max-width: 767px) {
	.site-lead-form .elementor-form-fields-wrapper {
		grid-template-columns: 1fr;
	}

	.site-lead-form .elementor-form-fields-wrapper > .elementor-field-group.elementor-col-25,
	.site-lead-form .elementor-form-fields-wrapper > .elementor-field-group.elementor-col-50 {
		grid-column: 1 / -1;
	}
}

/*
 * Шапка f309ca9: телефоны и мессенджеры (0a339cb) — всегда первой строкой на всех ширинах
 * (единый брейкоинт с Elementor tablet ≤1024 и desktop ≥1025).
 */
.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner {
	display: flex !important;
	flex-wrap: wrap !important;
	align-items: center;
	row-gap: 10px;
	column-gap: clamp(8px, 2vw, 20px);
}

.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-0a339cb {
	order: -10;
	flex: 1 0 100%;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	display: flex !important;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 8px 18px;
}

@media (min-width: 1025px) {
	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-0a339cb {
		justify-content: flex-start;
	}
}

/*
 * Шапка (контейнер f309ca9): на узком экране
 * виджет «липкий» Elementor Pro опирается на jQuery Sticky и часто не активируется.
 * Нативный position:sticky + z-index дублирует поведение десктопа.
 * Брейкпоинт до 1024px совпадает с tablet в настройках Elementor для этой страницы.
 */
@media (max-width: 1024px) {
	.elementor.elementor-88 .elementor-element.elementor-element-f309ca9 {
		position: -webkit-sticky !important;
		position: sticky !important;
		top: 0 !important;
		z-index: 1000 !important;
		align-self: flex-start;
		width: 100%;
	}

	/* overflow у предков ломает sticky; на лендинге горизонтальный скролл не нужен */
	.elementor.elementor-88,
	body.elementor-page-88 {
		overflow-x: visible !important;
	}

	/*
	 * Виджет меню в шапке (3a6ff21) в колонке flex: выпадающий блок с position:absolute
	 * привязан к узкой ячейке — на планшете/мобиле «уезжает» вправо. При открытии бургера
	 * растягиваем панель на ширину viewport и фиксируем top через --g2-dropdown-top (site.js).
	 */
	.elementor-element-3a6ff21 .elementor-menu-toggle.elementor-active
		+ .elementor-nav-menu--dropdown.elementor-nav-menu__container {
		position: fixed !important;
		left: 0 !important;
		right: 0 !important;
		width: 100% !important;
		max-width: none !important;
		margin: 0 !important;
		transform: none !important;
		transform-origin: top center !important;
		z-index: 10050 !important;
		top: var(--g2-dropdown-top, 96px) !important;
		max-height: calc(100dvh - var(--g2-dropdown-top, 96px)) !important;
		box-sizing: border-box;
		overflow-y: auto !important;
		overflow-x: hidden !important;
		background: #fff;
		box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
		border-bottom: 1px solid rgba(0, 0, 0, 0.06);
		padding-bottom: max(12px, env(safe-area-inset-bottom, 0px));
	}

	.elementor-element-3a6ff21
		.elementor-menu-toggle.elementor-active
		+ .elementor-nav-menu--dropdown
		.elementor-nav-menu {
		width: 100%;
	}

	.elementor-element-3a6ff21
		.elementor-menu-toggle.elementor-active
		+ .elementor-nav-menu--dropdown
		.elementor-item {
		display: block;
		width: 100%;
		box-sizing: border-box;
		padding: 14px 20px;
		border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	}

	.elementor-element-3a6ff21
		.elementor-menu-toggle.elementor-active
		+ .elementor-nav-menu--dropdown
		li:last-child
		.elementor-item {
		border-bottom: 0;
	}

	/*
	 * Планшет/мобильный: контакты сверху; вторая строка — лого | заголовки (5bc1759) | бургер.
	 * Средняя колонка minmax(0,1fr) + компактные шрифты — блок аккуратно между лого и меню.
	 * Viber/WhatsApp у верха; при прокрутке — g2-header-mobile-compact (site.js). «Оставить заявку» скрыта.
	 */
	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner {
		display: grid !important;
		grid-template-columns: auto minmax(0, 1fr) auto;
		grid-template-rows: auto auto;
		align-items: center;
		column-gap: 8px;
		row-gap: 8px;
	}

	/* Перебиваем Elementor post-88 @media (min-width:768px): --width у детей f309ca9 */
	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-9174e47,
	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-5bc1759,
	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-a4f14f0,
	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-0a339cb {
		--width: auto !important;
		width: auto !important;
		max-width: none !important;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-0a339cb {
		order: 0;
		grid-column: 1 / -1;
		grid-row: 1;
		flex: unset !important;
		width: 100% !important;
		max-width: 100% !important;
		justify-content: center !important;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 .g2-header-zayavka-wrap {
		display: none !important;
	}

	body.g2-header-mobile-compact .elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-d1c65f5 {
		display: none !important;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-9174e47 {
		grid-column: 1;
		grid-row: 2;
		justify-self: start;
		min-width: 0;
		max-width: 100%;
	}

	/*
	 * Лого: в post-88 у img width:88% — на широкой ячейке сетки превращается в «огромную машинку».
	 */
	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec .elementor-widget-container,
	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec a {
		display: block;
		width: fit-content !important;
		max-width: 100%;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec img {
		display: block;
		width: auto !important;
		height: auto !important;
		max-width: min(200px, 52vw) !important;
		max-height: 48px !important;
		object-fit: contain;
		object-position: left center;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-a4f14f0 {
		grid-column: 3;
		grid-row: 2;
		justify-self: end;
		align-self: center;
		min-width: 0;
		width: auto !important;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-5bc1759 {
		grid-column: 2;
		grid-row: 2;
		width: 100% !important;
		max-width: 100%;
		min-width: 0;
		justify-self: stretch;
		align-self: center;
		--margin-top: 0 !important;
		--margin-bottom: 0 !important;
		--margin-left: 0 !important;
		--margin-right: 0 !important;
		--padding-left: 0 !important;
		--padding-right: 2px !important;
		--gap: 2px 0 !important;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-5bc1759 .elementor-widget-heading {
		margin-block: 0 !important;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-5bc1759 .elementor-element-e212fb7 .elementor-heading-title {
		font-size: clamp(12px, 3.1vw, 15px) !important;
		line-height: 1.15 !important;
		margin: 0 !important;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-5bc1759 .elementor-element-e212fb7 .elementor-heading-title a {
		color: inherit;
		text-decoration: none;
	}

	.elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-5bc1759 .elementor-element-c49f3af .elementor-heading-title {
		font-size: clamp(9px, 2.35vw, 11px) !important;
		line-height: 1.22 !important;
		font-weight: 500 !important;
		margin: 0 !important;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 2;
		line-clamp: 2;
		overflow: hidden;
		overflow-wrap: anywhere;
		hyphens: auto;
	}
}

/* Фиксированная кнопка «Позвонить» (планшет и мобильный, как у бургер-меню ≤1023px) */
@media (max-width: 1023px) {
	body.elementor-page-88 {
		padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));
	}

	.g2-mobile-call {
		position: fixed;
		left: max(14px, env(safe-area-inset-left, 0px));
		right: max(14px, env(safe-area-inset-right, 0px));
		bottom: max(14px, env(safe-area-inset-bottom, 0px));
		z-index: 10060;
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 64px;
		padding: 14px 18px;
		box-sizing: border-box;
		font-family: system-ui, 'Segoe UI', Roboto, Arial, sans-serif;
		text-decoration: none;
		color: #fff;
		background: linear-gradient(180deg, #1fa34a 0%, #168a3d 100%);
		border-radius: 16px;
		border: 1px solid rgba(255, 255, 255, 0.2);
		box-shadow:
			0 4px 0 rgba(0, 0, 0, 0.12),
			0 8px 24px rgba(22, 138, 61, 0.45);
		-webkit-tap-highlight-color: transparent;
		animation: g2-mobile-call-attn 2.6s ease-in-out infinite;
	}

	.g2-mobile-call:active {
		transform: scale(0.98);
		box-shadow: 0 2px 0 rgba(0, 0, 0, 0.1);
	}

	.g2-mobile-call__inner {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 14px;
		width: 100%;
	}

	.g2-mobile-call__icon {
		display: flex;
		flex-shrink: 0;
		opacity: 0.95;
	}

	.g2-mobile-call__text {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		line-height: 1.15;
		min-width: 0;
	}

	.g2-mobile-call__label {
		font-size: clamp(1.2rem, 4.2vw, 1.45rem);
		font-weight: 800;
		letter-spacing: 0.02em;
	}

	.g2-mobile-call__num {
		font-size: clamp(0.95rem, 3.4vw, 1.05rem);
		font-weight: 600;
		opacity: 0.92;
		margin-top: 4px;
	}

	.g2-mobile-call:focus-visible {
		outline: 3px solid #fff;
		outline-offset: 3px;
	}
}

@media (min-width: 1024px) {
	.g2-mobile-call {
		display: none !important;
	}

	body.elementor-page-88 {
		padding-bottom: 0;
	}
}

@keyframes g2-mobile-call-attn {
	0%,
	100% {
		box-shadow:
			0 4px 0 rgba(0, 0, 0, 0.12),
			0 8px 22px rgba(22, 138, 61, 0.4);
		transform: translateZ(0) scale(1);
	}

	45% {
		box-shadow:
			0 5px 0 rgba(0, 0, 0, 0.1),
			0 12px 32px rgba(22, 138, 61, 0.55),
			0 0 0 0 rgba(46, 204, 113, 0.45);
		transform: translateZ(0) scale(1.035);
	}

	70% {
		box-shadow:
			0 4px 0 rgba(0, 0, 0, 0.12),
			0 8px 22px rgba(22, 138, 61, 0.4),
			0 0 0 14px rgba(46, 204, 113, 0);
		transform: translateZ(0) scale(1);
	}
}

@media (prefers-reduced-motion: reduce) {
	.g2-mobile-call {
		animation: none !important;
	}
}

/*
 * Десктоп (≥1025px): липкая шапка только через CSS (Sticky Elementor отключён в разметке — иначе конфликт и «дёрганье»).
 * До прокрутки — исходная вёрстка Elementor и полноразмерный логотип.
 * После прокрутки (класс g2-header-scrolled на body) — верхняя строка контактов + «Оставить заявку», компактный лого, без подписей у лого.
 */
@media (min-width: 1025px) {
	.elementor.elementor-88,
	body.elementor-page-88 {
		overflow-x: visible !important;
	}

	.elementor.elementor-88 .elementor-element.elementor-element-f309ca9 {
		position: -webkit-sticky !important;
		position: sticky !important;
		top: 0 !important;
		z-index: 1001 !important;
		align-self: flex-start;
		width: 100%;
		background-color: #fff;
		transition: box-shadow 0.2s ease;
	}

	body.elementor-page-88.g2-header-scrolled .elementor.elementor-88 .elementor-element.elementor-element-f309ca9 {
		box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
	}

	/* Кнопка «Оставить заявку» в шапке — только в компактном режиме */
	body:not(.g2-header-scrolled) .elementor.elementor-88 .elementor-element-f309ca9 .g2-header-zayavka-wrap {
		display: none !important;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 .g2-header-zayavka-wrap {
		display: flex !important;
		align-items: center;
		flex: 0 0 auto;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner {
		display: grid !important;
		grid-template-columns: auto minmax(0, 1fr) auto;
		grid-template-rows: auto auto;
		column-gap: clamp(14px, 2vw, 28px);
		row-gap: 8px;
		align-items: center;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-0a339cb {
		grid-column: 1 / -1;
		grid-row: 1;
		width: 100% !important;
		max-width: 100%;
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: wrap !important;
		align-items: center !important;
		justify-content: flex-start !important;
		gap: 8px 18px !important;
		padding-bottom: 6px !important;
		margin-bottom: 2px !important;
		border-bottom: 1px solid rgba(0, 0, 0, 0.08);
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-0a339cb > .elementor-widget {
		margin-block-end: 0 !important;
		margin-bottom: 0 !important;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-9174e47 {
		grid-column: 1;
		grid-row: 2;
		align-self: center;
		justify-self: start;
		min-width: 72px;
		width: auto;
		max-width: min(220px, 42vw);
		flex-shrink: 0;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-5bc1759 {
		display: none !important;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 > .e-con-inner > .elementor-element-a4f14f0 {
		grid-column: 2 / -1;
		grid-row: 2;
		justify-self: start;
		justify-content: flex-start !important;
		align-items: center !important;
		width: 100%;
		max-width: none;
	}

	/* Меню после прокрутки — слева у лого, без центрирования Elementor (elementor-nav-menu__align-center) */
	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-3a6ff21.elementor-element {
		--align-self: flex-start;
		align-self: flex-start !important;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-3a6ff21 .elementor-widget-container {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		justify-content: flex-start;
		width: 100%;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-3a6ff21.elementor-nav-menu__align-center .elementor-nav-menu--main,
	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-3a6ff21 .elementor-nav-menu--layout-horizontal {
		text-align: left !important;
		justify-content: flex-start !important;
		width: auto;
		max-width: 100%;
		flex: 1 1 auto;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-3a6ff21 .elementor-nav-menu--layout-horizontal .elementor-nav-menu {
		justify-content: flex-start !important;
		width: auto !important;
		margin-inline: 0 !important;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec {
		flex: 0 0 auto;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec,
	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec .elementor-widget-container,
	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec a {
		overflow: visible !important;
		min-height: 0;
	}

	body.g2-header-scrolled .elementor.elementor-88 .elementor-element-f309ca9 .elementor-element-0761cec img {
		display: block;
		height: 48px !important;
		width: auto !important;
		max-height: none !important;
		max-width: min(200px, 38vw) !important;
		min-width: 48px;
		object-fit: contain;
		object-position: left center;
		transition: height 0.25s ease, width 0.25s ease;
	}

	.g2-header-zayavka-link {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		padding: 7px 14px;
		font-family: system-ui, 'Segoe UI', Roboto, Arial, sans-serif;
		font-size: 13px;
		font-weight: 700;
		text-decoration: none;
		color: #fff;
		background: linear-gradient(180deg, #1fa34a 0%, #168a3d 100%);
		border-radius: 9px;
		border: 1px solid rgba(255, 255, 255, 0.25);
		white-space: nowrap;
	}

	.g2-header-zayavka-link:hover {
		filter: brightness(1.06);
	}

	.g2-header-zayavka-link:focus-visible {
		outline: 2px solid #0f5c28;
		outline-offset: 2px;
	}
}

/*
 * Меню шапки (3a6ff21): подчёркивание только у якорных пунктов (не «Главная»), класс g2-scroll-active из site.js.
 */
.elementor-element-3a6ff21 .elementor-nav-menu > li > a.elementor-item-anchor {
	background-image: linear-gradient(#168a3d, #168a3d);
	background-repeat: no-repeat;
	background-position: 50% 100%;
	background-size: 0 2px;
	transition: background-size 0.45s cubic-bezier(0.4, 0, 0.2, 1), color 0.25s ease;
}

.elementor-element-3a6ff21 .elementor-nav-menu > li > a.elementor-item-anchor.g2-scroll-active {
	background-size: 100% 2px;
}

/* У «Главной» не показываем линию Elementor (elementor-item-active) */
.elementor-element-3a6ff21 .elementor-nav-menu--main.e--pointer-underline .elementor-item.elementor-item-active::after,
.elementor-element-3a6ff21 .elementor-nav-menu--main.e--pointer-underline .elementor-item.elementor-item-active::before {
	opacity: 0 !important;
}

@media (prefers-reduced-motion: reduce) {
	.elementor-element-3a6ff21 .elementor-nav-menu > li > a.elementor-item-anchor {
		transition-duration: 0.01ms;
	}
}

/* Системные шрифты вместо тяжёлых веб-шрифтов из набора Elementor (Roboto / Montserrat в kit) */
body.elementor-page-88 {
	--e-global-typography-primary-font-family: system-ui, 'Segoe UI', Roboto, Arial, sans-serif;
	--e-global-typography-secondary-font-family: Georgia, 'Times New Roman', serif;
	--e-global-typography-text-font-family: system-ui, 'Segoe UI', Roboto, Arial, sans-serif;
	--e-global-typography-accent-font-family: system-ui, 'Segoe UI', Roboto, Arial, sans-serif;
}

.g2-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.g2-header-micro {
	margin: 6px 0 0;
	padding: 0 4px;
	font-size: clamp(11px, 2.8vw, 13px);
	line-height: 1.35;
	color: #3d5345;
	text-align: center;
	max-width: 36rem;
	margin-inline: auto;
}

@media (min-width: 1025px) {
	.elementor.elementor-88 .elementor-element-f309ca9 .g2-header-micro {
		grid-column: 1 / -1;
		justify-self: center;
		margin-top: 4px;
	}
}

.g2-section-micro-wrap {
	margin: -6px auto 12px;
	padding: 0 12px;
	max-width: 52rem;
	text-align: center;
}

.g2-section-micro {
	margin: 0;
	font-size: clamp(12px, 2.4vw, 14px);
	line-height: 1.45;
	color: #4a5c52;
}

/* CTA-полосы: только десктоп */
.g2-cta-strip {
	display: none;
}

@media (min-width: 1025px) {
	.g2-cta-strip {
		display: block;
		width: 100%;
		box-sizing: border-box;
		padding: 18px 20px;
		background: linear-gradient(180deg, #f6fbf7 0%, #eaf5ee 100%);
		border-top: 1px solid rgba(22, 138, 61, 0.12);
		border-bottom: 1px solid rgba(22, 138, 61, 0.12);
	}

	.g2-cta-strip__inner {
		max-width: 1100px;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		gap: 14px 24px;
	}

	.g2-cta-strip__hint {
		margin: 0;
		flex: 1 1 260px;
		font-size: 0.98rem;
		line-height: 1.45;
		color: #2a3b31;
	}

	.g2-cta-strip__actions {
		display: flex;
		flex-wrap: wrap;
		gap: 10px;
		justify-content: flex-end;
	}

	.g2-cta-btn {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		padding: 10px 16px;
		border-radius: 10px;
		font-weight: 700;
		font-size: 0.9rem;
		text-decoration: none;
		white-space: nowrap;
		border: 1px solid transparent;
		transition: filter 0.15s ease, transform 0.12s ease;
	}

	.g2-cta-btn:active {
		transform: scale(0.98);
	}

	.g2-cta-btn--call {
		color: #fff;
		background: linear-gradient(180deg, #1fa34a 0%, #168a3d 100%);
		border-color: rgba(255, 255, 255, 0.25);
	}

	.g2-cta-btn--zayavka {
		color: #0f5c28;
		background: #fff;
		border-color: rgba(22, 138, 61, 0.35);
	}

	.g2-cta-btn:focus-visible {
		outline: 3px solid #126b32;
		outline-offset: 2px;
	}
}

@media (max-width: 1023px) {
	.g2-mobile-call__text {
		align-items: center;
		text-align: center;
		width: 100%;
	}

	.g2-mobile-call__label {
		width: 100%;
		text-align: center;
		line-height: 1.2;
	}
}

/*
 * Фоновые картинки в post-88.css вели на старый домен WordPress — при локальном сайте фон не грузился.
 * Переопределяем на файлы из /assets/img/ (путь относительно site.css).
 */
.elementor.elementor-88 .elementor-element.elementor-element-ba645d8:not(.elementor-motion-effects-element-type-background),
.elementor.elementor-88
	.elementor-element.elementor-element-ba645d8
	> .elementor-motion-effects-container
	> .elementor-motion-effects-layer {
	background-image: url('../img/photo-truck.jpg') !important;
	background-position: bottom center;
	background-size: cover;
}

.elementor.elementor-88 .elementor-element.elementor-element-c495430:not(.elementor-motion-effects-element-type-background),
.elementor.elementor-88
	.elementor-element.elementor-element-c495430
	> .elementor-motion-effects-container
	> .elementor-motion-effects-layer {
	background-image: url('../img/photo-10.jpg') !important;
	background-position: center right;
	background-size: cover;
}
