/** Shopify CDN: Minification failed

Line 152:19 Expected identifier but found whitespace
Line 152:21 Unexpected "{"
Line 152:30 Expected ":"
Line 958:2 Expected identifier but found "*"
Line 958:78 Expected identifier but found "*"
Line 959:59 Expected identifier but found "*"
Line 960:76 Expected identifier but found "*"
Line 972:2 Expected identifier but found "*"
Line 998:2 Expected identifier but found "*"
Line 998:80 Expected identifier but found "*"
... and 11 more hidden warnings

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:comparison-new (INDEX:15) */
.hoc-compare {
    background-color: rgb(var(--color-background));
    background-image: var(--hoc-compare-bg);
    background-size: cover;
    background-position: center;
  }
  .hoc-compare__heading {
    font-family: var(--hoc-font-heading);
    font-size: clamp(2.8rem, 5.5vw, 4.2rem);
    margin: 0 0 clamp(1.5rem, 3vw, 2.5rem);
  }
  .hoc-compare__scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .hoc-compare__scroll:focus-visible {
    outline: 3px solid rgb(var(--hoc-navy));
    outline-offset: 4px;
    border-radius: var(--hoc-radius-sm);
  }
  .hoc-compare__table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    min-width: 460px;
  }
  .hoc-compare__table th,
  .hoc-compare__table td {
    padding: clamp(0.6rem, 1.4vw, 1rem) clamp(0.4rem, 1.2vw, 1rem);
    text-align: center;
    vertical-align: middle;
  }
  .hoc-compare__table thead th {
    font-family: var(--hoc-font-heading);
    font-weight: 700;
    font-size: clamp(1.3rem, 1.8vw, 1.7rem);
    color: var(--hoc-heading-color);
    vertical-align: bottom;
  }
  .hoc-compare__table tbody th[scope="row"] {
    text-align: left;
    font-family: var(--hoc-font-body);
    font-weight: 500;
    font-size: clamp(1.2rem, 1.4vw, 1.45rem);
    color: rgb(var(--color-foreground));
    width: 38%;
  }
  .hoc-compare__table tbody tr + tr th,
  .hoc-compare__table tbody tr + tr td {
    border-top: 1px solid rgba(var(--color-foreground), 0.12);
  }
  .hoc-compare__brandname {
    font-family: var(--hoc-font-script);
    color: rgb(var(--hoc-red));
    font-size: clamp(1.3rem, 2.4vw, 1.9rem);
  }
  .hoc-compare__brandcol--head img {
    display: block;
    margin: 0 auto;
    width: clamp(80px, 12vw, 130px);
    height: auto;
  }

  /* Highlighted brand column outline */
  .hoc-compare__brandcol {
    border-inline: 2px solid rgb(var(--hoc-navy));
    background: rgba(var(--hoc-white), 0.55);
  }
  .hoc-compare thead .hoc-compare__brandcol--head {
    border-top: 2px solid rgb(var(--hoc-navy));
    border-start-start-radius: var(--hoc-radius-md);
    border-start-end-radius: var(--hoc-radius-md);
  }
  .hoc-compare tbody tr:last-child .hoc-compare__brandcol {
    border-bottom: 2px solid rgb(var(--hoc-navy));
    border-end-start-radius: var(--hoc-radius-md);
    border-end-end-radius: var(--hoc-radius-md);
  }
  .hoc-compare tbody tr + tr .hoc-compare__brandcol {
    border-top: 0;
  }

  .hoc-mark {
    display: inline-flex;
    width: clamp(22px, 3vw, 30px);
    height: clamp(22px, 3vw, 30px);
  }
  .hoc-mark svg { width: 100%; height: 100%; }
  .hoc-mark--yes { color: rgb(var(--hoc-navy)); }
  .hoc-mark--no { color: rgba(var(--color-foreground), 0.35); }

  /* Phones: the whole table fits the viewport — no horizontal scroll */
  @media screen and (max-width: 600px) {
    .hoc-compare__scroll { overflow-x: visible; }
    .hoc-compare__table {
      min-width: 0;
      width: 100%;
      table-layout: fixed;
    }
    .hoc-compare__table thead td:first-child { width: 31%; }
    .hoc-compare__table th,
    .hoc-compare__table td { padding: 0.55rem 0.2rem; }
    .hoc-compare__table thead th {
      font-size: 0.95rem;
      line-height: 1.2;
      hyphens: auto;
    }
    .hoc-compare__table tbody th[scope="row"] {
      font-size: 1.05rem;
      line-height: 1.3;
      width: auto;
      padding-inline-end: 0.4rem;
    }
    .hoc-compare__brandcol--head img { width: 62px; }
    .hoc-mark { width: 18px; height: 18px; }
    .hoc-compare thead .hoc-compare__brandcol--head,
    .hoc-compare tbody tr:last-child .hoc-compare__brandcol {
      border-start-start-radius: 12px;
      border-start-end-radius: 12px;
    }
    .hoc-compare tbody tr:last-child .hoc-compare__brandcol {
      border-start-start-radius: 0;
      border-start-end-radius: 0;
      border-end-start-radius: 12px;
      border-end-end-radius: 12px;
    }
  }
