.hero {
 padding: 90px 0;
}

.hero__content {
 display: flex;
 align-items: flex-end;
 justify-content: space-between;
}

.hero__title {
 max-width: 774px;
}

.hero__title span {
 font-weight: 400;
}

.hero__text {
 opacity: 0.8;
 color: #393B40;
 font-size: 15px;
 font-weight: 700;
 line-height: 139%;
 max-width: 460px;
}

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

.hero__category {
 aspect-ratio: 467/519;
 height: auto;
}

.hero__category-link {
 position: relative;
 display: block;
 height: 100%;
 border-radius: 20px;
 overflow: hidden;
}

.hero__category-img {
 position: absolute;
 width: 100%;
 height: 100%;
 object-fit: cover;
 z-index: 1;
 transition: all .5s;
}

.hero__category-link:hover .hero__category-img {
 transform: scale(1.03);
}

.hero__category-content {
 position: relative;
 z-index: 2;
 display: flex;
 flex-direction: column;
 justify-content: flex-end;
 height: 100%;
 padding: 30px;
}

.hero__category-count {
 margin-bottom: auto;
 color: #FFF;
 font-size: 12px;
 font-weight: 600;
 padding: 5px 8px;
 border-radius: 6px;
 background: rgba(255, 255, 255, 0.08);
 width: fit-content;
}

.hero__category-content-bottom {
 display: flex;
 align-items: flex-end;
 justify-content: space-between;
 gap: 10px;
}

.hero__category-content-info {
 max-width: 234px;
}

.hero__category-title {
 color: #fff;
 margin-bottom: 6px;
}

.hero__category-text {
 color: rgba(255, 255, 255, 0.7);
 font-size: 15px;
 font-weight: 400;
 line-height: 139%;
}

.hero__category-arrow {
 line-height: 0;
 transition: all .3s;
}

.hero__category-arrow:hover {
 transform: scale(1.07);
}

.products-section__wrapper {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 25px
}

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

.section-header__link {
 padding: 8px 12px;
 border-radius: 8px;
 gap: 7px;
 font-family: Oswald;
 font-size: 14px;
 font-weight: 500;
 text-transform: uppercase;
 transition: all .3s;
}

.section-header__link svg {
 line-height: 13;
}



.products-grid-weeks {
 display: grid;
 grid-template-columns: 1fr 1fr;
 gap: 25px;
 margin-top: 30px;
}


.promo-banners {
 overflow: hidden;
 border-radius: 20px;
}

.promo-banner {
 position: relative;
 aspect-ratio: 709/450;
 height: auto;
 width: 100%;
}

.promo-banner__image {
 width: 100%;
 object-fit: cover;
 position: absolute;
 top: 0;
 left: 0;
 height: 100%;
 object-fit: cover;
 z-index: 1;
}

.promo-banner__content {
 position: relative;
 z-index: 2;
 height: 100%;
 display: flex;
 flex-direction: column;
 justify-content: flex-end;
 padding: 30px;
}

.promo-banner__label {
 color: rgba(255, 255, 255, 0.7);
 font-size: 12px;
 font-weight: 800;
 line-height: 150%;
}

.promo-banner__title {
 max-width: 405px;
 color: #FFF;
 text-transform: uppercase;
 margin-top: 7px;
}

.promo-banner__text {
 margin-top: 7px;
 max-width: 363px;
 color: rgba(255, 255, 255, 0.8);
 font-size: 14px;
 font-weight: 500;
 line-height: 150%;
}

.promo-banner__link {
 margin-top: 18px;
 padding: 14px 12px;
 border-radius: 8px;
 background: #EDEDED;
 gap: 4px;
 width: fit-content;
 color: #111212;
 font-family: Oswald;
 font-size: 14px;
 font-weight: 600;
 line-height: normal;
 text-transform: uppercase;
}

.promo-banner__link:hover {
 background: rgba(17, 18, 18, 1);
 color: #fff;
}

