/* Homepage Trustpilot/reviews: match the supplied UI reference. */
body.home .h-tp-block {
  display: block !important;
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: 44px var(--px, 16px) 34px !important;
  background: #fff !important;
  border-bottom: 1px solid var(--g200) !important;
  text-align: center !important;
}

body.home .h-tp-logo {
  display: flex !important;
  justify-content: center !important;
  margin-bottom: 14px !important;
}

body.home .h-tp-score-row {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  margin-bottom: 7px !important;
}

body.home .h-tp-score {
  color: var(--black) !important;
  font-size: 28px !important;
  font-weight: 300 !important;
  letter-spacing: -.04em !important;
  line-height: 1 !important;
}

body.home .h-tp-stars {
  display: flex !important;
  align-items: center !important;
  gap: 3px !important;
}

body.home .h-tp-label {
  color: #00b67a !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

body.home .h-tp-meta {
  color: var(--g400) !important;
  font-size: 11px !important;
  letter-spacing: 0 !important;
}

body.home .h-tp-meta strong {
  color: var(--black) !important;
  font-weight: 700 !important;
}

body.home .h-reviews-sec {
  display: block !important;
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  background: #fff !important;
  border-top: 1px solid var(--g200) !important;
  padding: 0 !important;
}

body.home .h-reviews-hdr {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 18px var(--px, 16px) 14px !important;
}

body.home .h-reviews-title {
  color: var(--black) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
}

body.home .h-reviews-scroll {
  display: flex !important;
  gap: 10px !important;
  overflow-x: auto !important;
  scroll-snap-type: none !important;
  padding: 0 var(--px, 16px) 18px !important;
  scrollbar-width: none !important;
}

body.home .h-reviews-scroll::-webkit-scrollbar {
  display: none !important;
}

body.home .h-rv-card {
  flex: 0 0 220px !important;
  width: 220px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 9px !important;
  background: #fff !important;
  border: 1px solid var(--g200) !important;
  border-radius: 2px !important;
  padding: 15px !important;
  box-shadow: none !important;
  scroll-snap-align: none !important;
}

body.home .h-rv-top {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

body.home .h-rv-stars {
  display: flex !important;
  gap: 2px !important;
}

body.home .h-rv-via {
  display: flex !important;
  align-items: center !important;
}

body.home .h-rv-title {
  color: var(--black) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
}

body.home .h-rv-body {
  flex: 1 !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 4 !important;
  overflow: hidden !important;
  color: var(--g500) !important;
  font-size: 12px !important;
  letter-spacing: 0 !important;
  line-height: 1.65 !important;
}

body.home .h-rv-foot {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  margin-top: 2px !important;
  padding-top: 9px !important;
  border-top: 1px solid var(--g100) !important;
}

body.home .h-rv-avatar {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  background: var(--g100) !important;
  color: var(--black) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}

body.home .h-rv-name {
  color: var(--black) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
}

body.home .h-rv-date {
  margin-top: 1px !important;
  color: var(--g400) !important;
  font-size: 10px !important;
  letter-spacing: 0 !important;
}

body.home .h-reviews-link,
body.home .h-reviews-cta {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 14px 0 !important;
  background: #fff !important;
  border-top: 1px solid var(--g100) !important;
  color: #00b67a !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: .04em !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
}

body.home .h-reviews-link svg,
body.home .h-reviews-cta svg {
  width: 14px !important;
  height: 14px !important;
}

@media (min-width: 900px) {
  body.home .h-reviews-hdr {
    padding: 30px 39px 22px !important;
  }

  body.home .h-reviews-title {
    font-size: 10px !important;
    letter-spacing: .14em !important;
  }

  body.home .h-reviews-scroll {
    gap: 15px !important;
    padding: 0 39px 26px !important;
  }

  body.home .h-rv-card {
    flex-basis: 330px !important;
    width: 330px !important;
    min-height: 0 !important;
    gap: 9px !important;
    padding: 15px !important;
  }

  body.home .h-rv-stars svg,
  body.home .h-rv-via svg {
    width: 14px !important;
    height: 14px !important;
  }

  body.home .h-rv-title {
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1.35 !important;
  }

  body.home .h-rv-body {
    font-size: 12px !important;
    letter-spacing: 0 !important;
    line-height: 1.65 !important;
  }

  body.home .h-rv-foot {
    gap: 9px !important;
    margin-top: 2px !important;
    padding-top: 9px !important;
  }

  body.home .h-rv-avatar {
    width: 40px !important;
    height: 40px !important;
    font-size: 14px !important;
  }

  body.home .h-rv-name {
    font-size: 11px !important;
    letter-spacing: 0 !important;
  }

  body.home .h-rv-date {
    font-size: 10px !important;
    letter-spacing: 0 !important;
  }

  body.home .h-reviews-link,
  body.home .h-reviews-cta {
    padding: 14px 0 !important;
    font-size: 11px !important;
  }

  body.home .h-reviews-link svg,
  body.home .h-reviews-cta svg {
    width: 14px !important;
    height: 14px !important;
  }
}

/* Restore home sections that the older cascade hid, and keep them visible without scroll-reveal timing. */
body.home .h-flash,
body.home a.h-flash {
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.home .h-sec,
body.home .h-trust,
body.home .h-brands,
body.home .h-tp-block,
body.home .h-reviews-sec,
body.home .h-flash {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

body.home .h-sec:not([hidden]),
body.home .h-brands:not([hidden]),
body.home .h-tp-block:not([hidden]),
body.home .h-reviews-sec:not([hidden]) {
  display: block !important;
}

body.home .h-trust:not([hidden]) {
  display: flex !important;
}

body.home .h-trust-item {
  flex: 1 1 0 !important;
  padding: 18px 8px !important;
  gap: 7px !important;
}
