/* =============================================================
   Shared hero banners — 2-column carousel
   Page classes: dhatri-hero, cloffy-hero, fitlys-hero, gift-hero, chocolates-hero
   Page themes: css/hero-banner-themes.css
   ============================================================= */

:is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) {
  --dhatri-indicators-h: 36px;
  --dhatri-dot-inactive: rgba(57, 109, 27, 0.32);
  --dhatri-dot-active: var(--dhatri-brown);
  --dhatri-banner-h: min(
    600px,
    calc(100dvh - var(--announcement-bar-height) - var(--site-header-height) - var(--dhatri-indicators-h))
  );
  --dhatri-slide-h: var(--dhatri-banner-h);
  /* Banner typography — lg+ uses global type scale via typography.css */
  --banner-title-size: var(--type-heading, 42px);
  --banner-title-line: var(--type-heading-line, 1.22);
  --banner-lead-size: var(--type-body, 16px);
  --banner-lead-line: var(--type-body-line, 1.6);
  --banner-eyebrow-size: var(--type-body, 16px);
  --banner-eyebrow-icon-size: 16px;
  --banner-perk-size: var(--type-body, 16px);
  --banner-perk-icon-size: 16px;
  --banner-cta-size: var(--type-body, 16px);
  --banner-cta-icon-size: 16px;
  --banner-tag-size: var(--type-body, 16px);
  --banner-tag-sub-size: var(--type-body, 16px);
  --banner-strip-size: var(--type-body, 16px);
  --banner-strip-icon-size: 16px;
  position: relative;
  overflow: hidden;
  width: 100%;
  background: var(--dhatri-cream);
}

:is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel {
  position: relative;
  width: 100%;
}

:is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-inner {
  width: 100%;
  height: var(--dhatri-slide-h);
}

:is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-item {
  width: 100%;
  height: var(--dhatri-slide-h) !important;
  min-height: var(--dhatri-slide-h);
  transition: opacity 0.65s ease-in-out;
}

/* Pill indicators — flush bottom, no Bootstrap gap */
.dhatri-hero .carousel-indicators.dhatri-hero__indicators,
.cloffy-hero .carousel-indicators.cloffy-hero__indicators,
.fitlys-hero .carousel-indicators.fitlys-hero__indicators,
.gift-hero .carousel-indicators.gift-hero__indicators,
.chocolates-hero .carousel-indicators.chocolates-hero__indicators {
  position: absolute !important;
  left: 0;
  right: 0;
  bottom: 0;
  top: auto;
  z-index: 25;
  height: auto;
  margin: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 0 !important;
  padding: 0 0 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  pointer-events: none;
}

:is(.dhatri-hero__indicators,.cloffy-hero__indicators,.fitlys-hero__indicators,.gift-hero__indicators,.chocolates-hero__indicators) [data-bs-target] {
  pointer-events: auto;
  width: 28px;
  height: 5px;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 100px;
  background: var(--dhatri-dot-inactive);
  opacity: 1;
  text-indent: -9999px;
  overflow: hidden;
  transition: width 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
}

:is(.dhatri-hero__indicators,.cloffy-hero__indicators,.fitlys-hero__indicators,.gift-hero__indicators,.chocolates-hero__indicators) [data-bs-target].active {
  width: 44px;
  background: var(--dhatri-dot-active);
  box-shadow: 0 2px 8px rgba(57, 109, 27, 0.28);
}

:is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-control-prev,
:is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-control-next {
  display: none !important;
}

/* ---- Slide shell ---- */
:is(.dhatri-banner,.cloffy-banner,.fitlys-banner,.gift-banner,.chocolates-banner) {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  min-height: var(--dhatri-slide-h);
  color: var(--dhatri-brown);
  overflow: hidden;
  isolation: isolate;
  box-sizing: border-box;
}

