/** Shopify CDN: Minification failed

Line 488:24 Expected identifier but found "rgb("
Line 762:77 "padidng-bottom" is not a known CSS property
Line 926:18 Unexpected "{"
Line 941:37 "align-tiems" is not a known CSS property

**/
@font-face {
  font-family: "HauoraSans-Regular";
  src: url("/cdn/shop/files/hauora-sans-latin-400-normal.woff") format("woff"),
  url("/cdn/shop/files/hauora-sans-latin-400-normal.woff2") format("woff2");
}


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


body {
  font-family: "Instrument Sans", sans-serif !important;
  font-style: normal;
  line-height: 1.4;
  letter-spacing: 0em !important;
  max-width: 100%;
  overflow-x: hidden;
  }

  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 {font-family: "Instrument Sans", sans-serif !important;}

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

p {letter-spacing: 0em !important;}

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;
}


@media screen and (min-width: 990px) {
    .page-width--narrow {
        max-width: 80%;
        padding: 0;
    }
}

h1, h2, h3, h4, h5, .h0, .h1, .h2, .h3, .h4, .h5 {
  font-family: "HauoraSans-Regular", sans-serif;
  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: "HauoraSans-Regular", sans-serif !important;
    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-family: "beaufort-pro", serif;
    font-weight: 300;
    font-style: normal;
}

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

/*.image-text-full p em, */
.heading-main-med {
    color: rgba(var(--color-foreground), 1);
    font-style: normal !important;
    line-height: 1.1;
    font-family: "beaufort-pro", serif;
    font-weight: 300;
    font-style: normal;
    font-size: calc(var(--font-heading-scale) * 4rem);
}

.heading-alt {
    font-style: normal !important;
    line-height: 1;
    font-family: "HauoraSans-Regular", sans-serif;
    font-style: normal;
    font-size: 30px;
}

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

/* SMALL HEADING */
.treatment-label,
.instafeed-bottom-link-wrapper a,
.menu-collection__link,
.header__icon span,
h5, .h5,
.footer-block__heading,
.image-text-full h3 strong,
.eyebrow-text,
.regular-testimonials h3,
.fade-testimonials h3,
h3 span,
.accordion__title,
.collapsible-content__heading,
.caption-with-letter-spacing,
.totals__total,
.totals__total-value,
.cart-item__price-wrapper .price,
.menu-drawer__close-button
{
    font-family: "Instrument Sans", sans-serif !important;
    font-size: 14px !important;
    text-transform: uppercase !important;
    letter-spacing: .8px !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
  }


@media only screen and (max-width: 750px) {
  .header__icon span,
h5, .h5,
.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: 12px !important;}
  body {font-size: 1.2em;}
  .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;}
}


.treatment-label, .header__icon span, .menu-collection__link {font-size: 12px !important;}
.template-name--faq  .accordion__title {font-size: 1.3rem; min-height: 1.3rem;}

.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);}
  }

.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: "HauoraSans-Regular", sans-serif !important;
  }

.announcement-bar__message span {padding: 0 3px;}

.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 3px;}
}

/* ------ 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;
}


body.transparent-header .header__heading-logo,
body.transparent-header .header__icon--menu,
body.transparent-header .header__icon,
body.transparent-header .header__menu-item,
body.transparent-header .header__icon--account {
  filter: invert(1) brightness(2);
}

.header:hover, body.transparent-header-dark.scrolled .header-wrapper,
.header:hover, body.transparent-header.scrolled .header-wrapper {background-color: #fff !important;}

.header:hover .header__heading-logo,
.header:hover .header__icon--menu,
.header:hover .header__icon,
.header:hover .header__menu-item,
.header:hover .header__icon--account,
body.transparent-header.scrolled .header__heading-logo,
body.transparent-header.scrolled .header__icon--menu,
body.transparent-header.scrolled .header__icon,
body.transparent-header.scrolled .header__menu-item,
body.transparent-header.scrolled .header__icon--account {
  filter: invert(0);
}


.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: "HauoraSans-Regular", sans-serif !important;
  font-size: 1.6em  !important;
  justify-content: flex-start; 
  padding: 5px 0 !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: "Saans-Regular", serif !important;
  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-additional-links,
  .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;}
}




/* 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;
    }

.copyright__content,
.parallax-form button,
.parallax-button,
.button,
.button--primary
.button--secondary,
.button--alt,
.button--dot {
  font-size: 0.9em !important; 
  text-transform: uppercase; 
  letter-spacing: 0.8px !important;
  font-family: "Instrument Sans", sans-serif !important;
  }

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

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

.button--primary::after,
.button--secondary::after {
  content: '';
  position: relative;
  display: inline-flex !important;
  width: 1em;
  height: 1em;

  /* SVG as mask so colour comes from background-color */
  mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 65.54 51.97'><path d='m65.54,25.98l-29.39,25.19c-.62.53-1.39.8-2.15.8-.93,0-1.86-.4-2.51-1.16-1.19-1.38-1.03-3.47.36-4.66l19.69-16.87H3.31c-1.83,0-3.31-1.48-3.31-3.3s1.48-3.31,3.31-3.31h48.22L31.85,5.81c-1.39-1.19-1.55-3.27-.36-4.66,1.19-1.38,3.28-1.54,4.66-.36l29.39,25.19Z'/></svg>");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  margin-bottom: 2px;
  background-color: rgb(var(--color-button-text));
  transition: transform 0.3s ease;
}