/* END_SECTION:comparison-new */

/* START_SECTION:custom-testimonials (INDEX:18) */
.testimonial-slider-section {
  background-color: {{ section.settings.background_color }};
  padding: 50px 0;
}

.testimonial-slider-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
}

.testimonial-slider-title {
  text-align: center;
  margin-bottom: 30px;
  font-size: 2rem;
  color: #333;
}

.testimonial-slider {
  position: relative;
  overflow: hidden;
  width: 100%;
}

.testimonial-slider-wrapper {
  display: flex;
  transition: transform 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);
  will-change: transform;
}

.testimonial-slide {
  flex: 0 0 100%;
  width: 100%;
  padding: 0 15px;
  box-sizing: border-box;
}

.testimonial-slide-inner {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}

.testimonial-content {
  background-color: white;
  border-radius: 12px;
  box-shadow: 0 10px 25px rgba(0,0,0,0.1);
  padding: 35px;
  max-width: calc(50% - 10px);
  width: 100%;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.testimonial-content:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(0,0,0,0.12);
}

.testimonial-quote {
  font-size: 1.2rem;
  line-height: 1.6;
  color: #444;
  margin-bottom: 20px;
  position: relative;
  font-style: italic;
}

.testimonial-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.testimonial-rating {
  display: flex;
  color: #ffba00;
  margin-bottom: 10px;
}

.testimonial-author {
  font-weight: 600;
  color: #333;
}

.slider-controls {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}

.slider-btn {
  background: rgba(34, 96, 137, 0.1);
  border: none;
  color: #226089;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  pointer-events: auto;
  transition: background 0.3s ease, transform 0.2s ease;
}

.slider-btn:hover {
  background: rgba(34, 96, 137, 0.2);
}

.slider-btn:active {
  transform: scale(0.95);
}

