/** Shopify CDN: Minification failed

Line 3161:6 Expected identifier but found "setAttribute("
Line 3346:14 Unexpected "{"
Line 3346:23 Expected ":"
Line 3356:14 Unexpected "{"
Line 3356:23 Expected ":"
Line 3357:14 Unexpected "{"
Line 3357:23 Expected ":"
Line 3358:14 Unexpected "{"
Line 3358:23 Expected ":"
Line 3366:16 Unexpected "{"
... and 9 more hidden warnings

**/
/*
 *  1.0. Mixins
*/
#zoom, .product-gallery__thumbnails-holder {
  overflow: -moz-scrollbars-none;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#zoom::-webkit-scrollbar, .product-gallery__thumbnails-holder::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
}

#zoom, .product-gallery__thumbnails-holder {
  overflow: -moz-scrollbars-none;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#zoom::-webkit-scrollbar, .product-gallery__thumbnails-holder::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
}

.product-gallery-item model-viewer, .product-gallery-item__media > * {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
html[dir=rtl] .product-gallery-item model-viewer, .product-gallery-item html[dir=rtl] model-viewer, html[dir=rtl] .product-gallery-item__media > * {
  right: 0;
}
html[dir=ltr] .product-gallery-item model-viewer, .product-gallery-item html[dir=ltr] model-viewer, html[dir=ltr] .product-gallery-item__media > * {
  left: 0;
}

@media screen and (min-width: 768px) {
  .main-product .product-gallery,
.main-product .product-text {
    position: sticky;
    top: 1.25rem;
  }
}
/* -- Product Page Section * -- */
.button--product,
.shopify-payment-button__button {
  height: var(--button-product);
  padding: 0 1.875rem;
}
@media screen and (max-width: 1023px) {
  .button--product,
.shopify-payment-button__button {
    font-size: calc( 					18px / 16 * var(--base-body-size) + 0px 				);
  }
}
@media screen and (min-width: 1024px) {
  .button--product,
.shopify-payment-button__button {
    font-size: calc( 				20px / 16 * var(--base-body-size) + 0px 			);
  }
}

.shopify-payment-button__button--branded {
  padding-inline-start: 0px !important;
  padding-inline-end: 0 !important;
  border-radius: var(--border-radius-buttons) !important;
  border: none !important;
  overflow: hidden;
}
.shopify-payment-button__button--branded div[role=button] {
  padding-inline-start: 1.5rem !important;
  padding-inline-end: 1.5rem !important;
}

.shopify-payment-button__button--hidden,
.unavailable-variant .shopify-payment-button {
  display: none;
}

.add-to-cart.disabled + .shopify-payment-button {
  display: none;
}

product-variants[data-variant-required]:not(.variant-selected) .product-variant__quantity {
  display: none;
}

.product-gallery-item {
  position: relative;
  overflow: hidden;
  width: 100%;
}
.product-gallery-item img {
  border-radius: var(--border-radius-cards);
}
.product-gallery-item__media {
  height: 0;
  width: 100%;
  position: relative;
}
.product-gallery-item model-viewer {
  border-radius: var(--border-radius-cards);
}
.product-gallery-item .shopify-model-viewer-ui {
  width: 100%;
  height: 100%;
}
.product-gallery-item .shopify-model-viewer-ui__controls-overlay {
  opacity: 0;
}

button[data-shopify-xr-hidden] {
  display: none;
}

.shopify-model-viewer-ui .shopify-model-viewer-ui__button--poster {
  border-radius: var(--border-radius-buttons) !important;
  border: none !important;
}

@media screen and (max-width: 1023px) {
  .product-gallery--scroll css-slider:after {
    content: "css-slide";
    position: absolute;
    visibility: hidden;
  }
}
.product-gallery__thumbnails {
  padding-top: 0.5625rem;
  z-index: 9;
}
.product-gallery__thumbnails-holder {
  display: flex;
  flex-direction: row;
  margin: 0;
  padding: 0;
  overflow: auto;
  scroll-behavior: smooth;
}
.product-gallery__thumbnails .thumbnail {
  width: 5.25rem !important;
  opacity: 0.66;
  flex-shrink: 0;
  transition: all 100ms linear;
  position: relative;
  scroll-snap-align: start;
  cursor: pointer;
  overflow: hidden;
  border: 2px solid transparent;
}
.no-touchevents .product-gallery__thumbnails .thumbnail:hover {
  opacity: 1;
  border-color: var(--color-secondary-background-main);
}
.product-gallery__thumbnails .thumbnail.active {
  opacity: 1;
  border-color: var(--color-borders-main) !important;
}
.product-gallery__thumbnails .thumbnail:not(:last-child) {
  margin-inline-end: 0.5625rem;
}
.product-gallery__thumbnails .thumbnail__badge {
  position: absolute;
  top: 0.125rem;
  width: 1.25rem;
  height: 1.25rem;
  opacity: 1;
  transition: opacity 50ms linear;
  z-index: 9;
}
html[dir=rtl] .product-gallery__thumbnails .thumbnail__badge {
  left: 0.125rem;
}
html[dir=ltr] .product-gallery__thumbnails .thumbnail__badge {
  right: 0.125rem;
}
.product-gallery__thumbnails .thumbnail__badge svg {
  width: 100%;
  height: 100%;
}
.product-gallery__thumbnails .thumbnail__badge svg .bg {
  fill: var(--color-background-main);
}
.product-gallery__thumbnails .thumbnail__badge svg .path {
  fill: var(--color-text-main);
}
.product-gallery__thumbnails .thumbnail__badge svg .stroke {
  stroke: var(--color-text-main);
}

.product-gallery__view-in-space {
  margin: 1.5rem auto 0;
}

.product-text .product-price--original {
  font-weight: var(--font-weight-body-bold);
}
.product-text .product-price--compare {
  margin-inline-start: 1.25rem;
}
.product-text .product-price--unit {
  display: block;
}
.product-text > * {
  display: block;
}
.product-text > *:not(:last-child) {
  margin-bottom: 1.25rem;
}
.product-text > .toggle {
  margin-bottom: 1rem !important;
}
.product-text > .toggle:not(.toggle--table) + .toggle:not(.toggle--table) {
  margin-top: -1.25rem !important;
}
.product-text nutritional-info {
  display: block;
}
.product-text nutritional-info:not(:last-child) {
  margin-bottom: 1.25rem;
}
.product-text .empty-space {
  height: 0;
  margin-bottom: 1.25rem;
}
.product-text .star-rating {
  height: 1.75rem;
}
.product-text pickup-availability-compact .alert {
  margin-bottom: 0;
}
.product-text button:not(.button):not(.shopify-payment-button__button) {
  color: inherit;
}

.product-variant:not(:first-child) {
  margin-top: 1.25rem;
}
.product-variant__name {
  font-weight: var(--font-weight-body-bold);
  display: block;
}
.product-variants--select .product-variant__name {
  margin-bottom: 0.625rem;
}
.product-variant__quantity:not(:empty) {
  margin-top: 0.875rem;
  display: block;
}
.product-variants--radio .product-variant__item {
  position: relative;
  display: inline-block;
  margin: 0;
  margin-top: 0.9375rem;
  margin-inline-end: 0.9375rem;
}
.product-variants--radio .product-variant__item label {
  text-align: center;
  display: inline-flex;
  align-items: center;
  border-style: solid;
  border-width: 1px;
  border-radius: var(--border-radius-buttons);
  border-color: var(--color-borders-forms-primary);
  color: var(--color-text-main);
  padding: var(--input-padding) 1.25rem;
  transition: all 100ms linear;
}
.product-variants--radio .product-variant__item .product-variant__item-swatch {
  border-radius: 100%;
  margin-right: 0.5rem;
  width: 1.75rem;
  height: 1.75rem;
  box-shadow: var(--color-borders-main) 0 0 1px 1px;
}
.product-variants--radio .product-variant__item .product-variant__item-swatch img {
  object-fit: cover;
}
.product-variants--radio .product-variant__item input {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  border: none;
  background: transparent;
  opacity: 0;
  cursor: pointer;
}
html[dir=rtl] .product-variants--radio .product-variant__item input {
  right: 0;
}
html[dir=ltr] .product-variants--radio .product-variant__item input {
  left: 0;
}
.product-variants--radio .product-variant__item input:before {
  display: none;
}
.product-variants--radio .product-variant__item input.disabled + label {
  opacity: 0.22;
  text-decoration: line-through;
}
.product-variants--radio .product-variant__item input:checked + label {
  font-weight: var(--font-weight-body-bold);
  border-color: var(--color-text-main) !important;
  box-shadow: 0 0 0px 1px var(--color-text-main);
}
.no-touchevents .product-variants--radio .product-variant__item input:hover + label {
  border-color: var(--color-borders-forms-secondary);
}
.product-variants--radio .product-variant__item input:focus-visible + label {
  box-shadow: 0 0 0 3px var(--color-secondary-background-main);
}

/* -- Product Actions * -- */
.product-actions .product-price {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.product-actions .product-price--original + .product-price--unit {
  margin-inline-start: 1.25rem;
}
.product-actions .product-price--compare {
  text-decoration: none;
  opacity: 1;
  display: inline-flex;
  flex-direction: column;
  line-height: 1.25;
  margin-inline-end: auto;
}
.product-actions .product-price--compare > span:first-child {
  text-decoration: line-through;
}
.product-actions .product-price--compare > span:last-child {
  opacity: 0.62;
  font-size: 90%;
}

.product-form {
  border-top: 1px solid var(--color-borders-main);
  display: block;
  margin-top: 0.5rem;
  margin-bottom: 1.25rem;
  width: 100%;
  overflow: visible;
}
.product-form .flex-buttons {
  width: calc(100% + 1rem);
  margin-inline-start: -0.5rem;
}
.product-form .flex-buttons > * {
  margin: 1rem 0.5rem 0;
}

.product-quantity {
  display: flex;
  justify-content: space-between;
  min-width: calc(var(--button-product) * 3);
}
.product-quantity__minus, .product-quantity__plus {
  width: var(--button-product);
  height: var(--button-product);
  border-width: var(--border-width-buttons);
  border-radius: var(--border-radius-buttons);
  border-style: solid;
  border-color: var(--color-text-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.product-quantity__minus svg, .product-quantity__plus svg {
  width: 1.1875rem;
  height: 1.1875rem;
}
.product-quantity__minus svg *, .product-quantity__plus svg * {
  fill: var(--color-text-main);
}
.no-touchevents .product-quantity__minus:hover, .product-quantity__minus:focus-visible, .no-touchevents .product-quantity__plus:hover, .product-quantity__plus:focus-visible {
  box-shadow: 0 0 0 3px var(--color-secondary-background-main);
}
.product-quantity__selector {
  width: var(--button-product);
  height: var(--button-product);
  border: none;
  background-color: transparent;
  padding: 0;
  text-align: center;
}

.add-to-cart {
  flex-grow: 10;
}
.add-to-cart.disabled {
  pointer-events: none;
  opacity: 0.36;
}
.add-to-cart.disabled + .shopify-payment-button {
  pointer-events: none;
  opacity: 0.36;
}

.product__sku-barcode span {
  display: block;
}

.shopify-payment-button__button {
  border-style: solid;
  border-radius: var(--border-radius-buttons);
  border-width: var(--border-width-buttons);
  color: var(--color-text-main);
  font-weight: var(--font-weight-buttons);
  transition: all 100ms linear;
  background-color: transparent;
}
.shopify-payment-button__button:hover:not([disabled]) {
  background-color: var(--color-accent-main);
  border-color: var(--color-accent-main);
  color: var(--color-foreground-accent-main);
}
.shopify-buttons--not-outline .shopify-payment-button__button {
  background-color: var(--color-text-main);
  color: var(--color-foreground-main);
  border-color: var(--color-text-main);
}

.shopify-payment-button__more-options {
  font-size: 12px;
  margin-top: 0.5rem;
}

/* -- Product Elements * -- */
.pickup-availability-widget {
  display: block;
  border: 1px solid var(--color-borders-main);
  overflow: hidden;
}
.pickup-availability-widget__header {
  background: var(--color-secondary-background-main);
  padding: var(--gutter-small);
  display: flex;
  align-items: center;
}
.pickup-availability-widget__header .alert:before {
  top: 0.1875rem;
}
.pickup-availability-widget__header svg {
  margin-inline-end: 0.9375rem;
}
.pickup-availability-widget__header svg path {
  fill: var(--color-text-main);
  stroke: none;
}
.pickup-availability-widget__locations {
  border-top: 1px solid var(--color-borders-main);
}
.pickup-availability-widget__location {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: space-between;
  padding: var(--gutter-small);
}
.pickup-availability-widget__location:not(:first-child) {
  border-top: 1px solid var(--color-borders-main);
}
.pickup-availability-widget__location-icon {
  margin-inline-end: 0.75rem;
  position: relative;
  top: 0.3125rem;
}
.pickup-availability-widget__location-icon svg {
  width: 1.5rem;
  height: 1.5rem;
}
.pickup-availability-widget__location-icon * {
  stroke: var(--color-text-main);
}
.pickup-availability-widget__location-address {
  flex: 1;
}
.pickup-availability-widget__location-address svg * {
  fill: var(--color-text-main);
}
.pickup-availability-widget__location-view {
  display: block;
}
.pickup-availability-widget__location-view[aria-selected=true] .text-animation--underline-thin {
  background-size: 100% 1px;
}
.pickup-availability-widget__location-view[aria-selected=true] rect {
  display: none;
}
.pickup-availability-widget__location-details {
  display: block;
  width: 100%;
  flex-shrink: 0;
  border-top: 1px solid var(--color-third-background-main);
  padding-top: 0.875rem;
  padding-inline-start: 2.25rem;
  margin-top: 1.125rem;
  display: none;
}
.pickup-availability-widget__location-details.opened {
  display: block;
}
.pickup-availability-widget__more {
  width: 100%;
  text-align: start;
  padding: var(--gutter-small);
  border-top: 1px solid var(--color-borders-main);
}
.pickup-availability-widget__more span {
  border-bottom: 1px solid;
  transition: all 100ms linear;
}
.no-touchevents .pickup-availability-widget__more:hover {
  color: var(--color-accent-main);
}

.store-availability-list__item {
  margin-bottom: 1.875rem;
  padding-bottom: 1.875rem;
  border-bottom: 1px solid var(--color-secondary-background-main);
}
.store-availability-list__stock:before {
  top: 0.1875rem;
}
.store-availability-list__pickup-time {
  margin-top: 0.25rem;
  display: block;
}
.store-availability-list__address, .store-availability-list__phone {
  margin-inline-start: 1.375rem;
  margin-top: 0.75rem;
}
.store-availability-list__address a, .store-availability-list__phone a {
  border-bottom: 1px solid;
}

.product-related-title {
  margin-bottom: 1.5625rem;
  display: block;
}
.product-related-item {
  display: flex;
  align-items: center;
}
.product-related-item:not(:last-child) {
  padding-bottom: 1.125rem;
  margin-bottom: 1.125rem;
  border-bottom: 1px solid var(--color-borders-main);
}
.cart-block__item--spacing .product-related-item {
  padding: var(--gutter-regular);
  margin-bottom: 0;
}
.product-related-item__title {
  line-height: 1.1;
  display: block;
}
.product-related-item__image {
  flex-shrink: 0;
  width: 90px;
  align-self: flex-start;
  margin-inline-end: 1.125rem;
  border-color: var(--color-borders-main);
  overflow: hidden;
}
.product-related-item__image img {
  transition: all 0.2s linear;
  transform: scale(1);
}
.no-touchevents .product-related-item__image:hover img {
  transform: scale(1.05);
}
.product-related-item__text {
  flex-grow: 1;
}
.product-related-item__price {
  color: var(--color-secondary-text-main);
  display: block;
}
.product-related-item__price .product-price--original {
  font-weight: var(--font-weight-body);
}
.product-related-item__price .product-price--compare {
  margin-inline-start: 0.625rem;
}
.product-related-item__price .product-price--unit {
  display: block;
  margin-top: -0.3125rem;
  font-size: 90%;
}
.product-related-item__button {
  flex-shrink: 0;
  margin-inline-start: 0.75rem;
}

/* Image zoom */
.product-gallery-item__zoom {
  position: absolute;
  top: 0.9375rem;
  width: 2.125rem;
  height: 2.125rem;
  padding: 0.3125rem;
  z-index: 99;
  cursor: pointer;
  opacity: 0;
  transition: all 100ms linear 100ms;
  transform: translate3d(0, 0, 0);
}
html[dir=rtl] .product-gallery-item__zoom {
  left: 0.9375rem;
}
html[dir=ltr] .product-gallery-item__zoom {
  right: 0.9375rem;
}
.lazyloaded ~ .product-gallery-item__zoom {
  opacity: 1;
}
.product-gallery-item__zoom svg path, .product-gallery-item__zoom svg rect {
  fill: var(--color-text-main);
}
.product-gallery-item__zoom svg circle {
  stroke: var(--color-text-main);
}
.no-touchevents .product-gallery-item__zoom:hover svg {
  transform: scale(1.05);
}

#zoom {
  position: fixed;
  top: 0;
  width: 100vw;
  height: 100vh;
  overflow: scroll;
  visibility: hidden;
  opacity: 0;
  z-index: -1;
  -webkit-overflow-scrolling: touch;
  background: var(--color-background-main);
  transition: all 200ms linear;
}
html[dir=rtl] #zoom {
  right: 0;
}
html[dir=ltr] #zoom {
  left: 0;
}
html[dir=rtl] #zoom {
  right: 0;
}
html[dir=ltr] #zoom {
  left: 0;
}
#zoom.opened {
  visibility: visible;
  opacity: 1;
  z-index: 99999;
}
#zoom img {
  opacity: 0;
  max-width: none;
  position: absolute;
  top: 0;
  z-index: 7;
  transition: opacity 100ms linear;
}
html[dir=rtl] #zoom img {
  right: 0;
}
html[dir=ltr] #zoom img {
  left: 0;
}
.touchevents #zoom img {
  top: 0 !important;
  left: 0 !important;
}
#zoom.loaded img {
  opacity: 1;
}
#zoom.loaded:after {
  opacity: 0;
}
#zoom.loaded .zoom__loader {
  display: none;
}

