/*!
Theme Name: shu-shu
Theme URI: http://underscores.me/
Author: Eugene Winner
Description: shu-shu
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: shu-shu
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

shu-shu is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

html {
	margin: 0;
	padding: 0;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	overflow-x: hidden;
}

* {
	margin: 0;
	padding: 0;
	text-decoration: none;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	list-style-type: none;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}


body {
	margin: 0;
	font-family: 'Inter', sans-serif;
	color: #3F3F3F;
	background: #ffffff;
	overflow-x: hidden;
}

a {
	color: inherit;
	text-decoration: none;
}

button {
	font-family: inherit;
	cursor: pointer;
	border: none;
	background: none;
}

ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.container {
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding-left: 32px;
	padding-right: 32px;
}

/* =========================
   HEADER
========================= */

body.admin-bar .site-header {
	top: 32px;
}

@media (max-width: 782px) {
	body.admin-bar .site-header {
		top: 46px;
	}
}

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	z-index: 1000;
	background: #f3f3f3;
	border: 1px solid #d9d9d9;
	box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
}

.site-header::before {
	content: "";
	position: absolute;
	inset: 0;
	background: #f3f3f3;
	z-index: -1;
}

.site-header-spacer {
	width: 100%;
	height: 0;
	flex: 0 0 auto;
	pointer-events: none;
}

.header-top,
.header-bottom {
	position: relative;
	z-index: 2;
}

.header-top {
	background: #f3f3f3;
}

.header-top__inner {
	min-height: 92px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 22px 0;
}

.header-brand {
	display: flex;
	align-items: center;
	gap: 46px;
	min-width: 0;
}

.header-logo {
	flex: 0 0 auto;
	font-size: 24px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0;
	color: #454545;
	text-transform: uppercase;
	white-space: nowrap;
}

.header-logo:hover {
	color: #C66B36;
}

.header-tagline {
	font-size: 18px;
	line-height: 1.15;
	font-weight: 700;
	color: #95969E;
}

.header-right {
	display: flex;
	align-items: center;
	gap: 28px;
	flex: 0 0 auto;
}

.header-contacts {
	display: flex;
	align-items: center;
	gap: 28px;
}

.header-contact {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 16px;
	color: #4e4e4e;
	transition: opacity 0.2s ease;
}

.header-contact:hover {
	opacity: 0.7;
}

.header-contact__icon {
	font-size: 14px;
	color: #8a8a96;
	line-height: 1;
}

.consultation-btn {
	height: 52px;
	padding: 0 26px;
	border-radius: 16px;
	background: #3b63a4;
	color: #ffffff;
	font-size: 16px;
	font-weight: 400;
	line-height: 1;
	white-space: nowrap;
	transition: background 0.2s ease;
}

.consultation-btn:hover {
	background: #31558f;
}

.header-bottom {
	background: #ffffff;
	border-top: 1px solid #d8d8d8;
}

.desktop-nav {
	display: block;
}

.desktop-menu {
	display: flex;
	align-items: center;
	gap: 56px;
	min-height: 56px;
	flex-wrap: wrap;
}

.desktop-menu__item {
	position: relative;
	display: flex;
	align-items: center;
}

.desktop-menu__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 56px;
	font-size: 18px;
	font-weight: 700;
	color: #2f2f2f;
	color: #1f1f1f;
}

.header-bottom .desktop-menu__link {
	color: #2a2a2a;
}

.header-bottom .desktop-menu__link {
	color: #1f1f1f;
}

.desktop-menu__link {
	color: #262626;
}

.header-bottom .desktop-menu__link {
	color: #2c2c2c;
}

/* цвет как на макете */
.header-bottom .desktop-menu__link {
	color: #2e2e2e;
}

.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #2d2d2d;
}

.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #2b2b2b;
}

.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #262626;
}

/* финальный оттенок текста в черной панели */
.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #2f2f2f;
}

.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #3a3a3a;
}

.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #2f2f2f;
}

/* делаем читаемым */
.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #2a2a2a;
}

/* на реальном макете это тёмно-серый, но на чёрном фоне он плохо читается
   поэтому делаю визуально близкий и рабочий вариант */