.slider-dots {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

.slider-dot {
  width: 10px;
  height: 10px;
  background-color: #ddd;
  border-radius: 50%;
  margin: 0 5px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.slider-dot.active {
  background-color: #226089;
}

@media (max-width: 768px) {
  .testimonial-content {
    max-width: 100%;
    padding: 25px;
    margin-bottom: 20px;
  }
  
  .testimonial-slide-inner {
    flex-direction: column;
  }
}
/* END_SECTION:custom-testimonials */

/* START_SECTION:email-form (INDEX:19) */
.nl-banner { padding: clamp(20px, 4vw, 40px); }
  .nl-container { display: flex; border-radius: var(--hoc-radius-lg); overflow: hidden; max-width: var(--page-width); margin: 0 auto; border: 2px solid rgb(var(--hoc-navy)); }
  .nl-photo { flex: 0 0 40%; min-width: 140px; }
  .nl-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .nl-content { flex: 1; background-color: rgb(var(--hoc-white)); background-size: cover; background-position: center; padding: clamp(28px, 5vw, 60px) clamp(20px, 4vw, 48px); display: flex; flex-direction: column; justify-content: center; }
  .nl-heading { font-family: var(--hoc-font-script); font-size: clamp(2rem, 5vw, 3rem); color: var(--hoc-heading-color); margin: 0 0 0.5rem; }
  .nl-sub { font-family: var(--hoc-font-body); font-size: 1.4rem; margin: 0 0 1.5rem; color: rgb(var(--hoc-navy)); }
  .nl-form { display: flex; gap: 0.75rem; flex-wrap: wrap; }
  .nl-input { flex: 1 1 240px; padding: 0.9rem 1.4rem; font: inherit; border: 1px solid rgba(var(--hoc-navy), 0.35); border-radius: var(--hoc-radius-pill); outline: none; color: rgb(var(--hoc-navy)); background: rgb(var(--hoc-white)); }
  .nl-input:focus-visible { outline: 2px solid rgb(var(--hoc-navy)); outline-offset: 1px; }
  .nl-btn { background: rgb(var(--hoc-red)); color: rgb(var(--hoc-white)); font-family: var(--hoc-font-body); font-size: 1rem; font-weight: 700; padding: 0.9rem 2rem; border: none; border-radius: var(--hoc-radius-pill); cursor: pointer; box-shadow: var(--hoc-shadow-sm); transition: transform 0.15s ease, box-shadow 0.15s ease; }
  .nl-btn:hover { transform: translate(-1px, -2px); box-shadow: var(--hoc-shadow); }
  .nl-success { margin: 0; font-weight: 700; color: rgb(var(--hoc-navy)); }
  .nl-error { margin: 0.5rem 0 0; color: rgb(var(--hoc-red)); font-size: 0.9rem; }
  @media (max-width: 600px) {
    .nl-container { border-radius: var(--hoc-radius-md); }
    .nl-content { padding: 24px 16px; }
    .nl-heading { font-size: 1.9rem; }
    .nl-sub { font-size: 1.2rem; }
    .nl-form { flex-direction: column; gap: 0.6rem; }
    .nl-input,
    .nl-btn {
      /* in column direction the 240px flex-basis would become the HEIGHT */
      flex: 0 0 auto;
      width: 100%;
      box-sizing: border-box;
    }
    .nl-input { padding: 0.8rem 1.2rem; }
    .nl-btn { padding: 0.8rem 1.2rem; }
  }
/* END_SECTION:email-form */

/* START_SECTION:faq (INDEX:21) */
.faq-wrapper { background: rgb(var(--hoc-cream)); padding: clamp(48px, 8vw, 96px) 20px; }
  .faq-inner { max-width: var(--page-width); margin: 0 auto; display: flex; flex-wrap: wrap; gap: clamp(2rem, 5vw, 3.5rem); }
  .faq-heading { flex: 1 1 280px; font-family: var(--hoc-font-heading); font-size: clamp(2.8rem, 5.5vw, 4.2rem); color: var(--hoc-heading-color); margin: 0; }
  .faq-list { flex: 2 1 560px; display: flex; flex-direction: column; gap: 1rem; }
  .faq-item { background: rgb(var(--hoc-navy)); border-radius: var(--hoc-radius-lg); overflow: hidden; box-shadow: var(--hoc-shadow); }
  .faq-item summary { list-style: none; cursor: pointer; padding: 1.25rem 1.75rem; font-family: var(--hoc-font-body); font-size: 1.45rem; font-weight: 600; color: rgb(var(--hoc-white)); display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item summary:focus-visible { outline: 3px solid rgb(var(--hoc-yellow)); outline-offset: -3px; }
  .faq-icon { flex: none; transition: transform 0.25s ease; }
  .faq-item[open] .faq-icon { transform: rotate(45deg); }
  .faq-content { padding: 1.25rem 1.75rem; font-family: var(--hoc-font-body); font-size: 1.35rem; line-height: 1.6; color: rgb(var(--hoc-navy)); background: rgb(var(--hoc-white)); }
  @media (max-width: 749px) {
    .faq-heading { flex: 1 1 100%; text-align: center; }
  }
/* END_SECTION:faq */

/* START_SECTION:footer (INDEX:26) */
/* Hangover Cure — footer brand polish */
  .footer { border-top: 2px solid rgba(var(--hoc-navy), 0.12); }
  .footer .footer-block__heading {
    font-family: var(--hoc-font-heading);
    color: var(--hoc-heading-color);
  }
  .footer .footer-block__details-content a:hover,
  .footer .list-menu__item--link:hover { color: rgb(var(--hoc-red)); }
  .footer__content-bottom { border-top: 1px solid rgba(var(--hoc-navy), 0.12); }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:27) */
/* Hangover Cure — floating pill header */
  .header-wrapper,
  .header-wrapper.gradient {
    background: transparent !important;
    background-image: none !important;
    border: 0;
  }
  .header.page-width {
    max-width: min(1000px, calc(100% - 2.5rem));
    margin: 30px auto 12px;
    padding: 4px 20px;
    background: rgb(var(--hoc-cream));
    border: 1px solid rgba(var(--hoc-navy), 0.22);
    border-radius: var(--hoc-radius-pill);
    box-shadow: var(--hoc-shadow);
  }
  .header__heading-logo { max-width: 100%; max-height: 42px; width: auto; }
  .header__inline-menu { align-items: center; }

  .header__inline-menu .header__menu-item,
  .header__inline-menu .list-menu__item {
    font-family: var(--hoc-font-body);
    font-weight: 600;
    color: rgb(var(--hoc-navy));
  }
  .header__menu-item:hover,
  .header__icon:hover { color: rgb(var(--hoc-red)); }
  .header__icon { color: rgb(var(--hoc-navy)); }
  .cart-count-bubble { background: rgb(var(--hoc-red)); color: rgb(var(--hoc-white)); }

  /* Pull the home hero up so its collage sits behind the floating pill */
  .hoc-hero {
    margin-top: -100px;
    position: relative;
    z-index: 0;
  }

  @media screen and (max-width: 749px) {
    .header.page-width {
      margin: 20px auto 10px;
      padding: 4px 14px;
      max-width: calc(100% - 1.5rem);
    }
    .header__heading-logo { max-height: 34px; }
    .hoc-hero { margin-top: -96px; }
  }
/* END_SECTION:header */

/* START_SECTION:hero-hangover-cure (INDEX:28) */
.hoc-hero {
    position: relative;
    background-color: rgb(var(--hoc-sky));
    line-height: 0;
    overflow: hidden;
  }
  .hoc-hero__banner { margin: 0; }
  .hoc-hero__img {
    display: block;
    width: 100%;
    height: auto;
  }

  /* On large screens the full 1.91:1 collage is too tall — cap the hero at 36vw
     with a centre crop. The natural image height is 52.4vw (1006/1920), so the
     centre crop removes 8.2vw from the top; the baked-in button sits at 36.58vw
     in the artwork, i.e. 28.4vw from the container top. */
  @media screen and (min-width: 1100px) {
    .hoc-hero { height: 36vw; }
    .hoc-hero__banner {
      position: absolute;
      inset: 0;
    }
    .hoc-hero__img {
      height: 100%;
      object-fit: cover;
      object-position: center;
    }
    .hoc-hero__cta {
      top: 28.4vw;
    }
  }

  /* On phones the wide collage would collapse to a thin strip — give the hero a
     real height and cover-fill it (cover-by-height keeps the centred logo + the
     baked-in button, and the CTA overlay below, vertically aligned). */
  @media screen and (max-width: 749px) {
    .hoc-hero {
      min-height: clamp(440px, 66vh, 580px);
    }
    .hoc-hero__banner {
      position: absolute;
      inset: 0;
    }
    .hoc-hero__img {
      height: 100%;
      object-fit: cover;
      object-position: center center;
    }
  }
  /* Real CTA button (the baked-in one was erased from the artwork).
     Fixed type scale — it no longer grows with the image. */
  .hoc-hero__cta {
    position: absolute;
    left: 50%;
    top: 69.8%;
    transform: translate(-50%, -50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1.1;
    white-space: nowrap;
    font-family: var(--hoc-font-script);
    font-size: clamp(20px, 1.8vw, 30px);
    padding: 0.5em 2.4em;
    min-height: 44px;
    color: rgb(var(--hoc-white));
    background: rgb(var(--hoc-navy));
    border-radius: var(--hoc-radius-pill);
    box-shadow: 5px 5px 0 rgb(var(--hoc-white));
    text-decoration: none;
    transition: transform 0.15s ease;
  }
  .hoc-hero__cta:hover {
    transform: translate(-50%, calc(-50% - 2px));
  }
  .hoc-hero__cta:focus-visible {
    outline: 3px solid rgb(var(--hoc-white));
    outline-offset: 3px;
  }
  @media (prefers-reduced-motion: reduce) {
    .hoc-hero__cta,
    .hoc-hero__cta:hover {
      transition: none;
      transform: translate(-50%, -50%);
    }
  }
/* END_SECTION:hero-hangover-cure */

/* START_SECTION:hoc-benefit-columns (INDEX:29) */
.hoc-benefits {
    background-color: rgb(var(--color-background));
    color: rgb(var(--color-foreground));
  }
  .hoc-benefits__inner {
    margin-inline: auto;
  }
  .hoc-benefits--panel .hoc-benefits__inner {
    background-color: rgb(var(--color-background));
    border-radius: var(--hoc-radius-lg);
    padding: clamp(2rem, 4vw, 3.25rem) clamp(1.25rem, 3vw, 2.5rem);
  }
  .hoc-benefits--panel {
    background-color: transparent;
    padding-inline: 1.5rem;
  }

  .hoc-benefits__heading {
    text-align: center;
    margin: 0 0 clamp(1.5rem, 3vw, 2.5rem);
    font-family: var(--hoc-font-heading);
  }

  .hoc-benefits__layout {
    display: flex;
    align-items: center;
    gap: clamp(1rem, 3vw, 2.5rem);
  }
  .hoc-benefits__row {
    flex: 1 1 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(1rem, 3vw, 2.5rem);
  }
  .hoc-benefits__row.is-divided > .hoc-benefit + .hoc-benefit {
    border-inline-start: 1px solid rgba(var(--color-foreground), 0.22);
  }

  .hoc-benefit {
    text-align: center;
    padding-inline: clamp(0.5rem, 1.5vw, 1.5rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
  }
  .hoc-benefit__icon {
    width: clamp(42px, 4.5vw, 54px);
    height: clamp(42px, 4.5vw, 54px);
    margin-bottom: 0.4rem;
  }
  .hoc-benefit__icon svg,
  .hoc-benefit__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  .hoc-benefit__title {
    margin: 0;
    font-family: var(--hoc-font-heading);
    font-weight: 700;
    font-size: clamp(1.6rem, 2vw, 2rem);
    color: var(--hoc-heading-color);
  }
  .hoc-benefit__text {
    margin: 0;
    font-size: clamp(1.25rem, 1.4vw, 1.45rem);
    line-height: 1.45;
    opacity: 0.85;
  }

  .hoc-benefits__aside {
    flex: 0 0 auto;
    align-self: flex-end;
    line-height: 0;
  }
  .hoc-benefits__aside img {
    width: clamp(220px, 24vw, 320px);
    height: auto;
    /* extend past the section bottom so the next section's panel overlaps her
       (panel is position:relative + z-index:1; this img stays unpositioned) */
    margin-bottom: -5rem;
  }
  .hoc-benefits--aside-left .hoc-benefits__layout {
    flex-direction: row-reverse;
  }

  @media screen and (max-width: 749px) {
    .hoc-benefits__row {
      grid-template-columns: 1fr;
      gap: 1.75rem;
    }
    .hoc-benefits__row.is-divided > .hoc-benefit + .hoc-benefit {
      border-inline-start: 0;
      border-top: 1px solid rgba(var(--color-foreground), 0.22);
      padding-top: 1.5rem;
    }
    .hoc-benefits__aside {
      display: none;
    }
  }
/* END_SECTION:hoc-benefit-columns */

/* START_SECTION:hoc-how-it-works (INDEX:31) */
.hoc-how { background-color: rgb(var(--color-background)); }
  .hoc-how__heading {
    text-align: center;
    font-family: var(--hoc-font-heading);
    font-size: clamp(2.8rem, 5.5vw, 4.2rem);
    margin: 0 0 clamp(1.5rem, 3vw, 2.75rem);
  }
  .hoc-how__layout {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(1.5rem, 4vw, 3rem);
  }
  .hoc-how__steps {
    list-style: none;
    margin: 0;
    padding: 0;
    flex: 1 1 auto;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: clamp(1.5rem, 5vw, 5rem);
  }
  .hoc-how__step { display: flex; justify-content: center; }
  .hoc-how__stepimg {
    height: clamp(210px, 22vw, 290px);
    width: auto;
  }

  @media screen and (max-width: 600px) {
    .hoc-how__steps {
      flex-direction: column;
      align-items: center;
      gap: 2.25rem;
    }
    .hoc-how__step { width: 100%; justify-content: center; }
    .hoc-how__stepimg { height: 330px; }
    /* The "Pour" artwork's glass sits left of the bitmap centre (the sachet
       extends right) — nudge it so the glass + title align with the others */
    .hoc-how__step:first-child .hoc-how__stepimg { transform: translateX(9%); }
  }
  .hoc-how__aside { flex: 0 0 auto; line-height: 0; align-self: flex-end; }
  .hoc-how__aside img { width: clamp(200px, 26vw, 320px); height: auto; }

  @media screen and (max-width: 989px) {
    .hoc-how__aside { display: none; }
  }
  @media screen and (max-width: 600px) {
    .hoc-how__steps { gap: 1.5rem; }
  }
/* END_SECTION:hoc-how-it-works */

/* START_SECTION:hoc-reviews (INDEX:32) */
.hoc-reviews {
    background-color: rgb(var(--color-background));
  }
  .hoc-reviews__top {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) 2fr;
    gap: clamp(1.5rem, 4vw, 3.5rem);
    align-items: start;
  }
  .hoc-reviews__heading {
    font-family: var(--hoc-font-heading);
    font-size: clamp(3rem, 6vw, 4.8rem);
    margin: 0 0 1rem;
    line-height: 1.05;
  }
  .hoc-reviews__summary {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin-bottom: 1.25rem;
  }
  .hoc-reviews__summary .hoc-stars { font-size: 1.5rem; }
  .hoc-reviews__summary-text {
    font-size: 1.3rem;
    color: rgba(var(--color-foreground), 0.8);
  }
  .hoc-reviews__actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-width: 240px;
  }
  .hoc-btn--sm { padding: 0.6em 1.3em; font-size: 1.2rem; }

  .hoc-reviews__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(0.75rem, 2vw, 1.25rem);
  }
  .hoc-reviews__cards:empty { display: none; }
  .hoc-review {
    margin: 0;
    background: rgba(var(--hoc-white), 0.7);
    border: 1px solid rgba(var(--hoc-navy), 0.12);
    border-radius: var(--hoc-radius-md);
    padding: clamp(1rem, 2vw, 1.5rem);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
  .hoc-review__text {
    margin: 0;
    font-size: 1.35rem;
    line-height: 1.5;
    color: rgb(var(--hoc-navy));
  }
  .hoc-review__author {
    font-style: normal;
    font-weight: 700;
    font-size: 1.25rem;
    color: rgba(var(--hoc-navy), 0.85);
    margin-top: auto;
  }

  .hoc-reviews__ugc {
    list-style: none;
    margin: clamp(1.5rem, 3vw, 2.5rem) auto 0;
    padding: 0;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, 1fr);
    gap: clamp(0.5rem, 1.2vw, 0.9rem);
  }
  .hoc-reviews__ugc:empty { display: none; }
  .hoc-reviews__ugc-item,
  .hoc-reviews__ugc-item a { display: block; line-height: 0; }
  .hoc-reviews__ugc-item img {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    border-radius: var(--hoc-radius-sm);
  }

  @media screen and (max-width: 989px) {
    .hoc-reviews__top { grid-template-columns: 1fr; }
    .hoc-reviews__actions { flex-direction: row; max-width: none; }
  }
  @media screen and (max-width: 749px) {
    .hoc-reviews__cards { grid-template-columns: 1fr; }
    .hoc-reviews__ugc {
      grid-auto-flow: column;
      grid-auto-columns: 42%;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
    }
  }
/* END_SECTION:hoc-reviews */

/* START_SECTION:product_showcase (INDEX:62) */
.hoc-shop { background-color: rgb(var(--color-background)); }
  .hoc-shop__heading {
    text-align: center;
    font-family: var(--hoc-font-script);
    color: var(--hoc-heading-color);
    font-size: clamp(2.75rem, 7vw, 4.5rem);
    margin: 0 0 clamp(1.5rem, 3vw, 2.5rem);
  }
  .hoc-shop__panel {
    position: relative;
    z-index: 1;
    background: rgb(var(--hoc-white));
    border: 2px solid rgb(var(--hoc-navy));
    border-radius: var(--hoc-radius-lg);
    box-shadow: var(--hoc-shadow);
    padding: clamp(1.25rem, 3vw, 2.25rem);
  }
  .hoc-shop__grid {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(1.25rem, 2.5vw, 2rem);
  }
  .hoc-shopcard {
    flex: 1 1 260px;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    background: rgb(var(--hoc-cream));
    border-radius: 28px;
    padding: 12px 12px 18px;
    box-shadow: 4px 4px 0 var(--hoc-accent, #ffd900);
  }
  .hoc-shopcard--wide { flex: 1.6 1 340px; }
  .hoc-shopcard__body { padding-inline: 6px; }

  .hoc-shopcard__media {
    position: relative;
    border-radius: var(--hoc-radius-md);
    overflow: hidden;
    background: rgb(var(--hoc-cream));
  }
  .hoc-shopcard__media img {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
  }
  /* Coming-soon card is wider — its media takes ALL spare height (body stays compact) */
  .hoc-shopcard--wide .hoc-shopcard__media {
    flex: 1 1 auto;
    min-height: 0;
    position: relative;
  }
  .hoc-shopcard--wide .hoc-shopcard__body { flex: 0 0 auto; }
  .hoc-shopcard--wide .hoc-shopcard__media img {
    position: absolute;
    inset: 0;
    aspect-ratio: auto;
  }
  .hoc-shopcard__ph { width: 100%; aspect-ratio: 3 / 4; background: rgba(var(--hoc-navy), 0.08); }
  .hoc-shopcard__badge {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--hoc-font-heading);
    font-weight: 700;
    font-size: clamp(1.4rem, 3vw, 2rem);
    color: rgb(var(--hoc-white));
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.45);
    background: rgba(var(--hoc-navy), 0.28);
    letter-spacing: 0.02em;
  }

  .hoc-shopcard__body { display: flex; flex-direction: column; gap: 0.75rem; flex: 1; }
  .hoc-shopcard__row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.6rem;
  }
  .hoc-shopcard__chip {
    width: 34px; height: 34px; border-radius: 50%; overflow: hidden; flex-shrink: 0;
    box-shadow: 0 0 0 2px rgb(var(--hoc-navy));
  }
  .hoc-shopcard__chip img { width: 100%; height: 100%; object-fit: cover; }
  .hoc-shopcard__titlewrap { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
  .hoc-shopcard__title {
    margin: 0;
    font-family: var(--hoc-font-body);
    font-weight: 800;
    font-size: 1.5rem;
    color: rgb(var(--hoc-navy));
  }
  .hoc-shopcard__sub { margin: 0; font-size: 1.2rem; color: rgba(var(--hoc-navy), 0.72); }
  .hoc-shopcard__right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    line-height: 1.25;
    flex: none;
  }
  .hoc-shopcard__pack { font-size: 1.05rem; color: rgba(var(--hoc-navy), 0.6); white-space: nowrap; }
  .hoc-shopcard__price { font-weight: 800; font-size: 1.5rem; color: rgb(var(--hoc-navy)); white-space: nowrap; }

  .hoc-shop .hoc-shopcard__cta,
  .hoc-shop .hoc-shopcard__join {
    margin-top: auto;
    font-family: var(--hoc-font-script);
    font-size: 1.85rem;
    font-weight: 400;
  }
  .hoc-shopcard__cta.is-disabled { opacity: 0.55; pointer-events: none; }

  .hoc-shopcard__form { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: auto; }
  .hoc-shopcard__email {
    flex: 1 1 160px;
    min-width: 0;
    border: 1px solid rgba(var(--hoc-navy), 0.35);
    border-radius: var(--hoc-radius-pill);
    padding: 0.7rem 1.1rem;
    font: inherit;
    color: rgb(var(--hoc-navy));
    background: rgb(var(--hoc-white));
  }
  .hoc-shopcard__email:focus-visible { outline: 2px solid rgb(var(--hoc-navy)); outline-offset: 1px; }
  .hoc-shopcard__success { margin: 0; font-weight: 700; color: rgb(var(--hoc-navy)); }

  @media screen and (max-width: 749px) {
    .hoc-shopcard, .hoc-shopcard--wide { flex: 1 1 100%; }
    /* stacked: give the wide card's media its own height again */
    .hoc-shopcard--wide .hoc-shopcard__media { flex: none; aspect-ratio: 16 / 11; }
  }