.promo-banner__link:hover path {
 stroke: #fff;
}

.promo-banner__dots {
 position: absolute;
 bottom: 30px !important;
 right: 30px;
 left: auto !important;
 display: flex;
 align-items: center;
 gap: 31px;
 z-index: 3;
 width: fit-content !important;
}

.promo-banner__dots .swiper-pagination-bullet {
 width: 4px;
 height: 4px;
 background: #fff;
 border-radius: 999px;
 opacity: 1;
 position: relative;
 margin: 0 !important;
 transition: all 0.3s ease;
}

.promo-banner__dots .swiper-pagination-bullet::before {
 content: '';
 position: absolute;
 inset: -10px;
 border: 1px solid transparent;
 border-radius: 50%;
 transition: all 0.3s ease;
}

.promo-banner__dots .swiper-pagination-bullet-active {
 background: #FCAF17;
 opacity: 1;
 width: 8px;
 height: 8px;
}

.promo-banner__dots .swiper-pagination-bullet-active::before {
 border-color: #fff;
}

.products-section__wrapper-right {
 width: 100%;
 overflow: hidden;
 display: flex;
 align-items: flex-end;
}


.popular-section {
 padding: 80px 0;
}

.popular-section .section-header {
 width: 74.5%;
}

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

.popular-info {
 padding: 14.158px 14px 1.842px 14px;
 display: flex;
 flex-direction: column;
 height: 100%;
}

.popular-info__title {
 margin-bottom: 5px;
}

.popular-info__text {
 color: rgba(17, 18, 18, 0.8);
 font-size: 14px;
 font-weight: 500;
 line-height: 150%;
 margin-bottom: 25px;
}

.popular-info__buttons {
 display: flex;
 flex-wrap: wrap;
 gap: 8px;
}

.popular-info__btn {
 padding: 7px 13px 10px 13px;
 border-radius: 8px;
 background: #393B40;
 color: #FFF;
 font-family: Oswald;
 font-size: 14px;
 font-weight: 500;
 line-height: 150%;
 text-transform: uppercase;
}

.popular-info__btn:hover {
 background: rgba(252, 175, 23, 1);
}

.popular-info__counter {
 margin-top: auto;
 color: rgba(17, 18, 18, 0.6);
 font-size: 14px;
 font-weight: 500;
 line-height: 150%;
 display: flex;
 align-items: center;
 gap: 5px;
}

.popular-info__counter::before {
 content: "";
 width: 17px;
 height: 1px;
 opacity: 0.4;
 background: #8E8F91;
 display: block;
}


.promo-section__wrapper {
 position: relative;
 padding: 40px 30px;
 border-radius: 20px;
 background: #000;
 overflow: hidden;
}

.promo-section__picture {
 position: absolute;
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
}

.promo-section__image {
 width: 100%;
 height: 100%;
 object-fit: cover;
}

.promo-section__content {
 position: relative;
 z-index: 2;
 display: flex;
 align-items: center;
 justify-content: flex-end;
 gap: 77px;
}

.promo-section__title {
 color: #fff;
 max-width: 417px;
 margin-right: auto;
}

.promo-section__title span {
 display: block;
 font-weight: 400;
}

.promo-section__description {
 max-width: 397px;
 color: rgba(255, 255, 255, 0.56);
 font-size: 16px;
 font-weight: 400;
 line-height: 139%;
 margin-bottom: 0;
}

.promo-section__btn {
 padding: 14px 12px;
 border-radius: 8px;
 background: #EDEDED;
 color: #111212;
 font-family: Oswald;
 font-size: 14px;
 font-weight: 600;
 line-height: normal;
 text-transform: uppercase;
 white-space: nowrap;
}

.promo-section__btn:hover {
 background: #FCAF17;
}

.products-featured {
 padding: 80px 0;
}


.blog-section {
 padding: 90px 0;
 background: #fff;
}

