/** Shopify CDN: Minification failed

Line 698:24 Expected identifier but found "rgb("
Line 1068:77 "padidng-bottom" is not a known CSS property
Line 1408:18 Unexpected "{"
Line 1430:37 "align-tiems" is not a known CSS property

**/

@font-face {
  font-family: "Dia-Regular";
  src: url("https://cdn.shopify.com/s/files/1/0817/5439/0772/files/Dia-Regular.woff") format("woff"),
  url("https://cdn.shopify.com/s/files/1/0817/5439/0772/files/Dia-Regular.woff2") format("woff2");
}

@font-face {
  font-family: "hauora-sans-latin-400";
  src: url("https://cdn.shopify.com/s/files/1/0769/8608/9612/files/hauora-sans-latin-400-normal.woff") format("woff"),
  url("https://cdn.shopify.com/s/files/1/0769/8608/9612/files/hauora-sans-latin-400-normal.woff2") format("woff2");
}

@font-face {
  font-family: "instrument-sans-latin-400";
  src: url("https://cdn.shopify.com/s/files/1/0769/8608/9612/files/instrument-sans-latin-400-normal.woff") format("woff"),
  url("https://cdn.shopify.com/s/files/1/0769/8608/9612/files/instrument-sans-latin-400-normal.woff2") format("woff2");
}

:root {
  --font-main: "instrument-sans-latin-400", sans-serif;
  --font-head: "hauora-sans-latin-400", sans-serif;
  --font-roboto: "RobotoCondensed-Bold", sans-serif;
}



/* ------ GENERAL ----------*/


body {
  font-family: var(--font-main);
  font-style: normal;
  line-height: 1.5;
  letter-spacing: 0em !important;
  max-width: 100%;
  overflow-x: hidden;
  }

p {letter-spacing: 0em !important;}
strong {font-weight: 500 !important;}

.card-wrapper.product-card-wrapper .card__inner+.card__content .card__information .price, 
.card-wrapper.product-card-wrapper .card__inner+.card__content .card__information .card__heading,
.price, input, textarea, .text-area {font-family: var(--font-dia);}

body.no-scroll {overflow: hidden; height: 100vh;}

body, .color-background-1, .color-background-2, .color-inverse, .color-accent-1, .color-accent-2, 
.color-scheme-a12c8b07-9b29-447d-bfb0-83d0d38b850e, .color-scheme-bbdbc7aa-d40f-49d2-86d3-58492c7972f1, 
.color-scheme-6d854ed8-74db-4a0a-9c7b-240a8a913683, .color-scheme-cdcadfc3-ea28-48b2-a12e-9e8a8acf7e84, 
.color-scheme-0ec903cd-c9b2-4ffc-817d-225bb428f070, .color-scheme-a58c1aa3-0a51-4532-95cb-a5d410ee5d77, 
.color-scheme-03b8ea27-31e2-4aef-a522-6437c344ab35 {
    color: rgba(var(--color-foreground), 1) !important;
}

.global-settings-popup,
.header__submenu.global-settings-popup {
border: none !important;
box-shadow: none !important;

}

.page-width--narrow {padding: 0 1.5rem;}

@media screen and (min-width: 990px) {
    .page-width--narrow {
        max-width: 68rem;
        padding: 0;
        margin: auto;
    }
}

h1, h2, h3, .h0, .h1, .h2, .h3, h4 {
  font-family: var(--font-head);
  letter-spacing: -0.1px;
  line-height: 1.2;
  }

h5, .h5 {
  font-family: var(--font-main);
  letter-spacing: 0;
  line-height: 1.2;
  }

.kl_reviews__summary__average,
.kl_reviews__list h2,
.kl_reviews__summary__header,
.kl_reviews__reviews_list.kl_reviews__reviews_list.kl_reviews__reviews_list button.kl_reviews__list__tab {  
    font-family: var(--font-main);
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
    font-weight: 400 !important;
    }

p.heading-main, p.heading-main-med {letter-spacing: 0em !important;}

.h0 {font-size: calc(var(--font-heading-scale) * 4.6rem); line-height: 1;}
.h1 {font-size: calc(var(--font-heading-scale) * 2.8rem);}
h2, .h2 {font-size: calc(var(--font-heading-scale) * 2.6rem);}
h3, .h3 {font-size: calc(var(--font-heading-scale) * 2.4rem);}


.image-video-duo h3 strong {font-family: "beaufort-pro", serif; font-weight: 300 !important;}
.rich-text__heading.h2 {font-size: 34px;}

.underline-heading {
  border-bottom: 1px solid rgb(var(--color-foreground)); 
  padding-bottom: 15px;
  margin: 0;
  width: 100%;}

.heading-medium,
.heading-main {
    font-style: normal !important;
    line-height: 1;
    font-style: normal;
}

.heading-medium {font-size: calc(var(--font-heading-scale) * 4rem);}
.heading-main {font-size: calc(var(--font-heading-scale) * 5rem);}

.heading-main-med {
    color: rgba(var(--color-foreground), 1);
    font-style: normal !important;
    line-height: 1;
    font-weight: 300;
    font-style: normal;
    font-size: calc(var(--font-heading-scale) * 3.5rem);
}


.ct__title,
.heading-alt {
    font-style: normal !important;
    line-height: 1;
    font-family: var(--font-dia);
    font-style: normal;
    font-size: 16px;
}

.drawer__heading, .social-links h3 {font-size: 18px; margin: 5px 0;}

/* SMALL HEADING */
.article-featured h4,
.treatment-label,
.instafeed-bottom-link-wrapper a,
.header__icon span,
h5, .h5,
.footer-block__heading,
.image-text-full h3 strong,
.eyebrow-text,
.regular-testimonials h3,
.fade-testimonials h3,
h3 span,
.collapsible-content__heading,
.caption-with-letter-spacing,
.totals__total,
.totals__total-value,
.cart-item__price-wrapper .price,
.menu-drawer__close-button
{
    font-family: var(--font-dia);
    font-size: 14px !important;
    text-transform: uppercase !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
  }

  .menu-drawer__close-button {font-family: var(--font-dia) !important;}

.shopify-policy__container h4,
.eyebrow-text, .h4 {
  font-family: var(--font-roboto) !important;
  text-transform: uppercase !important;
  letter-spacing: -0.14px !important;
  font-size: 16px !important;
  }


  .large-p {font-size: 1.5rem; font-family: var(--font-dia);
  font-style: normal;
  line-height: 1.4;
  letter-spacing: 0em !important;
}

.new-label    {
  position: absolute;
  top: 10px;
  left: 10px;
   background-color: #FFFFFF;
  padding: 5px 8px;
  font-family: var(--font-roboto) !important;
  text-transform: uppercase !important;
letter-spacing: -0.14px !important;
font-size: 14px !important;
}


@media only screen and (max-width: 750px) {
  .header__icon span,
.footer-block__heading,
.image-text-full h3 strong,
.eyebrow-text,
.fade-testimonials h3,
h3 span,
.accordion__title,
.collapsible-content__heading,
.caption-with-letter-spacing,
.cart-item__name,
.totals__total,
.totals__total-value,
.cart-item__price-wrapper .price {font-size: 13px !important;}
  
body {font-size: 1.3em;}

.heading-main {font-size: 40px;}
.image-text-full p em, .heading-main-med {font-size: calc(var(--font-heading-scale) * 3rem);}
.heading-alt {font-size: 22px;}

h2, .h2 {font-size: calc(var(--font-heading-scale) * 2rem);}
h3, .h3 {font-size: calc(var(--font-heading-scale) * 2rem);}

}


#menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li a, #menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li summary {
     font-family: var(--font-rhymes);
  letter-spacing: -0.1px;
  line-height: 1.2;
}

.header__icon span {font-size: 16px !important;}

.collapsible-content summary:hover .accordion__title {
    text-decoration: none !important;
    text-underline-offset: 0rem !important;
}



.rich-text__heading {font-size: calc(var(--font-heading-scale)* 4.6rem);}

@media only screen and (max-width: 750px) {
  .caption-with-letter-spacing {font-size: 1.1rem;}
  .h0 {font-size: calc(var(--font-heading-scale)* 3.5rem);}
  .h1 {font-size: calc(var(--font-heading-scale) * 2.4rem);}
  .rich-text__heading {font-size: calc(var(--font-heading-scale)* 3rem);}
  h3, .h3 {font-size: calc(var(--font-heading-scale) * 2rem);}
  }

.shopify-policy__container {max-width: 1000px !important;}

@media only screen and (max-width: 1100px) {
  .shopify-policy__container {max-width: 100% !important;}
  }


/* ------ GENERAL ----------*/


.announcement-bar__message {
  width: 100%;
  font-size: 12px !important;
  line-height: 1.6;
  font-family: var(--font-dia);
  letter-spacing: 0rem;
  }

.announcement-bar__message span {padding: 0 3px;}
.announcement-bar__message a {color: rgb(var(--color-foreground));}
.announcement-bar__message a:hover {opacity: 0.8;}

.utility-bar__grid.page-width {
    padding-left: 0rem;
    padding-right: 0rem;
}
@media only screen and (max-width: 750px) {
.announcement-bar__message {font-size: 9.5px; line-height: 1.5; min-height: auto;}
.announcement-bar__message span {padding: 0 5px;}
}


.announcement-bar .slider-button--prev {
    margin-left: 1rem;
    min-width: 44px;
}

.announcement-bar .slider-button--next {
    margin-right: 1rem;
    min-width: 44px;
}

.announcement-bar__message strong {font-weight: 700 !important;}

/* ------ HEADER ----------*/

.js .menu-drawer {
  width: 40% !important; 
  border: 0 !important;
  /*height: calc(100vh - 40px) !important; */
  height: 100%;
  top: 0;
  }

.header-wrapper {position: absolute; width: 100%;}

.menu-drawer-container .header__icon { z-index: 9 !important;}

.header__icon--account {padding: 0 15px;}

body.transparent-header-dark .header-wrapper,
body.transparent-header .header-wrapper {
  background-color: transparent !important;
  transition: all 1s;
}


.menu-opening .header__icon {filter: invert(0) !important;}

header-drawer {margin-left: 0rem !important;}
.header__icon--menu {width: auto !important;}
.header__icon--menu[aria-expanded=true]:before {display: none;}
.header__icons {padding-right: 0rem;}

.menu-drawer-container .header__icon {text-decoration: none !important;}

.header__icon--account:hover,
.header__icon--cart:hover,
.list-menu__item:hover {opacity: 0.7;}

.header__active-menu-item {opacity: 0.7; border: none !important;}

.header__menu-item span:after, li>a.mega-menu__link:after {display: none;}

#menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li a {border-radius: 60px !important;}

#menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li:first-child {border-top: 0px dotted !important;}
#menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li {border-bottom: 0px dotted !important;}

.list-menu__item {
  font-family: var(--font-dia);
  font-size: 1.6em  !important;
  justify-content: flex-start; 
  padding: 5px 0 !important;
}


.header__menu-item span {
  background-image: linear-gradient(currentColor, currentColor);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  transition: background-size 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  padding-bottom: 2px;
}

.header__menu-item:hover span {
  background-position: left bottom;
  background-size: 100% 1px;
}


.header__inline-menu .list-menu__item {
  font-size: 1em  !important;
  justify-content: flex-start; 
  padding: 5px 10px !important;
}


.menu-drawer__navigation-container {
  display: flex !important; 
  flex-direction: column; 
  justify-content: space-between; 
  margin-top: 5rem;
  height: calc(100% - 5rem) !important;
  position: relative;
}

.menu-drawer__close-button {margin-top: 1rem !important;}

.menu-drawer__close-button,
.menu-drawer__navigation, 
.menu-drawer__inner-submenu .menu-drawer__menu,
.menu-drawer__utility-links {box-sizing: border-box; width: auto; padding: 3rem !important;}

.menu-drawer__inner-submenu .menu-drawer__menu {padding-top: 0 !Important;}

.menu-drawer__menu-item--active, 
.menu-drawer__menu-item:focus, 
.menu-drawer__close-button:focus,
.menu-drawer__menu-item:hover, .menu-drawer__close-button:hover {
  opacity: 0.7;
  background-color: transparent !important;
  }

.menu-drawer-container .close {display: none;}
.menu-opening .open {display: none;}
.menu-opening .close {display: flex;}

.menu-drawer__utility-links {background-color: transparent !important;}
.menu-drawer__utility-links img {width: 100%; height: auto; display: block; padding-top: 0px;}

.button, .price {letter-spacing: 0 !important;}

.menu-drawer__account {
  width: 100% !important;
  padding: 20px !important;
  font-size: 14px !important;
  color: #fff !important;
  text-align: center;
  font-family: var(--font-dia);
  background-color: rgba(var(--color-button), var(--alpha-button-background));
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin-top: 5px !important;
  }

