@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
}
body {
  font-family: Montserrat;
}
body p {
  line-height: 1.5;
}
ol,
ul {
  padding-left: 1rem;
}
ol {
  list-style-type: none;
  counter-reset: num;
  margin: 0 0 0 60px;
  padding: 15px 0 5px 0;
  position: relative;
}
ol li {
  position: relative;
  margin: 0 0 0 0;
  padding: 0 0 10px 0;
}
ol li:before {
  content: counter(num);
  counter-increment: num;
  display: inline-block;
  position: absolute;
  top: 0;
  left: -45px;
  width: 28px;
  height: 28px;
  background: #ba122b;
  color: #ffffff;
  text-align: center;
  line-height: 28px;
  font-size: 18px;
  border-radius: 5px;
}
ul li::marker {
  color: #ba122b;
}
strong,
b {
  font-weight: 600;
}
h6,
h5,
h4,
h3,
h2,
h1 {
  font-weight: 400;
  color: #ba122b;
}
h1 {
  margin: 1.5rem 0 1rem 0;
}
h6,
h5,
h4,
h3,
h2 {
  margin: .5rem 0;
}
ul.menu li {
  list-style: none;
}
.typical-link,
.typical-link:hover {
  color: #ba122b;
  text-decoration: none;
  border-bottom: 1px #ba122b solid;
}
.icon {
  width: auto;
  height: 30px;
  color: inherit;
  display: inline-block;
}
.icon img {
  color: inherit;
  display: block;
  height: 100%;
  margin: 0 auto;
  width: 100%;
}
.icon-small {
  width: auto;
  height: 14px;
  color: inherit;
  display: inline-block;
}
.icon-small img {
  color: inherit;
  display: block;
  height: 100%;
  margin: 0 auto;
  width: 100%;
}
a,
a:hover {
  color: #ba122b;
  text-decoration: none;
  border-bottom: 1px #ba122b solid;
}
button.button,
a.button {
  text-align: center;
  background-color: #ffffff;
  color: #ba122b;
  padding: 10px 20px;
  display: inline-block;
  border: 2px #ba122b solid;
  margin-bottom: 10px;
  cursor: pointer;
  background-position: 0;
  background-size: 300% 100%;
  background-image: linear-gradient(to top,#A2FFA0,#22ff21);
  transition: all .4s ease-in-out;
}
button.button:hover,
a.button:hover {
  color: #ffffff;
  background-position: 100% 0;
  box-shadow: 0 4px 10px 0 #ba122b;
}
button.button.round,
a.button.round {
  border-radius: 50px;
}
.round {
  border-radius: 50px;
}
button.button.red,
a.button.red {
  color: #ffffff;
  background-position: 0;
  background-size: 300% 100%;
  background-image: linear-gradient(to right,#ba122b,#ba122b,#ffffff,#ffb8c4);
}
button.button.red:hover,
a.button.red:hover {
  color: #ba122b;
  background-position: 100% 0;
  box-shadow: 0 4px 10px 0 #ba122b;
}
.red-bg {
  color: #ffffff;
  background-position: 0;
  background-size: 300% 100%;
  background-image: linear-gradient(to right,#ba122b,#ba122b,#ffffff,#ffb8c4);
}
.red-bg:hover {
  color: #ba122b;
  background-position: 100% 0;
  box-shadow: 0 4px 10px 0 #ba122b;
}
.callback-form input {
  padding: 10px 20px;
  background-color: #ffffff;
  color: #ba122b;
  border: 2px #ba122b solid;
  margin: 0 10px 10px 0;
}
@media (max-width: 992px) {
  .callback-form input,
  .callback-form button {
    width: 100%;
  }
}
.callback-form p.note,
.callback-form+p.note {
  color: #ffffff;
  font-size: 0.8rem;
}
header {
  background: #ffffff;
  box-shadow: 0 5px 5px 0 rgba(0,0,0,0.3);
  position: relative;
  z-index: 2;
}
header .site-logo {
  display: flex;
  align-items: center;
}
header .site-logo a {
  border-bottom: none;
}
header .site-logo a img {
  margin: 12px 0;
}
@media (max-width: 992px) {
  header .site-navigation {
    display: flex;
    justify-content: space-between;
    width: 100%;
    height: 100%;
  }
}
header .contacts {
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: end;
  font-size: 18px;
  color: #ba122b;
}
@media (max-width: 992px) {
  header .contacts {
    height: auto;
    align-items: start;
    justify-content: center;
    flex-direction: column;
  }
}
@media (max-width: 576px) {
  header .contacts .location {
    display: none;
  }
}
header .contacts i {
  margin-left: 24px;
}
header .contacts a {
  font-size: 14px;
  color: #ba122b;
  text-decoration: none;
  margin-left: 10px;
  border-bottom: 1px #ba122b dashed;
}
header nav.menu-main {
  display: flex;
  justify-content: end;
}
header nav.menu-main a {
  border-bottom: none;
}
header nav.menu-main button.open-mobile-menu {
  background-color: #ffffff;
  border: none;
}
@media (max-width: 576px) {
  header nav.menu-main button.open-mobile-menu {
    font-size: 24px;
  }
}
header nav.menu-main ul.menu {
  margin: 0;
  padding: 0;
  position: relative;
  list-style: none;
  background-color: #ffffff;
}
@media (max-width: 992px) {
  header nav.menu-main ul.menu {
    display: none;
  }
}
header nav.menu-main ul.menu a:hover {
  color: #ba122b;
}
header nav.menu-main ul.menu a.active {
  color: #ba122b;
}
header nav.menu-main ul.menu li {
  display: inline-block;
  margin: 0 1em 0 1em;
}
header nav.menu-main ul.menu li a,
header nav.menu-main ul.menu li .nolink {
  color: #2b2a29;
  font-weight: 400;
  text-transform: none;
  text-decoration: none;
  line-height: 70px;
  display: block;
}
header nav.menu-main ul.menu li:hover > ul {
  display: flex;
  flex-direction: column;
}
header nav.menu-main ul.menu ul {
  display: none;
  position: absolute;
  top: 100%;
  box-shadow: 0 5px 5px 0 rgba(0,0,0,0.3);
  z-index: 999;
}
header nav.menu-main ul.menu ul li {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  z-index: 999;
  min-height: 55px;
  min-width: 200px;
  max-width: 280px;
  margin: 0 0 0 0;
  padding: 0 0.5em 0 0.5em;
  float: none;
  position: relative;
}
header nav.menu-main ul.menu ul li:hover {
  background-color: #ba122b;
}
header nav.menu-main ul.menu ul li:hover > a {
  color: #ffffff;
}
header nav.menu-main ul.menu ul li a {
  z-index: 999;
  line-height: 1.5;
  text-align: left;
  width: 100%;
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: space-between;
}
header nav.menu-main ul.menu ul ul {
  position: absolute;
  top: 0;
  left: 100%;
}
header nav.menu-main > ul.menu > li:last-of-type {
  margin: 0 0 0 1.5em;
}
header nav.menu-main > ul.menu > li:last-of-type ul {
  right: 0;
}
header nav.menu-main > ul.menu > li > a:after {
  font: normal normal normal 1rem "Font Awesome 6 Free";
  content: "\f107";
  margin-left: 5px;
}
header nav.menu-main > ul.menu > li > a:only-child:after {
  content: '';
  margin-left: 0;
}
header nav.menu-main > ul.menu > li ul.menu li a:after {
  font: normal normal normal 1rem "Font Awesome 6 Free";
  content: "\f0da";
  margin-left: 5px;
}
header nav.menu-main > ul.menu > li ul.menu li a:only-child:after {
  content: '';
}
.mobile-menu {
  width: 0;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 5;
}
.mobile-menu.opened {
  width: 100%;
  background: rgba(0,0,0,0.2);
}
.mobile-menu.opened .wrapper {
  transform: translateX(0%);
  box-shadow: 5px 0 5px 0 rgba(0,0,0,0.3);
}
.mobile-menu .wrapper {
  width: 100%;
  padding: 21px 32px 48px 32px;
  box-shadow: 0 0 0 0 rgba(0,0,0,0.3);
  max-width: 413px;
  height: 100%;
  overflow-y: auto;
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 20;
  transition: .3s;
  transform: translateX(-100%);
}
.mobile-menu .wrapper button.close {
  font-size: 35px;
  line-height: 1;
  color: #ba122b;
  background-color: #ffffff;
  border: none;
  position: absolute;
  top: 20px;
  right: 35px;
}
.mobile-menu .wrapper .title-menu {
  font-size: 35px;
  line-height: 1;
}
.mobile-menu .wrapper > ul.menu {
  padding-left: 0;
  margin-top: 24px;
}
.mobile-menu .wrapper ul.menu li {
  margin: 12px 0;
}
.mobile-menu .wrapper ul.menu li a {
  padding: 6px 0;
  color: #2b2a29;
}
.mobile-menu .wrapper ul.menu li a:hover,
.mobile-menu .wrapper ul.menu li a.active {
  padding: 6px 12px;
  border-radius: 5px;
  color: #ffffff;
  background-color: #ba122b;
}
.popup-form {
  width: 0;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 5;
}
.popup-form.opened {
  width: 100%;
  background: rgba(0,0,0,0.2);
}
.popup-form.opened .wrapper {
  transform: translateX(0%);
  box-shadow: 5px 0 5px 0 rgba(0,0,0,0.3);
}
.popup-form .wrapper {
  width: 100%;
  padding: 21px 32px 48px 32px;
  box-shadow: 0 0 0 0 rgba(0,0,0,0.3);
  max-width: 413px;
  height: 100%;
  overflow-y: auto;
  background: #fff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 20;
  transition: .3s;
  transform: translateX(-100%);
}
.popup-form .wrapper div.title {
  display: block;
  margin: 0 0 1.5rem 0;
}
.popup-form .wrapper label {
  display: block;
}
.popup-form .wrapper input {
  display: block;
}
.popup-form .wrapper button.close {
  font-size: 35px;
  line-height: 1;
  color: #ba122b;
  background-color: #ffffff;
  border: none;
  position: absolute;
  top: 20px;
  right: 35px;
}
.popup-form .wrapper .title {
  font-size: 25px;
  line-height: 1;
}
.main .page-content img,
.main .section-content img {
  max-width: 100% !important;
  height: auto !important;
}
.main.catalog h1 {
  margin-top: 0;
}
.main.car-page h1 {
  margin: 0 0 0.5rem 0;
}
.main.car-page h1+div {
  margin: 0 0 1rem 0;
}
.main.car-page h2,
.main.car-page h3,
.main.car-page h4,
.main.car-page h5,
.main.car-page h6 {
  margin: 0.5rem 0 0.5rem 0;
}
.main.car-page a.back-link {
  display: inline-block;
  margin: 1.5rem 0;
  border-bottom: none;
}
.main.car-page .car-summary .year {
  font-weight: 300;
}
.main.car-page .car-summary .summary-items {
  display: flex;
  justify-content: space-between;
  margin: 0 0 1rem 0;
}
.main.car-page .car-summary .summary-items .summary-item {
  display: flex;
  align-items: center;
}
.main.car-page .car-summary .summary-items .summary-item .icon {
  margin-right: 10px;
}
.main.car-page .car-summary .price-wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.main.car-page .car-summary .price-wrapper .price {
  font-size: 2rem;
  margin-bottom: 12px;
}
@media (max-width: 992px) {
  .main.car-page .car-summary .price-wrapper a.button {
    width: 100%;
  }
}
.main.car-page .car-miniatures {
  margin: 0.5rem 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
}
.main.car-page .car-miniatures a {
  display: block;
  margin: 5px 5px 5px 0;
  border-bottom: none;
}
.main.car-page .advantage {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(350px,1fr));
  grid-auto-rows: 120px;
  gap: 20px;
}
.main.car-page .specifitations {
  margin: 0 0 1rem 0;
}
.main.car-page .specifitations ul.specifitations-list,
.main.car-page .specifitations ul.specifitations-list li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.main .second-menu {
  background-color: #ececec;
  padding: 12px 12px 12px 12px;
  border-radius: 10px;
}
.main .second-menu ul.menu {
  margin: 0;
  padding: 0;
}
.main .second-menu ul.menu li {
  margin-bottom: 12px;
}
body.frontpage .marks-block {
  margin: 2.5rem 0;
}
body.frontpage .callback-form-block {
  margin: 2.5rem 0 2.5rem 0;
  padding: 3.5rem 0;
  background: url("/images/pixel-black-70.png") no-repeat, url("/images/autosalon-reception-6CInA3p6N9E-1280x400.jpg") no-repeat center;
  background-size: cover;
}
body.frontpage .callback-form-block h2 {
  margin: 1.5rem 0;
  color: #ffffff;
}
body .marks-block {
  margin: 2.5rem 0;
}
.main.current-mark-all .filter-Модель {
  display: none;
}
.marks {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(250px,1fr));
  row-gap: 10px;
  column-gap: 20px;
}
.marks a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: none;
}
.marks a:hover {
  background-color: #CCCCCC2E;
}
.marks .divider {
  flex-grow: 1;
  border-bottom: 1px #ba122b dotted;
}
.marks .amount {
  color: #ff4040;
  font-size: 12px;
  align-items: center;
  background-color: #CCCCCC2E;
  padding: 2px 5px;
  border-radius: 3px;
}
.vehile-filters {
  font-size: 14px;
  display: flex;
  flex-direction: column;
}
.vehile-filters .filterLabel {
  color: #ba122b;
}
.vehile-filters .filterGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 20px;
}
.results {
  grid-template-columns: 1fr 1fr 1fr;
  display: grid;
  gap: 20px;
  margin-bottom: 40px;
}
@media (max-width: 992px) {
  .results {
    grid-template-columns: repeat(auto-fit,minmax(250px,1fr));
  }
}
@media (max-width: 768px) {
  .results {
    grid-template-columns: repeat(auto-fit,minmax(250px,1fr));
  }
}
@media (max-width: 992px) {
  .results {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 576px) {
  .results {
    grid-template-columns: 1fr;
  }
}
.results .card.shoe {
  border-radius: 15px;
  overflow: hidden;
  position: relative;
  border: 1px #e0e0e0 solid;
  background: linear-gradient(155.49deg,#f2f2f2 3.96%,#fcfcfc 98.95%), #fcfcfc;
  box-shadow: -3px -3px 6px #fff, 3px 3px 10px rgba(158,158,158,0.4);
  transition: transform .2s ease-in-out;
}
.results .card.shoe > a {
  color: #2b2a29;
  border-bottom: none;
}
.results .card.shoe > a > img {
  width: 100%;
  height: auto;
}
.results .card.shoe .wrapper {
  padding: 14px;
}
.results .card.shoe .wrapper h3 {
  margin: 0 0 1rem 0;
  font-size: 1.2rem;
}
.results .card.shoe .wrapper .year {
  font-weight: 300;
}
.results .card.shoe .wrapper .price {
  margin: 1.5rem 0 0 0;
  color: #ba122b;
  text-align: right;
}
.sevices-block {
  margin: 2.5rem 0;
}
.sevices-block .sevices-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(350px,1fr));
  gap: 40px;
}
.sevices-block .sevices-cards .sevices-card {
  display: flex;
  flex-direction: column;
  border-radius: 15px;
  overflow: hidden;
  position: relative;
  border: 1px #e0e0e0 solid;
  background: linear-gradient(155.49deg,#f2f2f2 3.96%,#fcfcfc 98.95%), #fcfcfc;
  box-shadow: -3px -3px 6px #fff, 3px 3px 10px rgba(158,158,158,0.4);
  transition: transform .2s ease-in-out;
}
.sevices-block .sevices-cards .sevices-card:hover {
  transform: translateY(-10px);
}
.sevices-block .sevices-cards .sevices-card .title {
  position: absolute;
  top: 10px;
  left: 20px;
  color: #FFF;
  font-weight: 600;
  font-size: 2rem;
  text-shadow: 1px 1px 5px #2b2a29;
}
.sevices-block .sevices-cards .sevices-card .wrapper {
  padding: 24px;
  display: flex;
  flex-grow: 1;
  flex-direction: column;
  justify-content: space-between;
}
.sevices-block .sevices-cards .sevices-card .teaser {
  color: #2b2a29;
}
.sevices-block .sevices-cards .sevices-card .button {
  width: 100%;
  margin-top: 2rem;
}
.sevices-block .sevices-cards .sevices-card img {
  width: 100%;
  height: auto;
}
footer {
  margin-top: 24px;
  background-color: #162235;
  color: #ffffff;
  font-size: 14px;
}
footer .wrapper {
  padding: 48px 0;
}
footer .contacts a {
  margin-left: 10px;
}
footer a {
  text-decoration: none;
  color: #ffffff;
  border-bottom: #162235 1px solid;
}
footer a:hover,
footer a.active {
  text-decoration: none;
  color: #ba122b;
  border-bottom: #ba122b 1px solid;
}
footer .footer-main-menu ul.menu {
  margin: 0;
  padding: 0;
}
footer .footer-main-menu ul.menu li a {
  display: inline-block;
  margin-bottom: 10px;
}
footer .footer-main-menu > ul.menu {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr 1fr 1fr;
}
@media (max-width: 576px) {
  footer .footer-main-menu > ul.menu {
    grid-template-columns: 1fr 1fr;
  }
}
footer .footer-main-menu > ul.menu > li > a {
  font-weight: 600;
}
.slider .slide {
  position: relative;
}
.slider .slide .button {
  position: absolute;
  font-size: 24px;
}
.slider .slide .button.top {
  top: 50px;
}
.slider .slide .button.right {
  right: 50px;
}
.slider .slide .button.bottom {
  bottom: 50px;
}
.slider .slide .button.left {
  left: 50px;
}
