:root {
    --card-radius: 14px;
    --card-bg: #fff;
    --card-text: #222;
    --card-muted: #676767;
    --card-br: rgba(0, 0, 0, .06);
    --shadow-hover: 0 10px 24px rgba(0, 0, 0, .10);
    --btn-bg: #EC582C;
    --btn-bg-hover: #0D162B;
}


*, *:before, *:after {
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box;
}

*,*:before,*:after{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}div,span,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,code,img,b,u,i,center,table,tr,th,td,video{margin:0;padding:0;border:0}


input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {color: #0d162b;opacity: 0.5;}
input::-moz-placeholder,textarea::-moz-placeholder {color: #0d162b;opacity: 0.5;}
input:-moz-placeholder,textarea:-moz-placeholder {color: #0d162b;opacity: 0.5;}
input:-ms-input-placeholder,textarea:-ms-input-placeholder {color: #0d162b;opacity: 0.5;    font-family: 'Prompt', Arial, sans-serif;}

input {
outline: none;

}
input[type="text"], input[type="tel"], input[type="email"], textarea {    color: #0d162b;outline:none;
    border: 1px solid #e1e1e1;
    background-color: #ffffff;
    border-radius: 6px;    height: 56px;    padding: 0 20px;    box-sizing: border-box;font-family: 'Prompt', Arial, sans-serif;}
body {    margin: 0;color: #1e1e1e;font-size: 16px;    font-family: 'Prompt', Arial, sans-serif;}
a {text-decoration:none;color: #1e1e1e;}
.container{
  width: 100%;
  max-width: 1200px;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0 20px;
}



h2 {font-size: 32px;font-weight: 800;color: #000000;margin-bottom:35px;}






.nav {
  margin: 0 auto;
  padding: 18px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  color: #0d162b;
  font-size: 16px;
  font-family: 'Prompt', Arial, sans-serif;
}

/* ссылки */
.nav__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #2d3748;           /* темно-серый как на скрине */
  text-decoration: none;
  font-weight: 500;
  line-height: 1;
  padding: 6px 0;
}

.nav__link:hover { color: #ff6a3d; } /* оранжевый при ховере */
.nav__link--active {/* color: #ff6a3d; */}

/* dropdown контейнер */
.nav__item {
  position: relative;
}

/* стрелка */
.caret {
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  transform: translateY(1px);
  opacity: 0.9;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

/* дропдаун */
.dropdown {
  position: absolute;
  top: calc(100% + 14px);
  left: -12px;                /* чуть “уходит” влево как на скрине */
  /* min-width: 320px; */
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 12px 28px rgba(16, 24, 40, 0.16);
  padding: 14px 0;
  display: none;
  z-index: 50;
}

/* чтобы не закрывалось при перемещении курсора */
.nav__item--dropdown:hover .dropdown,
.nav__item--dropdown:focus-within .dropdown {
  display: block;
}

/* пункты внутри */
.dropdown__link {
  display: block;
  padding: 10px 18px;
  color: #1f2937;
  text-decoration: none;
  /* font-weight: 600; */
  white-space: nowrap;
}

.dropdown__link:hover {
  background: #f7fafc;
  color: #0f172a;
}

/* маленький “зазор”, чтобы ховер не обрывался */
.nav__item--dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 18px;
}

nav.nav a:hover {
    color: #fb663a;
}


.nav__item--dropdown:hover .caret,
.nav__item--dropdown:focus-within .caret{
  transform: rotate(-180deg) translateY(-1px); /* выглядит как ˄ */
}





  .proudly{
    padding: 105px 0;
    font-family: 'Prompt', Arial, sans-serif;
  }

  .proudly .container{
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
  }

  h2{
    text-align: center;
    margin-bottom: 20px;
    font-weight: 700;
    color: #0d162b;
    font-size: 44px;
    font-family: 'Prompt', Arial, sans-serif;
  }

  .proudly p{
    text-align: center;
    margin: 0 0 30px;
    color: #464646;
    font-size: 20px;
  }

  /* 2 колонки */
  .proudly_container{
    display: flex;
    gap: 24px;
    align-items: center; /* ключ: колонки одной высоты */
  }

  /* Левая колонка */
  .proudly_left{
    border: 1px solid #ddd;
    border-radius: 14px;
    overflow: hidden;
    display: flex;              /* чтобы img мог занять 100% высоты */
    align-items: center;
    justify-content: center;
    background: #fff;
    max-width: 800px;
    max-height: 650px;
  }

  .proudly_left img{
    width: 100%;
    height: 100%;
    object-fit: cover;        /* карта не режется */
    display: block;
  }

  /* Правая колонка */
  .proudly_right{
    width: 330px;               /* как на скрине */
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .proudly_right a{
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    border: 1px solid #ddd;
    border-radius: 14px;
    text-decoration: none;
    color: #000;
    background: #fff;
    transition: .2s ease;
  }

  .proudly_right a:hover{
  background: #f1f5f9
  }

  .proudly_right a span{
    font-weight: 400;
    color: #0d162b;
    font-size: 20px;
  }

  .proudly_right a img:first-child{
    width: 42px;
    height: 42px;
  }

  .proudly_right a img:last-child{
    width: 26px;
    height: 26px;
    margin-left: auto;
  }
  
.steps {
    padding-top: 105px;
    padding-bottom: 105px;
    background-color: rgb(241, 245, 249);
}

.steps > div > p,.beats > .container > p {
    color: #464646;
    font-size: 20px;
    text-align: center;
}

.steps_cart {
    background: #fff;
    border-radius: 16px;
    padding: 25px 20px;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.steps_cart img {
    max-width: 140px;
    width: 100%;
    /* position: absolute; */
    margin-top: -70px;
}

.steps_cart span {
    color: #0d162b;
    font-size: 18px;
    font-weight: 600;
    display: block;
    margin-top: 15px;
}

.steps_cart p {
    color: #ed3c07;
    font-size: 22px;
    font-weight: 600;
    margin: 15px 0;
}

.steps_cart div {
    color: #464646;
    font-size: 16px;
    line-height: 25px;
}

.steps_container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    position: relative;
    margin-top: 70px;
    text-align: center;
}

.steps_container:after {
    content: '';
    background: #ec582c;
    height: 6px;
    width: 100%;
    position: absolute;
    top: 50%;
}



.intro_service {padding: 105px 0;}
.people {padding: 105px 0;}
/**/
.faq {padding: 105px 0;}
.faq__item{
  background: #f1f5f9;
  border-radius: 999px;
  padding: 18px 30px;
  margin: 18px 0;
   /* чтобы при анимации ничего не выпирало */
}

.faq__btn{
  width: 100%;
  border: 0;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 6px 10px;
  text-align: left;
}

.faq__q{
  font-weight: 600;
  font-size: 24px;
  line-height: 1.35;
  color: #0d162b;
}

/* --- icon button look --- */
.faq__icon{
  min-width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  display: grid;
  place-items: center;
}

.faq__icon svg{
  transform-origin: 50% 50%;
  transition: transform .22s ease;
}

/* OPEN STATE -> rotate(-45deg) => крестик */
.faq__item.is-open .faq__icon svg{
  transform: rotate(-45deg);
}

/* --- panel animation --- */
.faq__panel{
  /* overflow: hidden; */
  /* transition: height .28s ease; */
  display: none;
}

.faq__answer{
  padding: 10px 10px 6px 10px;
  margin-top: 6px;
  color: #0d162b;
  font-size: 16px;
  line-height: 1.55;
}

/* Когда открыт, делаем форму как на скрине (верх уже, низ чуть прямее) */
.faq__item.is-open{
  border-radius: 44px;
  padding-bottom: 16px;
}


.faq > div > p {
    color: #464646;
    font-size: 20px;
    padding-bottom: 20px;
    text-align: center;
}

.faq_container {
    /* margin-top: 15px; */
}

.faq__item.is-open .faq__panel {
    display: block;
}

.up_btn svg rect, .up_btn svg path {
    transition: 0.2s ease-in;
}

.up_btn:hover svg rect {
        fill: #0d162b;
        fill-opacity: 1;
    }

.up_btn:hover svg path {
        stroke: #ffffff;
        stroke-width: 1;
}
.up_btn {
    right: 30px;
    left: unset;
    bottom: 30px;
    position: fixed;
    cursor:pointer;
    z-index:2;
}


.top_info {
    background-color: #f1f5f9;
    color: #464646;
    font-size: 16px;
    /* opacity: 0.8; */
    padding: 9px 0;
}

.top_info_container {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.top_info_container span {
    color: #0d162b;
    font-size: 16px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 5px;
}

.top_info_container p {
    opacity: 0.8;
}

a.top_logo img {
    max-width: 206px;
    width: 100%;
}

.top_right_info a.btn1 {
    color: #ffffff;
    /* font-weight: 600; */
    background-color: #fb663a;
    /* border-radius: 6px; */
}

.top_right_info a.btn1, .top_right_info a.btn2 {
    width: 172px;
    height: 48px;
    font-size: 16px;
    font-weight: 600;
    border-radius: 6px;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
    box-sizing: border-box;
}

.top_right_info {
    display: flex;
    align-items: center;
    gap: 15px;
}

.top_right_info a {
    display: flex;
    align-items: center;
    justify-content: center;
}

.top_right_info a.btn1:hover {
    background: #0d162b;
}

.top_right_info a.btn2 {
    color: #fb663a;
    border: 2px solid #fb663a;
    /* box-sizing: border-box; */
}

.top_right_info a.btn2:hover {
    border-color: #0d162b;
    background-color: #0d162b;
    color: #fff;
}

.top_m_container {
    display: flex;
    align-items: center;
    margin:15px 0;
}

.header_menu {
    display: flex;
    align-items: center;
}

header {
    position: sticky;
    top: 0;
    z-index: 3;
    background: #fff;
}
.banner_index_container {
    /* background: url("/assets/images/tild3666-6262-4438-b634-363532306164__miami-bayside-landsc.jpg") no-repeat; */
    /* background-position: center center; */
    /* background-attachment: scroll; */
    /* background-size: cover; */
    /* background-color: rgba(0, 0, 0, 0.3); */
    /* position: relative; */
    display: flex;
    align-items: self-end;
    padding: 65px 0 0;
}
.banner_index_container::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.3); /* <- темнее/светлее тут */
  pointer-events: none;
}

/* чтобы контент баннера был поверх оверлея */
.banner_index_container > *{
  position: relative;
  z-index: 1;
}

.bg_white {
    background-color: #f1f5f9;
    border-radius: 12px;
    padding: 35px 35px 50px 35px;
}

.banner_index_left h1 {
    color: #0d162b;
    font-size: 46px;
    font-weight: 800;
    line-height: 55px;
}

.banner_index {
    background: url(/assets/images/tild3666-6262-4438-b634-363532306164__miami-bayside-landsc.jpg) no-repeat;
    background-position: center center;
    background-attachment: scroll;
    background-size: cover;
    /* background-color: rgba(0, 0, 0, 0.3); */
    position: relative;
}

.banner_index_right img {
    max-width: 460px;
    width: 100%;
    display: block;
}

.banner_index_left {
    max-width: 723px;
    width: 100%;
    padding-bottom: 60px;
}

.bg_dark_blue ul li img {
    max-width: 28px;
    width: 100%;
}

.bg_dark_blue {
    background-color: #0d162b;
    border-radius: 12px;
    color: #fff;
    font-size: 16px;
    padding: 25px 35px;
    margin-top: -20px;
}

.bg_dark_blue ul li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.bg_dark_blue ul li:not(:last-child) {
    margin-bottom: 15px;
}

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

.bg_white p {
    color: #464646;
    font-size: 18px;
    font-weight: 300;
    margin: 20px 0;
}

.btn_banner a {
    font-weight: 600;
    font-size: 16px;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
    border-radius: 6px;
    width: 253px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.btn_banner a:first-child {
    background-color: #ec582c;
    color: #fff;
}

.btn_banner {
    display: flex;
    gap: 15px;
}

.btn_banner a:last-child {
    border: 2px solid #0d162b;
}

.btn_banner a:first-child:hover {
    background: #0d162b;
}

.btn_banner a:last-child:hover {
    background: #0d162b;
    color: #fff;
}

.banner_index_right {
    margin-left: -35px;
}


.our_expert {
    padding: 105px 0;
}

.our_expert > .container > p, .right_img_block > .container > p, .slider_service > .container > p, .choosing > .container > p, .brands_water > .container > p {
    color: #464646;
    font-size: 20px;
    font-weight: 400;
    text-align: center;
}
.our > .container > p, .causes > .container > p, .why > .container > p, .how_to > .container > p,.behind.v2 > .container > p {
    color: #fff;
    font-size: 20px;
    font-weight: 400;
    text-align: center;
    }
    
.behind_descr p {    color: #fff;
    font-size: 20px;
    font-weight: 400;}
.header_cart {
    color: #ffffff;
    font-size: 22px;
    font-weight: 500;
    border-radius: 10px 10px 0px 0px;
    background-color: #0d162b;
    padding: 15px;
}

.bottom_cart {
    border-radius: 10px;
    background-color: #f1f5f9;
    padding: 20px;
    /* height: 100%; */
}

.bottom_cart a {
    background-color: #ffffff;
    display: flex;
    padding: 15px;
    margin-bottom: 15px;
    border-radius: 10px;
    --t396-speedhover: 0.5s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
    box-sizing: border-box;
    border: 1px solid #fff;
}

.descr_podcart > span {
    color: #0d162b;
    font-size: 20px;
    font-weight: 600;
    display: block;
    line-height: normal;
}

.descr_podcart > p {
    color: #464646;
    font-size: 16px;
    font-weight: 400;
    margin: 7px 0;
    padding-right: 80px;
}

.learn_more {
    color: #ec582c;
    font-size: 15px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 10px;
}

.learn_more span {
    order: -1;
}

.learn_more img {
    width: 22px;
}

.our_expert_container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin-top: 30px;
}

.podcart_cart > img {
    max-width: 90px;
    width: 100%;
}

.podcart_cart {
    display: flex;
    gap: 15px;
}



.bottom_cart a:hover {
    border: 1px solid #ec582c;
}


.why {
    padding: 105px 0;
    background-color: rgb(236, 88, 44);
}

.why h2 {
    color: #fff;
}

.why > .container > p, .causes > .container > p
    color: #ffffff;
    font-size: 20px;
    text-align: center;
}

.why_cart img {
    max-width: 140px;
    width: 100%;
}

.why_cart span {
    margin-top: 12px;
    margin-bottom: 15px;
    font-size: 26px;
    font-weight: 600;
    color: #fff;
}

.why_cart p {
    font-size: 16px;
    line-height: 1.55;
    color: #fff;
    font-weight: 300;
}

.why_cart {
    display: flex;
    align-items: center;
    flex-direction: column;
}

.why_container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
    text-align: center;
    margin-top: 30px;
}


.reviews {
    padding: 105px 0;
}

.reviews h2 {
    text-align: left;
}

.arr_reviews_container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom:40px;
}

.arr_rev svg {
    width: 100%;
}

.arr_rev_prev, .arr_rev_next {
    background-color: rgba(251, 102, 58, 1);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
    cursor: pointer;
}

.arr_rev {
    display: flex;
    align-items: center;
    gap: 5px;
}

.arr_rev_next {
    transform: rotate(0.5turn);
}

.arr_rev div:hover {
    background: rgba(13,22,43,1);
}

.arr_reviews_container p {
    font-size: 20px;
    line-height: 1.55;
    color: #464646;
    font-weight: 300;
}

.reviews_cart_header img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    border-radius: 50%;
}

.reviews_cart_header {
    width: 100px;
    height: 100px;
}

.reviews_cart {
    background: #f1f5f9;
    padding: 30px;
    box-sizing: border-box;
}

.reviews_cart_descr span {
    font-size: 26px;
    color: #0d162b;
    font-weight: 600;
}

.star_reviews {
    font-size: 22px;
    color: #fb663a;
    font-weight: 400;
}

.reviews_cart > p {
    font-size: 18px;
    color: #464646;
    margin-top: 20px;
}

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

/* ваш блок станет swiper-контейнером */
.full_page_reviews{
  width: 100%;           /* ВАЖНО: не 100vw */
  overflow: hidden;      /* чтобы не торчали “лишние” части */
  box-sizing: border-box;
}

/* ваш текущий контейнер со слайдами станет wrapper */
.full_page_reviews > .reviews_cart{
  /* на всякий случай: если раньше задавали width */
  width: auto;
}

/* это “обёртка” для слайдов — у вас она называется .full_page_reviews */
.full_page_reviews.swiper{
  /* ничего не ломаем, просто уточняем */
}

/* Слайды (карточки) */
.full_page_reviews .reviews_cart{
  height: auto;
}

/* Важное: Swiper сам задаёт flex, но на некоторых сборках нужно помочь */
.full_page_reviews .swiper-wrapper{
  display: flex;
}

/* чтобы у слайдов нормально считалась ширина */
.full_page_reviews .swiper-slide{
  box-sizing: border-box;
}


.more_plumbers {
    background-color: rgb(13, 22, 43);
    padding: 105px 0;
}

.more_plumbers, .more_plumbers h2 {
    color: #ffffff;
}

.more_plumbers p, .more_plumbers ul li {
    color: #ffffff;
    font-size: 20px;
}

.more_plumbers ul {
    /* list-style: none; */
    padding: 0;
    margin: 0;
    /* border-radius: 0px 0px 10px 10px; */
    /* background-color: #ec582c; */
}

.more_plumbers .plumbers_left ul li {
    display: flex;
    align-items: flex-start;
    gap: 15px;
}

.more_plumbers ul li img {
    max-width: 38px;
    width: 100%;
}

.more_plumbers ul li:not(:last-child) {
    margin-bottom: 10px;
}
.plumbers_right .plumbers_right  ul:not(:last-child) {
    margin-bottom: 25px;
}
.more_plumbers p {
    text-align: center;
    margin-bottom: 25px;
}

.more_plumbers_container {
    display: flex;
    align-items: center;
    gap: 35px;
}

.plumbers_right img {
    min-width: 560px;
    width: 100%;
    border-radius: 10px 10px 0px 0px;
    display: block;
}

.plumbers_right ul {
    border-radius: 0px 0px 10px 10px;
    background-color: #ec582c;
    list-style: disc;
    /* padding-left: 0; */
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /* align-items: flex-start; */
    justify-content: center;
    padding: 20px;
}

.plumbers_right ul li {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 10px;
}

.plumbers_right ul li:before {
    content: '';
    background: #fff;
    min-width: 8px;
    height: 8px;
    border-radius: 50%;
}



.limited_time_left span {
    color: #0d162b;
    font-size: 42px;
    font-weight: 800;
    line-height: 50px;
}

.limited_time {
    background-color: #fbaa3a;
    padding: 60px 0;
    position: relative;
    overflow: hidden;
}

.limited_time_left p {
    color: #464646;
    font-size: 18px;
    font-weight: 300;
    margin-top: 10px;
}

.limited_time_center a {
    font-size: 17px;
    font-weight: 600;
    color: #fff;
    background: #0d162b;
    border-radius: 6px;
    width: 297px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

.limited_time_center a:hover {
    background: #f1f5f9;
    color: #0d162b;
}

.limited_time_center p {
    color: #464646;
    font-size: 14px;
    font-weight: 300;
    margin-top: 15px;
}

.limited_time_container {
    display: flex;
    align-items: center;
    gap: 40px;
}

.limited_time > img {
    transform: rotate(225deg);
    max-width: 360px;
    width: 100%;
    position: absolute;
    right: 0;
    top: -70px;
}



.ready {
    background-color: rgb(236, 88, 44);
    padding: 105px 0;
}

.ready h2 {
    color: #fff;
}

.ready > .container > p {
    color: #ffffff;
    font-size: 20px;
    font-weight: 400;
    text-align: center;
}

.ready_left img {
    max-width: 566px;
    width: 100%;
    border-radius: 20px;
    display: block;
}

.ready_container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin-top: 30px;
}

.ready_container form {
    background-color: #ffffff;
    border-radius: 20px;
    padding: 30px;
}

.form_input > div, .form_textarea {
    display: flex;
    flex-direction: column;
    /* resize: none; */
}

.form_input {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
}

.form_textarea {
    margin-top: 20px;
}

.ready_container input[type="text"], .ready_container input[type="tel"], .ready_container  textarea {
    margin-top: 10px;
    font-size: 16px;
    resize: none;
    box-sizing: border-box;
}

.ready_container input[type="submit"] {
    cursor: pointer;
    background-color: #0d162b;
    transition: 0.3s ease all;
    font-size: 15px;
    border-radius: 6px;
    width: 200px;
    font-weight: 600;
    height: 56px;
    color: #fff;
    display: flex;
    padding: 0;
    margin: 0;
    outline: none;
    border: none;
    margin-top: 20px;
}

.ready_container input[type="submit"]:hover {
    background-color: #ec582c;
}

.ready_container form > p {
    font-size: 13px;
    color: rgb(70, 70, 70);
    margin-top: 20px;
}

.ready_container form > p > a {
    color: rgb(236, 88, 44);
    border-bottom: 1px solid rgb(236, 88, 44);
}

.call_use img {
    max-width: 70px;
    width: 100%;
}

.call_use {
    background-color: #0d162b;
    border-radius: 20px;
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 23px 30px;
    margin-top: -70px;
    z-index: 1;
    position: relative;
}

.call_use_descr p {
    color: #ec582c;
    font-size: 28px;
    font-weight: 600;
}

.call_use_descr span {
    color: #ffffff;
    font-size: 20px;
    font-weight: 400;
}

.ready_container textarea {
    height: 85px;
    padding-top:15px;
}


.footer_left a img {
    max-width: 206px;
    width: 100%;
}

footer {
    background-color: #0d162b;
    color: #fff;
    padding: 40px 0;
}

.footer_container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
}

footer a {
    color: #fff;
    display: block;
}

.footer_left a {
    display: block;
    margin-bottom: 10px;
}

.footer_container > div > span {
    color: #ffffff;
    font-size: 18px;
    font-family: 'Prompt', Arial, sans-serif;
    line-height: 1.55;
    font-weight: 600;
    opacity: 0.8;
    margin-bottom: 20px;
    display: block;
}

.footer_container > div > ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer_container > div > ul li a, .footer_quick_links ul li span {
    color: #ffffff;
    font-size: 16px;
    opacity: 0.8;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

.footer_container > div > ul li:not(:last-child) {
    margin-bottom: 10px;
}

.footer_quick_links {}

.footer_quick_links ul li span {}

.footer_quick_links ul li span {
    display: block;
    margin-bottom: 10px;
}

.footer_quick_links ul li ul {
    list-style: none;
    padding: 0;
    margin-left: 20px;
}

.footer_contacts div {
    white-space: nowrap;
}

.footer_contacts {
    font-size: 18px;
    font-weight: 600;
    opacity: 0.8;
}

.footer_contacts a {
    margin-bottom: 10px;
}

.footer_contacts > div:not(:last-child) {
    margin-bottom: 10px;
}

.footer_container .footer_left ul {
    margin-top: 15px;
}

.footer_container .footer_left ul li {
    color: #ec582c;
    font-size: 14px;
    font-weight: 600;
    /* opacity: 0.8; */
}

.footer_container .footer_left ul li:not(:last-child) {
    margin-bottom: 5px;
}

.footer_left, .footer_our_sevice, .footer_quick_links {
    border-right: 1px solid #464646;
    padding-right: 40px;
}

.footer_container > div > ul li a:hover, .footer_quick_links ul li span:hover {
    color: #fb663a;
}


.footer_info {
    padding: 25px 0;
    background: #f1f5f9;
}

.footer_info p, .footer_info p a {
    color: #0d162b;
    font-size: 16px;
    font-weight: 600;
    opacity: 0.8;
}

.footer_info p a {
    opacity: 1;
}

.footer_info p {
    opacity: 0.8;
}

.footer_info > .container > div {
    color: #0d162b;
    font-size: 16px;
    font-weight: 400;
    opacity: 0.8;
    margin-top: 10px;
}


.top_right_info a.mob_nav {display:none;cursor:pointer;}
a.mob_nav img {
    width: 48px;
}
.navigation_menu {display:none;}

























/* Desktop default: menu hidden */
.navigation_menu { display: none; }

/* Overlay hidden by default */
.navigation_overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
  z-index: 9998;
}



a.mob_nav {
    height: 48px;
}
.footer_left > p {
    opacity: .8;
}

/* ===== Modal (fancybox content) ===== */
#popup_call.bModal{
  max-width: 560px;
  padding: 40px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 16px 40px rgba(0,0,0,.25);
  position: relative;
  width: 100%;
}
/*
#popup_call .request-form-rev .btn-wrap{
  position: relative;
}


#popup_call .request-form-rev .btn-wrap::before{
  content:"";
  position:absolute;
  top: 50%;
  left: calc(50% - 60px);
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  pointer-events: none;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24'%3E%3Cpath d='M5 12h12' stroke='%23fff' stroke-width='2.2' stroke-linecap='round'/%3E%3Cpath d='M13 6l6 6-6 6' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center/22px 22px;
  z-index: 1;
}*/

#popup_call .bModal__caption{
  text-align: center;
  font-weight: 600;
  text-transform: uppercase;
  margin: 0 0 15px;
  font-size: 30px;
  color: #0d162b;
}