.menu-drawer__account .icon-account {display: none;}
.menu-drawer__account:hover {background-color: #424041; color: #fff;}

.btn-active svg {transform: rotate(180deg);}

.menu-drawer-additional-links {display: flex; flex-wrap: wrap; gap: 50px; padding: 3rem !important;}
.menu-drawer-additional-links .menu-block {width: auto;}
.drawer-button {position: absolute !important; top: 3rem; right: 3rem;}

#menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li a, 
#menu-drawer ul.menu-drawer__menu.has-submenu.list-menu li summary {gap: 7px;}

.menu-drawer__menu-item>.icon-arrow {
    position: relative !important;
    right: 0 !important;
    top: 0 !important;
    transform: none !important;
}

.js .menu-drawer {overflow-y: hidden;}

@media only screen and (max-width: 1300px) {
  .drawer-button {position: relative !important; top: 2rem; right: 0rem;}

}

@media only screen and (max-width: 750px) {

  .menu-drawer__close-button {margin-top: 5rem !important;}
  .menu-drawer__navigation-container {
  margin-top: 0;
  padding-top: 5rem;
  height: 100% !important;
}

  .drawer-button {position: relative !important; top: 2rem; right: 0rem;}

  .js .menu-drawer {width: 100% !important; }
  .header {padding: 10px 2rem !important;}
  .header__icons .button {display: none; padding: 0 1rem;min-width: auto; min-height: 25px; font-size: 11px; width: auto;}
  .header__heading-logo {transform: scale(1); padding-top: 0px;}
  

  .menu-drawer__close-button,
.menu-drawer__navigation, 
.menu-drawer__inner-submenu .menu-drawer__menu,
.menu-drawer__utility-links {box-sizing: border-box; width: auto; padding: 2rem !important;}
.menu-drawer-additional-links {box-sizing: border-box; width: auto; padding: 0 2rem !important;}
}

.header__icon--account {padding: 0;}
.header__icon .icon {height: 2rem; width: 2rem;}
.header__icon, .header__icon--cart .icon {width: 3.5rem;}



/* ----------- Mega Menu Image Tile --------- -*/
   
.mega-menu__list {
  column-count: 3; 
  column-width: 8rem; 
  max-width: 50%;
  }

 .mega-menu__list li a[href="#divider"],
 .mega-menu__list li:has(a[href="#divider"]) {
  display: none;
}

.menu-drawer__inner-submenu li:has(a[href="#divider"]) {
  padding-top: 16px; /* adjust as needed */
}

.menu-drawer__inner-submenu li:has(a[href="#divider"]) a {
  display: none;
}


/* force column break on the item after it */
 .mega-menu__list li:has(a[href="#divider"]) + li {
  break-before: column;
}


.mega-menu__content .page-width {
  padding-top: 2.4rem;
  padding-bottom: 2.4rem;
}
 
/* Wrapper that holds image tile + links side-by-side */
.mega-menu__inner {
  display: flex;
  align-items: flex-start;
  gap: 3.2rem;
}
 
/* Image tile — fixed width, no absolute positioning */
.mega-menu__image-tile {
  flex: 0 0 300px;
  max-width: 300px;
  width: 300px;
  position: relative;
}

@media screen and (max-width: 749px) {
/* Image tile — fixed width, no absolute positioning */
.mega-menu__image-tile {
  flex: 0 0 1;
  max-width: 100%;
  width: 100%;
  position: relative;
}
}
 
.mega-menu__image-link {
  display: block;
  overflow: hidden;
}


.mega-menu__image,
.mega-menu__image--placeholder {
  display: block;
  width: 300px;
height: 300px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  transition: transform 0.4s ease;
}
 
 
.mega-menu__image-badge {  
  color: #fff;
  position: absolute;
  top: 20px;
  font-family: var(--font-roboto) !important;
  text-transform: uppercase !important;
  letter-spacing: -0.14px !important;
  font-size: 14px !important;
  left: 50%;
  transform: translateX(-50%);
  }

.mega-menu__image-tile:hover .mega-menu__image-label.button--alt {
  background-position: left bottom;
  background-size: 100% 1px;
}

.mega-menu__image-label.button--alt {
  background-image: linear-gradient(currentColor, currentColor);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  transition: background-size 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  padding-bottom: 2px;
  text-decoration: none;
  }

.mega-menu__image-label {
  display: inline-block;
  position: absolute;
  bottom: 20px;
  color: #fff !important;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  width: max-content;
  }
 
.mega-menu__inner .mega-menu__list {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr));
  gap: 0 3.2rem;
  }

  mega-menu__list--condensed .mega-menu__link {
    font-weight: 400;
}


.mega-menu__link {
    color: rgba(var(--color-foreground), 1) !important;
    font-size: 1em !important;
    text-transform: none;
    padding-bottom: 0.2rem !important;
    padding-top: 0.8rem !important;
    position: relative;
    text-decoration: none;
    }

.mega-menu__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px; /* thickness of the underline */
  background-color: currentColor; /* matches the text color */
  transition: width 0.3s ease;
  display: block !important;
}

.mega-menu__link:hover::after {
  width: 100%;
}



/* BUTTONS */

.button:before, .shopify-challenge__button:before, .customer button:before, 
.shopify-payment-button__button--unbranded:before, 
.shopify-payment-button [role=button]:before, .cart__dynamic-checkout-buttons [role=button]:before {display: none;}

.button, 
.shopify-challenge__button, 
.customer button, button.shopify-payment-button__button--unbranded {
    min-height: auto !important;
    padding: 1.5rem 3rem !important;
    }


.article-featured__kicker,
.copyright__content,
.parallax-form button,
.parallax-button,
.button,
.button--primary
.button--secondary,
.button--alt,
.button--dot,
.button--arrow {
  font-size: 0.9em !important; 
  text-transform: uppercase; 
  font-family: var(--font-main);
  }

.button--primary {border-radius: 60px;}