.button--secondary:hover::after {
  transform: translateX(4px);
  background-color: rgb(var(--color-secondary-button));
}

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

.button--secondary {
    border-radius: 60px;
    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--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;
}

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

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

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

.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;}

.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;  /* controls bullet indent */
  margin-left: 0 !important;
}

.multicolumn-card li {
  padding-left: 0 !important;       /* ensures wrapped lines align */
  text-indent: 0 !important;        /* fixes the wrap misalignment */
  margin-bottom: 0.6rem;            /* spacing between bullets */
}

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

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


/* ---- HOME - Fade Testimonials ----*/

.regular-testimonials h3,
.fade-testimonials h3 {padding-bottom: 20px; margin-bottom: 30px !important; border-bottom: 1px solid rgb(var(--color-foreground));}

.fade-testimonials .multicolumn-card {opacity: 0.6;}
.fade-testimonials .multicolumn-card:hover {opacity: 1;}

@media screen and (min-width: 750px) {
   .regular-testimonials .grid,
   .fade-testimonials .grid {
        column-gap: 6%;
        row-gap: 6%;
    }
     .regular-testimonials .grid__item,
     .fade-testimonials .grid__item {
        padding: 0; 
        width: calc(33.33% - 6% * 2 / 3);
        max-width: calc(33.33% - 6% * 2 / 3);
    }
}

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

/*.banner__box .banner__heading+* {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;
}



.page-hero {}
.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;}

.home-hero .banner__content--middle-left,
.home-hero .banner__content--bottom-left
.page-hero .banner__content--middle-left,
.page-hero .banner__content--bottom-left {width: 100% !important; padding: 1.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: 749px) {
  .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;}

  }

  @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;}

  .banner__content.banner__content--bottom-left {padding: 3rem 1.5rem  !important;}
  .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;
}
}

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

.rich-text__wrapper--center {display: flex; justify-content: center;}
  .rich-text__wrapper--right {display: flex; justify-content: flex-end;}
/* ------ IMAGE WITH TEXT ----------*/

.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: 8% 12% !important;}

.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: 30px; gap: 0rem;}


@media only screen and (max-width: 750px) { 
  .image-with-text .image-with-text__content {padding: 9% 1.5rem 9% 1.5rem !important;}
  .section-product-image .secondary-img {width: 300px; height: auto;}
  }

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

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




/* ------ 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: 1px solid #eee;}
.card-wrapper.product-card-wrapper .card__inner>.card__content:before {display: none;}
.price {opacity: 0.5;}


.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: 1024px) {
    .card-wrapper.product-card-wrapper .card__inner+.card__content .card__information {
        display: flex; justify-content: space-between; gap: 10px;
    }
}

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

.product__title h1 {font-size: calc(var(--font-heading-scale) * 2.6rem) !important;}

.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__info-wrapper .caption-with-letter-spacing {opacity: 0.5; padding-bottom: 10px;}


/* ------ 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;
}

/* ------ 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-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;}

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

.footer-block-button {margin-left: auto;}
.footer-block .social-links {text-align: right; padding-top: 20px;}


.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) {

  .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;}

}

/* ------ 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;}}


/* ------ PRIVACY ----------*/