.blog-tabs {
 margin-top: 20px;
 display: flex;
 align-items: center;
 gap: 24px;
}

.blog-tabs__item {
 padding: 0;
 background: transparent;
 color: rgba(57, 59, 64, 0.4);
 font-size: 15px;
 font-weight: 600;
 line-height: 139%;
 transition: all .3s;
}

.blog-tabs__item:hover {
 color: rgba(57, 59, 64, 0.8);
}

.blog-tabs__item--active {
 color: #393B40;
 font-weight: 800;
}

.blog-carousel__wrapper {
 position: relative;
 margin-top: 30px;
}

.blog-carousel__slider {
 overflow: hidden;
}

.blog-carousel__dots {
 display: none;
 position: absolute;
 bottom: -40px;
 left: 50%;
 transform: translateX(-50%);
 align-items: center;
 gap: 31px;
 z-index: 3;
 width: fit-content;
}

.blog-carousel__dots .swiper-pagination-bullet {
 width: 4px;
 height: 4px;
 background: #303133;
 border-radius: 999px;
 opacity: 1;
 position: relative;
 margin: 0;
 transition: all 0.3s ease;
 cursor: pointer;
}

.blog-carousel__dots .swiper-pagination-bullet::before {
 content: '';
 position: absolute;
 inset: -10px;
 border: 1px solid transparent;
 border-radius: 50%;
 transition: all 0.3s ease;
}

.blog-carousel__dots .swiper-pagination-bullet-active {
 background: #FCAF17;
 opacity: 1;
 width: 8px;
 height: 8px;
}

.blog-carousel__dots .swiper-pagination-bullet-active::before {
 border-color: #FCAF17;
}

.post-card__image-link {
 width: 100%;
 height: auto;
 aspect-ratio: 1/0.6;
 border-radius: 12px;
 overflow: hidden;
 display: block;
}

.post-card__image {
 width: 100%;
 height: 100%;
 object-fit: cover;
 transition: all .5s;
}

.post-card__image-link:hover .post-card__image {
 transform: scale(1.03);
}

.post-card__content {
 margin-top: 12px;
 text-align: left;
}

.post-card__date {
 display: -webkit-box;
 -webkit-box-orient: vertical;
 -webkit-line-clamp: 2;
 align-self: stretch;
 overflow: hidden;
 color: #393B40;
 text-overflow: ellipsis;
 font-size: 13px;
 font-weight: 500;
 line-height: 150%;
}

.post-card__title {
 margin-top: 10px;
 overflow: hidden;
 color: #393B40;
 text-overflow: ellipsis;
 display: -webkit-box;
 -webkit-box-orient: vertical;
 -webkit-line-clamp: 2;
 align-self: stretch;
}

.post-card__btn {
 margin-top: 10px;
 width: fit-content;
 padding: 8px 10px;
 border-radius: 8px;
 font-size: 13px;
 font-weight: 700;
 line-height: 150%;
 transition: all .3s;
}



.reviews-section {
 padding: 90px 0;
}

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

.reviews-stats__card {
 padding: 30px;
 border-radius: 30px;
 background: #FFF;
}

.reviews-stats__card--highlight {
 border-radius: 30px;
 border: 3px solid #FCAF17;
 background: transparent;
}

.reviews-stats__header {
 display: flex;
 align-items: center;
 justify-content: space-between;
 margin-bottom: 14px;
}

.reviews-stats__label {
 color: #303133;
 font-size: 15px;
 font-weight: 700;
 line-height: 139%;
}

.reviews-stats__value {
 margin-top: 14px;
 display: flex;
 align-items: center;
 gap: 10px;
}

.reviews-stats__rating,
.reviews-stats__count {
 color: #303133;
 font-family: Oswald;
 font-size: 117px;
 font-weight: 700;
 line-height: 91%;
}