.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #3f3f3f;
}

.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #4a4a4a;
}

/* итог */
.header-bottom .desktop-menu__item>.desktop-menu__link {
	color: #494848;
}

/* hover */
.desktop-menu__item:hover>.desktop-menu__link,
.desktop-menu__item.active>.desktop-menu__link {
	color: #C66B36;
}

.menu-arrow {
	position: relative;
	width: 10px;
	height: 6px;
	display: inline-block;
	flex: 0 0 auto;
}

.menu-arrow::before,
.menu-arrow::after {
	content: "";
	position: absolute;
	top: 2px;
	width: 6px;
	height: 1.5px;
	background: currentColor;
}

.menu-arrow::before {
	left: 0;
	transform: rotate(45deg);
}

.menu-arrow::after {
	right: 0;
	transform: rotate(-45deg);
}

.has-submenu:hover .menu-arrow {
	transform: rotate(180deg);
}

.submenu {
	position: absolute;
	top: calc(100% + 0px);
	left: 0;
	min-width: 240px;
	padding-top: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: all 0.22s ease;
	z-index: 30;
}

.submenu-list {
	background: #ffffff;
	border: 1px solid #e5e5e5;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
	padding: 14px 0;
}

.submenu-list li a {
	display: block;
	padding: 12px 18px;
	font-size: 15px;
	color: #333333;
	transition: background 0.2s ease, color 0.2s ease;
}

.submenu-list li a:hover {
	background: #f3f3f3;
	color: #C66B36;
}

.has-submenu:hover .submenu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* =========================
   BURGER
========================= */

.burger {
	display: none;
	width: 42px;
	height: 42px;
	position: relative;
	flex: 0 0 auto;
}

.burger span {
	position: absolute;
	left: 6px;
	width: 30px;
	height: 2px;
	background: #4f5964;
	transition: transform 0.25s ease, opacity 0.25s ease, top 0.25s ease;
}

.burger span:nth-child(1) {
	top: 11px;
}

.burger span:nth-child(2) {
	top: 20px;
}

.burger span:nth-child(3) {
	top: 29px;
}

.burger.active span:nth-child(1) {
	top: 20px;
	transform: rotate(45deg);
}

.burger.active span:nth-child(2) {
	opacity: 0;
}

.burger.active span:nth-child(3) {
	top: 20px;
	transform: rotate(-45deg);
}

/* =========================
   MOBILE MENU
========================= */

.mobile-menu-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	opacity: 0;
	visibility: hidden;
	transition: all 0.25s ease;
	z-index: 198;
}

.mobile-menu-overlay.active {
	opacity: 1;
	visibility: visible;
}

.mobile-menu {
	position: fixed;
	top: 140px;
	right: 0;
	width: min(380px, 92vw);
	height: calc(100vh - 140px);
	background: #ffffff;
	box-shadow: -8px 0 28px rgba(0, 0, 0, 0.16);
	transform: translateX(100%);
	transition: transform 0.3s ease;
	z-index: 199;
	display: flex;
	flex-direction: column;
}

.mobile-menu.active {
	transform: translateX(0);
}

.mobile-menu__head {
	min-height: 74px;
	padding: 20px 20px 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid #ececec;
}

.mobile-menu__title {
	font-size: 22px;
	font-weight: 700;
	color: #2f2f2f;
}

.mobile-menu__close {
	font-size: 34px;
	line-height: 1;
	color: #4f5964;
}

.mobile-menu__body {
	padding: 20px;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	gap: 22px;
}

.mobile-contacts {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 18px 22px;
	justify-content: space-around;
}

.mobile-contact {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: #4f4f4f;
	font-size: 15px;
}

.mobile-contact__icon {
	color: #8a8a96;
	font-size: 13px;
}

.consultation-btn--mobile {
	width: 100%;
	justify-content: center;
	height: 52px;
}

.mobile-menu-list {
	display: flex;
	flex-direction: column;
}

.mobile-menu-item {
	border-bottom: 1px solid #ececec;
}