/* END_SECTION:product_showcase */

/* START_SECTION:section_one (INDEX:67) */
.hero-toast-sunrise-wrapper {
  background: #fff9f0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  padding: 0px 20px 160px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hero-toast-sunrise-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.hero-toast-sunrise-heading {
  font-family: 'Damion', cursive;
  font-size: 8rem;
  color: #2f2f75;
  margin-bottom: 32px;
  transform: rotate(-4deg);
  line-height: 1.2;
}

.hero-toast-sunrise-subtext {
  font-size: 2.25rem;
  line-height: 1.4;
  max-width: 600px;
  margin: 0 auto 40px auto;
  color: #1a1a1a;
}

.hero-toast-sunrise-button {
  padding: 8px 48px;
  font-size: 2rem;
  color: white;
  background-color: #2f2f75;
  border-radius: 8px;
  box-shadow: 0 4px 0 #d0d0d0;
  text-decoration: none;
  display: inline-block;
  /* Added these for general button safety, though specific mobile issues are handled below */
  position: relative;
  z-index: 5; /* A moderate z-index for general button visibility */
}

.hero-toast-sunrise-button-desktop {
  display: inline-block;
}

.hero-toast-sunrise-button-mobile {
  display: none; /* Hidden by default, shown on mobile */
  font-size: 1.8rem;
  padding: 10px 30px;
  margin: 0 auto;
  **pointer-events: auto; /* Crucial: Ensures the button responds to clicks */**
  **position: relative; /* Essential for z-index to work */**
  **z-index: 10; /* Ensures the mobile button is on top of other elements */**
}