.reviews-stats__description {
 margin-bottom: 0;
 margin-top: 14px;
 color: #8E8F91;
 font-size: 14px;
 font-weight: 500;
 line-height: 150%;
 max-width: 294px;
}


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

.review-card {
 padding: 25px;
 border-radius: 15px;
 background: #FFF;
}

.review-card__header {
 display: flex;
 align-items: center;
 gap: 14px;
 margin-bottom: 10px;
}

.review-card__avatar {
 line-height: 0;
}

.review-card__avatar img {
 width: 69px;
 height: 69px;
 border-radius: 900px;
 object-fit: cover;
}

.review-card__author-name {
 color: #303133;
 font-size: 16px;
 font-weight: 700;
 line-height: 139%;
}

.review-card__rating {
 display: flex;
 align-items: center;
 gap: 1px;
 margin-top: 2px;
}

.review-card__rating svg {
 flex-shrink: 0;
}

.review-card__rating svg path {
 fill: #FCAF17;
 transition: fill 0.3s;
}

.review-card__rating--gray svg path {
 fill: #E0E0E0;
}

.review-card__rating svg.star--gray path {
 fill: #E0E0E0;
}

.review-card__text {
 color: #303133;
 font-size: 15px;
 font-weight: 400;
 line-height: 150%;
 margin-bottom: 0;
}

.review-card__read-more {
 color: #526086;
 font-size: 13px;
 font-weight: 600;
 line-height: 150%;
 border-bottom: 1px dashed rgba(82, 96, 134, 0.50);
 margin-top: 6px;
}

.review-card__read-more:hover {
 border-bottom: 1px dashed rgba(17, 18, 18, 1);
 color: rgba(17, 18, 18, 1);
}

.review-card__date {
 margin-top: 10px;
 color: #8E8F91;
 font-size: 13px;
 font-weight: 500;
 line-height: 150%;
 display: block;
}

.reviews-section__more-btn {
 width: fit-content;
 margin-inline: auto;
 margin-top: 30px;
 padding: 16px 25px;
 border-radius: 10px;
 font-size: 15px;
 font-weight: 800;
 line-height: 139%;
 gap: 10px;
}



.about-section {
 padding: 90px 0;
 background: #fff;
}

.about-section__wrapper {
 display: grid;
 grid-template-columns: 1fr 1.35fr;
 gap: 60px;
 align-items: center;
}

.about-section__image {
 line-height: 0;
}

.about-section__image img {
 width: 100%;
 height: auto;
 aspect-ratio: 4/3;
 object-fit: cover;
 border-radius: 15px;
}

.about-section__title {
 max-width: 348px;
 margin-bottom: 20px;
}

.about-section__text {
 color: #111212;
 font-size: 15px;
 font-weight: 400;
 line-height: 150%;
 max-width: 683px;
}

.about-section__text p {
 margin-bottom: 20px;
}

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

.about-section__btn {
 margin-top: 20px;
 border-radius: 10px;
 padding: 16px 25px;
 gap: 10px;
 font-size: 15px;
 font-weight: 800;
 line-height: 139%;
 width: fit-content;
}

@media (max-width: 1275px) {
 .products-section__wrapper {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
 }

 .promo-banners {
  height: 100%;
 }

 .promo-banner {
  aspect-ratio: auto;
  height: 100%;
 }
}


@media (max-width: 1200px) {
 .hero__category-title {
  font-size: 26px;
 }

 .promo-banners {
  height: 100%;

 }

 .products-section__wrapper {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
 }
}

@media (max-width: 1150px) {
 .popular-section__grid {
  grid-template-columns: repeat(3, 1fr);
 }

 .popular-section .section-header {
  width: 100%;
 }
}