.mobile-menu-link,
.mobile-menu-toggle {
	width: 100%;
	min-height: 56px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	text-align: left;
	color: #2f2f2f;
	font-size: 18px;
	font-weight: 600;
	padding: 0;
}

.mobile-arrow {
	position: relative;
	width: 12px;
	height: 7px;
	flex: 0 0 auto;
	transition: transform 0.25s ease;
}

.mobile-arrow::before,
.mobile-arrow::after {
	content: "";
	position: absolute;
	top: 2px;
	width: 7px;
	height: 1.5px;
	background: #4f5964;
}

.mobile-arrow::before {
	left: 0;
	transform: rotate(45deg);
}

.mobile-arrow::after {
	right: 0;
	transform: rotate(-45deg);
}

.has-mobile-submenu.active .mobile-arrow {
	transform: rotate(180deg);
}

.mobile-submenu {
	display: none;
	padding: 0 0 14px 0;
}

.has-mobile-submenu.active .mobile-submenu {
	display: block;
}

.mobile-submenu li a {
	display: block;
	padding: 10px 0 10px 14px;
	color: #5b5b5b;
	font-size: 15px;
	line-height: 1.35;
}

/* =========================
   POPUP
========================= */

.popup-overlay-header {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	opacity: 0;
	visibility: hidden;
	transition: all 0.25s ease;
	z-index: 210;
}

.popup-overlay-header.active {
	opacity: 1;
	visibility: visible;
}

.popup-overlay-header .popup {
	position: relative;
	width: 100%;
	max-width: 460px;
	padding: 40px 28px 28px;
	border-radius: 20px;
	background: #ffffff;
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.18);
}

.popup-overlay-header .popup-close {
	position: absolute;
	top: 12px;
	right: 14px;
	font-size: 30px;
	line-height: 1;
	color: #5d6570;
}

.popup-overlay-header .popup-title {
	font-size: 28px;
	font-weight: 700;
	color: #2f2f2f;
	margin-bottom: 14px;
}

.popup-overlay-header .popup-text {
	font-size: 17px;
	line-height: 1.5;
	color: #5b5b5b;
}

/* =========================
   DEMO
========================= */

.demo-content {
	padding: 60px 0;
}

.demo-placeholder {
	min-height: 400px;
	border: 1px dashed #cccccc;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #999999;
	font-size: 22px;
}

/* =========================
   ADAPTIVE
========================= */

@media (max-width: 1200px) {

	.header-tagline {
		font-size: 14px;
	}
}

@media (max-width: 1100px) {
	.container {
		padding-left: 20px;
		padding-right: 20px;
	}

	.header-logo {
		font-size: 22px;
	}

	.header-tagline {
		font-size: 14px;
	}

	.header-brand {
		flex-direction: column;
		gap: 5px;
		align-items: flex-start;
	}

	.header-right {
		gap: 18px;
	}

	.header-contacts {
		gap: 18px;
	}

	.desktop-menu {
		gap: 0 34px;
	}

	.desktop-menu__link {
		font-size: 17px;
	}
}

@media (max-width: 1000px) {
	.header-right {
		gap: 18px;
		flex-direction: column;
	}
}

@media (max-width: 770px) {
	.header-contacts--desktop {
		display: none;
	}

	.site-header {
		border: none;
	}

	.header-top {
		display: flex;
		border: 1px solid #d9d9d9;
		min-height: 60px;
		align-items: center;
	}

	.header-top__inner {
		min-height: fit-content;
		padding: 16px 0;
	}

	.header-bottom {
		display: none;
	}

	.burger {
		display: block;
	}

	.header-brand {
		flex-direction: column;
		align-items: flex-start;
		gap: 6px;
	}

	.header-logo {
		font-size: 21px;
	}

	.header-tagline {
		max-width: 320px;
	}

	.header-right {
		display: flex;
		align-items: center;
		gap: 16px;
	}

	.header-contact {
		font-size: 14px;
	}

	.consultation-btn {
		height: 50px;
		min-height: 50px;
		padding: 0 24px;
		font-size: 16px;
	}

	.consultation-btn {
		display: none;
	}

	.consultation-btn.consultation-btn--mobile {
		display: flex;
		justify-content: center;
		align-items: center;
	}
}

