* {
	margin: 0;
	padding: 0;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

body {
	font-family: "Rubik", sans-serif;
	font-optical-sizing: auto;
	color: #041a46;
	font-size: 16px;
	line-height: 1.55;
	font-weight: 400;
	font-style: normal;
}

.container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

input.input {
	color: rgb(4, 26, 70);
	border: 1px solid rgb(207, 207, 207);
	background-color: transparent;
	border-radius: 30px;
	font-size: 16px;
	font-weight: 400;
	height: 50px;
	outline: none;
	padding: 0 20px;
}

.btn {
	padding: 0px 15px;
	display: flex;
	width: 100%;
	max-width: 250px;
	font-weight: 500;
	height: 50px;
	color: #ffffff;
	border-radius: 30px;
	font-size: 16px;
	font-family: Rubik;
	cursor: pointer;
	background-color: #fff;
	transition: 0.3s  ease all;
	border: 0;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.btn-green {
	background-color: #00de5d;
}

.btn-blue {
	background-color: #194fb9;
}

section {
	padding: 60px 0;
}

.h2 {
	color: #0c163b;
	font-size: 46px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.07;
	font-weight: 600;
	text-align: center;
	margin-bottom: 40px;
	display: block;
}

.h2.white {
	color: #fff;
}
.h2.left{
    text-align: left;
}
a {
	text-decoration: none;
}

/* HEADER */

.header {
	background: #cae4fb;
	border-bottom: 1px solid #041a4645;
	padding: 15px 0;
	position: fixed;
	width: 100%;
	top: 0;
	z-index: 10;
}

.header .wrap {
	display: flex;
	justify-content: space-between;
	gap: 50px;
	align-items: center;
}

.header .wrap .logo {
	width: 240px;
}

img {
	max-width: 100%;
}

.header .wrap .phone a {
	color: #ffffff;
	font-size: 14px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.55;
	font-weight: 600;
	border-radius: 30px 30px 30px 30px;
	background-color: #194fb9;
	background-position: center center;
	width: 200px;
	display: block;
	text-align: center;
	text-decoration: none;
	transition: all 0.3s;
	padding: 13px 0;
}

.header .wrap .menu {
	flex: 1;
}

.header .wrap .phone a:hover {
	background: #0b3993;
}

.header .wrap .menu li.dropdown .submenu {
	display: none;
}

.header .wrap .menu>ul {
	display: flex;
	list-style: none;
	gap: 30px;
	justify-content: center;
	align-items: center;
}

.header .wrap .menu li a {
	color: #041a46;
	font-size: 16px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.55;
	font-weight: 400;
	text-decoration: none;
	transition: all 0.3s;
}

.header .wrap .menu li a:hover {
	color: #194fb9;
}

.header .wrap .menu li.dropdown:hover .submenu {
	display: flex;
}

.header .wrap .menu li.dropdown  .submenu {
	background: #fff;
	box-shadow: 2px 2px 10px 0px rgba(200, 200, 200, 1);
	width: 500px;
	position: absolute;
	border-radius: 12px;
	padding: 15px;
	flex-wrap: wrap;
	gap: 5px;
	list-style: none;
}

.header .wrap .menu .dropdown {
	position: relative;
}

.header .wrap .menu  li.dropdown .submenu li {
	width: calc(100%/2 - 5px);
}

.header .wrap .menu li.dropdown .submenu li a {
	display: flex;
	background: #e4f3ff;
	padding: 10px;
	border-radius: 10px;
	align-items: center;
	gap: 10px;
	line-height: normal;
	transition: all 0.3s;
}

.header .wrap .menu li.dropdown .submenu li a img {
	width: 50px;
}

.header .wrap .menu li.dropdown .submenu li a:hover {
	background: #cae4fb;
}

.header .wrap .burger{
    display: none;
}

/* HERO */


section.hero {
	margin-top: 100px;
	background: #cae4fb;
	padding: 50px 0;
}
section.hero.white {
    background: #fff;
    padding-bottom: 0;
}
section.hero .wrap {
	display: flex;
	gap: 30px;
}

section.hero .wrap .data {
	width: 100%;
	max-width: 650px;
}

section.hero .wrap .image {
	flex: 1;
	position: relative;
}

section.hero  .title {
	color: #041a46;
	font-size: 50px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.07;
	font-weight: 700;
	margin-bottom: 20px;
}

section.hero .wrap .data .desc {
	color: #2e384d;
	font-size: 20px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.55;
	font-weight: 400;
	margin-bottom: 30px;
}

section.hero .wrap .data .form {
	background: #fff;
	padding: 30px;
	border-radius: 16px;
}

section.hero .wrap .data .form .name {
	color: #041a46;
	font-size: 18px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.55;
	font-weight: 700;
	margin-bottom: 15px;
}

section.hero .wrap .data .form .flex {
	display: flex;
	gap: 15px;
	justify-content: space-between;
}

section.hero .wrap .data .form .flex input {
	width: calc(100%/3 - 10px);
}

section.hero .wrap .data .form .flex button {
	width: calc(100%/3 - 10px);
}
section.hero .bread ol {
    list-style-type: none;
    margin-bottom: 40px;
    display: flex;
    gap: 15px;
    color: #2e384d;
    font-family: 'Rubik';
    font-weight: 300;
}

section.hero .bread ol a {
    color: #2e384d;
    font-family: 'Rubik';
    font-weight: 300;
}
.politico {
	margin: 15px 0;
	color: #cfcfcf;
	font-size: 14px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.07;
	font-weight: 300;
}

.politico a {
	color: rgb(12, 22, 59);
}

section.hero .wrap .image .label {
	width: 140px;
	height: 140px;
	position: absolute;
	right: 0;
	background-image: url(/assets/images/tild3037-6234-4430-b837-663334336233__star_1.svg);
	background-repeat: no-repeat;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	font-size: 16px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1;
	font-weight: 500;
	flex-direction: column;
	text-transform: uppercase;
	background-size: contain;
	bottom: 50%;
	text-align: center;
	padding: 15px;
	line-height: 1.2;
}

section.hero .wrap .image .label span {
	color: #ffffff;
	font-size: 43px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1;
	font-weight: 700;
	text-transform: uppercase;
}
section.hero .wrap .image .brand {
    position: absolute;
    right: -4px;
    bottom: 44%;
    border-radius: 8px;
    width: 150px;
    overflow: hidden;
    display: flex;
}

section.hero .wrap .image.full {
    display: flex;
    border-radius: 20px;
    overflow: hidden;
}

section.hero .wrap .image.full img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}


section.hero .advantages {
	margin-top: 40px;
	display: flex;
	justify-content: space-between;
	gap: 20px;
}

section.hero .advantages .item {
	display: flex;
	flex-direction: column;
	gap: 10px;
	align-items: center;
	width: calc(100%/6 - 10px);
}

section.hero .advantages .item .name {
	color: #041a46;
	font-size: 19px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.5;
	font-weight: 400;
	text-align: center;
}

section.hero .advantages .item .name span {
	font-weight: 600;
	white-space: nowrap;
}




/* DONTWAIT */

section.dont-wait .icon {
	text-align: center;
	width: 74px;
	margin: 0 auto 30px;
}

section.dont-wait .h2 {
	max-width: 75%;
	margin: 0 auto 30px;
}

section.dont-wait .wrap {
	background: #00de5d;
	display: flex;
	align-items: center;
	gap: 30px;
	border-radius: 200px;
	padding: 10px;
}

section.dont-wait .wrap .image {
	width: 160px;
	height: 160px;
	display: flex;
	border-radius: 200px;
	overflow: hidden;
}

section.dont-wait .wrap .data {
	flex: 1;
}

section.dont-wait .wrap .data .name {
	color: #000000;
	font-size: 26px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.55;
	font-weight: 600;
	margin-bottom: 15px;
}

section.dont-wait .wrap .data .desc {
	display: flex;
	align-items: center;
	gap: 50px;
}

section.dont-wait .wrap .data .desc .text {
	max-width: 450px;
	color: #000000;
	font-size: 18px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.55;
	font-weight: 400;
}

/* WHY */

section.why .wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
}

section.why .wrap .item {
	width: calc(100%/2 - 20px);
	padding: 30px;
	background: #cae4fb;
	border-radius: 14px;
	display: flex;
	gap: 30px;
	align-items: center;
}

section.why .wrap .item .icon {
	width: 104px;
	height: 104px;
}

section.why .wrap .item .desc {
	flex: 1;
}

section.why .wrap .item .desc .name {
	color: #041a46;
	font-size: 22px;
	font-weight: 600;
	margin-bottom: 10px;
}

section.why .wrap .item .desc .text {
	color: #2e384d;
	font-family: 'Rubik';
	font-weight: 400;
	font-size: 18px;
}

/* HOW */

.how {
	background: #08d05e;
	padding: clamp(28px, 4vw, 56px) 0;
}

.how__steps {
	display: flex;
	gap: clamp(18px, 2.8vw, 44px);
	align-items: flex-start;
}

.how__step {
	flex: 1 1 0;
	min-width: 0;
}

.how__top {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 12px;
}

.how__num {
	font-weight: 900;
	font-size: 70px;
	line-height: 1;
	letter-spacing: -1px;
}

  /* пунктирная линия после цифры */
.how__line {
	flex: 1 1 auto;
	height: 0;
	border-top: 3px dotted rgb(4, 26, 70);
	transform: translateY(6px);
 /* визуально как на скриншоте */
	;
}

.how__line.is-hidden {
	border-top-color: transparent;
}

.how__headline {
	margin: 0 0 10px;
	font-weight: 600;
	font-size: 24px;
	line-height: 1.15;
}

.how__text {
	margin: 0;
	font-size: 16px;
	line-height: 1.45;
	max-width: 28ch;
}

  /* адаптация под мобильные */
@media (max-width: 820px) {
	.how__steps {
		flex-direction: column;
		gap: 22px;
	}

	.how__line {
		border-top-width: 2px;
	}

	.how__text {
		max-width: none;
	}

	.how__step {
		width: 100%;
	}
}

/* MASTERS */
 

.masters {
	background: #cfe4fb;
	padding: clamp(22px, 3vw, 44px) 0;
	color: #0b1b35;
}

.masters__container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 18px;
}

.masters__title {
	text-align: center;
	margin: 0 0 22px;
	font-weight: 900;
	letter-spacing: .2px;
	font-size: clamp(28px, 4vw, 50px);
	line-height: 1.05;
}

.masters__sliderWrap {
	position: relative;
	padding: 0 56px;
 /* место под стрелки */
	;
}

.masters__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 999px;
	border: none;
	background: #0d4ac7;
	color: #fff;
	font-size: 28px;
	line-height: 1;
	display: grid;
	place-items: center;
	cursor: pointer;
	z-index: 10;
}

.masters__nav--prev {
	left: 0;
}

.masters__nav--next {
	right: 0;
}

.masters__nav:disabled {
	opacity: .5;
	cursor: default;
}

  /* Card */
.masterCard {
	background: #ffffff;
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 14px 30px rgba(0,0,0,.08);
	height: 100%;
	display: flex;
	flex-direction: column;
}

.masterCard__image {
	height: 260px;
	background: #e9eef7;
}

.masterCard__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.masterCard__body {
	padding: 16px 18px 18px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-height: 220px;
}

.masterCard__rating {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 700;
}

.stars {
	display: inline-flex;
	gap: 2px;
}