@media (max-width: 1024px) {
 .hero {
  padding: 40px 0;
 }

 .hero__title {
  max-width: 365px;
 }

 .hero__text {
  gap: 30px;
  max-width: 325px;
  font-size: 13px;
 }

 .hero__categories {
  margin-top: 20px;
  gap: 10px;
 }

 .hero__category {
  aspect-ratio: 235 / 242;
  width: 235px;
 }

 .hero__category-title {
  font-size: 23px;
 }

 .hero__category-content {
  padding: 20px;
 }

 .hero__category-link {
  border-radius: 14px;
 }

 .hero__category-arrow {
  display: none;
 }

 .hero__category-text {
  font-size: 12px;
 }

 .hero__category-count {
  margin-bottom: 6px;
  font-size: 10px;
 }

 .promo-banners {
  height: 321px;
  border-radius: 12px;
 }

 .section-header__link {
  padding: 0 !important;
  gap: 0 !important;
  font-size: 0 !important;
  background: transparent !important;
 }

 .section-header__link path {
  stroke: #111212 !important;
 }

 .section-header {
  justify-content: flex-start;
  gap: 3px;
 }

 .section-header__link svg {
  width: 22px;
  height: 13px;
 }

 .products-grid-weeks {
  gap: 16px;
  margin-top: 20px;
 }

 .products-section__wrapper {
  grid-template-columns: 2fr 1fr;
  gap: 16px;
 }

 .promo-banner__content {
  padding: 12px;
  justify-content: flex-start;
 }

 .promo-banner__title {
  font-size: 18px;
 }

 .promo-banner__text {
  font-size: 12px;
 }

 .promo-banner__link {
  padding: 10px;
  font-size: 12px;
 }

 .promo-banner__dots {
  position: absolute;
  bottom: 30px !important;
  right: 50%;
  transform: translateX(50%);
 }

 .popular-section__grid {
  margin-top: 20px;
  gap: 12px;
 }

 .popular-info {
  grid-column: 2 / span 2;
 }

 .popular-section__grid .product-card:nth-child(5) {
  order: -1;
 }

 .popular-info__title {
  max-width: 200px;
 }

 .popular-info__text {
  font-size: 13px;
  margin-bottom: 20px;
 }

 .popular-info__btn {
  padding: 7px 12px;
  font-size: 13px;
 }

 .popular-info__buttons {
  gap: 3px;
 }

 .popular-info__counter {
  margin-top: 20px;
 }




 .popular-section {
  padding: 40px 0 20px;
 }

 .promo-section__content {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 6px;
 }

 .promo-section__description {
  max-width: 341px;
  font-size: 13px;
 }

 .promo-section__btn {
  width: 300px;
 }

 .promo-section__wrapper {
  border-radius: 12px;
  padding: 14px;
 }

 .products-featured {
  padding: 40px 0;
 }

 .products-carousel__wrapper {
  position: relative;
  margin-top: 20px;
 }

 .blog-section {
  padding: 40px 0;
 }

 .blog-tabs {
  margin-top: 10px;
  gap: 12px;
 }

 .blog-tabs__item {
  font-size: 13px;
 }

 .blog-carousel__wrapper {
  margin-top: 20px;
 }

 .blog-carousel__wrapper .carousel-arrow {
  display: none;
 }

 .blog-carousel__dots {
  display: flex;
  position: static;
  transform: none;
  justify-content: center;
  margin-top: 20px;
  height: 28px;
 }

 .post-card__content {
  margin-top: 10px;
 }

 .post-card__date {
  font-size: 12px;
 }

 .post-card__title {
  margin-top: 6px;
 }

 .post-card__btn {
  margin-top: 6px;
 }

 .reviews-section {
  padding: 40px 0;
 }

 .reviews-stats {
  gap: 12px;
  margin-top: 20px;
 }

 .reviews-stats__card {
  padding: 16px;
  border-radius: 16px;
 }

 .reviews-stats__card--highlight {
  border: 2px solid #FCAF17;
 }

 .reviews-stats__header svg {
  width: 28px;
  height: 28px;
 }

 .reviews-stats__header {
  margin-bottom: 5px;
 }

 .reviews-stats__value svg {
  width: 36px;
  height: 36px;
  aspect-ratio: 1/1;
 }

 .reviews-stats__rating,
 .reviews-stats__count {
  font-size: 34px;
 }

 .reviews-stats__value {
  gap: 4px;
  margin: 0;
 }

 .reviews-stats__info {
  display: flex;
  align-items: flex-start;
  gap: 10px;
 }

 .reviews-stats__description {
  margin-bottom: 0;
  margin-top: 0;
  font-size: 12px;
 }


 .reviews-grid {
  margin-top: 20px;
  gap: 16px;
 }

 .review-card {
  padding: 16px;
 }

 .review-card__avatar img {
  width: 40px;
  height: 40px;
 }

 .review-card__header {
  gap: 10px;
 }

 .review-card__author-name {
  font-size: 14px;
 }

 .review-card__text {
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
  align-self: stretch;
 }

 .review-card__date {
  font-size: 12px;
 }

 .reviews-section__more-btn {
  margin-top: 20px;
  padding: 12px 20px;
  font-size: 14px;
 }

 .about-section {
  padding: 40px 0;
 }

 .about-section__wrapper {
  gap: 15px;
  align-items: flex-start;
 }

 .about-section__wrapper {
  grid-template-columns: 1fr 1.1fr;
 }

 .about-section__title {
  margin-bottom: 10px;
 }

 .about-section__btn {
  margin-top: 10px;
  padding: 12px 20px;
  font-size: 14px;
 }

 .footer {
  padding: 40px 0;
 }

 .blog-carousel__slider {
  overflow: visible;
 }

 .blog-section {
  overflow: hidden;
 }

}