.button--primary, 
.button--secondary  {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.button--secondary {
    color: rgb(var(--color-secondary-button-text));
    border: none !important;
    border: 1px solid rgb(var(--color-secondary-button-text)) !important;
    }

.button--dot, .button--alt {
  background: none;
  color: rgb(var(--color-secondary-button-text));
  border-radius: 0;
  padding: 0 !important;
  border: none !important;
  text-decoration: underline;
  text-underline-offset: 4px;
  width: fit-content;
  }

.button:after {display: none;}
.button--secondary:after {border: none !important;}
.button--primary:hover {rgb(var(--color-secondary-button), 0.7);}
.button--dot:hover, .button--alt:hover {opacity: 0.7;}

.button--primary:hover {color: #fff;
  background-color: rgb(var(--color-button-text));
}
.button--secondary:hover {
  color: rgb(var(--color-secondary-button)) !important;
  background-color: rgb(var(--color-secondary-button-text));
  }

.button, .shopify-challenge__button, 
.customer button, button.shopify-payment-button__button--unbranded {
    min-width: 20px;
}

.button--arrow {
  background: none;
  color: rgb(var(--color-secondary-button-text));
  border-radius: 0;
  padding: 0 !important;
  border: none !important;
  text-decoration: none;  
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
}
.button--arrow::after {
  content: '';
  display: block;
  width: 1em;
  height: 1em;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='1.5'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  transition: transform 0.2s ease;
}

.button--arrow:hover::after {
  transform: translateX(4px);
}

.header-group {position: fixed; width: 100%; z-index: 999;}

.list-menu {align-items: center;}

.article-featured__kicker,
.button--dot,
.team-section_name,
.quick-add__submit {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  display: flex !important;
  gap: 7px !Important;
  justify-content: flex-start;
  align-items: center;
  min-height: 0 !important;
}

.button--dot {text-decoration: none;}

.article-featured__kicker:before,
.button--dot:before,
.team-section_name:before,
.quick-add__submit:before {
    content: " ";
    opacity: 1;
    position: relative;
    display: block !important;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: rgb(var(--color-secondary-button-text));
}



/* Fix uneven bullet indentation */
.multicolumn-card ul, .multicolumn-card li {
  list-style-position: outside !important;
}

.multicolumn-card ul {
  list-style-type: disc !important;
  padding-left: 1.4rem !important;
  margin-left: 0 !important;
}

.multicolumn-card li {
  padding-left: 0 !important; 
  text-indent: 0 !important; 
  margin-bottom: 0.6rem; 
}

/* Fix nested lists */
.multicolumn-card ul ul {
  padding-left: 1.6rem !important;
}

.multicolumn-card ul ul li {
  text-indent: 0 !important;
  padding-left: 0 !important;
}



.recipient-checkbox>svg {
    margin-top: 0 !important;
    margin-right: 1.2rem;
    flex-shrink: 0;
}

.recipient-checkbox {
    flex-grow: 1;
    font-size: 1.2rem !important;
}

/* ------ Rich Text  ----------*/

@media screen and (min-width: 990px) {
    .rich-text__blocks {
        max-width: 105rem !important;
    }
}


/* ------ HOME HERO ----------*/


.banner__box>*+.banner__buttons, .rich-text__blocks>*+* {margin-top: 3rem !important;}


.banner__box .banner__heading+*,
.banner__heading, h2 {margin-block-start: 0.3em; margin-block-end: 0.3em; margin-bottom: 0.3em !important; margin-top:  0.3em !important;}

.banner__heading.eyebrow-text {margin-block-end: 1.5em;}
.image-with-text__text {margin-block-start: 0.5em; margin-block-end: 0.5em; display: block;}
.banner__box, .image-text-inner {display: flex; flex-direction: column;}
.banner--content-align-left .banner__box {align-items: flex-start;}

.image-with-text__content>*+* {
    margin-top: 0rem !important;
    margin-bottom: 1em;
}


.home-hero {min-height: calc(100vh - 40px) !important; margin-top: 0px;}

.btn-container .banner__buttons--multiple {
  border: 1px solid rgb(var(--color-secondary-button-text))!important;
  border-radius: 60px;
  margin-top: 20% !important;
  }

.banner__content {max-width: 100% !important;}

.btn-container .banner__buttons--multiple .button {border: none !important}
.btn-container .banner__box {min-width: 65rem;}
.btn-container .banner__buttons {min-width: auto !important; width: auto !important; max-width: 100% !important; flex-wrap: nowrap;}

.home-hero, .banner__box, .page-hero .banner__box {padding: 0 !important;}

.banner__content--middle-left, .banner__content--bottom-left {width: 100% !important; padding: 5rem !important;}
.banner__content--middle-center {padding: 0rem 3rem !important;}


@media screen and (min-width: 750px) {
.btn-container .banner__box,
.banner--desktop-transparent .banner__box,
.banner__box {min-width: calc(60% - 10rem) !important; max-width: calc(60% - 10rem) !important;}

.banner__content--middle-left {margin-left: 0 !important; width: 50% !important;}
.banner__content--middle-left .banner__box {
        min-width: 100% !important;
        max-width: 100%!important;
}
}


  @media screen and (max-width: 1400px) {
  .btn-container .banner__box {min-width: 20px;}
  .btn-container .banner__buttons--multiple {border: none !important; border-radius: 0px; flex-direction: column;}
  .btn-container .button {padding: 0; justify-content: flex-start; gap: 7px; padding: 5px 0 !important;}
  .btn-container .banner__buttons--multiple {margin-top: 10% !important; gap: 0rem;}
.btn-container .button--secondary:hover {
    background-color: transparent !important;
    color: rgb(var(--color-secondary-button));
    opacity: 0.7;
}
}


@media screen and (max-width: 749px) {
  .banner__box>*+.banner__buttons, .rich-text__blocks>*+* {margin-top: 1.5rem !important;}
  .banner__media-half {width: 100% !important;}
  .banner__media-half+.banner__media-half {display: none;}

  .banner--large:not(.banner--mobile-bottom):not(.banner--adapt) .banner__content {min-height: 50rem !important;}
  .home-hero {min-height: 60vh !important;}
  .home-hero .banner__content {padding: 3rem;}
  .banner__content.banner__content--bottom-left {align-items: flex-end; justify-content: flex-start;}


.banner__content--middle-left, 
.banner__content--bottom-left {width: 100% !important; padding: 1.5rem !important;}
}


/* ------ RICHTEXT ----------*/

.rich-text__wrapper--center {display: flex; justify-content: center;}
.rich-text__wrapper--right {display: flex; justify-content: flex-end;}


/* ------ IMAGE WITH TEXT ----------*/

.secondary-image {width: 100% !important; height: 100% !important; padding: 15% 20%;}
.secondary-image img {width: 100% !important; height: 100% !important; object-fit: cover;}
.multicolumn .slider-buttons {display: none;}

.image-text-vh .grid__item {min-height: 100vh;}

.last-item-push .image-text-inner {display: flex; flex-direction: column; height: 100%;}
.last-item-push .image-text-inner div:last-child {margin-top: auto;}

.button-full-width .image-text-inner {height: 100%;}
.button-full-width .banner__buttons {margin-top: auto;}  
.button-full-width .button--secondary {width: 100%;}

.image-with-text_has-cols {display: flex; gap: 20px;}

.image-with-text-images {
  display: flex;
  gap: 20px; /* optional */
  max-width: 60%;
  padding: 4rem 0;
  overflow: hidden;
  margin: 0 auto;
  }

.image-with-text-images img {
  width: calc(50% - 10px) !important;
  height: auto;
  max-width: 100%;
  object-fit: cover;
  }

.image-text-full  h4 {
  font-size: calc(var(--font-heading-scale) * 2.4rem); 
  margin-top: 0.5em !important; 
  margin-bottom: 2em !important;
  }

.image-text-full .page-width {
  max-width: 100%; 
  width: 100%;
  padding: 0;
  }

.image-with-text .image-with-text__content {padding: 5% 7% !important;}
.no-padding .image-with-text__content {padding: 5% 0% !important;}
.first-about .image-with-text__content {padding: 11% 7% 5% 7% !important;}
.landing-page .image-with-text__content {padding: 10% 20% 10% 10% !important;}

.no-padding .image-with-text__text-item {padding-right: 10%;}

.section-product-image .secondary-img {width: 400px; height: auto;}
.section-logo-image .secondary-img {width: 70px; height: auto;}  

.image-with-text .image-with-text__heading p {margin-bottom: 0;}
.image-with-text .banner__buttons {padding-top: 25px; gap: 1rem; display: flex;}


@media screen and (min-width: 750px) {
  .no-padding .grid--3-col-tablet .grid__item:first-child {width: calc(60% - var(--grid-desktop-horizontal-spacing) * 2 / 3);}
  .no-padding .grid--3-col-tablet .grid__item:last-child {width: calc(40% - var(--grid-desktop-horizontal-spacing) * 2 / 3);}
  .grid--3-col-tablet .grid__item {width: calc(45% - var(--grid-desktop-horizontal-spacing)* 2 / 3);}
  }

@media only screen and (max-width: 750px) { 
  .image-with-text .image-with-text__content, .first-about .image-with-text__content {padding: 5% 1.5rem !important;}
  .section-product-image .secondary-img {width: 300px; height: auto;}
  .no-padding .image-with-text__text-item {padding-right: 5%;}
  .no-padding .image-with-text__content {padding: 5% 0rem !important;}

  .mobile-no-padding, .mobile-no-padding .page-width, .mobile-no-padding .image-with-text__content {padding: 0 !important;}
  .mobile-no-padding  .image-with-text__text-item {padding: 1.5rem;}
  .image-with-text .banner__buttons {padding-top: 15px; gap: 1rem;}

  .image-text-vh .grid__item {min-height: auto;}
  }


.image-with-text-img-con {position: relative;}
.image-with-text-img-con .image-with-text__text--caption {position: absolute; top: 20px; left: 20px;}


/* ------ IMAGE WITH TEXT - IMAGE GRID ----------*/

.image-grid-block {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  width: 100%;
}

.image-grid-item {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  text-decoration: none;
}

.image-grid-item img,
.image-grid-item svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.image-grid-label {
  width: 100%;
  text-align: center;
  position: absolute;
  color: white;
  font-size: 1.4rem;
  line-height: 1.3;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-decoration: underline;
  text-underline-offset: 5px;
}

@media screen and (max-width: 749px) {
  .image-grid-block {
    grid-template-columns: 1fr;
  }
}

/* ------ MULTICARD ----------*/

.multicolumn-card__info h3 {display: flex; justify-content: space-between; align-items: center;}
.multicolumn-card__info h3 span {opacity: 0.5;}

.multicolumn-list h3, .template-name--about .content-container h3 {
  line-height: 1.4;
  font-size: calc(var(--font-heading-scale) * 2.2rem);
  }

.multicolumn-list p, .multicolumn-card ul {margin-bottom: 1.5rem !important;}
.multicolumn .button {margin-top: 1rem !important;}

@media screen and (min-width: 750px) {
        .background-none .multicolumn-list .multicolumn-card__info, .background-none .multicolumn-list:not(.slider) .center .multicolumn-card__info {
        padding-left: 0rem !important;
        padding-right: 0rem !important;
    }
    .background-none .multicolumn-card__image-wrapper {
        margin-left: 0px !important;
        margin-right: 0px !important;
    }
}

@media only screen and (max-width: 500px) { 
.multicolumn-card__info h3 {flex-direction: column; align-items: flex-start; padidng-bottom: 10px;}
}

/* ------ TREARMENT PAGES ----------*/
@media screen and (min-width: 1600px) {
    .treatment-hero .banner__content {
        padding: 5rem 16rem !important;
    }
}

/* ------ COLLECTIONS ----------*/

.card__media {border: none;}
.card-wrapper.product-card-wrapper .card__inner>.card__content:before {display: none;}

.product-form__input input[type=radio]+label {
    padding: 0.8rem 1.2rem !important;
    font-size: 1.2rem !important;
    letter-spacing: 0 !important;
}


.card-wrapper.product-card-wrapper .card__inner+.card__content .card__information .price, 
.card-wrapper.product-card-wrapper .card__inner+.card__content .card__information .card__heading {
    font-size: 1.4rem !important;
    line-height: calc(1 + .5 / var(--font-body-scale)) !important;
}


@media screen and (min-width: 750px) {
    .card__information {
        padding-bottom: 1.2rem;
        padding-top: 1.2rem;
    }
}
@media screen and (min-width: 1024px) {
    .card-wrapper.product-card-wrapper .card__inner+.card__content .card__information {
        display: block; text-align: center;
    }
}


/* ------ PRODUCTS ----------*/

.product__media-wrapper {overflow: hidden;}
.product__tax {display: none;}
.product-grid {margin-top: 0;}

.icon-with-text--horizontal {padding: 0 5%;}
.icon-with-text__item .inline-richtext {text-align: center;}

@media screen and (min-width: 990px) {
    .product--stacked .product__media-item {
        max-width: 100% !important;
    }
}

.product-form__label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.size-guide-link {font-size: 1.2rem;}
.product-form__buttons, .product-form__input {max-width: 100% !important; min-width: 100% !important; }
.product-container .page-width {width: 100% !important; padding: 0;}
.product__info-wrapper {padding: 6% !important;}
.card__inner {position: relative;}

.card__content--overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 2rem !important;
  z-index: 2;
  display: flex !important;
  text-align: left !important;
  justify-content: space-between;
  align-items: flex-end;

}