@media (max-width: 640px) {

	.header-contacts--desktop {
		gap: 18px;
		top: 18px;
	}

	.header-contact__text {
		font-size: 13px;
	}

	.consultation-btn {
		padding: 0 18px;
		font-size: 15px;
	}

	.header-logo {
		font-size: 20px;
	}
}

@media (max-width: 480px) {
	.container {
		padding-left: 16px;
		padding-right: 16px;
	}

	.header-top__inner {
		align-items: center;
	}

	.header-right {
		gap: 12px;
	}

	.header-contacts--desktop {
		left: auto;
		right: 74px;
		transform: none;
		top: 18px;
		gap: 16px;
	}

	.header-brand {
		justify-content: center;
	}

	.header-tagline {
		display: none;
	}
	.mobile-menu {
		top: 125px;
		height: calc(100vh - 125px);
	}
}

@media (max-width: 365px) {
	.header-top__inner {
		min-height: 76px;
	}

	.header-tagline,
	.header-contacts--desktop,
	.consultation-btn {
		display: none;
	}

	.header-brand {
		flex-direction: row;
		align-items: center;
		gap: 0;
	}

	.header-logo {
		font-size: 20px;
	}

	.header-right {
		margin-left: auto;
	}

	.burger {
		width: 40px;
		height: 40px;
	}

	.burger span {
		left: 5px;
		width: 30px;
	}

	.burger span:nth-child(1) {
		top: 10px;
	}

	.burger span:nth-child(2) {
		top: 19px;
	}

	.burger span:nth-child(3) {
		top: 28px;
	}
}










/* =========================
   FOOTER
========================= */

.site-footer {
	background: #555558;
	color: #f3f3f3;
}

.site-footer__inner {
	padding-top: 45px;
	padding-bottom: 24px;
}

.site-footer__top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 36px;
}

.footer-col {
	display: flex;
	flex-direction: column;
}

.footer-col--brand {
	width: 100%;
	max-width: 380px;
}

.footer-col--nav {
	width: 16%;
	min-width: 220px;
}

.footer-col--directions {
	width: 225px;
	min-width: 220px;
}

.footer-col--contacts {
	width: 300px;
}

.footer-logo {
	display: inline-block;
	font-size: 30px;
	line-height: 1.1;
	font-weight: 700;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-bottom: 23px;
}

.footer-brand-text {
	font-size: 23px;
	line-height: 1.4;
	font-weight: 700;
	color: #f0f0f0;
}

.footer-brand-text--main {
	max-width: 410px;
	margin-bottom: 28px;
}

.footer-brand-text--secondary {
	max-width: 410px;
	margin-bottom: 30px;
}

.footer-brand-actions {
	display: flex;
	align-items: center;
	gap: 24px;
	flex-wrap: wrap;
}

.footer-socials {
	display: flex;
	align-items: center;
	gap: 20px;
}

.footer-social {
	width: 46px;
	height: 46px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #e8e8ec;
	transition: opacity 0.2s ease;
}

.footer-social:hover {
	opacity: 0.75;
}

.footer-social__icon {
	font-size: 30px;
	line-height: 1;
}

.footer-title {
	font-size: 23px;
	line-height: 1.2;
	font-weight: 700;
	margin-bottom: 26px;
	color: #f2f2f2;
}

.footer-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
	font-size: 20px;
	line-height: 1.4;
}

.footer-list li a {
	font-size: 23px;
	line-height: 1.05;
	font-weight: 600;
	color: #f1f1f1;
	transition: opacity 0.2s ease;
}

.footer-list li a:hover {
	opacity: 0.75;
}

.footer-contacts {
	display: flex;
	flex-direction: column;
	gap: 18px;
	margin-bottom: 28px;
}

.footer-contact {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-size: 22px;
	line-height: 1.2;
	font-weight: 500;
	color: #f1f1f1;
	transition: opacity 0.2s ease;
}

.footer-contact:hover {
	opacity: 0.75;
}

.footer-contact__icon {
	width: 24px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	line-height: 1;
	color: #f1f1f1;
}