.star {
	width: 16px;
	height: 16px;
	display: inline-block;
	background: radial-gradient(circle at 35% 35%, #fff 0 12%, transparent 13%),
      conic-gradient(from 0deg, #ff8a00 0 100%);
	clip-path: polygon(
      50% 0%,
      61% 35%,
      98% 35%,
      68% 57%,
      79% 91%,
      50% 70%,
      21% 91%,
      32% 57%,
      2% 35%,
      39% 35%
    );
	opacity: .25;
 /* по умолчанию "пустая" */
	;
}

.star.is-on {
	opacity: 1;
}

.ratingValue {
	font-weight: 400;
	color: #0b1b35;
	font-size: 17px;
}

.masterCard__name {
	margin: 0;
	font-size: 22px;
	line-height: 1.15;
	font-weight: 700;
}

.masterCard__row {
	margin: 0;
	color: #111831;
	line-height: 1.35;
	font-size: 16px;
	font-weight: 300;
}

.masterCard__row b {
	color: #0b1b35;
	font-weight: 700;
	font-size: 16px;
}

.masterCard__cert {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.check {
	width: 18px;
	height: 18px;
	border-radius: 3px;
	background: #09d15f;
	color: #fff;
	display: inline-grid;
	place-items: center;
	font-size: 14px;
	font-weight: 900;
}

.masterCard__btn {
	margin-top: 6px;
	align-self: flex-start;
	background: #09d15f;
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: 12px 22px;
	font-weight: 800;
	cursor: pointer;
}

  /* Swiper spacing */
.mastersSwiper {
	padding: 8px 2px 18px;
}

@media (max-width: 900px) {
	.masters__sliderWrap {
		padding: 0 46px;
	}

	.masterCard__image {
		height: 230px;
	}
}

@media (max-width: 640px) {
	.masters__sliderWrap {
		padding: 0 0;
	}

	.masters__nav {
		display: none;
	}
}
  
/* SERTIFICATES */


section.sertificates {
	background: rgb(202, 228, 251);
}

section.sertificates .wrap {
	display: flex;
	gap: 20px;
}

section.sertificates .wrap .item {
	display: flex;
	width: calc(100%/5 - 10px);
	border-radius: 6px;
	overflow: hidden;
}

section.sertificates .wrap .item img {
	object-fit: cover;
	height: 100%;
	width: 100%;
}

/* GARANT */

 
section.guarantee {
	background: #cae4fb;
}

.guarantee__grid {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 22px;
	align-items: start;
}

  /* LEFT COLUMN */
.guarantee__left {
	display: grid;
	gap: 14px;
}

.miniCard {
	background: #fff;
	border-radius: 12px;
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 14px;
	align-items: center;
}

.miniCard__img {
	width: 160px;
	height: 124px;
	border-radius: 10px;
	overflow: hidden;
	background: #e9f2ff;
}

.miniCard__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.miniCard__title {
	margin: 0 0 6px;
	font-size: 18px;
	font-weight: 500;
	color: #0b2a60;
}

.miniCard__text {
	margin: 0;
	font-size: 15px;
	line-height: 1.45;
	color: #2f405f;
}

.textCard {
	background: #fff;
	border-radius: 12px;
	padding: 18px 18px 20px;
}

.textCard__p {
	margin: 0 0 12px;
	font-size: 15px;
	line-height: 1.6;
	color: #2f405f;
}

.textCard__h3 {
	margin: 10px 0 8px;
	font-size: 20px;
	font-weight: 500;
	color: #0b2a60;
}

  /* RIGHT COLUMN */
.guarantee__right {
	display: grid;
	gap: 14px;
}

.imgCard {
	background: #fff;
	border-radius: 12px;
	overflow: hidden;
}

.imgCard--large {
}

.imgCard img {
	width: 100%;
	height: 100%;
	max-height: 100%;
	display: block;
	object-fit: cover;
	border-radius: 8px;
}

.imgCard--large img {
	height: 360px;
	object-fit: contain;
 /* как талон на скрине */
	background: #fff;
}

.guarantee__rightBottom {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}

.guarantee__rightBottom .imgCard img {
	height: 190px;
	object-fit: cover;
}

.guarantee__rightBottom .imgCard {
	height: 280px;
	display: flex;
}

.guarantee__rightBottom .imgCard img {
	height: 100%;
}
  /* Responsive */
@media (max-width: 1000px) {
	.guarantee__grid {
		grid-template-columns: 1fr;
	}

	.imgCard--large img {
		height: 320px;
	}
}

@media (max-width: 560px) {
	.miniCard {
		grid-template-columns: 96px 1fr;
	}

	.miniCard__img {
		width: 96px;
		height: 120px;
	}

	.guarantee__rightBottom {
		grid-template-columns: 1fr;
	}

	.guarantee__rightBottom .imgCard img {
		height: 210px;
	}
}

/* REVIEWS */

.reviewsWide {
	padding: 60px 0;
	color: #ffffff;
	font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
	background: radial-gradient(1200px 380px at 20% 65%, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0) 60%),
      linear-gradient(180deg, #041a4a 0%, #03133c 100%);
	overflow: visible;
}

.reviewsWide h2 {
	margin-bottom: 0;
}
  /* Заголовок — можно оставить с легким ограничением по ширине, как в макете */
.reviewsWide__head {
	max-width: 1220px;
	margin: 0 auto 42px;
	padding: 0 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
}

.reviewsWide__title {
	margin: 0;
	font-weight: 900;
	font-size: clamp(26px, 3.2vw, 44px);
	line-height: 1.1;
}

.reviewsWide__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 44px;
	padding: 0 26px;
	border-radius: 999px;
	background: #00d45a;
	color: #ffffff;
	text-decoration: none;
	font-weight: 800;
	white-space: nowrap;
}

  /* ВАЖНО: тут ширина 100% без контейнера */
.reviewsWide__sliderArea {
	position: relative;
	width: 100%;
}

.reviewsWide__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 54px;
	height: 54px;
	border-radius: 999px;
	border: none;
	cursor: pointer;
	display: grid;
	place-items: center;
	font-size: 30px;
	line-height: 1;
	color: #ffffff;
	background: rgba(17, 74, 195, 0.95);
	box-shadow: 0 10px 26px rgba(0,0,0,0.25);
}

.reviewsWide__nav--prev {
	left: 24px;
}

.reviewsWide__nav--next {
	right: 24px;
}

.reviewsWide__nav:disabled {
	opacity: .55;
	cursor: default;
}

  /* Swiper */
.reviewsWideSwiper {
	padding: 6px 0 10px;
}

.reviewsWideSwiper .swiper-slide {
	height: auto;
	background: #f6f6f6;
}

  /* Card */
.reviewCardW {
	background: #ffffff;
	color: #0b1b35;
	border-radius: 14px;
	padding: 22px 22px 18px;
	height: 100%;
	box-shadow: 0 18px 42px rgba(0,0,0,0.22);
	display: grid;
	grid-template-rows: auto 1fr auto;
	gap: 14px;
}

.reviewCardW__top {
	display: grid;
	grid-template-columns: 92px 1fr;
	gap: 16px;
	align-items: center;
	margin-bottom: 30px;
}

.reviewCardW__logo {
	width: 92px;
	height: 92px;
	border-radius: 999px;
	background: #fff;
	display: flex;
	place-items: center;
}

.badgeW {
	font-weight: 900;
	letter-spacing: .5px;
	color: #1b2b4b;
}

.pinW {
	width: 30px;
	height: 30px;
	border-radius: 999px 999px 999px 0;
	background: #ff4a1f;
	transform: rotate(-45deg);
	position: relative;
	display: block;
}

.pinW:after {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: #ffffff;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.yellW {
	width: 46px;
	height: 46px;
	border-radius: 12px;
	background: #ff3b30;
	color: #fff;
	display: grid;
	place-items: center;
	font-weight: 900;
	font-size: 22px;
	transform: rotate(-6deg);
}

.otzW {
	width: 52px;
	height: 52px;
	border-radius: 999px;
	border: 8px solid #b0403f;
	box-sizing: border-box;
	position: relative;
}

.otzW:before {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: #b0403f;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.otzW:after {
	content: "";
	position: absolute;
	width: 12px;
	height: 12px;
	border-radius: 999px;
	background: #b0403f;
	left: 50%;
	top: -6px;
	transform: translateX(-50%);
}

.reviewCardW__name {
	font-weight: 600;
	font-size: 26px;
	margin: 0 0 4px;
}

.reviewCardW__src {
	color: #7a879b;
	font-size: 15px;
	line-height: 1.25;
}

.reviewCardW__src b {
	color: #6b778a;
	font-weight: 800;
}

.reviewCardW__text {
	font-size: 16px;
	line-height: 1.65;
	color: #24324a;
}

.reviewCardW__text.is-collapsed {
	display: -webkit-box;
	-webkit-line-clamp: 8;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.reviewCardW__more {
	background: transparent;
	border: none;
	padding: 0;
	color: #7a879b;
	font-weight: 700;
	cursor: pointer;
	justify-self: start;
}

.reviewCardW__more:hover {
	color: #5f6c80;
	text-decoration: underline;
}

  /* Responsive */
@media (max-width: 980px) {
	.reviewsWide__sliderArea {
		padding: 0 50px;
	}

	.reviewsWide__nav--prev {
		left: 16px;
	}

	.reviewsWide__nav--next {
		right: 16px;
	}
}

@media (max-width: 680px) {
	.reviewsWide__head {
		flex-direction: column;
		align-items: flex-start;
	}

	.reviewsWide__sliderArea {
		padding: 0 18px;
	}

	.reviewsWide__nav {
		display: none;
	}
}


/* FAQ */

.faq { 
	background: #ffffff; 
}

.faq__container {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 18px;
}

.faq__title {
	margin: 0 0 26px;
	text-align: center;
	color: #071a3f;
	font-weight: 900;
	font-size: clamp(30px, 3.3vw, 54px);
	line-height: 1.1;
}

.faq__list {
	display: grid;
	gap: 14px;
}

.faqItem {
	border-radius: 14px;
	background: #cfe6fb;
 /* светло-голубой как на скрине */
	overflow: hidden;
}

.faqItem__head {
	width: 100%;
	border: 0;
	background: transparent;
	text-align: left;
	padding: 22px 22px;
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 16px;
	cursor: pointer;
}

.faqItem__q {
	color: #071a3f;
	font-weight: 900;
	font-size: clamp(18px, 2vw, 24px);
	line-height: 1.25;
}

.faqItem__icon {
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: #ffffff;
	display: grid;
	place-items: center;
	box-shadow: 0 10px 22px rgba(7, 26, 63, 0.12);
}

.faqItem__glyph {
	position: relative;
	width: 18px;
	height: 18px;
	display: block;
}

  /* plus */
.faqItem__glyph--plus:before,
  .faqItem__glyph--plus:after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 18px;
	height: 2px;
	background: #0b45c6;
	transform: translate(-50%, -50%);
	border-radius: 2px;
}

.faqItem__glyph--plus:after {
	transform: translate(-50%, -50%) rotate(90deg);
}

  /* x */
.faqItem__glyph--x:before,
  .faqItem__glyph--x:after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 18px;
	height: 2px;
	background: #0b45c6;
	transform: translate(-50%, -50%) rotate(45deg);
	border-radius: 2px;
}

.faqItem__glyph--x:after {
	transform: translate(-50%, -50%) rotate(-45deg);
}

.faqItem__body {
	max-height: 0;
	overflow: hidden;
	transition: max-height 260ms ease;
}

.faqItem__content {
	padding: 0 22px 22px;
	color: #12305f;
	font-size: 15px;
	line-height: 1.7;
}

.faqItem.is-open .faqItem__body {
	max-height: 320px;
 /* хватит для пары абзацев; ниже в JS подстроим точнее */;
}

  /* чуть аккуратнее на мобилке */
@media (max-width: 640px) {
	.faqItem__head {
		padding: 18px 16px;
	}

	.faqItem__content {
		padding: 0 16px 18px;
	}

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


/* CONTACTS */

 

.contacts__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: start;
}

  /* MAP */
.contactsMap {
	position: relative;
}

.contactsMap__frame {
	height: 520px;
	border-radius: 14px;
	overflow: hidden;
	background: #e9f2ff;
	box-shadow: 0 18px 34px rgba(7, 26, 63, 0.12);
}

.contactsMap__open {
	position: absolute;
	left: 18px;
	bottom: 18px;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	border-radius: 999px;
	background: #ffffff;
	color: #0a2a66;
	font-weight: 700;
	font-size: 14px;
	text-decoration: none;
	box-shadow: 0 10px 22px rgba(7, 26, 63, 0.18);
}