.card__content--overlay {
  pointer-events: none;
}

.card__content--overlay a,
.card__content--overlay button,
.card__content--overlay .card__badge {
  pointer-events: auto;
}

.card__inner-con {
  display: flex !important;
  flex-direction: column;
  gap: 5px;
}

.blog-product-feature__price,
.card__inner-con .price span {
  font-family: var(--font-rhymes) !important;
  opacity: 1 !important;
  color: rgb(var(--color-foreground)) !important;
  letter-spacing: -0.1px;
  line-height: 1.2;
  font-size: 1.6rem !important;
  }

.product__title h1 {font-size: calc(var(--font-heading-scale) * 2.6rem) !important;}
.product__info-wrapper .caption-with-letter-spacing {opacity: 0.5; padding-bottom: 10px;}
.price--large {font-size: 1.6rem !important;}

.quantity__input {font-size: 1.2rem !important;}
.quantity {width: calc(12rem / var(--font-body-scale) + var(--inputs-border-width) * 2) !important; min-height: calc((var(--inputs-border-width) * 2) + 3rem) !important;}

.product__media-list  {column-gap: 0 !important; row-gap: 0 !important;}

@media screen and (min-width: 990px) {
    .product--medium:not(.product--no-media) .product__info-wrapper, 
    .product--small:not(.product--no-media) .product__media-wrapper,
    .product--medium:not(.product--no-media) .product__media-wrapper,
     .product--small:not(.product--no-media) .product__info-wrapper {
        max-width: 50% !important;
        width: calc(50% - var(--grid-desktop-horizontal-spacing) / 2) !important;
    }
}

@media screen and (min-width: 750px) {
    .product__info-container {max-width: 100% !important;}
    .product__column-sticky {top: 12rem !important;}
}

.product__column, .product__media-wrapper {display: block; width: 100%;}
.product__media-list {margin-bottom: 0rem;
}
@media screen and (max-width: 749px) {
    .product__column-sticky {overflow: hidden;} 
    .slider.slider--mobile .slider__slide {padding-top: 0 !important;}
}


/* ------ CART ----------*/

.product-option {font-size: 1.2rem !Important;}
.cart-item__name {font-size: calc(var(--font-heading-scale) * 1.3rem)!Important;}
.cart-item__name:hover {
    text-decoration: underline;
    text-underline-offset: 0rem;
    text-decoration-thickness: 0rem;
}

/* ------ CONTACT ----------*/

.contact-page  .page-width {
    max-width: 100% !important;
    margin: 0 auto;
    padding: 0 !important;
}


.contact-page  .body {padding: 10px 0 0 0;}

.contact-page .border-under {margin: 20% 0 15px 0; padding-bottom: 15px; border-bottom: 1px solid rgba(var(--color-foreground), 1); }
.contact-page .banner__buttons {position: absolute; top: 0; right: 0;}

.contact-page .image-with-text__content {padding: 5% 5% !important;}
.contact-page .image-text-inner {width: 100%; position: relative; display: block;}
.contact-page .col {width: auto; float: left; padding-right: 50px; padding-bottom: 20px;}

@media screen and (max-width: 750px) {
  .contact-page .banner__buttons {position: relative;}
.contact-page .image-with-text__content {padding: 2rem 1.5rem 0 1.5rem  !important;}
}


.customer .caption-large, 
.customer .field input, 
.customer select, 
.customer .field__input, 
.customer .form__label, 
.customer .select__select {
    border:  1px solid rgba(var(--color-foreground), 1) !important;
}

.customer .field label {display: none;}

.field__input, 
.select__select, 
.customer .field input, 
.customer select {
    height: 4.5rem;
    min-height: calc(var(--inputs-border-width) * 2);
    min-width: calc(7rem + (var(--inputs-border-width) * 2));
    position: relative;
}


.contact .field {margin-bottom: 1rem !important;}