.dhatri-banner--diabetic {
  background: linear-gradient(118deg, #f4fbf2 0%, #e8f5e9 42%, #dcefd8 100%);
}

.dhatri-banner--women {
  background: linear-gradient(118deg, #f7fcf5 0%, #eef8eb 44%, #e2f2dc 100%);
}

.dhatri-banner--liver {
  background: linear-gradient(118deg, #fafdf8 0%, #f0f7ec 46%, #e5f0df 100%);
}

.dhatri-banner--digestive {
  background: linear-gradient(118deg, #f6fbf4 0%, #ebf5e8 44%, #deecda 100%);
}

.dhatri-banner--weight {
  background: linear-gradient(118deg, #f8fcf6 0%, #eef6ef 45%, #e0edd9 100%);
}

:is(.dhatri-banner__leaf,.cloffy-banner__leaf,.fitlys-banner__leaf,.gift-banner__leaf,.chocolates-banner__leaf) {
  position: absolute;
  inset: 0;
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cpath fill='%23396d1b' fill-opacity='0.11' d='M32 6c-7 12-18 16-18 28a18 18 0 1 0 36 0c0-12-11-16-18-28z'/%3E%3C/svg%3E");
  background-size: 72px 72px;
}

:is(.dhatri-banner__diagonal,.cloffy-banner__diagonal,.fitlys-banner__diagonal,.gift-banner__diagonal,.chocolates-banner__diagonal) {
  position: absolute;
  top: 0;
  right: 0;
  width: 58%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(165deg, rgba(57, 109, 27, 0.06) 0%, rgba(42, 82, 20, 0.14) 100%);
  clip-path: polygon(22% 0, 100% 0, 100% 100%, 0 100%);
}

:is(.dhatri-banner__layout,.cloffy-banner__layout,.fitlys-banner__layout,.gift-banner__layout,.chocolates-banner__layout) {
  position: relative;
  z-index: 2;
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  align-items: stretch;
  gap: clamp(12px, 2.5vw, 36px);
  max-width: 1280px;
  margin: 0 auto;
  padding: clamp(20px, 3vw, 44px) clamp(20px, 4vw, 48px) clamp(32px, 2.5vw, 40px);
  width: 100%;
  height: 100%;
  min-height: 0;
  box-sizing: border-box;
}

/* ---- Copy panel — centered in left column ---- */
:is(.dhatri-banner__copy,.cloffy-banner__copy,.fitlys-banner__copy,.gift-banner__copy,.chocolates-banner__copy) {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 100%;
}

:is(.dhatri-banner__eyebrow,.cloffy-banner__eyebrow,.fitlys-banner__eyebrow,.gift-banner__eyebrow,.chocolates-banner__eyebrow) {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  margin-bottom: 14px;
  font-size: var(--banner-eyebrow-size);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dhatri-brown-mid);
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(57, 109, 27, 0.12);
  border-radius: 100px;
}

:is(.dhatri-banner__eyebrow,.cloffy-banner__eyebrow,.fitlys-banner__eyebrow,.gift-banner__eyebrow,.chocolates-banner__eyebrow) i {
  font-size: var(--banner-eyebrow-icon-size);
  color: var(--dhatri-warm-deep);
}

:is(.dhatri-banner__title,.cloffy-banner__title,.fitlys-banner__title,.gift-banner__title,.chocolates-banner__title) {
  font-family: var(--font-primary);
  font-size: var(--banner-title-size);
  font-weight: 800;
  line-height: var(--banner-title-line);
  letter-spacing: -0.02em;
  color: var(--dhatri-brown);
  margin: 0 0 12px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(var(--banner-title-line) * 3em);
}

:is(.dhatri-banner__title,.cloffy-banner__title,.fitlys-banner__title,.gift-banner__title,.chocolates-banner__title) em {
  font-style: normal;
  color: var(--dhatri-brown-mid);
}

:is(.dhatri-banner__lead,.cloffy-banner__lead,.fitlys-banner__lead,.gift-banner__lead,.chocolates-banner__lead) {
  font-size: var(--banner-lead-size);
  line-height: var(--banner-lead-line);
  color: var(--dhatri-brown-soft);
  margin: 0 0 20px;
  max-width: 38ch;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(var(--banner-lead-line) * 2em);
}

:is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) {
  list-style: none;
  margin: 0 auto 22px;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 100%;
  gap: 10px;
}

:is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) li {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 14px;
  font-size: var(--banner-perk-size);
  /* font-weight: 600; */
  color: var(--dhatri-brown);
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(57, 109, 27, 0.1);
  border-radius: 100px;
  box-shadow: 0 4px 14px rgba(57, 109, 27, 0.07);
  line-height: 1.2;
  text-align: center;
}

:is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) i {
  font-size: var(--banner-perk-icon-size);
  color: var(--dhatri-warm-deep);
}

:is(.dhatri-banner__cta,.cloffy-banner__cta,.fitlys-banner__cta,.gift-banner__cta,.chocolates-banner__cta) {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  font-size: var(--banner-cta-size);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--white);
  background: var(--dhatri-brown);
  border: 2px solid var(--dhatri-brown);
  border-radius: 100px;
  box-shadow: 0 8px 24px rgba(57, 109, 27, 0.22);
  transition: background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

:is(.dhatri-banner__cta,.cloffy-banner__cta,.fitlys-banner__cta,.gift-banner__cta,.chocolates-banner__cta):hover {
  color: var(--white);
  background: var(--dhatri-brown-dark);
  border-color: var(--dhatri-brown-dark);
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(61, 34, 25, 0.28);
}

:is(.dhatri-banner__cta,.cloffy-banner__cta,.fitlys-banner__cta,.gift-banner__cta,.chocolates-banner__cta) i {
  font-size: var(--banner-cta-icon-size);
  transition: transform 0.25s ease;
}

:is(.dhatri-banner__cta,.cloffy-banner__cta,.fitlys-banner__cta,.gift-banner__cta,.chocolates-banner__cta):hover i {
  transform: translateX(4px);
}

/* ---- Visual panel ---- */
:is(.dhatri-banner__visual,.cloffy-banner__visual,.fitlys-banner__visual,.gift-banner__visual,.chocolates-banner__visual) {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: 380px;
  padding: 8px 4px;
}

:is(.dhatri-banner__arch,.cloffy-banner__arch,.fitlys-banner__arch,.gift-banner__arch,.chocolates-banner__arch),
:is(.dhatri-banner__arch,.cloffy-banner__arch,.fitlys-banner__arch,.gift-banner__arch,.chocolates-banner__arch)::after {
  display: none !important;
}

:is(.dhatri-banner__product,.cloffy-banner__product,.fitlys-banner__product,.gift-banner__product,.chocolates-banner__product) {
  position: relative;
  z-index: 2;
  max-height: min(540px, 62vh);
  width: auto;
  max-width: 98%;
  object-fit: contain;
  filter: drop-shadow(0 22px 40px rgba(57, 109, 27, 0.22));
  transition: transform 0.5s cubic-bezier(0.34, 1.4, 0.64, 1);
}

:is(.dhatri-banner,.cloffy-banner,.fitlys-banner,.gift-banner,.chocolates-banner):hover :is(.dhatri-banner__product,.cloffy-banner__product,.fitlys-banner__product,.gift-banner__product,.chocolates-banner__product) {
  transform: scale(1.03) translateY(-4px);
}

:is(.dhatri-banner__tag,.cloffy-banner__tag,.fitlys-banner__tag,.gift-banner__tag,.chocolates-banner__tag) {
  position: absolute;
  z-index: 3;
  right: 6%;
  bottom: 10%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 92px;
  height: 92px;
  margin: 0;
  padding: 8px;
  font-size: var(--banner-tag-size);
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.2;
  color: var(--dhatri-brown);
  background: var(--white);
  border: 3px solid var(--dhatri-warm-deep);
  border-radius: 50%;
  box-shadow: 0 10px 24px rgba(57, 109, 27, 0.18);
}

:is(.dhatri-banner__tag,.cloffy-banner__tag,.fitlys-banner__tag,.gift-banner__tag,.chocolates-banner__tag) span {
  display: block;
  font-size: var(--banner-tag-sub-size);
  font-weight: 600;
  color: var(--dhatri-brown-soft);
  margin-top: 2px;
  letter-spacing: 0.04em;
}

/* ---- Bottom wellness strip ---- */
:is(.dhatri-banner__strip,.cloffy-banner__strip,.fitlys-banner__strip,.gift-banner__strip,.chocolates-banner__strip) {
  position: relative;
  z-index: 3;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 18px;
  margin: 0;
  padding: 10px clamp(16px, 4vw, 32px) 36px;
  background: rgba(255, 255, 255, 0.68);
  border-top: 1px solid rgba(57, 109, 27, 0.08);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

:is(.dhatri-banner__strip,.cloffy-banner__strip,.fitlys-banner__strip,.gift-banner__strip,.chocolates-banner__strip) span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--banner-strip-size);
  font-weight: 600;
  color: var(--dhatri-brown);
}