.contactsMap__pin {
	width: 16px;
	height: 16px;
	position: relative;
	display: inline-block;
}

.contactsMap__pin:before {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 10px;
	height: 10px;
	background: #ff3b30;
	border-radius: 50%;
	transform: translate(-50%, -70%);
	box-shadow: 0 0 0 3px rgba(255, 59, 48, 0.16);
}

.contactsMap__pin:after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 8px solid #ff3b30;
	transform: translate(-50%, 0%);
}

  /* INFO */
.contactsInfo__title {
	margin: 0 0 10px;
	color: #071a3f;
	font-weight: 900;
	font-size: clamp(32px, 3.2vw, 52px);
	line-height: 1.05;
}

.contactsInfo__subtitle {
	margin: 0 0 18px;
	color: #041a46;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.6;
}

.contactsInfo__cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px 28px;
	margin: 18px 0 18px;
}

.contactsInfo__label {
	color: #041a46;
	font-weight: 500;
	font-size: 16px;
	margin-bottom: 6px;
}

.contactsInfo__link {
	color: #0b45c6;
	font-weight: 500;
	text-decoration: none;
}

.contactsInfo__link:hover {
	text-decoration: underline;
}

.contactsInfo__work {
	margin-top: 10px;
}

.contactsInfo__text {
	color: #041a46;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.6;
}

  /* FORM */
.contactsForm {
	margin-top: 26px;
	background: #f3f5f7;
	border-radius: 16px;
	padding: 22px 22px 18px;
}

.contactsForm__title {
	color: #041a46;
	font-weight: 500;
	font-size: 18px;
	line-height: 1.3;
	margin: 0 0 14px;
}

.contactsForm__row {
	display: grid;
	grid-template-columns: 0.5fr auto;
	gap: 14px;
	align-items: center;
}

.contactsForm__field {
	display: block;
}

.contactsForm__input {
	width: 100%;
	height: 52px;
	padding: 0 16px;
	border-radius: 999px;
	border: 1px solid rgba(7, 26, 63, 0.16);
	outline: none;
	font-size: 16px;
	font-weight: 600;
	color: #071a3f;
	background: #ffffff;
}

.contactsForm__input:focus {
	border-color: rgba(11, 69, 198, 0.55);
	box-shadow: 0 0 0 4px rgba(11, 69, 198, 0.10);
}

.contactsForm__btn {
	height: 52px;
	padding: 0 22px;
	border: 0;
	border-radius: 999px;
	background: #10c45a;
	color: #ffffff;
	font-weight: 900;
	font-size: 15px;
	cursor: pointer;
	white-space: nowrap;
	box-shadow: 0 14px 26px rgba(16, 196, 90, 0.28);
	transition: transform 120ms ease, filter 120ms ease;
}

.contactsForm__btn:hover {
	filter: brightness(0.98);
}

.contactsForm__btn:active {
	transform: translateY(1px);
}

.contactsForm__btn:disabled {
	opacity: 0.65;
	cursor: not-allowed;
	box-shadow: none;
}

.contactsForm__note {
	margin-top: 10px;
	color: rgba(7, 26, 63, 0.55);
	font-size: 13px;
	line-height: 1.5;
}

.contactsForm__noteLink {
	/* color: rgba(7, 26, 63, 0.75); */
	/* font-weight: 700; */
	/* text-decoration: underline; */
	/* text-underline-offset: 3px; */
}

.contactsForm__status {
	margin-top: 10px;
	font-size: 14px;
	font-weight: 700;
	min-height: 18px;
	color: #071a3f;
}

.contactsForm__status.is-ok {
	color: #0f8a3f;
}

.contactsForm__status.is-err {
	color: #c81e1e;
}

  /* Responsive */
@media (max-width: 980px) {
	.contacts__grid {
		grid-template-columns: 1fr;
		gap: 26px;
	}

	.contactsMap__frame {
		height: 420px;
	}
}

@media (max-width: 560px) {
	.contactsInfo__cols {
		grid-template-columns: 1fr;
	}

	.contactsForm__row {
		grid-template-columns: 1fr;
	}

	.contactsForm__btn {
		width: 100%;
	}

	.contactsMap__frame {
		height: 340px;
	}
}


/* FOOTER */

footer.footer {
	background: #090627;
	color: #ffffff;
	font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.footer__container {
	max-width: 1220px;
	margin: 0 auto;
	padding: 0 18px;
}

.footer__top {
	padding: 40px 0;
}

.footer__topRow {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
 /* как на скрине: центр по контенту */
	align-items: start;
	gap: 28px;
}

  /* LEFT */
.footer__brandCol {
	display: grid;
	gap: 30px;
	justify-items: start;
}

.footerBrand {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	color: #fff;
	max-width: 230px;
}

.footerBrand__icon {
	width: 52px;
	height: 52px;
	display: grid;
	place-items: center;
}

.footerBrand__text {
	display: grid;
	gap: 3px;
}

.footerBrand__name {
	font-size: 22px;
	line-height: 1.1;
	font-weight: 600;
	letter-spacing: 0.2px;
}

.footerBrand__nameWhite {
	color: #ffffff;
}

.footerBrand__nameGreen {
	color: #10c45a;
}

.footerBrand__tagline {
	font-size: 12px;
	line-height: 1.2;
	font-weight: 500;
	color: rgba(255,255,255,0.65);
}

.footerNav {
	display: flex;
	flex-wrap: wrap;
	gap: 18px 28px;
}

.footerNav__link {
	font-size: 15px;
	line-height: 1.2;
	font-weight: 600;
	color: rgba(255,255,255,0.92);
	text-decoration: none;
}

.footerNav__link:hover {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 4px;
}

  /* CENTER */
.footer__infoCol {
	display: grid;
	gap: 16px;
	justify-items: start;
	padding-top: 4px;
}

.footerInfo__label {
	font-size: 16px;
	line-height: 1;
	font-weight: 500;
	color: #ffffff6b;
	margin-bottom: 6px;
}

.footerInfo__value {
	font-size: 18px;
	line-height: 1.2;
	font-weight: 400;
	color: #ffffff;
	text-decoration: none;
}

.footerPay {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}
.footerPay img {
    width: 50px;
}

  /* RIGHT */
.footer__ctaCol {
	display: grid;
	justify-items: end;
	padding-top: 4px;
}

.footerCta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 44px;
	padding: 0 26px;
	border-radius: 999px;
	background: #1e56c4;
	color: #ffffff;
	text-decoration: none;
	font-size: 14px;
	line-height: 1;
	font-weight: 600;
	box-shadow: 0 14px 28px rgba(30,86,196,0.35);
	white-space: nowrap;
	transition: filter 120ms ease, transform 120ms ease;
}

.footerCta:hover {
	filter: brightness(1.04);
}

.footerCta:active {
	transform: translateY(1px);
}

  /* BOTTOM STRIP */
.footer__bottom {
	padding: 30px 0;
	border-top: 2px solid rgba(255,255,255,0.10);
	background: #090627;
}

.footer__bottomRow {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}

.footer__copy,
  .footer__privacy {
	font-size: 16px;
	line-height: 1.2;
	font-weight: 500;
	color: rgba(255,255,255,0.4);
}

.footer__privacy {
	text-decoration: none;
}

.footer__privacy:hover {
	color: rgba(255,255,255,0.60);
	text-decoration: underline;
	text-underline-offset: 4px;
}

  /* TO TOP */
.toTop {
	position: fixed;
	right: 22px;
	bottom: 26px;
	width: 52px;
	height: 52px;
	border-radius: 999px;
	border: 0;
	background: #1e56c4;
	box-shadow: 0 16px 30px rgba(30,86,196,0.35);
	cursor: pointer;
	display: none;
	z-index: 50;
}

.toTop.is-visible {
	display: inline-grid;
	place-items: center;
}

.toTop__chev {
	width: 12px;
	height: 12px;
	border-left: 2.5px solid rgba(255,255,255,0.92);
	border-top: 2.5px solid rgba(255,255,255,0.92);
	transform: rotate(45deg) translateY(1px);
}

.toTop:hover {
	filter: brightness(1.05);
}

.toTop:active {
	transform: translateY(1px);
}

  /* MOBILE: по твоему правилу (в одну колонку, порядок как раньше озвучивал) */
@media (max-width: 920px) {
	.footer__topRow {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.footer__brandCol,
    .footer__infoCol,
    .footer__ctaCol {
		justify-items: center;
		text-align: center;
	}

	.footerNav {
		justify-content: center;
		gap: 12px 18px;
		flex-direction: column;
	}

	.footer__ctaCol {
		order: 2;
	}

	.footer__infoCol {
		order: 3;
	}

	.footer__brandCol {
		order: 1;
	}

	.footer__bottomRow {
		flex-direction: column;
		gap: 10px;
		text-align: center;
	}

	.toTop {
		right: 16px;
		bottom: 16px;
		width: 50px;
		height: 50px;
	}
}


/* MODALS */

/* ===== POPUP LAYER ===== */
.popupLayer {
	position: fixed;
	inset: 0;
	z-index: 999;
	pointer-events: none;
}

.popup {
	position: absolute;
	inset: 0;
	display: none;
}

.popup.is-open {
	display: block;
	pointer-events: auto;
}

.popup__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
}

.popup__dialog {
	position: relative;
	width: min(560px, calc(100vw - 40px));
	margin: 26px auto;
	background: #ffffff;
	border-radius: 14px;
	padding: 34px 34px 28px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
	outline: none;
}

.popup__close {
	position: absolute;
	top: 10px;
	right: 14px;
	width: 36px;
	height: 36px;
	border: 0;
	border-radius: 10px;
	background: transparent;
	color: #1b1b1b;
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	font-weight: 500;
}

.popup__title {
	margin: 0;
	text-align: center;
	font-weight: 600;
 /* <= 600 */
	color: #041a46;
	font-size: 32px;
	line-height: 1;
}

.popup__title--big {
	font-size: 40px;
}

.popup__desc {
	margin: 10px 0 0;
	text-align: center;
	font-weight: 300;
	color: #2e384d;
	font-size: 16px;
	line-height: 1.5;
}

/* ===== FORM ===== */
.popupForm {
	margin-top: 22px;
	display: grid;
	gap: 16px;
}