.hero-toast-sunrise-images-desktop {
  position: absolute;
  top: 70%;
  left: 0;
  right: 0;
  width: 100%;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  **/* Removed 'pointer-events: none;' from this container. */**
  /* If you want the images *themselves* not to be clickable on desktop, apply pointer-events: none; directly to the <img> tags, not the parent div. */
  z-index: 1; /* Lower z-index than buttons */
}

.hero-toast-sunrise-image {
  max-height: 500px;
  height: auto;
}

.hero-toast-sunrise-mobile-image-row {
  display: none;
  width: 100%;
  justify-content: center;
  align-items: center;
  gap: 16px;
  margin-top: 40px;
  flex-wrap: nowrap;
  text-align: center;
  position: relative; /* Might need this for z-index context on images */
  z-index: 2; /* Keep images behind the button */
}

.hero-toast-sunrise-image-mobile-left,
.hero-toast-sunrise-image-mobile-right {
  margin: 0 auto;
  **pointer-events: none; /* Make mobile images not clickable if they overlap */**
}

.hero-toast-sunrise-image-mobile-left {
  width: 35vw;
  height: auto;
}

.hero-toast-sunrise-image-mobile-right {
  width: 55vw;
  height: auto;
}

.hero-toast-sunrise-mobile-button-wrapper {
  display: none; /* Hidden by default, shown on mobile */
  width: 100%;
  text-align: center;
  margin-top: -70px;
  **position: relative; /* Essential for z-index to work */**
  **z-index: 10; /* Ensures the wrapper is also on top */**
}