:is(.dhatri-banner__strip,.cloffy-banner__strip,.fitlys-banner__strip,.gift-banner__strip,.chocolates-banner__strip) i {
  font-size: var(--banner-strip-icon-size);
  color: var(--dhatri-warm-deep);
}

:is(.dhatri-banner__strip-dot,.cloffy-banner__strip-dot,.fitlys-banner__strip-dot,.gift-banner__strip-dot,.chocolates-banner__strip-dot) {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--dhatri-brown-soft);
  opacity: 0.45;
}

/* ---- Responsive ---- */
@media screen and (max-width: 991px) {
  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) {
    --dhatri-indicators-h: 46px;
    --dhatri-slide-h: 400px;
  }
}

@media screen and (max-width: 767px) {
  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) {
    --dhatri-indicators-h: 44px;
    --dhatri-slide-h: auto;
    --banner-title-size: var(--type-heading);
    --banner-title-line: var(--type-heading-line);
    --banner-lead-size: var(--type-body);
    --banner-eyebrow-size: var(--type-body);
    --banner-perk-size: var(--type-body);
    --banner-cta-size: var(--type-body);
    --banner-tag-size: var(--type-body);
    --banner-tag-sub-size: var(--type-body);
  }

  :is(.dhatri-banner__diagonal,.cloffy-banner__diagonal,.fitlys-banner__diagonal,.gift-banner__diagonal,.chocolates-banner__diagonal) {
    display: none;
  }

  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel {
    display: flex;
    flex-direction: column;
  }

  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-inner {
    order: 1;
    flex: 0 0 auto;
    height: auto !important;
    min-height: 0;
    overflow: visible;
  }

  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-item {
    height: auto !important;
    min-height: 0;
    overflow: visible;
  }

  .dhatri-hero .carousel-indicators.dhatri-hero__indicators,