.zoom__overlay {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background: var(--color-background-main);
  z-index: 6;
}
html[dir=rtl] .zoom__overlay {
  right: 0;
}
html[dir=ltr] .zoom__overlay {
  left: 0;
}

.zoom__exit {
  z-index: 9;
  position: fixed;
  width: 3rem;
  height: 3rem;
  border-radius: var(--border-radius-buttons);
  background: var(--color-background-main);
  top: 1.5625rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
html[dir=rtl] .zoom__exit {
  left: 1.5625rem;
}
html[dir=ltr] .zoom__exit {
  right: 1.5625rem;
}
.zoom__exit svg path, .zoom__exit svg rect {
  fill: var(--color-text-main);
}
.zoom__exit svg circle {
  stroke: var(--color-text-main);
}
.no-touchevents .zoom__exit:hover svg {
  transform: scale(1.05);
}

.zoom__loader {
  position: absolute;
  margin: 0;
  width: 20px;
  height: 20px;
  transform: translate3d(-50%, -50%, 0);
  top: 50%;
  left: 50%;
  display: block;
  z-index: 9;
}
.zoom__loader-element {
  animation: rotate 2s linear infinite;
  height: 100%;
  transform-origin: center center;
  width: 100%;
  position: absolute;
  top: 0;
  margin: auto;
}
html[dir=rtl] .zoom__loader-element {
  right: 0;
}
html[dir=ltr] .zoom__loader-element {
  left: 0;
}
.zoom__loader-element circle {
  stroke-dasharray: 150, 200;
  stroke-dashoffset: -10;
  animation: dash 1.5s ease-in-out infinite;
  stroke-linecap: round;
  stroke: var(--color-text-main);
}

.product-icons-list-container {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem 0;
}

.star-rating {
  font-size: 0;
  width: 100%;
  height: 1rem;
  display: grid;
  grid-template-columns: max-content auto;
  align-items: center;
  gap: 0.625rem;
}
.star-rating__stars {
  background-repeat: repeat-x;
  font-size: 0;
  display: inline-block;
  text-align: left;
}
html[dir=rtl] .star-rating__stars {
  transform: scaleX(-1);
}
.star-rating__stars-active {
  display: inline-block;
  font-size: 0;
  height: 0.875rem;
  background-repeat: repeat-x;
}

@media screen and (max-width: 767px) {
  .product-quick-view__header {
    position: fixed;
    background: var(--color-background-main);
    border-bottom: 1px solid var(--color-borders-main);
    top: 0;
    right: 0;
    width: 100%;
    height: 3.75rem;
    z-index: 99;
  }

  .product-quick-view__product {
    padding-top: 3.75rem;
  }
}
.product-quick-view__close {
  position: absolute;
  top: calc(var(--gutter-large) * 0.75);
}
html[dir=rtl] .product-quick-view__close {
  left: calc(var(--gutter-large) * 0.75);
}
html[dir=ltr] .product-quick-view__close {
  right: calc(var(--gutter-large) * 0.75);
}
.product-quick-view__close svg path {
  stroke: var(--color-text-main);
}

.product-quick-view__title {
  position: absolute;
  top: calc(var(--gutter-large) * 0.75);
  left: calc(var(--gutter-large) * 0.75);
}

.product-text .stamped-badge-caption {
  margin-inline-start: 8px;
  font-size: 80%;
}
.product-text .yotpo .yotpo-bottomline .yotpo-icon-star, .product-text .yotpo .yotpo-bottomline .yotpo-icon-half-star, .product-text .yotpo .yotpo-bottomline .yotpo-icon-empty-star {
  color: var(--color-text-main);
}
.product-text .yotpo a, .product-text .yotpo a:hover {
  color: var(--color-text-main) !important;
  margin-inline-start: 8px;
  pointer-events: none !important;
}
.product-text .yotpo .standalone-bottomline.star-clickable, .product-text .yotpo .standalone-bottomline .star-clickable {
  cursor: default !important;
}

.modal .shopify-payment-button__button[disabled] {
  display: none;
}

.sticky-add-to-cart {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  background-color: var(--color-background-main);
  box-shadow: 0px -6px 8px rgba(0, 0, 0, 0.08);
  transform: translate(0, 100%);
  color: var(--color-text-main);
}
.sticky-add-to-cart--floating {
  border-radius: clamp(0px, var(--border-radius-cards), 10px);
  box-shadow: 0 0 8px 0px rgba(0, 0, 0, 0.08);
}
.sticky-add-to-cart--floating.visible {
  width: calc(100% - (1.25rem * 2) );
}
html[dir=rtl] .sticky-add-to-cart--floating.visible {
  right: 1.25rem;
  bottom: 1.25rem;
}
html[dir=ltr] .sticky-add-to-cart--floating.visible {
  left: 1.25rem;
  bottom: 1.25rem;
}
@media screen and (max-width: 767px) {
  .sticky-add-to-cart--floating.visible {
    width: calc(100% - (0.625rem * 2) );
  }
  html[dir=rtl] .sticky-add-to-cart--floating.visible {
    right: 0.625rem;
    bottom: 0.625rem;
  }
  html[dir=ltr] .sticky-add-to-cart--floating.visible {
    left: 0.625rem;
    bottom: 0.625rem;
  }
}
.sticky-add-to-cart.visible {
  display: block;
  transform: translate(0, 0);
  transition: linear transform 200ms;
}
.sticky-add-to-cart__inner {
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: var(--gutter-small);
  padding: var(--gutter-small) 0;
}
@media screen and (max-width: 767px) {
  .sticky-add-to-cart__inner {
    display: block;
  }
}
.sticky-add-to-cart__title {
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .sticky-add-to-cart__title {
    display: none;
  }
}
.sticky-add-to-cart__actions {
  display: flex;
  align-items: center;
  gap: var(--gutter-small) var(--gutter-regular);
  justify-self: end;
}
@media screen and (max-width: 474px) {
  .sticky-add-to-cart__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (max-width: 359px) {
  .sticky-add-to-cart__actions {
    display: grid;
    grid-template-columns: 100%;
  }
}
.sticky-add-to-cart__price {
  display: flex;
  margin-left: auto;
  flex: 1 1 auto;
  justify-content: start;
  gap: 0.5rem;
}
@media screen and (max-width: 359px) {
  .sticky-add-to-cart__price {
    display: inline-block;
    text-align: center;
    width: 100%;
  }
  .sticky-add-to-cart__price span {
    padding-inline-start: 0.3125rem;
    padding-inline-end: 0.3125rem;
  }
}
.sticky-add-to-cart__price-compare {
  opacity: 0.54;
  text-decoration: line-through;
}
.sticky-add-to-cart__button {
  margin-right: auto;
  flex: 1 1 auto;
}
@media screen and (max-width: 767px) {
  .sticky-add-to-cart__button .button {
    width: 100%;
    height: 2.875rem;
    padding-inline-end: 1.25rem;
    padding-inline-start: 1.25rem;
  }
}
@media screen and (max-width: 359px) {
  .sticky-add-to-cart__button {
    margin: 0;
    justify-content: center;
  }
}
.sticky-add-to-cart .button--outline {
  border-color: var(--color-text-main);
}
.sticky-add-to-cart .button--outline .button__text {
  color: var(--color-text-main) !important;
}
.sticky-add-to-cart .button--solid {
  border-color: var(--color-text-main);
  background-color: var(--color-text-main);
}
.sticky-add-to-cart .button--solid .button__text {
  color: var(--color-background-main) !important;
}
.sticky-add-to-cart .button--solid .button__preloader circle {
  stroke: var(--color-background-main) !important;
}

/* ───────────────────────────────────────────────────────────────────────────
   1) RESET FIELDSET/LEGEND
──────────────────────────────────────────────────────────────────────────── */
.mysite-subscription-fieldset {
  border: none;
  margin: 16px 0 0;
  padding: 0;
}
.mysite-subscription-fieldset legend {
  margin-bottom: 12px;
  padding: 0;
}

/* 2) STYLE THE LEGEND ("Select your frequency: Subscribe & Save 20%") */
.mysite-subscription-legend {
  display: flex;
  align-items: baseline;
  font-size: 18px;
  font-weight: 500;
  color: #111111;
}
.mysite-subscription-legend .mysite-discount-text {
  margin-left: 8px;
  font-size: 16px;
  font-weight: 600;
  color: #0f9f2d; /* green accent for "Subscribe & Save 20%" */
}

/* 3) SHARED “OPTION‐WRAPPER” STYLING (one‐time + subscription) */
.option-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-radius: 8px;
  margin-bottom: 12px;
  position: relative;
  transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
}

/* 6) PRICE TAG (shared) */
.option-price {
  font-size: 18px;
  font-weight: 600;
  color: #111111;
}



/* ── Round just the top & bottom label blocks ── */
.shopify_subscriptions_app_container 
  .shopify_subscriptions_app_block_label:first-of-type {
  border-top-left-radius: 16px  !important;
  border-top-right-radius: 16px !important;
}
.shopify_subscriptions_app_container 
  .shopify_subscriptions_app_block_label:last-of-type {
  border-bottom-left-radius: 16px  !important;
  border-bottom-right-radius: 16px !important;
  /* remove its own bottom border so it matches the container’s curve */
  border-bottom: none !important;
}

/* ── Add space between each Shopify “toggle-tab” section ── */
.product-text toggle-tab,
.product-text .toggle {
  display: block !important;
  margin-bottom: 2.5rem !important;  /* adjust as needed */
}

/* Remove extra gap after the last one */
.product-text toggle-tab:last-of-type,
.product-text .toggle:last-of-type {
  margin-bottom: 0 !important;
}

/* ── Compact toggle headers ── */
/* Strip out the big padding on the wrapper */
.product-text toggle-tab,
.product-text .toggle {
  padding: 0 !important;
}

/* Give the title just enough breathing room */
.product-text toggle-tab .toggle__title,
.product-text .toggle .toggle__title {
  padding: 1.25rem 1rem !important; /* adjust vertical/horizontal padding */
  font-size: 1rem           !important; /* slightly smaller text if desired */
  line-height: 1.25         !important;
}

/* Shrink the icon wrapper so it doesn’t add extra height */
.product-text toggle-tab .toggle__icon-title,
.product-text .toggle .toggle__icon-title {
  width: 1.5rem  !important;
  height: 1.5rem !important;
  margin-right: 0.5rem !important;
}

/* (You already have margin-bottom between toggles; no change needed there) */

/* ── Replace toggle arrows with + / – icons ── */
/* 2) Make the title position itself for our pseudo‐icon */
.product-text toggle-tab .toggle__title,
.product-text .toggle .toggle__title {
  position: relative !important;
  padding-right: 2.5rem !important; /* room for our symbol */
}

/* 3) Add a circular “+” after each closed title */
.product-text toggle-tab .toggle__title::after,
.product-text .toggle .toggle__title::after {
  content: "+" !important;
  position: absolute !important;
  right: 1rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 1.5rem !important;
  height: 1.5rem !important;
  line-height: 1.5rem !important;
  text-align: center !important;
  border-radius: 50% !important;
  background: #000 !important;
  color: #fff !important;
}

/* 4) Switch to “–” when expanded */
.product-text toggle-tab .toggle__title[aria-expanded="true"]::after,
.product-text .toggle .toggle__title[aria-expanded="true"]::after {
  content: "–" !important;
}

/* ── Fully hide the built-in arrow icon ── */
.product-text toggle-tab .toggle__icon,
.product-text .toggle .toggle__icon {
  display: none !important;
}

/* ── Re-add our +/– via pseudo-element ── */
.product-text toggle-tab .toggle__title,
.product-text .toggle .toggle__title {
  position: relative !important;
  padding-right: 2.5rem !important; /* room for our symbol */
}

.product-text toggle-tab .toggle__title::after,
.product-text .toggle .toggle__title::after {
  content: "+" !important;
  position: absolute !important;
  right: 1rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 1.5rem !important;
  height: 1.5rem !important;
  line-height: 1.5rem !important;
  text-align: center !important;
  border-radius: 50% !important;
  background: #000 !important;
  color: #fff !important;
}

.product-text toggle-tab .toggle__title[aria-expanded="true"]::after,
.product-text .toggle .toggle__title[aria-expanded="true"]::after {
  content: "–" !important;
}


/* ── CLEAN TOGGLE STYLING ── */

/* 1) Hide the default SVG icon entirely */
.product-text toggle-tab .toggle__icon,
.product-text .toggle .toggle__icon {
  display: none !important;
}

/* 2) Tighten up the toggle container */
.product-text toggle-tab,
.product-text .toggle {
  background-color: #f5f5f5 !important; /* light grey panel */
  padding: 0.75rem 0.75rem !important;      /* less vertical padding */
  margin-bottom: 2.5rem !important;      /* existing spacing */
  border-radius: 0.5rem !important;      /* softer corners */
  border: none !important;               /* drop any border */
}

/* 3) Style the title text */
.product-text toggle-tab .toggle__title,
.product-text .toggle .toggle__title {
  font-size: 1rem   !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  position: relative !important;         /* for our pseudo‐icon */
  padding-right: 2rem !important;        /* room for the +/– */
}

/* 4) Inject a plain +, no circle, on closed toggles */
.product-text toggle-tab .toggle__title::after,
.product-text .toggle .toggle__title::after {
  content: "+"                         !important;
  position: absolute                  !important;
  right: 1rem                         !important;
  top: 50%                            !important;
  transform: translateY(-50%)        !important;
  font-size: 1.25rem                  !important;
  font-weight: bold                   !important;
  color: var(--color-text-main)       !important;
  background: none                    !important;
  width: auto !important; height: auto !important;
  line-height: normal !important;
  border-radius: 0 !important;
}

/* 5) Swap to a “–” when the section is open */
.product-text toggle-tab .toggle__title[aria-expanded="true"]::after,
.product-text .toggle .toggle__title[aria-expanded="true"]::after {
  content: "–" !important;
}



/* ───────────────────────────────────────────────────────────────────────────
   [1] KEEP ALL OF YOUR EXISTING CSS ABOVE THIS LINE, UNTOUCHED
   ────────────────────────────────────────────────────────────────────────── */


/* ───────────────────────────────────────────────────────────────────────────
   [3] PANEL STYLING ON EACH SHOPIFY LABEL DIV
   We treat each .shopify_subscriptions_app_block_label as its own “card.”
──────────────────────────────────────────────────────────────────────────── */

/* 3a) Default look for every panel */
.shopify_subscriptions_app_container
  .shopify_subscriptions_app_block_label {
  background:    #f8f8f8    !important;
  border:        1px solid #ddd!important;
  border-radius: 0.75rem    !important;
  padding:       1rem       !important;
  margin-bottom: 1.5rem     !important;
}

/* 3b) Remove bottom margin on the very last panel */
.shopify_subscriptions_app_container
  .shopify_subscriptions_app_block_label:last-of-type {
  margin-bottom: 0 !important;
}

/* 3c) Highlight the one with `.highlight` (your JS already toggles this) */
.shopify_subscriptions_app_container
  .shopify_subscriptions_app_block_label.highlight {
  background:    #ffffff    !important;
  border:        2px solid #000!important;
}

/* 3d) Tuck the nested radio list down from its header */
.shopify_subscriptions_app_container
  .shopify_subscriptions_app_block_label
  .shopify_subscriptions_app_block_label_children {
  margin-top: 1rem !important;
}

/* ───────────────────────────────────────────────────────────────────────────
   [4] END OF SUBSCRIPTIONS PANEL OVERRIDES
──────────────────────────────────────────────────────────────────────────── */


/* ── SHOPIFY SUBSCRIPTIONS PANEL OVERRIDES ── */


/* 2) Style each “card” (label) */
.shopify_subscriptions_app_block_label {
  background:    #f8f8f8    !important;
  border:        1px solid #ddd!important;
  border-radius: 0.75rem    !important;
  padding:       1rem       !important;
  margin-bottom: 1.5rem     !important;
}

/* 3) No extra gap on the last one */
.shopify_subscriptions_app_block_label:last-of-type {
  margin-bottom: 0 !important;
}

/* 4) Highlight whichever has your JS’s .highlight class */
.shopify_subscriptions_app_block_label.highlight {
  background:    #ffffff    !important;
  border:        2px solid #000!important;
}

/* 5) Tuck its nested radio list down under the header */
.shopify_subscriptions_app_block_label
  .shopify_subscriptions_app_block_label_children {
  margin-top: 1rem !important;
}



/* ── SHOPIFY SUBSCRIPTIONS: STYLE EACH “CARD” ── */
.shopify_subscriptions_app_block_label {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin-bottom: 1.5rem !important;
}

.shopify_subscriptions_app_block_label:last-of-type {
  margin-bottom: 0 !important;
}
/* ── HIGHLIGHT THE ONE WITH A CHECKED RADIO ── */
.shopify_subscriptions_app_block_label:has(input[type="radio"]:checked) {
  background:    #ffffff    !important;
  border:        2px solid #000!important;
}
/* ── Tuck the nested plan list down just a hair ── */
.shopify_subscriptions_app_block_label
  .shopify_subscriptions_app_block_label_children {
  margin-top: 1rem !important;
}

/* remove the “group” wrapper border around both cards */
.shopify_subscriptions_app_container
  .shopify_subscriptions_fieldset > div {
  border: none !important;
  box-shadow: none !important;
  border-radius: 0     !important;
  padding:       0     !important;
  margin:        0     !important;
}

/* make the space between your two “cards” white again */
.shopify_subscriptions_app_container
  .shopify_subscriptions_fieldset {
  background-color: #fff !important;
}

/* if you also need the immediate inner div white, too */
.shopify_subscriptions_app_container
  .shopify_subscriptions_fieldset > div {
  background-color: #fff !important;
}




/* ─── Mega-menu: increase overall width ─── */
.mega-menu-item-container {
  width: 800px !important;
  max-width: 100% !important;
  padding: 1rem !important;
}

/* ─── turn the UL into a 2-column flex grid ─── */
.mega-menu-item-container .mm-product-list {
  display: flex;
  flex-wrap: wrap;
  margin: -1rem; /* compensate for item padding */
}

/* ─── each LI becomes half the container ─── */
.mega-menu-item-container .mm-product-list li {
  width: calc(50% - 2rem);
  margin: 1rem;
  box-sizing: border-box;
}


/* ─── bump up the product title & price ─── */
.mega-menu-item-container .mm-product-name .mm-title {
  font-size: 1.1rem !important;
  line-height: 1.3 !important;
}

.mega-menu-item-container .mega-menu-price .money {
  font-size: 1rem !important;
  font-weight: 600;
}

.product-form .button {
  background-color: #97d700 !important; /* bright green */
  color: #000000 !important;           /* black text */
  border: none;
  border-radius: 1rem;                 /* optional: rounded corners */
}


.product-buttons-wrapper .flex-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
}