input::placeholder {color: rgb(var(--color-foreground)); font-size: 1.3rem !important;}
::placeholder {color: rgb(var(--color-foreground)); font-size: 1.3rem !important;}

.field__input, 
.select__select, 
.customer .field input, 
.customer select {
  background-color: transparent;
  padding: 8px 12px;
  text-transform: uppercase;
  font-weight: 400;
  height: auto;
  }


.contact .field__input, 
.contact.select__select, 
.contact .customer .field input, 
.contact .customer select {
  text-align: center;
  }

.contact .field__input, 
.contact .select__select, 
.contact .customer .field input, 
.contact .customer select {
  background-color:transparent;
  border: 1px solid rgba(var(--color-foreground), 1) !important; 
}

.contact__button {margin-top: 1rem !important; text-align: center;}
.contact__button .button {width: 100%;}
.contact .field__label {display: none;}

@media screen and (min-width: 750px) {.contact__fields {display: block;}}
@media screen and (min-width: 990px) {.template-name--contact .rich-text__blocks {max-width: 60rem;}}

.field:after, .select:after, .customer .field:after, 
.customer select:after, .localization-form__select:after,
.field:before, .select:before, .customer .field:before, 
.customer select:before, .localization-form__select:before {display: none;}

.newsletter-form__field-wrapper .field {border: 1px solid rgba(var(--color-foreground), 1) !important; border-radius: var(--inputs-radius);}
.newsletter-form__button {width: auto !important; text-transform: uppercase;}

.field__input:focus-visible, 
.select__select:focus-visible, 
.customer .field input:focus-visible, 
.customer select:focus-visible, 
.localization-form__select:focus-visible.localization-form__select:after,
.field__input:focus, .select__select:focus, 
.customer .field input:focus, 
.customer select:focus, 
.localization-form__select:focus.localization-form__select:after {
    box-shadow: none !important;
}

.field__label, 
.customer .field label {
    font-size: 1.3rem;
    color: rgba(var(--color-foreground), 1);
    letter-spacing: 0rem;
    line-height: 1.5;
}



/* ------ FOOTER ----------*/


.page-width:has(#insta-feed)  {
    max-width: 100% !important;
    margin: 0 auto;
    padding: 0 !important;
}

.instafeed-bottom-link-wrapper[data-feed-id="0"] {justify-content: flex-end !important;}
.instafeed-bottom-link-wrapper a {}

.footer {border-top: none !important;}
.menu-block .rte a, .footer .rte a, .footer-block .social-links a {text-decoration: none; opacity: 1; color: rgba(var(--color-foreground), 1);}
.menu-block .rte a:hover, .footer .rte a:hover, .footer-block .social-links a:hover {opacity: 0.7}
.footer-block {width: auto !important;}

.footer__blocks-wrapper {display: flex; gap: 3.5rem; flex-wrap: wrap;}
.footer-block--newsletter-block {margin-left: auto; margin-right: 0;}

.footer-block__heading {margin-bottom: 15px !important;}

.footer .grid {align-items: flex-start; margin-bottom: 0 !important;}
.footer-block {width: auto !important;}
.footer-block__details-content {margin-bottom: 0 !important; line-height: 1.6;}
.footer-block__image-wrapper {margin-bottom: 0 !important;}

.footer-block__newsletter p {max-width: 36rem;}
.footer-block__newsletter {
  text-align: left !important; 
  flex-direction: column !important;
  display: flex !important; 
  align-items: flex-start !important;
  justify-content: flex-start !important;
  }

.footer-block__newsletter .newsletter-form {margin: 0 !important;}
.footer-block__newsletter .button {min-height: 45px; padding: 0 30px; background-color: transparent; color: rgb(var(--color-background));}
.footer__newsletter .button {
  background-color: transparent; 
  color: rgba(var(--color-foreground), 1) !important;
min-width: auto !important;
font-size: 1.4em !important;
    padding: 1rem 1.5rem !important;
}

.footer__newsletter .field__input {
    min-width: 30rem !important;
}

.footer__content-bottom {padding: 0 0 30px 0 !important; border-top: none !important;}
.footer__copyright {text-align: center; margin-top: 0rem !important;}

.footer-block-button {margin-left: auto;}
.footer-block .social-links {text-align: right; padding-top: 20px;}
             
.list-social {padding: 0 !important; justify-content: flex-start !important; gap: 7px;}
.list-social__link {padding: 0 !important;}


.localization-form__select, .disclosure__button {opacity: 0.5; height: auto !important; min-height: auto !important;}
.localization-selector.link {padding: 0 !important;}

.localization-form {margin: 0 !important; padding: 0 !important;}

.localization-form:only-child .button, 
.localization-form:only-child .localization-form__select {margin: 0 !important; display: flex; gap: 8px; align-items: center; justify-content: center;}
.localization-form__select .icon-caret {position: relative !important; top: 0 !important; right: 0 !important;}

@media screen and (max-width: 750px) {
.newsletter-form__field-wrapper {max-width: 100% !important;}
  .footer .grid {display: flex !important; flex-direction: row; gap: 0px;}
  .footer-block {width: 50% !important; padding: 0 10px 20px 0 !important; margin: 0 !important; }
  .footer-block-, {width: 100% !important;}
  .footer-block-button, .footer-block__newsletter {width: 100% !important;}
  .footer-block--newsletter {margin-top: 0rem !important; align-items: flex-start !important;}
  .footer-block .social-links {text-align: left;}
  .footer__content-top {padding: 2rem 1.5rem !important;}
  .footer__content-bottom {padding: 0 0 15px 0 !important;}
  .footer__content-bottom-wrapper {row-gap: 0.1rem !important;}
  .localization-form:only-child .button, .localization-form:only-child .localization-form__select {justify-content: flex-start !important;}
.footer-block__heading {margin: 0 !important;}
.footer-block-image {padding-top: 15px;}
}

@media screen and (min-width: 750px) {
    .footer__content-bottom.bottom-align .footer__content-bottom-wrapper:has(.footer__copyright) {
        justify-content: center;
    }
}



/* ------ SIGNUP ----------*/

.newsletter__wrapper {display: flex; align-tiems: center; justify-content: space-between;}
.newsletter__wrapper>*+* {margin-top: 0rem !important;}


.newsletter-form__field-wrapper .field {display: flex; align-items: center; justify-content: space-between;}
.newsletter-form__field-wrapper .field__label {display: none;}
.newsletter-form__button {border: none !important; box-shadow: none !important; padding: 10px; color: rgba(var(--color-foreground), 1) !important;}
.newsletter-form__button:hover {opacity: 0.7;}

@media screen and (max-width: 750px) {.newsletter__wrapper {flex-direction: column;}}


/* ------ POLICY + PRIVACY ----------*/

.shopify-policy__container {
  margin: 15vh auto 7vh auto !important;
  max-width: var(--page-width) !important;
    padding: 0 1.5rem !important;;
  }

  @media screen and (min-width: 750px) {
    .shopify-policy__container {padding: 0 5rem !important;}
}

.shopify-policy__title {text-align: left;}



.shopify-pc__banner__dialog a,
.shopify-pc__banner__dialog p {color: rgba(var(--color-foreground), 1) !important; font-size: 1.2rem !important;}

.shopify-pc__banner__dialog h2 {
  display: none;
  color: rgba(var(--color-foreground), 1) !important;
  font-size: calc(var(--font-heading-scale)* 2rem) !important;
  }