.field__sr {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.field__input {
	width: 100%;
	height: 56px;
	border-radius: 999px;
	border: 1px solid #e3e3e3;
	background: #ffffff;
	padding: 0 22px;
	font-size: 16px;
	font-weight: 500;
	color: #0a1c3b;
	outline: none;
}

.field__input::placeholder {
	color: #8a96a6;
	font-weight: 500;
}

.field__input:focus {
	border-color: #1e56c4;
	box-shadow: 0 0 0 3px rgba(30, 86, 196, 0.14);
}

.field__input--square {
	border-radius: 6px;
	height: 58px;
}

.field__textarea {
	height: 150px;
	padding: 16px 18px;
	resize: vertical;
}

/* agree */
.agree {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	cursor: pointer;
	user-select: none;
}

.agree__input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.agree__box {
	width: 18px;
	height: 18px;
	border: 2px solid #1e56c4;
	border-radius: 2px;
	margin-top: 2px;
	flex: 0 0 auto;
	position: relative;
}

.agree__input:checked + .agree__box::after {
	content: "";
	position: absolute;
	left: 4px;
	top: 0px;
	width: 6px;
	height: 10px;
	border-right: 2px solid #1e56c4;
	border-bottom: 2px solid #1e56c4;
	transform: rotate(45deg);
}

.agree__text {
	font-size: 14px;
	line-height: 1.4;
	color: rgb(66, 69, 82);
	font-weight: 400;
}

.agree__link {
	color: rgb(25, 79, 185);
	text-decoration: underline;
	text-underline-offset: 3px;
	font-weight: 400;
}

/* submit */
.popupForm__submit {
	height: 58px;
	border-radius: 999px;
	border: 0;
	background: #00e04a;
	color: #ffffff;
	font-size: 16px;
	font-weight: 600;
 /* <= 600 */
	cursor: pointer;
	transition: filter 120ms ease, transform 120ms ease;
}

.popupForm__submit:hover {
	filter: brightness(0.98);
}

.popupForm__submit:active {
	transform: translateY(1px);
}

.popupForm__status {
	text-align: center;
	font-size: 14px;
	font-weight: 500;
	color: #2c3a4f;
	min-height: 18px;
}

/* ===== BODY LOCK ===== */
.body-lock {
	overflow: hidden;
}

/* ===== MOBILE ===== */
@media (max-width: 520px) {
	.popup__dialog {
		margin: 18px auto;
		padding: 26px 18px 22px;
		width: calc(100vw - 24px);
	}

	.popup__title {
		font-size: 28px;
	}

	.popup__title--big {
		font-size: 30px;
	}

	.field__input {
		height: 54px;
	}

	.popupForm__submit {
		height: 54px;
	}
}

/* MOBILE MENU */

.mMenu {
  position: fixed;
  inset: 0;
  z-index: 1000;
  pointer-events: none;
}

.mMenu.is-open {
  pointer-events: auto;
}

.mMenu__overlay {
  position: absolute;
  inset: 0;
  background: rgba(7, 22, 44, 0.5);
  opacity: 0;
  transition: opacity 180ms ease;
}

.mMenu.is-open .mMenu__overlay {
  opacity: 1;
}

.mMenu__panel {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: min(86vw, 360px);
  background: #fff;
  transform: translateX(102%);
  transition: transform 220ms ease;
  box-shadow: -18px 0 48px rgba(0, 0, 0, 0.24);
  outline: none;
  display: flex;
  flex-direction: column;
  padding: 22px 18px 18px;
}

.mMenu.is-open .mMenu__panel {
  transform: translateX(0);
}

.mMenu__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  color: #0a1c3b;
  font-weight: 500;
}

.mMenu__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-right: 44px; /* чтобы не наезжало на крестик */
  max-width: 250px;
}

.mMenu__logo {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: rgba(10, 28, 59, 0.08);
  flex: 0 0 auto;
}

.mMenu__brandName {
  font-weight: 600;
  font-size: 22px;
  color: #0a1c3b;
  line-height: 1.1;
}

.mMenu__brandNameAccent {
  color: #19c95a;
  font-weight: 600;
}

.mMenu__brandSub {
  margin-top: 4px;
  font-weight: 500;
  font-size: 12px;
  color: rgba(10, 28, 59, 0.72);
}

.mMenu__nav {
  margin-top: 22px;
  display: grid;
  gap: 0px;
}

.mMenu__link {
  text-decoration: none;
  color: #0a1c3b;
  font-weight: 400;
  font-size: 18px;
  padding: 3px 2px;
}

.mMenu__link:active {
  opacity: 0.75;
}

.mMenu__bottom {
  margin-top: auto;
  padding-top: 18px;
}

.mMenu__phone {
  display: inline-block;
  text-decoration: none;
  color: #1f49a6;
  font-weight: 600;
  font-size: 20px;
}
.mMenu__nav ul {
    list-style-type: none;
}

.mMenu__nav ul li.dropdown ul.submenu {margin-left: 20px;display: none;}

.mMenu__nav ul li.dropdown ul.submenu li a {
    text-decoration: none;
    color: #0a1c3b;
    font-weight: 400;
    font-size: 18px;
    padding: 3px 2px;
}

.mMenu__nav ul li.dropdown.show ul.submenu {
    display: block;
}

/* PRICES */

section.prices table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 30px;
}
section.prices a {
    color: #0C163B;
}
section.prices th, td {
	border: 1px solid #E2E7FF;
	padding: 12px;
	text-align: left;
	color: #090627;
}

section.prices th {
	background-color: #194fb9;
	color: white;
}

section.prices td:nth-child(2) {
	width: 120px;
 /* Установите желаемую ширину в пикселях или процентах */;
}

section.prices tr.subheading td {
	background-color: #B6C3FF;
	font-weight: bold;
}

section.prices .service-cell {
	display: flex;
	align-items: center;
	justify-content: space-between;
 /* Выравнивание по краям */
	gap: 10px;
 /* Отступ между текстом услуги и кнопкой */
	flex-direction: column;
	align-items: flex-start;
}
 

section.prices .order-button {
	background-color: #E4F3FF;
	border: none;
	border-radius: 30px;
	padding: 5px 10px;
	cursor: pointer;
	text-decoration: none;
}

section.prices .order-button:hover {
	background-color: #CAE4FB;
}

section.prices table tbody tr:nth-child(n+11) {
    display: none;
}
section.prices table.show tbody tr:nth-child(n+11) {
    display: table-row;
}
section.prices .alert {
    display: flex;
    gap: 20px;
    align-items: center;
    margin-bottom: 30px;
}

section.prices .alert .icon {
    display: flex;
    width: 36px;
    height: 36px;
    background: #ff0000;
    align-items: center;
    justify-content: center;
    color: #fff;
    border-radius: 100%;
    font-size: 30px;
    font-weight: 600;
}

section.prices .alert .text {
    flex: 1;
}

section.prices .alert .text .name {
    font-size: 18px;
    font-weight: 600;
}

.btn.btn-view {
    color: #00de5d;
    border: 1px solid #00de5d;
    margin: 0 auto;
}

.btn.btn-view:hover {
    background: #00de5d;
    color: #fff;
}
@media (max-width: 768px) {
	section.prices th, td {
		font-size: 14px;
	}
 
}

/* FAULTS */

section.faults {
    background: rgb(202, 228, 251);
}

section.faults .wrap {
	display: flex;
	flex-wrap: wrap;
	margin: -10px;
}

section.faults .card {
	border-radius: 12px;
	width: calc(50% - 20px);
 /* Учитывая отступ */
	padding: 20px;
	box-sizing: border-box;
	background-color: #fff;
	margin: 10px;
}

@media (max-width: 767px) {
	section.faults .card {
		width: calc(100% - 20px);
 /* Учитывая отступ */;
	}
}

section.faults .title {
	font-size: 20px;
	font-family: 'Rubik', Arial, sans-serif;
	font-weight: 500;
	color: #0c163b;
	margin-bottom: 10px;
}

section.faults .description {
	font-size: 16px;
	font-family: 'Rubik', Arial, sans-serif;
	font-weight: 400;
	color: #2e384d;
	margin-bottom: 15px;
}

section.faults .bottom-card {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

section.faults .price {
	font-size: 17px;
	font-family: 'Rubik', Arial, sans-serif;
	font-weight: 600;
	color: #194fb9;
	background: transparent;
}

section.faults .button {
	padding: 8px 16px;
	border: solid 2px #00de5d;
	color: #00de5d;
	text-decoration: none;
	border-radius: 30px;
}

section.faults .button:hover {
	background-color: #00de5d;
	border: solid 2px #00de5d;
	color: #fff;
	
}

@media (max-width: 767px) {
section.faults 	.price {
		font-size: 15px;
	}
}

/* BRANDS */

section.brands .desc {
    text-align: center;
    margin-bottom: 20px;
}

section.brands .brand-container {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
 /* Центрирование по горизонтали */;
}

section.brands .brand-card {
	border: 1px solid #cfcfcf;
	padding: 20px;
	text-align: center;
	margin: 10px;
	border-radius: 8px;
	width: 150px;
	cursor: pointer;
	transition: 0.3s;
}

section.brands .brand-card:hover {
	border-color: #f15c34;
}

section.brands p {
	color: #0c163b;
}

section.brands .brand-logo {
	width: 130px;
	height: auto;
}
						/* Медиазапрос для мобильных устройств */
@media (max-width: 768px) {
	section.brands .brand-card {
		width: 100%;
 /* Плашка будет занимать всю ширину экрана на мобильных устройствах */;
	}
}

/* WORKS */

section.works {
    background: rgb(4, 26, 70);
}
 
section.works .tab-buttons {
	display: flex;
	justify-content: center;
	border-radius: 6px;
	overflow: hidden;
	width: max-content;
	margin: 0 auto 30px;
}

section.works .tab-button {
	padding: 10px 20px;
	border: none;
	cursor: pointer;
	transition: all 0.3s ease;
	font-size: 14px;
	color: #041a46;
	font-weight: 400;
	padding-top: 14px;
	padding-bottom: 14px;
	background: #fff;
}

section.works .tab-button:hover {
	color: #333;
}

section.works .tab-button.active {
	color: #fff;
	background: #194fb9;
	font-weight: 600;
}

section.works .tab-content {
	display: none;
}

section.works .tab-content.active {
	display: block;
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
} 

/* Main grid */
section.works .grid {
	display: grid;
	grid-template-columns: 485px 1fr;
	gap: 36px;
	align-items: start;
}

      /* Slider card */
section.works .media-card {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.04);
	box-shadow: 0 14px 40px rgba(0, 0, 0, 0.25);
}

section.works .swiper {
	width: 100%;
	height: 560px;
}

section.works .swiper-slide {
	position: relative;
	width: 100%;
	height: 100%;
}

section.works .slide-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: saturate(1.05) contrast(1.05);
}

section.works .img-dim {
	position: absolute;
	inset: 0;
	background: linear-gradient(
          180deg,
          rgba(0, 0, 0, 0.2) 0%,
          rgba(0, 0, 0, 0.15) 45%,
          rgba(0, 0, 0, 0.35) 100%
        );
	pointer-events: none;
}

section.works .nav-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 36px;
	height: 36px;
	border-radius: 999px;
	border: 0;
	background: rgba(255, 255, 255, 0.9);
	color: #0b2a6c;
	display: grid;
	place-items: center;
	cursor: pointer;
	z-index: 10;
	box-shadow: 0 10px 18px rgba(0, 0, 0, 0.25);
}

section.works .nav-btn:hover {
	background: rgba(255, 255, 255, 1);
}

section.works .nav-btn:active {
	transform: translateY(-50%) scale(0.98);
}

section.works .nav-prev {
	left: 14px;
}

section.works .nav-next {
	right: 14px;
}

section.works .nav-icon {
	width: 16px;
	height: 16px;
	display: block;
}

section.works .repair-time {
	background: #00de5d;
	color: #ffffff;
	font-weight: 600;
	text-align: center;
	padding: 14px 16px;
	font-size: 16px;
	line-height: 20px;
}

      /* Right content */
section.works .meta {
	display: grid;
	grid-template-columns: 1.2fr 0.7fr 0.7fr;
	gap: 28px;
	padding-top: 6px;
}

section.works .meta .label {
	font-size: 20px;
	line-height: 26px;
	font-weight: 600;
	margin-bottom: 10px;
	color: #fff;
}

section.works .meta .value {
	font-size: 18px;
	line-height: 26px;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.92);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

section.works .problem-box {
	margin-top: 16px;
	border: 1px solid rgba(255, 255, 255, 0.55);
	border-radius: 12px;
	padding: 18px 20px 18px;
	background: rgba(0, 0, 0, 0.06);
}

section.works .problem-title {
	font-size: 20px;
	line-height: 26px;
	font-weight: 600;
	margin: 0 0 10px;
	color: #fff;
}

section.works .problem-text {
	margin: 0;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.92);
}

section.works .issues {
	margin-top: 18px;
}

section.works .issues-title {
	font-size: 20px;
	line-height: 26px;
	font-weight: 600;
	margin: 0 0 10px;
	color: #fff;
}

section.works .issues-lead {
	margin: 0 0 14px;
	font-size: 16px;
	line-height: 24px;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.92);
}

section.works .issues-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 12px;
	max-width: 640px;
}

section.works .issue {
	display: grid;
	grid-template-columns: 30px 1fr;
	gap: 14px;
	align-items: start;
}

section.works .badge-num {
	width: 26px;
	height: 26px;
	border-radius: 6px;
	background: #0f4fd2;
	display: grid;
	place-items: center;
	font-weight: 400;
	font-size: 18px;
	line-height: 14px;
	color: #ffffff;
	box-shadow: 0 10px 16px rgba(0, 0, 0, 0.2);
}