.product-buttons-wrapper button[name="add"],
.product-buttons-wrapper .shopify-payment-button__button {
  min-height: 56px; /* consistent button height */
  flex: 1 1 auto;
  border-radius: 1rem;
}


.product-buttons-wrapper {
  margin-top: 1rem;
}

.product-buttons-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: stretch;
}

.product-buttons-row button[name="add"],
.product-buttons-row .shopify-payment-button__button {
  min-height: 56px;
  flex: 1;
  border-radius: 1rem;
  font-weight: bold;
  font-size: 16px;
  padding: 12px;
}


/* Fix inconsistent button row height */
.shopify-payment-button .shopify-payment-button__button {
  min-height: 56px !important;
  height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px;
  font-weight: bold;
  border-radius: 12px;
}

/* Match Add to Cart button height as well */
button[name="add"].button--product {
  min-height: 56px !important;
  height: 56px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: bold;
  border-radius: 12px;
}

/* Ensure both buttons sit in a stable row */
.flex-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.flex-buttons > * {
  flex: 1 1 auto;
}





/* Normalize button height across purchase modes */
.product-buttons-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.product-buttons-row .shopify-payment-button__button,
.product-buttons-row button[name="add"] {
  min-height: 56px !important;
  height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  font-weight: bold !important;
  border-radius: 12px !important;
  padding: 0 20px !important;
  width: 100%;
}