.shopify-pc__banner__dialog {
    position: fixed;
    z-index: 2000000;
    box-shadow: none !important;
    max-height: 90%;
    box-sizing: border-box;
    opacity: 1;
    padding: 30px;
    background-color: rgb(var(--color-background)) !important;
    max-width: 800px !important;
    width: auto !important;
    border-radius: 0 !important;
}

.shopify-pc__banner__dialog button,
.shopify-pc__banner__dialog button.shopify-pc__banner__btn-decline,
.shopify-pc__banner__dialog button.shopify-pc__banner__btn-accept {
    font-size: 14px !important; 
    text-transform: none; 
     font-family: var(--font-dia) !important;
    border-radius: 0px !important;
    color: rgba(var(--color-foreground), 1) !important;
    border: none !important;
    border: 1px solid rgba(var(--color-foreground), 1)  !important;
    background-color: rgb(var(--color-background)) !important;
    padding: 10px 5px !important;
    line-height: 90% !important;
    margin: 10px 10px 0 0 !important;
    }

.shopify-pc__banner__btns {gap: 5px !important;}
.shopify-pc__banner__dialog button.shopify-pc__banner__btn-manage-prefs {text-decoration: none !important;}
.shopify-pc__banner__dialog button.shopify-pc__banner__btn-manage-prefs {color: rgba(var(--color-foreground), 1) !important;}




/* ------ ACCORDION ----------*/

.accordion {
  border-bottom: .1rem solid #CBC1B5 !important;
  border-top: .1rem solid #CBC1B5 !important;
  }

.accordion+.accordion  {border-bottom: .1rem solid #CBC1B5 !important; border-top: none !important;}

.collapsible-content summary:hover {background: transparent !important;}

.accordion__content {margin-bottom: 1rem; padding: 0 !important;}

.image-with-text__grid .image-with-text__heading p {margin-top: 0 !Important;}



/* ------ FORMS ----------*/
input::placeholder {color: rgb(var(--color-foreground));}
::placeholder {color: rgb(var(--color-foreground));}

.field__input, .select__select, .customer .field input, .customer select {
  background-color: transparent;
  padding: 10px;
  }

.field:after, .select:after, .customer .field:after, .customer select:after, .localization-form__select:after,
.field:before, .select:before, .customer .field:before, .customer select:before, .localization-form__select:before {display: none;}

.newsletter-form__field-wrapper .field {border: 1px solid rgba(var(--color-foreground), 1) !important;}
.newsletter-form__button {width: auto !important; text-transform: uppercase;}

.field__input:focus-visible, 
.select__select:focus-visible, 
.customer .field input:focus-visible, 
.customer select:focus-visible, 
.localization-form__select:focus-visible.localization-form__select:after,
.field__input:focus, .select__select:focus, 
.customer .field input:focus, 
.customer select:focus, 
.localization-form__select:focus.localization-form__select:after {
    box-shadow: none !important;
}

.field__label, .customer .field label {
    font-size: 1.3rem;
    color: rgba(var(--color-foreground), 1);
    letter-spacing: 0rem;
    line-height: 1.5;
}

.caption-large, .customer .field input, .customer select, .field__input, .form__label, .select__select {
    font-size: 1.3rem !important;
    letter-spacing: 0 !important;
    }











.summary-content {
  display: flex;
  align-items: center;
}

.summary-content .eyebrow-text {
  margin-right: auto; /* pushes the others to the right */
}

.summary-meta + .summary-meta {
  margin-left: 20px; /* space between time and price */
}

.treatment-dropdowns summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

.treatment-dropdowns summary::marker {display: none;}
.dropdown-body {padding-top: 0px;}

.treatment-labels {
  position: absolute;
  top: 15px; left: 15px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.treatment-label {
  background-color: #fff;
  border-radius: 8px;
  padding: 6px 14px;
  transition: all 0.2s ease;
  color: rgba(var(--color-button), var(--alpha-button-background));
}


summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  list-style: none;
}

.summary-content {
  display: flex;
  flex-direction: row;
  width: 100%;
  justify-content: space-between;
  gap: 4px;
}

.summary-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-left: 1em;
  position: relative;
}

.summary-icon svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  fill: currentColor;
  transition: opacity 0.3s ease;
}

details .icon-minus, details[open] .icon-plus {opacity: 0;}

details[open] .icon-minus {opacity: 1;}







/* ---------- BLOG -------------*/

.article-card__info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 1% 4%;
}
.article-card-inner {
  display: flex;
  flex-direction: column;
}

.article-card-inner img.article-img {
  width: 100%;
  flex: 1;           /* fills remaining height */
  min-height: 0;     /* prevents flex overflow */
  object-fit: cover;
  object-position: center;
  display: block;
  aspect-ratio: 1 / 1;
}

.article-card-wrapper .card__content {padding: 15px 0;}

.main-blog .card__content {gap: 10px; display: flex !important; flex-direction: column;}

.article-card__excerpt {margin-bottom: 0; margin-top: 0;}

@media screen and (min-width: 990px) {
    .main-blog .underline-links-hover:hover a {
        text-decoration: none;
        text-underline-offset: 0rem;
    }
}


.blog-articles {
  display: grid;
  gap:  var(--grid-desktop-horizontal-spacing);
  position: relative;
}

@media (min-width: 990px) {.blog-articles {grid-template-columns: repeat(3, 1fr);}}
@media (max-width: 990px) {.blog-articles {grid-template-columns: 1fr;}}
@media screen and (max-width: 750px) {.blog-articles {gap: 1rem;}}




.active-facets__button-inner {padding: 0.6rem 1rem !important;}

.facets__item {
    padding: 0 !important;
    line-height: 1em !important;
}
.facet-checkbox {
    font-size: 1.2rem !important;
    padding: 0 !important;
    display: flex; 
    align-items: center;
}

.facet-checkbox .icon-checkmark {
    left: .3rem !important;
    top: .8rem !important;
}





/* SEARCH */
.modal__content {z-index: 10;}
.search-modal {border-bottom: none;}

.predictive-search {border: none !important; border-radius: 6px;}

.search-modal__form .field {
  display: flex; 
      border-bottom: 1px solid rgb(var(--color-foreground));
  padding: 0.5rem 0;
  }

  details[open] .modal-overlay:after {
    position: absolute;
    content: "";
    background-color: rgb(var(--color-foreground), 0);
    top: 100%;
    left: 0;
    right: 0;
    height: 100vh;
}


  .search__input {
  flex-grow: 1;
  border: none;
  background: transparent;
  font-size: 1rem;
  padding: 0.5rem 0;
  outline: none;
  }

/* Label - visually hidden but accessible */
.search-modal__form .field__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Buttons inside input */
.search-modal__form  .field__button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0 0.5rem;
  display: flex;
  align-items: center;
}

/* Hide reset button by default */
.search-modal__form .reset__button.hidden {
  display: none;
}

/* Predictive search results */
.predictive-search--header {
  margin-top: 1rem;
  border-top: 1px solid #eee;
  padding-top: 1rem;
}

/* Loading spinner */
.predictive-search__loading-state {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem;
}

.spinner {
  width: 36px;
  height: 36px;
  animation: spin 1s linear infinite;
}