.footer-btn {
	min-width: 240px;
	height: 54px;
	padding: 0 26px;
	border-radius: 16px;
	/* background: linear-gradient(90deg, #6fb5f0 0%, #3e88ec 100%); */
	background: #2D5996;
	color: #ffffff;
	font-size: 21px;
	line-height: 1;
	font-weight: 500;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	transition: opacity 0.2s ease;
}

.footer-btn:hover {
	opacity: 0.9;
}

.footer-btn--arrow {
	display: flex;
	justify-content: center;
	justify-content: center;
	gap: 25px;
	padding-left: 30px;
	padding-right: 28px;
	margin-bottom: 34px;
	min-width: 285px;
}

.footer-btn__arrow {
	font-size: 31px;
	line-height: 1;
	transform: translateY(-1px);
}

.footer-project__title {
	font-size: 25px;
	line-height: 1.2;
	font-weight: 700;
	color: #f1f1f1;
	margin-bottom: 14px;
}

.footer-policy-links {
	display: flex;
	gap: 12px 6px;
}

.footer-policy-links a {
	font-size: 17px;
	line-height: 1.3;
	font-weight: 600;
	color: #ededed;
	transition: opacity 0.2s ease;
}

.footer-policy-links a:hover {
	opacity: 0.75;
}

.footer-policy-links--top {
	flex-direction: column;
	align-items: flex-start;
	margin-bottom: 22px;
}

.site-footer__bottom {
	margin-top: 28px;
}

.footer-bottom-line {
	width: 100%;
	height: 1px;
	background: rgba(255, 255, 255, 0.16);
	margin-bottom: 24px;
}

.footer-bottom-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.footer-copy {
	font-size: 22px;
	line-height: 1.2;
	font-weight: 700;
	color: #f0f0f0;
	white-space: nowrap;
}

.footer-policy-links--bottom {
	flex: 1;
	justify-content: center;
	gap: 72px;
}

.footer-policy-links--bottom a {
	font-size: 18px;
	line-height: 1.2;
	font-weight: 600;
}

.left-area-ft {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 1015px;
}

.top-area-ft {
	display: flex;
	justify-content: space-between;
	width: 100%;
	max-width: 940px;
	gap: 25px;
}

/* =========================
   POPUP
========================= */

.popup-overlay-footer {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.45);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	opacity: 0;
	visibility: hidden;
	transition: all 0.25s ease;
	z-index: 1000;
}

.popup-overlay-footer.active {
	opacity: 1;
	visibility: visible;
}

.popup-overlay-footer .popup {
	position: relative;
	width: 100%;
	max-width: 460px;
	padding: 40px 28px 28px;
	border-radius: 20px;
	background: #ffffff;
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.18);
}

.popup-overlay-footer .popup-close {
	position: absolute;
	top: 12px;
	right: 14px;
	font-size: 30px;
	line-height: 1;
	color: #5d6570;
}

.popup-overlay-footer .popup-title {
	font-size: 28px;
	font-weight: 700;
	color: #2f2f2f;
	margin-bottom: 14px;
}

.popup-overlay-footer .popup-text {
	font-size: 17px;
	line-height: 1.5;
	color: #5b5b5b;
}


/* =========================
   ADAPTIVE
========================= */

@media (max-width: 1280px) {
	.container {
		padding-left: 28px;
		padding-right: 28px;
	}

	.site-footer__top {
		gap: 28px;
	}

	.footer-logo {
		font-size: 26px;
	}

	.footer-brand-text,
	.footer-project__title {
		font-size: 20px;
	}

	.footer-title {
		font-size: 20px;
	}

	.footer-list li a,
	.footer-contact {
		font-size: 18px;
	}

	.footer-btn {
		min-width: 220px;
		font-size: 18px;
		height: 50px;
	}

	.footer-copy {
		font-size: 20px;
	}

	.footer-policy-links--bottom a {
		font-size: 17px;
	}
}