/* close button (fancybox) */
#popup_call .f-button.is-close-btn{
  position: absolute;
  top: 16px;
  right: 16px;
  width: 43px;
  height: 43px;
  border-radius: 10px;
  background: transparent;
  border: none;
  color: #082c37;
  cursor: pointer;
  display: grid;
  place-items: center;
  box-sizing: border-box;
  opacity: 1;
  transition: opacity .3s ease-in-out;
}
#popup_call .f-button.is-close-btn:hover{
  opacity:.8;
}
#popup_call .f-button.is-close-btn svg{
  width: 24px;
  height: 24px;
}
#popup_call .f-button.is-close-btn path{
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
}

/* ===== Form ===== */
#popup_call .request-form-rev{
  display: flex;
  gap: 18px;
  flex-direction:column;
  margin-top: 4px;
}

#popup_call .request-form-rev input[type="text"],
#popup_call .request-form-rev input[type="tel"]{
  height: 60px;
  padding: 0 20px;
  border: 1px solid #e6e8ee;
  outline: none;
  font-size: 16px;
  color: #0d162b;
  background: #fff;
  transition: border-color .2s ease, box-shadow .2s ease;
  border-radius: 6px;
}

#popup_call .request-form-rev input::placeholder{
    color: #0d162b;
    opacity: 0.5;
}


/* ===== Submit button with moving diagonal sheen ===== */
#popup_call .request-form-rev input[type="submit"]{
  height: 54px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
width:100%;
  background: #ec582c;
  color: #fff;
  font-weight: 400;
  text-transform: uppercase;
  font-size: 16px;
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: transform .15s ease, filter .2s ease;
}


#popup_call .request-form-rev input[type="submit"]{
   /* place for arrow */
   transition-duration: 0.2s;
   transition-property: background-color, color, border-color, box-shadow, opacity, transform, gap;
   transition-timing-function: ease-in-out;
   padding: 0 20px;
   position: relative;
}


#popup_call .request-form-rev input[type="submit"]:hover{
background:#0d162b;
}


.banner_service {
    background: #0d162b;
    padding: 80px 0;
}

.banner_service_container {
    background: #fff;
    /* padding-top: 60px; */
    border-radius: 12px;
    padding: 5px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    justify-content: space-between;
    grid-auto-flow: column;
}

.banner_service_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.banner_service_img {
    /* max-width: 540px; */
    height: 100%;
    width: 100%;
}

.banner_service_img img {
    display: block;
    border-radius: 0px 10px 10px 0px;
    max-width: 540px;
    margin-left: auto;
}

.banner_service_left {
    padding-top: 25px;
    padding-left: 25px;
    padding-bottom: 25px;
}

.banner_service h1 {
    color: #0d162b;
    font-size: 45px;
    font-weight: 800;
    line-height: 55px;
    margin-bottom: 15px;
}

.banner_service_left ul {
    padding: 0 0 0 20px;
    margin: 0;
}

.banner_service_left ul li {
    color: #464646;
    font-size: 18px;
    font-weight: 300;
}

.banner_service_left ul li:not(:last-child) {
    margin-bottom: 5px;
}

.banner_service .btn_banner {
    flex-direction: column;
    gap: 10px;
    margin-top: 25px;
}

.btn_banner a {
    max-width: 430px;
    width: 100%;
}

.intro_service {
    background-color: rgb(241, 245, 249);
}

.intro_service h2 {
    text-align: left;
}

.intro_service p {
    color: #464646;
    font-size: 18px;
    font-weight: 400;
}

.process {
  padding: 105px 0;
  background-color: #0d162b;
}

.process h2 {
  color: #fff;font-size:42px;
}

/* если у тебя реально есть абзац прямо под container (как было .why > .container > p) */
.process > .container > p {
  color: #ffffff;
  font-size: 20px;
  text-align: center;
}

.process__card img {
  max-width: 110px;
  width: 100%;
}

.process__card span {
  margin-top: 12px;
  margin-bottom: 15px;
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  display: block;
}

.process__card p {
  font-size: 14px;
  line-height: 1.55;
  color: #fff;
  font-weight: 300;
}

.process__card {
  display: flex;
  align-items: center;
  flex-direction: column;
}

.process__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 30px;
  text-align: center;
  margin-top: 30px;
}


.text_service {padding:105px 0;}

.uc-d-none {
    display: none;
}

img.uc-st-img {
    float: right;
    border-radius: 10px;
    width: 450px;
    margin: 50px 0 50px 50px;
}
img.uc-st-img.w-auto {
    width: auto;
    max-width: 100%;
}

img.uc-st-img.mt-0 {
    margin-top: 0;
}

@media screen and (max-width: 960px) {
    img.uc-st-img {
        float: right;
        width: 100%;
        margin: 0 0 25px 0;
    }
}

.uc-text-b {
    color: #464646;
    font-size: 16px;
    font-family: 'Prompt', Arial, sans-serif;
    line-height: 1.6;
    font-weight: 400; 
    counter-reset: myCounter; /* Инициализация счетчика */
}

.uc-text-b p + * {
    margin-top: 20px;
}

.uc-text-b h2 {
    font-size: 42px;
    font-family: 'Prompt', Arial, sans-serif;
    font-weight: 700;
    line-height: 1.4;
    margin: 40px 0 20px;
    color: #0D162B;
    text-align:left;
}

.uc-text-b h3 {
    font-size: 28px;
    font-family: 'Prompt', Arial, sans-serif;
    font-weight: 600;
    margin: 30px 0 10px;
    color: #0D162B;
}

.uc-text-b ol {
    counter-reset: myCounter; /* Сброс счетчика при начале нового блока */
    padding-left: 0 !important;
    margin-left: 0;
}

.uc-text-b ul {
    padding-left: 0 !important;
    margin-left: 0;
}

.uc-text-b ol li,
.uc-text-b ul li {
    list-style: none;
    padding-left: 35px; /* Или бОльшее значение, если маркеры шире */
    position: relative;
    margin-bottom: 20px; /* Указать отступы между элементами списка, если надо */
}

.uc-text-b ol li:before {
    counter-increment: myCounter;
    content: counter(myCounter);
    font-family: 'Prompt', Arial, sans-serif;
    color: white;
    display: inline-block;
    text-align: center;
    width: 24px;
    height: 24px;
    border-radius: 12px;
    background-color: #EC582C;
    line-height: 24px;
    position:absolute;
    top:0;
    left: 0; /* Смещаем маркеры влево от текста */
}

.uc-text-b ul li:before {
    content: "";
    position: absolute;
    top: 0px; 
    width: 26px; 
    height: 26px; 
    background-image: url('/assets/images/free-icon-check-3472.svg'); 
    background-size: cover;
    left: 0; /* Смещаем маркеры влево от текста */
}

@media (max-width: 960px) {
    .uc-text-b .t-col {
        max-width: 375px;
        margin: 0 auto;
    }

    .uc-text-b h2 {
    font-size: 26px;
    }
    .uc-text-b h3 {
    font-size: 22px;
    }
}

.elevate__left span {
  color: #0d162b;
  font-size: 42px;
  font-weight: 800;
  line-height: 50px;
  display: block;
}

.elevate {
  background-color: #fbaa3a;
  padding: 0;
  position: relative;
  overflow: hidden;
}

.elevate__left p {
  color: #464646;
  font-size: 18px;
  font-weight: 300;
  margin-top: 10px;
}