.cloffy-hero .carousel-indicators.cloffy-hero__indicators,
.fitlys-hero .carousel-indicators.fitlys-hero__indicators,
.gift-hero .carousel-indicators.gift-hero__indicators,
.chocolates-hero .carousel-indicators.chocolates-hero__indicators {
    order: 2;
    position: relative !important;
    bottom: auto;
    flex: 0 0 var(--dhatri-indicators-h);
    flex-shrink: 0;
    padding: 12px 0 14px;
    margin: 0 !important;
    background: var(--dhatri-cream);
    border-top: 1px solid rgba(57, 109, 27, 0.08);
    pointer-events: auto;
  }

  :is(.dhatri-hero__indicators,.cloffy-hero__indicators,.fitlys-hero__indicators,.gift-hero__indicators,.chocolates-hero__indicators) [data-bs-target] {
    background: var(--dhatri-dot-inactive);
    height: 5px;
  }

  :is(.dhatri-hero__indicators,.cloffy-hero__indicators,.fitlys-hero__indicators,.gift-hero__indicators,.chocolates-hero__indicators) [data-bs-target].active {
    background: var(--dhatri-dot-active);
    box-shadow: 0 2px 8px rgba(57, 109, 27, 0.28);
  }

  :is(.dhatri-banner,.cloffy-banner,.fitlys-banner,.gift-banner,.chocolates-banner) {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  :is(.dhatri-banner__leaf,.cloffy-banner__leaf,.fitlys-banner__leaf,.gift-banner__leaf,.chocolates-banner__leaf) {
    display: block;
    opacity: 0.2;
    background-size: 64px 64px;
  }

  :is(.dhatri-banner__layout,.cloffy-banner__layout,.fitlys-banner__layout,.gift-banner__layout,.chocolates-banner__layout) {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: none;
    padding: 0;
    height: auto;
    min-height: 0;
    flex: 0 0 auto;
  }

  :is(.dhatri-banner__visual,.cloffy-banner__visual,.fitlys-banner__visual,.gift-banner__visual,.chocolates-banner__visual) {
    order: 1;
    flex: 0 0 260px;
    width: 100%;
    height: 260px;
    min-height: 260px;
    max-height: 260px;
    padding: 8px 4px 16px;
    background: linear-gradient(165deg, var(--dhatri-warm) 0%, var(--dhatri-cream-deep) 55%, #f5ddd0 100%);
    box-sizing: border-box;
    overflow: hidden;
  }

  :is(.dhatri-banner__visual,.cloffy-banner__visual,.fitlys-banner__visual,.gift-banner__visual,.chocolates-banner__visual)::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: 0.45;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cpath fill='%23396d1b' fill-opacity='0.14' d='M32 6c-7 12-18 16-18 28a18 18 0 1 0 36 0c0-12-11-16-18-28z'/%3E%3C/svg%3E");
    background-size: 52px 52px;
  }

  :is(.dhatri-banner__product,.cloffy-banner__product,.fitlys-banner__product,.gift-banner__product,.chocolates-banner__product) {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 100%;
    max-height: 230px;
    object-fit: contain;
    filter:
      drop-shadow(0 12px 22px rgba(57, 109, 27, 0.2))
      drop-shadow(0 24px 40px rgba(57, 109, 27, 0.16));
  }

  :is(.dhatri-banner__tag,.cloffy-banner__tag,.fitlys-banner__tag,.gift-banner__tag,.chocolates-banner__tag) {
    display: none !important;
  }

  :is(.dhatri-banner__copy,.cloffy-banner__copy,.fitlys-banner__copy,.gift-banner__copy,.chocolates-banner__copy) {
    order: 2;
    flex: 0 0 auto;
    height: auto;
    min-height: 0;
    align-items: center;
    text-align: center;
    margin: -20px 12px 30px;
    padding: 16px 14px 6px;
    background: rgba(255, 255, 255, 0.96);
    border-radius: 20px;
    box-shadow:
      0 4px 6px rgba(57, 109, 27, 0.04),
      0 18px 44px rgba(57, 109, 27, 0.12);
    border: 1px solid rgba(57, 109, 27, 0.08);
    z-index: 4;
    justify-content: flex-start;
    overflow: visible;
  }

  :is(.dhatri-banner__eyebrow,.cloffy-banner__eyebrow,.fitlys-banner__eyebrow,.gift-banner__eyebrow,.chocolates-banner__eyebrow) {
    padding: 6px 12px;
    margin-bottom: 10px;
  }

  :is(.dhatri-banner__title,.cloffy-banner__title,.fitlys-banner__title,.gift-banner__title,.chocolates-banner__title) {
    margin-bottom: 8px;
    min-height: 0;
    -webkit-line-clamp: 2;
  }

  :is(.dhatri-banner__lead,.cloffy-banner__lead,.fitlys-banner__lead,.gift-banner__lead,.chocolates-banner__lead) {
    display: block;
    margin-bottom: 12px;
    max-width: none;
    min-height: 0;
    overflow: visible;
    -webkit-line-clamp: unset;
    -webkit-box-orient: unset;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 100%;
    margin: 0 auto 10px;
    padding: 0;
    gap: 6px 0;
    row-gap: 6px;
    overflow: visible;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) li {
    display: inline-flex;
    align-items: center;
    flex: 0 1 auto;
    min-width: 0;
    padding: 0;
    font-size: var(--banner-perk-size);
    line-height: var(--type-body-line, 1.55);
    font-weight: 600;
    color: var(--dhatri-brown-soft);
    background: none;
    border: none;
    border-radius: 0;
    box-shadow: none;
    white-space: nowrap;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) li + li::before {
    content: "/";
    display: inline-block;
    margin: 0 0.45em;
    color: rgba(57, 109, 27, 0.4);
    font-weight: 400;
    flex-shrink: 0;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) i {
    display: none;
  }

  :is(.dhatri-banner__cta,.cloffy-banner__cta,.fitlys-banner__cta,.gift-banner__cta,.chocolates-banner__cta) {
    width: 100%;
    justify-content: center;
    margin-bottom: 16px;
    padding: 14px 18px;
    border-radius: 12px;
  }

  :is(.dhatri-banner__strip,.cloffy-banner__strip,.fitlys-banner__strip,.gift-banner__strip,.chocolates-banner__strip) {
    display: none;
  }
}