@media (max-width: 1180px) {
	.container {
		padding-left: 24px;
		padding-right: 24px;
	}

	.site-footer__inner {
		padding-top: 26px;
		padding-bottom: 18px;
	}

	.site-footer__top {
		flex-wrap: wrap;
		justify-content: center;
		gap: 34px 24px;
	}

	.footer-col--contacts {
		order: -1;
		width: 100%;
		min-width: 0;
		flex-direction: row;
		gap: 35px;
		justify-content: space-between;
		max-width: 700px;
	}

	.footer-col--brand {
		order: 2;
		width: 100%;
		max-width: none;
		align-items: center;
		text-align: center;
	}

	.footer-col--nav {
		order: 3;
		width: calc(50% - 12px);
		min-width: 0;
	}

	.footer-col--directions {
		order: 4;
		width: calc(50% - 12px);
		min-width: 0;
	}

	.footer-brand-text--main,
	.footer-brand-text--secondary {
		max-width: 700px;
	}

	.footer-brand-actions {
		justify-content: center;
	}

	.footer-project {
		align-items: flex-start;
		width: 100%;
		max-width: 300px;
	}

	.wrapper-ft-1 {
		align-items: flex-start;
		width: 100%;
		max-width: 300px;
	}

	.footer-bottom-content {
		flex-direction: column-reverse;
		gap: 18px;
	}

	.footer-policy-links--bottom {
		justify-content: center;
		gap: 40px;
		flex-wrap: wrap;
	}

	.footer-copy {
		white-space: normal;
		text-align: center;
	}
}

@media (max-width: 800px) {
	.top-area-ft {
		flex-wrap: wrap;
		gap: 45px 25px;
		justify-content: center;
	}

	.footer-col--nav {
		width: 100%;
		max-width: 285px;
	}

	.footer-col--directions {
		width: 100%;
		max-width: 340px;
	}

	.footer-title {
		text-align: center;
	}

	.footer-list {
		text-align: center;
	}
}

@media (max-width: 600px) {
	.footer-col--contacts {
		flex-direction: column;
		align-items: center;
	}

	.footer-contact {
		display: flex;
		justify-content: center;
		align-items: center;
		text-align: center;
	}

	.footer-btn {
		justify-content: center;
		align-items: center;
		display: flex;
		margin: 0;
		width: 100%;
	}

	.footer-policy-links--bottom {
		gap: 16px;
	}

	.footer-project__title {
		text-align: center;
	}

	.footer-policy-links--bottom a {
		text-align: center;
	}

	.footer-policy-links a {
		text-align: center;
	}
}



.popup-overlay-footer,
.popup-overlay-header {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 20px;
	background: rgba(20, 24, 34, 0.55);
	backdrop-filter: blur(4px);
}

.popup-overlay-footer.active,
.popup-overlay-header.active {
	display: flex;
}

.popup-overlay-footer .popup,
.popup-overlay-header .popup {
	position: relative;
	width: 100%;
	max-width: 720px;
	max-height: 90vh;
	overflow-y: auto;
	padding: 34px 34px 28px;
	background: #FFFFFF;
	border: 1px solid #E7E8EC;
	border-radius: 28px;
	box-shadow: 0 24px 60px rgba(24, 29, 39, 0.16);
}

.popup-overlay-footer .popup-close-footer,
.popup-overlay-header .popup-close-header {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 42px;
	height: 42px;
	border: none;
	border-radius: 50%;
	background: #F3F4F6;
	color: #1F2024;
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	transition: background-color 0.25s ease, transform 0.2s ease;
}

.popup-overlay-footer .popup-close-footer:hover,
.popup-overlay-header .popup-close-header:hover {
	background: #E7E8EC;
	transform: rotate(90deg);
}

.popup-overlay-footer .popup-title,
.popup-overlay-header .popup-title {
	margin: 0 0 14px;
	padding-right: 56px;
	font-size: 34px;
	line-height: 1.15;
	font-weight: 700;
	color: #1F2024;
}

.popup-overlay-footer .popup-text,
.popup-overlay-header .popup-text {
	margin: 0 0 24px;
	font-size: 17px;
	line-height: 1.6;
	color: #5B5E66;
}

.popup-form-wrap {
	width: 100%;
}

.popup-form-wrap .wpcf7 {
	width: 100%;
}

.popup-form-wrap .wpcf7 form {
	margin: 0;
}