.spinner .path {
  stroke: #999;
  stroke-linecap: round;
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}

/* Close button */
.search-modal__close-button {
  position: absolute;
  top: 0rem;
  right: 1rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  z-index: 10000;
}

.search-modal__close-button svg {
  width: 24px;
  height: 24px;
  stroke: #333;
}

.modal__close-button.link {
    height: 100% !important;
    width: 4rem !important;
}


/* Remove the blue clear button in WebKit browsers (Chrome, Safari, Edge) */
input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

/* Optional: ensure consistent appearance across browsers */
input[type="search"] {
  -webkit-appearance: none;
  appearance: none;
}



/* INSTAFEED */
.instafeed-bottom-link-wrapper[data-feed-id="0"] {padding: 40px 5rem 0px 5rem;}
.instafeed-bottom-link-wrapper a:after {display: none !important;}
.instafeed-bottom-link-wrapper a:hover {opacity: 0.7;}

@media screen and (max-width: 749px) {
.instafeed-bottom-link-wrapper[data-feed-id="0"] a {font-size: 12px !important;   padding: 0 !important;}
.instafeed-bottom-link-wrapper[data-feed-id="0"] {padding: 30px 1.5rem 0px 1.5rem;}
}



/* COLOUR SWATCH */

.color-swatch-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.variant-swatch {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 1px solid rgba(0,0,0,0.15);
  flex-shrink: 0;
}

.swatch-label-text {display: inline-block;}


.mooi-favourites__header .button {margin-top: 10px;}
.mooi-favourites__header .eyebrow-text {margin-top: 0px;}
.mooi-favourites__header .rte {margin: 0.6em 0;}


.voucher-form {border: none; padding: 0 0 15px 0; margin: 0;}
.voucher-form .voucher-label {font-size: 1.3rem !important; padding: 8px 0 5px 0;}
.voucher-form input, .voucher-form textarea {
  width: 44rem; border-radius: 0; padding: 10px; border: 1px solid rgba(var(--color-foreground), 1);}



/* ---------------- ARTICLE ------------ */

.article-featured__breadcrumbs {font-size: 12px; opacity: 0.75; padding-top: 30px;}
.article-featured__breadcrumbs a {text-decoration: none;}

.article-featured__title { margin: 15px 0 25px 0; line-height: 1.05; max-width: 100%; }

@media screen and (max-width: 989px) {
  .article-featured__title {
    max-width: 26ch;
  }
}

.article-featured__meta {
  font-size: 13px;
  opacity: 0.85;
  margin-bottom: 18px;
}

.article-featured__excerpt {
  margin: 0;
  max-width: 54ch;
  font-size: 15px;
  line-height: 1.5;
}

.article-featured__image-wrap {
  overflow: hidden;
  background: none;
  position: relative; 
  max-width: 900px;
  padding: 0 1.5rem; 
  aspect-ratio: 7 / 4; 
  overflow: hidden;
  margin: auto;
  margin-top: 40px;
}

.article-featured__image {
  display: block;
  object-fit: cover;
}

.article-featured__content {
  padding-top: 0;
}

.article-featured__rte {
  max-width: 780px;
  margin: 0 auto;
  padding: 7vh 0;
}

.article-featured__post-nav {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 16px;
  border-top: 1px solid rgba(var(--color-foreground), 1);
}

.article-featured__nav-link {
  text-decoration: none;
  font-size: 13px;
  opacity: 0.85;
}

.article-featured__nav-link--right {margin-left: auto; text-align: right;}


@media screen and (max-width: 990px) {
  .article-featured__rte {padding: 3vh 0;}
  .article-featured__hero {padding-bottom: 3vh;}

  .article-featured__image-wrap {
  margin: 0 1.5rem;
}

}




/* =============================================
   SIZE GUIDE — assets/size-guide.css
   ============================================= */

.size-guide {
  padding-top: 4rem;
  padding-bottom: 6rem;
}

/* Page title */
.size-guide__title {
  margin-bottom: 2.4rem;
}

/* ── Tab navigation ── */
.size-guide__tabs {
  display: flex;
  gap: 2.4rem;
  border-bottom: 1px solid rgba(var(--color-foreground), 1);
  margin-bottom: 4rem;
  flex-wrap: wrap;
}

.size-guide__tab-btn {
  background: none;
  border: none;
  padding: 0 0 1.2rem;
  cursor: pointer;
  font-size: 1.4rem;
  color: rgba(var(--color-foreground), 0.45);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.2s, border-color 0.2s;
  font-family: inherit;
}

.size-guide__tab-btn:hover {color: rgb(var(--color-foreground));}
.size-guide__tab-btn.is-active {color: rgb(var(--color-foreground));}

/* ── Tab panels ── */
.size-guide__panel {
  display: none;
}

.size-guide__panel.is-active {
  display: grid;
  grid-template-columns: 1fr 50rem;
  gap: 6rem;
  align-items: start;
}

/* ── Left content ── */
.size-guide__content {min-width: 0;}


.size-guide__content h1:first-child,
.size-guide__content h2:first-child {margin-top: 0;}


.size-guide__content h4 {
  font-family: var(--font-dia);
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: .8px !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
    text-decoration: underline;
}


.size-guide__content ul,
.size-guide__content ol {
  padding-left: 1.6rem;
  margin-bottom: 1.2rem;
}


/* Tables — for size charts */
.size-guide__content table {
  max-width: 350px;
  width: 100%;
  border-collapse: collapse;
  border: none;
  box-shadow: none;
  margin: 1.6rem 0 2.4rem;

}

.size-guide__content table th {
  text-align: left;
  text-transform: uppercase;
  padding: 0.5rem 0;
  border: none;
}

.size-guide__content table td {
  padding: 0.5rem 0;
  border: none;
}

/* ── Right sticky image ── */
.size-guide__image-wrap {
  position: sticky;
  top: 10rem;
}

.size-guide__image-wrap img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* ── Mobile ── */
@media screen and (max-width: 749px) {
  .size-guide__panel.is-active {
    grid-template-columns: 1fr;
    gap: 3.2rem;
  }

  .size-guide__image-wrap {
    position: static;
    order: -1;
  }

  .size-guide__tabs {
    gap: 1.6rem;
  }
}



/* ------------ FAQ -------------- */

.faq {
    justify-content: center;
    align-items: start;
    column-gap: 3.75rem;
    display: flex;
}

.faq__toc {
  align-content: start;
  justify-items: start;
  gap: .75rem;
  min-width: 150px;
  max-width: 300px;
  transition: inset-block-start .15s ease-in-out;
  display: grid;
  position: sticky;
  inset-block-start: calc(var(--sticky-area-height)  + 1.25rem);
}

.faq__content {
  flex-basis: 100%;
}

.faq__category {
  flex-wrap: wrap;
  align-items: center;
  column-gap: 1rem;
  scroll-margin-block-start: 1.25rem;
  display: flex;
}

.faq__category + .accordion {
  margin-block-start: 1.25rem;
}

.accordion + .faq__category {
  margin-block-start: 3rem;
}


.totals {
    display: flex;
    justify-content: center;
    align-items: center !important;
}



.waitlist-form__field-wrapper {display: flex; align-items: center; gap: 10px;}

.waitlist-form__field-wrapper input {padding: 10px; border: none;}