.elevate__center a {
  font-size: 17px;
  font-weight: 600;
  color: #fff;
  background: #ec582c;
  border-radius: 6px;
  min-width: auto;
  padding:0 20px;
      box-sizing: border-box;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  --t396-speedhover: 0.2s;
  transition: background-color var(--t396-speedhover, 0s) ease-in-out,
              color var(--t396-speedhover, 0s) ease-in-out,
              border-color var(--t396-speedhover, 0s) ease-in-out,
              box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

.elevate__center a:hover {
  background: #0d162b;
  color: #fff;
}

.elevate__center p {
  color: #464646;
  font-size: 14px;
  font-weight: 300;
  margin-top: 15px;
}

.elevate__container {
  display: flex;
  align-items: flex-start;
  gap: 40px;
  flex-direction: column;
  max-width: 700px;
}

.elevate > .container {
  display: flex;
  align-items: center;
  gap: 30px;
}

.elevate__img img {
    transform: rotate(225deg);
    width: 110%;
    height: 110%;
    object-fit: contain;
    object-position: center;
    display: block;
}

.elevate__img {
    max-width: 330px;
    height: 390px;
    margin-left: 90px;
}

.service_area_page .faq {
    background: rgb(241, 245, 249);
}



.service_area_page .faq__item {background:#fff;}

.bModal {
    display: none;
}




.btn_banner a br {display:none;}



.blog h1, .text h1 {
    color: #0d162b;
    font-size: 44px;
    line-height: 57px;
    text-align: center;
    margin-bottom: 30px;
}

.blog_container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}

.img_blog {
    max-height: 220px;
    height: 100%;
}

.img_blog img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: 14px 14px 0 0;
}
.blog_container a {
background-color: #f1f5f9;
border-radius: 14px;
}

.blog_prev {
    padding: 27px 30px;    
}

.date_blog {
    color: #ec582c;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 2.5px;
}

.article_name {
    font-size: 20px;
    line-height: 1.35;
    color: #0d162b;
    font-weight: 600;
    margin: 15px 0;
}

.intro_article {
    color: #464646;
    font-size: 14px;
    line-height: 1.55;
    font-weight: 300;
}

.blog, .text {
    margin-top: 40px;
    padding-bottom: 105px;
}

.need {
    background-color: rgb(236, 88, 44);
    padding: 75px 0;
    color: #fff;
}

.need h2 {
    color: #ffffff;
    line-height: 57px;
}

.need p {
    font-size: 20px;
    line-height: 31px;
    text-align: center;
    max-width: 760px;
    margin: 0 auto;
}

.btn_need a {
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
    padding: 0 20px;
    height: 55px;
    font-weight: 600;
    border-radius: 6px;
    min-width: 320px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}
.btn_need a:first-child:hover {        color: #0d162b;background:#f1f5f9}
.btn_need a:first-child {
    background-color: #0d162b;
    color: #fff;
}

.btn_need {
    display: flex;
    gap: 20px;
    justify-content: center;
    margin-top: 25px;
}

.btn_need a:last-child {
    color: #0d162b;
    border: 2px solid #0d162b;
}
.btn_need a:last-child:hover {background:#f1f5f9;border-color:#f1f5f9;}

.need_btn_text {
    text-align: center;
    margin-top: 10px;
    font-size: 15px;
    opacity: .6;
}

.blog_btn_footer {
  background:
    /* левый цвет 60% */
    linear-gradient(90deg, #fbaa3a 0 60%, transparent 60% 100%),
    /* затемнение только справа 40% */
    linear-gradient(90deg, transparent 0 60%, rgba(0,0,0,.3) 60% 100%),
    /* картинка справа 40% */
    url("/assets/images/tild3763-3933-4163-a661-633036323938__miami-bayside-landsc.jpg");
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-size: 100% 100%, 100% 100%, 40% 100%;
  background-position: left top, left top, right top;
  padding: 10px 0 0;
}


.img_btn_footer img {
    /* max-width: 386px; */
    width: 100%;
    /* display: block; */
    height: 100%;
    object-fit: cover;
    object-position: top;
}

.descr_btn_footer_container {
    display: flex;
    align-items: center;
    /* justify-content: space-between; */
    gap: 30px;
}

.descr_btn_footer .need_z {
    line-height: 50px;
    color: #0d162b;
    font-size: 42px;
    font-weight: 800;
    margin-bottom: 15px;
}

.descr_btn_footer p {
    line-height: 31px;
    color: #464646;
    font-size: 18px;
    font-weight: 300;
}

.descr_btn_footer a {
    font-size: 17px;
    font-weight: 600;
    color: #fff;
    background: #ec582c;
    border-radius: 6px;
    min-width: auto;
    padding: 0 20px;
    box-sizing: border-box;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

.descr_btn_footer a:hover {
    background: #0d162b;
    color: #fff;
}

.need_btn {
    max-width: 280px;
    width: 100%;
    margin-top: 20px;
}

.need_z {}

.descr_btn_footer {
    max-width: 600px;
    width: 100%;
}

.img_btn_footer {
    /* max-height: 400px; */
    height: 100%;
    width: 340px;
    height: 400px;
}

.blog_btn_footer{}

.blog_inner {
    margin-top: 40px;
}

.blog_inner_container {
    padding-bottom: 105px;
}

.blog_inner_nav {
    display: flex;
    gap: 30px;
    align-items: flex-start;
    margin-bottom: 20px;
}

.blog_nav {
    min-width: 360px;
    background-color: #f1f5f9;
    border-radius: 10px;
    padding: 25px;
    box-sizing: border-box;
}

.blog_nav ul {
    padding: 0 0 0 20px;
    margin: 0;
}

.blog_nav ul li:not(:last-child) {
    margin-bottom: 5px;
}

.blog_nav ul li a {
    color: rgb(13, 22, 43);
    line-height: 28px;
    font-size: 18px;
}

.blog_previews_text p {
    line-height: 28px;
    color: #464646;
    font-size: 18px;
}

.full_img_blog {
    width: 100%;
    height: 360px;
}

.full_img_blog img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    object-position: top;
    border-radius: 12px;
    margin-top: 20px;
    display:block;
}

h1 {}

.blog_previews_text h1 {
    color: #0d162b;
    font-size: 46px;
    line-height: 60px;
    margin-bottom: 25px;
}
.text_container p {
    font-size: 18px;
    color: #464646;
    font-weight: 300;
}

.text_container p:not(:last-child) {
    margin-bottom: 25px;
}

  .error_404 {
    background: #f1f5f9;
    text-align: center;
  }

  .error_404 .container {
    position: relative;
    padding: 85px 20px;
    background: transparent; /* фон-картинку переносим в ::before */
    z-index: 0;
  }

  /* полупрозрачный фон */
  .error_404 .container::before {
    content: "";
    margin: 10px 0;
    position: absolute;
    inset: 0;
    background: url("/assets/images/tild3261-3731-4731-b932-363663663633__404_.svg") no-repeat;
    background-size: contain;      /* можно заменить на contain */
    background-position: center; /* можно менять */
    opacity: 0.7;               /* регулируй прозрачность */
    pointer-events: none;
    z-index: 0;
    filter: invert(10%);
  }

  /* контент поверх фона */
  .error_404 .container > * {
    position: relative;
    z-index: 1;
  }

  .error_404 h1 {
    color: #0d162b;
    font-size: 170px;
    font-weight: 700;
    text-align: center;
    line-height: 170px;
    margin: 0;
  }

  .error_404_container p {
    color: #0d162b;
    font-size: 22px;
    font-weight: 500;
    margin: 15px 0 25px;
  }

  .err_home a {
    color: #ffffff;
    font-size: 16px;
    font-weight: 600;
    border-radius: 6px;
    background-color: #ec582c;
    width: 218px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    text-decoration: none;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out,
      color var(--t396-speedhover, 0s) ease-in-out,
      border-color var(--t396-speedhover, 0s) ease-in-out,
      box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
  }

  .err_home a:hover {
    background: #0d162b;
  }
  

:root{
  --ink:#0b1220;
  --text:#3a4354;
  --right-bg:#f3f6f9;
  --accent:#ff5a2a;
}

/* wrapper */
.about_history{
  background:#fff;
  /* padding: 105px 0; */
  /* margin: 20px; */
}

/* container (если у тебя уже есть — можно удалить этот блок) */
.about_history .container{
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
}

/* main layout */
.about_history .history_container{
  display:flex;
  align-items: center;
  justify-content: space-between;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
}

/* LEFT SIDE */
.about_history .history_descr{
  /* margin: 40px 0; */
}

.about_history .history_descr h2{
  margin: 0;
  font-weight: 700;
  line-height: 1.05;
  text-align: left;
  color: #0d162b;
  font-size: 44px;
  margin-bottom: 25px;
}

/* если хочешь как в макете — текст узкой колонкой по центру */
.about_history .history_descr .history_text{
  max-width: 100%;
}

.about_history .history_descr p{
  /* margin: 0 0 22px; */
  color: #464646;
  font-size: 18px;
  line-height: 28px;
}

/* RIGHT SIDE */
.about_history .history_years{
  /* flex: 0 0 44%; */
  background: #f1f5f9;
  padding: 0 60px;
  /* margin: 20px; */
}

/* Timeline grid: year | line+dot | title */
.about_history .history_years .timeline{
  --year-col: 120px;
  --mid-col: 64px;
  --line-w: 3px;
  position: relative;
  display: grid;
  grid-template-columns: var(--year-col) var(--mid-col) 1fr;
  row-gap: 76px;

  /* чтобы линия была чуть длиннее точек сверху/снизу как на макете */
  padding: 80px 0 80px;
}

/* Single vertical line centered in mid column */
.about_history .history_years .timeline::before{
  content:"";
  position:absolute;
  top: 0;
  bottom: 0;
  left: calc(var(--year-col) + (var(--mid-col) / 2) - (var(--line-w) / 2));
  width: 4px;
  background: #ec582c;
  border-radius: 3px;
}

/* Each item uses parent's grid */
.about_history .history_years .t_item{
  display: contents;
}

.about_history .history_years .t_year{
  grid-column: 1;
  align-self: center;
  justify-self: end;
  /* padding-right: 14px; */
  font-weight: 600;
  line-height: 1;
  color: #ec582c;
  font-size: 24px;
}

.about_history .history_years .t_mid{
  grid-column: 2;
  align-self: center;
  justify-self: center;
  position: relative;
  z-index: 1;
  width: var(--mid-col);
  display: flex;
  justify-content: center;
}

.about_history .history_years .t_dot{
  width: 22px;
  height: 22px;
  border-radius: 999px;
  border: 4px solid #ec582c;
  background: #f1f5f9;
}

.about_history .history_years .t_title{
  grid-column: 3;
  align-self: center;
  font-weight: 600;
  color: #0d162b;
  font-size: 26px;
  line-height: 40px;
}

.about_history .history_descr p:not(:last-child) {
    margin-bottom: 15px;
}

.about_container {
    display: flex;
    align-items: flex-end;
    gap: 90px;
    position: relative;
}

.about {
    background: url('/assets/images/tild3661-3665-4635-a564-396434613239__russian-manufacturin.jpg');
    /* padding: 105px 0; */
    background-position: center;
    background-size: cover;
    background-image: linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.45)),
    url('/assets/images/tild3661-3665-4635-a564-396434613239__russian-manufacturin.jpg');
}

.about_descr {
    background: #f1f5f9;
    border-radius: 12px;
}

.about_descr p {
    color: #464646;
    font-size: 18px;
}

.about_img img {
    max-width: 824px;
    width: 100%;
    display: block;
    position: absolute;
    bottom: 0;
}

.about_container .banner_index_left {
    max-width: 530px;
    width: 100%;
    padding-bottom: 0;
    margin: 80px 0;
}

.about_img {
    margin-left: -150px;
    /* position: relative; */
}

  .about_container .bg_dark_blue ul {
        grid-template-columns: repeat(2, 1fr);display: grid;
    }
    
    
    
.people_container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
}

.people_img img {
    max-width: 580px;
    width: 100%;
    border-radius: 16px 16px 0 0;
}

.people_descr {
    /* background-color: #f1f5f9; */
    padding: 25px;
}

.people_cart {
    background-color: #f1f5f9;
    border-radius: 12px;
}

.people_img {}

.people_cart {
    /* border-radius: 12px; */
}

.people_founder {
    font-size: 16px;
    color: #ec582c;
    font-weight: 600;
    letter-spacing: 2.5px;
}

.people_name {
    font-size: 24px;
    color: #0d162b;
    font-weight: 600;
    margin: 10px 0;
}
    
    
    
    
.contact {
    background: url(/assets/images/tild3666-6262-4438-b634-363532306164__miami-bayside-landsc.jpg) no-repeat;
    background-position: center center;
    background-attachment: scroll;
    background-size: cover;
    /* background-color: rgba(0, 0, 0, 0.3); */
    position: relative;
}

.contact::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    pointer-events: none;
}

.contact_container .banner_index_left {
    position: relative;
    padding: 60px 0;
    max-width: 560px;
}

.contact_container .btn_banner {
    flex-direction: column;
}

.contact_container .btn_banner a {
    max-width: 360px;
}

.easy {
  padding: 105px 0;
}

/* grid for 2 cards */
.easy_container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  align-items: stretch; /* одинаковая высота строк */
}

/* card wrapper: единая рамка/скругление и одинаковая высота */
.easy_cart {
  display: flex;
  flex-direction: column;
  height: 100%;
  border-radius: 10px;
  overflow: hidden; /* чтобы скругление применялось ко всей карточке */
}

/* header */
.header_easy {
  background-color: #0d162b;
  color: #ffffff;
  font-size: 22px;
  font-weight: 500;
  padding: 18px;
  border-radius: 0; /* скругление теперь на .easy_cart */
}

/* orange area should stretch to equalize height */
.easy_descr_container {
  background: #ec582c;
  padding: 18px;
  flex: 1;            /* растягиваем низ карточки */
  display: flex;
}

/* white inner box */
.easy_descr_container > div {
  border-radius: 10px;
  background: #fff;
  padding: 20px;
  display: flex;
  gap: 15px;
  width: 100%;
  flex: 1;            /* тянем белый блок по высоте */
}

/* icon circle */
.phone_easy {
  background-color: #f1f5f9;
  border-radius: 50%;
  min-width: 78px;
  height: 78px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 78px;
}

.phone_easy a {
  font-size: 42px;
  line-height: 1;
  text-decoration: none;
}

/* text column */
.easy_descr {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
}

/* title */
.easy_z {
  color: #0d162b;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 6px;
}

/* paragraph */
.easy_descr p {
  color: #464646;
  font-size: 16px;
  margin: 0 0 10px;
}

/* phone link */
a.easy_phone {
  color: #ec582c;
  font-size: 24px;
  font-weight: 600;
  margin: 0 0 10px;
  display: block;
  text-decoration: none;
}

/* small bold line */
.easy_h {
  color: #0d162b;
  font-size: 16px;
  font-weight: 600;
  margin-top: auto; /* прижать вниз (если нужно убрать — удали эту строку) */
}

/* link row */
a.easy_link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #ec582c;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  margin-top: auto; /* прижать вниз (если не нужно — удали эту строку) */
}

a.easy_link img {
  width: 22px;
  height: auto;
  display: block;
}

.easy_cart:nth-child(2) .easy_descr_container {
    background: #f1f5f9;
}
    
    

.why_call_cart a:first-child {
    font-size: 42px;
    width: 78px;
    height: 78px;
    background: #fff;
    display: flex;
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
}

.why_call_cart a:last-child {
    color: #0d162b;
    font-size: 20px;
    font-weight: 500;
}


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

.why_call_container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
}

.why_call {
    background-color: rgb(241, 245, 249);
    padding: 0 0 105px 0;
}

.free_estimate {
    background-color: rgb(241, 245, 249);
    padding: 105px 0 30px 0;
}

.free_estimate.v2 {
    padding: 105px 0;
}

.free_estimate_container form {
    background-color: #ffffff;
    border-radius: 20px;
    padding: 30px;
    max-width: 570px;
    width: 100%;
    margin: 0 auto;
}

.free_estimate_container .form_input > div,
.free_estimate_container .form_textarea {
    display: flex;
    flex-direction: column;
    /* resize: none; */
}

.free_estimate_container .form_input {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
}

.free_estimate_container .form_textarea, .form_input_email {
    margin-top: 20px;
    position: relative; /* нужно для стрелки */
}

/* базовые инпуты */
.free_estimate_container input[type="text"],
.free_estimate_container input[type="tel"],
.free_estimate_container input[type="email"],
.free_estimate_container select {
    margin-top: 10px;
    font-size: 16px;
    resize: none;
    box-sizing: border-box;
}

.free_estimate_container input[type="submit"] {
    cursor: pointer;
    background-color: #0d162b;
    transition: 0.3s ease all;
    font-size: 15px;
    border-radius: 6px;
    width: auto;
    font-weight: 600;
    height: 56px;
    color: #fff;
    display: flex;
    padding: 0 20px;
    margin: 0;
    outline: none;
    border: none;
    margin-top: 20px;
}