.popup-cf7-form {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.popup-cf7-form__field {
	position: relative;
	margin: 0;
}

.popup-cf7-form__field p {
	margin: 0;
}

.popup-cf7-form__input,
.popup-cf7-form__textarea {
	width: 100%;
	border: 1px solid #D9DCE3;
	background: #FFFFFF;
	border-radius: 18px;
	box-shadow: none;
	outline: none;
	font-family: inherit;
	font-size: 16px;
	line-height: 1.5;
	color: #1F2024;
	transition: border-color 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
	-webkit-appearance: none;
	appearance: none;
	box-sizing: border-box;
}

.popup-cf7-form__input {
	height: 60px;
	padding: 0 20px;
}

.popup-cf7-form__textarea {
	min-height: 150px;
	padding: 18px 20px;
	resize: vertical;
}

.popup-cf7-form__input::placeholder,
.popup-cf7-form__textarea::placeholder {
	color: #8E929C;
	opacity: 1;
}

.popup-cf7-form__input:focus,
.popup-cf7-form__textarea:focus {
	border-color: #C66B36;
	box-shadow: 0 0 0 4px rgba(198, 107, 54, 0.12);
}

.popup-cf7-form__input:hover,
.popup-cf7-form__textarea:hover {
	border-color: #C8CDD6;
}

.popup-cf7-form__submit-wrap {
	margin-top: 4px;
}

.popup-cf7-form__button {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	min-height: 60px;
	padding: 16px 24px;
	border: none;
	border-radius: 18px;
	background: #C66B36;
	color: #FFFFFF;
	font-family: inherit;
	font-size: 17px;
	line-height: 1.2;
	font-weight: 700;
	text-align: center;
	cursor: pointer;
	transition: background-color 0.25s ease, transform 0.2s ease, box-shadow 0.25s ease;
	box-shadow: 0 14px 30px rgba(198, 107, 54, 0.22);
}

.popup-cf7-form__button:hover {
	background: #B65E2C;
	transform: translateY(-1px);
}

.popup-cf7-form__button:active {
	transform: translateY(0);
	background: #A55325;
}

.popup-cf7-form__button:focus {
	outline: none;
	box-shadow: 0 0 0 4px rgba(198, 107, 54, 0.18);
}

.popup-cf7-form__policy {
	margin-top: 2px;
	font-size: 13px;
	line-height: 1.6;
	color: #8A8F99;
}

.popup-form-wrap .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
}

.popup-form-wrap .wpcf7-not-valid {
	border-color: #D63638 !important;
	box-shadow: 0 0 0 4px rgba(214, 54, 56, 0.10) !important;
}

.popup-form-wrap .wpcf7-not-valid-tip {
	display: block;
	margin-top: 8px;
	font-size: 13px;
	line-height: 1.4;
	font-weight: 500;
	color: #D63638;
}

.popup-form-wrap .wpcf7-spinner {
	margin: 12px 0 0;
	vertical-align: middle;
}

.popup-form-wrap .wpcf7 form .wpcf7-response-output {
	margin: 20px 0 0;
	padding: 14px 16px;
	border-radius: 16px;
	font-size: 14px;
	line-height: 1.5;
}

.popup-form-wrap .wpcf7 form.sent .wpcf7-response-output {
	border: 1px solid #2E9E5B;
	background: rgba(46, 158, 91, 0.08);
	color: #1E7A45;
}

.popup-form-wrap .wpcf7 form.invalid .wpcf7-response-output,
.popup-form-wrap .wpcf7 form.unaccepted .wpcf7-response-output,
.popup-form-wrap .wpcf7 form.failed .wpcf7-response-output,
.popup-form-wrap .wpcf7 form.aborted .wpcf7-response-output {
	border: 1px solid #D63638;
	background: rgba(214, 54, 56, 0.06);
	color: #B42318;
}

.popup-form-wrap .wpcf7 form.submitting .popup-cf7-form__button {
	opacity: 0.75;
	pointer-events: none;
}

.popup-form-wrap .ajax-loader {
	display: none;
}

