.footer-newsletter button.btn.btn-default.btn-arrow-right {
  background: #23436c;
  border-radius: 0px !important;
  border: 0px;
}

.image-link {
  position: relative;
  display: inline-block;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
}

.image-link img {
  display: block;
  width: 100%;
  height: 100%;
  transition: transform 0.4s ease, opacity 0.4s ease;
}

.image-text {
  position: absolute;
  bottom: calc(50% - 10px);
  left: 0%;
  opacity: 1;
  width: 100%;
  text-align: center;
  font: normal normal normal 33px / 24px Poppins;
  letter-spacing: 0px;
  color: #23436c;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.mid-section-banner img {
  opacity: 0.66;
  transition: transform 0.4s ease, opacity 0.4s ease;
}

.mid-section-banner a:hover img {
  opacity: 1;
  transform: scale(1.1);
}

.mid-section-banner a:hover .image-text {
  opacity: 0;
}

.promo-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
}

.promo-section .promo-image-wrapper {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 100%;
}

.promo-section .custom-carousel {
  position: relative;
  width: 100%;
  height: 100%;
}

.promo-section .slide {
  position: absolute;
  top: 0;
  left: 100%;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: all 0.8s ease;
}

.promo-section .slide.active {
  left: 0;
  opacity: 1;
  z-index: 2;
}

.promo-section .slide.exit-left {
  left: -100%;
  opacity: 0;
  z-index: 1;
}

@media (max-width: 768px) {
  .promo-section {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .promo-text {
    margin-top: 20px;
    padding: 2em !important;
  }
}

.promo-text {
  background: #23436c40 0% 0% no-repeat padding-box;
  padding: 80px;
  text-align: left;
}

.promo-text p,
.clinique-content p {
  text-align: left;
  font: normal normal normal 16px/24px Poppins;
  letter-spacing: 0px;
  color: #23436c;
}

.promo-text h2,
.clinique-content h1 {
  text-align: left;
  font: normal normal bold 33px/36px Poppins;
  letter-spacing: 0px;
  color: #ffffff;
  text-transform: uppercase;
  margin-top: 0px;
}

.promo-text p:first-of-type,
.clinique-content p:first-of-type {
  margin-bottom: 2px !important;
}

.promo-text a.btn,
.clinique-content a.btn {
  font: normal normal normal 14px Poppins;
  letter-spacing: 0px;
  color: #23436c;
}

.clinique-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  margin-top: 7em;
}

.clinique-image {
  padding: 60px 0 60px 60px;
}

.clinique-content {
  text-align: left;
}

@media (max-width: 768px) {
  .clinique-section {
    grid-template-columns: 1fr;
  }
}

.brand-logos {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 40px 20px;
  margin-top: 100px;
}

.brand-logos::before {
  content: "";
  position: absolute;
  background: #e5ce99;
  top: 0px;
  display: inline-block;
  left: -100vw;
  width: 1000vw;
  height: 100%;
  z-index: -1;
}

.brand-logos h2 {
  text-align: center;
  font: normal normal normal 24px / 24px Poppins;
  letter-spacing: 0px;
  color: #23436c;
  opacity: 1;
}

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

.brand-grid img {
  max-width: 160px;
  height: auto;
  object-fit: contain;
  filter: brightness(0) invert(1);
  transition: filter 0.3s ease-in-out;
}

.brand-grid img:hover,
.brand-grid img:focus {
  filter: brightness(1) invert(0);
}

@media (hover: hover) {

  .brand-grid a:hover,
  .brand-grid a img:hover {
    cursor: pointer !important;
  }
}

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

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

.homepage-latest-contribution .latest-contribution-wrapper h2 {
  font: normal normal normal 24px/24px Poppins;
  letter-spacing: 0px;
  color: #23436c;
  opacity: 1;
}

.pw-latest-contribution-wrapper .latest-contribution-inner {
  display: flex;
}

h4.latest-contribution-product {
  text-align: left;
  font: normal normal bold 16px/24px Poppins;
  letter-spacing: 0px;
  color: #23436c !important;
  opacity: 1;
}

span.latest-contribution-date {
  text-align: left;
  font: normal normal normal 10px/24px Poppins;
  letter-spacing: 0px;
  color: #23436c !important;
  padding: 0px;
}

.latest-contribution-info {
  text-align: left;
  align-items: flex-start !important;
}

.homepage-latest-contribution .latest-contribution-rating .stars .star {
  margin: 0px;
  margin-right: 5px;
}

span.star.star-on::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url("/user/documents/pw/upload/star.svg");
  background-size: contain;
  background-repeat: no-repeat;
}

.in-index span.star.star-off {
  display: none;
}

.latest-contribution-description {
  text-align: left;
}

span.latest-contribution-author {
  font: normal normal bold 14px/18px Poppins;
  letter-spacing: 0px;
  color: #23436c;
  padding: 0px !important;
}

.latest-contribution-description {
  font: normal normal normal 14px/18px Poppins;
  letter-spacing: 0px;
  color: #23436c;
  font-size: 14px;
}

span.latest-contribution-date {
  padding: 0px !important;
}

h4.latest-contribution-product {
  margin-bottom: 0px !important;
}

.pw-latest-contribution-wrapper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

@media (max-width: 1024px) {
  .pw-latest-contribution-wrapper {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .pw-latest-contribution-wrapper {
    grid-template-columns: 1fr;
  }
}

.footer-newsletter h2 {
  color: #23436c !important;
}

.newsletter-left {
  text-align: left;
}

.newsletter-left p {
  font: normal normal normal 16px/22px Poppins;
  letter-spacing: 0px;
}

.newsletter-left p:first-of-type {
  margin-bottom: 5px;
}

.homepage-blog-wrapper.row.blog-wrapper {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}

.homepage-blog-wrapper .homepage-group-title.h4 {
  flex-basis: 100%;
  text-align: center;
  font: normal normal normal 24px/24px Poppins;
  letter-spacing: 0px;
  color: #23436c;
}

.homepage-blog-wrapper .news-item {
  flex-basis: calc(33.333% - 14px);
  width: calc(33.333% - 14px);
}

.homepage-blog-wrapper .news-item .text {
  position: unset;
  background: transparent;
}

.homepage-blog-wrapper .news-item .text .title {
  text-align: center;
  font: normal normal bold 24px/28px Poppins;
  letter-spacing: 0px;
  color: #e5ce99;
}

.homepage-blog-wrapper .news-item .text:hover {
  background: transparent;
}

.homepage-blog-wrapper .news-item .text .description {
  text-align: center;
  font: normal normal normal 16px/24px Poppins;
  letter-spacing: 0px;
  margin-bottom: 20px;
}

.blog-wrapper .news-item .description {
    font-weight: 400 !important;
}

.homepage-blog-wrapper.row.blog-wrapper {
  margin: 0 !important;
}