.shopify-policy__container {
  max-width: 100%;
  margin: 7vh auto;
  padding-left: 20px;
  padding-right: 20px;
  }

.shopify-pc__banner__dialog a,
.shopify-pc__banner__dialog p {color: #fff !important; font-size: 1.2rem !important;}

.shopify-pc__banner__dialog h2 {
  display: none;
  color: #fff !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: 32px;
    background-color: #2b2c29 !important;
    bottom: 5px !important;
    right: 5px !important;
    left: 5px !important;
    max-width: calc(100% - 10px) !important;
    width: calc(100% - 10px) !important;
    border-radius: 6px !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: "Saans-Regular", serif !important;
    border-radius: 6px !important;
    color: #fff;
    border: none !important;
    border: 1px solid #fff !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: #fff !important;}




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

.accordion {
  border-top: none !important;
  border-bottom: none !important;
  }

.accordion summary {border-bottom: .1rem solid rgba(var(--color-foreground), 1) !important;}

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

.accordion__content {margin-bottom: 1.5rem; padding: 20px 0 !important;}

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


/* ------ CONTACT PAGE - FORM ----------

.image-with-text .contact__button .button {width: 100% !Important;}
.image-with-text .field {margin-bottom: 15px; border: 1px solid rgba(var(--color-foreground), 1) !important; border-radius: 6px;}

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

.image-with-text .field__label {display: none;}
.image-with-text #ContactForm {padding-top: 10vh;}*/


/* ------ 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;
    }

.list-social {padding: 0 25px !important; justify-content: center !important;}
.list-social__link {padding: 0.8rem 0.5rem !important;}



@media screen and (max-width: 750px) {
  .template-name--faq .banner--adapt,
  .template-name--return-policy .banner--adapt,
  .template-name--about .banner--adapt,
  .template-name--policy-pages .banner--adapt {
    height: 30vh;
}

}





/* TREATMENTS & SKIN CONCERNS */

.treatment-multicol .grid__item:first-child {margin-right: 10%;}
.treatment-multicol .grid__item:not(:first-child) {
  width: 25% !important; 
  max-width:  25% !important;
  border-top: 1px solid rgba(var(--color-foreground), 1) !important;
  padding-top: 20px;
  }

  @media screen and (max-width: 990px) {
.treatment-multicol .grid__item:not(:first-child) {
  width: calc(50% - 10px) !important; 
  max-width: 50% !important; 
  }

}

 .treatment-multicol .grid__item:not(:first-child) p {opacity: 0.5; margin-left: 20px;}

  .treatment-multicol .grid__item:not(:first-child) h5 {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  display: flex !important;
  gap: 10px !Important;
  justify-content: flex-start;
  align-items: center;
  min-height: 0 !important;
}

  .treatment-multicol .grid__item:not(:first-child) h5:before {
    content: " ";
    position: relative;
    display: block !important;
    content: " ";
    position: relative;
    display: block !important;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: rgb(var(--color-secondary-button-text));
}


/* TREATMENTS & SKIN CONCERNS */

.treatment-dropdowns .dropdown-item:first-of-type {padding-top: 20px;}

.treatment-menu {overflow: visible; height: 0;}

.treatment-menu__wrapper {padding: 8vh 0; width: 25%;}

.skin-concern-con, .treatment-section {
  padding: 8vh 0; 
  padding-left: 25%;
  }

.skin-concern-con .page-width,
.treatment-section .page-width {border-left: 1px solid rgba(var(--color-foreground), 1) !important;}

.treatment-menu__content {margin-bottom: 30px;}

.treatment-menu__content a {
  color: rgba(var(--color-foreground), 1) !important;
  display: flex;
  gap: 7px;
  align-items: center;
  text-decoration: none;
  padding: 0.3rem 0;
  transition: color 0.25s ease, font-weight 0.25s ease;
  opacity: 0.5;
  }

.view-all-btn {margin-bottom: 20px;}
.treatment-menu__content a:active,
.treatment-menu__content a.first-item,
.treatment-menu__content a.active,
.treatment-menu__content a.active-link,
.treatment-menu__content a:hover {
  margin-left: 0px; opacity: 1;
  }

.treatment-section {display: none;}
.treatment-section.visible {display: block;}

.treatment-header {margin-bottom: 40px; display: flex; justify-content: space-between; align-items: flex-start;}
.treatment-header .eyebrow-text {margin-top: 0;}
.treatment-header .h1 {margin: 0;}

.treatment-wrapper {
  display: flex;
  align-items: stretch;
  gap: 50px;
  margin: 0 auto;
  height: 100%;
}

.treatment-image {position: relative; flex: 0 0 40%;}

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

.treatment-content {flex: 1; height: 100%; display: flex; justify-content: space-between; flex-direction: column;}
.treatment-description p:first-child {margin-top: 0 !important;}
.treatment-dropdowns {margin-top: auto; width: 100%;}

.treatment-dropdowns details,
.treatment-dropdowns .no-dropdown {
  border-bottom: 1px solid rgba(var(--color-foreground), 1); 
  padding: 1.25rem 0;
  }


  .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;}


/* Mobile Styles */
@media screen and (max-width: 900px) {
  .treatment-wrapper {flex-direction: column; gap: 30px;}
  .treatment-menu__wrapper {padding: 5vh 0 0 0;width: 100%;}
  .treatment-menu {height: auto; display: none;}
  .treatment-image {width: 100%;}
  .treatment-header {margin-bottom: 30px; flex-direction: column; gap: 20px;}
  .skin-concern-con {padding-left: 0%;}
  .skin-concern-con .page-width, .treatment-section .page-width {border-left: none !important;}
  .treatment-section {padding: 10vh 0; padding-left: 0%;}
  .treatment-menu__content {display: flex; flex-wrap: wrap;}
  .treatment-menu__content a {width: 40%;}
}


.article-img {display: block; width: 100%; object-fit: cover; height: 400px;}
.journal-featured-grid__left .article-img {height: 100%;}
.journal-featured-grid__left .article-card-inner {height: 100%; display: flex; flex-direction: column;}
.article-card-wrapper .card__content {padding: 10px 0;}








.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;
}