@media (max-width: 768px) {

	.popup-overlay-footer,
	.popup-overlay-header {
		padding: 16px;
	}

	.popup-overlay-footer .popup,
	.popup-overlay-header .popup {
		max-width: 100%;
		padding: 24px 18px 20px;
		border-radius: 22px;
	}

	.popup-overlay-footer .popup-title,
	.popup-overlay-header .popup-title {
		margin-bottom: 12px;
		padding-right: 44px;
		font-size: 28px;
	}

	.popup-overlay-footer .popup-text,
	.popup-overlay-header .popup-text {
		margin-bottom: 18px;
		font-size: 15px;
	}

	.popup-overlay-footer .popup-close-footer,
	.popup-overlay-header .popup-close-header {
		top: 12px;
		right: 12px;
		width: 38px;
		height: 38px;
		font-size: 24px;
	}

	.popup-cf7-form {
		gap: 14px;
	}

	.popup-cf7-form__input {
		height: 54px;
		padding: 0 16px;
		font-size: 15px;
		border-radius: 16px;
	}

	.popup-cf7-form__textarea {
		min-height: 130px;
		padding: 15px 16px;
		font-size: 15px;
		border-radius: 16px;
	}

	.popup-cf7-form__button {
		min-height: 54px;
		padding: 14px 18px;
		font-size: 16px;
		border-radius: 16px;
	}

	.popup-cf7-form__policy {
		font-size: 12px;
	}
}

@media (max-width: 420px) {

	.popup-overlay-footer .popup-title,
	.popup-overlay-header .popup-title {
		font-size: 24px;
	}

	.popup-overlay-footer .popup-text,
	.popup-overlay-header .popup-text {
		font-size: 14px;
	}
}


.page-404-section {
	padding: 100px 0;
	background: linear-gradient(180deg, #ffffff 0%, #F7F8FA 100%);
}

.page-404__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
}

.page-404__content {
	max-width: 520px;
}

.page-404__code {
	font-size: 120px;
	font-weight: 700;
	color: #C66B36;
	margin-bottom: 20px;
}

.page-404__title {
	font-size: 36px;
	margin-bottom: 16px;
}

.page-404__text {
	font-size: 16px;
	color: #666;
	margin-bottom: 30px;
}

.page-404__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	justify-content: center;
}

.btn-primary {
	background: #C66B36;
	color: #fff;
	padding: 14px 28px;
	border-radius: 8px;
	text-decoration: none;
}

.btn-secondary {
	border: 1px solid #C66B36;
	color: #C66B36;
	padding: 14px 28px;
	border-radius: 8px;
	text-decoration: none;
}

.page-404__image img {
	max-width: 420px;
}

@media (max-width: 768px) {
	.page-404__inner {
		flex-direction: column;
		text-align: center;
	}

	.page-404__actions {
		justify-content: center;
		flex-wrap: wrap;
	}
}


.text-page-hero {
	padding: 60px 0 30px;
	background: linear-gradient(180deg, #ffffff 0%, #F7F8FA 100%);
}

.text-page-title {
	font-size: 42px;
	line-height: 1.2;
	margin-top: 20px;
	word-break: break-all;
}

.breadcrumbs {
	font-size: 14px;
	color: #7c8798;
}

.breadcrumbs a {
	color: #C66B36;
	text-decoration: none;
}

.text-page-content {
	padding: 40px 0 80px;
}

.text-content {
	max-width: 900px;
	margin: 0 auto;
	font-size: 16px;
	line-height: 1.7;
	color: #333;
}

.text-content h2 {
	font-size: 26px;
	margin: 40px 0 16px;
}

.text-content h3 {
	font-size: 20px;
	margin: 30px 0 12px;
}

.text-content p {
	margin-bottom: 16px;
}

.text-content ul {
	padding-left: 20px;
	margin-bottom: 16px;
}

.text-content li {
	margin-bottom: 8px;
}

.text-content a {
	color: #C66B36;
}

.text-content strong {
	font-weight: 600;
}
.text-page-content ul li,
.text-page-content ol li{
		list-style: circle;
}

@media (max-width: 768px) {
	.text-page-title {
		font-size: 28px;
	}

	.text-content {
		font-size: 15px;
	}
}