.product-buttons-wrapper {
  display: flex;
  flex-direction: column;
}

@media (min-width: 640px) {
  .product-buttons-row {
    flex-wrap: nowrap;
  }
  .product-buttons-row > * {
    flex: 1 1 0;
  }
}

#shopify-buyer-consent {
  display: none !important;
}




@media screen and (max-width: 749px) {
  .product-form__buttons {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .product-form__quantity {
    margin-bottom: 1rem !important;
    width: 100% !important;
  }

  .product-form__submit {
    width: 100% !important;
    display: block !important;
  }

  .shopify-payment-button {
    width: 100% !important;
  }

  .shopify-payment-button__button {
    width: 100% !important;
    display: block !important;
    text-align: center !important;
  }

  .shopify-payment-button__more-options {
    text-align: center;
    margin-top: 0.5rem;
  }
}



.product-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.pill-icon img {
  height: 16px;
  width: 16px;
  margin-right: 0.5rem;
}

.product-feature-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.75rem 0 1rem 0;
}

.pill-icon {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  background-color: #f4f4f4;
  color: #333;
  font-size: 0.875rem;
  font-weight: 500;
  box-shadow: inset 0 0 0 1px #ddd;
  transition: all 0.2s ease;
}

.pill-icon:hover {
  background-color: #eaeaea;
}

.pill-icon::before {
  font-size: 1rem;
  margin-right: 0.4rem;
}

.product-feature-pills {
  margin-bottom: 0.5rem;
}


.feature-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

.feature-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  background: linear-gradient(to bottom right, #f3f3f3, #e9e9e9);
  border-radius: 999px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
  font-size: 14px;
  font-weight: 500;
  color: #333;
  transition: transform 0.2s ease;
}

.feature-badge:hover {
  transform: scale(1.05);
}

.feature-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 6px;
  color: #4CAF50; /* Green for Vegan by default */
}

.feature-badge {
  padding: 6px 14px;
}

.feature-icon svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.feature-icon {
  margin-right: 6px;
  display: flex;
  align-items: center;
}

.feature-badge {
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
  background: #f9f9f9;
  border: 1px solid #e0e0e0;
}

.feature-badge[data-icon="vegan"] {
  background-color: #e9f8ef;
  color: #2e7d32;
}
.feature-badge[data-icon="gluten-free"] {
  background-color: #fef6f6;
  color: #c62828;
}

.feature-icon svg {
  vertical-align: middle;
  margin-top: 1px; /* tweak as needed */
}

.feature-badge:hover .feature-icon svg {
  color: #4CAF50;
}

.feature-badge {
  transition: transform 0.2s ease;
}
.feature-badge:hover {
  transform: translateY(-1px) scale(1.02);
}

.feature-icon {
  display: flex;
  align-items: center;
  margin-right: 6px;
}

.feature-icon svg {
  vertical-align: middle;
  stroke: #4CAF50; /* or use currentColor and override per badge */
}


.feature-badge[data-icon="vegan"] svg {
  stroke: #4CAF50;
}
.feature-badge[data-icon="gluten-free"] svg {
  stroke: #F44336;
}
.feature-badge[data-icon="vegetarian"] svg {
  stroke: #8BC34A;
}
.feature-badge[data-icon="gmo-free"] svg {
  stroke: #9C27B0;
}

.feature-badge:hover {
  box-shadow: 0 3px 6px rgba(0,0,0,0.08);
  transform: translateY(-1px);
}

.feature-badge-row {
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
}

.feature-badge {
  font-weight: 600;
}

.feature-badge:hover {
  background-color: #f3f3f3;
  transform: translateY(-1px);
}


.shopify_subscriptions_app_block label {
  display: flex;
  align-items: center;
  padding: 0.5rem 0;
  font-size: 15px;
  gap: 0.5rem;
  cursor: pointer;
  transition: background 0.2s;
}

.shopify_subscriptions_app_block input[type="radio"] {
  appearance: none;
  width: 18px;
  height: 18px;
  border: 2px solid #bbb;
  border-radius: 50%;
  background: white;
  display: inline-block;
  position: relative;
}

.shopify_subscriptions_app_block input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 8px;
  height: 8px;
  background: #000;
  border-radius: 50%;
}

.shopify_subscriptions_app_block input[type="radio"]:checked + span {
  background-color: #f0f8f5;
  border-radius: 8px;
  padding: 4px 8px;
}

.shopify_subscriptions_in_widget_price {
  font-style: italic;
  color: #888;
  font-size: 14px;
  margin-top: 4px;
}

.shopify_subscriptions_app_block label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  font-size: 15px;
  padding: 0.5rem 0;     /* Reduce padding */
  border: none;          /* Remove border */
  background: none;      /* Remove background */
  margin: 0;             /* No bottom margin */
  border-radius: 0;
  transition: none;
}

.shopify_subscriptions_app_block input[type="radio"] {
  appearance: none;
  width: 18px;
  height: 18px;
  border: 2px solid #bbb;
  border-radius: 50%;
  background: white;
  position: relative;
  flex-shrink: 0;
}

.shopify_subscriptions_app_block input[type="radio"]:checked {
  border-color: #4CAF50;
}

.shopify_subscriptions_app_block input[type="radio"]:checked::after {
  content: "";
  width: 12px;
  height: 12px;
  background: #97d700;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
}


.shopify_subscriptions_app_block input[type="radio"]:checked + span {
  background-color: #97d700;
  border-color: #4CAF50;
}

/* Clean up default card styling */
.shopify_subscriptions_app_block_label {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin-bottom: 1rem !important;
  box-shadow: none !important;
}

.shopify_subscriptions_app_block_label + .shopify_subscriptions_app_block_label {
  margin-top: 0.75rem !important;
}


.subscription-most-popular {
  display: inline-block;
  background-color: #97d700;
  color: #111;
  font-size: 0.75rem;
  font-weight: bold;
  padding: 2px 6px;
  border-radius: 999px;
  margin-left: 8px;
  text-transform: uppercase;
}


.shopify_subscriptions_app_block label {
  font-size: 14px;
  font-style: italic;
  color: #555;
  font-weight: 400;
}


.shopify_subscriptions_app_block_label.shopify_subscriptions_purchase_option_wrapper > label,
.shopify_subscriptions_purchase_option_wrapper > label {
  font-weight: 700;
  font-size: 16px;
  color: #111;
}





/* --- BUNDLE CONTAINER --- */
.gbbMultipleCategoriesContainerHTML {
  background: #f9f7f2;
  padding: 2rem;
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
  font-family: 'Helvetica Neue', sans-serif;
}

/* --- PRODUCT CARD --- */
.gbbProductItem {
  background: #fff !important;
  border-radius: 12px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
  transition: transform 0.2s ease;
  padding: 1rem;
}

.gbbProductItem:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
  transform: translateY(-4px);
  transition: all 0.25s ease;
}

.gbbProductTitleOnly {
  font-weight: 600;
  font-size: 1rem;
  color: #2b2b2b;
}

.gbbProductItemPrice {
  font-weight: 500;
  margin-top: 0.5rem;
  font-size: 0.95rem;
  color: #6c6c6c;

}