@media (max-width: 768px) {
 .hero__content {
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
 }

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

 .hero__category {
  aspect-ratio: 328 / 170;
  width: 100%;
 }

 .products-section__wrapper {
  display: block;
 }

 .products-grid-weeks {
  margin-top: 20px;
  gap: 12px;
  display: block;
  overflow: visible;
 }

 .products-grid-weeks.swiper {
  overflow: hidden;
  margin-left: -15px;
  margin-right: -15px;
  padding-left: 15px;
  padding-right: 15px;
  margin-bottom: 20px;
 }




 .promo-banners {
  height: auto;
 }

 .popular-section__grid {
  margin-top: 20px;
  gap: 12px;
  display: block;
  overflow: visible;
 }

 .popular-section__grid.swiper {
  overflow: hidden;
  margin-left: -15px;
  margin-right: -15px;
  padding-left: 15px;
  padding-right: 15px;
 }

 .popular-section__grid .popular-info {
  display: none;
 }

 .popular-info {
  padding: 0;
  margin-top: 20px;
 }

 .popular-info__text {
  margin-bottom: 15px;
 }

 .popular-info__counter {
  margin-top: 15px;
 }

 .popular-info__counter {
  font-size: 13px;
 }

 .promo-section__btn {
  width: 100%;
  margin-top: auto;
 }

 .promo-section__wrapper {
  aspect-ratio: 1;
 }

 .promo-section__content {
  height: 100%;
 }

 .products-featured {
  overflow: hidden;
 }

 .blog-carousel__dots {
  display: none;
 }

 .blog-carousel__wrapper {
  margin-left: -15px;
  margin-right: -15px;
  padding-left: 15px;
  padding-right: 15px;
 }





 .reviews-stats {
  grid-template-columns: 1fr;
  gap: 10px;
 }

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

 .reviews-section__more-btn {
  width: 100%;
 }

 .about-section__wrapper {
  gap: 20px;
  grid-template-columns: 1fr;
 }

 .promo-banner {
  aspect-ratio: 1/0.7;
 }




}

@media (max-width: 550px) {
 .promo-section__wrapper {
  aspect-ratio: 328 / 390;
 }

 .promo-banner {
  aspect-ratio: 1;
 }

}