/* TEAM SECTION */

.team-intro .rich-text__text {float: right; width: 35%; text-align: right;}
.team-intro .banner__heading {float: left; width: 35%;}
.team-intro .banner__heading:nth-child(2) {clear: both; width: 40%;}

.team-intro .rich-text__blocks::after {
    content: "";
    display: block;
    clear: both;
    visibility: hidden;
    height: 0; 
}

@media screen and (min-width: 990px) {
    .team-intro .rich-text__blocks {max-width: 100%;}
}

@media screen and (max-width: 990px) {
.team-intro .rich-text__text {float: none; width: 100%; text-align: left;}
.team-intro .banner__heading {float: none; width: 100%;}
.team-intro .banner__heading:nth-child(2) {clear: both; width: 100%;}
  }




/* SEARCH */


.modal__content {z-index: 10;}
.search-modal {background-color: #FAF9F6; border-bottom: none;}

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

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

  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;
}




.pairs-well-with {
  border: 1px solid #707070;
  padding: 1rem 2rem 1rem 1rem;
  margin-top: 2rem;
}

.pairs-wrapper {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 2rem;
}

.pairs-image img {
  width: 120px;
  height: auto;
  object-fit: cover;
  display: block;
}

.pairs-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  position: relative;
}

.pairs-label {
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: #999;
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}

.pairs-title {
  font-size: 1.6rem;
  margin: 0 0 1.2rem;
  font-weight: 500;
}

.pairs-title a {color: #000;text-decoration: none;}
.pairs-content .eyebrow-text, .pairs-price {margin-top: 0 !important; opacity: 0.5; }
.pairs-price {position: absolute; top: 0; right: 0;font-size: 1.4rem;}

.pairs-button {
  margin-top: 10px;
  padding: 0.8rem 2.5rem !important;
  font-size: 1.2rem !important;
  align-self: flex-start;
}

.pairs-button:hover {
  background: #000;
  color: #fff;
}

/* Mobile layout */
@media (max-width: 300px) {
  .pairs-wrapper {flex-direction: column; text-align: center;}
  .pairs-content {align-items: center;}
  .pairs-price {position: static;margin-bottom: 1rem;}
  .pairs-button {align-self: center;}
}




.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;}
  }



.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;}