.free_estimate_container input[type="submit"]:hover {
    background-color: #ec582c;
}

.free_estimate_container form > p {
    font-size: 13px;
    color: rgb(70, 70, 70);
    margin-top: 20px;
}

.free_estimate_container form > p > a {
    color: rgb(236, 88, 44);
    border-bottom: 1px solid rgb(236, 88, 44);
}

.free_estimate_container {}


/* =========================
   SELECT как на скрине + стрелка треугольником
   ========================= */

.free_estimate_container .form_textarea select {
    width: 100%;
    height: 56px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 0 44px 0 20px; /* место под стрелку справа */
    font-size: 16px;
    color: #111827;
    outline: none;
    box-sizing: border-box;

    /* убираем системный стиль стрелки */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;

    /* на всякий случай убираем фон-иконки если где-то были */
    background-image: none;
    cursor: pointer;
}


/* стрелка как у тебя (CSS-треугольник) */
.free_estimate_container .form_textarea::after {
    border-color: #000 transparent transparent;
    border-style: solid;
    border-width: 6px 5px 0;
    bottom: 0;
    content: " ";
    height: 0;
    margin: auto;
    pointer-events: none;
    position: absolute;
    right: 20px;
    bottom: 26px;
    width: 0;
}

/* IE (если вдруг нужно) */
.free_estimate_container .form_textarea select::-ms-expand {
    display: none;
}
.why_call h2 {
    font-size: 34px;
}





/* ===== SERVICE BANNER (clean) ===== */
.service_banner{
  background: url(/assets/images/tild3033-3561-4962-b335-363332653032__miami-bayside-landsc.jpg) no-repeat center/cover;
  position: relative;
  padding: 70px 0;
}

.service_banner::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.3);
  pointer-events:none;
}

.service_banner > .container{
  position: relative;
  z-index: 1;
}

/* ключевой момент: перебить глобальный flex */
.service_banner .banner_index_container{
  display: grid !important;          /* единственный important */
  grid-template-columns: 1fr 1fr;
  gap: 15px;
  background: #f1f5f9;
  border-radius: 12px;
  padding: 0;
  align-items: stretch;
  position: relative;
}

/* убираем оверлей от общего баннера */
.service_banner .banner_index_container::before{
  display: none;
}

/* точечно чиним глобальный box-sizing:content-box */
.service_banner .banner_index_container,
.service_banner .banner_index_container *{
  box-sizing: border-box;
}

/* LEFT */
.service_banner .banner_index_left{
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: 100%;
  padding-bottom: 0;
}

.service_banner .banner_index_left .bg_white{
  background: none;
  border-radius: 0;
  padding: 35px 0 0 35px;
  position: relative;
  flex: 0 0 auto;
}

/* кнопки */
.service_banner .banner_index_left .btn_banner{
  display: flex;
  flex-direction: column;
  gap: 15px;
}

/* синий блок прижимаем вниз */
.service_banner .banner_index_left .bg_dark_blue{
  margin-top: 35px;
  width: 100%;
  padding: 20px 0 20px 35px;
}

.service_banner .banner_index_left .bg_dark_blue ul{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* RIGHT */
.service_banner .banner_service_right{
  width: 100%;
  min-height: 0;
  align-self: stretch;

  border-radius: 0 12px 12px 0;
  border: 6px solid #f1f5f9;

  position: relative;
  overflow: hidden;
}

.service_banner .banner_service_right img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
    object-position: top;
  border-radius: 0 12px 12px 0;
  display: block;
}


.service_banner .btn_banner a:first-child {gap: 8px;}










:root {
--card-radius:14px;
--card-bg:#fff;
--card-text:#222;
--card-muted:#676767;
--card-br:rgba(0,0,0,.06);
--shadow-hover:0 10px 24px rgba(0,0,0,.10);
}

.emergency {
    background-color: rgb(241, 245, 249);
    padding: 105px;
}

.cards {
    font-family: 'Prompt', Arial, sans-serif;
}
.cards__grid {
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:20px;
}


.card {
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:10px;
    padding:24px 20px;
    background:var(--card-bg);
    border:1px solid var(--card-br);
    border-radius:var(--card-radius);
    color:var(--card-text);
    text-decoration:none;
    transition:box-shadow .2s ease, transform .2s ease, border-color .2s ease;
    will-change: box-shadow, transform;
}
.card:hover {
    box-shadow:var(--shadow-hover);
    transform:translateY(-2px);
    border-color:rgba(0,0,0,.12);
}
.card:focus-visible {
    outline:2px solid rgba(0,0,0,.35);
    outline-offset:3px;
}


.img {
    width:40px;
    height:40px;
    flex:0 0 56px;
}
.card__title {
    margin:8px 0 0;
    font-size:18px;
    color: #ec582c;
    line-height:1.3;
    font-weight:700;
}
.card__desc {
    margin:6px 0 0;
    color:var(--card-muted);
    font-size:14px;
    line-height:1.5;
}

.why_container.v2 {
    display: flex;
    flex-direction: column;
    text-align: left;
}

.why_container.v2 .why_cart {
    display: flex;
    flex-direction: row;
    gap: 30px;
}

.why_container.v2 .why_cart span {
    font-size: 24px;
}

.why_container.v2 .why_cart p {
    font-size: 18px;
}

.why_container.v2 .why_cart img {
    max-width: 100px;
}


.free_estimate_container.v2  .form_textarea::after {
    display: none;
}

.free_estimate_container.v2 textarea {
    height: 85px;
    padding-top: 15px;
    margin-top: 10px;
    font-size: 16px;
    resize: none;
    box-sizing: border-box;
}

.free_estimate > .container > p, .tabs_block > .container > p, .brands > .container > p {
    color: #464646;
    font-size: 20px;
    text-align: center;
    margin-bottom:30px;
}



.free_estimate > .container > a {
    color: rgb(236, 88, 44);
    font-weight: 700;
    text-align: center;
    display: block;
    font-size: 20px;
    margin: 20px 0;
}

.free_estimate.v2 {}

.emergency.bg2 {
    background: #fff;
}

.emergency > .container > p {
    color: #464646;
    font-size: 20px;
    font-weight: 400;
    text-align: center;
    margin-bottom: 35px;
}



/* ===== Emergency pricing table block ===== */
.emergency-pricing {
  /* можно задать внешний отступ в месте вставки, здесь не навязываю */
}

/* Горизонтальный скролл на мобилках */
.emergency-pricing__scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Таблица */
.emergency-pricing__table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: auto;
  min-width: 720px; /* чтобы на мобилках появлялся скролл и таблица не ломалась */
}

/* Ячейки */
.emergency-pricing__th,
.emergency-pricing__td {
  padding: 18px 20px;
  vertical-align: middle;
  text-align: left;
  border-bottom: 1px solid #eee;
  font-family: "Prompt", Arial, sans-serif;
  color: #000;
}

.emergency-pricing__th {
  font-weight: 600;
  font-size: 18px;
  line-height: 1.3;
  background: #fff;
  border-top: 1px solid #eee;
  color: #ec582c;
  background: #f1f5f9;
    border-bottom: 1px solid #d9d9d9;
}

.emergency-pricing__td {
  line-height: 1.55;
      font-weight: 300;
    font-size: 18px;
    line-height: 1.55;
    color: #4d4c4c;
}

/* Ряды */
.emergency-pricing__row:nth-child(odd) .emergency-pricing__td {
  background: #fff;
}

.emergency-pricing__row:nth-child(even) .emergency-pricing__td {
    background: #f1f5f9;
    border-top: 1px solid #d9d9d9;
    border-bottom: 1px solid #d9d9d9;
}

/* Цена */
.emergency-pricing__price {
  white-space: nowrap;
}



.repairs {
    padding: 105px 0;
}

.repairs_cart img {
    min-width: 40px;
    width: 40px;
}

.repairs_cart p {
    color: #0d162b;
    font-size: 18px;
}

.repairs_cart {
    display: flex;
    gap: 15px;
    align-items: flex-start;
    padding: 25px;
    background-color: #f1f5f9;
    border-radius: 10px;
}

.repairs_cart:not(:last-child) {
    margin-bottom: 20px;
}


.form_page{
  width:100%;
  position:relative;
  overflow:hidden;
  background:#FBAA3A;            /* как на скрине */
  /* min-height:525px; */              /* высота как у десктоп-скрина */
  display:flex;
  align-items:center;
  padding: 50px 0;
}

/* правая картинка */
.form_page::after{
  content:"";
  position:absolute;
  top:0;
  right:0;
  height:100%;
  width: 40%;                     /* доля картинки справа как на скрине */
  background:url("/assets/images/tild6262-3635-4836-b034-353262366439__close-up-of-a-hand-h.png")
    center right / cover no-repeat;
  z-index:1;
}

.form_page.v2:after {
    background: url(/assets/images/tild6237-3063-4534-b039-663837396639__santehniceskii-kran-.jpg) center right / cover no-repeat;
}

/* контейнер */
.form_page .container{
  /* width:100%; */
  /* max-width:1400px; */
  /* margin:0 auto; */
  /* padding: 60px 0; */            /* большие поля слева/справа */
  /* position:relative; */
  /* z-index:2; */                     /* выше картинки */
}

/* текстовый блок */
.form_page_text{
  max-width: 690px;
}

/* заголовок */
.form_page_text > span{
  display:block;
  font-weight:800;
  line-height: 50px;
  margin-bottom:20px;
  color: #0d162b;
  font-size: 42px;
}

/* описание */
.form_page_text p{
  margin:0 0 28px;
  /* max-width:690px; */
  font-weight: 300;
  line-height: 31px;
  color: #464646;
  font-size: 18px;
}

/* кнопка/ссылка */
.form_page_text > a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  white-space:nowrap;
  font-family:"Prompt", Arial, sans-serif;
  font-weight: 600;
  font-size: 17px;
  line-height:1.2;
  color:#ffffff;
  background: #ec582c;            /* как на скрине */
  padding:22px 34px;
  border-radius:6px;             /* почти прямоугольная */
  box-shadow:none;
  border:0;
  --t396-speedhover: 0.2s;
  transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

/* убираем переносы внутри, чтобы было в одну строку как на скрине */
.form_page_text > a br{ display:none; }

/* hover (аккуратно, без “прыжков”) */
.form_page_text > a:hover{
  filter:brightness(0.98);
}

.form_page_text > a:hover {
    background: #0d162b;
}

.pricing {
    padding: 105px 0;
}

.pricing > .container > p {
    color: #464646;
    font-size: 20px;
    margin-bottom: 30px;
    text-align: center;
}

.pricing_container > p {
    font-size: 14px;
    color: #464646;
    line-height: 1.55;
    font-weight: 300;
    margin-top: 15px;
}

.quote_price {
    line-height: 37px;
    font-size: 24px;
    color: #0d162b;
    font-weight: 600;
    border: 6px solid #fbaa3a;
    border-radius: 18px;
    padding: 15px 40px;
    margin-top: 35px;
}
.card__btn {
    position: relative;
    z-index: 2;
    margin-top: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 24px;
    background: var(--btn-bg);
    color: #fff !important;
    border-radius: 6px;
    font-weight: 600;
    text-decoration: none;
    transition: background-color .2s ease, transform .15s ease;
}
.card__btn:hover {
    background: var(--btn-bg-hover);
}

a.dropdown__link.nav__link--active {
    color: #ec582c;
    font-weight: 600;
}