@media screen and (max-width: 400px) {
  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) {
    --dhatri-slide-h: auto;
  }

  :is(.dhatri-banner__visual,.cloffy-banner__visual,.fitlys-banner__visual,.gift-banner__visual,.chocolates-banner__visual) {
    flex: 0 0 230px;
    height: 230px;
    min-height: 230px;
    max-height: 230px;
    padding: 6px 2px 12px;
  }

  :is(.dhatri-banner__product,.cloffy-banner__product,.fitlys-banner__product,.gift-banner__product,.chocolates-banner__product) {
    width: 100%;
    max-width: 100%;
    max-height: 200px;
  }

  :is(.dhatri-banner__copy,.cloffy-banner__copy,.fitlys-banner__copy,.gift-banner__copy,.chocolates-banner__copy) {
    margin: -16px 10px 30px;
    padding: 14px 12px 4px;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) li + li::before {
    margin: 0 0.35em;
  }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) {
    --dhatri-indicators-h: 48px;
    --dhatri-slide-h: 440px;
    --banner-title-size: var(--type-heading);
    --banner-title-line: var(--type-heading-line);
    --banner-lead-size: var(--type-body);
    --banner-perk-size: var(--type-body);
    --banner-tag-size: var(--type-body);
    --banner-tag-sub-size: var(--type-body);
  }

  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel {
    display: flex;
    flex-direction: column;
  }

  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-inner {
    order: 1;
    flex: 0 0 var(--dhatri-slide-h);
    height: var(--dhatri-slide-h);
  }

  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-item {
    height: var(--dhatri-slide-h) !important;
    min-height: var(--dhatri-slide-h);
  }

  .dhatri-hero .carousel-indicators.dhatri-hero__indicators,