section.works .issue-text {
	font-size: 16px;
	line-height: 22px;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.95);
}

      /* Responsive */
@media (max-width: 1160px) {
	section.works .grid {
		grid-template-columns: 520px 1fr;
		gap: 28px;
	}

	section.works .swiper {
		height: 340px;
	}

	section.works .tab {
		min-width: 260px;
	}
}

@media (max-width: 980px) {
	section.works .tabs {
		justify-content: flex-start;
	}

	section.works .tabs-pill {
		width: 100%;
	}

	section.works .tab {
		min-width: 0;
		flex: 1;
		padding: 12px 14px;
	}

	section.works .grid {
		grid-template-columns: 1fr;
		gap: 22px;
	}

	section.works .swiper {
		height: 320px;
	}

	section.works .meta {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	section.works .meta .value {
		white-space: normal;
	}

	section.works .issues-list {
		max-width: none;
	}
}

@media (max-width: 420px) {
	section.works .swiper {
		height: 260px;
	}

	section.works .repair-time {
		font-size: 15px;
	}

	section.works .problem-box {
		padding: 16px 16px;
	}
}


section.works .wrap {
    width: 100%;
    margin-top: 40px;
}
section.works .title {
	font-weight: 600;
	font-size: 22px;
	line-height: 28px;
	margin: 0 0 8px;
	color: #fff;
}

section.works .subtitle {
	font-weight: 400;
	font-size: 16px;
	line-height: 22px;
	margin: 0 0 22px;
	color: rgba(255, 255, 255, 0.92);
}

      /* Cards grid */
section.works .cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 26px 28px;
	align-items: stretch;
	margin-bottom: 28px;
}

section.works .card {
	background: #cfe6ff;
	border-radius: 12px;
	min-height: 118px;
	display: grid;
	grid-template-columns: 44px 1fr;
	gap: 18px;
	align-items: center;
	padding: 18px 20px;
	box-shadow: 0 14px 40px rgba(0, 0, 0, 0.22);
}

section.works .num {
	width: 44px;
	height: 44px;
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.75);
	display: grid;
	place-items: center;
	color: #001a4b;
	font-weight: 600;
	font-size: 16px;
	line-height: 16px;
	background: transparent;
}

section.works .card-text {
	color: #001a4b;
	font-weight: 600;
	font-size: 18px;
	line-height: 24px;
}

      /* Place the 4th and 5th in row 2 like screenshot (left + center), leaving right empty */
section.works .card:nth-child(4) {
	grid-column: 1;
}

section.works .card:nth-child(5) {
	grid-column: 2;
}

      /* Pricing table */
section.works .table {
	margin-top: 12px;
}

section.works .row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 18px;
	padding: 22px 2px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.28);
	align-items: center;
}

section.works .row .left {
	font-weight: 400;
	font-size: 18px;
	line-height: 20px;
	color: #fff;
}

section.works .row .right {
	font-weight: 600;
	font-size: 18px;
	line-height: 22px;
	color: rgba(255, 255, 255, 0.95);
	text-align: right;
	white-space: nowrap;
}

section.works .total {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 18px;
	padding: 24px 2px 4px;
	align-items: baseline;
}

section.works .total .left {
	font-weight: 600;
	font-size: 20px;
	line-height: 26px;
	color: #ffffff;
}

section.works .total .right {
	font-weight: 600;
	font-size: 28px;
	line-height: 30px;
	color: #00de5d;
	white-space: nowrap;
}

      /* Responsive */
@media (max-width: 1120px) {
	section.works .cards {
		grid-template-columns: repeat(2, 1fr);
	}

	section.works .card:nth-child(4) {
		grid-column: auto;
	}

	section.works .card:nth-child(5) {
		grid-column: auto;
	}
}