a.nav__link.nav__link--active {color: #ec582c;}

.leak_container {
    display: flex;
    align-items: stretch;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    /* justify-content: space-between; */
    /* justify-items: self-end; */
    gap: 90px;
}

.leak_left {
    /* max-width: 400px; */
}

.leak_right_container div {
    display: flex;
    align-items: center;
    gap: 160px;
}

.leak_right_container span {
    color: #0d162b;
    font-size: 26px;
    font-weight: 600;
    line-height: 40px;
    display: block;
}

.leak_right_container div img {
    max-width: 80px;
    width: 100%;
}

.lkrs {
    position: relative;
    height: 100%;
}

.leak_img img {
    transform: rotate(270deg);
    width: 111px;
}

.leak_img:before {
    width: 33px;
    background: #ec582c;
    content: '';
    display: flex;
    height: 100%;
    position: absolute;
    top: 50px;
    left: 39px;
}

.leak_img {position: absolute;top: 0;left: 105px;height: 100%;}

.leak_right {
    position: relative;
}

.leak_right_container {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.leak_left h2 {
    text-align: left;
}

.leak_right_container div:not(:last-child) {
    margin-bottom: 80px;
}

.leak {
    /* padding: 105px 0; */
    overflow-y: hidden;
    padding: 105px 0;
    margin-bottom: 0;
}

.leak_left p:not(:last-child) {
    margin-bottom: 25px;
}

.leak_left p {
    color: #464646;
    font-size: 18px;
}

.service_area_page .faq.v2 {
    background: #fff;
}

.faq.v2 .faq_container {
    /* background: #f1f5f9; */
    padding: 20px;
    max-width: 760px;
    margin: 0 auto;
}

.faq.v2 .faq_container  .faq__item {
    border-radius: unset;
    background: none;
    padding: 20px;
    /* padding-left: 0; */
    /* padding-right: 0; */
    background: #f1f5f9;
}

.faq.v2 .faq__panel {
    /* background: #fff; */
    margin-top: 10px;
}

.faq.v2 .faq__panel img {
    display: block;
    width: 100%;
    margin-bottom: 15px;
}



.faq.v2 .faq_container .faq__item {
    /* margin-bottom: 10px; */
}

.faq.v2 .faq__icon {
    background: none;
}

.faq.v2 .faq__icon:hover {
    background: #ec582c;
}

svg {
    /* background: #fff; */
}

.faq.v2 .faq__icon:hover g[transform] {
  stroke: #fff !important;
}


.steps.v2 .steps_container{
 display: grid;
 grid-template-columns: repeat(4, 1fr);
 gap: 70px 30px;
 position: relative;
 margin-top: 70px;
 text-align: center;
}

.steps.v2 .steps_cart{
  position: relative;
  background: #fff;
}

.steps.v2 .steps_cart:not(:last-child)::after{
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 100%;
  width: 24px;          /* ровно gap */
  height: 6px;
  background: #ec582c;
  z-index: 0;
}
.steps.v2 .steps_cart > *{
  position: relative;
  z-index: 1;
}


.steps.v2 .steps_container:after {
    display: none;
}

.steps.v2 .steps_cart:nth-child(4n)::after{
   display: none;
}

.form_q {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 15px;
}

.form_q img {
    max-width: 38px;
    width: 100%;
}

.form_q a {
    color: #0d162b;
    font-size: 14px;
    line-height: 24px;
    font-weight: 600;
}



.qu {
    line-height: 26px;
    color: #464646;
    font-size: 17px;
    font-weight: 600;
    border-left: 6px solid #ec582c;
    padding-left: 15px;
    margin-bottom: 20px;
}

.our_call a {
    line-height: 31px;
    color: #464646;
    font-size: 20px;
    text-align: center;
}
.our_call p {margin-top:15px;    color: #d9d9d9;
    font-size: 16px;}
.our_call {
    text-align: center;
    margin-top: 20px;
}

.our_call a strong {
    color: rgb(236, 88, 44);
}

.bg-white {background:#fff;}





.our {
    background-color: rgb(13, 22, 43);
    padding: 105px 0;
}

.our h2 {
    color: #fff;
}

.our_container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-top: 30px;
    align-items: stretch;
}

.our_img img {
    max-width: 280px;
    width: 100%;
    display: block;
    object-fit: cover;
    height: 100%;
    border-radius: 12px 12px 0 0;
}

.our_descr {
    background: #f1f5f9;
    padding: 20px;
    border-radius: 0 0 12px 12px;
    flex: 1 1 auto;
}

.our_img {
    height: 200px;
}

.our_cart {
    /* border-radius: 12px; */
    height: 100%;
    display: flex;
    flex-direction: column;
}

.our_descr span {
    font-size: 22px;
    color: #0d162b;
    font-weight: 600;
    line-height: 1.35;
    display: block;
    margin-bottom: 15px;
}


p {}

.our_descr p {
    font-size: 16px;
    color: #464646;
    font-weight: 300;
}

.beats {
    padding: 105px 0;
}

.beats_container {
    display: flex;
    align-items: center;
}

.beats_container > div {
    display: flex;
    align-items: center;
    border: 2px solid #d9d9d9;
    border-radius: 6px;
    padding: 10px 40px;
    gap: 5px;
}

.beats_container > div img {
    max-width: 20px;
    width: 100%;
}

.beats_container > div span {
    color: #ec582c;
    font-size: 22px;
    font-weight: 600;
}

.beats_container > img {
    max-width: 739px;
    width: 100%;
}

.beats_container > div:last-child img {transform: rotate(180deg);}

.beats_adv {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-top: 30px;
}

.beats_adv_cart img {
    max-width: 100px;
    width: 100%;
}

.beats_adv_cart span {
    display: block;
    font-size: 22px;
    color: #0d162b;
    line-height: 1.35;
    font-weight: 600;
    margin-bottom: 20px;
    margin-top: 20px;
}

.beats_adv_cart {
    text-align: center;
    border-right: 1px solid #d9d9d9;
    padding-right: 30px;
}

.beats_adv_cart p {
    font-size: 16px;
    color: #464646;
    font-weight: 300;
    line-height: 1.55;
}

.beats_adv_cart:last-child {
    padding-right: 0;
    border: none;
}

/* ====== ТВОИ СТИЛИ (ТОЛЬКО СКОУПНУЛ НА БЛОК) ====== */
.brands_container ul {
  list-style: none;
  margin-bottom: 0;
  padding-left: 0;
}

.brands_container .brands_link,
.brands_container .brands_link_second {
  outline: none;
}

.brands_container .brands_link {
  color: inherit !important;
}

.brands_container .focusable,
.brands_container .focusable .btn,
.brands_container .focusable .btntext {
  position: relative;
}

/* ====== ДОБАВЛЕНИЯ: ВЕРСТКА И ЛИНИИ КАК НА СКРИНЕ ====== */
.brands_container {
  --border-color: #bebebe;
  --border-size: 1px;
}

.brands_container .brands_list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  margin: 0;
  padding: 0;
}

.brands_container .brands_item {
  min-height: 140px;              /* высота ячейки как на скрине */
  display: flex;
  align-items: center;
  justify-content: center;

  /* внутренние линии */
  border-right: var(--border-size) solid var(--border-color);
  border-bottom: var(--border-size) solid var(--border-color);
}

/* убрать правую линию у 5-й колонки */
.brands_container .brands_item:nth-child(5n) {
  border-right: 0;
}

/* убрать нижнюю линию у последнего ряда (для 10 элементов = 2 ряда) */
.brands_container .brands_item:nth-last-child(-n + 5) {
  border-bottom: 0;
}

.brands_container .brands_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.brands_container .brands_img {
  display: block;
  max-width: 210px;  /* как у тебя было */
  width: 100%;
  height: auto;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
  filter: #808080;
}

/* ====== Адаптив (чтобы не разваливалось) ====== */
@media (max-width: 960px) {
  .brands_container .brands_list { grid-template-columns: repeat(3, 1fr); }
  .brands_container .brands_item { border-right: var(--border-size) solid var(--border-color); }

  .brands_container .brands_item:nth-child(5n) { border-right: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-child(3n) { border-right: 0; }

  .brands_container .brands_item:nth-last-child(-n + 5) { border-bottom: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-last-child(-n + 3) { border-bottom: 0; }
}

@media (max-width: 640px) {
  .brands_container .brands_list { grid-template-columns: repeat(2, 1fr); }

  .brands_container .brands_item:nth-child(3n) { border-right: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-child(2n) { border-right: 0; }

  .brands_container .brands_item:nth-last-child(-n + 3) { border-bottom: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-last-child(-n + 2) { border-bottom: 0; }
}


li.brands_item a:hover img {
    -webkit-filter: grayscale(0%);
    -moz-filter: grayscale(0%);
    -ms-filter: grayscale(0%);
    -o-filter: grayscale(0%);
    filter: grayscale(0%);
    filter: none;
}
.our_call.bold a {
    font-weight: 600;
    font-size: 24px;
}

/* ====== ТВОИ СТИЛИ (ТОЛЬКО СКОУПНУЛ НА БЛОК) ====== */
.brands_container ul {
  list-style: none;
  margin-bottom: 0;
  padding-left: 0;
}

.brands_container .brands_link,
.brands_container .brands_link_second {
  outline: none;
}

.brands_container .brands_link {
  color: inherit !important;
}

.brands_container .focusable,
.brands_container .focusable .btn,
.brands_container .focusable .btntext {
  position: relative;
}

/* ====== ДОБАВЛЕНИЯ: ВЕРСТКА И ЛИНИИ КАК НА СКРИНЕ ====== */
.brands_container {
  --border-color: #bebebe;
  --border-size: 1px;
}

.brands_container .brands_list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  margin: 0;
  padding: 0;
}

.brands_container .brands_item {
  min-height: 140px;              /* высота ячейки как на скрине */
  display: flex;
  align-items: center;
  justify-content: center;

  /* внутренние линии */
  border-right: var(--border-size) solid var(--border-color);
  border-bottom: var(--border-size) solid var(--border-color);
}

/* убрать правую линию у 5-й колонки */
.brands_container .brands_item:nth-child(5n) {
  border-right: 0;
}

/* убрать нижнюю линию у последнего ряда (для 10 элементов = 2 ряда) */
.brands_container .brands_item:nth-last-child(-n + 5) {
  border-bottom: 0;
}

.brands_container .brands_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.brands_container .brands_img {
  display: block;
  max-width: 210px;  /* как у тебя было */
  width: 100%;
  height: auto;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
  filter: #808080;
}

/* ====== Адаптив (чтобы не разваливалось) ====== */
@media (max-width: 960px) {
  .brands_container .brands_list { grid-template-columns: repeat(3, 1fr); }
  .brands_container .brands_item { border-right: var(--border-size) solid var(--border-color); }

  .brands_container .brands_item:nth-child(5n) { border-right: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-child(3n) { border-right: 0; }

  .brands_container .brands_item:nth-last-child(-n + 5) { border-bottom: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-last-child(-n + 3) { border-bottom: 0; }
}

@media (max-width: 640px) {
  .brands_container .brands_list { grid-template-columns: repeat(2, 1fr); }

  .brands_container .brands_item:nth-child(3n) { border-right: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-child(2n) { border-right: 0; }

  .brands_container .brands_item:nth-last-child(-n + 3) { border-bottom: var(--border-size) solid var(--border-color); }
  .brands_container .brands_item:nth-last-child(-n + 2) { border-bottom: 0; }
}


li.brands_item a:hover img {
    -webkit-filter: grayscale(0%);
    -moz-filter: grayscale(0%);
    -ms-filter: grayscale(0%);
    -o-filter: grayscale(0%);
    filter: grayscale(0%);
    filter: none;
}

.form_page.v3:after {
    background: url(/assets/images/tild3531-3464-4036-b564-626239323234__image_14_1.png) #0d162b center right / cover no-repeat;
    background-size: 490px;
}

.form_page.v3 .form_page_text p {
    margin-bottom: 15px;
}
.block_images_container {
    display: flex;
    align-items: center;
    gap: 60px;
}

.block_images_descr h2 {
    text-align: left;
    line-height: 57px;
}

.block_images_descr p {
    color: #464646;
    font-size: 18px;
    line-height: 28px;
}

.block_images_descr p:not(:last-child) {
    margin-bottom: 20px;
}

.block_images {
    padding: 105px 0;
}

.block_images_container img {
    min-width: 500px;
}

.tabs_block {
    background: rgb(13, 22, 43);
    color: #fff;
    padding: 105px 0;
}

.tabs_block h2 {
    color: #fff;
}

.brands {
    padding: 105px 0;
}

.quote_price.v2 {
    border: 2px solid #ec582c;
}



/* ====== Tabs header ====== */
.tabs_block_container {
  margin-top: 26px;
}

.header_tabs {
  list-style: none;
  padding: 0;
  margin: 0 auto 22px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-radius: 10px;
  overflow: hidden;
  background: #ffffff;
  color: #0d162b;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.28);
}

.header_tabs li {
  padding: 16px 18px;
  font-size: 16px;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  user-select: none;

  border-right: 1px solid rgba(11, 21, 48, 0.14);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.header_tabs li:last-child {
  border-right: 0;
}

.header_tabs li:hover {
}

.header_tabs li.is-active,
.header_tabs li.active {
  background: #fbaa3a; /* orange highlight like screenshot */
  cursor: default;
}

/* Keyboard focus */
.header_tabs li:focus-visible {
  outline: 3px solid rgba(255, 173, 58, 0.7);
  outline-offset: -3px;
}

/* ====== Content area ====== */
.tabs_content {
  margin: 0 auto;
}

.tabs_cart {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 26px;

  background: #eef1f5;
  color: #0b1530;
  border-radius: 18px;
  padding: 34px 40px;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

.tabs_cart.is-active,
.tabs_cart.active {
  display: flex;
}

/* Left icon */
.tabs_cart > img {
  max-width: 130px;
  border-radius: 50%;
  background: #fff;
  box-shadow: inset 0 0 0 1px rgba(11, 21, 48, 0.08);
  flex: 0 0 auto;
  width: 100%;
  box-sizing: border-box;
}

/* Text */
.tabs_cart_descr {
  flex: 1 1 auto;
  min-width: 240px;
}

.tabs_cart_descr p {
  font-size: 18px;
  line-height: 1.55;
  color: rgba(11, 21, 48, 0.88);
}

.tabs_cart_descr p strong {
  color: rgba(11, 21, 48, 0.92);
  font-weight: 800;
}

/* Right button */
.tabs_cart .btn2 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 28px;
  border-radius: 8px;
  background: #f05a2a;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.03em;
  white-space: nowrap;
  --t396-speedhover: 0.2s;
  transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

.tabs_cart .btn2:hover {
      background: #0d162b;
}





.tabs_cart_descr p:not(:last-child) {
    margin-bottom: 15px;
}
.tabs_block > .container > p {color:#fff;}

.form_page.v4:after {
    background: url(/assets/images/tild6437-3762-4139-a235-656238363435__image_18_1.png) #0d162b center right / cover no-repeat;
    background-size: 460px;
}
.form_page.v5:after {
    background: url(/assets/images/clock_sink_50px.png) #0d162b bottom -20px right / cover no-repeat;
    background-size: 440px;
}

.form_page.v6:after {
        background: url(/assets/images/tild3762-3437-4366-b562-313164323361__image_23.png) #0d162b bottom right / contain no-repeat;

}

.form_page.v7:after {
        background: url(/assets/images/tild3637-6633-4439-a633-653033656439__shutterstock_2003389.jpg) bottom right / cover no-repeat;

}

.form_page.v8:after {
        background: url(/assets/images/tild3931-3038-4638-a638-613737626630__d1f06ff9cc3790b05dee.jpg) bottom right / contain no-repeat;

}

.tabs_block_container.v2 .header_tabs {
    grid-template-columns: repeat(2, 1fr);
}


.two_tabs_cart {
    grid-template-columns: repeat(2, 1fr);
    display: grid;
    gap: 20px;
    width:100%;
}

.two_tabs_cart > div {
    background: #eef1f5;
    border-radius: 16px;
    padding: 30px 0;
}

.tabs_block_container.v2 .tabs_cart {
    padding: 0;
    background: none;
    box-shadow: none;
    /* border-radius: 16px; */
}

.tabs_block_container.v2 .tabs_cart_descr span {
    color: #ec582c;
    font-size: 20px;
    font-weight: 700;
    display: block;
}

.full_tabs_cart img {
    max-width: 130px;
    width: 100%;
}

.full_tabs_cart .tabs_cart_descr p {
    color: #464646;
    font-size: 16px;
    line-height: 25px;
}

.bottom_tabs_cart {
    border-top: 1px solid #d9d9d9;
    margin-top: 20px;
    padding: 15px 15px 0 20px;
}

.full_tabs_cart {
    padding: 0 20px;
}

.full_tabs_cart {
    display: flex;
    align-items: center;
    gap: 15px;
}

.tabs_block_container.v2 > p {
    font-size: 16px;
    margin-top: 20px;font-weight:300;
}

.bottom_tabs_cart {
    color: #464646;
    font-size: 16px;
}

.two_tabs_cart.v2 {
    grid-template-columns: repeat(1, 1fr);
}

.causes {
    background-color: rgb(13, 22, 43);
    padding: 105px 0;
    color: #fff;
}

.causes h2 {
    color: #fff;
}

.causes_container {
    grid-template-columns: repeat(2, 1fr);
    display: grid;
    gap: 20px;
    width: 100%;
    margin-top:30px;
}

.causes_cart {
    background: #eef1f5;
    border-radius: 16px;
    padding: 30px 0;
}

.causes_top {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 0 20px;
}

.causes_descr span {
    color: #ec582c;
    font-size: 20px;
    font-weight: 700;
    display: block;
    margin-bottom: 5px;
}

.causes_descr p {
    color: #464646;
    font-size: 16px;
    line-height: 25px;
}

.causes_top img {
    max-width: 130px;
    width: 100%;
}

.causes_bottom {
    border-top: 1px solid #d9d9d9;
    margin-top: 20px;
    padding: 15px 20px 0 20px;
}

.causes_bottom p {
    color: #464646;
    font-size: 16px;
}

.right_img_block {
    padding: 105px 0;
}

.right_img_block_container {
    display: flex;
    align-items: stretch;
    gap: 60px;
    margin-toP:30px;
}

.left_right_text p, .left_right_text ul li {
    color: #464646;
    font-size: 18px;
    line-height: 28px;
}

.left_right_text ul {
    margin: 0;
    padding: 0 0 0 20px;
}

ul.img_ul li {
    display: flex;
    align-items: center;
    gap: 10px;
}

ul.img_ul li img {
    width: 28px;
    min-width: 28px;
}

.left_right_text ul.img_ul {
    padding: 0;
    margin-top: 20px;
}

.left_right_text p:not(:last-child) {
    margin-bottom: 20px;
}

.left_right_text ul li:not(:last-child) {
    margin-bottom: 10px;
}

.right_right_img img {
    width: 100%;
    border-radius: 20px;
    height: 100%;
    object-fit: cover;
    /* flex: 1 1; */
    /* display: flex; */
}

.right_right_img {
    display: flex;
    /* align-items: stretch; */
}

.left_right_text, .right_right_img {
    flex: 1;
}

.slider_service {
    padding: 105px 0;
}

.slider_service_cart {
    /* border-radius: 12px; */
    /* background-color: rgb(241, 245, 249); */
}

.slider_desc {
    background-color: rgb(241, 245, 249);
    padding: 20px;
    border-radius: 0 0 12px 12px;
}

.slider_service_cart img {
    border-radius: 12px 12px 0 0;
    display: block;
    max-width: 640px;
    width: 100%;
}

.slider_desc span {
    font-size: 24px;
    color: #ed3c07;
    font-weight: 600;
}

.slider_desc p {
    font-size: 16px;
    color: #464646;
    font-weight: 300;
}

.slider_desc p:not(:last-child) {
    margin-bottom: 15px;
}

.slider_desc p strong {
    font-weight: 700;
}

.behind {
    padding: 105px 0;
    background-color: rgb(13, 22, 43);
}

.behind h2 {
    color: #fff;
    text-align: left;
    margin-bottom: 0;
}

.behind_img {
    width: 560px;
    height: 280px;
    margin-left: auto;
}

.behind_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px;
    object-position: top;
}

.behind_container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    align-items: center;
}

.behind_adv {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 100px;
}

.behind_adv_cart img {
    max-width: 140px;
    width: 100%;
    margin-top: -70px;
}

.behind_adv_cart span {
    color: #ed3c07;
    font-size: 22px;
    font-weight: 600;
    display: block;
    margin: 15px 0;
}

.behind_adv_cart p {color: #464646;
    font-size: 16px;}

.behind_adv_cart {
    background: #fff;
    border-radius: 16px;
    padding: 0 20px 20px 20px;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.arr_service_prev, .arr_service_next {
    background-color: rgba(251, 102, 58, 1);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
    cursor: pointer;
}

.arr_service {
    display: flex;
    align-items: center;
    gap: 5px;
    width: 100%;
}

.arr_service_next {
    transform: rotate(0.5turn);
}

.arr_service div:hover {
    background: rgba(13, 22, 43, 1);
}

/* ====== SERVICE SLIDER (like screenshot) ====== */

.slider_service .container{
  position: relative; /* чтобы стрелки позиционировались относительно контейнера */
}

.slider_service_container{
  position: relative;
  overflow: hidden; /* чтобы слайды не вылезали */
  margin-top: 30px;
}

/* если после JS контейнер станет .swiper */
.slider_service_container.swiper{
  overflow: hidden;
}

/* wrapper/slides – чтобы не ломалось, когда Swiper добавит классы */
.slider_service_container .swiper-wrapper{
  align-items: stretch;
}

.slider_service_container .swiper-slide{
  height: auto;
}

/* карточка как на скрине: белый блок, скругления */
.slider_service_cart{
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* картинка сверху */
.slider_service_cart img{
  width: 100%;
  height: 220px;           /* можно подогнать */
  object-fit: cover;
  display: block;
}

/* текстовая часть */
.slider_desc{
  padding: 22px 22px 26px;
}

.slider_desc span{
  display: block;
  font-size: 28px;
  line-height: 1.15;
  font-weight: 800;
  color: #fb663a;          /* как оранжевый на скрине */
  margin-bottom: 12px;
}

.slider_desc p{
  margin: 0 0 14px 0;
  font-size: 16px;
  line-height: 1.55;
  color: #2c2c2c;
}

.slider_desc p:last-child{
  margin-bottom: 0;
}

.slider_desc strong{
  font-weight: 800;
}

/* ====== ARROWS (position like screenshot) ====== */
.arr_service{
  position: absolute;
  left: 0;
  right: 0;
  top: 60%;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  pointer-events: none; /* кликаем только по кнопкам */
  z-index: 2;
}

/* сами кнопки */
.arr_service_prev,
.arr_service_next{
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fb663a;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  pointer-events: auto;
  user-select: none;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
}








.arr_service_prev {
    margin-left: -40px;
}

.arr_service_next {
    margin-right: -40px;
}

.slider_service_container .swiper-wrapper{
  align-items: stretch;
}

.slider_service_container .swiper-slide{
  height: auto;
  display: flex;         /* чтобы карточка могла растянуться */
}

.steps.v4 .steps_container:after {
    display: none;
}

.steps.v4 {
    background: #fff;
}

.steps.v4 .steps_cart {
    background: #f1f5f9;
}

.form_page_text > a:last-of-type {
    background-color: #f1f5f9;
    color: #0d162b;
    margin-top: 15px;
}

.form_page.v5 .form_page_text > a {
    min-width: 390px;
    box-sizing: border-box;
}

.form_page_text > a:hover:last-of-type {
    background: #0d162b;
    color: #fff;
}

.faq.v2.bg_deep_navy {
    background-color: rgb(13, 22, 43);
}

.faq.v2.bg_deep_navy h2, .faq.v2.bg_deep_navy p {
    color: #fff;
}

.faq.v2.bg_deep_navy .faq__item {
    border-radius: 8px;
}

.how_to_container {
    grid-template-columns: repeat(5, 1fr);
    display: grid;
    gap: 15px;
    margin: 30px 0;
}

.how_to_cart {
    display: flex;
    flex-direction: column;
    text-align: center;
    background-color: #f1f5f9;
    border-radius: 12px;
    padding: 20px;
}

.how_to_cart img {
    max-width: 64px;
    width: 100%;
    margin: 0 auto;
}

.how_to {
    background-color: rgb(13, 22, 43);
    padding: 105px 0;
}

.how_to h2, .how_to p {
    color: #fff;
}

.how_to_cart span {
    color: #464646;
    font-size: 17px;
    font-weight: 600;
    display: block;
    margin-top: 20px;
}




/* ===== Material cell ===== */
.material_media{
  display:flex;
  gap:16px;
  align-items:center;
}

.material_img{
  width:130px;
  height:114px;
  background:#fff;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 2px 10px rgba(0,0,0,.08);
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
}

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

.material_name{
  font-size:20px;
  font-weight:400;
  color:#111;
  line-height:1.15;
}

.material_name .muted{
  font-weight:400;
  color:#111;
}

/* ===== Lifespan ===== */
.lifespan_val{
  font-size:18px;
  color:#111;
  line-height:1.2;
}

/* ===== Pros & Cons list ===== */
.pc_list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}

.pc_item{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-size:18px;
  color:#111;
  line-height:26px;
}

.pc_icon{
  width:22px;
  height:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:2px; /* квадратная иконка */
  font-size:16px;
  font-weight:900;
  flex:0 0 auto;
  margin-top:1px;
}

.pc_item.is-ok .pc_icon{
  background:#16b33a;
  color:#fff;
}

.pc_item.is-no .pc_icon{
  background:transparent;
  color:#d11f1f;
  font-size:18px;
}

/* ===== Best for ===== */
.bestfor_text{
  font-size:18px;
  color:#111;
  line-height:1.35;
}




/* ===== Choosing table ===== */
.choosing_table{
  width:100%;
  border-radius:10px;
  overflow:hidden;
}

.choosing_head{
  display:grid;
  grid-template-columns: 320px 160px 1fr 320px;
  gap:0;
  padding:14px 18px;
  align-items:center;
}

.choosing_head .th{
  font-weight:800;
  color:#ff5a2f; /* оранжевый как на скрине */
  font-size:18px;
}

.choosing_row{
  display:grid;
  grid-template-columns: 320px 160px 1fr 320px;
  gap:0;
  padding:26px 18px;
  align-items:center;
}

.choosing_row.is-green{background: #e0ffd5;}
.choosing_row.is-beige{background: #ffecd1;}
.choosing_row.is-gray{background: #f1f5f9;}

.choosing_row + .choosing_row{
  /* border-top:1px solid rgba(0,0,0,.06); */
}

.td{ padding:0 10px; }

.choosing_container > p {
    font-size: 14px;
    color: #464646;
    font-weight: 300;
    margin-top: 15px;
}

.choosing {
    padding: 105px 0;
}

.choosing_container {
    margin-top: 20px;
}

.tabs_cart_img {
    display: flex;
    background-color: #f1f5f9;
    padding: 25px;
    border-radius: 16px;
    gap: 20px;
    align-items: center;
}

.tc_img img {
    /* max-width: 450px; */
    width: 450px;
    border-radius: 10px;
}

.tc_descr span {
    color: #ec582c;
    font-size: 22px;
    font-weight: 700;
    display: block;
    margin-bottom: 10px;
}

.tc_descr p {
    color: #464646;
    font-size: 16px;
    line-height: 25px;
}

.form_page.v6 .form_page_text a, .form_page.v7 .form_page_text a, .form_page.v8 .form_page_text a {
    background: #ec582c;
    color: #fff;
}

.form_page.v6 .form_page_text a:hover, .form_page.v7 .form_page_text a:hover, .form_page.v8 .form_page_text a:hover {
    background: #0d162b;
}

.tabs_block.off-white {
    background: rgb(241, 245, 249);
}

.tabs_block.off-white  h2 {
    color: #0d162b;
}

.tabs_block.off-white > .container > p {
    color: #464646;
}

.tabs_block.off-white .tabs_block_container.v2 .header_tabs {
    box-shadow: none;
    /* border-radius: 50%; */
}

.tabs_block.off-white .header_tabs li {
    border: 1px solid #d9d9d9;
    box-sizing: border-box;
}

.tabs_block.off-white .header_tabs li.is-active {
    border: 1px solid #fbaa3a;
}

.tabs_block.off-white .tabs_content {
    background: #fff;
    border-radius: 16px;
    padding: 20px;
}
.tcrt1 {
    align-items: center;
    justify-content: space-between;
    gap: 26px;
    display: flex;
}

.tcrt1 > img {
    width: 130px;
}

.tabs_block.off-white .tabs_block_container.v2 .tabs_cart {
    flex-direction: column;
    align-items: flex-start;
}
.tcrt1 {
    align-items: center;
    justify-content: space-between;
    gap: 26px;
    display: flex;
}

.tcrt1 > img {
    width: 130px;
}

.tabs_block.off-white .tabs_block_container.v2 .tabs_cart {
    flex-direction: column;
    align-items: flex-start;
}

.desc_trc {
    color: #464646;
    font-size: 16px;
}



.tabs_block.off-white .tabs_block_container.v2 > p {
    font-size: 16px;
    color: #464646;
}


.brand-grid {
display: flex;
justify-content: center;
gap: 20px;
margin-bottom: 20px;
}
.brand-item {
position: relative;
border: 2px solid #ccc;
padding: 20px;
background-color: #fff;
transition: transform 0.3s;
flex-basis: calc(20% - 20px); /* Пять колонок с учетом отступов */
}
.brand-item:hover {
transform: scale(1.05);
border-color: #EC582C;
}
.brand-item img {
width: 170px;
filter: grayscale(100%);
transition: filter 0.3s;
}
.brand-item:hover img {
filter: grayscale(0%);
}
.tooltip {
display: none;
position: absolute;
top: 100%;
left: 50%;
transform: translateX(-50%);
background-color: #fff;
border: 1px solid #ccc;
padding: 10px;
width: 200px;
box-shadow: 0 0 10px rgba(0,0,0,0.1);
text-align: left;
z-index: 10;
}
.brand-item:hover .tooltip {
display: block;
}
.brands_water_container {margin-top:30px;}

.behind.v2 h2 {
    text-align: center;
    margin-bottom:20px;
}

.behind.v2 .behind_adv {
    grid-template-columns: repeat(4, 1fr);
}
.brands_water {
    padding: 105px 0;
}

.bg-v3 {background:rgb(13, 22, 43);}

.steps.v2.bg-v3 h2, .steps.v2.bg-v3 > .container > p {
    color: #fff;
}


.tabs_block_container.v3 .header_tabs {
    grid-template-columns: repeat(5, 1fr);
}

.tabs_block_container.v3 .header_tabs li {
    display: flex;
    align-items: center;
    justify-content: center;
}

.protect {
    background-color: rgb(13, 22, 43);
    padding: 105px 0;
    color: #fff;
}

.protect h2 {
    color: #fff;
    text-align: left;
}

.protect_container {
    display: flex;
    align-items: center;
    gap: 40px;
}

.protect_cart {
    background-color: #ec582c;
    border-radius: 16px;
    text-align: center;
    padding: 30px 50px;
}

.protect_cart img {
    max-width: 140px;
    width: 100%;
    margin-top: -90px;
}

.protect_descr span {
    font-size: 22px;
    font-weight: 600;
    display: block;
    margin-bottom: 10px;
    margin-top: 10px;
}

.protect_descr p {
    font-size: 16px;
}

.protect_left p {
    font-size: 18px;
}

.protect_right {
    max-width: 375px;
    width: 100%;
}

.protect_descr a {
    background-color: #fbaa3a;
    color: #0d162b;
    font-size: 14px;
    border-radius: 6px;
    font-weight: 600;
    max-width: 240px;
    width: 100%;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 20px auto 0 auto;
    --t396-speedhover: 0.2s;
    transition: background-color var(--t396-speedhover, 0s) ease-in-out, color var(--t396-speedhover, 0s) ease-in-out, border-color var(--t396-speedhover, 0s) ease-in-out, box-shadow var(--t396-shadowshoverspeed, 0.2s) ease-in-out;
}

.protect_descr a:hover {
    background: #0d162b;
    color: #fff;
}


@media (max-width: 1440px) {
.about_img {
    position: relative;
}

.about_img img {
    position: relative;
}
}
@media (max-width: 1199px) {
.about_history .history_years .t_year {font-size:22px;}
.about_container .banner_index_left {
    max-width: 458px;
}

.about_img {
    margin-left: -190px;
}

.about_container .banner_index_left {
    margin: 50px 0;
}
.bg_white {
    padding: 20px;
}
.need h2 {font-size: 42px;}
.article_name {        font-size: 18px;}
.blog h1, .text h1 {font-size:42px;}
form.request-form-rev {
    box-sizing: border-box;
    height: 100%;
}



.ready_container {
    display: flex;
    align-items: stretch;
}

.ready_container > * {
    width: 50%;
}

.ready_left > img {
    max-width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 20px 20px 0 0;
}

.form_input > div, .form_textarea {
    /* flex-wrap: wrap; */
}

.form_input {
    /* display: flex; */
    /* flex-wrap: wrap; */
}

.form_input {
    grid-template-columns: repeat(1, 1fr);
}

.call_use {
    margin-top: 0;
    border-radius: 0 0 20px 20px;
}

.ready_left {
    display: flex;
    flex-direction: column;
}
.faq__q {    font-size: 22px;}
.limited_time > img {
    max-width: 240px;
    top: 0;
    right: -100px;
}

.limited_time_left span {
    font-size: 40px;
}

.limited_time_left p {
    font-size: 17px;
}

.limited_time_container {
    gap: 30px;
}
.proudly_left {
    max-height: 100%;
}

.proudly_container {
    align-items: stretch;
}
h2 {font-size: 42px;}
.bg_white p {        font-size: 17px;}
.banner_index_left {
    max-width: 600px;
}


nav.nav {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    justify-items: center;
}



a.top_logo img {
    max-width: 190px;
}
.banner_index_left h1 {        font-size: 40px;}

.banner_service h1 {font-size: 38px;}
.banner_service_left ul li {font-size: 17px;}
.intro_service p {
    font-size: 16px;
}
.elevate__img {
    max-height: unset;
    max-width: 330px;        margin-left: 0;
}

.elevate__container {
    max-width: 600px;
}

.elevate__left span {font-size: 36px;}
.error_404_container p {font-size: 20px;}

.blog_previews_text h1 {        font-size: 42px;}
.descr_btn_footer .need_z {font-size: 36px;}

.about_history .history_descr p {font-size: 16px;}
.about_history .history_years .t_title {font-size: 24px;}
.why_call h2 {
    font-size: 32px;
}

.repairs_cart p {font-size: 18px;}
.form_page_text {
    max-width: 530px;
}
.form_page_text > span  {font-size: 36px;}

.beats_container {
    flex-direction: column;
    align-items: center;
    margin-top: 30px;
}

.beats_container > div:first-child {
    margin-left: auto;
    margin-right: 160px;
    margin-bottom: -40px;
}
.beats_container > div:last-child {
    margin-right: auto;
    margin-left: 160px;
    margin-top: -40px;
}

.beats_adv {
    margin-top: 60px;
}
.beats_container > div {z-index:1;background:#fff;}

.left_right_text p, .left_right_text ul li {font-size:17px;}

.arr_service_prev {
    margin-left: 10px;
}

.arr_service_next {
    margin-right: 10px;
}

.slider_service_container {
    margin: 30px 40px 0 40px;
}
.how_to_container {
    grid-template-columns: repeat(3, 1fr);
}
.form_page.v5:after {
    background-size: contain;
    background-position: center center;
}

.brand-grid {display:grid;grid-template-columns: repeat(3, 1fr);}
/*1199*/


}

@media (max-width: 959px) {
.brand-grid {display:grid;grid-template-columns: repeat(1, 1fr);}
.blog_container {
    grid-template-columns: repeat(2, 1fr);
}
.btn_need {
    flex-direction: column;
    align-items: center;
}

.btn_need a {
    max-width: 340px;
}
.need p {font-size:18px;}
.blog h1, .text h1 {font-size:36px;}
.need h2 {font-size: 36px;}
.footer_container {
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
}

.footer_our_sevice {
    border-bottom: unset;
    padding-right: 0;
    padding-left: 0;
    padding-bottom: 0;
    order: 3;
    border-right: 1px solid #464646;
    padding-top: 25px;
    padding-right: 25px;
}

.footer_left {
    border-bottom: 1px solid #464646;
    order: 1;
    padding-bottom: 25px;
    padding-right: 25px;
}

.footer_quick_links, .footer_contacts {
    padding-top: 25px;
}

.footer_contacts {
    padding-left: 25px;
    order: 2;
    border-bottom: 1px solid #464646;
}

.footer_quick_links {
    order: 4;
    padding-right: 0;
    border-right: none;
    padding-left: 25px;
}


.ready_container {
    flex-direction: column;gap:15px;
}

.ready_container > * {
    width: 100%;
}

.call_use_descr span {
    font-size: 18px;
}

.call_use_descr p {
    font-size: 24px;
}

.steps_container {
    grid-template-columns: repeat(2, 1fr);
    gap: 70px 20px;
}

.steps_container:after {
    display: none;
}

.steps_cart:after {
    content: '';
    width: 100%;
    height: 10px;
}

.proudly_container {
    align-items: stretch;
}



.proudly_container {
    flex-direction: column;
}

.proudly_right {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    width: 100%;
}

.proudly_left {
    max-height: 453px;max-width: 100%;
}


.why_container {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
}
.more_plumbers_container {
    flex-direction: column;
}

.plumbers_right img {
    min-width: 100%;
}

.plumbers_right ul {
    grid-template-columns: repeat(1, 1fr);
    text-align: center;
}

.plumbers_right ul li {
    justify-content: center;
}

.more_plumbers ul li img {
    max-width: 28px;
}

.plumbers_right {
    order: -1;
}

.descr_podcart > p {padding-right:0;}
.learn_more img {
    width: 16px;
}
.our_expert_container {
    grid-template-columns: repeat(1, 1fr);
}
.learn_more {font-size: 14px;}
.our_expert > .container > p, .descr_podcart > span, .why > .container > p, .arr_reviews_container p, .proudly p, .steps > div > p, .faq > div > p, .ready > .container > p, .pricing > .container > p, .emergency > .container > p, .free_estimate > .container > p, .free_estimate > .container > p, .our > .container > p, .our > .container > p,.beats > .container > p, .brands > .container > p, .tabs_block > .container > p, .causes > .container > p, .right_img_block > .container > p, .slider_service > .container > p,.behind_descr p, .how_to > .container > p, .brands_water > .container > p, .behind.v2 > .container > p {font-size: 17px;}

.descr_podcart > p {font-size: 15px;}
h2,.process h2, .about_history .history_descr h2 {font-size: 36px;line-height: 44px;}
.banner_index_left h1 {        font-size: 36px;}

.banner_index_left {
    max-width: 640px;
    padding-bottom: 0;
    margin-bottom: -20px;
}

.banner_index_container {
    flex-direction: column;
    align-items: center;
}

.banner_index_right img {
    max-width: 345px;
}

.banner_index_right {}
.top_right_info a.mob_nav {display:block;}
nav.nav {
    display: none;
}


.top_info {
    display: none;
}

.top_m_container {
    justify-content: center;
    margin: 10px 0;
}

.top_right_info {
    margin-left: 35px;
}

  .navigation_menu {
    display: block;               /* есть в DOM на мобиле */
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    width: min(360px, 86vw);
    background: #fff;
    z-index: 9999;

    transform: translateX(100%);
    transition: transform .28s ease;
    /*box-shadow: -12px 0 30px rgba(0,0,0,.12);*/

    /* чтобы внутри скроллилось */
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* open states */
  .navigation_menu.is-open { transform: translateX(0); }

  .navigation_overlay.is-open {
    opacity: 1;
    pointer-events: auto;
  }

  /* basic layout */
  .nav__inner {padding: 25px;}
  .nav__top { padding-top: 10px; }
  .nav__logo img { max-width: 180px; height: auto; display: block; }

  /* close button */
  .nav__close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 44px;
    height: 44px;
    border: 0;
    background: transparent;
    cursor: pointer;
  }

  .nav__close-icon {
    position: relative;
    display: block;
    width: 20px;
    height: 20px;
    margin: 0 auto;
  }
  .nav__close-icon::before,
  .nav__close-icon::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 24px;
    height: 2px;
    background: #42515a;
    transform-origin: center;
  }
  .nav__close-icon::before { transform: translate(-50%, -50%) rotate(45deg); }
  .nav__close-icon::after  { transform: translate(-50%, -50%) rotate(-45deg); }

  /* menu list */
  .nav__list {
    list-style: none;
    padding: 18px 0 0;
    margin: 0;
  }
  .nav__item { margin: 0; }

  .nav__link {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    text-decoration: none;
    line-height: 1.2;
    background: transparent;
    border: 0;
    cursor: pointer;
    text-align: left;
    font-size: 16px;
    color: #42515a;
  }

  .nav__link.is-active { color: #ff5a2a; }

  /* Arrow */
  .nav__arrow {
    transition: transform .2s ease;
    position: relative;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
    transform: translateY(1px);
    opacity: 0.9;
    /* transition: transform 0.3s, -webkit-transform 0.3s; */
  }
  .nav__arrow::before {
    /* content: ""; */
    position: absolute;
    inset: 0;
    margin: auto;
    width: 8px;
    height: 8px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    color: #0d162b;
  }

  /* submenu */
  .nav__submenu {
    list-style: none;
    margin: 0;
    padding: 0 0 10px 0;
  }
  .nav__submenu-item { margin: 0; }

  .nav__sublink {
    display: block;
    padding: 10px 0 10px 14px;
    text-decoration: none;
    color: #42515a;
    font-size: 16px;
    line-height: 1.25;
  }

  /* open submenu state */
  .nav__item--has-submenu.is-sub-open > .nav__link--toggle .nav__arrow {
    transform: rotate(180deg);
  }

  /* actions */
  .nav__actions {
    padding-top: 18px;
    border-top: 1px solid rgba(0,0,0,.08);
    margin-top: 16px;
  }

  .nav__phone {
    display: inline-block;
    margin: 12px 0 16px;
    text-decoration: none;
    color: #ec582c;
    font-weight: 600;
    font-size: 18px;
  }

  .nav__button {
    display: block;
    text-align: center;
    border: 1px solid #0d162b;
    border-radius: 10px;
    text-decoration: none;
    font-size: 16px;
    width: 197px;
    height: 59px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    color: #0d162b;
  }

  /* optional: lock body scroll when menu open */
  body.is-menu-open { overflow: hidden; }
.limited_time_container {
    flex-direction: column;
    align-items: flex-start;
}

.limited_time > img {
    right: -50px;        top: 60px;        transform: rotate(-70deg);
}

.banner_service h1 {font-size: 36px;}


.banner_service_container {
    grid-auto-flow: row;
    grid-template-columns: repeat(1, 1fr);
}

.banner_service_img {}

.banner_service_img img {
    max-width: 100%;
    border-radius: 0px 0px 10px 10px;
}

.banner_service_left {
    padding-bottom: 0;
}
.banner_service_left {
    padding: 25px 15px 0 15px;
}

.btn_banner a:last-child {
    order: -1;
}
.elevate__img {
    display: none;
}

.elevate__container {
    max-width: 100%;
    padding: 40px 0;
}
.elevate__left span {font-size: 36px;}
.process__grid {
    grid-template-columns: repeat(3, 1fr);
}

.process__card img {
    max-width: 90px;
}

.blog_previews_text h1 {font-size: 36px;}

.blog_inner_nav {
    flex-direction: column;
}

.blog_btn_footer {
    background: /* левый цвет 70% */ linear-gradient(90deg, #fbaa3a 0 70%, transparent 70% 100%), /* затемнение только справа 30% */ linear-gradient(90deg, transparent 0 70%, rgba(0, 0, 0, .45) 70% 100%), /* картинка справа 30% */ url(/assets/images/tild3763-3933-4163-a661-633036323938__miami-bayside-landsc.jpg);
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-size: contain;
    background-position: left top, left top, right top;
    padding: 10px 0 0;
}
.img_btn_footer {
    display: none;
}

.blog_btn_footer {
    background: #fbaa3a;padding: 30px 0;
}

.descr_btn_footer {
    max-width: 100%;
}

.descr_btn_footer_container {
    text-align: center;
}

.need_btn {
    margin: 20px auto 0 auto;
}
.blog_nav {min-width:100%;}
.error_404 h1 {font-size: 125px;line-height: 125px;}



.about_container {
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.about_container .banner_index_left {
    margin: 0;
    max-width: 100%;
}

.about_container .bg_dark_blue ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

.about_img {
    margin: 30px 0 0;
}
.about {padding:50px 0 0;}

.about_history .history_container {
    grid-template-columns: repeat(1, 1fr);
    gap: 30px;
}

.about_history {
    padding: 80px 0;
}
.about_history .history_years .t_title {font-size: 22px;}
.about_history .history_years .timeline {
    padding: 40px 0 40px;
}
.about_history .history_years {        padding: 0;}
.why_call h2 {
    font-size: 28px;
}
.easy_container {
    grid-template-columns: repeat(1, 1fr);
}
.easy_z  {font-size: 18px;}
.easy_descr p, .easy_h  {font-size: 15px;}
.easy_descr_container {
    padding: 10px;
}
a.easy_phone  {font-size: 18px;}
.free_estimate_container .form_input {
    grid-template-columns: repeat(1, 1fr);
}

.why_call_container {
    grid-template-columns: repeat(2, 1fr);
    text-align: center;
}

.why_call_cart {
    align-items: center;
}
.why_call_cart a:last-child  {font-size: 18px;}

.cards__grid {
    grid-template-columns:1fr
}

.why_container.v2 .why_cart span {
    margin-bottom: 15px;
    margin-top: 0;
    display: block;
}

.why_container.v2 .why_cart p {
    font-size: 16px;
}

.why_container.v2 .why_cart img {
    max-width: 80px;
}

.why_container.v2 {
    gap: 25px;
}

.why_container.v2 .why_cart {
    gap: 20px;    align-items: flex-start;
}

.form_page_text > span  {font-size: 36px;color:#fff;}
.form_page_text p {color:#fff;}
.form_page {
    background: url(/assets/images/tild6262-3635-4836-b034-353262366439__close-up-of-a-hand-h.png) center right / cover no-repeat;
}

.form_page::after {content: "";position: absolute;inset: 0;background: rgba(0, 0, 0, 0.3);pointer-events: none;width: 100%;height: 100%;}

.form_page_text {
    margin: 0 auto;
    text-align: center;
    z-index: 2;
    position: relative;
}

.form_page .container {
    /* z-index: 2; */
    /* position: relative; */
}
.quote_price {
    font-size: 22px;
    padding: 20px;
}
.free_estimate > .container > a {font-size: 18px;}

.service_banner .banner_index_container {
    grid-template-columns: repeat(1, 1fr);
    gap: 0;
}

.service_banner .banner_service_right img {
    position: relative;
    border-radius: unset;
}

.service_banner .banner_index_left .bg_dark_blue {
    width: 100%;
    border-radius: unset;
}

.service_banner .banner_index_left {
    max-width: 100%;
    text-align: center;
}

.service_banner .banner_index_left .bg_white {
    padding: 20px 20px 0 20px;
}

.service_banner .banner_index_left .btn_banner {
    align-items: center;
}

.service_banner .banner_index_left .bg_dark_blue {
    padding: 20px;        text-align: left;
}

.service_banner .banner_service_right {
    margin-top: 20px;
    border-radius: 0 0 12px 12px;
            height: 365px;
}

.form_page.v2:before {
    background: rgba(0, 0, 0, 0.4);
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    width: 100%;
    height: 100%;
    z-index: 2;
}
.form_q a {color:#fff;line-height:normal;text-align:left;}
.leak_container {
    grid-template-columns: repeat(1, 1fr);
    gap: 40px;
}

.leak_left p {
    font-size: 16px;
}

.leak_right_container span {
    font-size: 24px;
    line-height: 34px;
}

.leak_right_container {
    /* align-items: center; */
    /* margin-top: 40px; */
    padding-top: 30px;
}

.leak_right_container div img {
    max-width: 70px;
}

.leak_img {
    left: 90px;
}

.lkrs {
}
.our_container {
    grid-template-columns: repeat(2, 1fr);
}

.our_img img {
    max-width: 100%;
    object-position: top;
}

.our_img {
    height: 250px;
}
.steps.v2 .steps_container {
    grid-template-columns: repeat(1, 1fr);
}/*
.steps.v2 .steps_cart:nth-child(3n)::after{
   display:none;
}
.steps.v2 .steps_cart:nth-child(4n)::after{
   display:block;
}*/


.steps.v2 .steps_cart:not(:last-child)::after {
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 100%;
    /* bottom: 0; */
    width: 6px;
    height: 30px;
    transform: unset;
}

.steps.v2 .steps_cart:nth-child(4n)::after{
   display:block;
}
.beats_adv {
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
}

.beats_adv_cart {
    border-right: none;
    border-bottom: 1px solid #d9d9d9;
    padding: 0 0 20px;
}

.beats_container > div:first-child, .beats_container > div:last-child {
    margin: 0 auto;
}

.block_images_container {
    flex-direction: column;
    gap: 30px;
    text-align: center;
}

.block_images_descr {
    order: -1;
}

.block_images_container img {
    max-width: 380px;
    width: 100%;
    min-width: auto;
}

.block_images_descr h2 {
    text-align: center;
}

ul.header_tabs {
    grid-template-columns: repeat(1, 1fr);
}

.header_tabs li {
    border-right: unset;
    border-bottom: 1px solid rgba(11, 21, 48, 0.14);
}

.tabs_cart {
    flex-direction: column;
}

.quote_price.v2 br {
    display: none;
}

.form_page.v3:after {
    background: rgba(0, 0, 0, 0.4);
}

.form_page.v4:after {
    background: rgba(0, 0, 0, 0.6);
}

.form_page.v5:after  {
    background: rgba(0, 0, 0, 0.6);
}
.form_page.v6:after  {
    background: rgba(0, 0, 0, 0.6);
}
.form_page.v7:after  {
    background: rgba(0, 0, 0, 0.6);
}
.form_page.v8:after  {
    background: rgba(0, 0, 0, 0.6);
}
.form_page.v3 {
    background: url(/assets/images/tild3531-3464-4036-b564-626239323234__image_14_1.png) center right / cover no-repeat;
    background-size: contain;
}
.form_page.v4 {     background: url(/assets/images/tild6437-3762-4139-a235-656238363435__image_18_1.png) center right / cover no-repeat;
    background-size: contain;}
    
.form_page.v5 {     background: url(/assets/images/clock_sink_50px.png) center right / cover no-repeat;
    background-size: contain;}
.form_page.v6 {     background: url(/assets/images/tild3762-3437-4366-b562-313164323361__image_23.png) center right / cover no-repeat;
    background-size: contain;}
.form_page.v7 {     background: url(/assets/images/tild3637-6633-4439-a633-653033656439__shutterstock_2003389.jpg) center right / cover no-repeat;
    background-size: cover;} 
.form_page.v8 {     background: url(/assets/images/tild3931-3038-4638-a638-613737626630__d1f06ff9cc3790b05dee.jpg) center right / cover no-repeat;
    background-size: cover;} 
.our_call.bold a {
    font-size: 18px;
}

.our_call a, .our_call p {
    font-size: 18px;
}
.causes_container {
    grid-template-columns: repeat(1, 1fr);
}

.right_img_block_container {
    flex-direction: column;
    gap: 30px;
}

.two_tabs_cart {
    grid-template-columns: repeat(1, 1fr);
}

.left_right_text p, .left_right_text ul li {font-size:16px;}
.tabs_block_container.v2 .header_tabs {
    grid-template-columns: repeat(1, 1fr);
}

.behind_container, .behind_adv {
    grid-template-columns: repeat(1, 1fr);
}

.behind_img {
    width: 100%;
}

.behind_container {
    /* gap: 90px; */
}

.behind_adv {
    gap: 90px;
}



.arr_service_prev {
    margin-left: 5px;
}

.arr_service_next {
    margin-right: 5px;
}

.slider_service_container {
    margin: 30px 30px 0 30px;
}

.how_to_container {
    grid-template-columns: repeat(2, 1fr);
}
.form_page.v5 .form_page_text > a {width:100%;    min-width: auto;white-space: normal;}
.form_page_text > a{white-space: normal;}




.choosing_row {grid-template-columns: repeat(2, 1fr);align-items: flex-start;/* justify-content: center; *//* justify-items: center; */gap: 30px 40px;}

.lifespan::before {
    content: "Lifespan";
}.td.material::before {
    content: "Material";
}

.td.proscons::before {
    content: "Pros & Cons";
}

.bestfor::before {
    content: "Best For";
}


.choosing_row .td:before {
    color: #ec582c;
    font-size: 18px;
    font-weight: 600;
    display: block;
    margin-bottom: 10px;
}

.pc_item, .lifespan_val, .bestfor_text, .material_name {
    font-size: 16px;
}

.choosing_row .td:not(:last-of-type) {
    /* margin-bottom: 20px; */
}

.material_img {
    width: 120px;
    height: 115px;
}

.choosing_head {
    display: none;
}

.choosing_row {
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
}

.choosing_row.is-green {}

.tabs_cart_img {
    flex-direction: column;padding:0;
}

.tc_descr {
    order: -1;
}

.tc_img img {
    max-width: 450px;
    width: 100%;
}

.td{ padding:0; }
.behind.v2 .behind_adv {
    grid-template-columns: repeat(1, 1fr);
}

.tcrt1 {
    flex-direction: column;
    /* text-align: center; */
}

.tabs_block.off-white .tabs_block_container.v2 .tabs_cart_descr span {
    font-size: 17px;
}

.tabs_block.off-white .tabs_block_container.v2 .tabs_cart_descr p {
    font-size: 15px;
}

.tabs_block.off-white .tabs_block_container.v2 .tabs_cart {
    text-align: center;
}
.protect_container {
    flex-direction: column;
    text-align: center;
    gap: 90px;
}

.protect_container h2 {
    text-align: center;
}
/*959*/

}

@media (max-width: 690px) {
.ready_container input[type="text"], .ready_container input[type="tel"], .ready_container textarea {
    width: 100%;
}
.limited_time_container {
    align-items: center;
    text-align: center;
}

.limited_time_left span {
    font-size: 34px;
}

.steps_container {
    grid-template-columns: repeat(1, 1fr);
}
.limited_time > img {display:none;}

.steps_container:before {
    position: absolute;
    top: 0;
    content: '';
    width: 6px;
    height: 100%;
    background: #ec582c;
    left: 0;
    right: 0;
    margin: 0 auto;
}
.banner_index_right {
    height: 275px;
    width: 275px;
}

.banner_index_right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
}
.btn_banner {
    flex-direction: column;
    align-items: center;
}
.process__grid {
    grid-template-columns: repeat(2, 1fr);
}

.choosing_row {
    grid-template-columns: repeat(1, 1fr);
    gap: 20px;
}
.tabs_block_container.v3 .header_tabs {
    grid-template-columns: repeat(1, 1fr);
}
}

@media (max-width: 639px) {
.article_name, .need p {        font-size: 16px;}
.need h2 {font-size: 30px;}
.date_blog {font-size:10px;}
.blog h1, .text h1 {font-size:30px;}
.up_btn {
    transform: scale(.8);
}
.process__grid {
    grid-template-columns: repeat(1, 1fr);
}
.footer_container {
    grid-template-columns: repeat(1, 1fr);
}

.footer_left {
    padding-right: 0;
    border-right: none;
}

.footer_contacts {
    padding-left: 0;
    padding-bottom: 25px;
}

.footer_our_sevice {
    border-right: none;
    border-bottom: 1px solid #464646;
    padding-bottom: 25px;
    padding-right: 0;
}

.footer_quick_links {
    padding-left: 0;
}

.reviews_cart_descr span {
    font-size: 22px;
}

.reviews_cart > p {
    font-size: 16px;
}

.reviews_cart {
    padding: 20px;
}

.why_cart span {        font-size: 24px;}
.why_cart p {font-size: 15px;}
.our_expert > .container > p, .why > .container > p, .more_plumbers p, .more_plumbers ul li, .proudly p, .steps > div > p, .faq > div > p, .ready > .container > p,.pricing > .container > p, .emergency > .container > p, .free_estimate > .container > p, .free_estimate > .container > p, .our > .container > p,.beats > .container > p, .brands > .container > p, .tabs_block > .container > p, .causes > .container > p, .right_img_block > .container > p, .slider_service > .container > p,.behind_descr p, .how_to > .container > p, .choosing > .container > p {font-size: 17px;}
 
.learn_more {font-size: 12px;}
h2,.process h2, .about_history .history_descr h2 {font-size: 30px;}
.bg_white {
    text-align: center;
}
.banner_index_container {padding:20px 0 0;}
.bg_dark_blue {
    padding: 20px;
    font-size: 15px;
}

.bg_dark_blue ul li img {
    max-width: 26px;
}
.banner_index_left h1 {        font-size: 34px;line-height:33px;}
.top_right_info a.btn2 {display:none;}

.banner_service h1 {font-size: 30px;}

.banner_service_left ul li {font-size: 16px;}

.elevate__left span {font-size: 34px;}
.elevate__left p {font-size: 17px;}
.blog_container {
        grid-template-columns: repeat(1, 1fr);
}
.blog_previews_text h1 {font-size: 30px;}
.blog_previews_text p {        font-size: 16px;}
.blog_nav ul li a {font-size: 16px;}
.descr_btn_footer p  {font-size: 17px;}
.descr_btn_footer .need_z {font-size: 34px;}
.error_404 h1 {font-size: 111px;line-height: 111px;}

.about_container .bg_dark_blue ul {
    grid-template-columns: repeat(1, 1fr);
}

.about_history .history_years .t_year {font-size:20px;}

.why_call h2 {
    font-size: 26px;
}

.why_call_container {
    grid-template-columns: repeat(1, 1fr);
    text-align: left;
}

.why_call_cart {
    flex-direction: row;
    align-items: center;
    /* justify-content: center; */
    gap: 15px;
}

.why_call_cart a:first-child {
    margin: 0;
}
.why_call_cart a:first-child {min-width:78px;}

  .emergency-pricing__th,
  .emergency-pricing__td {
    padding: 14px 14px;
    font-size: 14px;
  }

  .emergency-pricing__table {
    min-width: 640px;
  }
  
.form_page_text > span  {font-size: 34px;}
.form_page_text p  {font-size: 17px;}
.free_estimate > .container > a {font-size: 16px;}
.our_container {
    grid-template-columns: repeat(1, 1fr);gap:20px;
}

.our_img {
    height: 220px;
}
.brand-grid {
flex-wrap: wrap;
}
.brand-item {
flex-basis: 100%; /* Один элемент в строке */
display: flex;
flex-direction: column;
align-items: center;
}
.tooltip {
color: #0D162B;
position: static;
display: block;
transform: none;
border: none;
box-shadow: none;
margin-top: 10px;
}



.protect_left p {
    font-size: 16px;
}

.protect_descr span {
    font-size: 20px;
}

.protect_descr p {
    font-size: 15px;
}

.protect_cart {
    padding: 20px;
}
/*639*/
}

@media (max-width: 479px) {
.need_btn_text {font-size: 14px;line-height: 23px;}
.need h2 {line-height: 38px !important;        font-size: 28px;}
.need p {font-size:15px;}
.blog h1, .text h1 {font-size:28px;    line-height: 38px;}
.footer_info {
    padding: 20px 0;
}
.footer_info p, .footer_info p a {font-size:15px;}
.footer_left > p {
    opacity: .8;
    font-size: 14px;
}

.footer_container > div > span {
    font-size: 16px;
}

.footer_left > p {}

.footer_contacts {
    font-size: 16px;
}

.call_use img {max-width:45px;}
.faq__q {        font-size: 20px;}
.call_use_descr span {font-size:16px;}
    .call_use_descr p {
        font-size: 22px;
    }
.faq__answer {margin-top:15px;}
.faq__item {padding: 20px;border-radius: 20px;}

.faq__icon {
    min-width: 35px;
    height: 35px;
}

.faq__btn {
    gap: 10px;
    padding: 0;
}



.faq__answer {
    padding: 0;
    font-size: 15px;
}
.limited_time_left span {
    font-size: 28px;
    line-height: 31px;
}

.limited_time_left p {
    font-size: 16px;
}


.proudly_right {
    grid-template-columns: repeat(1, 1fr);
}

.proudly_right a span {
    font-size: 16px;
}

.proudly_right a img:first-child {
    width: 36px;
    height: 36px;
}

.proudly_right a img:last-child {
    width: 20px;
    height: 20px;
}

.proudly_right a {
    padding: 10px 15px;
}
.arr_reviews_container {
    flex-direction: column;
    align-items: center;
    /* text-align: center; */
    gap: 15px;
    margin-bottom: 30px;
}

.arr_rev_prev, .arr_rev_next {
    width: 40px;
    height: 40px;
}

.arr_rev {
    gap: 15px;
}

.podcart_cart > img {
    max-width: 75px;
}
.descr_podcart > p {font-size: 14px;}
.header_cart {font-size:18px;}
.descr_podcart > span {font-size:16px;}
h2,.process h2, .about_history .history_descr h2 {font-size: 28px;line-height: 38px !important;}
.banner_index_left h1 {        font-size: 30px;}
.top_right_info a.btn1, .top_right_info a.btn2 {
    width: 171px;
    height: 42px;
}

a.mob_nav {
    height: 42px;
}

a.mob_nav img {
    width: 42px;
}

a.top_logo img {
    max-width: 140px;
}

.top_right_info {
    margin-left: 15px;
}
.our_expert, .why, .reviews, .more_plumbers, .proudly, .steps, .faq, .ready, .intro_service, .text_service, .process, .people, .easy, .emergency, .repairs, .pricing, .free_estimate.v2,.leak,.our,.beats, .block_images, .tabs_block, .brands, .block_images, .causes, .right_img_block,.behind,.slider_service,.how_to,.choosing,.brands_water, .protect {
    padding: 50px 0;
}
.free_estimate {
    padding: 50px 0 30px 0;
}
.leak {
    padding-bottom:: 105px;
}
.why_call {
    padding: 0 0 50px 0;
}
.easy {padding-top:90px;}
.blog, .text {    padding-bottom: 70px;}
.steps_cart img {
    max-width: 120px;
}

.steps_cart span {
    font-size: 16px;
    margin-top: 10px;
}

.steps_cart p {
    font-size: 20px;
    margin: 10px 0;
}

.steps_cart div {
    font-size: 15px;
}
.call_use, .ready_container form.request-form-rev {
    padding: 15px;
}

.banner_service h1 {        font-size: 28px;    line-height: 31px;}
.banner_service_left ul li {font-size: 15px;}
.btn_banner a {width:100%;font-size:15px;padding:0 10px;}
.btn_banner a {
    text-align: center;
}
.btn_banner a br {display:block;}
.elevate__left span {font-size: 28px;}
.elevate__left p {font-size: 16px;}

.elevate__center {
    width: 100%;
}

.elevate__container {
    text-align: center;
    gap: 20px;
}

.elevate__left span {
    line-height: 31px;
}
.need {padding:40px 0;}

.blog_previews_text h1 {line-height: 38px;font-size: 28px;}
.full_img_blog {
    height: 200px;
}
.blog_nav {
    padding: 15px;
}
.descr_btn_footer .need_z {font-size: 28px;line-height:31px;}
.descr_btn_footer p  {font-size: 16px;}
.error_404 h1 {font-size: 100px;line-height: 100px;}
.error_404_container p {font-size: 18px;}
.error_404 .container {
    padding: 30px 20px;
}
.err_home a {
    width: 100%;
}
.about_history .history_descr p {font-size: 15px;}
    .about_history .history_years .t_title {
        font-size: 17px;
        line-height: 25px;
    }
.about_history .history_years .t_year {font-size:17px;}
.about_history .history_years .timeline {
    --year-col: 70px;
    }

.people_container {
    grid-template-columns: repeat(1, 1fr);gap:25px;
}
.why_call h2 {
    font-size: 28px;
}
.header_easy {
    font-size: 18px;
}

.easy_descr_container > div {
    flex-direction: column;
    text-align: center;
    align-items: center;
}

.phone_easy {
    width: 78px;
}

a.easy_link {
    justify-content: center;
}
.free_estimate_container input[type="submit"] {width:100%;        box-sizing: border-box;        font-size: 13px;}
.free_estimate_container form {
    padding: 10px;
}



.why_container.v2 .why_cart {
    flex-direction: column;
    align-items: center;
    gap: 15px;        text-align: center;
}

.why_container.v2 .why_cart img {
    max-width: 70px;
}

.why_container.v2 {
    margin-top: 40px;
}
.why_container.v2 .why_cart span {
    font-size: 23px;
}
    .why_container.v2 .why_cart p {
        font-size: 15px;
    }
    .repairs_cart p {font-size: 16px;}
    
.repairs_cart img {
    min-width: 34px;
    width: 34px;
}

.repairs_cart {
    padding: 15px;
}
.form_page_text > span  {font-size: 28px;    line-height: 31px;}
.form_page_text p  {font-size: 16px;line-height: normal;}
.form_page_text > a br {
    display: block;
}

.form_page_text > a {
    padding: 15px;
}
.quote_price {
    font-size: 18px;
    padding: 15px;
}
.free_estimate_container.v2 input[type="submit"] {
    font-size: 15px;
}
.service_banner .banner_index_left .bg_dark_blue ul {grid-template-columns: repeat(1, 1fr);}
.service_banner .banner_service_right {
    height: 225px;
}
.faq.v2 .faq_container {
    padding: 0;
}
.qu {font-size:15px;}
.our_call a, .our_call p {font-size:16px;}


.leak_right_container span {
    font-size: 20px;
    line-height: 29px;
    text-align: left;
}

.leak_right_container div img {
    max-width: 50px;
}

.leak_img img {
    width: 53px;
}

.leak_img:before {
    width: 16px;
    left: 19px;
    top: 20px;
}

.leak_right_container div {
    gap: 70px;
}

.leak_img {
    left: 58px;
}

.leak_right_container div:not(:last-child) {margin-bottom: 15px;}

.leak_container {
    text-align: center;
    gap: 20px;
}

.lkrs {
    display: flex;
}

.leak_right {
    display: flex;
    justify-content: center;
}

.leak_left p:not(:last-child) {
    margin-bottom: 15px;
}

.leak_left p {
    font-size: 15px;
}
.leak_left h2 {
    text-align: center;
}

.beats_container > div span {
    font-size: 16px;
}

.beats_adv {
    margin-top: 25px;
}
.beats_adv_cart span {margin:15px 0;}

.block_images_descr p {font-size: 16px;}
.block_images_descr p:not(:last-child) {margin-bottom:15px;}
.tabs_cart > img {
    max-width: 100px;
}

.tabs_cart_descr p {
    font-size: 15px;
}

.tabs_cart .btn2 {
    width: 100%;
    font-size: 15px;
    box-sizing: border-box;
}

ul.header_tabs {
    margin-bottom: 10px;
}
.quote_price {
    line-height: 28px;
}
.our_call.bold a {font-size:16px;}
.our_call.bold {
    margin-top: 10px;
}

.full_tabs_cart {
    flex-direction: column;
    text-align: center;
}

.full_tabs_cart img {
    max-width: 100px;
}

.tabs_block_container.v2 .tabs_cart_descr span {
    font-size: 17px;
    margin-bottom: 10px;
}

.full_tabs_cart .tabs_cart_descr p, .bottom_tabs_cart {
    font-size: 15px;
}

.causes_descr span {
    font-size: 18px;
    margin-bottom: 10px;
}

.causes_descr p, .causes_bottom p {
    font-size: 15px;
}

.causes_top {
    flex-direction: column;
}

.causes_top img {
    max-width: 100px;
}

.causes_cart {
    text-align: center;
}

.arr_service_prev, .arr_service_next {
    width: 30px;
    height: 30px;
}

.arr_service {
    top: unset;
    bottom: 30%;
    transform: none;
}

.arr_service_prev, .arr_service_next {
    width: 30px;
    height: 30px;
}

.arr_service {
    top: unset;
    bottom: 30%;
    transform: none;
}

.slider_desc span {
    font-size: 24px;
}

.slider_desc p {
    font-size: 16px;
}
.behind_adv_cart img {
    max-width: 120px;
    margin-top: -60px;
}

.behind_adv_cart span {
    font-size: 20px;
    margin: 10px 0;
}

.behind_adv_cart p {
    font-size: 15px;
}

.behind_adv {
    gap: 80px;
}

.behind_descr {
    text-align: center;
}

.behind h2 {
    text-align: center;
}
.how_to_container {
    grid-template-columns: repeat(1, 1fr);
}

.tc_descr span {
    font-size: 17px;
    line-height: 25px;
}

.tc_descr p {
    font-size: 15px;
}

.tc_descr p {
    line-height: 20px;
}

.header_tabs li {
    font-weight: 600;
    line-height: 20px;
}
.tabs_block_container.v3 .tabs_cart {
    padding: 20px;
    text-align: CENTER;
}
/*479*/
}

@media (max-width: 380px) {
.btn_need a {font-size: 14px;max-width: 100%;min-width: auto;padding: 0 10px;width: 100%;}

.btn_need {
    gap: 10px;
}
.btn_banner a {
    font-size: 14px;
    padding: 10px;
}

.banner_service_left {
    padding: 25px 10px 0 10px;
}
.podcart_cart > img {
    max-width: 75px;
}

.bottom_cart {
    padding: 10px;
}

.bottom_cart a {
    padding: 10px;
    margin-bottom: 10px;
}



.top_right_info a.btn1, .top_right_info a.btn2 {
    width: 127px;
    height: 36px;
    font-size: 13px;
}

a.mob_nav {
    height: 36px;
}

a.mob_nav img {
    width: 36px;
}

.top_right_info {
    margin-left: 10px;
}

.top_right_info {
    gap: 10px;
}

header .container {
    padding: 0 10px;
}

.banner_service_img {
    height: 240px;
}

.banner_service_img img {
    object-position: left;
}

.banner_service {
    padding: 30px 0;
}

.banner_service h1 {
    text-align: center;
}
.intro_service p {
    font-size: 16px;
}
.elevate__center a {width:100%;}
.elevate__center {
    width: 100%;
}
}

