* {margin: 0px; padding: 0px; box-sizing: border-box; outline: none; -webkit-locale: auto}

html, body {width: 100%}
body {font-family: 'Onest', sans-serif; color: #4F4F4F; line-height: 1; font-size: 15px; -webkit-text-size-adjust: none; font-weight: 400; -webkit-font-smoothing: antialiased}
.max {margin: 0px auto; max-width: 1680px; padding: 0 120px}
a {color: inherit; text-decoration: none; outline: none; cursor: pointer; transition: 250ms}
h1, h2, h3 {color: #000; font-weight: 500}
h1, .h1-like {font-size: 42px; text-align: center; margin-bottom: 20px}
h2 {line-height: 1.3; font-size: 32px; text-align: center}
b, strong, th {font-weight: 700}
i {font-style: normal}
ul {list-style-type: none}
img {object-fit: contain}
img, svg {height: auto; max-height: 100%; max-width: 100%; display: block}
iframe {width: 100%; border: none; display: block}
.phone-svg svg{fill: none;}
input, select, textarea, button {-webkit-appearance: none; -moz-appearance: none; font-family: inherit; font-size: inherit; color: inherit; border-radius: 0px}
input[type=text], input[type=tel], input[type=email], input[type=password], input[type=search] {display: block; width: 100%; font-size: 15px; border: 3px solid transparent; padding: 0px 20px; background: #ebebeb; line-height: 46px; height: 50px; border-radius: 5px; font-weight: 500; transition: 250ms}
textarea {display: block; width: 100%; border:2px solid transparent; padding: 25px; resize: none; height: 100px; font-size: 15px; background: #ebebeb; border-radius: 5px; font-weight: 500; transition: 250ms}
input[type=text]:focus, input[type=tel]:focus, input[type=email]:focus, textarea:focus, input[type=password]:focus, input[type=search]:focus {border-color: #A1AA27}
input[type=checkbox] {display: inline-block; vertical-align: middle; width: 16px !important; height: 16px; margin-right: 10px !important; position: relative; border:none; border: 1px solid #dadada; background: #fff}
input[type=checkbox]:hover {border-color: #E73633}
input[type=checkbox]:checked {background: url("data:image/svg+xml,<svg viewBox='0 0 356.7 297.3' xmlns='http://www.w3.org/2000/svg'><polygon points='42.4,153 0,195.4 101.9,297.3 356.7,42.4 314.3,0 101.9,212.4'/></svg>") 50% 50% no-repeat; background-size: 9px; border-color: #E73633}
input[type=radio] {display: inline-block; vertical-align: middle; width: 16px !important; height: 16px; margin-right: 10px !important; position: relative; border-radius: 50%; margin-left: 4px; border:none; border: 1px solid #dadada; background: #fff}
input[type=radio]:hover {border-color: #FF3D00}
input[type=radio]:checked {background: #fff; border: 4px solid #FF3D00}
select, .form-list .SumoSelect>.CaptionCont {display: block; width: 100%; font-size: 15px; font-weight: 500; border: none; border: 2px solid transparent; padding: 0px 25px; background: #ebebeb url("data:image/svg+xml,<svg viewBox='11.4 7.1' width='11.4' height='7.1' xmlns='http://www.w3.org/2000/svg'><path d='M5,6.4l-5-5L1.4,0l4.3,4.3L10,0l1.4,1.4l-5,5L5.7,7.1L5,6.4z'/></svg>") no-repeat; background-position: right 25px center; border-radius: 5px; line-height: 46px; height: 50px !important; color: #7f7f7f; box-shadow: none !important; cursor: pointer; transition: border-color 250ms}
select:hover, .form-list .SumoSelect>.CaptionCont:hover {border-color: #E73633}
input[readonly], input[readonly]:focus {opacity: 0.5; border-color: #b3b3b3}
input.check:focus:invalid {border-bottom-color: #f10d48}
svg {fill: currentColor}
svg * {transition: fill 250ms}
::placeholder {color:#BEC0C2}
header .wrapper{display: flex;align-items: center;gap: 20px;}
/* GLOBAL *//* BASIC */.hidden {display: none}
.lazy {visibility: hidden; opacity: 0; transition: 250ms}
.ds {-webkit-user-select: none; -moz-user-select: none; -webkit-user-drag: none; -webkit-touch-callout: none}
.flex {display: flex; flex-wrap: wrap}
.flex.center {justify-content: center}
.flex.column {flex-direction: column}
.flex.align-center {align-items: center}
.flex.end {justify-content: end}
.flex.space-between {justify-content: space-between}
.flex.nowrap {flex-wrap: nowrap}
.cover {background-position: 50% 50%; background-repeat: no-repeat; background-size: cover}
.contain-0 {background-position: 0% 50%; background-repeat: no-repeat; background-size: contain}
.contain-50 {background-position: 50% 50%; background-repeat: no-repeat; background-size: contain}
.mobile-show {display: none}
.tablet-show {display: none}
.button {background: #FDBC00; height: 50px; border-radius: 25px; transition: 250ms; padding: 0 25px; color: #000}
.button:hover {box-shadow: -5px 5px 10px rgba(0,0,0,0.1); cursor: pointer}
.show-all-link{background: #FDBC00; height: 50px; border-radius: 25px; transition: 250ms; padding: 0 25px; color: #000;text-align: center;display: flex;align-items: center;justify-content: center;gap: 10px;margin-top: 30px;}
.show-all-link svg{max-width: 20px;max-height: 20px;}
.top-line {background: #000; height: 40px}
.logo img {height: 40px}
.logo .desc {text-transform: uppercase; font-size: 14px; letter-spacing: 5px; margin-top: 10px; text-align: center}
header {background: #fff; box-shadow: 0 0 10px rgba(0,0,0,0.1); position: sticky; position: -webkit-sticky; top: 0; z-index: 1000; height: 80px}
header .max {height: 100%}
header .menu {font-weight: 500; color: #000; gap: 20px}
header .menu li a {padding: 10px 0; display: block}
header .menu li:hover > a {color: #d3202a}
header .menu li {position: relative}
header .sub-menu {position: absolute; top: 100%; left: -20px; background: #fff; box-shadow: 0 0 10px rgba(0,0,0,0.1); padding: 20px; transform: scaleY(0); transform-origin: 0 0; width: 300px; border-radius: 5px; transition: 250ms}
header .menu li:hover .sub-menu {transform: scaleY(1)}
header .contacts .phone {margin-left: 10px}
header .contacts {font-size: 16px; gap: 5px}
header .social {width: 40px; height: 40px; background: #f3f4f5; border-radius: 3px}
header .social svg {width: 25px; height: 25px}
.home-slider .swiper-slide {overflow: hidden; aspect-ratio: 4/1}
.home-slider .max {height: 100%}
.home-slider .inner {height: 100%; padding: 0 40px; background: rgba(0,0,0,0.5); color: #fff; backdrop-filter: blur(20px); width: 50%; z-index: 1; align-items: start}
.home-slider .title {font-size: 42px; font-weight: 500}
.home-slider .sub-title {font-size: 18px; margin: 20px 0 40px 0}
.home-slider img {height: 100%; width: 100%; object-fit: cover; position: absolute; z-index: -1; left: 0; top: 0}
.home-about {text-align: center; font-size: 18px; margin: 80px 0}
.home-about .grid {display: grid; max-width: 900px; margin: 40px auto 0 auto; grid-template-columns: repeat(4,1fr); gap: 20px}
.home-about .item {gap: 10px; font-size: 14px}
.home-about .item b {font-size: 18px; font-weight: 500; color: #000}

.home-services {margin: 80px 0; text-align: center}
.services .grid {display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 40px; margin-top: 40px}
.services .item img {border-radius: 10px; object-fit: cover; aspect-ratio: 16/9; background: #f3f4f5}
.services .item .title {font-size: 18px; font-weight: 500; color: #000; margin-top: 10px}

.home-brands {padding: 80px 0; background: #FDBC00}
.home-brands .grid {gap: 20px; margin-top: 40px}
.home-brands .item {width: 200px; aspect-ratio: 16/9;display: flex;align-items: center;justify-content: center}
.works .grid {grid-template-columns: repeat(3,1fr); gap: 40px; display: grid}
.works .item {border-radius: 10px; box-shadow: 0 0 10px rgba(0,0,0,0.1); font-size: 14px}
.works .item img {border-radius: 10px 10px 0 0; object-fit: cover; aspect-ratio: 16/9; background: #f3f4f5}
.works .item b {font-size: 18px; font-weight: 500; color: #000; margin-bottom: 20px; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; display: block}
.works .item .bottom-part {border-radius: 0 0 10px 10px; padding: 20px; background: #fff}
.works .item .text {display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; -webkit-line-clamp: 3; height: 3.9em}
.home-works {margin: 80px 0}
.home-works .grid {margin: 40px 0}

.home-news {padding: 80px 0; margin: 80px 0; background: #f3f4f5}
.home-news .grid {margin: 40px 0; display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 40px}
.news .item {border-radius: 10px; box-shadow: 0 0 10px rgba(0,0,0,0.1); font-size: 14px}
.news .item img {border-radius: 10px 10px 0 0; object-fit: cover; aspect-ratio: 16/9; background: #f3f4f5}
.news .item b {font-size: 18px; font-weight: 500; color: #000; margin-bottom: 20px; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; display: block}
.news .item .bottom-part {border-radius: 0 0 10px 10px; padding: 20px; background: #fff}
.news .item .text {display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; -webkit-line-clamp: 3; height: 3.9em}

/* SPOILER */
.spoiler {margin-top: 20px}
.spoiler-title {background: #f3f4f5; padding: 0 20px; height: 50px; font-weight: 500; position: relative; cursor: pointer; transition: background 250ms, color 250ms; border-radius: 25px}
.spoiler-title:after {content: ''; position: absolute; right: 30px; width: 2px; top: 20px; height: 10px; background: #000; transform: rotateZ(0); transition: 250ms; transform-origin: 50% 50%; border-radius: 1px}
.spoiler-title:before {content: ''; position: absolute; right: 30px; width: 2px; top: 20px; height: 10px; background: #000; transform: rotateZ(90deg); transition: 250ms; transform-origin: 50% 50%; border-radius: 1px}
.spoiler-content {padding: 20px; display: none}
.spoiler.active .spoiler-title {background: #FDBC00}
.spoiler.active .spoiler-title:after {transform: rotateZ(45deg)}
.spoiler.active .spoiler-title:before {transform: rotateZ(135deg)}
/* SPOILER */

/* FOOTER */
footer:before {content: ''; height: 40px; width: 100%; display: block; background: url(images/pattern.svg) repeat-x 0 0 /contain; transform: translateY(-100%)}
footer {background: #000; padding: 20px 0; margin-top: 80px}
footer .grid {grid-template-columns: repeat(4, auto); gap: 40px; display: grid}
footer b {font-weight: 400; display: block; margin-bottom: 40px; color: white; font-size: 18px}
footer .categories ul {column-count: 2; column-gap: 40px}
footer li{margin-bottom: 20px}
footer li a {opacity: 1; color: white}
footer .social {gap: 12px}
footer .social a {width: 40px; height: 40px; background: rgba(255, 255, 255, 0.1); border-radius: 3px}
footer .social svg {width: 25px; height: 25px}
footer .level-2 {display: none}
/* FOOTER */


.tags {margin-bottom: 40px; font-size: 13px}
.tags a {padding: 0 20px; margin: 0 5px 5px 0; background: #eaeef2; position: relative; line-height: 40px; height: 40px}
.tags a.active {background: #d3202a; color: #fff}
.search-block {position: relative; margin-bottom: 20px}
.search-block input{display: block; width: 100%; font-size: 15px; border: none; border-bottom: 1px solid rgba(0, 0, 0, 0.1); padding: 0px; background: transparent; border-radius: 0px; line-height: 44px; height: 45px}
.search-block button {position: absolute; padding: 15px; width: 50px; height: 50px; right: 0; top: -5px; color: #6F7F89; background: transparent; border: none; cursor: pointer}
.catalog .grid {grid-template-columns: repeat(4, minmax(0,1fr)); display: grid; grid-gap: 40px; margin-top: 40px}
.catalog .item {border-radius: 10px; box-shadow: 0 0 10px rgba(0,0,0,0.1); font-size: 14px}
.catalog .item img {border-radius: 10px 10px 0 0; object-fit: cover; aspect-ratio: 16/9; background: #f3f4f5}
.catalog .item b {font-size: 18px; font-weight: 500; color: #000;  text-overflow: ellipsis; overflow: hidden; white-space: nowrap; display: block}
.bottom-part{display: flex;flex-direction: column;gap: 20px;}
.catalog .item .bottom-part {border-radius: 0 0 10px 10px; padding: 20px; background: #fff}
.catalog .item .text {display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; -webkit-line-clamp: 3; height: 3.9em}
.catalog .item .price {line-height: 1; font-size: 16px; display: block; font-weight: 500; }
.catalog .item .addToCart {width: 100px; background: #d3202a; height: 32px; line-height: 32px; color: #fff; text-align: center; transition: 250ms; cursor: pointer; display: block}
.catalog .item .stickers {position: absolute; text-transform: lowercase; transform-origin: left top; left: 0; top: 20px; z-index: 2; display: flex; transform: rotateZ(-90deg) translateX(-100%); pointer-events: none}
.catalog .item .stickers span {position: relative; color: #fff; padding: 0px 10px; font-size: 12px; font-weight: 500; line-height: 1.7}
.catalog .item .stickers span.new {background: #feda19}
.catalog .item .stickers span + span {margin-left: 10px}
.catalog .item .stickers span.hit {background: #d3202a}


/* PAGER */
.pagination .screen-reader-text, .pagination .prev, .pagination .next {display: none}
.pagination {text-align: center; display: block; margin-bottom: 40px; width: 100%; grid-column: span 4}
.pagination a, .pagination span {margin: 0px 5px; width: 40px; font-size: 14px; text-align: center; color: #d3202a; line-height: 30px; height: 30px; background: transparent; display: inline-block; border-radius: 2px}
.pagination span.current {background: #d3202a; color: #fff}
/* PAGER */


/* BREAD-CRUMBS */
.bread-crumbs {margin: 40px 0; font-weight: 400; display: block; font-size: 13px; text-align: center; color: #6F7F89}
.bread-crumbs .separator {margin: 0 10px; opacity: 0.5}
.bread-crumbs a:hover, .bread-crumbs .breadcrumb_last {opacity: 1; color: #d3202a}
/* BREAD-CRUMBS */

.product-slider {display: flex; justify-content: center; gap: 20px; padding: 60px 0; flex-wrap: wrap}
.product-slider .item {width: 170px; height: 170px}
.product-slider .item img {width: 100%; height: 100%; object-fit: cover}
.white {background: #fff; padding: 40x; border-radius: 20px; }
.white h2:nth-of-type(1) {margin-top: 0; margin-bottom: 40px}
.single-catalog .price span {display: block}
b, strong, th {font-weight: 500}
.single-catalog .buttons {display: flex; justify-content: center; gap: 20px}
.single-catalog .button, .buttons button {background: #d3202a; margin-top: 40px; transition: 250ms; line-height: 50px; height: 50px; padding: 0px 15px; border: none; display: inline-block; cursor: pointer; vertical-align: top; text-align: center; white-space: nowrap; font-size: 16px; color: #fff; border-radius: 3px; width: 250px}
.single-catalog .buttons .TINKOFF_BTN_YELLOW {background: #ffdd2d; color: #283a4c; padding: 0}


/* TABS */
.tab-links {border-bottom: 1px solid #eaeef2; text-align: center; font-size: 15px; margin-bottom: 40px; margin-top: 40px}
.tab-links .tab-link {cursor: pointer; position: relative; display: inline-block; line-height: 40px; height: 40px}
.tab-links .tab-link.active, .tab-links .tab-link:hover {color: #000}
.tab-links .tab-link:before {content: ''; left: 0px; bottom: -1px; background: transparent; height: 2px; width: 100%; position: absolute}
.tab-links .tab-link.active:before {background: #000}
.tab-links .tab-link + .tab-link {margin-left: 30px}
.tab:not(.active) {display: none}
/* TABS */

.single-catalog .line .name {color: #6F7F89; white-space: nowrap; margin-right: 5px}
.single-catalog .line .separator {background: linear-gradient(90deg, #7f7f7f 0, #7f7f7f 25%, hsla(0, 0%, 100%, 0) 0, hsla(0, 0%, 100%, 0)); flex-grow: 1; background-position: 0 bottom; background-size: 4px 1px; background-repeat: repeat-x}
.single-catalog .line .value {text-align: right; margin-left: 5px; color: #6F7F89}
main .back-ring {margin: 80px auto; padding: 40px 80px; background: #f1f1f1; border-radius: 20px; /* box-shadow: 0 0 10px rgba(16, 20, 26, 0.3); */ width: 100%}
footer .belka {width: 30px;height: 14px; display: block}
main .back-ring h2 {color: #232323; margin-bottom: 40px}
main .back-ring .grid {grid-template-columns: repeat(2, 1fr); gap: 80px; display: grid}
.wpcf7 .hidden-fields-container {display: none}
.wpcf7-form-control-wrap {display: block; margin-top: 20px}
main .back-ring input[type=tel] {border-bottom: 1px solid #151618; height: 50px; line-height: 46px; padding: 0 10px; border-radius: 5px; color: #151618; font-size: 18px; background: transparent}
main .back-ring input::placeholder{color: #C1C2C9}
main .back-ring input[type=submit] {background: #fff; color: #d3202a; height: 50px; line-height: 50px; border-radius: 5px; border: none; -webkit-appearance: none; font-size: 14px; letter-spacing: 1px; font-weight: 500; text-transform: uppercase; cursor: pointer; background: #FDBC00; color: black; height: 50px; padding: 0 35px; /* width: fit-content; */ border-radius: 20px}
.wpcf7-spinner {visibility: hidden; display: inline-block; background-color: #23282d; opacity: 0.75; width: 24px; height: 24px; border: none; border-radius: 100%; padding: 0; margin: 0 24px; position: relative}
.wpcf7-spinner {position: absolute}
.back-ring .wpcf7-form-control-wrap {margin-top: 0}
.wpcf7-form-control-wrap {position: relative}
.back h1{line-height: 1.2;font-size: 26px;max-width: 840px;margin: 0 auto}
.single-catalog .line{line-height: 1.7}
.single-catalog .buttons button{margin-top: 0}
.single-catalog .buttons .button{margin-top: 0}
.menu-button{display: none}

/* CONTENT */
.content {line-height: 1.7}
.max .content{padding: 30px;border-radius: 30px;background: rgb(238, 238, 238);border: 2px solid #FDBC00;}
.max .content .content{padding: 0;border-radius: 0;background: none;border: none;}
.content ul + p, .content p + ul, .content p + p, .content ol + p, .content p + ol {margin-top: 15px}
/* CONTENT */

.archive-works .grid {display: grid; grid-template-columns: repeat(4, 1fr); grid-gap: 40px}
.archive-works .item .img {display: block; border-radius: 3px; height: 0; padding-bottom: 60%; position: relative; margin-bottom: 10px}
.cover {background-position: 50% 50%; background-repeat: no-repeat; background-size: cover}
.archive-works .item h3 {font-size: 14px; color: #d3202a}
.archive-works{padding: 80px 0;padding-bottom: 40px}
.archive-works h2{margin-bottom: 20px}
.archive-works .item:hover h3 {color: #d3202a}
.form-bottom{display: flex;align-items: center;gap: 30px}
main .back-ring{height: fit-content}
.no-mt footer{margin-top: 0 !important}

@media screen and (max-width: 1919px){
  .catalog .item .bottom-part{row-gap: 10px}
  .home-slider .title{font-size: 35px;}
}

@media screen and (max-width: 1199px){
  header .contacts .phone{display: none}
 .archive-works .grid{grid-template-columns: repeat(3, 1fr)}
 .form-picture{max-width: 300px;height: 100%}
}

@media screen and (max-width: 1023px) {
  header .menu li:hover .sub-menu{transform: none;display: none;}
header .menu.active li a{height: auto;padding: 0;}
  header .submenu-open .sub-menu{position: static;transform: none;}
  header .submenu-open .sub-menu li{margin-bottom: 10px;}
  .services .grid{grid-template-columns: repeat(3, minmax(0, 1fr));gap: 20px;}
  .services .item .title{font-size: 16px;}
  h1, .h1-like {
        font-size: 32px;
    }
      .home-slider .inner {
        padding: 30px 20px;
    }
        .home-slider .swiper-slide {
        aspect-ratio: 3 / 1;
    }
  .home-slider .title{font-size: 32px;}
  .menu-overlay { position: fixed;  top: 0;  left: 0;  width: 100vw;  height: 100vh;  /* background: rgba(0, 0, 0, 0.5); */  opacity: 0;  visibility: hidden;  transition: opacity 0.3s ease, visibility 0.3s ease;  z-index: 998;  pointer-events: none; }
 .menu-overlay.active { opacity: 1;  visibility: visible;  pointer-events: auto; }
 .menu { position: fixed;  top: -200%;  width: 100%; left: 0;  height: 100vh;  background: #fff;  flex-direction: column;  align-items: flex-start;  padding: 80px 20px 40px;  box-shadow: -5px 0 15px rgba(0,0,0,0.1);  overflow-y: auto;   z-index: 999; padding-top: 20px; padding-bottom: 20px; transition: 400ms; }
 .menu.active {  max-width: none; width: 100%; box-shadow: none; gap: 10px; top: 120px; z-index: 9999999; overflow-y: scroll;box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);height: 100%;background: white;}
 .menu-button.active svg{width: 20px; height: 20px; stroke: #333; stroke-width: 2.5; stroke-linecap: round; fill: none}
 .menu-close-button { display: none;  position: absolute;  top: 20px;  right: 20px;  width: 40px;  height: 40px;  z-index: 1001;   cursor: pointer; }
 header .menu.active li{width: 100%}
 header .menu.active li a{padding: 0; display: block; padding:0px; height: auto; border: none; font-size: 20px; display: flex; align-items: center; transition: background 250ms; border-radius: 3px;color: rgb(0, 0, 0);background: none; }
 .menu-close-button svg .line{fill: none; transition: stroke-dasharray 400ms, stroke-dashoffset 400ms; stroke: currentColor; stroke-width: 4; stroke-linecap: round; }
 .menu.active .menu-close-button { display: flex;  align-items: center;  justify-content: center;  background: #fff;  border-radius: 50%;  box-shadow: 0 2px 10px rgba(0,0,0,0.1); }
.menu.active .menu-close-button {display: flex; align-items: center; justify-content: center; background: #fff; border-radius: 50%; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); width: 40px; height: 40px; position: absolute; top: 20px; right: 20px; z-index: 1001; cursor: pointer}
.menu.active .menu-close-button svg {width: 20px; height: 20px; stroke: #333; stroke-width: 2.5; stroke-linecap: round; fill: none}
 body.locked { overflow: hidden;  height: 100vh;  position: fixed;  width: 100%; }
 .menu.active .menu-close-button svg .top {stroke-dashoffset: -64px}
.menu.active .menu-close-button svg .middle {transform: scale(0); opacity: 0}
.menu.active .menu-close-button svg .bottom {stroke-dashoffset: -64px}
/* === ВИДИМОСТЬ И СТИЛЬ КНОПКИ === */.menu.active .menu-close-button {display: flex; align-items: center; justify-content: center; background: #fff; border-radius: 50%; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1)}
 h2, .h2-like, .back h1 {font-size: 22px; }
 body {font-size: 14px; }
 .white {padding: 40px 20px; margin: 0 -20px 0 -20px; border-radius: 0; }
 .menu-button {width: 50px; height: 50px; display: flex; flex-direction: column; justify-content: center; align-items: center; cursor: pointer; z-index: 1002}
.menu-button__line {width: 30px; height: 3px; background: currentColor; border-radius: 2px; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); position: relative}
.menu-button__line--1 {transform: translateY(-8px); }
.menu-button__line--3 {transform: translateY(8px); }
/* === КРЕСТИК — ТОЛЬКО ЧЕРЕЗ .menu-button.active === */.menu-button.active .menu-button__line--1 {transform: translateY(-1px) rotate(45deg)}
.menu-button.active .menu-button__line--2 {opacity: 0; transform: scale(0)}
.menu-button.active .menu-button__line--3 {transform: translateY(-8px) rotate(-45deg)}
 .menu.active .menu-close-button{display: none}
 .catalog .grid{grid-template-columns: repeat(3, minmax(0,1fr))}
 .pagination{grid-column: span 3}
 .catalog .item .title {font-size: 14px; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; height: 36px; }
 .catalog .item .price {overflow: unset; margin-bottom: 5px; }
 .menu-button svg {width: 50px; }
 .menu-button svg {cursor: pointer; -webkit-tap-highlight-color: transparent; transition: transform 400ms; width: 50px}
.menu-button {display: flex; align-items: center; cursor: pointer; margin-left: 0px}
.menu-button svg .line {fill: none; transition: stroke-dasharray 400ms, stroke-dashoffset 400ms; stroke: currentColor; stroke-width: 4; stroke-linecap: round}
.menu-button svg .top {stroke-dasharray: 40 160}
.menu-button svg .middle {stroke-dasharray: 40 142; transform-origin: 50%; transition: transform 400ms}
.menu-button svg .bottom {stroke-dasharray: 40 85; transform-origin: 50%; transition: transform 400ms, stroke-dashoffset 400ms}
 }
 
@media screen and (max-width: 767px) {
	.logo .desc {font-size: 10px; letter-spacing: 0; margin-top: 5px}
    .services .grid{grid-template-columns: repeat(2, minmax(0, 1fr));gap: 20px;}
  .services .item .title{font-size: 14px;}
  .catalog .item b{font-size: 14px;}
  header .sub-menu{box-shadow: none;background: transparent;z-index: 2;}
  .home-news{padding: 60px 0;
    margin: 60px 0;}
  .show-all-link{height: 40px;}
      .button {
        height: 40px;
    }
  .tags a {
        padding: 0 10px;
        line-height: 30px;
        height: 30px;
    }
        .tags {
        margin-bottom: 20px;
    }
      .works .item b {
        font-size: 16px;
    }
   
      .works .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 20px;
    }
        .max {
        padding: 0px 20px;
    }
        .works .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 20px;
    }
  .home-services .item .title {
        font-size: 16px;
    }
        .home-brands .grid {
        flex-wrap: wrap;
        justify-content: center;
    }
        .home-brands .item {
        width: 40px;
    }
    .home-services{margin: 60px 0;}
        .home-brands {
        padding: 60px 0;
    }

        .home-works {
        margin: 60px 0;
    }

      .home-services .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 20px;
    }

      .home-about .item img {
        max-width: 60px;
        margin: 0 auto;
    }
      .home-about .grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        row-gap: 40px;
    }
      .home-about {
        margin: 60px 0;
    }
        .text {
        font-size: 16px;
    }
      h1, .h1-like {
        font-size: 28px;
    }
      .home-slider .max {
        padding: 0;
    }
      .home-slider .swiper-slide {
        aspect-ratio: 2 / 1;
    }
    .home-slider .sub-title{margin-bottom: 20px;}
        .home-slider .inner {
        width: 100%;
        backdrop-filter: blur(3px);
    }
    
   .home-slider .title{font-size: 24px;}
  .form-picture{display: none}
 main .back-ring .grid{gap: 20px}
 .works .item b{font-size: 16px}
 .archive-works{padding: 60px 0;padding-bottom: 0}
 .archive-works .grid {grid-template-columns: repeat(2, 1fr); grid-gap: 30px; }
 header .back-ring.button{display: none}
 .logo img{height: 25px}
 .catalog .grid, .home-news .grid {grid-template-columns: repeat(2, calc((100vw - 55px) / 2)); grid-column-gap: 15px; grid-row-gap: 30px; }
 .catalog .item .price {font-size: 14px; }
 .catalog .item .addToCart {width: 100%; }
 .catalog .item .title {font-size: 13px; display: block; overflow: unset; height: unset; margin: 5px 0px; }
 .catalog .item {display: flex; flex-direction: column; justify-content: space-between; height: 100%; }
 .pagination {grid-column: span 2; }
 .bread-crumbs{margin-top: 20px;margin-bottom: 20px}
 .single-catalog .line .name {white-space: unset; }
 .single-catalog .line {font-size: 11px; }
 .tab .h2-like {color: inherit; height: 40px; line-height: 40px; background: #eaeef2; padding: 0px 20px; margin: 0px -20px 15px -20px; width: calc(100% + 40px); }
 .tab {display: block !important; margin-top: 30px; }
 .single-catalog .line .value {min-width: 30px; }
 main .back-ring h2 {margin-bottom: 20px; }
 main .back-ring {padding: 40px 20px; margin: 40px 0; }
 main .back-ring .grid {grid-template-columns: 100%; }
 .single-catalog .buttons .button, .single-catalog .buttons button {width: 100%; margin-top: 0; }
 .single-catalog .buttons {flex-wrap: wrap; gap: 10px; }
 footer ul {display: none; padding-top: 20px; }
 .max {padding: 0px 20px; }
 .product-slider .item {width: calc(50vw - 30px); height: calc(50vw - 30px); }
 .single-catalog .buttons {flex-wrap: wrap; gap: 10px; }
 .tab .h2-like {color: inherit; height: 40px; line-height: 40px; background: #eaeef2; padding: 0px 20px; margin: 0px -20px 15px -20px; width: calc(100% + 40px); }
 .mobile-show {display: block; }
 h2, .h2-like {font-size: 16px; margin-bottom: 15px; }
 body, footer, input[type=text], input[type=tel], input[type=email], input[type=password], input[type=search], input[type=date], textarea {font-size: 13px; }
 footer b svg {transform: rotateZ(180deg); right: 0; width: 12.5px; height: 7.5px; position: absolute; top: 50%; margin-top: -3px; }
 footer .item + .item {border-top: 1px solid rgba(255, 255, 255, 0.1); padding-top: 20px; margin-top: 20px; }
 .mobile-hide {display: none !important; }
 footer .grid {grid-template-columns: 100%; gap: 0; }
 footer b {margin-bottom: 0; position: relative; font-size: 14px; }
 footer .max.grid{margin-bottom: 40px}
 footer{padding: 40px 0}
 .product-slider{padding-top: 60px !important}
}

@media screen and (max-width: 512px){
  header .social{width: auto;height: auto;border-radius: 0;background: none;}
  .home-slider .inner{align-items: center;}
  .home-slider .title{text-align: center;}
  .button{width: 100%;}
      .spoiler-title {
        padding-right: 50px;
    }
      .home-services .item .title {
        font-size: 14px;
    }
      .home-about .item b {
        font-size: 14px;
    }
     h1, .h1-like {
        font-size: 25px;
    }
  .home-slider .swiper-slide {
        aspect-ratio: 1 / 1;
    }
  .home-slider .title{font-size: 25px;}
 header .wrapper{gap: 10px;}
 .menu-button{width: 25px;height: 16px;}
 .archive-works .grid{grid-template-columns: 100%}
 .menu-button__line{width: 20px;height: 2px;}
 .menu-button__line--1 {
        transform: translateY(-4px);
    }
        .menu-button__line--3 {
        transform: translateY(4px);
    }
    .logo img{height: 20px;}
        .menu-button.active .menu-button__line--1 {
        transform: translateY(3px) rotate(45deg);
    }
        .menu-button.active .menu-button__line--3 {
        transform: translateY(-1px) rotate(-45deg);
    }
    header{height: 60px;}
    .menu.active{top: 100px;}

}
@media screen and (max-width: 412px) {
    .works .grid {
        grid-template-columns: 100%;
    }
}