@media (max-width: 720px) {
	 

	section.works .cards {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	section.works .card {
		min-height: 110px;
		grid-template-columns: 56px 1fr;
		padding: 16px 16px;
		gap: 14px;
	}

	section.works .card-text {
		font-size: 17px;
		line-height: 23px;
	}

	section.works .row {
		padding: 18px 2px;
		flex-direction: column;
		display: flex;
		align-items: start;
	}

	section.works .row .right {
		font-size: 16px;
		line-height: 20px;
	}

	section.works .total .right {
		font-size: 24px;
		line-height: 28px;
	}
}

@media (max-width: 390px) {
	section.works .title {
		font-size: 20px;
		line-height: 26px;
	}

	section.works .subtitle {
		font-size: 15px;
		line-height: 21px;
	}

	section.works .num {
		width: 42px;
		height: 42px;
	}
}

/* ALL PRICES */

section.all-prices {
    padding-bottom: 0;
}
section.all-prices .container-uslugi {
	display: flex;
	font-family: 'Rubik', Arial, sans-serif;
}

section.all-prices .sidebar-uslugi {
	width: 300px;
	margin-right: 10px;
}

section.all-prices .category-uslugi {
	margin-bottom: 10px;
	padding: 20px;
	background-color: #f6f6f6;
	color: #041a46;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.4px;
	text-align: center;
	cursor: pointer;
	text-transform: uppercase;
	border-radius: 0px;
	transition: all 0.2s ease-in-out;
}

section.all-prices .category-uslugi:hover {
	background-color: #E6E6E6;
}

section.all-prices .category-uslugi:last-child {
	margin-bottom: 0px;
}

section.all-prices .content-uslugi {
	flex: 1;
	background-color: #fff;
	padding: 0px;
	border-radius: 0px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

section.all-prices .buttons-wrapper {
	display: flex;
	border-radius: 30px;
	flex-wrap: wrap;
	gap: 10px;
}

section.all-prices .service-btn {
	background-color: #FDF3E8;
	padding: 12px 15px;
	text-align: center;
	font-size: 15px;
	font-weight: 500;
	text-decoration: none;
	color: #3F424B !important;
	border-radius: 0px;
	transition: all 0.2s ease-in-out;
}

section.all-prices .service-btn:hover {
	background-color: #FCEBD6;
}

section.all-prices .more-btn-wrapper {
	display: flex;
	justify-content: flex-end;
}

section.all-prices .more-btn {
	background-color: #00de5d;
	color: #ffffff !important;
	font-size: 15px;
	border-radius: 30px;
	font-weight: 600;
	padding: 10px 50px;
	margin: 10px 0 0 0;
	text-decoration: none;
	transition: all 0.2s ease-in-out;
}

section.all-prices .more-btn:hover {
	background-color: #00bb4f;
}

section.all-prices .hidden {
	display: none;
}

section.all-prices .active-category {
	background-color: #00de5d !important;
	color: #ffffff !important;
}

@media (max-width: 960px) {
	section.all-prices .container-uslugi {
		flex-direction: column;
	}

	section.all-prices .sidebar-uslugi {
		width: 100%;
		margin-right: 0;
		margin-bottom: 25px;
		max-height: 230px;
 /* Задаем максимальную высоту для показа 4 элементов */
		overflow-y: auto;
	}

	section.all-prices .category-uslugi {
		margin-bottom: 15px;
	}

	section.all-prices .content-uslugi {
		padding: 20px;
	}

	section.all-prices .content-wrapper {
		margin-bottom: 30px;
	}

	section.all-prices .content-wrapper h3 {
		font-size: 24px;
		margin-bottom: 20px;
	}

	section.all-prices .buttons-wrapper {
		gap: 10px;
	}

	section.all-prices .service-btn {
		padding: 10px;
		font-size: 16px;
	}

	section.all-prices .more-btn {
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 480px) {
	section.all-prices .buttons-wrapper {
		gap: 15px;
	}

	section.all-prices .service-btn {
		width: 100%;
	}

	section.all-prices .content-wrapper h3 {
		font-size: 22px;
	}
}

section.all-prices table {
	width: 100%;
	border-collapse: collapse;
}

section.all-prices th, section.all-prices td {
	border: 1px solid #E2E7FF;
	padding: 12px;
	text-align: left;
	color: #090627;
}

section.all-prices th {
	background-color: #194fb9;
	color: white;
}

section.all-prices td:nth-child(2) {
	width: 100px;
 /* Установите желаемую ширину в пикселях или процентах */;
}

section.all-prices tr.subheading td {
	background-color: #B6C3FF;
	font-weight: bold;
}

section.all-prices .service-cell {
	display: flex;
	align-items: center;
	justify-content: space-between;
 /* Выравнивание по краям */
	gap: 10px;
 /* Отступ между текстом услуги и кнопкой */
	flex-direction: column;
	align-items: flex-start;
}

section.all-prices .service-cell a {
    color: #0C163B;
}

section.all-prices .order-button {
	background-color: #E4F3FF;
	border: none;
	border-radius: 30px;
	padding: 5px 10px;
	cursor: pointer;
	text-decoration: none;
}

section.all-prices .order-button:hover {
	background-color: #CAE4FB;
}

@media (max-width: 768px) {
	section.all-prices th, section.all-prices td {
		font-size: 14px;
	}

	section.all-prices td:nth-child(2) {
		width: 80px;
 /* Установите желаемую ширину в пикселях или процентах */;
	}
}

/* LEADER */

.leader {
	width: 100%;
	padding: 0;
}

.leader__inner {
	display: grid;
	grid-template-columns: 1.3fr 0.7fr;
	min-height: 300px;
}

.leader__content {
	background: #cfe9ff;
	padding: 46px 56px 44px;
	display: grid;
	align-content: start;
	gap: 16px;
	padding-left: calc((100% - 530px)/2);
}

.leader__title {
	margin: 0;
	font-weight: 600;
	font-size: 44px;
	line-height: 52px;
}

.leader__text {
	margin: 0 auto;
	max-width: 920px;
	font-weight: 400;
	font-size: 18px;
	line-height: 28px;
	color: rgba(11, 15, 26, 0.88);
}

.leader__bottom {
	margin-top: 18px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
}

.leader__sign {
	font-style: italic;
	font-weight: 600;
	font-size: 16px;
	line-height: 22px;
	color: rgba(11, 15, 26, 0.85);
	max-width: 520px;
}

.leader__mail {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 16px 22px;
	min-width: 300px;
	border-radius: 999px;
	background: #1a55c9;
	color: #ffffff;
	text-decoration: none;
	font-weight: 600;
	font-size: 16px;
	line-height: 20px;
	box-shadow: 0 10px 26px rgba(26, 85, 201, 0.35);
	white-space: nowrap;
}

.leader__photo {
	background: #d4d6d9;
	position: relative;
	overflow: hidden;
	display: grid;
	place-items: end center;
	max-height: 500px;
}

.leader__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center bottom;
	display: block;
}

      /* Responsive */
@media (max-width: 1100px) {
	.leader__content {
		padding: 40px 34px 36px;
	}

	.leader__title {
		font-size: 38px;
		line-height: 46px;
	}

	.leader__text {
		font-size: 17px;
		line-height: 27px;
	}

	.leader__mail {
		min-width: 280px;
	}
}

@media (max-width: 860px) {
	.leader__inner {
		grid-template-columns: 1fr;
	}

	.leader__photo {
		order: -1;
		height: 280px;
	}

	.leader__bottom {
		flex-direction: column;
		align-items: flex-start;
	}

	.leader__mail {
		min-width: 0;
		width: 100%;
		max-width: 420px;
	}
}

@media (max-width: 480px) {
	.leader__content {
		padding: 28px 16px 26px;
	}

	.leader__title {
		font-size: 28px;
		line-height: 34px;
	}

	.leader__text {
		font-size: 15px;
		line-height: 24px;
	}

	.leader__sign {
		font-size: 14px;
		line-height: 20px;
	}

	.leader__mail {
		padding: 14px 16px;
		font-size: 14px;
		line-height: 18px;
	}
}


/* ABOUT */

section.about-page .history {
    background: #194fb9;
    border-radius: 16px;
    padding: 40px;
}

section.about-page .history .h2 {
    margin-top: 0;
}

section.about-page .history p {
    color: #ffffff;
    font-size: 16px;
    font-family: 'Rubik', Arial, sans-serif;
    line-height: 1.55;
    font-weight: 400;
}

section.about-page .tech {
    display: flex;
    gap: 30px;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

section.about-page .tech .item {
    background: #cae4fb;
    border-radius: 10px;
    padding: 30px;
    display: flex;
    gap: 40px;
    width: calc(100%/2 - 20px);
    align-items: center;
}

section.about-page .tech .item .image {
    width: 120px;
}

section.about-page .tech .item .text {
    flex: 1;
}

section.about-page .tech .item .text .name {
    font-size: 20px;
    color: #041a46;
    font-weight: 600;
    margin-bottom: 10px;
}

/* CONTACT */

 

section.contact .contact__subtitle {
	margin: 10px 0 28px;
	text-align: center;
	font-weight: 400;
	font-size: 16px;
	line-height: 22px;
	color: rgba(10, 15, 28, 0.78);
}

section.contact .contact__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 22px;
	align-items: stretch;
}

section.contact .panel {
	background: linear-gradient(180deg, #081b46 0%, #07173a 100%);
	border-radius: 12px;
	padding: 22px 26px;
	min-height: 96px;
	box-shadow: 0 14px 38px rgba(0, 0, 0, 0.18);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
}

section.contact .panel__left {
	display: flex;
	align-items: baseline;
	gap: 14px;
	flex-wrap: wrap;
	min-width: 0;
}

section.contact .panel__label {
	font-weight: 600;
	font-size: 20px;
	line-height: 26px;
	color: rgba(255, 255, 255, 0.95);
	white-space: nowrap;
}

section.contact .panel__value {
	font-weight: 600;
	font-size: 20px;
	line-height: 26px;
	color: rgba(255, 255, 255, 0.95);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

section.contact .panel__value--green {
	color: #00de5d !important;
	font-size: 24px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.4;
	font-weight: 600;
}
 

section.contact .contact__note {
	margin: 18px 0 0;
	text-align: center;
	font-weight: 600;
	font-size: 14px;
	line-height: 20px;
	color: rgba(10, 15, 28, 0.82);
}

section.contact .link-reset {
	text-decoration: none;
	color: #fff;
}
section.contact .panel  .btn {
    max-width: 200px;
}
      /* Responsive */
@media (max-width: 980px) {
	section.contact .contact__grid {
		grid-template-columns: 1fr;
	}

	section.contact .panel {
		padding: 20px 20px;
	}

	section.contact .panel__label,
        .panel__value {
		font-size: 20px;
		line-height: 24px;
	}
}

@media (max-width: 520px) {
	  

	section.contact .contact__subtitle {
		margin: 8px 0 18px;
		font-size: 14px;
		line-height: 20px;
	}

	section.contact .panel {
		flex-direction: column;
		align-items: flex-start;
		gap: 14px;
	}

	section.contact .panel__left {
		width: 100%;
	}

	section.contact .panel__label,
        .panel__value {
		font-size: 18px;
		line-height: 22px;
		white-space: normal;
	}
 

	section.contact .contact__note {
		text-align: left;
		font-size: 13px;
		line-height: 18px;
		margin-top: 14px;
	}
}

/* ALL WORKS */

section.all-works .works-grid {
	display: flex;
	gap: 20px;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
}

section.all-works .work-card {
	background: #f6f6f6;
	border-radius: 12px;
	flex: 1 1 calc(33.333% - 13.33px);
	min-width: 280px;
	text-align: left;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

section.all-works .work-card-content {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

section.all-works .work-card img {
	width: 100%;
	height: 230px;
	object-fit: cover;
}

section.all-works .work-card-title {
	font-family: 'Rubik', sans-serif;
	padding: 18px 20px 0px 20px;
	font-weight: bold;
	font-size: 1.1em;
	color: #041a46;
}

section.all-works .work-card p {
	font-family: 'Rubik', sans-serif;
	padding: 10px 20px;
	color: #041a46;
}

section.all-works .more-link {
	font-family: 'Rubik', sans-serif;
	display: block;
	margin: 20px;
	text-align: center;
	padding: 12px;
	color: #fff;
	background-color: #194FB9;
	text-decoration: none;
	border-radius: 30px;
	margin-top: auto;
}

section.all-works .more-link:hover {
	background-color: #0B3993;
}

/* BLOG PAGE */

section.blog-page .layout {
	display: flex;
	gap: 20px;
}

section.blog-page .articles {
	flex: 2;
 /* Две статьи займут две части, так что здесь можно использовать flex: 2 */
	display: grid;
	grid-template-columns: repeat(2, 1fr);
 /* Две статьи в строку */
	gap: 20px;
}

section.blog-page .sidebar {
	flex: 1;
 /* Одна часть для сайдбара */;
}

section.blog-page .article {
	border-radius: 8px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

section.blog-page .article img {
	border-radius: 8px;
	width: 380px;
	height: 210px;
	object-fit: cover;
}

section.blog-page .article-content {
	padding: 12px 0 0 0;
	flex: 1;
	display: flex;
	flex-direction: column;
}

section.blog-page .article .tags {
	margin-bottom: 10px;
}

section.blog-page .article .tag {
	display: inline-block;
	background: #CAE4FB;
	color: #333;
	padding: 2px 6px;
	margin-right: 4px;
	font-size: 12px;
	border-radius: 4px;
	cursor: pointer;
}

section.blog-page .title {
	font-size: 17px;
	font-weight: 700;
	margin: 0 0 10px;
	color: #0C163B;
}

section.blog-page .article .meta {
	display: flex;
	gap: 10px;
	font-size: 14px;
	color: #777;
	margin-top: 4px;
}

section.blog-page .meta img {
	margin: 0 -6px 0 0;
	height: 16px;
}

section.blog-page .sidebar {
	flex: 1;
}

section.blog-page .sidebar .tags-list {
	background: #CAE4FB;
	padding: 15px;
	border-radius: 8px;
}

section.blog-page .side-title {
	font-size: 18px;
	margin-top: 0;
	font-weight: 600;
}

section.blog-page .tags-list .tag-item {
	display: flex;
	justify-content: space-between;
	margin: 6px 0;
	cursor: pointer;
}

section.blog-page .tags-list .tag-item span {
	background: #fff;
	padding: 2px 6px;
	border-radius: 50%;
	font-size: 12px;
	color: #333;
}

section.blog-page .social-follow, .newsletter-subscription {
	background: #CAE4FB;
	padding: 15px;
	border-radius: 8px;
	margin-top: 20px;
}

section.blog-page .social-follow span, .newsletter-subscription span {
	display: block;
	margin-bottom: 10px;
}

section.blog-page .subscription-form button img {
	width: 22px;
	height: 22px;
}

section.blog-page .social-icons a img {
	width: 26px;
	height: 26px;
	margin-right: 8px;
}

section.blog-page .subscription-form {
	display: flex;
	align-items: center;
}

section.blog-page .subscription-form input {
	padding: 12px;
	border-radius: 6px;
	border: none;
	background: #fff;
	margin-right: 8px;
}

section.blog-page .subscription-form button {
	padding: 8px 10px;
	border-radius: 6px;
	background: #00DE5D;
	border: none;
	cursor: not-allowed;
}
 
						/* Мобильная версия */
@media (max-width: 768px) {
	section.blog-page .layout {
		flex-direction: column;
	}

	section.blog-page .articles {
		grid-template-columns: 1fr;
	}

	 
	section.blog-page .article img {
		width: 100%;
	}
}

/* ARTICLE */

@media screen and (max-width: 767px) {
    section.article .wrap {
    	flex-direction: column;
     /* Столбец для полной ширины */
    	width: 100%;
    }
    
    section.article .content {
    	width: 100%; 
    }
}
section.article .image-main {
    width: 100%;
    display: flex;
    height: 500px;
    border-radius: 20px;
    overflow: hidden;
    margin-bottom: 30px;
}

section.article .image-main img {
    height: 100%;
    width: 100%;
    object-fit: cover;
} 

section.article .wrap {
	display: flex;
	width: 100%;
	gap: 20px;
	position: relative;
}

section.article .content {
	flex: 3;
	color: #424552;
	font-size: 16px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.6;
	font-weight: 400;
	counter-reset: myCounter;
}
section.article ol {
    padding-left: 22px;
}
section.article ul {
    padding-left: 20px;
}
section.article a {
    color: #424552;
    text-decoration: none;
}
section.article .content p + * {
	margin-top: 20px;
}

section.article .toc {
	background: #F0F8F0;
	padding: 15px 20px;
	border-radius: 10px;
	margin-bottom: 20px;
}

section.article .side-title {
	font-size: 20px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.6;
	font-weight: 600;
	margin-top: 0;
}

section.article .toc ul {
	list-style-type: disc !important;
	padding-left: 40px;
}

section.article .sidebar {
	flex: 1;
}

section.article .sidebar .block {
	color: #424552;
	font-size: 14px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.6;
	font-weight: 400;
	background: #CAE4FB;
	border-radius: 10px;
	padding: 15px;
	margin-bottom: 20px;
}

section.article .toc-sticky {
	color: #424552;
	font-size: 16px;
	font-family: 'Rubik', Arial, sans-serif;
	line-height: 1.6;
	font-weight: 400;
	position: sticky;
	top: 110px;
	background: #CAE4FB;
	border-radius: 10px;
	padding: 15px;
}

section.article .sidebar h3,
section.article .questions h3 {
	margin-top: 0;
	font-size: 24px;
	font-family: 'Rubik', Arial, sans-serif;
	font-weight: 700;
}

section.article .sidebar a {
	display: flex;
	align-items: center;
	color: #424552;
	text-decoration: none;
	margin: 8px 0;
}

section.article .sidebar a img {
	width: 90px;
	height: 70px;
	margin-right: 10px;
	border-radius: 5px;
}

section.article .sidebar a:hover {
	text-decoration: underline;
}

section.article h2 {
	margin-top: 40px;
	font-size: 42px;
	font-family: 'Rubik', Arial, sans-serif;
	font-weight: 700;
	line-height: 1.4;
	color: #0C163B;
}

section.article h3 {
	margin-top: 25px;
	font-size: 24px;
	font-family: 'Rubik', Arial, sans-serif;
	font-weight: 700;
	color: #333;
}

@media screen and (max-width: 768px) {
	section.article .toc-sticky,
	section.article .sidebar .block {
		display: none;
	}
}

section.article .block {
	background: #fff;
	border: 1px solid #ddd;
	border-radius: 10px;
	padding: 20px;
	margin-bottom: 25px;
	box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

section.article .questions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border: 1px solid #7CBF6A;
}

section.article .questions .btn {
	background: #4CAF50;
	color: #fff;
	border: none;
	padding: 10px 20px;
	border-radius: 30px;
	cursor: pointer;
}

section.article .questions .btn:hover {
	background: #43A047;
}

section.article .master-form {
	background: #69B648;
	color: #fff;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 25px;
	border-radius: 10px;
}

section.article .master-form input {
	padding: 10px;
	border: none;
	border-radius: 6px;
	width: 200px;
	margin-right: 10px;
 /* добавлен отступ */;
}

section.article .master-form button {
	padding: 10px;
	width: 200px;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	background: #FF9800;
	color: #fff;
}

section.article .master-form button:hover {
	background: #E68A00;
}

section.article .master-form img {
	width: 130px;
	height: 130px;
}

@media (max-width: 600px) {
	section.article .master-form button {
		margin-top: 10px;
	}

	section.article .master-form img {
		display: none;
	}
}

section.article .author {
	display: flex;
	align-items: center;
	gap: 20px;
}

section.article .author img {
	width: 80px;
	height: 80px;
	border-radius: 50%;
}

section.article .author-info h4 {
	margin: 0;
}

section.article .verified {
	color: green;
	font-size: 14px;
}

section.article .tags {
	margin-top: 10px;
}

section.article .tag {
	display: inline-block;
	background: #F0F0F0;
	color: #333;
	padding: 5px 10px;
	margin-right: 8px;
	border-radius: 6px;
	font-size: 14px;
}

section.article .stars {
	margin-top: 10px;
}

section.article .star {
	font-size: 24px;
	cursor: pointer;
	color: #ddd;
}

section.article .star.active {
	color: gold;
}

 

@media (max-width: 768px) {
	section.article .questions {
		flex-direction: column;
		align-items: flex-start;
	}

	section.article .questions .side-title,
	section.article .questions .btn,
	section.article .questions a {
		margin-bottom: 10px; 
	}

	section.article .questions a:last-child {
		margin-bottom: 0; 
	}
}

@media (max-width: 960px) {
	section.article h2 {
		font-size: 26px;
	}

	section.article h3 {
		font-size: 22px;
	}
}


/* META */
 
section.meta {
    padding-bottom: 0;
} 
section.meta.pb {
    padding-bottom: 60px;
}
section.meta .meta__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
}

section.meta .meta__left {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
}

section.meta .meta__avatar {
	width: 90px;
	height: 90px;
	border-radius: 50%;
	overflow: hidden;
	flex: 0 0 auto;
}

section.meta .meta__avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

section.meta .meta__author {
	min-width: 0;
}

section.meta .meta__name {
	margin: 0;
	font-weight: 600;
	font-size: 22px;
	line-height: 28px;
	color: #041a46;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

section.meta .meta__views {
	margin-top: 6px;
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 400;
	font-size: 16px;
	line-height: 18px;
	color: rgba(10, 15, 28, 0.55);
}

section.meta .meta__views svg {
	width: 18px;
	height: 18px;
	flex: 0 0 auto;
	opacity: 0.55;
}

section.meta .meta__center {
	flex: 0 1 340px;
	min-width: 240px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

section.meta .meta__line {
	font-weight: 400;
	font-size: 16px;
	line-height: 18px;
	color: #2e384d;
	white-space: nowrap;
}

section.meta .meta__right {
	flex: 0 0 auto;
	display: flex;
	justify-content: flex-end;
	flex-direction: column;
	gap: 5px;
}

section.meta .meta__tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 7px 12px;
	border-radius: 6px;
	background: #d6e8ff;
	color: #041a46;
	/* font-weight: 600; */
	font-size: 14px;
	line-height: 16px;
	text-decoration: none;
	white-space: nowrap;
}
section.meta  .meta__check {
    color: #00bb4f;
    font-weight: 600;
}

section.meta .meta__stars {
    display: flex;
    align-items: center;
    gap: 15px;
    color: #777777;
    font-size: 16px;
    font-weight: 400;
}
      /* Responsive */
@media (max-width: 860px) {
	section.meta .meta__row {
		flex-wrap: wrap;
		align-items: flex-start;
	}

	section.meta .meta__center {
		flex: 1 1 100%;
		min-width: 0;
		padding-left: 70px;
 /* визуально как на десктопе: под контентом слева */;
	}

	section.meta .meta__right {
		width: 100%;
		justify-content: flex-start;
		padding-left: 70px;
	}
}

@media (max-width: 520px) {
	 
	section.meta .meta__avatar {
		width: 48px;
		height: 48px;
	}

	section.meta .meta__name {
		font-size: 18px;
		line-height: 24px;
	}

	section.meta .meta__center,
        .meta__right {
		padding-left: 62px;
	}

	section.meta .meta__line {
		white-space: normal;
	}
}


/* BOTTOM ARTICLE */
section.cta-block {
    padding: 0;
}

section.cta-block .btn {
    max-width: 300px;
}
/* ===== TOP STRIP ===== */
section.cta-block .qa {
	background: #ffffff;
	border: 1px solid #18c158;
	border-radius: 18px;
	padding: 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
}

section.cta-block .qa__title {
	margin: 0;
	font-weight: 600;
	font-size: 28px;
	line-height: 36px;
	color: #0a1e4a;
}

section.cta-block .qa__center {
	display: flex;
	justify-content: center;
	flex: 1 1 auto;
}

section.cta-block .qa__btn {
	border: 0;
	cursor: pointer;
	padding: 14px 26px;
	border-radius: 999px;
	background: #11d154;
	color: #ffffff;
	font-weight: 600;
	font-size: 16px;
	line-height: 20px;
	box-shadow: 0 10px 20px rgba(17, 209, 84, 0.25);
	white-space: nowrap;
}

section.cta-block .qa__phone {
	font-weight: 600;
	font-size: 22px;
	line-height: 26px;
	color: #0a1e4a;
	text-decoration: none;
	white-space: nowrap;
}

      /* ===== BIG CTA CARD ===== */
section.cta-block .cta {
	margin-top: 18px;
	background: #194fb9;
	border-radius: 18px;
	padding: 22px;
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: 18px;
	align-items: center;
}

section.cta-block .cta__left {
	padding: 22px 22px 22px 22px;
	color: #ffffff;
}

section.cta-block .cta__h {
	margin: 0;
	font-weight: 600;
	font-size: 30px;
	line-height: 38px;
}

section.cta-block .cta__p {
	margin: 10px 0 18px;
	font-weight: 500;
	font-size: 15px;
	line-height: 20px;
	color: rgba(255, 255, 255, 0.9);
}

section.cta-block .cta__form {
	display: flex;
	align-items: center;
	gap: 14px;
}

section.cta-block .cta__input {
	width: 290px;
	max-width: 100%;
	height: 48px;
	padding: 0 18px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.55);
	background: transparent;
	color: #ffffff;
	outline: none;
	font-weight: 500;
	font-size: 14px;
}

section.cta-block .cta__input::placeholder {
	color: rgba(255, 255, 255, 0.75);
}

section.cta-block .cta__btn {
	height: 48px;
	padding: 0 26px;
	border-radius: 999px;
	border: 0;
	cursor: pointer;
	background: #11d154;
	color: #ffffff;
	font-weight: 600;
	font-size: 14px;
	line-height: 18px;
	white-space: nowrap;
}

section.cta-block .cta__note {
	margin: 12px 0 0;
	font-weight: 400;
	font-size: 12px;
	line-height: 16px;
	color: rgba(255, 255, 255, 0.85);
}

section.cta-block .cta__note a {
	color: #ffffff;
	text-decoration: underline;
}

section.cta-block .cta__media {
	border-radius: 16px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.08);
	height: 210px;
	display: flex;
	align-items: center;
	justify-content: center;
}

section.cta-block .cta__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

      /* ===== Responsive ===== */
@media (max-width: 980px) {
	section.cta-block .qa {
		padding: 18px 18px;
		flex-wrap: wrap;
		justify-content: flex-start;
	}

	section.cta-block .qa__center {
		justify-content: flex-start;
		width: 100%;
	}

	section.cta-block .cta {
		grid-template-columns: 1fr;
	}

	section.cta-block .cta__media {
		order: -1;
		height: 220px;
	}

	section.cta-block .cta__left {
		padding: 10px 12px 16px 12px;
	}
}

@media (max-width: 520px) {
	 

	section.cta-block .qa__title {
		font-size: 20px;
		line-height: 26px;
	}

	section.cta-block .qa__btn {
		width: 100%;
		text-align: center;
		padding: 14px 18px;
		font-size: 14px;
	}

	section.cta-block .qa__phone {
		font-size: 18px;
		line-height: 22px;
	}

	section.cta-block .cta {
		padding: 16px;
	}

	section.cta-block .cta__h {
		font-size: 22px;
		line-height: 28px;
	}

	section.cta-block .cta__form {
		gap: 10px;
	}

	section.cta-block .cta__input,
        .cta__btn {
		width: 100%;
	}

	section.cta-block .cta__media {
		height: 180px;
	}
}

/* SOVET */

section.sovet {
    background: rgb(246, 246, 246);
}

section.sovet .item {
    background: #2e384d;
    border-radius: 9px;
    padding: 40px;
    margin-bottom: 20px;
}

section.sovet .item .name {
    display: flex;
    align-items: center;
    gap: 30px;
    margin-bottom: 15px;
    font-size: 18px;
    line-height: 1.55;
    color: #fff;
    font-weight: 700;
}

section.sovet .item .name span {
    color: #00de5d;
}

section.sovet .item .text {
    font-size: 18px;
    line-height: 1.55;
    color: #fff;
}

/* SPEC */

 
section.spec .spec__wrap {
	max-width: 1160px;
	margin: 0 auto;
}

section.spec .spec__top {
	display: grid;
	grid-template-columns: 320px 1fr 360px;
	gap: 26px;
	align-items: start;
}

      /* LEFT PHOTO */
section.spec .spec__photo {
	border-radius: 12px;
	overflow: hidden;
	background: #f3f6ff;
	height: 290px;
}

section.spec .spec__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

      /* MIDDLE INFO */
section.spec .spec__info {
}

section.spec .spec__row {
	padding: 14px 0 16px;
}

section.spec .spec__row + .spec__row {
	border-top: 1px solid #dfe8ff;
}

section.spec .spec__label {
	margin: 0 0 6px;
	font-size: 16px;
	line-height: 20px;
	font-weight: 400;
	color: #535353;
}

section.spec .spec__value {
	margin: 0;
	font-size: 20px;
	line-height: 28px;
	font-weight: 600;
	color: #090627;
}

section.spec .spec__year {
	margin: 0;
	font-size: 30px;
	line-height: 34px;
	font-weight: 600;
	color: #00de5d;
}

      /* RIGHT CARD */
section.spec .spec__sideTitle {
	margin: 0 0 12px;
	font-size: 18px;
	line-height: 24px;
	font-weight: 400;
	color: #535353;
}

section.spec .specCard {
	border: 1px solid #e3e9f8;
	border-radius: 10px;
	overflow: hidden;
	background: #ffffff;
	display: grid;
	grid-template-columns: 150px 1fr;
	min-height: 140px;
}

section.spec .specCard__media {
	background: #cfe6ff;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 12px;
}

section.spec .specCard__media img {
	width: 96px;
	max-width: 100%;
	height: auto;
	display: block;
}

section.spec .specCard__content {
	padding: 18px 18px 16px;
}

section.spec .specCard__name {
	margin: 0 0 14px;
	font-size: 18px;
	line-height: 22px;
	font-weight: 600;
	color: #0a1e4a;
}

section.spec .specCard__price {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 16px;
	border-radius: 999px;
	background: #00de5d;
	color: #ffffff;
	font-size: 14px;
	line-height: 18px;
	font-weight: 600;
	white-space: nowrap;
}

      /* CERTS */
section.spec .spec__bottom {
	margin-top: 18px;
}

section.spec .spec__certTitle {
	margin: 0 0 10px;
	font-size: 18px;
	line-height: 24px;
	font-weight: 400;
	color: #0a1e4a;
}

section.spec .spec__certList {
	margin: 0;
	padding: 0;
	list-style: none;
}

section.spec .spec__certItem {
	margin: 0;
	font-size: 20px;
	line-height: 32px;
	font-weight: 600;
	color: #090627;
}

      /* RESPONSIVE */
@media (max-width: 1120px) {
	section.spec .spec__top {
		grid-template-columns: 320px 1fr 360px;
		gap: 20px;
	}

	section.spec .spec__photo {
		height: 240px;
	}
}

@media (max-width: 980px) {
	section.spec .spec__top {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	section.spec .spec__photo {
		height: 240px;
	}

	section.spec .specCard {
		grid-template-columns: 140px 1fr;
	}
}

@media (max-width: 520px) {
	 

	section.spec .spec__photo {
		height: 210px;
		border-radius: 12px;
	}

	section.spec .spec__label {
		font-size: 15px;
		line-height: 20px;
	}

	section.spec .spec__value {
		font-size: 18px;
		line-height: 26px;
	}

	section.spec .spec__year {
		font-size: 28px;
		line-height: 32px;
	}

	section.spec .spec__sideTitle {
		font-size: 16px;
		line-height: 22px;
	}

	section.spec .specCard__name {
		font-size: 16px;
		line-height: 20px;
	}

	section.spec .spec__certItem {
		font-size: 18px;
		line-height: 30px;
	}
}


/* FREVIEW FORM */

section.review-form {background: rgb(4, 26, 70);}

section.review-form .review__card {
	width: 100%;
	max-width: 1200px;
	background: #ffffff;
	border-radius: 18px;
	padding: 44px 46px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
}

section.review-form .review__grid {
	display: grid;
	grid-template-columns: 1fr 1.55fr;
	gap: 40px;
	align-items: start;
	padding: 40px;
	background: #fff;
	border-radius: 20px;
}

      /* LEFT */
section.review-form .review__title {
	margin: 0 0 18px;
	font-weight: 600;
	font-size: 44px;
	line-height: 50px;
	color: #071b49;
}

section.review-form .review__text {
	margin: 0;
	font-weight: 400;
	font-size: 16px;
	line-height: 24px;
	color: #1c2d57;
	max-width: 360px;
}

      /* FORM */
section.review-form .form {
	width: 100%;
}

section.review-form .form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
}

section.review-form .form__field {
	width: 100%;
	height: 56px;
	border-radius: 8px;
	border: 1px solid #d7d7d7;
	padding: 0 18px;
	font-size: 16px;
	line-height: 20px;
	font-weight: 400;
	outline: none;
	background: #ffffff;
	color: #0b1020;
}

section.review-form .form__field::placeholder {
	color: #8a8ea0;
}

section.review-form .form__field:focus {
	border-color: #b9c4da;
}

section.review-form .form__field--phone {
	margin-top: 18px;
}

section.review-form .form__textarea {
	margin-top: 18px;
	width: 100%;
	min-height: 120px;
	border-radius: 8px;
	border: 1px solid #d7d7d7;
	padding: 16px 18px;
	font-size: 16px;
	line-height: 22px;
	font-weight: 400;
	outline: none;
	resize: vertical;
	background: #ffffff;
	color: #0b1020;
}

section.review-form .form__textarea::placeholder {
	color: #8a8ea0;
}

section.review-form .form__textarea:focus {
	border-color: #b9c4da;
}

section.review-form .form__actions {
	margin-top: 22px;
}

section.review-form .form__btn {
	border: 0;
	cursor: pointer;
	height: 56px;
	padding: 0 46px;
	border-radius: 999px;
	background: #00d84f;
	color: #ffffff;
	font-weight: 600;
	font-size: 16px;
	line-height: 20px;
	box-shadow: 0 14px 28px rgba(0, 216, 79, 0.2);
}

section.review-form .form__btn:active {
	transform: translateY(1px);
}

section.review-form .form__note {
	margin: 14px 0 0;
	font-size: 13px;
	line-height: 18px;
	font-weight: 400;
	color: #6e7386;
}

section.review-form .form__note a {
	color: #0a56c2;
	text-decoration: underline;
}

      /* Responsive */
@media (max-width: 980px) {
	section.review-form .review__card {
		padding: 34px 26px;
	}

	section.review-form .review__grid {
		grid-template-columns: 1fr;
		gap: 22px;
	}

	section.review-form .review__title {
		font-size: 36px;
		line-height: 42px;
		margin-bottom: 12px;
	}

	section.review-form .review__text {
		max-width: 100%;
	}
}

@media (max-width: 520px) {
	section.review-form .review {
		padding: 22px 14px;
	}

	section.review-form .review__card {
		padding: 22px 16px;
		border-radius: 16px;
	}

	section.review-form .review__title {
		font-size: 28px;
		line-height: 32px;
	}

	section.review-form .form__row {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	section.review-form .form__field {
		height: 52px;
		border-radius: 10px;
	}

	section.review-form .form__btn {
		width: 100%;
		padding: 0 22px;
	}
}


/* 404 */

section.notfound {
    
}

section.notfound .wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    min-height: 400px;
}

section.notfound .wrap .name {
    color: #194fb9;
    font-size: 200px;
    font-family: 'Rubik', Arial, sans-serif;
    line-height: 1;
    font-weight: 600;
}

section.notfound .wrap .desc {
    color: #2e384d;
    font-size: 24px;
    font-family: 'Rubik', Arial, sans-serif;
    line-height: 1.55;
    font-weight: 500;
    margin-bottom: 40px;
}

section.contact-page .wrap {
    display: flex;
    gap: 50px;
    align-items: center;
}

section.contact-page {}

section.contact-page .wrap .image {
    display: flex;
    border-radius: 20px;
    overflow: hidden;
    width: 50%;
    height: 450px;
}

section.contact-page .wrap .text {
    flex: 1;
    color: #041a46;
    font-size: 20px;
    font-family: 'Rubik', Arial, sans-serif;
    line-height: 1.55;
    font-weight: 500;
}

section.contact-page .wrap .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

section.contact-page .wrap .text .btn {
    margin-top: 30px;
}
/* ADAPTIVE */

@media screen and (max-width: 1024px) {
    .header .wrap .logo {
        max-width: 200px;
    }
    
    .header .wrap {
        gap: 20px;
    }
    
    section.hero {
        margin-top: 90px;
    }
    
    section.hero  .title {
        font-size: 48px;
    }
    
    section.hero .wrap .data .desc {
        font-size: 18px;
    }
    
    .h2 {
        font-size: 38px;
    }
    
    .how__headline {
        font-size: 22px;
    }
    
    section.sertificates .wrap {
        flex-wrap: wrap;
        justify-content: center;
    }
    
    section.sertificates .wrap .item {
        width: calc(100%/3 - 15px);
    }
}

@media screen and (max-width: 768px) {
    .header .wrap .menu {
        display: none;
    }
    
    .header .wrap .burger {
        display: flex;
        background-color: #194fb9;
        width: 44px;
        height: 44px;
        border-radius: 100%;
        flex-direction: column;
        gap: 4px;
        align-items: center;
        justify-content: center;
    }
    
    .header .wrap .burger span {
        display: block;
        width: 20px;
        height: 2px;
        background: #fff;
    }
    
    section.hero  .title {
        font-size: 36px;
    }
    
    section.hero .wrap {
        flex-direction: column;
    }
    
    section.hero .wrap .data {
        max-width: 100%;
    }
    
    section.hero .wrap .data .desc {
        font-size: 16px;
    }
    
    section.hero .wrap .image {
        display: none;
    }
    
    section.hero .wrap .data .form .flex {
        flex-direction: column;
    }
    
    section.hero .wrap .data .form .flex input {
        width: 100%;
    }
    
    section.hero .wrap .data .form .flex button {
        width: 100%;
        max-width: 100%;
    }
    
    section.hero .wrap .data .form .name {
        text-align: center;
    }
    
    .politico {
        text-align: center;
    }
    
    section.hero .advantages {
        flex-wrap: wrap;
    }
    
    section.hero .advantages .item {
        width: calc(100%/3 - 15px);
    }
    
    section.hero .advantages .item .name {
        font-size: 16px;
    }
    
    .h2 {
        font-size: 32px;
        margin-bottom: 20px;
    }
    
    section.dont-wait .wrap .data .desc {
        flex-direction: column;
        align-items: start;
        gap: 20px;
        margin-bottom: 20px;
    }
    
    section.dont-wait .wrap {
        border-radius: 40px;
    }
    
    section.dont-wait .wrap .data .name {
        font-size: 24px;
        line-height: normal;
    }
    
    section.dont-wait .wrap .data .desc .text {
        font-size: 16px;
    }
    
    section.why .wrap .item {
        width: 100%;
    }
    
    section.why .wrap .item .desc .name {
        font-size: 20px;
    }
    
    section.why .wrap .item .desc .text {
        font-size: 16px;
    }
    .reviewsWide__head {
        flex-direction: column;
    }
    .masterCard__name {
        font-size: 20px;
    }
    
    .reviewCardW__name {
        font-size: 22px;
    }
    
    .contactsForm__row {
        flex-direction: column;
        display: flex;
    }
    
    .contactsForm__field {
        width: 100%;
    }
    
    .contactsForm__field input {
        width: 100%;
    }
    
    .contactsForm__title {
        text-align: center;
    }
    
    .btn {
        max-width: 100%;
    }
    
    .contacts__grid {
        flex-direction: column-reverse;
        display: flex;
        gap: 30px;
    }
    
    .contactsMap {
        width: 100%;
    }
    
    .contactsInfo {
        width: 100%;
    }
    
    .contactsInfo .h2 {
        text-align: center;
    }
    
    .contactsInfo__subtitle {
        text-align: center;
    }
    
    .contactsInfo__cols {
        text-align: center;
    }
    
    .contactsInfo__work {
        text-align: center;
    }
    
    section.about-page .history {
        padding: 20px;
    }
    
    section.about-page .tech .item {
        width: 100%;
    }
    
    section.contact-page .wrap {
        flex-direction: column;
    }
    
    section.contact-page .wrap .image {
        width: 100%;
    }
    
    section.contact-page .wrap .text {
        text-align: center;
    }
    section.sovet .item .name {
        flex-direction: column;
        gap: 0;
        align-items: start;
    } 
    
    section.sovet .item {
        padding: 20px;
    }
    
    section.sovet .item .text {
        font-size: 16px;
    }
}

@media screen and (max-width: 600px) {
    .header .wrap .phone a {
        padding: 5px 10px;
        width: auto;
        white-space: nowrap;
        font-size: 12px;
    }
    
    .header .wrap .logo {
        max-width: 150px;
    }
    
    .header .wrap {
        gap: 5px;
    }
    
    section.hero {
        margin-top: 75px;
    }
    
    section.hero  .title {
        text-align: center;
        font-size: 30px;
    }
    
    section.hero .wrap .data .desc {
        font-size: 14px;
        text-align: center;
    }
    
    section.hero .wrap .data .form .name {
        font-size: 16px;
        max-width: 90%;
        margin: 0 auto 20px;
    }
    
    section.hero .wrap .data .form {
        padding: 20px;
    }
    
    section.hero .advantages .item {
        width: calc(100%/2 - 15px);
    }
    
    .h2 {
        font-size: 28px;
    }
    
    .service-container {
        margin: 0;
    }
    
    section.dont-wait .h2 {
        max-width: 100%;
    }
    
    section.dont-wait .icon {
        max-width: 50px;
        margin: 0 auto 15px;
    }
    
    section.dont-wait .wrap {
        flex-direction: column;
        gap: 15px;
        text-align: center;
    }
    
    section.dont-wait .wrap .data .name {
        font-size: 20px;
    }
    
    section.dont-wait .wrap .data .desc .text {
        line-height: normal;
    }
    
    section {
        padding: 30px 0;
    }
    
    section.why .wrap .item {
        flex-direction: column;
        align-items: start;
        gap: 15px;
    }
    
    section.why .wrap .item .desc .name {
        font-size: 18px;
    }
    
    section.why .wrap .item .desc .text {
        line-height: normal;
    }
    
    .how__num {
        font-size: 54px;
        font-weight: 700;
    }
    
    .how__headline {
        font-size: 20px;
    }
    
    section.sertificates .wrap .item {
        width: calc(100%/2 - 15px);
    }
    
    .guarantee__rightBottom .imgCard {
        height: 150px;
    }
    
    .reviewsWide__head h2 {
        text-align: center;
        width: 100%;
    }
    
    .faqItem__q {
        font-size: 16px;
        font-weight: 600;
    }
    
    .footer__copy, .footer__privacy {
        font-size: 14px;
    }
    
    section.about-page .tech .item {
        padding: 15px;
        gap: 20px;
        flex-direction: column;
        text-align: center;
    }
    
    section.about-page .tech .item .image {
        width: 80px;
    }
    
    section.contact .panel {
        min-height: auto;
    }
    
    section.contact .contact__note {
        text-align: center;
    }
    section.contact .panel__left {
        flex-direction: column;
        text-align: center;
        align-items: center;
        gap: 5px;
    }
    
    section.contact .panel .btn {
        margin: 0 auto;
    }
    
    section.contact-page .wrap .image {
        height: 200px;
    }
    
    section.contact-page .wrap .text {
        font-size: 16px;
    }
    
    section.contact-page .wrap {
        gap: 30px;
    }
    section.works .total {
        flex-direction: column;
        display: flex;
        gap: 5px;
    }
}