/** Shopify CDN: Minification failed

Line 6849:0 Expected "}" to go with "{"

**/
* {
  box-sizing: border-box;
}

body {
  color: var(--color-foreground);
  background: var(--color-background);
  display: flex;
  flex-direction: column;
  margin: 0;
  min-height: 100svh;
  font-variation-settings: 'slnt' 0;
}

:root {
  --hover-lift-amount: 4px;
  --hover-scale-amount: 1.03;
  --hover-subtle-zoom-amount: 1.015;
  --hover-shadow-color: var(--color-shadow);
  --hover-transition-duration: 0.25s;
  --hover-transition-timing: ease-out;
  --surface-transition-duration: 0.3s;
  --surface-transition-timing: var(--ease-out-quad);
}

html {
  /* Firefox */
  scrollbar-width: thin;
  scrollbar-color: rgb(var(--color-foreground-rgb) / var(--opacity-40)) var(--color-background);
  scroll-behavior: smooth;
}

html[scroll-lock] {
  overflow: hidden;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

img {
  width: 100%;
  height: auto;
}

input,
textarea,
select {
  font: inherit;
  border-radius: var(--style-border-radius-inputs);
}

input:hover {
  background-color: var(--color-input-hover-background);
}

/** override ios and firefox defaults */
select {
  background-color: var(--color-background);
  color: currentcolor;
}

.product-card,
.collection-card,
.resource-card,
.predictive-search-results__card--product,
.predictive-search-results__card {
  position: relative;
  transition: transform var(--hover-transition-duration) var(--hover-transition-timing),
    box-shadow var(--hover-transition-duration) var(--hover-transition-timing);
  will-change: transform, box-shadow;
  z-index: var(--layer-flat);
}

.product-card__link {
  position: absolute;
  inset: 0;
}

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

.product-card__content slideshow-component {
  --cursor: pointer;
}

.predictive-search-results__card .product-card,
.predictive-search-results__card .collection-card,
.predictive-search-results__card .resource-card {
  transition: none;
  will-change: auto;
}

@media (any-pointer: fine) and (prefers-reduced-motion: no-preference) {
  .card-hover-effect-lift .product-card:hover,
  .card-hover-effect-lift .collection-card:hover,
  .card-hover-effect-lift .resource-card:hover,
  .card-hover-effect-lift .predictive-search-results__card:hover {
    transform: translateY(calc(-1 * var(--hover-lift-amount)));
  }

  .card-hover-effect-lift .header .product-card:hover,
  .card-hover-effect-lift .header .collection-card:hover,
  .card-hover-effect-lift .header .resource-card:hover,
  .card-hover-effect-lift .header-drawer .product-card:hover,
  .card-hover-effect-lift .header-drawer .collection-card:hover,
  .card-hover-effect-lift .header-drawer .resource-card:hover {
    transform: none;
  }

  .card-hover-effect-scale .product-card:hover,
  .card-hover-effect-scale .collection-card:hover,
  .card-hover-effect-scale .resource-card:hover,
  .card-hover-effect-scale .predictive-search-results__card:hover {
    transform: scale(var(--hover-scale-amount));
  }

  .card-hover-effect-scale .header .product-card:hover,
  .card-hover-effect-scale .header .collection-card:hover,
  .card-hover-effect-scale .header .resource-card:hover,
  .card-hover-effect-scale .header-drawer .product-card:hover,
  .card-hover-effect-scale .header-drawer .collection-card:hover,
  .card-hover-effect-scale .header-drawer .resource-card:hover {
    transform: none;
  }

  .card-hover-effect-subtle-zoom .card-gallery,
  .card-hover-effect-subtle-zoom .collection-card__image,
  .card-hover-effect-subtle-zoom .product-card__image,
  .card-hover-effect-subtle-zoom .resource-card__image {
    overflow: hidden;
    transition: transform var(--hover-transition-duration) var(--hover-transition-timing);
  }

  .predictive-search-results__card .card-gallery,
  .predictive-search-results__card .collection-card__image,
  .predictive-search-results__card .product-card__image,
  .predictive-search-results__card .resource-card__image {
    transition: none;
  }

  .card-hover-effect-subtle-zoom .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .resource-card:hover .resource-card__image,
  .card-hover-effect-subtle-zoom .predictive-search-results__card:hover {
    transform: scale(var(--hover-subtle-zoom-amount));
  }

  .card-hover-effect-subtle-zoom .header .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .header .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .header .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .header .resource-card:hover .resource-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .header-drawer .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .resource-card:hover .resource-card__image {
    transform: none;
  }

  .predictive-search-results__card .product-card:hover,
  .predictive-search-results__card .collection-card:hover,
  .predictive-search-results__card .resource-card:hover,
  .header .product-card:hover,
  .header .collection-card:hover,
  .header .resource-card:hover,
  .header-drawer .product-card:hover,
  .header-drawer .collection-card:hover,
  .header-drawer .resource-card:hover {
    transform: none;
    box-shadow: none;
  }
}

dialog {
  /* the ::backdrop inherits from the originating element, custom properties must be set on the dialog element */
  --backdrop-color-rgb: var(--color-shadow-rgb);

  background-color: var(--color-background);
  color: var(--color-foreground);
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

.wrap-text {
  overflow-wrap: break-word;
  word-break: break-word;
  hyphens: auto;
}

p:empty {
  display: none;
}

:first-child:is(p, h1, h2, h3, h4, h5, h6),
:first-child:empty + :where(p, h1, h2, h3, h4, h5, h6) {
  margin-block-start: 0;
}

/* Remove bottom margin from last text item, or previous to last if the last is empty */
:last-child:is(p, h1, h2, h3, h4, h5, h6),
:where(p, h1, h2, h3, h4, h5, h6):nth-child(2):has(+ :last-child:empty) {
  margin-block-end: 0;
}

/* view transitions */
@media (prefers-reduced-motion: no-preference) {
  @view-transition {
    navigation: auto;
  }

  /* Keep page interactive while view transitions are running */
  :root {
    view-transition-name: none;
  }

  /* Have the root transition during page navigation */
  html:active-view-transition-type(page-navigation),
  html:active-view-transition-type(product-image-transition) {
    view-transition-name: root-custom;
  }

  ::view-transition {
    pointer-events: none;
  }

  html:active-view-transition-type(page-navigation) main[data-page-transition-enabled='true'] {
    view-transition-name: main-content;
  }

  html:active-view-transition-type(page-navigation) main[data-product-transition='true'][data-template*='product'] {
    view-transition-name: none;
  }

  ::view-transition-old(main-content) {
    animation: var(--view-transition-old-main-content);
  }

  ::view-transition-new(main-content) {
    animation: var(--view-transition-new-main-content);
  }

  html:active-view-transition-type(product-image-transition) {
    [data-view-transition-type='product-image-transition'] {
      view-transition-name: product-image-transition;
    }

    [data-view-transition-type='product-details'] {
      view-transition-name: product-details;
    }
  }

  ::view-transition-group(product-image-transition) {
    z-index: 1;
  }

  ::view-transition-group(product-image-transition),
  ::view-transition-group(product-details) {
    animation-duration: var(--animation-speed);
    animation-timing-function: var(--animation-easing);
  }

  ::view-transition-old(product-image-transition),
  ::view-transition-new(product-image-transition) {
    block-size: 100%;
    overflow: hidden;
    object-fit: cover;
    animation-duration: 0.25s;
    animation-timing-function: var(--animation-easing);
  }

  ::view-transition-new(product-details) {
    animation: var(--view-transition-new-main-content);
  }
}

/* Focus */
*:focus-visible {
  outline: var(--focus-outline-width) solid currentcolor;
  outline-offset: var(--focus-outline-offset);
}

@supports not selector(:focus-visible) {
  *:focus {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }
}

.focus-inset {
  outline-offset: calc(var(--focus-outline-width) * -1);
}

/* Layout */
.content-for-layout {
  flex: 1;
}

/* Set up page widths & margins */
.page-width-wide,
.page-width-normal,
.page-width-narrow,
.page-width-content {
  --page-margin: 16px;
}

@media screen and (min-width: 750px) {
  .page-width-wide,
  .page-width-normal,
  .page-width-narrow,
  .page-width-content {
    --page-margin: 40px;
  }
}

.page-width-wide {
  /* NOTE: This results in a page width of 2400px because of how we set up margins with grid */
  --page-content-width: var(--wide-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-normal {
  --page-content-width: var(--normal-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-narrow,
.page-width-content {
  /* NOTE: This results in a page width of 1400px because of how we set up margins with grid */
  --page-content-width: var(--narrow-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-content {
  --page-content-width: var(--normal-content-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

/* Section width full vs. page
   The reason we use a grid to contain the section is to allow for the section to have a
   full-width background image even if the section content is constrained by the page width. Do not try
   to rewrite this to max-width: --page-width; margin: 0 auto;, it doesn't work. */
.section {
  --full-page-grid-central-column-width: min(
    var(--page-width) - var(--page-margin) * 2,
    calc(100% - var(--page-margin) * 2)
  );
  --full-page-grid-margin: minmax(var(--page-margin), 1fr);
  --full-page-grid-with-margins: var(--full-page-grid-margin) var(--full-page-grid-central-column-width)
    var(--full-page-grid-margin);

  /* Utility variable gives the grid's first column width. Provides an offset width for components like carousels */
  --util-page-margin-offset: max(
    var(--page-margin),
    calc((100% - min(var(--page-content-width), calc(100% - (var(--page-margin) * 2)))) / 2)
  );

  /* Offset for full-width sections to account for the page margin,
  used for Marquee — note that --util-page-margin-offset doesn't work here */
  --full-page-margin-inline-offset: calc(((100vw - var(--full-page-grid-central-column-width)) / 2) * -1);

  width: 100%;

  /* This is required to make background images work, which are <img> rendered absolutely */
  position: relative;

  /* Set up the grid */
  display: grid;
  grid-template-columns: var(--full-page-grid-with-margins);
  min-height: var(--section-min-height, 'auto');
}

/* Place all direct children in the center column by default */
.section > * {
  grid-column: 2;
}

/* Make the actual section background transparent, and instead apply it to a separate sibling element to enable stacking with hero shadow  */
.shopify-section:not(.header-section) :is(.section, .cart__summary-container) {
  background: transparent;
}

.shopify-section:not(.header-section):has(.section) {
  position: relative;
}

.shopify-section:not(.header-section) .section-background {
  content: '';
  position: absolute;
  inset: 0;
  z-index: var(--layer-section-background);
}

/* For page-width sections, all content goes in the center column */
.section--page-width > * {
  grid-column: 2;
}

/* For full-width sections, content spans all columns */
.section--full-width > * {
  grid-column: 1 / -1;
}

/* Some page-width sections should still extend all the way to the right edge of the page, e.g. collection carousel */
.section--page-width.section--full-width-right > * {
  grid-column: 2 / 4;
}

/* For full-width sections with margin, content still spans full width but with space on the sides */
.section--full-width.section--full-width-margin > * {
  grid-column: 1 / -1;

  @media screen and (min-width: 750px) {
    padding-left: var(--page-margin);
    padding-right: var(--page-margin);
  }
}

/* Some section content break out to full width of the page */
.section > .force-full-width {
  grid-column: 1 / -1;
}

.section--height-small {
  --section-min-height: var(--section-height-small);
}

.section--height-medium {
  --section-min-height: var(--section-height-medium);
}

.section--height-large {
  --section-min-height: var(--section-height-large);
}

.section--height-full-screen {
  --section-min-height: 100svh;
}

.section-content-wrapper.section-content-wrapper {
  min-height: calc(var(--section-min-height, 'auto') - var(--section-height-offset, 0px));
  position: relative;
  width: 100%;
  height: 100%;
}

/* Utility */

.hidden {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

@media screen and (max-width: 749px) {
  .hidden--mobile,
  .mobile\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

@media screen and (min-width: 750px) {
  .hidden--desktop,
  .desktop\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

.hide-when-empty:empty {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

.visually-hidden:not(:focus, :active) {
  /* stylelint-disable-next-line declaration-no-important */
  position: absolute !important;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  /* stylelint-disable-next-line declaration-no-important */
  word-wrap: normal !important;
}

@media screen and (max-width: 749px) {
  .is-visually-hidden-mobile:not(:focus, :active) {
    /* stylelint-disable-next-line declaration-no-important */
    position: absolute !important;
    overflow: hidden;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    clip: rect(0 0 0 0);
    /* stylelint-disable-next-line declaration-no-important */
    word-wrap: normal !important;
  }
}

.contents {
  display: contents;
}

.flex {
  display: flex;
  gap: var(--gap-md);
}

.grid {
  --centered-column-number: 12;
  --full-width-column-number: 14;
  --centered: column-1 / span var(--centered-column-number);
  --full-width: column-0 / span var(--full-width-column-number);

  display: flex;
  flex-direction: column;
}

@media screen and (min-width: 750px) {
  .grid {
    display: grid;
    gap: 0;
    grid-template-columns: var(--margin-4xl) repeat(var(--centered-column-number), minmax(0, 1fr)) var(--margin-4xl);
    grid-template-areas: 'column-0 column-1 column-2 column-3 column-4 column-5 column-6 column-7 column-8 column-9 column-10 column-11 column-12 column-13';
  }
}

@media screen and (min-width: 1400px) {
  .grid {
    grid-template-columns:
      1fr repeat(
        var(--centered-column-number),
        minmax(0, calc((var(--page-width) - var(--page-margin) * 2) / var(--centered-column-number)))
      )
      1fr;
  }
}

.flex {
  display: flex;
  gap: var(--gap-md);
}

.flip-x {
  scale: -1 1;
}

.flip-y {
  scale: 1 -1;
}

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

.skip-to-content-link {
  position: absolute;
  overflow: hidden;
  height: 1px;
  left: -99999px;
  /* stylelint-disable-next-line declaration-no-important */
  word-wrap: normal !important;
}

.skip-to-content-link:focus {
  z-index: var(--layer-temporary);
  overflow: auto;
  width: auto;
  height: auto;
  padding: var(--padding-lg) var(--padding-4xl);
  left: var(--margin-lg);
  top: var(--margin-lg);
  box-shadow: 0 0 0 var(--focus-outline-offset) var(--color-background);
}

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

  text-align: left;
}

.text-center {
  --text-align: center;

  text-align: center;
}

.text-right {
  --text-align: right;

  text-align: right;
}

.text-inherit {
  color: inherit;
}

.user-select-text {
  user-select: text;
}

.justify-left {
  justify-content: left;
}

.justify-center {
  justify-content: center;
}

.justify-right {
  justify-content: right;
}

.title--aligned-center {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.background-image-container {
  overflow: hidden;
  position: absolute;
  inset: 0;
  opacity: var(--image-opacity);
}

.background-image-container img,
.background-image-container svg {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.background-image-fit img,
.background-image-fit svg {
  object-fit: contain;
}

.svg-wrapper {
  color: currentcolor;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  pointer-events: none;
}

.svg-wrapper--smaller {
  width: var(--icon-size-2xs);
  height: var(--icon-size-2xs);
}

.svg-wrapper--small {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

.svg-wrapper > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
}

.relative {
  position: relative;
}

/* Icons */
.icon-success,
.icon-error {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  flex-shrink: 0;
}

.icon-success {
  color: var(--color-success);
}

.icon-error {
  fill: var(--color-error);
}

placeholder-image {
  display: block;
  height: 100%;
  aspect-ratio: var(--ratio);
}

placeholder-image[data-type='product'] {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-15));
  width: 100%;
}

/** Placeholder background for the placeholder image, the dimensions are the same as the product images */
placeholder-image[data-type='product']:not(:has(> img)) {
  aspect-ratio: var(--ratio);
  height: 350px;
}

placeholder-image > img {
  object-fit: cover;
  aspect-ratio: var(--ratio);
  height: 100%;
}

[data-placeholder='true'] * {
  cursor: default;
}

slideshow-component [data-placeholder='true'] * {
  cursor: grab;
}

/* Base text and heading styles */
body,
.paragraph:not(.button),
.paragraph > * {
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-weight: var(--font-paragraph--weight);
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  text-transform: var(--font-paragraph--case);
  -webkit-font-smoothing: antialiased;
  color: var(--color, var(--color-foreground));
}

/* Ensure inputs with type presets maintain minimum 16px on mobile to prevent iOS zoom */
@media screen and (max-width: 1200px) {
  input.paragraph.paragraph,
  input.paragraph.paragraph:not([type]),
  textarea.paragraph.paragraph,
  select.paragraph.paragraph {
    font-size: max(1rem, var(--font-paragraph--size));
  }
}

.paragraph > small {
  font-size: smaller;
}

/* Typography presets */

h1,
.h1.h1,
.text-block.h1 > * {
  font-family: var(--font-h1--family);
  font-style: var(--font-h1--style);
  font-weight: var(--font-h1--weight);
  font-size: var(--font-h1--size);
  line-height: var(--font-h1--line-height);
  letter-spacing: var(--font-h1--letter-spacing);
  text-transform: var(--font-h1--case);
  color: var(--color, var(--font-h1-color));
}

@media screen and (max-width: 1200px) {
  input.h1.h1,
  textarea.h1.h1,
  select.h1.h1 {
    font-size: max(1rem, var(--font-h1--size));
  }
}

h2,
.h2.h2,
.text-block.h2 > * {
  font-family: var(--font-h2--family);
  font-style: var(--font-h2--style);
  font-weight: var(--font-h2--weight);
  font-size: var(--font-h2--size);
  line-height: var(--font-h2--line-height);
  letter-spacing: var(--font-h2--letter-spacing);
  text-transform: var(--font-h2--case);
  color: var(--color, var(--font-h2-color));
}

@media screen and (max-width: 1200px) {
  input.h2.h2,
  textarea.h2.h2,
  select.h2.h2 {
    font-size: max(1rem, var(--font-h2--size));
  }
}

h3,
.h3,
.h3.h3,
.text-block.h3 > * {
  font-family: var(--font-h3--family);
  font-style: var(--font-h3--style);
  font-weight: var(--font-h3--weight);
  font-size: var(--font-h3--size);
  line-height: var(--font-h3--line-height);
  letter-spacing: var(--font-h3--letter-spacing);
  text-transform: var(--font-h3--case);
  color: var(--color, var(--font-h3-color));
}

@media screen and (max-width: 1200px) {
  input.h3,
  textarea.h3,
  select.h3 {
    font-size: max(1rem, var(--font-h3--size));
  }
}

h4,
.h4.h4,
.text-block.h4 > * {
  font-family: var(--font-h4--family);
  font-style: var(--font-h4--style);
  font-weight: var(--font-h4--weight);
  font-size: var(--font-h4--size);
  line-height: var(--font-h4--line-height);
  letter-spacing: var(--font-h4--letter-spacing);
  text-transform: var(--font-h4--case);
  color: var(--color, var(--font-h4-color));
}

@media screen and (max-width: 1200px) {
  input.h4.h4,
  textarea.h4.h4,
  select.h4.h4 {
    font-size: max(1rem, var(--font-h4--size));
  }
}

h5,
.h5.h5,
.text-block.h5 > * {
  font-family: var(--font-h5--family);
  font-style: var(--font-h5--style);
  font-weight: var(--font-h5--weight);
  font-size: var(--font-h5--size);
  line-height: var(--font-h5--line-height);
  letter-spacing: var(--font-h5--letter-spacing);
  text-transform: var(--font-h5--case);
  color: var(--color, var(--font-h5-color));
}

@media screen and (max-width: 1200px) {
  input.h5.h5,
  textarea.h5.h5,
  select.h5.h5 {
    font-size: max(1rem, var(--font-h5--size));
  }
}

h6,
.h6.h6,
.text-block.h6 > * {
  font-family: var(--font-h6--family);
  font-style: var(--font-h6--style);
  font-weight: var(--font-h6--weight);
  font-size: var(--font-h6--size);
  line-height: var(--font-h6--line-height);
  letter-spacing: var(--font-h6--letter-spacing);
  text-transform: var(--font-h6--case);
  color: var(--color, var(--font-h6-color));
}

@media screen and (max-width: 1200px) {
  input.h6.h6,
  textarea.h6.h6,
  select.h6.h6 {
    font-size: max(1rem, var(--font-h6--size));
  }
}

:first-child:is(.h1, .h2, .h3, .h4, .h5, .h6) {
  margin-block-start: 0;
}

:last-child:is(.h1, .h2, .h3, .h4, .h5, .h6) {
  margin-block-end: 0;
}

/* Links */
a {
  --button-color: var(--color, var(--color-primary));

  color: var(--button-color);
  text-decoration-color: transparent;
  text-decoration-thickness: 0.075em;
  text-underline-offset: 0.125em;
  transition: text-decoration-color var(--animation-speed) var(--animation-easing),
    color var(--animation-speed) var(--animation-easing);
}

:is(h1, h2, h3, h4, h5, h6, p) > a:hover {
  --button-color: var(--color, var(--color-primary-hover));
}

/* Add underline to text using our paragraph styles only. */
p:not(.h1, .h2, .h3, .h4, .h5, .h6) a:where(:not(.button, .button-primary, .button-secondary)),
.rte
  :is(p, ul, ol, table):not(.h1, .h2, .h3, .h4, .h5, .h6)
  a:where(:not(.button, .button-primary, .button-secondary)) {
  text-decoration-color: currentcolor;

  &:hover {
    text-decoration-color: transparent;
    color: var(--color-primary-hover);
  }
}

.container-background-image {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

details[open] .summary-closed {
  display: none;
}

details:not([open]) .summary-open {
  display: none;
}

details[open] > summary .icon-animated > svg {
  transform: rotate(180deg);
}

/* iOS fix: hide the default arrow on the summary */
summary::-webkit-details-marker {
  display: none;
}

/* When header is transparent, pull the first main content section up to sit under the floating header */
body:has(.header[transparent]) .content-for-layout > .shopify-section:first-child {
  margin-top: calc(var(--header-group-height) * -1);
}

body:has(.header[transparent]) #header-group > *:not(.header-section) {
  z-index: 1;
}

body:has(.header[transparent]) #header-group > .header-section {
  z-index: var(--layer-sticky);
}

/* Featured collection block */
.featured-collection-block {
  width: 100%;
}

/* Product grid */
.product-grid-container {
  display: block;
  width: 100%;
  padding-block: var(--padding-block-start) var(--padding-block-end);

  @media screen and (min-width: 750px) {
    display: grid;
  }
}

.product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--product-grid-gap);
  margin: auto;
  padding: 0;
  list-style: none;
}

@media screen and (min-width: 750px) {
  .product-grid {
    grid-template-columns: var(--product-grid-columns-desktop);
  }
}

.product-grid :is(h3, p) {
  margin: 0;
}

.product-grid__item {
  border: var(--product-card-border-width) solid rgb(var(--color-border-rgb) / var(--product-card-border-opacity));
}

.product-grid--organic[product-grid-view='default'] .product-grid__item {
  height: fit-content;
}

.product-grid__card.product-grid__card {
  display: flex;
  flex-flow: column nowrap;
  gap: var(--product-card-gap);
  align-items: var(--product-card-alignment);
  text-decoration: none;
  color: var(--color, var(--color-foreground));
  padding-block: var(--padding-block-start) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  overflow: hidden;
}

[product-grid-view='zoom-out'] .product-grid__card {
  row-gap: var(--padding-xs);
}

[product-grid-view='default'] {
  --product-grid-gap: 16px;
  --padding-block-start: 24px;
  --padding-block-end: 24px;
  --padding-inline-start: 0px;
  --padding-inline-end: 0px;
}

[product-grid-view='default'] .product-grid__item {
  padding-block: 0;
}

[product-grid-view='mobile-single'],
.product-grid-mobile--large {
  @media screen and (max-width: 749px) {
    grid-template-columns: 1fr;
  }
}

.product-grid__card .group-block > * {
  @media screen and (max-width: 749px) {
    flex-direction: column;
  }
}

ul[product-grid-view='zoom-out'] .product-grid__card > * {
  display: none;
}

ul[product-grid-view='zoom-out'] .product-grid__card .card-gallery {
  display: block;
}

[product-grid-view='zoom-out']
  .card-gallery
  > :is(quick-add-component, .product-badges, slideshow-component > slideshow-controls) {
  display: none;
}

ul[product-grid-view='zoom-out'] .card-gallery > img {
  display: block;
}

[product-grid-view='zoom-out'] {
  --product-grid-columns-desktop: repeat(
    10,
    minmax(clamp(50px, calc(100% - 9 * var(--product-grid-gap)) / 10, 80px), 1fr)
  );
}

.product-grid-view-zoom-out--details {
  display: none;
}

.product-grid-view-zoom-out--details .h4,
.product-grid-view-zoom-out--details span,
.product-grid-view-zoom-out--details s {
  font-size: var(--font-size--xs);
  font-family: var(--font-paragraph--family);
}

.product-grid-view-zoom-out--details span {
  font-weight: 500;
}

.product-grid-view-zoom-out--details .h4 {
  line-height: 1.3;
  font-weight: 400;
}

.product-grid-view-zoom-out--details > span.h6,
.product-grid-view-zoom-out--details > div.h6 > product-price {
  display: inline-block;
  line-height: 0;
  margin-top: var(--margin-2xs);
}

.product-grid-view-zoom-out--details > span.h6 > *,
.product-grid-view-zoom-out--details > div.h6 > * > * {
  line-height: 1.2;
}

@media (prefers-reduced-motion: no-preference) {
  :root:active-view-transition-type(product-grid) {
    details[open] floating-panel-component {
      view-transition-name: panel-content;

      .checkbox *,
      .facets__pill-label {
        transition: none;
      }

      .facets--vertical & {
        view-transition-name: none;
      }
    }

    .product-grid {
      view-transition-name: product-grid;
    }

    footer {
      view-transition-name: footer;
    }

    .product-grid__item,
    floating-panel-component {
      transition: none;
    }
  }
}

::view-transition-group(panel-content) {
  z-index: 1;
}

::view-transition-new(product-grid) {
  animation-delay: 150ms;
  animation-name: fadeInUp;
  animation-duration: var(--animation-speed);
  animation-timing-function: var(--animation-easing);
}

results-list[initialized] {
  .product-grid__item {
    transition: opacity var(--animation-speed) var(--animation-easing),
      transform var(--animation-speed) var(--animation-easing);

    @starting-style {
      opacity: 0;
      transform: translateY(10px);
    }
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Collection and product list cards have equal heights */
:is(.product-grid__item, .resource-list__item) .product-card {
  display: grid;
  height: 100%;
}

/* Video background */
.video-background,
.video-background * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.video-background--cover * {
  object-fit: cover;
}

.video-background--contain * {
  object-fit: contain;
}

.text-block {
  width: 100%;
}

.text-block > *:first-child,
.text-block > *:first-child:empty + * {
  margin-block-start: 0;
}

.text-block > *:last-child,
.text-block > *:has(+ *:last-child:empty) {
  margin-block-end: 0;
}

/* This is to deal with the margin applied to the p when custom styles are enabled. The p isn't the first child anymore due to the style tag */
.text-block > style + * {
  margin-block-start: 0;
}

/* Dialog */
.dialog-modal {
  border: none;
  box-shadow: var(--shadow-popover);

  @media screen and (min-width: 750px) {
    border-radius: var(--style-border-radius-popover);
    max-width: var(--normal-content-width);
  }

  @media screen and (max-width: 749px) {
    max-width: 100%;
    max-height: 100%;
    height: 100dvh;
    width: 100dvw;
    padding: var(--padding-md);
  }
}

.dialog-modal::backdrop {
  transition: backdrop-filter var(--animation-speed) var(--animation-easing);
  backdrop-filter: brightness(1);
  background: rgb(var(--backdrop-color-rgb) / var(--backdrop-opacity));
}

.dialog-modal[open] {
  animation: elementSlideInTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    animation: backdropFilter var(--animation-speed) var(--animation-easing) forwards;
    transition: opacity var(--animation-speed) var(--animation-easing);
  }
}

.dialog-modal.dialog-closing {
  animation: elementSlideOutTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    opacity: 0;
  }
}

/* stylelint-disable value-keyword-case */
.dialog-drawer {
  --dialog-drawer-opening-animation: slideInLeft;
  --dialog-drawer-closing-animation: slideOutLeft;
}

.dialog-drawer--right {
  --dialog-drawer-opening-animation: slideInRight;
  --dialog-drawer-closing-animation: slideOutRight;
}
/* stylelint-enable value-keyword-case */

.dialog-drawer[open] {
  animation: var(--dialog-drawer-opening-animation) var(--animation-speed) var(--animation-easing) forwards;
}

.dialog-drawer.dialog-closing {
  animation: var(--dialog-drawer-closing-animation) var(--animation-speed) var(--animation-easing);
}

/* Buttons */
.button,
.button-secondary,
button.shopify-payment-button__button--unbranded {
  --text-align: center;

  display: grid;
  align-content: center;
  text-decoration: none;
  text-align: var(--text-align);
  color: var(--button-color);
  appearance: none;
  background-color: var(--button-background-color);
  border: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  margin-block: 0;
  transition: color var(--animation-speed) var(--animation-easing),
    box-shadow var(--animation-speed) var(--animation-easing),
    background-color var(--animation-speed) var(--animation-easing);
  cursor: pointer;
  width: fit-content;
  box-shadow: inset 0 0 0 var(--button-border-width) var(--button-border-color);
  padding-block: var(--button-padding-block);
  padding-inline: var(--button-padding-inline);
}

.button {
  font-family: var(--button-font-family-primary);
  text-transform: var(--button-text-case-primary);
  border-radius: var(--style-border-radius-buttons-primary);
}

.button:not(.button-secondary, .button-unstyled) {
  outline-color: var(--button-background-color);
}

.button-secondary {
  font-family: var(--button-font-family-secondary);
  text-transform: var(--button-text-case-secondary);
  border-radius: var(--style-border-radius-buttons-secondary);
}

button.shopify-payment-button__button--unbranded {
  font-family: var(--button-font-family-primary);
  text-transform: var(--button-text-case-primary);
}

textarea,
input {
  background-color: var(--color-input-background);
  border-color: var(--color-input-border);
}

textarea::placeholder,
input::placeholder {
  color: var(--color-input-text);
}

textarea:not(:placeholder-shown)::placeholder,
input:not(:placeholder-shown)::placeholder {
  opacity: 0;
}

/* The declaration above is messing with buttons that have an attribute of hidden as it overwrites the display value */
.button[hidden] {
  display: none;
}

.button[aria-disabled='true'],
.button-secondary[aria-disabled='true'],
.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.button,
button.shopify-payment-button__button--unbranded {
  --button-color: var(--color-primary-button-text);
  --button-background-color: var(--color-primary-button-background);
  --button-border-color: var(--color-primary-button-border);
  --button-border-width: var(--style-border-width-primary);
}

.button:hover,
button.shopify-payment-button__button--unbranded:hover:not([disabled]) {
  --button-color: var(--color-primary-button-hover-text);
  --button-background-color: var(--color-primary-button-hover-background);
  --button-border-color: var(--color-primary-button-hover-border);
}

.button-secondary {
  --button-color: var(--color-secondary-button-text);
  --button-background-color: var(--color-secondary-button-background);
  --button-border-color: var(--color-secondary-button-border);
  --button-border-width: var(--style-border-width-secondary);
}

.button-secondary:hover {
  --button-color: var(--color-secondary-button-hover-text);
  --button-background-color: var(--color-secondary-button-hover-background);
  --button-border-color: var(--color-secondary-button-hover-border);
}

/* Needed to override the default Shopify styles */
button.shopify-payment-button__button--unbranded:hover:not([disabled]) {
  background-color: var(--button-background-color);
}

.button-unstyled {
  display: block;
  padding: 0;
  background-color: inherit;
  color: inherit;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-size: var(--font-paragraph--size);
}

.button-unstyled:hover {
  background-color: inherit;
}

.button-unstyled--with-icon {
  color: var(--color-foreground);
  display: flex;
  gap: var(--gap-2xs);
  align-items: center;
}

.button-unstyled--transparent {
  background-color: transparent;
  box-shadow: none;
}

/* Show more */

.show-more__button {
  color: var(--color-primary);
  cursor: pointer;
}

.show-more__button:hover {
  @media screen and (min-width: 750px) {
    color: var(--color-primary-hover);
  }
}

.show-more__label {
  text-align: start;
  font-size: var(--font-size--body-md);
  font-family: var(--font-paragraph--family);
}

.show-more__button .svg-wrapper {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

.show-more[data-expanded='true'] .show-more__label--more,
.show-more[data-expanded='false'] .show-more__label--less {
  display: none;
}

.link {
  display: inline-block;
  text-align: center;
}

shopify-accelerated-checkout,
shopify-accelerated-checkout-cart {
  --shopify-accelerated-checkout-button-border-radius: var(--style-border-radius-buttons-primary);
  --shopify-accelerated-checkout-button-block-size: var(--height-buy-buttons);
}

.product-form-buttons:has(.add-to-cart-button.button-secondary)
  :is(shopify-accelerated-checkout, shopify-accelerated-checkout-cart) {
  --shopify-accelerated-checkout-button-border-radius: var(--style-border-radius-buttons-secondary);
  --shopify-accelerated-checkout-button-block-size: var(--height-buy-buttons);
}

/* Collapsible row */

.icon-caret svg {
  transition: transform var(--animation-speed) var(--animation-easing);
}

.icon-caret--forward svg {
  transform: rotate(-90deg);
}

.icon-caret--backward svg {
  transform: rotate(90deg);
}

summary {
  display: flex;
  align-items: center;
  cursor: pointer;
  list-style: none;
  padding-block: var(--padding-sm);
}

summary:hover {
  color: var(--color-primary-hover);
}

summary .svg-wrapper {
  margin-inline-start: auto;
  height: var(--icon-size-xs);
  width: var(--icon-size-xs);
  transition: transform var(--animation-speed) var(--animation-easing);
}

/* Shared plus/minus icon animations */
summary .icon-plus :is(.horizontal, .vertical),
.show-more__button .icon-plus :is(.horizontal, .vertical) {
  transition: transform var(--animation-speed) var(--animation-easing);
  transform: rotate(0deg);
  transform-origin: 50% 50%;
  opacity: 1;
}

details[open] > summary .icon-plus .horizontal,
.details-open > summary .icon-plus .horizontal,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .horizontal {
  transform: rotate(90deg);
}

details[open] > summary .icon-plus .vertical,
.details-open > summary .icon-plus .vertical,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .vertical {
  transform: rotate(90deg);
  opacity: 0;
}

/* Product Media */
media-gallery {
  display: block;
  width: 100%;
}

:where(media-gallery, .product-grid__item) {
  .media-gallery__grid {
    grid-template-columns: 1fr;
    gap: var(--image-gap);
  }
}

.product-media-gallery__slideshow--single-media slideshow-container {
  @media screen and (max-width: 749px) {
    grid-area: unset;
  }
}

:not(.dialog-zoomed-gallery) > .product-media-container {
  /* width and overflow forces children to shrink to parent width */
  --slide-width: round(up, 100%, 1px);

  display: flex;
  aspect-ratio: var(--gallery-aspect-ratio, var(--media-preview-ratio));
  max-height: var(--constrained-height);
  width: 100%;

  /* Relative position needed for video and 3d models */
  position: relative;
  overflow: hidden;

  &:where(.constrain-height) {
    /* arbitrary offset value based on average theme spacing and header height */
    --viewport-offset: 400px;
    --constrained-min-height: 300px;
    --constrained-height: max(var(--constrained-min-height), calc(100vh - var(--viewport-offset)));

    margin-right: auto;
    margin-left: auto;
  }
}

media-gallery:where(.media-gallery--grid) .media-gallery__grid {
  display: none;
}

media-gallery.media-gallery--grid .media-gallery__grid .product-media-container {
  /* Needed for safari to stretch to full grid height */
  height: 100%;
}

.product-media :is(deferred-media, product-model) {
  position: absolute;
}

@media screen and (max-width: 749px) {
  .product-media-container.constrain-height {
    max-height: none;
  }
}

@media screen and (min-width: 750px) {
  .product-media-container.constrain-height {
    --viewport-offset: var(--header-height, 100px);
    --constrained-min-height: 500px;
  }

  .media-gallery--two-column .media-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .media-gallery--large-first-image .product-media-container:first-child,
  .media-gallery--two-column .product-media-container:only-child {
    /* First child spans 2 columns */
    grid-column: span 2;
  }

  /* Display grid view as a carousel on mobile, grid on desktop */
  media-gallery:is(.media-gallery--grid) slideshow-component {
    display: none;
  }

  media-gallery:where(.media-gallery--grid) .media-gallery__grid {
    display: grid;
  }
}

.product-media-container--model {
  /* Usefull when view in your space is shown */
  flex-direction: column;
}

.shopify-model-viewer-ui__controls-area {
  bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
}

.product-media-container img {
  aspect-ratio: inherit;
  object-fit: contain;
}

.product-media-container.media-fit-contain img {
  object-position: center center;
}

.product-media-container.media-fit {
  --product-media-fit: cover;

  img {
    object-fit: var(--product-media-fit);
  }
}

/* Media gallery zoom dialog */
.product-media-container__zoom-button {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: var(--layer-flat);
  cursor: zoom-in;
  background-color: transparent;

  &:hover {
    background-color: transparent;
  }
}

zoom-dialog dialog {
  width: 100vw;
  height: 100vh;
  border: none;
  margin: 0;
  padding: 0;
  max-width: 100%;
  max-height: 100%;
  background: #fff;
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
  scrollbar-width: none;

  &[open] {
    opacity: 1;
  }

  @media (prefers-reduced-motion: no-preference) {
    scroll-behavior: smooth;
  }

  &::backdrop {
    background: transparent;
  }
}

/* Animate the UI elements in only after the view transition is complete */
.close-button {
  position: fixed;
  top: var(--margin-lg);
  right: var(--margin-lg);
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
  z-index: var(--layer-flat);
  background-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;

  /* For the outline radius */
  border-radius: 50%;
}

/* This triggers iOS < 16.4. The outline bug is not recognized as a lack of @supports */

@supports not (background-color: rgb(from red 150 g b / alpha)) {
  /**
    There is a bug in safari < 16.4 that causes the outline to not follow the elements border radius. This is a workaround.
    Using element selector to increase specificity.
  **/

  .close-button:focus-visible {
    outline: none;
    overflow: visible;
  }

  .close-button:focus-visible::after {
    content: '';
    position: absolute;
    inset: calc(-1 * var(--focus-outline-offset));
    border: var(--focus-outline-width) solid currentColor;
    border-radius: 50%;
    display: inherit;
  }
}

.dialog--closed .close-button {
  animation: elementSlideOutBottom calc(var(--animation-speed) * 0.5) var(--animation-easing) forwards;
}

.dialog-thumbnails-list-container {
  position: fixed;
  width: 100%;
  bottom: 0;
  display: flex;
  z-index: var(--layer-raised);
}

.dialog-thumbnails-list {
  position: relative;
  display: inline-flex;
  flex-direction: row;
  gap: 8px;
  bottom: 0;
  overflow-x: auto;
  opacity: 0;
  padding: var(--padding-lg);
  margin-inline: auto;
  scrollbar-width: none;
  animation: thumbnailsSlideInBottom calc(var(--animation-speed) * 0.75) var(--animation-easing) forwards;
  animation-delay: calc(var(--animation-speed) * 1.5);
}

.dialog--closed .dialog-thumbnails-list {
  animation: thumbnailsSlideOutBottom var(--animation-speed) var(--animation-easing) forwards;
}

@media screen and (min-width: 750px) {
  .dialog-thumbnails-list {
    position: fixed;
    flex-direction: column;
    inset: 50% var(--margin-lg) auto auto;
    right: 0;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
    animation: thumbnailsSlideInTop calc(var(--animation-speed) * 0.5) var(--animation-easing) forwards;
    animation-delay: calc(var(--animation-speed) * 2);
  }

  .dialog--closed .dialog-thumbnails-list {
    animation: thumbnailsSlideOutTop var(--animation-speed) var(--animation-easing) forwards;
  }
}

.dialog-thumbnails-list__thumbnail {
  width: var(--thumbnail-width);
  height: auto;
  transition: transform var(--animation-speed) var(--animation-easing);
  flex-shrink: 0;
  border-radius: var(--media-radius);

  img {
    height: 100%;
    object-fit: cover;
    border-radius: var(--media-radius);
    aspect-ratio: var(--aspect-ratio);
  }

  &:is([aria-selected='true']) {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: calc(var(--focus-outline-offset) / 2);
    border: var(--style-border-width) solid rgb(var(--color-border-rgb) / var(--media-border-opacity));
  }
}

.close-button:hover {
  background-color: transparent;
  opacity: 0.8;
}

.close-button svg {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

/* Product media */
.product-media {
  display: flex;
  flex: 1;
}

/* If the product media is already providing an image cover, hide images provided by sibling deferred-media */
.product-media__image ~ * .deferred-media__poster-image {
  display: none;
}

/* If the product media is playing, hide the preview image */
.product-media-container:has(.deferred-media__playing) .product-media__image {
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
}

/* Deferred media & Product model  */
:is(product-model, deferred-media) {
  /* Height needed to make sure when it's set to be stretched, it takes the full height */
  height: 100%;
  width: 100%;
  position: relative;
}

product-model model-viewer,
/* Media that have a poster button sibling providing the size should be absolute-positioned.
Otherwise, it should be a block to rely on its own size */
:is(deferred-media, product-model) > .deferred-media__poster-button ~ *:not(template) {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;

  /* Required to make sure the absolute position respects the padding of the wrapper: */
  padding: inherit;
}

slideshow-slide .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
  bottom: var(--padding-sm);
  right: var(--padding-sm);
}

.dialog-zoomed-gallery .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
  /* Move the controls above the thumbnails. Need to calculate the height of the thumbnails list */
  bottom: calc(var(--thumbnail-width) / calc(var(--media-preview-ratio)) + var(--padding-lg) * 2);
  right: var(--padding-lg);
}

@media screen and (max-width: 749px) {
  slideshow-component:has(:not(.mobile\:hidden) :is(.slideshow-controls__dots, .slideshow-controls__counter))
    .shopify-model-viewer-ui__controls-area {
    /* Position the controls just above the counter */
    bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
  }
}

@media screen and (min-width: 750px) {
  slideshow-component:has(:not(.desktop\:hidden) :is(.slideshow-controls__dots, .slideshow-controls__counter))
    .shopify-model-viewer-ui__controls-area {
    /* Position the controls just above the counter */
    bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
  }

  .dialog-zoomed-gallery .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
    /* Move the controls up to match the padding on the thumbnails */
    bottom: var(--padding-lg);

    /* Move the controls to the left of the thumbnails list on the right */
    right: calc(var(--thumbnail-width) + var(--padding-lg) * 2);
  }
}

:is(deferred-media, .video-placeholder-wrapper).border-style {
  /* Apply the border radius to the video */
  overflow: hidden;
}

deferred-media {
  /* The overflow hidden in the deferred-media won't let the button show the focus ring */
  &:has(:focus-visible) {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }

  @supports not selector(:focus-visible) {
    &:has(:focus) {
      outline: var(--focus-outline-width) solid currentcolor;
      outline-offset: var(--focus-outline-offset);
    }
  }
}

.deferred-media__poster-button {
  width: 100%;
  height: 100%;
  aspect-ratio: var(--video-aspect-ratio, auto);
}

.deferred-media__poster-button.deferred-media__playing {
  opacity: 0;
  transition: opacity 0.3s ease;
}

deferred-media img {
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}

deferred-media iframe {
  width: 100%;
  height: 100%;
  border: none;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

deferred-media[data-media-loaded] img {
  opacity: 0;
}

.deferred-media__poster-icon,
.video-placeholder-wrapper__poster-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.deferred-media__poster-icon svg,
.video-placeholder-wrapper__poster-icon svg {
  width: var(--button-size);
  height: var(--button-size);
  color: var(--color-white);
  filter: drop-shadow(var(--shadow-button));

  &:hover {
    color: rgb(var(--color-white-rgb) / var(--opacity-80));
  }

  @media screen and (min-width: 750px) {
    width: 4rem;
    height: 4rem;
  }
}

deferred-media[class] :is(.deferred-media__poster-button img, .deferred-media__poster-button ~ video) {
  /* only apply this on the video block not product media */
  object-fit: cover;
  height: 100%;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

.button-shopify-xr {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--padding-md);
}

.button-shopify-xr > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  fill: currentcolor;
  margin-inline-end: var(--margin-md);
}

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

/* Swatches */
.swatch {
  --color-border: rgb(var(--color-foreground-rgb) / var(--style-border-swatch-opacity));
  --min-width-unitless: 15.9999; /* want to avoid division by 0 */
  --min-height-unitless: 15.9999; /* want to avoid division by 0 */
  --min-height: 16px;
  --min-width: 16px;

  /* mobile values */
  --scaling-factor: 0.5;
  --max-swatch-size: 28px;
  --max-pill-size: 20px;
  --max-filter-size: 32px;

  /* From the settings */
  --offset-swatch-width: calc(var(--variant-picker-swatch-width-unitless) - var(--min-width-unitless));
  --offset-swatch-height: calc(var(--variant-picker-swatch-height-unitless) - var(--min-height-unitless));

  /**
    Offset values are obtained from the following formulas:
      offset-width = width - min-width
      offset-height = height - min-height

    The offset-scaled-width and heigth are obtained by extending the line from
    [min,min] to [W,H] and taking the intersection with a square that starts at
    [min,min] and ends at [max,max].

    The extending line forms right angle triangles with the [min,min]->[max,max]
    box that enable us to derive the following formulas

    We also want the result to always be smaller than the input (pdp > everywhere else)
    by some scaling factor.
  */
  --offset-scaled-width: calc(
    var(--scaling-factor) * var(--offset-swatch-width) / var(--offset-swatch-height) * var(--offset-max-swatch-size)
  );
  --offset-scaled-height: calc(
    var(--scaling-factor) * var(--offset-swatch-height) / var(--offset-swatch-width) * var(--offset-max-swatch-size)
  );
  --offset-max-swatch-size: calc(var(--max-swatch-size) - var(--min-width));

  /* width = min(m + sU, (m + s * W'/H' * M'), M) */
  --swatch-width: min(
    calc(var(--min-width) + calc(var(--scaling-factor) * var(--offset-swatch-width) * 1px)),
    calc(var(--min-width) + var(--offset-scaled-width)),
    var(--max-swatch-size)
  );

  /* height = min(m + sV, (m + s * H'/W' * M'), M) */
  --swatch-height: min(
    calc(var(--min-height) + calc(var(--scaling-factor) * var(--offset-swatch-height) * 1px)),
    calc(var(--min-height) + var(--offset-scaled-height)),
    var(--max-swatch-size)
  );

  display: block;
  background: var(--swatch-background);
  background-position: var(--swatch-focal-point, center);
  border-radius: var(--variant-picker-swatch-radius);
  border: var(--style-border-swatch-width) var(--style-border-swatch-style) var(--color-border);
  width: var(--swatch-width);
  height: var(--swatch-height);

  /* This is different than `background-size: cover` because we use `box-sizing: border-box`,
   * doing it like makes the background clip under the border without repeating.
   */
  background-size: var(--swatch-width) var(--swatch-height);

  &.swatch--unavailable {
    border-style: dashed;
  }

  &.swatch--unscaled {
    /* for when you want fixed sizing (e.g. pdp) */
    --swatch-width: var(--variant-picker-swatch-width);
    --swatch-height: var(--variant-picker-swatch-height);
  }

  &.swatch--filter {
    --swatch-width: var(--max-filter-size);
    --swatch-height: var(--max-filter-size);

    border-radius: var(--variant-picker-swatch-radius);
  }

  &.swatch--pill {
    --swatch-width: var(--max-pill-size);
    --swatch-height: var(--max-pill-size);

    border-radius: var(--variant-picker-swatch-radius);
  }

  /* swatches in filters and pills always have a border  */
  &.swatch--filter,
  &.swatch--pill {
    --style-border-swatch-width: var(--variant-picker-border-width);
    --style-border-swatch-style: var(--variant-picker-border-style);
    --color-border: rgb(var(--color-foreground-rgb) / var(--variant-picker-border-opacity));
  }

  @media screen and (min-width: 750px) {
    /* desktop values */
    --max-swatch-size: 32px;
    --max-pill-size: 16px;
    --max-filter-size: 28px;
    --scaling-factor: 0.65;
  }
}

.variant-picker .variant-option--buttons label:has(.swatch) {
  border-radius: var(--variant-picker-swatch-radius);
}

.sticky-content {
  position: sticky;
  top: var(--sticky-header-offset, 0);
  z-index: var(--layer-flat);
}

@media screen and (min-width: 750px) {
  .sticky-content--desktop,
  .sticky-content--desktop.full-height--desktop > .group-block {
    position: sticky;
    top: var(--sticky-header-offset, 0);
    z-index: var(--layer-flat);
  }
}

.price,
.compare-at-price,
.unit-price {
  white-space: nowrap;
}

.unit-price {
  display: block;
  font-size: min(0.85em, var(--font-paragraph--size));
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

.tax-note.tax-note.tax-note {
  font-size: min(0.85em, var(--font-paragraph--size));
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

product-price.text-block:is(.h1, .h2, .h3, .h4, .h5, .h6) > *:not(.tax-note) {
  margin-block: 0;
}

.compare-at-price {
  opacity: 0.4;
  text-decoration-line: line-through;
  text-decoration-thickness: 1.5px;
}

.card-gallery {
  position: relative;
}

@media screen and (min-width: 750px) {
  product-card:focus-within .quick-add__button,
  .card-gallery:hover .quick-add__button {
    display: grid;
    will-change: margin, opacity;
    animation: elementSlideInTop var(--animation-speed) var(--animation-easing);
  }
}

@container (max-width: 70px) {
  .card-gallery:hover .quick-add__button {
    display: none;
  }
}

/* Drawer */
.drawer {
  background-color: var(--color-background);
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--sidebar-width);
  z-index: var(--layer-raised);
  transform: translateX(-120%);
  transition: transform var(--animation-speed) var(--animation-easing);
}

.drawer[data-open='true'] {
  transform: translateX(0);
}

.drawer-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.drawer__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--drawer-header-block-padding) var(--drawer-inline-padding);
}

.drawer__title {
  font-size: var(--font-h2--size);
  margin: 0;
}

.drawer__close {
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
}

.drawer__content {
  display: block;
  padding: var(--drawer-content-block-padding) var(--drawer-inline-padding);
  width: 100%;
}

/* Background overlay */
.background-overlay {
  position: relative;

  &::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--background-overlay-color, rgb(0 0 0 / 15%));
  }
}

/* Spacing style */
.spacing-style {
  --spacing-scale: var(--spacing-scale-md);

  @media screen and (min-width: 990px) {
    --spacing-scale: var(--spacing-scale-default);
  }

  /* Must disable this, when you use these with calc and another unit type, things break — see logo.liquid */
  /* stylelint-disable length-zero-no-unit */
  --padding-block: 0px;
  --padding-block-start: var(--padding-block, 0px);
  --padding-block-end: var(--padding-block, 0px);
  --padding-inline: 0px;
  --padding-inline-start: var(--padding-inline, 0px);
  --padding-inline-end: var(--padding-inline, 0px);
  --margin-block: 0px;
  --margin-block-start: var(--margin-block, 0px);
  --margin-block-end: var(--margin-block, 0px);
  --margin-inline: 0px;
  --margin-inline-start: var(--margin-inline, 0px);
  --margin-inline-end: var(--margin-inline, 0px);
}

.spacing-style,
.inherit-spacing {
  padding-block: calc(var(--padding-block-start) + var(--section-top-offset, 0px)) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  margin-block: var(--margin-block-start) var(--margin-block-end);
  margin-inline: var(--margin-inline-start) var(--margin-inline-end);
}

/* Size style */
.size-style {
  width: var(--size-style-width-mobile, var(--size-style-width));
  height: var(--size-style-height-mobile, var(--size-style-height));

  @media screen and (min-width: 750px) {
    width: var(--size-style-width);
    height: var(--size-style-height);
  }
}

/* Custom Typography style */
.custom-typography,
.custom-typography > * {
  font-family: var(--font-family);
  font-weight: var(--font-weight);
  text-transform: var(--text-transform);
  text-wrap: var(--text-wrap);
  line-height: var(--line-height);
  letter-spacing: var(--letter-spacing);
}

.custom-typography {
  h1 {
    line-height: var(--line-height--display, var(--line-height));
  }

  h2,
  h3,
  h4 {
    line-height: var(--line-height--heading, var(--line-height));
  }

  p {
    line-height: var(--line-height--body, var(--line-height));
  }
}

.custom-font-size,
.custom-font-size > * {
  font-size: var(--font-size);
}

.custom-font-weight,
.custom-font-weight > * {
  font-weight: var(--weight);
}

/* Border override style */
.border-style {
  border-width: var(--border-width);
  border-style: var(--border-style);
  border-color: var(--border-color);
  border-radius: var(--border-radius);
}

/* Gap scaling style */
.gap-style,
.layout-panel-flex {
  --gap-scale: var(--spacing-scale-md);

  @media screen and (min-width: 990px) {
    --gap-scale: var(--spacing-scale-default);
  }
}

.layout-panel-flex {
  display: flex;
  gap: var(--gap);
  height: 100%;
}

.layout-panel-flex--row {
  flex-flow: row var(--flex-wrap);
  justify-content: var(--horizontal-alignment);
  align-items: var(--vertical-alignment);
}

.layout-panel-flex--column {
  flex-flow: column var(--flex-wrap);
  align-items: var(--horizontal-alignment);
  justify-content: var(--vertical-alignment);
}

@media screen and (max-width: 749px) {
  .mobile-column {
    flex-flow: column nowrap;
    align-items: var(--horizontal-alignment);
    justify-content: var(--vertical-alignment-mobile);
  }

  .layout-panel-flex--row:not(.mobile-column) {
    flex-wrap: var(--flex-wrap-mobile);

    > .text-block {
      flex: 1 1 var(--max-width--display-tight);
    }

    > .image-block {
      flex: 1 1 var(--size-style-width-mobile-min);
    }

    > .button {
      flex: 0 0 fit-content;
    }
  }
}

@media (min-width: 750px) {
  .layout-panel-flex {
    flex-direction: var(--flex-direction);
  }
}

/* Form fields */
.field {
  position: relative;
  width: 100%;
  display: flex;
  transition: box-shadow var(--animation-speed) ease;
}

.field__input {
  flex-grow: 1;
  text-align: left;
  border-radius: var(--style-border-radius-inputs);
  transition: box-shadow var(--animation-speed) ease, background-color var(--animation-speed) ease;
  padding: var(--input-padding);
  box-shadow: var(--input-box-shadow);
  background-color: var(--color-input-background);
  color: var(--color-input-text);
  border: none;
  outline: none;
  font-size: var(--font-paragraph--size);

  &:autofill {
    background-color: var(--color-input-background);
    color: var(--color-input-text);
  }
}

.field__input:is(:focus, :hover) {
  box-shadow: var(--input-box-shadow-focus);
  background-color: var(--color-input-hover-background);
}

.field__input--button-radius {
  border-radius: var(--style-border-radius-buttons-primary);
}

.field__input--button-padding {
  padding-inline: var(--padding-3xl);
}

.field__label {
  color: rgb(var(--color-input-text-rgb) / var(--opacity-80));
  font-size: var(--font-paragraph--size);
  left: var(--input-padding-x);
  top: 50%;
  transform: translateY(-50%);
  margin-bottom: 0;
  pointer-events: none;
  position: absolute;
  transition: top var(--animation-speed) ease, font-size var(--animation-speed) ease;
}

/* RTE styles */
.rte,
.shopify-policy__title {
  :is(h1, h2, h3, h4, h5, h6) {
    margin-block: clamp(1.5rem, 1em * 3.3, 2.5rem) clamp(1rem, 1em * 0.25, 2rem);
  }

  :first-child:is(p, h1, h2, h3, h4, h5, h6),
  :first-child:empty + :is(p, h1, h2, h3, h4, h5, h6) {
    margin-block-start: 0;
  }

  ul,
  ol {
    margin-block-start: 0;
    padding-inline-start: 1.5em;
  }

  /* Only apply margin-block-end to the higher level list, not nested lists */
  :is(ul, ol):not(:is(ul, ol) :is(ul, ol)) {
    margin-block-end: 1em;
  }

  blockquote {
    margin-inline: 1.5em 2.3em;
    margin-block: 3.8em;
    padding-inline-start: 0.8em;
    border-inline-start: 1.5px solid rgb(var(--color-foreground-rgb) / var(--opacity-25));
    font-style: italic;
    font-weight: 500;
  }

  .rte-table-wrapper {
    overflow-x: auto;
  }

  table {
    /* stylelint-disable-next-line declaration-no-important */
    width: 100% !important;
    border-collapse: collapse;
  }

  tr:not(:has(td)),
  thead {
    background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
    font-weight: bold;
    text-transform: uppercase;
  }

  tr:has(td) {
    border-bottom: 1px solid rgb(var(--color-foreground-rgb) / var(--opacity-10));
  }

  th,
  td {
    text-align: start;
    padding-inline: var(--padding-md);
    padding-block: var(--padding-sm);
  }
}

.shopify-policy__container {
  padding-block: var(--padding-xl);
}

.checkbox {
  --checkbox-size: 22px;
  --checkbox-top: 50%;
  --checkbox-left: 1.5px;
  --checkbox-offset: 3px;
  --checkbox-border-radius: 7px;
  --checkbox-label-padding: 8px;
  --checkbox-path-opacity: 0;
  --checkbox-cursor: pointer;
  --checkbox-border: 1px solid rgb(var(--color-foreground-rgb) / var(--opacity-35-55));

  position: relative;
  display: flex;
  align-items: center;

  @media screen and (min-width: 750px) {
    --checkbox-size: 16px;
    --checkbox-border-radius: 5px;
    --checkbox-label-padding: 6px;
  }

  &:has(.checkbox__input:checked) {
    --checkbox-path-opacity: 1;
  }

  &:has(.checkbox__input:disabled) {
    --checkbox-cursor: not-allowed;
  }
}

.checkbox__input {
  position: absolute;
  opacity: 0;
  margin: 0;
  width: var(--checkbox-size);
  height: var(--checkbox-size);

  /* Outline is on the SVG instead, to allow it to have border-radius */
  &:focus-visible {
    outline: none;
  }

  &:focus-visible + .checkbox__label .icon-checkmark {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }

  &:checked + .checkbox__label .icon-checkmark {
    background-color: var(--color-foreground);
    border-color: var(--color-foreground);
  }

  &:disabled + .checkbox__label .icon-checkmark {
    background-color: var(--input-disabled-background-color);
    border-color: var(--input-disabled-border-color);
  }
}

.checkbox__label {
  position: relative;
  display: inline-flex;
  cursor: var(--checkbox-cursor);
  line-height: var(--checkbox-size);
  min-width: var(--minimum-touch-target);
}

.checkbox .icon-checkmark {
  height: var(--checkbox-size);
  width: var(--checkbox-size);
  flex-shrink: 0;
  border: var(--checkbox-border);
  border-radius: var(--checkbox-border-radius);
  background-color: var(--color-background);
}

.checkbox__label-text {
  padding-inline-start: var(--checkbox-label-padding);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.checkbox .icon-checkmark path {
  stroke: var(--color-background);
  opacity: var(--checkbox-path-opacity);
  transition: opacity var(--animation-speed) var(--animation-easing);
}

.checkbox__input:disabled + .checkbox__label {
  color: var(--input-disabled-text-color);
}

/* Add to cart button */
.button[id^='BuyButtons-ProductSubmitButton-'] {
  position: relative;
  overflow: hidden;
}

/* Cart bubble */
.cart-bubble {
  --cart-padding: 0.2em;

  position: relative;
  width: 20px;
  aspect-ratio: 1;
  border-radius: 50%;
  border-width: 0;
  display: flex;
  line-height: normal;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-button-text);
  padding-inline: var(--cart-padding);
}

.cart-bubble__background {
  position: absolute;
  inset: 0;
  background-color: var(--color-primary-button-background);
  border-radius: var(--style-border-radius-lg);
}

.cart-bubble__text {
  font-size: var(--font-size--2xs);
  z-index: var(--layer-flat);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Quantity selector */
.quantity-selector {
  --quantity-selector-width: 124px;

  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--color-input-text);
  background-color: var(--color-input-background);
  border: var(--style-border-width-inputs) solid var(--color-input-border);
  border-radius: var(--style-border-radius-inputs);
  flex: 1 1 var(--quantity-selector-width);
  align-self: stretch;
  transition: background-color var(--animation-speed) var(--animation-easing);

  &:hover {
    background-color: var(--color-input-hover-background);
  }
}

.product-form-buttons:has(.add-to-cart-button.button-secondary) .quantity-selector {
  border-radius: var(--style-border-radius-buttons-secondary);
}

.quantity-selector :is(.quantity-minus, .quantity-plus) {
  /* Unset button styles */
  padding: 0;
  background: transparent;
  box-shadow: none;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
  flex-shrink: 0;
  color: var(--color-input-text);
}

.quantity-selector .quantity-minus {
  border-start-start-radius: var(--style-border-radius-inputs);
  border-end-start-radius: var(--style-border-radius-inputs);
}

.quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-inputs);
  border-end-end-radius: var(--style-border-radius-inputs);
}

.product-details .quantity-selector {
  border-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-minus {
  border-start-start-radius: var(--style-border-radius-buttons-primary);
  border-end-start-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-buttons-primary);
  border-end-end-radius: var(--style-border-radius-buttons-primary);
}

.quantity-selector .svg-wrapper {
  transition: transform var(--animation-speed) var(--animation-easing);
}

.quantity-selector svg {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

:is(.quantity-minus, .quantity-plus):active .svg-wrapper {
  transform: scale(0.9);
}

.quantity-selector input[type='number'] {
  margin: 0;
  text-align: center;
  border: none;
  appearance: none;
  max-width: calc(var(--quantity-selector-width) - var(--minimum-touch-target) * 2);
  border-radius: var(--style-border-radius-buttons);
  color: var(--color-input-text);
  background-color: transparent;
}

/* Chrome, Safari, Edge, Opera */
.quantity-selector input[type='number']::-webkit-inner-spin-button,
.quantity-selector input[type='number']::-webkit-outer-spin-button {
  appearance: none;
}

/* Firefox */
.quantity-selector input[type='number'] {
  appearance: textfield;
}

/* Pills (used in facets and predictive search) */

.pills__pill {
  --pills-pill-background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5-15));

  color: var(--color-foreground);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--gap-sm);
  min-width: 48px;
  padding: 6px 12px;
  border-radius: var(--style-border-radius-pills);
  cursor: pointer;
  background-color: var(--pills-pill-background-color);
  transition: background-color var(--animation-speed) var(--animation-easing);

  &:hover {
    --pills-pill-background-color: rgb(var(--color-foreground-rgb) / var(--opacity-10-25));
  }

  @media screen and (max-width: 749px) {
    padding: var(--padding-xs) var(--padding-md);
  }
}

.pills__pill > .svg-wrapper {
  --close-icon-opacity: 0.4;
  --icon-stroke-width: 1px;

  color: var(--color-foreground);
}

.pills__pill--swatch {
  @media screen and (max-width: 749px) {
    padding-inline-start: var(--padding-sm);
  }
}

.pills__pill--swatch .swatch {
  margin-right: -4px;
}

.pills__pill--desktop-small {
  @media screen and (min-width: 750px) {
    font-size: var(--font-size--xs);
  }
}

/* Fly to cart animation */
fly-to-cart {
  position: fixed;
  width: 40px;
  height: 40px;
  left: 0;
  top: 0;
  border-radius: 50%;
  z-index: calc(infinity);
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  box-shadow: 0 4px 8px rgb(0 0 0 / 20%);
  transition: opacity 0.3s ease;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: var(--color-foreground);
  transform: translate(var(--x, 0), var(--y, 0)) scale(var(--scale, 1));
}

/* ------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------ */

/* Animation declarations - to be kept at the bottom of the file for ease of find */
@keyframes grow {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.2);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes slideInLeft {
  from {
    transform: translateX(var(--custom-transform-from, 100%));
  }

  to {
    transform: translateX(var(--custom-transform-to, 0));
  }
}

@keyframes slideInLeftViewTransition {
  from {
    transform: translateX(100px);
  }
}

@keyframes slideOutRight {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(var(--custom-transform-to, -100%));
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes slideOutLeft {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(100%);
  }
}

@keyframes slideInTop {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes slideInTopViewTransition {
  from {
    transform: translateY(100px);
  }
}

@keyframes slideOutBottom {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(100%);
  }
}

@keyframes slideInBottom {
  from {
    transform: translateY(-100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes slideOutTop {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-100%);
  }
}

@keyframes cartBubbleSlideIn {
  from {
    transform: translateY(-1em);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes elementSlideInTop {
  from {
    margin-top: var(--padding-sm);
    opacity: 0;
  }

  to {
    margin-top: 0;
    opacity: 1;
  }
}

@keyframes elementSlideOutTop {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }
}

@keyframes elementSlideInBottom {
  from {
    transform: translateY(calc(-1 * var(--padding-sm)));
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes elementSlideOutBottom {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(calc(-1 * var(--padding-sm)));
    opacity: 0;
  }
}

@keyframes thumbnailsSlideInTop {
  from {
    transform: translateY(calc(-50% + var(--margin-lg)));
    opacity: 0;
  }

  to {
    transform: translateY(-50%);
    opacity: 1;
  }
}

@keyframes thumbnailsSlideOutTop {
  from {
    transform: translateY(-50%);
    opacity: 1;
  }

  to {
    transform: translateY(calc(-50% + var(--margin-lg)));
    opacity: 0;
  }
}

@keyframes thumbnailsSlideInBottom {
  from {
    transform: translateY(100%);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes thumbnailsSlideOutBottom {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(100%);
    opacity: 0;
  }
}

@keyframes search-element-slide-in-bottom {
  0% {
    transform: translateY(20px);
    opacity: 0;
  }

  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes search-element-slide-out-bottom {
  0% {
    transform: translateY(0);
    opacity: 1;
  }

  100% {
    transform: translateY(20px);
    opacity: 0;
  }
}

@keyframes dialogZoom {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(0.95) translateY(1em);
  }
}

@keyframes thumbnail-selected {
  0%,
  100% {
    box-shadow: 0 0 0 2px transparent;
    scale: 0.9;
  }

  50% {
    box-shadow: 0 0 0 2px #000;
    scale: 1;
  }
}

@keyframes backdropFilter {
  from {
    backdrop-filter: brightness(1);
  }

  to {
    backdrop-filter: brightness(0.75);
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes modalSlideInTop {
  from {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes modalSlideOutTop {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }
}

.bubble {
  display: inline-flex;
  height: calc(var(--variant-picker-swatch-height) / 1.5);
  font-size: var(--font-size--xs);
  border-radius: 20px;
  min-width: 20px;
  padding: 0 6px;
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-10-25));
  color: var(--color-foreground);
  align-items: center;
  justify-content: center;
}

.bubble svg {
  width: 12px;
  height: 12px;
}

.top-shadow::before {
  content: '';
  box-shadow: 0 0 10px var(--color-shadow);
  position: absolute;
  z-index: var(--layer-lowest);
  inset: 0;
  clip-path: inset(-50px 0 0 0); /* stylelint-disable-line */
}

@media (min-width: 750px) {
  .top-shadow--mobile::before {
    display: none;
  }
}

.bottom-shadow::before {
  content: '';
  box-shadow: 0 0 10px var(--color-shadow);
  position: absolute;
  z-index: var(--layer-lowest);
  inset: 0;
  clip-path: inset(0 0 -50px 0); /* stylelint-disable-line */
}

@media (min-width: 750px) {
  .bottom-shadow--mobile::before {
    display: none;
  }
}

.video-placeholder-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

:not(deferred-media) > .video-placeholder-wrapper {
  width: var(--video-placeholder-width);
}

.video-placeholder-wrapper > * {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/*
 * Slideshow Component
 */
slideshow-component {
  --cursor: grab;

  position: relative;
  display: flex;
  flex-direction: column;
  timeline-scope: var(--slideshow-timeline);
}

.slideshow--single-media {
  --cursor: default;
}

a slideshow-component {
  --cursor: pointer;
}

/*
 * Slideshow Slides
 */
slideshow-slides {
  width: 100%;
  position: relative;
  display: flex;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-color: transparent transparent;
  scrollbar-width: none;
  gap: var(--slideshow-gap, 0);
  cursor: var(--cursor);

  @media (prefers-reduced-motion) {
    scroll-behavior: auto;
  }

  &::-webkit-scrollbar {
    width: 0;
  }

  &::-webkit-scrollbar-track {
    background: transparent;
  }

  &::-webkit-scrollbar-thumb {
    background: transparent;
    border: none;
  }

  &[size='small'] {
    min-height: 17.5rem;
  }

  &[size='medium'] {
    min-height: 21.25rem;
  }

  &[size='large'] {
    min-height: 25rem;
  }

  @media screen and (min-width: 750px) {
    &[size='small'] {
      min-height: 26.25rem;
    }

    &[size='medium'] {
      min-height: 35rem;
    }

    &[size='large'] {
      min-height: 45rem;
    }
  }
}

slideshow-component[disabled='true'] slideshow-slides {
  overflow: hidden;
}

slideshow-component[mobile-disabled] slideshow-slides {
  @media screen and (max-width: 749px) {
    overflow: hidden;
  }
}

slideshow-slide {
  position: relative;
  scroll-snap-align: start;
  width: var(--slide-width, 100%);
  max-height: 100%;
  flex-shrink: 0;
  view-timeline-axis: inline;
  content-visibility: auto;
  contain-intrinsic-size: auto none;

  slideshow-component[actioned] &,
  &[aria-hidden='false'] {
    content-visibility: visible;
  }

  slideshow-component slideshow-slide:not([aria-hidden='false']) {
    content-visibility: hidden;
  }

  &[hidden]:not([reveal]) {
    display: none;
  }
}

slideshow-slide.product-media-container--tallest {
  content-visibility: visible;
}

@media screen and (max-width: 749px) {
  /* Media gallery has a peeking slide on the right side always, and on the left side when the current slide is the last one */
  .media-gallery--hint
    :is(
      slideshow-slide:has(+ slideshow-slide[aria-hidden='false']:last-of-type),
      slideshow-slide[aria-hidden='false'] + slideshow-slide
    ) {
    content-visibility: auto;

    slideshow-component[actioned] & {
      content-visibility: visible;
    }
  }
}

/*
 * Collection and Resource list carousels have peeking slides on both sides.
 * Card galleries preview the next or previous images on 'pointerenter', so we
 * try to kick load them beforehand (they are lazy loaded otherwise).
 */
:is(.resource-list__carousel, .card-gallery)
  :is(
    slideshow-slide:has(+ slideshow-slide[aria-hidden='false']),
    slideshow-slide[aria-hidden='false'] + slideshow-slide
  ) {
  content-visibility: auto;

  slideshow-component[actioned] & {
    content-visibility: visible;
  }
}

/*
 * Be specific about HTML children structure to avoid targeting nested slideshows.
 * Ensure that the content is 'visible' while scrolling instead of 'auto' to avoid issues in Safari.
 */
slideshow-component:is([dragging], [transitioning], :hover) > slideshow-container > slideshow-slides > slideshow-slide {
  content-visibility: visible;
}

slideshow-slides[gutters*='start'] {
  padding-inline-start: var(--gutter-slide-width, 0);
  scroll-padding-inline-start: var(--gutter-slide-width, 0);
}

slideshow-slides[gutters*='end'] {
  padding-inline-end: var(--gutter-slide-width, 0);
}

slideshow-component[dragging] {
  --cursor: grabbing;

  * {
    pointer-events: none;
  }
}

slideshow-component[dragging] slideshow-arrows {
  display: none;
}

slideshow-container {
  width: 100%;
  display: block;
  position: relative;
  grid-area: container;
  container-type: inline-size;
}

/*
 * Slideshow Controls
 */
slideshow-controls {
  flex-shrink: 0;
  display: flex;
  justify-content: space-between;
  scrollbar-width: none;
  min-height: var(--minimum-touch-target);
  grid-area: controls;

  &[controls-on-media] {
    position: absolute;
    bottom: 0;
  }
}

slideshow-controls::-webkit-scrollbar {
  display: none;
}

slideshow-controls button {
  --color: rgb(var(--color-foreground-rgb) / var(--opacity-30));
  --color-active: var(--color-foreground);
  --color-hover: rgb(var(--color-foreground-rgb) / var(--opacity-50));

  display: inline-block;
  height: var(--minimum-touch-target);
  width: var(--minimum-touch-target);
  cursor: pointer;
}

slideshow-controls .icon {
  width: var(--icon-size-sm);
  height: var(--icon-size-xs);
}

slideshow-controls[pagination-position='center'] {
  align-items: center;
  justify-content: center;
}

slideshow-controls[pagination-position='center'][thumbnails] {
  width: 100%;
}

slideshow-controls[pagination-position='center']:not([controls-on-media], [thumbnails], [icons-on-media]) {
  justify-content: space-between;
}

slideshow-component:has(slideshow-controls[thumbnails]) {
  &:has(slideshow-controls[pagination-position='right']) {
    display: grid;
    grid-template:
      'container controls' auto
      'arrows controls' min-content
      / 1fr auto;
  }

  &:has(slideshow-controls[pagination-position='left']) {
    display: grid;
    grid-template:
      'controls container' auto
      'controls arrows' min-content
      / auto 1fr;
  }

  slideshow-controls[pagination-position='left'] {
    order: -1;
  }
}

slideshow-controls[thumbnails]:is([pagination-position='right'], [pagination-position='left']) {
  display: flex;
  flex-direction: column;
  height: 0;
  min-height: 100%;

  .slideshow-controls__thumbnails-container {
    overflow: hidden auto;
  }

  &:not([controls-on-media]) {
    .slideshow-controls__thumbnails-container {
      position: sticky;
      top: var(--sticky-header-offset, 0);
    }

    .slideshow-controls__thumbnails {
      padding-block-start: var(--focus-outline-offset);
    }
  }
}

slideshow-controls:not([controls-on-media])[icons-on-media] {
  &[pagination-position='right'] {
    justify-content: flex-end;
  }

  &[pagination-position='left'] {
    justify-content: flex-start;
  }
}

slideshow-controls:not([controls-on-media]):is([pagination-position='left'], [pagination-position='right'])
  .slideshow-controls__thumbnails {
  padding-block: var(--padding-2xs);
}

slideshow-controls:not([controls-on-media]) {
  &:is([pagination-position='right']) {
    .slideshow-controls__thumbnails {
      padding-inline-end: var(--slideshow-thumbnails-padding-inline, var(--focus-outline-offset));
    }
  }

  &:is([pagination-position='left']) {
    .slideshow-controls__thumbnails {
      padding-inline-start: var(--slideshow-thumbnails-padding-inline, var(--focus-outline-offset));
    }
  }
}

slideshow-controls[controls-on-media] {
  z-index: var(--layer-raised);

  &:has(.slideshow-controls__dots, .slideshow-controls__counter) {
    --color-foreground: #fff;
    --color-foreground-rgb: var(--color-white-rgb);
  }

  &[pagination-position='right'] {
    right: 0;
  }

  &[pagination-position='left'] {
    left: 0;
  }

  &[pagination-position='center'] {
    width: 100%;
  }

  &:not([thumbnails])[pagination-position='left'] {
    width: fit-content;
    align-self: flex-start;
  }

  &:not([thumbnails])[pagination-position='right'] {
    width: fit-content;
    align-self: flex-end;
  }
}

slideshow-controls:is([pagination-position='right'], [pagination-position='left']) {
  .slideshow-controls__thumbnails {
    flex-direction: column;
  }
}

.slideshow-controls__arrows {
  display: flex;
  justify-content: space-between;
  height: var(--minimum-touch-target);
  grid-area: arrows;

  button {
    padding: 0 var(--padding-xs);
  }
}

.slideshow-controls__dots,
.slideshow-controls__counter {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  list-style: none;

  button {
    --color: rgb(var(--color-foreground-rgb) / var(--opacity-30));
    --color-active: var(--color-foreground);
    --color-hover: rgb(var(--color-foreground-rgb) / var(--opacity-50));
  }
}

slideshow-controls:has(.slideshow-controls__dots),
slideshow-component[autoplay] slideshow-controls {
  mix-blend-mode: difference;
}

.slideshow-controls__dots {
  gap: 0.6rem;
  padding: var(--padding-sm) var(--padding-lg);
  border-radius: 3rem;
  overflow: hidden;

  button {
    --size: 0.5rem;

    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(var(--size) * 2);
    height: calc(var(--size) * 2);
    margin: calc(var(--size) / -2);
    font-size: 0;
    border-radius: calc(var(--size));

    &::after {
      content: '';
      display: block;
      background-color: var(--color);
      height: var(--size);
      width: var(--size);

      /* This is at --size / 2 to remove a visual regression on subpixel rendering displays */
      border-radius: calc(var(--size) / 2);

      @supports not (view-timeline-axis: inline) {
        &[aria-selected='true'] {
          --color: var(--color-active);
        }
      }

      &:hover {
        --color: var(--color-hover);
      }
    }

    &[aria-selected='true'] {
      --color: var(--color-active);
    }
  }
}

.slideshow-controls__dots,
.slideshow-controls__counter {
  &:only-child {
    margin-inline: auto;
  }
}

.slideshow-controls__counter {
  color: var(--color-foreground);
  background-color: rgb(0 0 0 / 40%);
  width: auto;
  border-radius: 2rem;
  padding: 0.3rem var(--padding-sm);
  margin-inline: var(--margin-sm);
  backdrop-filter: blur(10px);
  font-variant-numeric: tabular-nums;
  font-size: var(--font-size--xs);

  .slash {
    color: rgb(var(--color-foreground-rgb) / var(--opacity-40));
    padding-inline: var(--padding-2xs);
    margin-block-start: -0.1rem;
  }
}

.slideshow-control[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.slideshow-control--large {
  .icon-caret {
    --icon-stroke-width: 1px;
  }

  .icon-caret {
    --icon-stroke-width: 1px;
  }

  .svg-wrapper,
  svg {
    width: var(--slideshow-controls-icon);
    height: var(--slideshow-controls-icon);
  }
}

/* Slideshow control shape styles */
.button-unstyled.slideshow-control.slideshow-control--shape-square,
.button-unstyled.slideshow-control.slideshow-control--shape-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1 / 1;
  background-color: var(--color-primary-button-background);
  color: var(--color-primary-button-text);
}

.button-unstyled.slideshow-control.slideshow-control--shape-circle {
  border-radius: 50%;
}

.button-unstyled.slideshow-control.slideshow-control--shape-square {
  border-radius: 0;
}

.slideshow-control .icon-caret {
  rotate: -90deg;
}

/* Slideshow Thumbnails */
.slideshow-controls__thumbnails-container {
  display: flex;
  width: 100%;
  max-height: 100%;
  overflow-x: scroll;
  scrollbar-width: none;
}

.slideshow-controls__thumbnails {
  display: inline-flex;
  padding-inline: var(--slideshow-thumbnails-padding-inline, var(--padding-sm));
  padding-block: var(--slideshow-thumbnails-padding-block, var(--padding-sm));
  gap: var(--gap-xs);
  margin-inline: auto;
  height: fit-content;

  .slideshow-control {
    border-radius: var(--media-radius);
    width: clamp(44px, 7vw, var(--thumbnail-width));
    height: auto;
    aspect-ratio: var(--aspect-ratio);

    img {
      height: 100%;
      object-fit: cover;
      border-radius: var(--media-radius);
    }

    &:is([aria-selected='true']) {
      outline: var(--focus-outline-width) solid currentcolor;
      outline-offset: calc(var(--focus-outline-offset) / 2);
      border: var(--style-border-width) solid rgb(var(--color-border-rgb) / var(--media-border-opacity));
    }
  }
}

.slideshow-controls__thumbnail {
  position: relative;
}

.slideshow-controls__thumbnail-badge {
  position: absolute;
  top: var(--padding-2xs);
  right: var(--padding-2xs);
  width: clamp(16px, 10%, 20px);
  height: clamp(16px, 10%, 20px);
  background-color: var(--color-background);
  border-radius: var(--style-border-radius-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 1px rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

.slideshow-controls__thumbnail-badge svg {
  width: 60%;
  height: 60%;
  fill: var(--color-foreground);
  opacity: 0.6;
}

/* Slideshow Play/Pause */
.slideshow-control:is(.icon-pause, .icon-play) {
  color: var(--color-active);

  &:hover {
    color: var(--color-hover);
  }

  svg {
    display: none;
  }
}

slideshow-component:is([autoplay]) {
  &:is([paused]) {
    .icon-play > svg {
      display: block;
    }
  }

  &:not([paused]) {
    .icon-pause > svg {
      display: block;
    }
  }
}

/* Slideshow Arrows */
slideshow-arrows {
  --cursor-previous: w-resize;
  --cursor-next: e-resize;

  position: absolute;
  inset: 0;
  display: flex;
  z-index: var(--layer-heightened);
  pointer-events: none;
  mix-blend-mode: difference;
  align-items: flex-end;

  &[position='left'] {
    justify-content: flex-start;
    padding-inline: var(--padding-xs);
  }

  &[position='right'] {
    justify-content: flex-end;
    padding-inline: var(--padding-xs);
  }

  &[position='center'] {
    justify-content: space-between;
    align-items: center;
  }
}

slideshow-arrows:has(.slideshow-control--shape-square),
slideshow-arrows:has(.slideshow-control--shape-circle) {
  mix-blend-mode: normal;
}

slideshow-component[disabled='true'] slideshow-arrows {
  display: none;
}

slideshow-arrows .slideshow-control {
  pointer-events: auto;
  opacity: 0;
  min-height: var(--minimum-touch-target);
  padding: 0 var(--padding-xs);
  color: var(--color-white);
}

slideshow-arrows .slideshow-control.slideshow-control--style-none {
  display: none;
}

.media-gallery--carousel slideshow-arrows .slideshow-control {
  padding-inline: 0 var(--padding-md);
}

.card-gallery slideshow-arrows .slideshow-control {
  /* Align icons with quick-add button */
  padding-inline: var(--padding-xl);

  @container (max-width: 249px) {
    padding-inline: 0 var(--padding-sm);
  }
}

.media-gallery--carousel slideshow-arrows .slideshow-control {
  opacity: 1;
}

:not(.media-gallery--carousel)
  > :is(slideshow-component:hover, slideshow-component:focus-within):not(:has(slideshow-controls:hover))
  > slideshow-container
  > slideshow-arrows
  .slideshow-control {
  animation: arrowsSlideIn var(--animation-speed) var(--animation-easing) forwards;
}

@keyframes arrowsSlideIn {
  from {
    transform: translate(var(--padding-sm), 0);
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.block-resource-list {
  display: flex;
  flex-direction: column;
  row-gap: var(--gap);
  min-width: 0;
  min-height: 0;
  container-type: inline-size;
  container-name: resource-list;
}

.section-resource-list {
  row-gap: var(--gap);
}

.section-resource-list__content {
  display: flex;
  flex-direction: column;
  align-items: var(--horizontal-alignment);
  gap: var(--gap);
  width: 100%;
}

.section-resource-list__content:empty {
  display: none;
}

.section-resource-list__header:is(:empty, :has(.group-block-content:empty)),
.section-resource-list__content:empty {
  display: none;
}

.section-resource-list.section--full-width product-card-link > .group-block {
  @media screen and (max-width: 749px) {
    padding-inline: max(var(--padding-xs), var(--padding-inline-start))
      max(var(--padding-xs), var(--padding-inline-end));
  }
}

.resource-list--carousel-mobile {
  display: block;

  @media screen and (min-width: 750px) {
    display: none;
  }
}

.resource-list {
  --resource-list-mobile-gap-max: 9999px;
  --resource-list-column-gap: min(var(--resource-list-column-gap-desktop), var(--resource-list-mobile-gap-max));
  --resource-list-row-gap: min(var(--resource-list-row-gap-desktop), var(--resource-list-mobile-gap-max));

  width: 100%;

  @media screen and (max-width: 749px) {
    --resource-list-mobile-gap-max: 12px;
  }

  @container resource-list (max-width: 749px) {
    --resource-list-mobile-gap-max: 12px;
  }
}

.resource-list--grid {
  display: grid;
  gap: var(--resource-list-row-gap) var(--resource-list-column-gap);
  grid-template-columns: var(--resource-list-columns-mobile);

  @media screen and (min-width: 750px) {
    grid-template-columns: var(--resource-list-columns);
  }

  @container resource-list (max-width: 449px) {
    grid-template-columns: var(--resource-list-columns-mobile);
  }

  @container resource-list(min-width: 450px) and (max-width: 749px) {
    --resource-list-columns-per-row: 3;

    grid-template-columns: repeat(var(--resource-list-columns-per-row), 1fr);

    /* Avoid orphan in last row when there are 4, 7, or 10 items */
    &:has(.resource-list__item:first-child:nth-last-child(3n + 1)),
    /* Clean two full rows when there are 8 items */
    &:has(.resource-list__item:first-child:nth-last-child(8n)) {
      --resource-list-columns-per-row: 4;
    }
  }

  @container resource-list (min-width: 750px) {
    grid-template-columns: repeat(var(--resource-list-columns-per-row), 1fr);

    &:has(.resource-list__item:first-child:nth-last-child(n + 9)) {
      --resource-list-columns-per-row: 5;
    }

    &:has(.resource-list__item:first-child:nth-last-child(n + 7):nth-last-child(-n + 8)) {
      --resource-list-columns-per-row: 4;
    }

    &:has(.resource-list__item:first-child:nth-last-child(6)) {
      --resource-list-columns-per-row: 3;
    }

    &:has(.resource-list__item:first-child:nth-last-child(5)) {
      --resource-list-columns-per-row: 5;
    }

    &:has(.resource-list__item:first-child:nth-last-child(-n + 4)) {
      --resource-list-columns-per-row: 4;
    }
  }

  @container resource-list (min-width: 1200px) {
    &:has(.resource-list__item:first-child:nth-last-child(6)) {
      --resource-list-columns-per-row: 6;
    }
  }
}

.resource-list__item {
  height: 100%;
  color: var(--color-foreground);
  text-decoration: none;
}

.resource-list__carousel {
  --slide-width: 60vw;

  width: 100%;
  position: relative;
  container-type: inline-size;
  container-name: resource-list-carousel;

  .slideshow-control[disabled] {
    display: none;
  }

  .slideshow-control--next {
    margin-inline-start: auto;
  }
}

@container resource-list-carousel (max-width: 749px) {
  .resource-list__carousel .resource-list__slide {
    --slide-width: clamp(150px, var(--mobile-card-size, 60cqw), var(--slide-width-max));
  }
}

@container resource-list-carousel (min-width: 750px) {
  .resource-list__carousel .resource-list__slide {
    --section-slide-width: calc(
      (100% - (var(--resource-list-column-gap) * (var(--column-count) - 1)) - var(--peek-next-slide-size)) /
        var(--column-count)
    );
    --fallback-slide-width: clamp(150px, var(--mobile-card-size, 60cqw), var(--slide-width-max));
    --slide-width: var(--section-slide-width, var(--fallback-slide-width));
  }
}

.resource-list__carousel slideshow-slides {
  gap: var(--resource-list-column-gap);

  /* Add padding to prevent hover animations from being clipped in slideshow
     15px accommodates:
     - Scale effect (9px on each side from 1.03 scale)
     - Lift effect (4px upward movement)
     - Shadow (15px spread with -5px offset)
     Using 16px for better alignment with our spacing scale */

  margin-block: -16px;
  padding-block: 16px;
}

.resource-list__carousel slideshow-arrows {
  padding-inline: var(--util-page-margin-offset);
}

.resource-list__carousel .resource-list__slide {
  width: var(--slide-width);
  flex: 0 0 auto;
  scroll-snap-align: start;
  min-width: 0;
}

/* Base styles */
.group-block,
.group-block-content {
  position: relative;
}

.group-block:has(> video-background-component),
.group-block:has(> .background-image-container) {
  overflow: hidden;
}

.group-block-content {
  height: 100%;
  width: 100%;
}

/* Container styles */
.section-content-wrapper.section-content-wrapper:where(.layout-panel-flex) .group-block--fill {
  flex: 1;
}

/* Flex behavior for width variants */
.layout-panel-flex--row > .group-block--width-fit {
  flex: 0;
}

.layout-panel-flex--row > .group-block--width-fill {
  flex: 1;
}

.layout-panel-flex--row > .group-block--width-custom {
  flex-basis: var(--size-style-width);
}

/* Dimension utilities - Height */
.group-block--height-fit {
  height: auto;
}

.group-block--height-custom,
.group-block--height-fill {
  height: var(--size-style-height);
}

/* Flex behavior for height variants */
.layout-panel-flex--column > .group-block--height-fit {
  flex: 0 1 auto;
}

.layout-panel-flex--column > .group-block--height-fill {
  flex: 1;
}

.layout-panel-flex--column > .group-block--height-custom {
  flex-basis: var(--size-style-height);
}

accordion-custom {
  details {
    &::details-content,
    .details-content {
      block-size: 0;
      overflow-y: clip;
      opacity: 0;
      interpolate-size: allow-keywords;
      transition: content-visibility var(--animation-speed-slow) allow-discrete,
        padding-block var(--animation-speed-slow) var(--animation-easing),
        opacity var(--animation-speed-slow) var(--animation-easing),
        block-size var(--animation-speed-slow) var(--animation-easing);
    }

    &:not([open]) {
      &::details-content,
      .details-content {
        padding-block: 0;
      }
    }

    &[open] {
      &::details-content,
      .details-content {
        opacity: 1;
        block-size: auto;

        @starting-style {
          block-size: 0;
          opacity: 0;
          overflow-y: clip;
        }

        &:focus-within {
          overflow-y: visible;
        }
      }
    }
  }
}

accordion-custom[data-disable-on-mobile='true'] summary {
  @media screen and (max-width: 749px) {
    cursor: auto;
  }
}

accordion-custom[data-disable-on-desktop='true'] summary {
  @media screen and (min-width: 750px) {
    cursor: auto;
  }
}

text-component {
  --shimmer-text-color: rgb(var(--color-foreground-rgb) / var(--opacity-50));
  --shimmer-color-light: rgb(var(--color-foreground-rgb) / var(--opacity-10));
  --shimmer-speed: 1.25s;

  display: inline-block;
  position: relative;
  transition: color var(--animation-speed-slow) ease;
  line-height: 1;

  &::after {
    content: attr(value);
    position: absolute;
    inset: 0;
    color: transparent;
    opacity: 0;
    transition: opacity var(--animation-speed-slow) var(--animation-easing);
    pointer-events: none;
    background-image: linear-gradient(
      -85deg,
      var(--shimmer-text-color) 10%,
      var(--shimmer-color-light) 50%,
      var(--shimmer-text-color) 90%
    );
    background-clip: text;
    background-size: 200% 100%;
    background-position: 100% 0;
    place-content: center;
  }

  &[shimmer] {
    color: transparent;

    &::after {
      opacity: 1;
      animation: text-shimmer var(--shimmer-speed) infinite linear;
    }
  }
}

@keyframes text-shimmer {
  0% {
    background-position: 100% 0;
  }

  100% {
    background-position: -100% 0;
  }
}

/* Animation transitions */
.transition-background-color {
  transition: background-color var(--animation-speed-medium) ease-in-out;
}

.transition-transform {
  transition: transform var(--animation-speed-medium) var(--animation-timing-bounce);
}

.transition-border-color {
  transition: border-color var(--animation-speed-medium) var(--animation-timing-hover);
}

/* Global scrollbar styles */

/* Webkit browsers */
::-webkit-scrollbar {
  width: 20px;
}

::-webkit-scrollbar-track {
  background-color: transparent;
}

::-webkit-scrollbar-thumb {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-40));
  border-radius: 20px;
  border: 6px solid transparent;
  background-clip: content-box;
  transition: background-color 0.2s;
}

::-webkit-scrollbar-thumb:hover {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-60));
}

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* Product card title truncation - applied only to zoom-out view */
[product-grid-view='zoom-out'] :is(.product-card, .product-grid__card) :is(h4, .h4) {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
}

/* Product card title truncation - applied on mobile regardless of view */
@media screen and (max-width: 749px) {
  :is(.product-card, .product-grid__card) :is(h4, .h4) {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 3;
  }
}

.product-card:hover,
.collection-card:hover,
.resource-card:hover,
.predictive-search-results__card--product:hover,
.predictive-search-results__card:hover {
  position: relative;
  z-index: var(--layer-raised);
  transition: transform var(--hover-transition-duration) var(--hover-transition-timing),
    box-shadow var(--hover-transition-duration) var(--hover-transition-timing);
}

.header .product-card:hover,
.header .collection-card:hover,
.header .resource-card:hover,
.header-drawer .product-card:hover,
.header-drawer .collection-card:hover,
.header-drawer .resource-card:hover {
  z-index: auto;
  transform: none;
  box-shadow: none;
}

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}
/* ===== HospitalsKart – Product Grid Styling ===== */

/* Product Card Base */
.card, .product-grid-item, .product-card {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 10px;
  transition: all 0.3s ease;
  background: #fff;
}

.card:hover, .product-grid-item:hover, .product-card:hover {
  box-shadow: 0 4px 15px rgba(0,0,0,0.08);
  transform: translateY(-3px);
}

/* Product Image */
.card__media img, .product-card__image img {
  border-radius: 10px;
}

/* Product Title */
.card__heading, .product-card__title {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 15px;
  color: #0b2340;
  text-align: center;
  margin-top: 10px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  padding: 6px;
}

/* Product Price */
.price, .product-card__price {
  font-size: 16px;
  color: #007acc;
  font-weight: 700;
  text-align: center;
  margin: 8px 0;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  display: inline-block;
  padding: 5px 10px;
}

/* Add to Cart + Buy Now Buttons (Below Photo) */
.card__content, .product-card__content {
  text-align: center;
}

.add-to-cart-btn, .buy-now-btn {
  display: inline-block;
  margin: 6px 5px;
  padding: 10px 18px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}

/* Add to Cart button */
.add-to-cart-btn {
  background-color: #007acc;
  color: #fff;
}
.add-to-cart-btn:hover {
  background-color: #005fa3;
}
/* ===== HospitalsKart — Final Product Card Buttons Style ===== */

.hk-actions {
  text-align: center;
  margin-top: 10px;
}

/* Base style for both buttons */
.hk-add, .hk-buy {
  display: inline-block;
  min-width: 120px;
  margin: 6px 4px;
  padding: 10px 20px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.25s ease;
  border: 2px solid transparent;
  text-decoration: none;
  text-align: center;
}

/* Add to Cart Button */
.hk-add {
  background: #007acc;
  color: #fff;
  border-color: #007acc;
  box-shadow: 0 2px 6px rgba(0,122,204,0.25);
}
.hk-add:hover {
  background: #005fa3;
  border-color: #005fa3;
  transform: translateY(-2px);
}

/* Buy Now Button */
.hk-buy {
  background: #fff;
  color: #1dbf73;
  border-color: #1dbf73;
  box-shadow: 0 2px 6px rgba(29,191,115,0.2);
}
.hk-buy:hover {
  background: #1dbf73;
  color: #fff;
  transform: translateY(-2px);
}

/* Price border improvement */
.price, .product-card__price {
  display: inline-block;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  padding: 5px 10px;
  font-weight: 700;
  color: #007acc;
  background: #f8fafc;
}

/* Responsive layout */
@media (max-width: 768px) {
  .hk-add, .hk-buy {
    width: 45%;
    margin: 5px 2%;
  }
}
/* HospitalsKart Blue Buttons */
.hk-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}
/* HospitalsKart Blue Buttons */
.hk-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}

.hk-btn {
  background: #007acc;
  color: #fff;
  padding: 10px 18px;
  border-radius: 8px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: 0.25s;
  min-width: 120px;
  text-align: center;
}

.hk-btn:hover {
  background: #005fa3;
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .hk-actions { flex-direction: column; gap: 8px; }
  .hk-btn { width: 100%; }
}
/* HK: Inserted Add to Cart style (blue) */
.hk-inline-wrapper {
  display: inline-block;
  margin-left: 10px;
  vertical-align: middle;
}

.hk-btn.hk-js-add, .hk-btn {
  background: #007acc;
  color: #fff;
  padding: 7px 14px;
  border-radius: 8px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  transition: all .18s;
  line-height: 1;
}

.hk-btn.hk-js-add:hover, .hk-btn:hover { background: #005fa3; transform: translateY(-1px); }

@media (max-width: 768px) {
  .hk-inline-wrapper { display: block; margin-left: 0; margin-top: 6px; }
  .hk-btn.hk-js-add { width: 90%; text-align:center; }
}


.hk-btn {
  background: #007acc;
  color: #fff;
  padding: 8px 16px;
  border-radius: 8px;
  border: none;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s;
  white-space: nowrap;
}

.hk-btn:hover {
  background: #005fa3;
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .hk-price-row {
    flex-direction: column;
    align-items: center;
  }
  .hk-btn {
    width: 90%;
    text-align: center;
  }
}
/* ===== HospitalsKart FORCE: Price + Add to Cart side-by-side ===== */
/* high-specificity + !important to override theme defaults */

.product-card__content .hk-price-row,
.product-grid__card .hk-price-row,
.card .hk-price-row,
.hk-price-row {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 12px !important;
  margin-top: 8px !important;
}

.hk-price-row .hk-price,
.hk-price-row .price,
.hk-price-row [class*="price"] {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
}

.hk-price-row form,
.hk-price-row .hk-inline,
.hk-price-row .hk-btn {
  margin: 0 !important;
  vertical-align: middle !important;
}

.hk-btn {
  background: #007acc !important;
  color: #fff !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  border: none !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  min-width: 110px !important;
}

/* Mobile: stack vertically */
@media (max-width: 768px) {
  .product-card__content .hk-price-row,
  .hk-price-row {
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
  }
  .hk-btn {
    width: 90% !important;
  }
}
/* ===== HospitalsKart | Price Left – Add to Cart Right ===== */
.hk-price-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important; /* price left, button right */
  flex-wrap: nowrap !important;
  width: 100%;
  margin-top: 8px;
  gap: 10px;
}

/* Price styling */
.hk-price-row .hk-price {
  font-size: 16px;
  font-weight: 600;
  color: #0b2340;
  display: inline-flex;
  align-items: center;
}

/* Add-to-Cart button */
.hk-btn {
  background: #007acc;
  color: #fff;
  padding: 8px 18px;
  border-radius: 8px;
  border: none;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s ease;
  white-space: nowrap;
}

.hk-btn:hover {
  background: #005fa3;
  transform: translateY(-1px);
}

/* Mobile view: stack vertically */
@media (max-width: 768px) {
  .hk-price-row {
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .hk-btn {
    width: 90%;
    text-align: center;
  }
}
/* === HospitalsKart | Orange + Light Purple Gradient Announcement Bar === */
.header__announcement,
.announcement-bar,
.announcement-bar__message {
  background: linear-gradient(90deg, #ff7a00 0%, #b37cff 100%) !important;
  color: #ffffff !important;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.3px;
  text-align: center;
  padding: 10px 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  animation: fadeSlide 0.8s ease;
}

.header__announcement a,
.announcement-bar a {
  color: #fff !important;
  text-decoration: underline;
  font-weight: 700;
}

@keyframes fadeSlide {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* ===== HospitalsKart | Right Corner Partner With Us Button (with twinkling star) ===== */
.announcement-bar,
.announcement-bar__message,
.header__announcement {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  text-align: left !important;
}

.hk-top-btn-wrap {
  margin-left: auto !important;
}

.hk-top-btn {
  background: #ffffff;
  color: #ff7a00;
  font-weight: 700;
  text-decoration: none;
  padding: 6px 16px;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 0.25s ease;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
  animation: star-blink 1.5s infinite ease-in-out;
}

.hk-top-btn:hover {
  background: #b37cff;
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 2px 12px rgba(179,124,255,0.6);
}

@keyframes star-blink {
  0%, 100% { box-shadow: 0 0 8px rgba(255,122,0,0.5); }
  50% { box-shadow: 0 0 18px rgba(255,122,0,0.9); }
}

/* Mobile responsive */
@media (max-width: 768px) {
  .announcement-bar,
  .announcement-bar__message,
  .header__announcement {
    flex-direction: column !important;
    text-align: center !important;
  }
  .hk-top-btn-wrap {
    margin: 6px 0 0 0 !important;
  }
}
/* ===== HOSPITALSKART: Force announcement layout + right CTA + twinkle ===== */

/* Make header announcement a two-column flex (text left, CTA right) */
.header__announcement,
.announcement-bar,
.announcement-bar__message {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important; /* left text, right CTA */
  gap: 12px !important;
  padding: 10px 14px !important;
  box-sizing: border-box !important;
  background: linear-gradient(90deg, #ff7a00 0%, #b37cff 100%) !important;
  color: #fff !important;
}

/* Ensure inner wrapper behaves correctly */
.hk-top-btn-wrap {
  margin-left: auto !important;
  display: inline-flex !important;
  align-items: center !important;
}

/* CTA button visual + star */
.hk-top-btn {
  background: #ffffff !important;
  color: #ff7a00 !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15) !important;
  transition: all 0.25s ease !important;
  position: relative !important;
  z-index: 5 !important;
}

/* Make the star (left of text) twinkle — use pseudo element if star not present */
.hk-top-btn .hk-star,
.hk-top-btn::before {
  content: "✨" !important;
  display: inline-block !important;
  margin-right: 6px !important;
  transform-origin: center;
  animation: hk-star-twinkle 1.6s infinite ease-in-out !important;
  font-size: 16px !important;
}

/* If you already have a star char inside the link, ensure it also twinkles */
.hk-top-btn span, .hk-top-btn strong {
  /* no-op but keeps text styling consistent */
}

/* twinkle keyframes */
@keyframes hk-star-twinkle {
  0%   { transform: scale(1); opacity: 1; filter: drop-shadow(0 0 4px rgba(255,122,0,0.4)); }
  50%  { transform: scale(1.25); opacity: 0.9; filter: drop-shadow(0 0 14px rgba(255,122,0,0.9)); }
  100% { transform: scale(1); opacity: 1; filter: drop-shadow(0 0 4px rgba(255,122,0,0.4)); }
}

/* hover style */
.hk-top-btn:hover {
  background: #b37cff !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 18px rgba(179,124,255,0.45) !important;
}

/* make sure announcement text part uses available width and doesn't push CTA down */
.header__announcement .announcement-bar__message,
.announcement-bar__message {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

/* Mobile: stack vertically, CTA centered and slightly separated */
@media (max-width: 768px) {
  .header__announcement,
  .announcement-bar,
  .announcement-bar__message {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 8px !important;
  }
  .hk-top-btn-wrap {
    margin-left: 0 !important;
  }
  .hk-top-btn {
    width: auto !important;
    padding: 8px 14px !important;
  }
}
/* ===== HospitalsKart — Centered announcement text + Right CTA (final) ===== */

/* Container: make relative so we can center the message while keeping CTA right */
.header__announcement,
.announcement-bar,
.announcement-bar__message {
  position: relative !important;
  background: linear-gradient(90deg, #ff7a00 0%, #b37cff 100%) !important;
  color: #ffffff !important;
  padding: 10px 16px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

/* Center the message text (absolute center) */
.header__announcement .announcement-bar__message,
.announcement-bar .announcement-bar__message,
.announcement-bar__message {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  white-space: nowrap !important;
  text-align: center !important;
  width: auto !important;
  font-weight: 600 !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 15px !important;
}

/* Ensure the announcement inner wrapper doesn't push the centered text */
.header__announcement > * {
  position: relative !important;
  z-index: 2 !important;
}

/* CTA wrapper: keep it at right side inside the header */
.hk-top-btn-wrap {
  position: absolute !important;
  right: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 5 !important;
  display: inline-flex !important;
}

/* CTA button visual */
.hk-top-btn {
  background: #ffffff !important;
  color: #ff7a00 !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  padding: 8px 14px !important;
  border-radius: 8px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
  transition: all .25s ease !important;
}

/* Twinkling star (if present inside link as span.hk-star) */
.hk-top-btn .hk-star {
  animation: hk-star-twinkle 1.6s infinite ease-in-out !important;
  font-size: 16px !important;
}

/* Hover */
.hk-top-btn:hover {
  background: #b37cff !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 18px rgba(179,124,255,0.35) !important;
}

/* Twinkle keyframes */
@keyframes hk-star-twinkle {
  0%   { transform: scale(1); opacity: 1; filter: drop-shadow(0 0 4px rgba(255,122,0,0.4)); }
  50%  { transform: scale(1.25); opacity: 0.9; filter: drop-shadow(0 0 14px rgba(255,122,0,0.9)); }
  100% { transform: scale(1); opacity: 1; filter: drop-shadow(0 0 4px rgba(255,122,0,0.4)); }
}

/* MOBILE: centered text should wrap and CTA move below (center) */
@media (max-width: 768px) {
  .header__announcement,
  .announcement-bar,
  .announcement-bar__message {
    padding: 12px 12px !important;
  }
  .header__announcement .announcement-bar__message,
  .announcement-bar .announcement-bar__message,
  .announcement-bar__message {
    position: relative !important;
    left: 0 !important;
    top: 0 !important;
    transform: none !important;
    white-space: normal !important;
    width: 100% !important;
    padding: 0 12px !important;
    box-sizing: border-box !important;
    margin-bottom: 6px !important;
  }
  .hk-top-btn-wrap {
    position: relative !important;
    right: 0 !important;
    transform: none !important;
    margin: 0 auto !important;
    display: inline-block !important;
  }
  .hk-top-btn { width: auto !important; }
}
/* === HOSPITALSKART | Center text + Right Partner CTA (FINAL FIX) === */

/* Container layout */
.header__announcement,
.announcement-bar {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important; /* Center by default */
  position: relative !important;
  background: linear-gradient(90deg, #ff7a00 0%, #b37cff 100%) !important;
  color: #fff !important;
  padding: 12px 18px !important;
  box-sizing: border-box !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  letter-spacing: 0.3px !important;
  text-align: center !important;
}

/* Right-side button wrapper */
.hk-top-btn-wrap {
  position: absolute !important;
  right: 18px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  display: inline-flex !important;
  align-items: center !important;
}

/* Partner With Us button */
.hk-top-btn {
  background: #ffffff !important;
  color: #ff7a00 !important;
  font-weight: 700 !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15) !important;
  transition: all 0.25s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* Star twinkle */
.hk-top-btn::before {
  content: "✨" !important;
  animation: twinkle 1.4s infinite ease-in-out !important;
}

@keyframes twinkle {
  0%, 100% { opacity: 1; transform: scale(1); filter: drop-shadow(0 0 5px rgba(255, 122, 0, 0.6)); }
  50% { opacity: 0.8; transform: scale(1.2); filter: drop-shadow(0 0 10px rgba(255, 122, 0, 1)); }
}

/* Hover */
.hk-top-btn:hover {
  background: #b37cff !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
}

/* Mobile View */
@media (max-width: 768px) {
  .header__announcement,
  .announcement-bar {
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 10px 12px !important;
  }
  .hk-top-btn-wrap {
    position: relative !important;
    right: 0 !important;
    top: 0 !important;
    transform: none !important;
    margin-top: 8px !important;
  }
}
/* ===== HOSPITALSKART | Partner With Us - Right Corner, Visible Button ===== */

/* Make announcement bar relative to position the CTA */
.header__announcement,
.announcement-bar {
  position: relative !important;
}

/* Right corner placement */
.hk-top-btn-wrap {
  position: absolute !important;
  right: 20px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 999 !important;
}

/* Button visual */
.hk-top-btn {
  background: #ffffff !important;         /* White button background */
  color: #ff7a00 !important;              /* Orange text */
  font-weight: 700 !important;
  font-family: 'Poppins', sans-serif !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: all 0.25s ease !important;
}

/* Twinkling star */
.hk-top-btn::before {
  content: "✨" !important;
  animation: hk-twinkle 1.5s infinite ease-in-out !important;
}

@keyframes hk-twinkle {
  0%,100% { opacity: 1; transform: scale(1); filter: drop-shadow(0 0 6px rgba(255,122,0,0.6)); }
  50% { opacity: 0.8; transform: scale(1.3); filter: drop-shadow(0 0 12px rgba(255,122,0,1)); }
}

/* Hover */
.hk-top-btn:hover {
  background: #b37cff !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(179,124,255,0.4) !important;
}

/* Mobile layout fix */
@media (max-width: 768px) {
  .hk-top-btn-wrap {
    position: relative !important;
    right: 0 !important;
    top: 0 !important;
    transform: none !important;
    margin-top: 10px !important;
    display: flex !important;
    justify-content: center !important;
  }
}
/* ===== HospitalsKart — Announcement bar (centered text + right CTA) ===== */
.announcement-bar__outer { width:100%; }
.announcement-bar__inner {
  position: relative !important;
  background: linear-gradient(90deg, #ff7a00 0%, #b37cff 100%) !important;
  color: #fff !important;
  padding: 10px 16px !important;
  box-sizing: border-box !important;
  display: block !important;
  overflow: visible !important;
  z-index: 9999 !important;
}

/* message centered */
.announcement-bar__message { position: relative; text-align: center; }
.announcement-text {
  display: inline-block;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 15px;
  white-space: nowrap;
  color: #fff;
}

/* CTA on right */
.hk-top-btn-wrap {
  position: absolute !important;
  right: 18px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 10000 !important;
  display: inline-flex !important;
}

/* button look */
.hk-top-btn {
  background: #ffffff !important;
  color: #ff7a00 !important;
  font-weight: 700 !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  box-shadow: 0 3px 12px rgba(0,0,0,0.18) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* star before (twinkle) */
.hk-top-btn::before {
  content: "✨" !important;
  display: inline-block !important;
  margin-right: 6px !important;
  animation: hk-twinkle 1.4s infinite ease-in-out !important;
}

/* twinkle */
@keyframes hk-twinkle {
  0%,100% { transform: scale(1); opacity:1; filter: drop-shadow(0 0 6px rgba(255,122,0,0.5)); }
  50% { transform: scale(1.25); opacity:0.9; filter: drop-shadow(0 0 12px rgba(255,122,0,1)); }
}

/* hover */
.hk-top-btn:hover {
  background: #b37cff !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 30px rgba(179,124,255,0.35) !important;
}

/* ensure container doesn't clip */
.header__announcement, .site-header, .header-wrapper, .announcement-bar__inner { overflow: visible !important; }

/* mobile: stack */
@media (max-width: 768px) {
  .announcement-text { white-space: normal; display:block; padding: 0 8px; }
  .hk-top-btn-wrap { position: relative !important; right:0 !important; top:0 !important; transform:none !important; margin-top:8px; display:flex; justify-content:center; }
}
/* ===== HospitalsKart | Final Premium Announcement Bar Polish ===== */

/* full width fix */
.announcement-bar__outer,
.announcement-bar__inner {
  width: 100% !important;
  max-width: 100vw !important;
  margin: 0 auto !important;
  padding: 12px 0 !important;
  box-sizing: border-box !important;
  border-bottom: 2px solid rgba(255,255,255,0.2);
}

/* partner with us button premium style */
.hk-top-btn {
  background: linear-gradient(145deg, #ffffff 0%, #f2f2f2 100%) !important;
  color: #ff7a00 !important;
  font-weight: 700 !important;
  padding: 10px 20px !important;
  border-radius: 10px !important;
  text-decoration: none !important;
  border: 2px solid transparent !important;
  background-clip: padding-box !important;
  box-shadow: 0 3px 12px rgba(0,0,0,0.18), 0 0 0 3px rgba(255,122,0,0.25) !important;
  transition: all 0.35s ease !important;
}

/* hover: orange border glow + subtle lift */
.hk-top-btn:hover {
  background: linear-gradient(145deg, #b37cff 0%, #ff7a00 100%) !important;
  color: #fff !important;
  border: 2px solid #fff !important;
  box-shadow: 0 6px 25px rgba(255,122,0,0.5), 0 0 15px rgba(179,124,255,0.5) !important;
  transform: translateY(-2px) !important;
}

/* glowing border pulse animation */
.hk-top-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  padding: 2px;
  background: linear-gradient(90deg, #ff7a00, #b37cff, #ff7a00);
  background-size: 300% 300%;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: borderFlow 3s linear infinite;
}

@keyframes borderFlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* fix for overlap */
.hk-top-btn-wrap { position: absolute !important; right: 20px !important; top: 50% !important; transform: translateY(-50%) !important; }
/* ===== Mobile fix: announcement bar stack + button below, disable heavy border ===== */
@media (max-width: 768px) {

  /* make inner container stack vertically and center items */
  .announcement-bar__inner,
  .announcement-bar__outer,
  .announcement-bar__message {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 10px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
    text-align: center !important;
  }

  /* make announcement text full width and allow wrapping */
  .announcement-text {
    order: 1 !important;
    width: 100% !important;
    white-space: normal !important;
    font-size: 15px !important;
    padding: 0 8px 8px 8px !important;
    margin: 0 !important;
  }

  /* place CTA under the text, centered */
  .hk-top-btn-wrap {
    order: 2 !important;
    position: relative !important;
    right: 0 !important;
    top: 0 !important;
    transform: none !important;
    margin: 6px auto 0 auto !important;
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
  }

  /* make button readable and not stretched to edges */
  .hk-top-btn {
    width: calc(100% - 32px) !important; /* leaves side padding */
    max-width: 420px !important;
    display: inline-flex !important;
    justify-content: center !important;
    padding: 10px 16px !important;
    font-size: 16px !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.12) !important;
  }

  /* disable the animated ::after border on small screens (prevents overlap) */
  .hk-top-btn::after {
    display: none !important;
  }
}
/* ===== HospitalsKart | Ultra Compact Mobile Announcement Bar ===== */
@media (max-width: 768px) {
  /* reduce total bar height */
  .announcement-bar__outer,
  .announcement-bar__inner,
  .announcement-bar__message {
    padding: 4px 8px !important;
    min-height: auto !important;
  }

  /* smaller text and tighter line spacing */
  .announcement-text {
    font-size: 13px !important;
    line-height: 1.3 !important;
    margin-bottom: 2px !important;
    padding: 0 !important;
  }

  /* compact CTA layout */
  .hk-top-btn-wrap {
    margin-top: 2px !important;
  }

  /* smaller button but full width for visibility */
  .hk-top-btn {
    font-size: 14px !important;
    padding: 6px 10px !important;
    width: calc(100% - 48px) !important;
    max-width: 360px !important;
    border-radius: 8px !important;
  }

  /* optional: reduce emoji twinkle size slightly */
  .hk-top-btn::before {
    font-size: 14px !important;
    margin-right: 4px !important;
  }
}
/* ===== HospitalsKart — Attractive Header & Menu (Gradient + Pills + CTA) ===== */

/* Header background (subtle gradient to match announcement) */
.site-header,
.header__inner,
.header-wrapper {
  background: linear-gradient(90deg,#ff7a00 0%, #b37cff 100%) !important;
  padding: 10px 20px !important;
  box-shadow: 0 6px 30px rgba(179,124,255,0.08) !important;
}

/* Menu container - center & limit width */
.header__menu,
.site-nav {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}

/* Menu links style (pill look) */
.header__menu-item a,
.site-nav__link,
.nav__link {
  background: rgba(255,255,255,0.12);
  color: #fff !important;
  padding: 10px 14px;
  border-radius: 999px;
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: none;
  transition: all .28s cubic-bezier(.2,.9,.2,1);
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  border: 1px solid rgba(255,255,255,0.06);
}

/* Icon support (if you add small emoji/icon inside link) */
.header__menu-item a .menu-icon { margin-right:8px; vertical-align:middle; }

/* Hover - pill fills with white then text becomes brand gradient */
.header__menu-item a:hover,
.site-nav__link:hover,
.nav__link:hover {
  background: #fff !important;
  color: transparent !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  background-image: linear-gradient(90deg,#ff7a00,#b37cff) !important;
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(179,124,255,0.18);
}

/* Active / current link */
.header__menu-item--active a,
.site-nav__link--active {
  background: rgba(255,255,255,0.95) !important;
  color: #ff7a00 !important;
  box-shadow: 0 8px 24px rgba(255,122,0,0.12) !important;
}

/* CTA (Partner With Us) - bigger pill on right (if placed as last menu item) */
.header__menu-item.partner-cta a,
.site-nav__link.partner-cta {
  background: #fff !important;
  color: #ff7a00 !important;
  padding: 10px 20px !important;
  border-radius: 12px !important;
  font-weight: 800 !important;
  box-shadow: 0 10px 30px rgba(255,122,0,0.18);
  border: 2px solid rgba(255,122,0,0.06);
}

/* CTA hover - gradient fill */
.header__menu-item.partner-cta a:hover,
.site-nav__link.partner-cta:hover {
  background: linear-gradient(90deg,#ff7a00 0%, #b37cff 100%) !important;
  color: #fff !important;
  transform: translateY(-3px);
  box-shadow: 0 16px 40px rgba(179,124,255,0.25) !important;
}

/* Dropdown styling (multi-column feel) */
.site-nav__dropdown,
.nav__dropdown,
.header__menu-item .dropdown {
  background: rgba(255,255,255,0.98) !important;
  color: #0b2340 !important;
  border-radius: 10px !important;
  padding: 12px !important;
  box-shadow: 0 12px 40px rgba(11,35,64,0.08) !important;
  min-width: 220px !important;
}

/* Dropdown links */
.site-nav__dropdown a,
.nav__dropdown a {
  display:block;
  padding: 8px 10px;
  border-radius: 8px;
  color: #0b2340 !important;
}
.site-nav__dropdown a:hover,
.nav__dropdown a:hover {
  background: linear-gradient(90deg,#ff7a00 0%, #b37cff 100%);
  color:#fff !important;
  transform: translateX(6px);
}

/* Mobile header: compact, show CTA prominent */
@media (max-width: 768px) {
  .site-header, .header__inner { padding: 8px 12px !important; }
  .header__menu, .site-nav { justify-content: space-between !important; }
  /* make menu pills smaller on mobile */
  .header__menu-item a, .site-nav__link { padding: 8px 10px; font-size:14px; }
  .header__menu-item.partner-cta a, .site-nav__link.partner-cta { padding:10px 12px; font-size:15px; }
}

/* small accessibility tweak: focus outlines */
.header__menu-item a:focus, .site-nav__link:focus { outline: 3px solid rgba(255,122,0,0.15); outline-offset: 3px; }
/* Header: Animated gradient border (premium) */
.header, .site-header, .header__inner, .header-wrapper {
  position: relative !important;
  z-index: 9999 !important;
  background-clip: padding-box !important; /* keep background inside border */
  border-radius: 12px !important;
}

/* gradient border via pseudo-element */
.header::before,
.site-header::before,
.header__inner::before,
.header-wrapper::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 2px;                       /* border thickness */
  border-radius: 12px;
  background: linear-gradient(90deg, #ff7a00, #b37cff, #ff7a00);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: -1; /* behind header content */
  animation: hk-border-flow 4s linear infinite;
}

/* subtle inner shadow so content stands out */
.header { box-shadow: 0 6px 24px rgba(11,35,64,0.08) !important; }

/* animation */
@keyframes hk-border-flow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* mobile: reduce thickness */
@media (max-width: 768px) {
  .header::before, .site-header::before { padding: 1px; border-radius: 10px; }
}
/* ===== HospitalsKart — FORCE center menu (desktop) ===== */

/* Make header a 3-zone container and give safe side padding to avoid overlap */
header-component.header,
header.header,
.site-header,
.shopify-section-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  position: relative !important;
  padding-left: 120px !important;   /* reserves space for logo on left */
  padding-right: 120px !important;  /* reserves space for actions on right */
  box-sizing: border-box !important;
}

/* Logo block — left */
header-component.header .header__logo,
header .header__logo,
.site-header .header__logo,
.header-logo,
.logo-wrapper {
  position: relative;
  z-index: 20;
  flex: 0 0 auto !important;
  display: flex;
  align-items: center;
}

/* Actions block — right (cart/search/cta) */
header-component.header .header-actions,
header .header-actions,
.site-header .header-actions,
.header__icons,
.site-header__icons {
  position: relative;
  z-index: 20;
  flex: 0 0 auto !important;
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}

/* ===== Center the nav absolutely within header (desktop only) ===== */
@media (min-width: 769px) {
  /* target common nav selectors inside the header */
  header-component.header nav,
  header-component.header .header__menu,
  header-component.header .site-nav,
  header-component.header .header-nav,
  header nav,
  header .header__menu,
  .site-header nav,
  .site-nav {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    display: flex !important;
    gap: 12px !important;
    z-index: 18 !important;
    pointer-events: auto !important;
    white-space: nowrap !important;
  }

  /* Ensure nav items display inline and have spacing */
  header-component.header nav a,
  header-component.header .header__menu a,
  header nav a,
  .site-nav a {
    display: inline-block !important;
    padding: 8px 12px !important;
    border-radius: 999px !important;
  }
}

/* ===== Mobile: remove absolute centering and use stacked/default behaviour ===== */
@media (max-width: 768px) {
  header-component.header,
  header.header,
  .site-header {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  header-component.header nav,
  header nav,
  .site-nav {
    position: static !important;
    transform: none !important;
    left: auto !important;
    top: auto !important;
    display: block !important;
    width: 100% !important;
  }

  header-component.header .header__logo,
  .header-logo { margin-right: 0 !important; }
  header-component.header .header-actions,
  .header__icons { margin-left: 0 !important; }
}
/* ===== HospitalsKart | Mobile Drawer Menu Compact Fix ===== */
@media (max-width: 768px) {

  /* Compact mobile drawer panel */
  .menu-drawer,
  .mobile-nav,
  .menu-modal__content,
  .menu-drawer__navigation {
    padding: 10px 15px !important;
  }

  /* Each menu link smaller & closer */
  .menu-drawer__menu-item,
  .mobile-nav__item,
  .menu-modal__item,
  .menu-drawer__navigation a {
    font-size: 15px !important;          /* smaller text */
    font-weight: 500 !important;
    line-height: 1.2 !important;
    padding: 6px 0 !important;           /* tighter vertical space */
    margin: 0 !important;
  }

  /* Reduce huge gap between items */
  .menu-drawer__menu,
  .mobile-nav__list,
  .menu-modal__list {
    gap: 4px !important;
  }

  /* Reduce top padding (first item) */
  .menu-drawer__inner {
    padding-top: 10px !important;
  }

  /* Optional: smaller close (X) icon */
  .menu-drawer__close-button,
  .menu-modal__close-button {
    font-size: 22px !important;
    padding: 6px !important;
  }

  /* Optional: reduce logo size if visible inside menu */
  .menu-drawer__logo img,
  .mobile-nav__logo img {
    max-width: 90px !important;
    height: auto !important;
  }

  /* Prevent background content from showing through */
  .menu-drawer__menu,
  .menu-modal__content {
    background: #fff !important;
  }
}
/* ===== HospitalsKart | Remove Logo & INR from Mobile Menu ===== */
@media (max-width: 768px) {

  /* Hide logo showing inside mobile drawer */
  .menu-drawer__logo,
  .mobile-nav__logo,
  .menu-drawer__inner img,
  .menu-drawer__header img {
    display: none !important;
  }

  /* Hide currency selector (INR or dropdown) */
  .menu-drawer__utility,
  .menu-drawer__currency,
  .menu-drawer__localization,
  .localization-form,
  .currency-selector,
  .disclosure,
  .menu-drawer__menu-item--localization {
    display: none !important;
  }

  /* Remove any empty space left behind */
  .menu-drawer__footer,
  .menu-drawer__bottom,
  .menu-drawer__menu + div {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
}
/* ===== Fix: Remove logo inside mobile menu completely ===== */
@media (max-width: 768px) {
  .menu-drawer__menu img,
  .menu-drawer__navigation img,
  .menu-drawer__menu-item img,
  .mobile-nav__item img,
  .menu-drawer__inner img,
  .menu-drawer__menu > li > img,
  .menu-drawer img[alt*="HospitalsKart"],
  .menu-drawer__menu svg {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    width: 0 !important;
  }

  /* Hide any empty container around it */
  .menu-drawer__menu-item:has(img),
  .mobile-nav__item:has(img),
  .menu-drawer__logo,
  .menu-drawer__header {
    display: none !important;
  }
}/* ===== HospitalsKart — FORCE hide any logo inside mobile menu (final) ===== */
@media (max-width: 768px) {

  /* common menu containers */
  .menu-drawer, .menu-modal__content, .mobile-nav, .menu-drawer__inner, .menu-drawer__header, .menu-modal, .menu-drawer__navigation {
    --hk-hide-logo: 1;
  }

  /* hide any img that likely is logo (src or alt contains logo/hospital/hospitalskart/name) */
  .menu-drawer img[src*="logo"],
  .menu-drawer img[src*="Logo"],
  .menu-drawer img[src*="hospital"] ,
  .menu-drawer img[src*="Hospital"] ,
  .menu-drawer img[src*="HospitalsKart"],
  .menu-drawer img[alt*="logo"],
  .menu-drawer img[alt*="Logo"],
  .menu-drawer img[alt*="Hospital"],
  .menu-drawer img[alt*="HospitalsKart"],
  .menu-modal__content img[src*="logo"],
  .mobile-nav img[src*="logo"],
  .menu-modal__content img[alt*="logo"],
  .mobile-nav img[alt*="logo"],
  .menu-drawer__logo img,
  .mobile-nav__logo img,
  .menu-drawer__header img,
  .menu-drawer__inner img {
    display: none !important;
    height: 0 !important;
    width: 0 !important;
    visibility: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* hide elements that might have logo as background-image */
  .menu-drawer [style*="background-image"],
  .menu-drawer__logo,
  .mobile-nav__logo,
  .menu-drawer__header,
  .menu-modal__logo {
    background-image: none !important;
    background: transparent !important;
    width: 0 !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    visibility: hidden !important;
    display: none !important;
  }

  /* remove any empty space left */
  .menu-drawer__logo + *,
  .menu-drawer__header + *,
  .menu-drawer__inner > *:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
}
/* ===== HospitalsKart — Hide product previews (name & price) inside mobile drawer ===== */
@media (max-width: 768px) {

  /* Common drawer preview containers */
  .menu-drawer__products,
  .menu-drawer__carousel,
  .menu-drawer__cards,
  .menu-drawer__preview-products,
  .drawer-preview-products,
  .menu-drawer .product-card,
  .menu-drawer .product-card__wrapper,
  .menu-drawer .product-card__info,
  .menu-drawer .product-card__title,
  .menu-drawer .product-card__price,
  .menu-drawer .product-card__meta,
  .menu-drawer .grid--view-items,
  .menu-drawer .collection-list,
  .menu-drawer .collection-grid,
  .menu-modal__footer,
  .menu-drawer__footer,
  .menu-drawer__bottom,
  .menu-drawer__cards-row,
  .menu-drawer .card,
  .menu-drawer .card__content,
  .menu-drawer .card__title,
  .menu-drawer .card__price {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  /* If thumbnails are shown as list items or anchors */
  .menu-drawer li.product,
  .menu-drawer a.product,
  .menu-drawer .product-item,
  .menu-drawer .preview-product {
    display: none !important;
  }

  /* Remove residual spacing at bottom of drawer */
  .menu-drawer__inner,
  .menu-modal__content,
  .menu-drawer__menu,
  .menu-drawer__navigation {
    padding-bottom: 12px !important;
  }
}
/* ===== HospitalsKart — PERMANENT hide of mobile menu product previews ===== */
@media (max-width: 992px) {
  /* Highest-priority rule to remove any product preview (title/price/thumb) shown inside mobile drawer */
  .menu-drawer, .menu-modal__content, .mobile-nav, .drawer, [id*="menu"], [class*="drawer"], [class*="menu"] {
    /* keep container but hide previews inside */
  }

  /* remove product cards, previews, thumbnails, price badges, titles inside mobile menu */
  .menu-drawer .product-card,
  .menu-drawer .product-card__wrapper,
  .menu-drawer .product-card__image,
  .menu-drawer .product-card__info,
  .menu-drawer .product-card__title,
  .menu-drawer .product-card__price,
  .menu-drawer__products,
  .menu-drawer__preview-products,
  .menu-drawer__carousel,
  .menu-drawer__cards,
  .menu-drawer__cards-row,
  .menu-drawer__bottom,
  .menu-drawer__footer,
  .menu-modal__footer,
  .drawer-preview-products,
  .menu-drawer .grid--view-items,
  .menu-drawer .collection-list,
  .menu-drawer .collection-grid,
  .menu-drawer .collection-item,
  .menu-drawer a.product,
  .menu-drawer li.product,
  .menu-drawer .preview-product,
  .menu-drawer .card,
  .menu-drawer .card__content,
  .menu-drawer .card__title,
  .menu-drawer .card__price,
  .menu-modal__content .product-card,
  [class*="preview-products"],
  [class*="preview-product"],
  [class*="drawer-preview"],
  [class*="preview-card"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  /* catch any element that contains prices (Rs./₹) and hide their card ancestors too */
  .menu-drawer *:where(:not(script)):not(svg):not(path) {
    /* nothing here — we'll use below to hide nodes containing price text */
  }

  /* final fallback: hide nodes that contain "Rs." or "₹" as text inside the drawer */
  @supports(selector(:has(*))) {
    /* modern browsers: use :has to remove parents that contain price text */
    .menu-drawer :has(:where(*):contains("Rs.") ) ,
    .menu-drawer :has(:where(*):contains("₹") ) {
      display: none !important;
    }
  }

  /* Older browsers fallback -- aggressively hide elements that look like price badges */
  .menu-drawer .price,
  .menu-drawer .product-price,
  .menu-drawer .price-badge,
  .menu-drawer .price--large,
  .menu-drawer .product-price__price {
    display: none !important;
  }

  /* Remove any leftover logo/branding inside drawer */
  .menu-drawer__logo,
  .mobile-nav__logo,
  .menu-drawer__header,
  .menu-drawer__branding,
  .menu-drawer__brand,
  .menu-drawer__logo img,
  .menu-drawer__header img {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* trim padding so drawer has no big blank area at bottom */
  .menu-drawer__inner,
  .menu-modal__content,
  .menu-drawer__menu {
    padding-bottom: 12px !important;
  }
}
/* ===== HospitalsKart — Hide product names inside mobile hamburger menu ===== */
@media (max-width: 992px) {
  /* Hide all product titles that appear in mobile drawer or menu */
  .menu-drawer .product-card__title,
  .menu-drawer .card__heading,
  .menu-drawer .product__title,
  .menu-drawer .title,
  .menu-drawer .product-title,
  .menu-drawer h3,
  .menu-drawer h2,
  .menu-drawer h4,
  .menu-drawer .card__content a,
  .menu-drawer .product-card__information,
  .menu-drawer li a[href*="/products"],
  .menu-drawer a[href*="/products"],
  .menu-modal__content a[href*="/products"],
  .mobile-nav__item a[href*="/products"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }
}
/* ===== HospitalsKart — FORCE hide any product links/names inside mobile drawer ===== */
@media (max-width: 992px) {
  /* hide direct anchors that point to products inside common drawer/menu containers */
  .menu-drawer a[href*="/products"],
  .menu-modal__content a[href*="/products"],
  .mobile-nav a[href*="/products"],
  [id*="menu"] a[href*="/products"],
  [class*="drawer"] a[href*="/products"],
  .menu-drawer a[href*="/collections"][href*="/products"] { 
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }

  /* hide headings/titles that are likely product names inside drawer */
  .menu-drawer .product-card__title,
  .menu-drawer .card__heading,
  .menu-drawer .product__title,
  .menu-drawer .product-title,
  .menu-drawer h2, .menu-drawer h3, .menu-drawer h4,
  .menu-modal__content h2, .menu-modal__content h3,
  .menu-drawer .card__title,
  .menu-drawer .card__heading {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* extra: hide any anchor text that looks like product link even if nested */
  .menu-drawer *:where(a[href*="/products"]) { display:none !important; }

  /* keep menu navigation items (collections/categories) visible */
  .menu-drawer .menu, .menu-drawer .menu__item, .menu-drawer .menu-modal__content a:not([href*="/products"]) {
    display: block !important;
    visibility: visible !important;
  }
}
/* ===== HospitalsKart — Final cleanup: hide remaining drawer preview bits & keep chat on top ===== */
@media (max-width: 992px) {

  /* force-hide any leftover preview cards/titles/prices inside drawer */
  .menu-drawer .product-card,
  .menu-drawer .product-card__wrapper,
  .menu-drawer .product-card__info,
  .menu-drawer .product-card__title,
  .menu-drawer .card__title,
  .menu-drawer .card__content,
  .menu-drawer__products,
  .menu-drawer__preview-products,
  .menu-drawer__cards,
  .drawer-preview-products,
  .menu-drawer__bottom,
  .menu-drawer__footer,
  .menu-drawer .collection-grid,
  .menu-drawer .collection-list,
  .menu-drawer li.product,
  .menu-drawer a[href*="/products"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  /* remove any small separators / lines */
  .menu-drawer hr,
  .menu-drawer .divider,
  .menu-drawer .menu-divider {
    display: none !important;
  }

  /* remove bottom space so nothing peeks under chat icon */
  .menu-drawer__inner,
  .menu-modal__content,
  .menu-drawer__menu,
  .menu-drawer__navigation {
    padding-bottom: 6px !important;
    margin-bottom: 0 !important;
    box-sizing: border-box !important;
  }

  /* ensure the drawer doesn't allow visible overflow */
  .menu-drawer,
  .menu-modal__content,
  .mobile-nav,
  .drawer {
    overflow: hidden !important;
  }

  /* keep close button and nav functional (visible above) */
  .menu-drawer__close-button,
  .menu-modal__close-button,
  .menu-drawer__menu {
    z-index: 70 !important;
  }

  /* ensure chat widget stays above everything so it doesn't block layout changes */
  .chat-widget, .chat-button, .wh-widget, .tawk-minified, .livechat, .clayful-chat, .zopim, .fb-customerchat, .intercom-launcher, .mc-widget, .widget-floating {
    z-index: 9999 !important;
    pointer-events: auto !important;
  }
}
/* ===== HospitalsKart — Final Cleanup: Hide Chat Icon + Any Residual Text Below ===== */
@media (max-width: 992px) {

  /* Hide all chat / floating support widgets completely */
  .tawk-min-container,
  #tawkchat-minified-wrapper,
  #tawkchat-container,
  iframe[id*="tawk"],
  #tawk-minified-wrapper,
  .chat-widget,
  .chat-button,
  .tawk-button,
  .wh-widget,
  .widget-floating,
  .zopim,
  .intercom-launcher,
  .fb-customerchat,
  .crisp-client,
  [id*="tawk"],
  [id*="chat-widget"],
  [class*="chat"],
  [data-testid*="chat"],
  .chaty-widget,
  #chaty-widget,
  .tidio-chat,
  .tidio-chat-iframe {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  /* Remove any text or product name appearing under chat bubble area */
  .menu-drawer *:where(h2,h3,h4,p,span,div) {
    max-height: 100vh !important;
  }

  /* Specifically hide any floating residual elements at bottom-right */
  .menu-drawer div[style*="bottom"],
  .menu-drawer div[style*="right"],
  .menu-drawer div[style*="position: fixed"],
  .menu-drawer div[style*="position: absolute"],
  .menu-drawer [style*="z-index: 9999"],
  body div[style*="bottom: 0"],
  body div[style*="right: 0"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  /* Remove any overflow causing text visible behind */
  .menu-drawer,
  .menu-drawer__inner {
    overflow: hidden !important;
  }
}
/* ===== HospitalsKart — Mobile drawer: width/height fit-to-content, top-aligned ===== */
@media (max-width: 992px) {
  :root { --hk-drawer-width: 84vw; --hk-drawer-max-height: 92vh; }

  /* Main drawer container: width control + allow height to grow/shrink */
  .menu-drawer,
  .menu-modal__content,
  .mobile-nav,
  .drawer,
  [id*="menu"][role="dialog"],
  [class*="menu-modal"] {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    width: var(--hk-drawer-width) !important;   /* change this value to 75vw / 80vw etc. */
    height: auto !important;                     /* allow content-size height */
    min-height: 0 !important;
    max-height: var(--hk-drawer-max-height) !important; /* prevents full-screen takeover */
    overflow: auto !important;                   /* allow scrolling if content exceeds max-height */
    background: #ffffff !important;
    box-shadow: 0 12px 30px rgba(11,35,64,0.08) !important;
    border-left: 1px solid rgba(0,0,0,0.04) !important;
    transform: translateZ(0);                    /* improve rendering on some phones */
  }

  /* Inner wrapper: keep content at top and reduce large paddings */
  .menu-drawer__inner,
  .menu-modal__inner,
  .menu-modal__content {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important; /* top-align items */
    justify-content: flex-start !important;
    padding-top: 14px !important;
    padding-bottom: 12px !important;
    gap: 6px !important;
  }

  /* Menu list / nav: stack from top, tighter spacing */
  .menu-drawer__menu,
  .mobile-nav__list,
  .menu-modal__list,
  .menu-drawer__navigation {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 16px !important;
  }

  .menu-drawer__menu-item,
  .mobile-nav__item,
  .menu-modal__item,
  .menu-drawer a,
  .mobile-nav a {
    padding: 12px 0 !important; /* vertical spacing per item */
    font-size: 17px !important;
    line-height: 1.2 !important;
  }

  /* If theme forces full-height with a helper class, override it */
  .menu-drawer.full-height,
  .menu-modal__content.full-height,
  .menu-drawer--open[style*="height"],
  .menu-drawer[style*="height"] {
    height: auto !important;
    min-height: 0 !important;
    max-height: var(--hk-drawer-max-height) !important;
  }

  /* Remove any giant footer/block that causes extra space */
  .menu-drawer__footer,
  .menu-drawer__bottom,
  .menu-modal__footer {
    display: none !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* keep close button visible on top of drawer */
  .menu-drawer__close-button,
  .menu-modal__close-button {
    z-index: 999 !important;
  }
}
/* ===== HospitalsKart – Desktop: Logo Left, Mobile: Logo Center ===== */

/* --- Desktop View --- */
@media (min-width: 993px) {
  .header__wrapper,
  .header__group,
  .shopify-section--header,
  .header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .header__heading,
  .header__heading-link,
  .header__heading-logo {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    margin: 0 !important;
    order: 0 !important;
  }

  .header__heading img {
    width: 240px !important;
    height: auto !important;
    object-fit: contain !important;
  }
}

/* --- Mobile View --- */
@media (max-width: 992px) {
  .shopify-section--header .header__heading,
  .header__heading,
  .header__heading-link,
  .header__heading-logo {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 5 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    pointer-events: none !important;
  }

  .header__heading img {
    width: 190px !important;  /* Increase if needed (e.g. 210px) */
    height: auto !important;
    object-fit: contain !important;
    pointer-events: auto !important;
  }

  /* Keep menu, search, cart clickable */
  .header__icon,
  .header__icon--menu,
  .header__icons,
  .header__action {
    position: relative !important;
    z-index: 10 !important;
  }
}
/* HK — Hide "Partner With Us" in header only on mobile */
@media (max-width: 767px) {
  a[href*="partner-with-us"],
  .header__menu-item a[href*="partner-with-us"],
  .site-nav__link[href*="partner-with-us"],
  nav a[href*="partner-with-us"] {
    display: none !important;
    visibility: hidden !important;
  }
}
/* HK — Mobile drawer: center logo, push menu below logo, hide product previews inside drawer */
@media (max-width: 767px) {

  /* drawer container: white bg, allow scrolling */
  .menu-drawer,
  .mobile-nav__drawer,
  .drawer__content,
  .mobile-menu,
  .menu-drawer__content {
    background: #ffffff !important;
    height: auto !important;
    min-height: 100vh !important;
    overflow-y: auto !important;
    box-sizing: border-box !important;
    padding-bottom: 40px !important;
  }

  /* center the logo at top of drawer and make it visible */
  .menu-drawer .logo,
  .mobile-nav__logo,
  .drawer__logo,
  .mobile-menu .logo {
    position: relative !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 18px 0 !important;
    z-index: 60 !important;
    pointer-events: auto !important;
  }
  .menu-drawer .logo img,
  .mobile-nav__logo img,
  .drawer__logo img {
    width: 110px !important;   /* adjust size if needed */
    height: auto !important;
    object-fit: contain !important;
  }

  /* push the menu items down so they start below the logo (adjust value if your logo is bigger) */
  .menu-drawer__content,
  .mobile-nav__content,
  .menu-drawer__list,
  .mobile-nav__list,
  .drawer__content .menu,
  .mobile-menu .menu {
    padding-top: 36px !important; /* small space after logo */
    box-sizing: border-box !important;
  }

  /* menu links style */
  .menu-drawer a,
  .mobile-nav__link,
  .menu-drawer__item a,
  .mobile-nav__item a {
    display: block !important;
    padding: 18px 20px !important;
    font-size: 20px !important;
    line-height: 1.2 !important;
    color: #222 !important;
    background: transparent !important;
  }

  /* remove any overlay or pseudo-element causing top clipping */
  .menu-drawer::before,
  .menu-drawer__overlay,
  .mobile-nav__overlay {
    display: none !important;
  }

  /* HIDE product preview tiles / prices that were appearing inside drawer */
  .menu-drawer [class*="product"],
  .menu-drawer [class*="Product"],
  .menu-drawer [class*="price"],
  .menu-drawer .product-card,
  .menu-drawer .product-grid,
  .menu-drawer .product-card__content,
  .menu-drawer .product-card__heading,
  .menu-drawer .card__heading,
  .mobile-nav__content [class*="product"],
  .drawer__content [class*="product"],
  .drawer__content [class*="price"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  /* If header is sticky and overlaps the drawer, add top offset */
  .menu-drawer,
  .mobile-nav__drawer {
    padding-top: calc(var(--header-height, 0px) + 8px) !important;
  }
}
/* ===== Customize Add to Cart Button Color ===== */
button[name="add"], 
.product-form__submit, 
.shopify-payment-button button {
  background-color: #ff7a00 !important;  /* Orange color */
  color: #fff !important;
  border: none;
  border-radius: 6px;
  font-weight: 600;
  transition: all 0.3s ease;
}
button[name="add"]:hover,
.product-form__submit:hover,
.shopify-payment-button button:hover {
  background-color: #e56a00 !important;  /* Darker orange hover */
  transform: translateY(-2px);
}
button[name="add"]:hover {
  background-color: #ff7a00 !important;
  box-shadow: 0 0 12px rgba(154, 99, 255, 0.3); /* subtle purple glow */
}
/* ===== Home & Collection Page Add to Cart Button Color ===== */
.card__content .button, 
.product-card__button, 
.quick-add__submit {
  background-color: #ff7a00 !important;   /* Orange */
  color: #fff !important;
  border: none;
  border-radius: 6px;
  font-weight: 600;
  padding: 10px 16px;
  transition: all 0.3s ease;
}
.card__content .button:hover, 
.product-card__button:hover, 
.quick-add__submit:hover {
  background-color: #e56a00 !important;   /* Darker Orange */
  transform: translateY(-2px);
  box-shadow: 0 0 10px rgba(255, 122, 0, 0.3);
}
.price__regular .price-item,
.price__sale .price-item,
.price,
.product-price,
.product-card .price,
.card-information .price-item {
  border: 2px solid;
  border-image: linear-gradient(90deg, #ff7a00, #a14fff) 1;
  color: #0070cc;
  padding: 5px 12px;
  border-radius: 8px;
  font-weight: 600;
  display: inline-block;
  background-color: #fff;
  transition: all 0.3s ease-in-out;
}
/* Hover effect - orange to purple glow */
.price__regular .price-item:hover,
.price__sale .price-item:hover,
.product-card .price:hover,
.card-information .price-item:hover {
  background: linear-gradient(90deg, rgba(255,122,0,0.1), rgba(161,79,255,0.1));
  box-shadow: 0 0 15px rgba(161,79,255,0.4);
  transform: translateY(-2px);
}
/* ===== HK FINAL — Orange + Purple Gradient Buttons (Header untouched) ===== */
:root {
  --hk-orange: #ff7a00;
  --hk-purple: #a14fff;
  --hk-orange-dark: #e56a00;
}
/* Main Product Buttons */
.product-form__submit,
.shop-now,
.button--primary,
.product-card button,
.card__button,
.quick-add__submit,
.add-to-cart,
.btn--add,
button[name="add"],
button[type="submit"].product-form__submit {
  background: linear-gradient(90deg, var(--hk-orange), var(--hk-purple)) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 10px 18px !important;
  font-weight: 600 !important;
  box-shadow: 0 0 15px rgba(161, 79, 255, 0.35) !important;
  transition: all 0.3s ease-in-out !important;
/* ===== HK Premium Gradient Footer (Orange + Purple Theme) ===== */
.footer,
.site-footer,
.shopify-section--footer {
  background: linear-gradient(90deg, #ff7a00, #a14fff) !important; /* orange to purple gradient */
  color: #ffffff !important;
  padding-top: 40px !important;
  padding-bottom: 30px !important;
  border-top: 3px solid rgba(255, 255, 255, 0.2);
}

/* Footer links */
.footer a,
.site-footer a {
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 500;
  transition: all 0.25s ease-in-out;
}

/* Hover on footer links */
.footer a:hover,
.site-footer a:hover {
  color: #ffedff !important;
  text-shadow: 0 0 8px rgba(161, 79, 255, 0.6);
}

/* Footer titles (like Quick Links, Contact Us) */
.footer h2,
.footer h3,
.footer__title,
.site-footer__title {
  color: #fff !important;
  font-weight: 700;
  margin-bottom: 12px;
  border-bottom: 2px solid rgba(255,255,255,0.3);
  display: inline-block;
  padding-bottom: 4px;
}

/* Social icons if present */
.footer__social,
.footer__social a svg {
  fill: #fff !important;
  transition: all 0.3s ease-in-out;
}
.footer__social a:hover svg {
  fill: #ffedff !important;
  transform: scale(1.1);
}

/* Footer bottom (copyright line) */
.footer__bottom,
.site-footer__bottom {
  background: rgba(0, 0, 0, 0.15) !important;
  text-align: center;
  padding: 10px 0 !important;
  font-size: 14px !important;
  color: #fff !important;
  border-top: 1px solid rgba(255,255,255,0.3);
}

/* Responsive */
@media (max-width: 767px) {
  .footer,
  .site-footer {
    text-align: center !important;
  }
}
/* ===== HK — Footer Gradient Border only (orange → purple) ===== */
footer,
.footer,
.site-footer,
.footer-wrapper,
.shopify-section--footer {
  background: transparent !important; /* agar aap pehle wali full gradient hata chuke ho to ye safe rakhega */
  position: relative;
  z-index: 1;
  border: 4px solid transparent !important;
  border-radius: 10px; /* rounded corners */
  /* gradient border */
  border-image: linear-gradient(90deg, #ff7a00, #c86be0, #9a40d6) 1;
  /* optional subtle inner glow behind the border (remove if you want only border) */
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), 0 6px 18px rgba(161,79,255,0.06);
  padding: 18px !important; /* safe inner spacing */
}

/* keep footer text & links readable */
footer a, .footer a, .site-footer a { color: #fff !important; }
footer h2, .site-footer__title { color: #fff !important; }

/* Mobile tweak: avoid thick-looking border on small screens */
@media (max-width: 767px) {
  footer, .site-footer, .footer-wrapper {
    border-width: 3px !important;
    border-radius: 8px !important;
  }
}
/* =============================
   HospitalsKart Menu Text + Icon Gradient
   ============================= */

/* Menu text (main navigation links) */
.header__menu-item,
.header__menu-item a,
.list-menu__item,
.list-menu__item a {
  background: linear-gradient(90deg, #ff7a00, #a14fff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 600;
  transition: all 0.3s ease;
}

/* Hover effect for menu text */
.header__menu-item:hover,
.header__menu-item a:hover,
.list-menu__item:hover a {
  background: linear-gradient(90deg, #a14fff, #ff7a00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  transform: scale(1.04);
}

/* Icons (search, login, cart) */
.header__icon,
.header__icon svg,
.header__action svg {
  fill: url(#hkGradient) !important;
  background: linear-gradient(90deg, #ff7a00, #a14fff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  transition: all 0.3s ease;
}

/* Hover for icons */
.header__icon:hover svg,
.header__action:hover svg {
  background: linear-gradient(90deg, #a14fff, #ff7a00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  transform: scale(1.1);
}

/* Make sure dropdown or mobile menu text also gets same gradient */
.menu-drawer__menu-item,
.menu-drawer__menu-item a {
  background: linear-gradient(90deg, #ff7a00, #a14fff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 600;
}
.menu-drawer__menu-item:hover a {
  background: linear-gradient(90deg, #a14fff, #ff7a00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
/* ============================
 /* ===============================
   HK Gradient Theme for Checkout Button
   =============================== */
button[name="checkout"],
.cart__checkout,
.cart__footer .cart__submit,
.cart__submit,
input[name="checkout"],
button.checkout-btn,
button.btn--checkout {
  background: linear-gradient(90deg, #ff7a00, #a14fff) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 14px 28px !important;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(161, 79, 255, 0.25);
}

/* Hover effect */
button[name="checkout"]:hover,
.cart__checkout:hover,
.cart__footer .cart__submit:hover,
input[name="checkout"]:hover,
button.btn--checkout:hover {
  background: linear-gradient(90deg, #a14fff, #ff7a00) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(255, 122, 0, 0.35);
}

/* Disabled state */
button[name="checkout"]:disabled,
.cart__checkout:disabled {
  background: #ccc !important;
  color: #777 !important;
  box-shadow: none !important;
  cursor: not-allowed;
}
/* ===== HospitalsKart - equal height product cards & sticky price/button ===== */

/* 1) Make card a column-flex container so we can push footer to bottom */
.product-card,
.card,
.grid__item .card,
.product-grid-item,
.product-card__inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important; /* ensure full height inside grid cell */
}

/* 2) Title / content block: give a fixed min-height so long titles wrap but leave space */
.product-card__title,
.card__heading,
.product-card__info,
.product-card .card__content,
.product-item__title {
  min-height: 64px;    /* adjust: ~2 lines on mobile, ~3 lines on desktop */
  overflow: hidden;
  display: block;
  line-height: 1.25;
  margin-bottom: 8px;
}

/* 3) Image wrapper ensure it does not shrink (keeps consistent top area) */
.product-card__image,
.card__media,
.product-item__image,
.product-card img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
  flex-shrink: 0;
}

/* 4) Price + button container should sit at bottom of the card */
.product-card__meta,
.card__footer,
.product-card .card__actions,
.product-item__price {
  margin-top: auto; /* the magic: pushes this section to the bottom */
  padding-top: 10px;
}

/* 5) Optional: make add-to-cart button full width for better alignment on mobile */
.product-card__meta .btn,
.card__actions .btn,
.product-item__button {
  width: 100%;
  box-sizing: border-box;
}

/* 6) Grid cells: ensure equal heights in each row (only if grid uses auto rows) */
.grid,
.grid--products,
.collection-grid {
  align-items: stretch;
}

/* 7) Mobile tweaks: reduce title min-height so it doesn't look cut */
@media (max-width: 767px) {
  .product-card__title,
  .card__heading,
  .product-item__title {
    min-height: 56px;
  }
}

/* 8) Small visual fix: consistent spacing for price boxed (if you use price border) */
.product-item__price,
.card__price,
.product-card__price {
  display: inline-block;
  padding: 6px 10px;
  border: 2px solid #6b46c1; /* change color if needed */
  border-radius: 4px;
  background: transparent;
}
/* ===== HospitalsKart - strong equal-height product card overrides (catch-all) ===== */
/* Apply flex column on common card wrappers */
.grid__item,
.grid__cell,
.product-grid-item,
.product-card,
.card,
.card__inner,
.product-item,
.product-card__inner,
.product-card-wrapper,
.product-loop-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  height: 100% !important;
  box-sizing: border-box !important;
}

/* Ensure the card content grows, and footer/meta sticks to bottom */
.card__content,
.product-card__content,
.product-card__info,
.card__heading,
.product-item__details,
.product-card__meta,
.card__footer,
.card__actions {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Title area: allow wrap but limit extreme height */
.card__heading,
.product-card__title,
.product-item__title,
.product-card__info h3 {
  min-height: 56px !important;   /* adjust if you want more/less */
  max-height: 120px !important;
  overflow: hidden !important;
  margin: 0 0 8px 0 !important;
  line-height: 1.25 !important;
}

/* Push price & add-to-cart to the bottom */
.card__footer,
.product-card__meta,
.card__actions,
.product-item__price-wrap {
  margin-top: auto !important;
  padding-top: 8px !important;
}

/* Make CTA consistent width on mobile */
@media (max-width: 767px) {
  .card__actions .btn,
  .product-card__meta .btn,
  .product-item__button {
    width: 100% !important;
  }
}

/* Force grid rows to stretch (helps when grid uses auto rows) */
.grid,
.collection-grid,
.product-grid {
  align-items: stretch !important;
}

/* Small visual polish: consistent price box */
.card__price,
.product-item__price,
.product-card__price {
  display: inline-block !important;
  padding: 6px 10px !important;
  border-radius: 4px !important;
  border: 2px solid rgba(107,70,193,0.9) !important;
  background: transparent !important;
}
/* ===== HospitalsKart - Uniform Product Image Sizes ===== */

/* Force all product images into the same aspect ratio */
.product-card__image,
.card__media,
.card__image,
.product-item__image,
.media,
.media img {
  width: 100%;
  aspect-ratio: 1 / 1;   /* square images, you can change to 4/3 or 3/4 */
  object-fit: cover;     /* crops evenly, fills the frame */
  display: block;
  border-radius: 8px;    /* optional rounded corners */
}

/* Make sure parent containers respect fixed height */
.product-card__media,
.card__media,
.product-item__media {
  overflow: hidden;
  height: auto;
  max-height: 300px;     /* adjust for desktop */
}

@media (max-width: 767px) {
  .product-card__image,
  .card__media,
  .card__image,
  .product-item__image {
    aspect-ratio: 1 / 1; /* keep square on mobile too */
  }
}
/* ===== Strong uniform product card fix (important rules) ===== */
.product-grid, .grid--view-items, .collection-products, .products-grid, .product-list {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
}
.product-card, .product-item, .grid__item, .grid-item, .product-grid-item, .product-list-item {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  box-sizing: border-box !important;
  background: #fff !important;
  border-radius: 6px !important;
  overflow: hidden !important;
}
.product-card img, .product-item img, .grid__image img, .product-grid-item img {
  width: 100% !important;
  height: 240px !important;
  object-fit: contain !important;
  display: block !important;
}
.product-card .product-info, .product-item__info, .grid__meta, .product-details {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
}
.product-card .product-title, .product-item__title, .grid__title, .product-title, .product-grid-item .title {
  min-height: 42px !important;
  margin: 8px 10px 6px !important;
  line-height: 1.25 !important;
  overflow: hidden !important;
}
.product-card .price, .product-item__price, .grid__price {
  margin: 0 10px 10px !important;
  font-weight: 700 !important;
  color: #007bff !important;
}
.product-card .add-to-cart, .product-item__cta, .btn--add, .grid__button, .product-grid-item .btn {
  margin-top: auto !important;
  align-self: flex-start !important;
  padding: 8px 12px !important;
  border-radius: 6px !important;
  background: linear-gradient(90deg,#ff6a00,#ff3ca6) !important;
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  border: none !important;
  cursor: pointer !important;
}
@media (max-width: 767px) {
  .product-card img, .product-item img { height: 180px !important; }
  .product-card .product-title { min-height: 40px !important; }
}