@media screen and (max-width: 768px) {
  .hero-toast-sunrise-wrapper {
    padding-bottom: 0px;
    padding-top: 60px;
  }

  .hero-toast-sunrise-inner {
    text-align: center;
  }

  .hero-toast-sunrise-heading {
    font-size: 4.5rem;
    padding: 0 16px;
    margin-top: -30px;
  }

  .hero-toast-sunrise-subtext {
    font-size: 2rem;
    padding: 0 16px;
    margin-bottom: 24px;
  }

  .hero-toast-sunrise-button-desktop {
    display: none !important;
  }

  .hero-toast-sunrise-button-mobile {
    display: inline-block !important;
    margin: -50px auto 0 auto;
    padding: 8px 48px;
    **z-index: 10; /* Ensure high z-index on mobile */**
    **position: relative; /* Ensure it stays positioned */**
  }

  .hero-toast-sunrise-images-desktop {
    display: none !important; /* Fully hide desktop images on mobile */
  }

  .hero-toast-sunrise-mobile-image-row {
    display: flex !important;
    position: relative;
    width: 100%;
    gap: 50px;
    **z-index: 2; /* Keep images behind button */**
  }

  .hero-toast-sunrise-mobile-button-wrapper {
    display: block;
    padding-bottom: 30px;
    **z-index: 10; /* Ensure high z-index for the wrapper */**
    **position: relative; /* Ensure it stays positioned */**
  }

  .hero-toast-sunrise-image-mobile-left {
    width: 35vw !important;
  }

  .hero-toast-sunrise-image-mobile-right {
    width: 55vw !important;
  }
}
/* END_SECTION:section_one */