/* --- ADD BUTTON --- */
.gbbProductAddButton {
  background: #bca464 !important;
  color: #fff !important;
  border-radius: 8px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* --- SIDECART BUNDLE PREVIEW --- */
.gbbPageFooterHTML {
  background: #fff;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06);
  max-width: 360px;
}

.gbbFooterBundleTitle {
  font-size: 1.25rem;
  font-weight: 700;
  color: #333;
}

.gbbDiscountMessage {
  padding: 0.75rem;
  margin-top: 1rem;
  border-radius: 8px;
  color: #4b4b4b;
  background-color: #fefaf3;
  border-left: 4px solid #d3b05a;
  font-size: 0.9rem;
}

/* --- ADD TO CART BUTTON --- */
.gbbFooterNextButton {
  font-weight: 600;
  padding: 0.75rem;
  transition: background 0.3s ease;
  background: #b1892f !important;
  color: #fff !important;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 600;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}

.gbbFooterNextButton:hover {
  background: #9d7426 !important;
}

.gbbProductAddButtonGroup {
  background-color: #f3f3f3;
  border-radius: 999px;
  padding: 0.25rem 0.5rem;
  font-weight: 600;
  box-shadow: inset 0 0 2px rgba(0,0,0,0.1);
}

.gbbProductAddButtonGroup > * {
  margin: 0 0.25rem;
}


.product-description-card {
  background: #fdfbf7;
  border-radius: 16px;
  padding: 2rem;
  margin-top: 2rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  max-width: 620px;
}

.product-description-card h2 {
  font-size: 1.5rem;
  margin-bottom: 1rem;
  color: #2b2b2b;
  font-weight: 600;
}

.product-benefits-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 1rem;
  font-weight: 600;
  font-family: inherit;
  color: #111;
}

.product-benefits-list li {
  margin-bottom: 0.8rem;
  padding-left: 1.5rem;
  position: relative;
  text-transform: uppercase;
}

.product-benefits-list li::before {
  content: "✔";
  position: absolute;
  left: 0;
  color: #3ca552;
  font-size: 1rem;
}

.product-benefits-box {
  background: #f9f9f9;
  border: 1px solid #e3e3e3;
  border-radius: 12px;
  padding: 1.5rem;
  margin-top: 2rem;
  max-width: 620px;
}


.product-benefits-box {
  background: #f9f9f9;
  border: 1px solid #e0e0e0;
  border-radius: 12px;
  padding: 1.5rem 1.75rem;
  margin-top: 2rem;
  max-width: 650px;
  font-family: inherit;
}

.product-benefits-heading {
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: #222;
}

.product-benefits-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 1rem;
  color: #111;
}

.product-benefits-list li {
  position: relative;
  padding-left: 1.8rem;
  margin-bottom: 0.75rem;
  font-weight: 500;
  text-transform: none;
}

.product-benefits-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: #3cb150;
  font-size: 1.2rem;
  line-height: 1;
}


.product-shipping-info {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 1.5rem;
  background-color: #fdfdfd;
  padding: 0.75rem 1rem;
  border-radius: 8px;
  border: 1px solid #e0e0e0;
}

.shipping-icon {
  font-size: 1.5rem;
  line-height: 1;
  margin-top: 2px;
}

.shipping-text p {
  margin: 0;
  color: #444;
  font-size: 0.95rem;
  line-height: 1.4;
}


.shipping-highlight-box {
  background: #fdfdfc;
  border: 1px solid #e5e5e5;
  border-radius: 12px;
  padding: 1.2rem 1.5rem;
  margin-top: 1.75rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

.shipping-icon-text {
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
}

.shipping-icon {
  font-size: 1.5rem;
  line-height: 1;
  margin-top: 2px;
}

.shipping-text {
  font-size: 0.96rem;
  color: #333;
}

.shipping-line {
  margin: 0;
  line-height: 1.5;
}



.btn-premium-cta {
  display: inline-block;
  background: #ec6323;
  color: white;
  padding: 14px 28px;
  border-radius: 999px;
  font-weight: bold;
  font-size: 1.1rem;
  text-decoration: none;
  text-align: center;
  transition: all 0.2s ease-in-out;
  box-shadow: 0 8px 16px rgba(236, 99, 35, 0.2);
  position: relative;
}

.btn-premium-cta:hover {
  transform: scale(1.05);
  box-shadow: 0 12px 24px rgba(236, 99, 35, 0.3);
}

.btn-premium-cta:active {
  transform: scale(0.97);
}

.btn-premium-cta .cta-subtext {
  display: block;
  font-size: 0.75rem;
  font-weight: normal;
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.85);
}


.benefits-card {
  background: #fcfcfc;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
  margin-bottom: 2rem;
  font-family: inherit;
}

.benefits-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: #1a1a1a;
  text-align: left;
}

.benefits-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.benefits-list li {
  display: flex;
  align-items: start;
  font-size: 1rem;
  margin-bottom: 0.75rem;
  line-height: 1.5;
  color: #333;
}

.benefit-icon {
  font-size: 1.2rem;
  margin-right: 0.6rem;
  flex-shrink: 0;
}


.benefits-card {
  background: #ffffff;
  border-radius: 16px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.06);
  padding: 1rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.benefits-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
}


.info-bullet-block {
  font-size: 1rem;
  line-height: 1.7;
  color: #333;
  margin-top: 1.5rem;
}

.info-bullet-block p {
  margin-bottom: 1rem;
}

.info-bullet-block ul.indented-lines {
  padding-left: 1.5rem;
  margin-top: -0.5rem;
  margin-bottom: 1rem;
}

.info-bullet-block ul.indented-lines li {
  margin-bottom: 0.5rem;
}

.bundle-info p,
.bundle-info li {
  line-height: 1.6;
  margin-bottom: 1rem;
}


.bundle-benefits-card {
  background: #fef7f0;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
  font-family: 'Helvetica Neue', sans-serif;
  margin-bottom: 2rem;
}

.bundle-benefits-card h3 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1.25rem;
}

.bundle-benefits-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
}

.bundle-benefits-list li {
  display: flex;
  align-items: flex-start;
  margin-bottom: 1rem;
  font-size: 1rem;
  line-height: 1.6;
}

.bundle-benefits-list li span {
  display: inline-block;
  width: 1.5rem;
  margin-right: 0.5rem;
  font-size: 1.2rem;
}

.bundle-benefits-list a {
  color: #ff6600;
  text-decoration: underline;
}

.bundle-benefits-list .nested {
  list-style: none;
  padding-left: 1.5rem;
  margin-top: 0.5rem;
}

.bundle-benefits-list .nested li {
  font-size: 0.95rem;
  margin-bottom: 0.4rem;
}

/* Shipping Box Styling */
.shipping-highlight-box {
  background-color: #fff7e6;
  border: 1px solid #f5d4a3;
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  align-items: center;
}

.shipping-icon-text {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.shipping-icon {
  font-size: 1.5rem;
  margin-top: 0.2rem;
}

.shipping-text .shipping-line {
  margin: 0;
  font-size: 0.95rem;
}


.bundle-benefits-card {
  background: #fef7f0;
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
  margin-bottom: 2rem;
}

.bundle-benefits-card h3 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  text-align: center;
}

/* Simplified benefits grid - scannable for cold traffic */
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.85rem;
  margin-bottom: 1.5rem;
}

.benefit-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
  background: white;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.benefit-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.benefit-icon-simple {
  font-size: 1.75rem;
  line-height: 1;
  flex-shrink: 0;
}

.benefit-item strong {
  font-size: 0.95rem;
  font-weight: 600;
  color: #2c2416;
  line-height: 1.3;
}