.cloffy-hero .carousel-indicators.cloffy-hero__indicators,
.fitlys-hero .carousel-indicators.fitlys-hero__indicators,
.gift-hero .carousel-indicators.gift-hero__indicators,
.chocolates-hero .carousel-indicators.chocolates-hero__indicators {
    order: 2;
    position: relative !important;
    bottom: auto;
    flex: 0 0 var(--dhatri-indicators-h);
    padding: 14px 0 16px;
    margin: 0 !important;
    background: var(--dhatri-cream);
    border-top: none;
    pointer-events: auto;
  }

  :is(.dhatri-hero__indicators,.cloffy-hero__indicators,.fitlys-hero__indicators,.gift-hero__indicators,.chocolates-hero__indicators) [data-bs-target] {
    background: var(--dhatri-dot-inactive);
    height: 5px;
  }

  :is(.dhatri-hero__indicators,.cloffy-hero__indicators,.fitlys-hero__indicators,.gift-hero__indicators,.chocolates-hero__indicators) [data-bs-target].active {
    background: var(--dhatri-dot-active);
    box-shadow: 0 2px 8px rgba(57, 109, 27, 0.28);
  }

  :is(.dhatri-banner,.cloffy-banner,.fitlys-banner,.gift-banner,.chocolates-banner) {
    height: 100%;
    min-height: var(--dhatri-slide-h);
    padding: 0;
    box-sizing: border-box;
  }

  :is(.dhatri-banner__leaf,.cloffy-banner__leaf,.fitlys-banner__leaf,.gift-banner__leaf,.chocolates-banner__leaf) {
    display: block;
    opacity: 0.18;
    background-size: 60px 60px;
  }

  :is(.dhatri-banner__layout,.cloffy-banner__layout,.fitlys-banner__layout,.gift-banner__layout,.chocolates-banner__layout) {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    grid-template-areas: "copy visual";
    align-items: stretch;
    gap: clamp(12px, 2vw, 24px);
    max-width: 1280px;
    height: 100%;
    margin: 0 auto;
    padding: clamp(16px, 2.5vw, 28px) clamp(16px, 3vw, 32px);
    background: transparent;
    border-radius: 0;
    overflow: visible;
    box-shadow: none;
    border: none;
  }

  :is(.dhatri-banner__copy,.cloffy-banner__copy,.fitlys-banner__copy,.gift-banner__copy,.chocolates-banner__copy) {
    grid-area: copy;
    height: 100%;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 28px 24px 28px 28px;
  }

  :is(.dhatri-banner__eyebrow,.cloffy-banner__eyebrow,.fitlys-banner__eyebrow,.gift-banner__eyebrow,.chocolates-banner__eyebrow) {
    margin-bottom: 12px;
  }

  :is(.dhatri-banner__title,.cloffy-banner__title,.fitlys-banner__title,.gift-banner__title,.chocolates-banner__title) {
    margin-bottom: 10px;
    min-height: calc(var(--banner-title-line) * 3em);
    -webkit-line-clamp: 3;
  }

  :is(.dhatri-banner__lead,.cloffy-banner__lead,.fitlys-banner__lead,.gift-banner__lead,.chocolates-banner__lead) {
    max-width: none;
    margin-bottom: 16px;
    min-height: calc(var(--banner-lead-line) * 2em);
    -webkit-line-clamp: 2;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) {
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    width: 100%;
    margin: 0 auto 18px;
    gap: 8px;
  }

  :is(.dhatri-banner__perks,.cloffy-banner__perks,.fitlys-banner__perks,.gift-banner__perks,.chocolates-banner__perks) li {
    flex: 0 1 auto;
    justify-content: center;
    text-align: center;
    padding: 8px 12px;
  }

  :is(.dhatri-banner__cta,.cloffy-banner__cta,.fitlys-banner__cta,.gift-banner__cta,.chocolates-banner__cta) {
    padding: 12px 22px;
    border-radius: 100px;
  }

  :is(.dhatri-banner__visual,.cloffy-banner__visual,.fitlys-banner__visual,.gift-banner__visual,.chocolates-banner__visual) {
    grid-area: visual;
    height: 100%;
    min-height: 0;
    padding: 12px 8px;
    background: transparent;
    overflow: hidden;
  }

  :is(.dhatri-banner__visual,.cloffy-banner__visual,.fitlys-banner__visual,.gift-banner__visual,.chocolates-banner__visual)::before {
    display: none;
  }

  :is(.dhatri-banner__product,.cloffy-banner__product,.fitlys-banner__product,.gift-banner__product,.chocolates-banner__product) {
    position: relative;
    z-index: 1;
    max-height: 380px;
    max-width: 96%;
  }

  :is(.dhatri-banner__tag,.cloffy-banner__tag,.fitlys-banner__tag,.gift-banner__tag,.chocolates-banner__tag) {
    width: 76px;
    height: 76px;
    right: 8%;
    bottom: 12%;
  }

  :is(.dhatri-banner__strip,.cloffy-banner__strip,.fitlys-banner__strip,.gift-banner__strip,.chocolates-banner__strip) {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  :is(.dhatri-hero,.cloffy-hero,.fitlys-hero,.gift-hero,.chocolates-hero) .carousel-item {
    transition: none;
  }

  :is(.dhatri-banner,.cloffy-banner,.fitlys-banner,.gift-banner,.chocolates-banner):hover :is(.dhatri-banner__product,.cloffy-banner__product,.fitlys-banner__product,.gift-banner__product,.chocolates-banner__product) {
    transform: none;
  }
}