@media (max-width: 640px) {
  .benefits-grid {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .benefit-item {
    padding: 0.65rem 0.85rem;
  }

  .benefit-icon-simple {
    font-size: 1.5rem;
  }

  .benefit-item strong {
    font-size: 0.9rem;
  }
}

/* Contact CTA Section */
.contact-cta-section {
  background: #fef5f1;
  padding: 3rem 2rem;
  text-align: center;
  margin: 3rem 0;
  border-radius: 0;
}

.contact-cta-heading {
  font-size: 2rem;
  font-weight: 700;
  color: #000;
  margin: 0 0 2rem;
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: -0.5px;
}

.contact-cta-button {
  display: inline-block;
  background: white;
  color: #000 !important;
  font-weight: 700;
  font-size: 1rem;
  padding: 1.25rem 4rem;
  border: 3px solid #000;
  border-radius: 50px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.3s ease;
}

.contact-cta-button:hover {
  background: #000;
  color: white !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

@media (max-width: 640px) {
  .contact-cta-section {
    padding: 2.5rem 1.5rem;
    margin: 2rem 0;
  }

  .contact-cta-heading {
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
  }

  .contact-cta-button {
    padding: 1rem 3rem;
    font-size: 0.9rem;
    width: 100%;
    max-width: 350px;
  }
}

/* ===========================
   NO LIST SECTION
   =========================== */

.no-list-section {
  background: white;
  padding: 4rem 2rem;
  margin: 3rem 0;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.no-list-title {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: left;
  margin: 0 0 2rem 0;
  color: #000;
  letter-spacing: 2px;
}

.no-list-content {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 0;
  padding-top: 0;
}

.no-list-full-image {
  width: 100%;
  max-width: 800px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.no-list-grid {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.no-list-image {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
}

.no-list-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.no-list-item {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 1.5rem;
}

.no-list-icon {
  width: 70px;
  height: 70px;
  flex-shrink: 0;
}

.no-list-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.no-list-item > div:last-child {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1;
}

.no-list-heading {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
  color: #000;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  line-height: 1.3;
}

.no-list-text {
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0;
  color: #555;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .no-list-section {
    padding: 3rem 1.5rem;
  }

  .no-list-title {
    font-size: 2rem;
    margin-bottom: 2rem;
  }

  .no-list-content {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .no-list-icon {
    width: 50px;
    height: 50px;
  }

  .no-list-heading {
    font-size: 0.95rem;
  }

  .no-list-text {
    font-size: 0.9rem;
  }
}

/* ===========================
   FAQ SECTION
   =========================== */

.faq-section {
  background: #FFF5F5;
  padding: 4rem 2rem;
  margin: 3rem 0;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.faq-title {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin: 0 0 3rem 0;
  color: #000;
  letter-spacing: 2px;
}

.faq-content {
  max-width: 900px;
  margin: 0 auto;
}

.faq-item {
  background: white;
  border-radius: 8px;
  margin-bottom: 1rem;
  overflow: hidden;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.faq-question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 2rem;
  background: white;
  border: none;
  text-align: left;
  font-size: 1.1rem;
  font-weight: 700;
  color: #000;
  cursor: pointer;
  transition: background 0.3s ease;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.faq-question:hover {
  background: #FAFAFA;
}

.faq-toggle {
  font-size: 1.8rem;
  font-weight: 400;
  color: #000;
  flex-shrink: 0;
  margin-left: 1rem;
  line-height: 1;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
  padding: 0 2rem;
}

.faq-item.active .faq-answer {
  max-height: 500px;
  padding: 0 2rem 1.5rem 2rem;
}

.faq-answer p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: #555;
}

@media (max-width: 768px) {
  .faq-section {
    padding: 3rem 1.5rem;
  }

  .faq-title {
    font-size: 2rem;
    margin-bottom: 2rem;
  }

  .faq-question {
    padding: 1.25rem 1.5rem;
    font-size: 1rem;
  }

  .faq-answer {
    padding: 0 1.5rem;
  }

  .faq-item.active .faq-answer {
    padding: 0 1.5rem 1.25rem 1.5rem;
  }
}

/* Legacy styles - keeping for backwards compatibility */
.benefit-row {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.benefit-icon {
  font-size: 1.4rem;
  line-height: 1.4;
  width: 1.5rem;
  text-align: center;
}

.benefit-text {
  font-size: 1rem;
  line-height: 1.6;
  margin: 0;
}

/* Optional link styling */
.benefit-text a {
  color: #ff6600;
  text-decoration: underline;
}

.benefit-icon {
  font-size: 1.4rem;
  width: 1.5rem;
  text-align: center;
  line-height: 1.6;
  margin-top: 0.1rem; /* NEW */
}

.benefit-text br {
  margin-bottom: 0.4rem;
  display: block;
  content: "";
}

.benefit-text a {
  color: #e15a00;
  text-decoration: underline;
  font-weight: 500;
}

.shipping-highlight-box {
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.gbbMultipleCategoriesPageHTML,
.gbbMultipleCategoriesContainerHTML {
  padding: 2px !important;
}


.featured-review {
  background-color: #fffbe8;
  border-left: 4px solid #f4aa28;
  padding: 8px 12px;
  margin-top: 8px;
  margin-bottom: 8px;
  font-size: 14px;
  line-height: 1.4;
  border-radius: 4px;
  max-width: 100%;
}

.featured-review__stars {
  color: #ffc107;
  font-size: 14px;
  margin-bottom: 4px;
  line-height: 1;
}

.featured-review__text {
  font-style: italic;
  margin: 0;
  padding: 0;
}

.featured-review__author {
  font-weight: bold;
  font-size: 13px;
  margin-top: 4px;
}




.swiper {
  width: 100%;
  padding: 1rem 0;
}

.swiper-slide blockquote {
  font-size: 1rem;
  font-style: italic;
  margin: 0 0 0.5rem;
}

.featured-review-slider-container {
  position: relative;
  width: 100%;
  max-width: 600px;
  margin: 0 auto 2rem;
  z-index: 1;
}

.featured-review-swiper {
  padding: 1rem;
  background: #fff;
  border-radius: 8px;
  min-height: 100px; /* Avoid jump */
  overflow: hidden;
}

.swiper-slide {
  text-align: left;
}

.swiper-pagination {
  margin-top: 10px;
  text-align: center;
}


.featured-review-swiper {
  background: #fff;
  border-radius: 8px;
  padding: 1rem 1.5rem;
  margin: 1rem 0;
  max-width: 600px;
}

.swiper-slide blockquote {
  font-style: italic;
  font-size: 1rem;
  line-height: 1.5;
  margin: 0 0 0.5rem 0;
  color: #333;
}

.featured-review__author {
  font-weight: bold;
  font-size: 0.9rem;
  color: #111;
}

/* Style the dots */
.swiper-pagination-bullet {
  background: #ccc;
  opacity: 1;
  width: 10px;
  height: 10px;
  margin: 0 4px !important;
  border-radius: 50%;
  transition: background 0.3s ease;
}

.swiper-pagination-bullet-active {
  background: #222;
}

.product-reviews {
  margin: 0.5rem 0 0.75rem !important;
  padding: 0 !important;
  line-height: 1.1;
}



/* Shrink Judge.me star review section */
.jdgm-preview-badge {
  font-size: 0.85rem !important;
  line-height: 1.2 !important;
  margin: 0.25rem 0 0.5rem !important;
  padding: 0 !important;
}

.jdgm-stars {
  font-size: 1rem !important;
  margin-right: 0.4rem !important;
}

.jdgm-review-count {
  font-size: 0.85rem !important;
  color: #111 !important;
}



/* Target the entire container from Shopify block */
.shopify-block.shopify-app-block {
  margin-top: 0.25rem !important;
  margin-bottom: 0.5rem !important;
  padding: 0 !important;
}

/* Tighten the inner Judge.me badge */
.jdgm-widget.jdgm-preview-badge {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0.85rem !important;
  line-height: 1.2 !important;
}

/* Reduce spacing on star + text display */
.jdgm-prev-badge__stars,
.jdgm-prev-badge__text {
  vertical-align: middle;
  font-size: 0.9rem !important;
  line-height: 1 !important;
  margin: 0 !important;
}

/* Optional: shrink the star size slightly */
.jdgm-star {
  font-size: 1rem !important;
}

.product__title, 
.product__info h1, 
.product-title {
  font-size: clamp(1.75rem, 5vw, 2.75rem) !important;
  line-height: 1.05 !important;
  white-space: normal !important; /* allow wrapping */
  word-break: break-word;
}

.product__info {
  padding-right: 0 !important;
}




.bundle-benefits-card p,
.bundle-benefits-card .benefit-text {
  line-height: 1.4; /* default might be 1.6+ */
  margin-bottom: 0.4rem; /* tighten bottom spacing */
}

.bundle-benefits-card .benefit-row {
  margin-bottom: 0.75rem; /* was likely 1rem+ */
}


.jdgm-star, 
.jdgm-star.jdgm--on, 
.jdgm-preview-badge__stars .jdgm-star,
.jdgm-all-reviews-rating__stars .jdgm-star,
.jdgm-widget .jdgm-star {
  color: #FFB800 !important;
  fill: #FFB800 !important;
}


/* -- Reset app block chrome -- */
.gbbExtBundleUpsellWrapper,
.gbbExtBundleUpsellContainer,
.gbbExtBundleUpsell,
.gbbExtBundleUpsellBody,
.gbbExtBundleUpsellActionContainer {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* -- Placement spacing under ATC -- */
#shopify-block-AQ3hRaC9pY0MxWENCN__eb_easy_bundle_builder_app_block_bundle_upsell_VFHMCb {
  margin-top: 10px;       /* tighter than before */
  margin-bottom: 10px;
}

/* -- Native-looking button -- */
.gbbExtBundleRedirectButton{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;                     /* match ATC height */
  padding: 0 18px;

  font: inherit;
  font-weight: 600;
  letter-spacing: .01em;

  background: #fff;
  color: #111;
  border: 1px solid rgba(17,17,17,.28); /* lighter outline than before */
  border-radius: 14px;                  /* matches your rounded CTAs */
  transition: background-color .2s ease, border-color .2s ease, transform .04s ease;
  cursor: pointer;
}

.gbbExtBundleRedirectButton:hover{
  background: #f7f7f7;
  border-color: rgba(17,17,17,.45);
}
.gbbExtBundleRedirectButton:active{ transform: translateY(1px); }

/* Chevron (subtle) */
.gbbExtBundleRedirectButton::after{
  content: "›";
  margin-left: 8px;
  transform: translateY(-1px);
  opacity: .7;
}

/* Desktop: sit side-by-side with ATC if your theme stacks buttons in a row */
@media (min-width: 900px){
  .product-form .product-form__buttons,
  .product-form .buttons,
  .product-form .shopify-payment-button__button--unbranded{
    /* no change; just scoping */
  }
  #shopify-block-AQ3hRaC9pY0MxWENCN__eb_easy_bundle_builder_app_block_bundle_upsell_VFHMCb{
    /* if your ATC area is a grid/flex row, let this size like a button */
    flex: 1 1 100%;
  }
}

.gbbExtBundleRedirectButton{
  display: inline-flex; align-items:center; justify-content:center;
  width:100%; min-height:52px; padding:0 18px;
  font: inherit; font-weight:600; letter-spacing:.01em;
  color: #111;
  background: var(--button-primary-background, #a6e050);
  border: 1px solid var(--button-primary-background, #a6e050);
  border-radius:14px;
  transition: filter .2s ease, transform .04s ease;
  cursor:pointer;
}
.gbbExtBundleRedirectButton:hover{ filter: brightness(.96); }
.gbbExtBundleRedirectButton:active{ transform: translateY(1px); }





/* Best Seller ribbon for GBB cards */
.gbbProductItem .ribbon-bestseller{
  position:absolute;
  top:10px; left:-10px;
  background:#0f9d58; /* brand green */
  color:#fff;
  padding:6px 14px;
  font-weight:700;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.03em;
  transform:rotate(-12deg);
  border-radius:8px;
  box-shadow:0 6px 16px rgba(0,0,0,.12);
  z-index:5;
}
/* Ensure card can host absolute children */
.gbbProductItem{ position:relative; overflow:visible; }

.ribbon-tag{ background:#111; color:#fff; }
.ribbon--green{ background:#0f9d58; }
.ribbon--amber{ background:#eab308; }
.ribbon--red{ background:#ef4444; }

/* Keep edges clean */
.gbbProductItem{ overflow:visible; } 
.gbbProductButtonWrapper{ z-index:10; position:relative; }

/* Clean, aligned BEST SELLER badge */
.gbbProductItem .ribbon-bestseller {
  position: absolute;
  top: 10px;
  left: 10px;
  background: #0f9d58;         /* green */
  color: #fff;
  padding: 6px 12px;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
  z-index: 5;
  transform: none;             /* removes the tilt */
}

/* Optional: adjust slightly on mobile */
@media (max-width: 420px) {
  .gbbProductItem .ribbon-bestseller {
    font-size: 0.7rem;
    padding: 5px 10px;
    top: 8px;
    left: 8px;
  }
}

.gbbProductItem .gbbProductImageContainer{ position:relative; }
.gbbProductItem .ribbon-bestseller{ top:10px; left:10px; }
@media (max-width:420px){
  .gbbProductItem .ribbon-bestseller{ top:8px; left:8px; font-size:.7rem; padding:5px 10px; }
}
.gbbProductItem .ribbon-bestseller.pill{ border-radius:999px; padding:6px 14px; }

.ribbon--blue {
  background: #2563eb; /* blue-600 */
  color: #fff;
}

.ribbon--amber {
  background: #f59e0b; /* amber-500 */
  color: #fff;
}

/* Base badge (no hard-coded color) */
.gbbProductItem .ribbon-bestseller{
  position:absolute; top:10px; left:10px;
  background: var(--ribbon-bg, #0f9d58); /* default green */
  color:#fff; padding:6px 12px; font-weight:700; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.02em;
  border-radius:10px; box-shadow:0 6px 16px rgba(0,0,0,.12); z-index:5;
  transform:none; border:2px solid rgba(255,255,255,.9); text-shadow:0 1px 0 rgba(0,0,0,.25);
}

/* Place inside image */
.gbbProductItem .gbbProductImageContainer{ position:relative; }

@media (max-width:420px){
  .gbbProductItem .ribbon-bestseller{ top:8px; left:8px; font-size:.7rem; padding:5px 10px; }
}

/* Color modifiers (just set the var) */
.ribbon--green { --ribbon-bg:#0f9d58; }
.ribbon--blue  { --ribbon-bg:#2563eb; }  /* Sundown Mix: New */
.ribbon--amber { --ribbon-bg:#f59e0b; }  /* Vida Mix: Trending Now */


/* Gift-bundle nudge */
.bundle-nudge {
  position: fixed; right: 16px; bottom: 16px; z-index: 9999;
  width: 320px; max-width: calc(100vw - 32px);
  background: #fff; border: 1px solid #e5e7eb; border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
  padding: 14px 14px 12px; display: none; opacity: 0; transform: translateY(8px);
  font-family: inherit;
}
.bundle-nudge.show { display:block; opacity:1; transform: translateY(0); transition: opacity .25s, transform .25s; }
.bundle-nudge__title { font-weight: 700; font-size: 15px; margin: 0 24px 6px 0; line-height: 1.35; }
.bundle-nudge__sub { font-size: 13px; color: #444; margin: 0 0 10px; }
.bundle-nudge__row { display:flex; gap:8px; align-items:center; margin-top: 8px; }
.bundle-nudge__pill { font-size: 12px; padding: 4px 8px; border-radius: 999px; background:#f3f4f6; }
.bundle-nudge__cta { display:flex; gap:8px; margin-top: 10px; }
.bundle-nudge button {
  appearance:none; border:0; padding:10px 12px; border-radius: 10px; cursor:pointer; font-weight:700; font-size: 14px;
}
.bundle-nudge .btn-primary { background:#111; color:#fff; flex:1; }
.bundle-nudge .btn-ghost   { background:#f3f4f6; color:#111; }
.bundle-nudge__close {
  position:absolute; top:8px; right:8px; width:28px; height:28px;
  display:grid; place-items:center; border-radius:8px; background:#f3f4f6; cursor:pointer;
}
@media (max-width:480px){
  .bundle-nudge { right:12px; bottom:12px; width: 92vw; }
}

/* lift the popup above the chat/help widget */
.bundle-nudge{ bottom: 112px; right: 16px; }
@media (max-width: 480px){
  .bundle-nudge{ bottom: 132px; right: 12px; } /* a bit higher on mobile */
}

:root{ --help-widget-h: 84px; }           /* adjust if your “Need help?” changes */
.bundle-nudge{ bottom: calc(var(--help-widget-h) + 16px); right:16px; }
@media (max-width:480px){
  .bundle-nudge{ bottom: calc(var(--help-widget-h) + 20px); right:12px; }
}

@media (prefers-reduced-motion: reduce){
  .bundle-nudge.show{ transition:none; }
}
nudge.setAttribute('aria-label','Suggested best-selling gift bundle');
nudge.querySelector('#bundle-nudge-add').setAttribute('aria-describedby','bundle-nudge-desc');

@media (max-width: 480px) {
  .bundle-nudge__cta {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .bundle-nudge__cta .btn-primary,
  .bundle-nudge__cta .btn-ghost {
    width: 100%;
  }
}
@media (max-width: 480px) {
  .bundle-nudge {
    bottom: 100px; /* adjust based on help widget height */
    right: 12px;
  }
}

/* 📱 Mobile optimization for bundle popup */
@media (max-width: 480px) {
  .bundle-nudge {
    bottom: 90px;          /* lifts popup above "Need help?" bubble */
    right: 12px;
    max-width: 85vw;       /* fits within screen without crowding */
    padding: 0.75rem 1rem;
  }

  .bundle-nudge__title {
    font-size: 0.95rem;
    line-height: 1.2;
    margin-bottom: 0.25rem;
  }

  .bundle-nudge__sub {
    font-size: 0.8rem;
    line-height: 1.3;
    margin-bottom: 0.5rem;
  }

  .bundle-nudge__pill {
    font-size: 0.75rem;
    padding: 3px 8px;
  }

  .bundle-nudge__cta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 0.5rem;
  }

  .bundle-nudge__cta .btn-primary,
  .bundle-nudge__cta .btn-ghost {
    width: 100%;
    text-align: center;
    font-size: 0.85rem;
    padding: 8px;
  }
}

.gbbAddProductPageSubtext-secondary {
  font-size: 0.9rem;
  color: #444;
  margin-top: 4px;
  line-height: 1.4;
  text-align: center;
}

@media (max-width: 480px) {
  .gbbAddProductPageSubtext-secondary {
    font-size: 0.8rem;
    padding: 0 8px;
  }
}

.best-selling-bundle-link {
  color: #0f9d58; /* or your accent color */
  font-weight: 600;
  text-decoration: underline;
  cursor: pointer;
}

.best-selling-bundle-link:hover {
  text-decoration: none;
  opacity: 0.85;
}


/* Fix cropping: kill intrinsic-padding on the lazy wrapper and make the img fill */
    .hh-viewport .product-gallery-item .lazy-image{
      padding-top: 0 !important;
      height: 560px;                /* adjust if you want a taller/shorter hero */
    }
    .hh-viewport .product-gallery-item .lazy-image img{
      position: static !important;  /* undo absolute positioning from theme */
      width: 100%;
      height: 100%;
      object-fit: contain;          /* no cropping */
    }

    /* Hide native slider UI so it can’t fight our logic */
    .product-gallery .css-slider-button,
    .product-gallery .css-slider-pagination { display: none !important; }

    /* Clean white canvas for the main image */
    .hh-viewport{
      background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;
      padding:28px;max-width:560px;margin:0 auto 10px;
    }
    .main-product .product-gallery{max-width:560px}

    /* Tall hero area with contained media */
    .hh-viewport .product-gallery-item img,
    .hh-viewport .product-gallery-item video,
    .hh-viewport .product-gallery-item model-viewer{
      width:100%;height:560px;object-fit:contain;display:block;
    }

    /* Hide any default dots/arrows */
    .hh-slider .css-slider-pagination,
    .hh-slider .css-slider-arrow{display:none !important}

    /* Thumbnail strip */
    .hh-thumbs{
      display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));
      gap:10px;max-width:560px;margin:8px auto 0;padding:0;list-style:none;
    }
    .hh-thumb{
      width:100%;aspect-ratio:1/1;border:1px solid rgba(0,0,0,.08);
      border-radius:12px;background:#fff;padding:4px;cursor:pointer;
      transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
    }
    .hh-thumb:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.06)}
    .hh-thumb.is-active{border-color:#9BE22D}
    .hh-thumb-img{width:100%;height:100%;object-fit:cover;border-radius:8px}

    @media (max-width:640px){
      .hh-viewport{padding:18px;border-radius:14px}
      .hh-viewport .product-gallery-item img,
      .hh-viewport .product-gallery-item video{height:420px}
    }

    /* TLH rating — polished inline style */
    .tlh-rating{display:inline-flex;align-items:center;gap:.45rem;line-height:1.2}
    .tlh-stars{display:inline-flex;gap:.22rem;line-height:1}
    .tlh-star{width:14px;height:14px;fill:currentColor;transform:translateY(1px)} /* baseline align */
    .tlh-reviews-label{font-weight:600;letter-spacing:.005em}

    /* Pill badge treatment */
    .tlh-rating.as-badge{
      padding:.35rem .55rem;
      border-radius:9999px;
      background: rgba(230,182,34,.12); /* soft gold tint */
      color:#E6B622;
      gap:.4rem;
    }


    /* Slightly soften the gold (optional) */
    .tlh-rating{color: #E6B622;} /* remove if you want to inherit text color */
      

    /* Hide native rating/count just for the bundle product */
    .template-product .product__title-wrapper .rating,
    .product .rating__caption {
      display:none !important;
    }


    /* 1) Kill any native slider dots/arrows entirely */
    .product-gallery .css-slider-pagination,
    .product-gallery .css-slider-index-nav,
    .product-gallery .css-slider-button{ display:none !important; }

    /* 2) Use the old full-bleed framed look instead of the white canvas */
    .hh-viewport{
      padding:0 !important;
      background:transparent !important;
      border:0 !important;   /* let the frame live on the image wrapper instead */
    }

    /* The frame lives on the lazy-image wrapper so it “fills” the product image */
    #product-{{ section.id }} .product-gallery-item .lazy-image{
      padding-top:0 !important;         /* avoid crop */
      height:560px;                     /* keep your hero height; adjust if needed */
      border:1px solid rgba(0,0,0,.08); /* faint outline */
      border-radius:16px;               /* match your theme’s corners */
      overflow:hidden;                  /* keep corners crisp */
      background:#fff;                  /* subtle card fill like before */
    }

    /* Make the actual media sit nicely inside the frame */
    #product-{{ section.id }} .product-gallery-item .lazy-image img,
    #product-{{ section.id }} .product-gallery-item .lazy-image video,
    #product-{{ section.id }} .product-gallery-item .lazy-image model-viewer{
      position:static !important;
      width:100%;
      height:100%;
      object-fit:contain;               /* no cropping */
    }

    @media (max-width:640px){
      #product-{{ section.id }} .product-gallery-item .lazy-image{ height:420px; }
    }

    /* Hide the theme’s dot nav for this product’s slider */
    #css-slider-{{ section.id }} .css-slider-dot-navigation{
      display: none !important;
    }

    /* Remove any extra space the slider reserves for dots */
    #css-slider-{{ section.id }} .css-slider-viewport{
      padding-bottom: 0 !important;
    }
    #css-slider-{{ section.id }} .css-slider-holder{
      margin-bottom: 0 !important;
    }

    /* Style tracker when it's inside the discount module (new position) */
    .gbbDiscountFooterHTML .free-ship-tracker{
      border:1px solid #e6e6e6;border-radius:12px;padding:12px;margin:0 0 12px;background:#fafafa
    }
    .gbbDiscountFooterHTML .free-ship-tracker .fst-message{font-weight:600;font-size:14px;margin-bottom:8px;line-height:1.3}
    .gbbDiscountFooterHTML .free-ship-tracker .fst-bar{height:8px;border-radius:999px;background:#eee;overflow:hidden}
    .gbbDiscountFooterHTML .free-ship-tracker .fst-fill{height:100%;width:0%;background:#10B981;transition:width .3s ease}
    .gbbDiscountFooterHTML .free-ship-tracker.met{background:#f0fff4;border-color:#bbf7d0}

    /* Hide EasyBundles' native free-shipping / notification bar */
    .gbbDiscountMessageContainer {
      display: none !important;
    }

    .progressBarContainer {
      display: none !important;
    }

    /* Card when mounted inside the purple discount box */
  .gbbDiscountFooterHTML .free-ship-tracker{
    border:1px solid #e6e6e6;border-radius:14px;padding:14px 16px;margin:0 0 12px;background:#fff;
    box-shadow:0 1px 0 rgba(0,0,0,.03);
  }
  .gbbDiscountFooterHTML .fst-row{margin-bottom:12px}
  .gbbDiscountFooterHTML .fst-row:last-child{margin-bottom:0}

  .gbbDiscountFooterHTML .fst-title{
    display:flex; align-items:center; gap:8px;
    font-weight:700; font-size:15px; line-height:1.2; margin-bottom:6px;
  }
  .gbbDiscountFooterHTML .fst-sub{
    font-size:13px; opacity:.8; margin-top:2px;
  }

  .gbbDiscountFooterHTML .fst-pill{
    font-size:11px; font-weight:700; border-radius:999px; padding:3px 8px; line-height:1;
    background:#f2f2f2; display:inline-block;
  }
  .gbbDiscountFooterHTML .met .fst-pill{ background:#dcfce7 }

  .gbbDiscountFooterHTML .fst-bar{height:8px;border-radius:999px;background:#eee;overflow:hidden}
  .gbbDiscountFooterHTML .fst-fill{height:100%;width:0%;background:#10B981;transition:width .3s ease}

  /* Completed row look */
  .gbbDiscountFooterHTML .met .fst-title{ color:#166534 }
  .gbbDiscountFooterHTML .met .fst-fill{ background:#16a34a }

  /* Footer layout: row 1 = Total + ATC, row 2 = tracker */
  .gbbPageFooterHTML .gbbFooterActionContainer{
    display:flex !important;
    align-items:center !important;
    gap:12px !important;
    flex-wrap:wrap !important;                 /* allows the tracker to sit below */
  }

  /* Keep TOTAL on the left */
  .gbbPageFooterHTML .gbbFooterTotalContainer{
    order:1;
    flex:0 1 auto !important;
    margin:0 !important;
    white-space:nowrap;
  }

  /* Keep ADD TO CART on the same row (no full-width) */
  .gbbPageFooterHTML .gbbFooterButtonsWrapper{
    order:2;
    flex:0 0 auto !important;
    width:auto !important;
    margin-left:auto !important;               /* pushes it to the right */
    white-space:nowrap;
  }
  .gbbPageFooterHTML .gbbFooterButtonsWrapper .gbbFooterNextButton{
    width:auto !important;                     /* override any 100% width */
    display:inline-flex !important;
  }

  /* Tracker sits on its own line below */
  .gbbPageFooterHTML .free-ship-tracker{
    order:3;
    flex:1 1 100% !important;                  /* full width on the next row */
    width:100% !important;
    margin-top:8px !important;
  }

  /* Optional: stack on very small screens */
  @media (max-width: 640px){
    .gbbPageFooterHTML .gbbFooterButtonsWrapper{ margin-left:0 !important; }
  }


  /* === TLH: Polished rating badge === */
  .tlh-rating{display:inline-flex;align-items:center;gap:.45rem;line-height:1.2}
  .tlh-stars{display:inline-flex;gap:.22rem;line-height:1}
  .tlh-star{width:14px;height:14px;fill:currentColor;flex:0 0 auto;transform:translateY(1px)}
  .tlh-reviews-label{font-weight:600;letter-spacing:.005em}

  /* Optional: pill/“chip” treatment */
  .tlh-rating.as-badge{
    padding:.35rem .55rem;
    border-radius:9999px;
    background:rgba(230,182,34,.12);  /* soft gold tint */
    color:#E6B622;
    gap:.4rem;
  }

  /* Optional: compact social-proof subclaim */
  .tlh-mid-dot{opacity:.6;margin:0 .35rem 0 .25rem}
  .tlh-reviews-sub{font-weight:500;opacity:.85}
  @media (max-width:480px){ .tlh-reviews-sub{display:none;} }

  /* (If needed) bring the badge a touch closer to the title — adjust selector to match your DOM */
  .product__title + .tlh-rating{ margin-top:.35rem; }

  /* --- Contrast + hierarchy --- */
  .tlh-rating.as-badge{
    background: rgba(230,182,34,.10);
    border: 1px solid rgba(230,182,34,.18);
    box-shadow: 0 1px 0 rgba(230,182,34,.08) inset;
    border-radius: 9999px;
    padding: .34rem .70rem .34rem .90rem;  /* left indent */
    gap: .46rem;
    color: #E6B622;                        /* star color via currentColor */
  }

  /* main line: darker, crisper */
  .tlh-reviews-label{
    color: #2f2a1f;        /* darker than gold for readability */
    font-weight: 700;
    letter-spacing: .003em;
  }

  /* sub-claim: softer tone + different font to avoid monotony */
  .tlh-reviews-sub{
    color: #9e7f2a;
    font: italic 500 .98rem var(--font-heading-family, Georgia, serif);
    opacity: .95;
  }

  /* divider dot: lighter, not competing with text */
  .tlh-mid-dot{ color:#d7b24a; opacity:.7; margin: 0 .40rem 0 .32rem }

  /* stars: sit nicely on the baseline */
  .tlh-stars{ gap:.20rem }
  .tlh-star{ width:13px; height:13px; transform: translateY(.5px); opacity:.95 }

  .tlh-rating.as-badge{ position: relative; }
  .tlh-rating.as-badge::before{
    content:""; position:absolute; left:.56rem; top:50%;
    width:6px; height:6px; border-radius:9999px;
    background:#E6B622; box-shadow:0 0 0 2px rgba(230,182,34,.20);
    transform:translateY(-50%);
  }

  @media (max-width:640px){
    .tlh-star{ width:12px; height:12px }
    .tlh-rating.as-badge{ padding:.28rem .56rem .28rem .78rem }
    .tlh-reviews-sub{ font-size:.94rem }
  }

  /* Remove the left accent dot inside the pill */
  .tlh-rating.as-badge::before{
    content: none !important;
    display: none !important;
  }

  /* Reduce the left indent now that the dot is gone */
  .tlh-rating.as-badge{
    padding-left: .56rem;  /* was .90rem */
  }

  /* Muted but still gold for the main label */
  .tlh-reviews-label{
    color: #d9a928;       /* softer gold */
    font-weight: 600;
    font-size: 0.95rem;   /* touch smaller */
    letter-spacing: 0.002em;
  }

  /* Keep divider dot black */
  .tlh-mid-dot{
    color: #000;
    opacity: .8;
  }

  

  /* Use your real container class here */
  .star-rating, .rating-pill { color:#111 !important; }

  /* Keep stars gold (works if stars use currentColor) */
  .star-rating .tlh-stars,
  .star-rating .stars,
  .rating-pill .tlh-stars,
  .rating-pill .stars,
  .star-rating svg,
  .rating-pill svg {
    color:#cfa335 !important;
    fill:#cfa335 !important; /* for SVGs that use fill */
  }

  .free-ship-tracker {
  border-radius: 0.75rem;
  background: #fff;
  padding: 0.85rem 1rem 1rem;
  margin-bottom: 0.75rem;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  font-size: 0.92rem;
  line-height: 1.35;
}

.free-ship-tracker {
  background: linear-gradient(135deg, #fff8e1 0%, #ffecb3 100%) !important;
  border: 2px solid #fbbf24 !important;
  border-radius: 12px !important;
  padding: 16px 18px !important;
  margin: 0 0 16px !important;
  box-shadow: 0 4px 12px rgba(251, 191, 36, 0.15) !important;
}

.free-ship-tracker.met {
  background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%) !important;
  border-color: #10b981 !important;
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.15) !important;
}

.free-ship-tracker .fst-row.fst-combined {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.free-ship-tracker .fst-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  color: #222;
  font-size: 0.9rem;
  line-height: 1.2;
}

.free-ship-tracker .fst-pill {
  background: #f3f3f3;
  border-radius: 999px;
  font-weight: 600;
  padding: 0.2rem 0.6rem;
  font-size: 0.75rem;
  color: #111;
}

.free-ship-tracker .fst-sub {
  color: #1a1a1a;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.4;
  margin-top: -2px;
}

.free-ship-tracker .fst-bar {
  width: 100%;
  height: 8px;
  background: rgba(0, 0, 0, 0.08);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 0.3rem;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

.free-ship-tracker .fst-fill {
  height: 100%;
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
  width: 0%;
  transition: width 0.4s ease;
  box-shadow: 0 0 8px rgba(251, 191, 36, 0.5);
}

.free-ship-tracker .fst-row.met .fst-fill {
  background: linear-gradient(90deg, #10b981, #34d399);
  box-shadow: 0 0 8px rgba(16, 185, 129, 0.5);
}

.free-ship-tracker strong {
  font-weight: 700;
  color: #111;
}

.free-ship-tracker .fst-code {
  background: #1a1a1a;
  color: #fbbf24;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 800;
  font-size: 1.05em;
  letter-spacing: 0.5px;
  display: inline-block;
  border: 1px solid rgba(0, 0, 0, 0.2);
}

.free-ship-tracker em {
  color: #999;
  font-style: normal;
}

/* Preferred: when placed inside the white discount module container */
    .gbbDiscountFooterHTML .tlh-first-order-banner{
      background:#FFF8E7;
      border:1px solid rgba(0,0,0,.08);
      border-radius:12px;
      padding:12px 16px;
      margin:0 0 12px 0;            /* same rhythm as the module below */
      font-size:.95rem; line-height:1.3;
      color:#614018; font-weight:600;
      text-align:left; box-shadow:0 1px 0 rgba(0,0,0,.03);
    }

    /* Fallback: if we end up under the title in the info container,
      pull the banner to the edges by countering container padding */
    .gbbFooterBundleInfoContentContainer .tlh-first-order-banner{
      background:#FFF8E7;
      border:1px solid rgba(0,0,0,.08);
      border-radius:12px;
      padding:12px 16px;
      margin:12px -14px 10px;       /* <— negative margins to span full width */
      font-size:.95rem; line-height:1.3;
      color:#614018; font-weight:600;
      text-align:left; box-shadow:0 1px 0 rgba(0,0,0,.03);
    }

    /* Tighten on small screens */
    @media (max-width:640px){
      .gbbFooterBundleInfoContentContainer .tlh-first-order-banner{ margin:10px -10px 8px; }
    }

    .gbbDiscountFooterHTML .tlh-first-order-banner,
    .gbbFooterBundleInfoContentContainer .tlh-first-order-banner{
      font-size: 0.86rem !important;
      line-height: 1.24 !important;
    }

    /* Whole message: smaller, crisper */
    .tlh-first-order-banner{
    font-size: 0.88rem !important;
    line-height: 1.26 !important;
    font-weight: 600;
    color: #1b1b1b;
    letter-spacing: .003em;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    }

    /* De-emphasize the opener */
    .tlh-first-order-banner .tlh-muted{
    opacity: .78;
    font-weight: 600;
    }

    /* Hero part: 10% OFF */
    .tlh-first-order-banner .tlh-em{
    font-weight: 800;
    font-size: 1.02rem;
    letter-spacing: .01em;
    /* Very subtle lift; remove if you don’t want any shadow */
    text-shadow: 0 1px 0 rgba(255,255,255,.45);
    }

    /* Code styling: clear & scannable without changing the banner box */
    .tlh-first-order-banner .tlh-code{
    font: 700 .92em/1.1 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    padding: 0 6px;
    border-radius: 6px;
    border-bottom: 2px dotted rgba(0,0,0,.22);
    background: transparent;
    }

    /* If you still have <strong> in the markup, keep it bold but not shouty */
    .tlh-first-order-banner strong{ font-weight: 700; }

    .tlh-first-order-banner {
      font-size: 0.85rem !important;    /* smaller overall */
      line-height: 1.25 !important;
      font-weight: 500;
      color: #1a1a1a;
      letter-spacing: 0.003em;
      -webkit-font-smoothing: antialiased;
    }

    .tlh-first-order-banner .tlh-muted {
      font-weight: 500;
      opacity: 0.7;                     /* deemphasize intro */
    }

    .tlh-first-order-banner .tlh-em {
      font-weight: 700;                 /* clean bold, not too thick */
      font-size: 0.9rem;                /* slightly larger for contrast */
      letter-spacing: 0.02em;
      text-shadow: none;               /* crisp, modern look */
    }

    .tlh-first-order-banner .tlh-code {
      font: 600 0.85rem/1.1 ui-monospace, Menlo, Monaco, Consolas, monospace;
      padding: 0 6px;
      background: #f8f8f8;
      border: 1px dashed rgba(0,0,0,0.15);
      border-radius: 6px;
    }

    .bundle-value-note {
  text-align: center;
  margin: 14px auto 8px;
  padding: 6px 12px;
  max-width: 260px;

  font-size: 0.86rem;
  font-weight: 500;
  line-height: 1.3;
  color: #444;

  background: #faf9f6;
  border-radius: 999px;
  box-shadow: 0 0 0 1px #e9e6e0, 0 1px 3px rgba(0,0,0,0.03);
  letter-spacing: 0.01em;
  animation: fadeUp 0.25s ease-out both;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (min-width: 768px) {
  .bundle-value-note {
    font-size: 0.9rem;
    margin-top: 16px;
  }
}
</style>
<style>
.tlh-first-order-banner {
  margin-bottom: 0 !important;
}

.free-ship-tracker {
  margin-top: 0 !important;
}

.gbbDiscountFooterHTML {
  gap: 0 !important;
}

.free-ship-tracker {
  padding: 0.6rem 0.9rem !important; /* tighter vertical + slightly reduced horizontal */
}

/* tighten spacing between text and progress bar */
.free-ship-tracker .fst-row.fst-combined {
  gap: 0.25rem !important;
}

.free-ship-tracker .fst-sub {
  margin-top: 0 !important;
}
</style>
<style>
.tlh-first-order-banner {
  padding: 0.45rem 0.75rem !important;   /* tighter vertical & horizontal space */
  font-size: 0.9rem;
  border-radius: 0.75rem;
  line-height: 1.3;
}

/* optional – make both banners visually aligned */
.tlh-first-order-banner,
.free-ship-tracker {
  box-shadow: 0 0 0 1px #f2f0ec;
}