/* ── Reset & Base ─────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  background-color: #F5F4F3;
  font-family: 'Work Sans', sans-serif;
  color: #1C1B1B;
  -webkit-font-smoothing: antialiased;
}


/* ══════════════════════════════════════════════════════════════
   JOURNEY SECTION — Before/After Slider (FIXED LAYOUT)
   Matches the "What to Expect" section style exactly
   Replace/update your journey-slider.css with this
   ══════════════════════════════════════════════════════════════ */

/* ── Left column: give it breathing room like the expect section ── */
.journey-left {
  padding-left: 0;        /* section already has padding */
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* ── Wrapper: constrained width, NOT full bleed ── */
.journey-ba-wrap {
  position: relative;
  width: 100%;
  max-width: 460px;       /* same feel as expect-image-wrap */
}

/* ── Each slide: hidden by default, shown when .active ── */
.journey-ba-slide {
  display: none;
  flex-direction: column;
  gap: 0;
  height: 90%;
}

.journey-ba-slide.active {
  display: flex;
}

/* ── Slide-in animation on transition ── */
.journey-ba-slide.entering {
  animation: journeySlideIn 0.4s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes journeySlideIn {
  from { opacity: 0; transform: translateX(14px); }
  to   { opacity: 1; transform: translateX(0);    }
}

/* ── Hide the old BEFORE/AFTER labels div above slider ── */
/* We use in-slider overlays like the expect section instead */
.journey-ba-labels {
  display: none;
}

/* ── The slider box: fixed height, contained ── */
.journey-ba-slider {
  width: 100%;
  height: 400px;
  overflow: hidden;
  position: relative;
  cursor: col-resize;
  user-select: none;
  -webkit-user-select: none;
  /* No border-radius — matches expect section style */
}

/* ── BEFORE / AFTER corner labels INSIDE the slider (like expect section) ── */
.journey-ba-slider .ba-arrow-left,
.journey-ba-slider .ba-arrow-right {
  position: absolute;
  bottom: 14px;
  font-family: 'Work Sans', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #F5F4F3;
  z-index: 4;
  pointer-events: none;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}

.journey-ba-slider .ba-arrow-left  { left: 14px;  z-index: 2; }
.journey-ba-slider .ba-arrow-right { right: 14px; z-index: 4; }

/* ── Caption below slider ── */
.journey-ba-caption {
  font-family: 'Work Sans', sans-serif;
  font-size: 12px;
  font-weight: 400;
  color: #1C1B1B;
  opacity: 0.5;
  margin-top: 8px;
  text-align: right;
  font-style: italic;
  letter-spacing: 0.02em;
  pointer-events: none;
}

/* ── Pagination dots — left-aligned, below caption ── */
.journey-ba-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 14px;
}

.journey-ba-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #C4BEBE;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background-color 0.25s ease, transform 0.25s ease;
  flex-shrink: 0;
}

.journey-ba-dot.active {
  background-color: #80130B;
  transform: scale(1.25);
}

.journey-ba-dot:hover:not(.active) {
  background-color: #999;
}

/* ══════════════════════════════════════════════════════════════
   OVERRIDE: Remove the old full-bleed journey-image styles
   so they don't conflict with the new slider
   ══════════════════════════════════════════════════════════════ */
.journey-cta{
    margin-top: 0px !important;
}

.journey-cta-wrapper{
    justify-content: normal !important;
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .journey-ba-wrap {
    max-width: 100%;
  }

  .journey-ba-slider {
    height: 260px;
  }

  .journey-ba-pagination {
    justify-content: center;
  }

  .journey-ba-dot {
    width: 9px;
    height: 9px;
  }
}

/* ── Product Section ──────────────────────────────────────── */
.product-section {
  width: 100%;
  min-height: 800px;
  display: flex;
  align-items: flex-start;
  background-color: #F5F4F3;
  overflow: hidden;
}

.product-layout {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 60px 80px;
  display: flex;
  align-items: flex-start;
  gap: 40px; /* increase slightly */
}

/* ── Left: Image ──────────────────────────────────────────── */
.product-image-col {
  align-items: flex-start;
  padding-top: 60px; /* pushes image down to match reference */
  width: 50%;
}

.product-layout {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 60px 80px;
  display: flex;
  align-items: flex-start;
  gap: 0px; /* increase slightly */
}

/* ── Left: Image ──────────────────────────────────────────── */
.product-image-col {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.product-img {
    width: 412px;
    height: 573px;
    object-fit: contain;
}

/* ── Right: Info ──────────────────────────────────────────── */
.product-info-col {
  flex: 1;
  min-width: 0;
  padding-top: 84px;
  align-self: flex-start;
}

.product-info-col p strong{
    font-size: 14px;
    font-weight: 600 !important;
}

/* Main Header — Libre Baskerville, 36px, -3%, 100% */
.product-title {
  font-family: 'Libre Baskerville', serif;
  font-size: 44px !important;
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 100%;
  color: #602622;
  margin-bottom: 8px;
  text-transform: capp
}

/* Sub-title — Work Sans Medium, 13px, uppercase, 10%, 140% */
.product-subtitle {
  font-family: 'Work Sans', sans-serif;
  font-size: 15px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  line-height: 140%;
  color: #1C1B1B;
  margin-bottom: 22px;
}

/* Body text — Work Sans, 16px, -3%, 140% */
.product-body {
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 140%;
  color: #1C1B1B;
  margin-bottom: 30px;
  margin-top: 30px;
}

/* Important note */
.product-note {
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 140%;
  color: #1C1B1B;
  margin-bottom: 20px;
}

.product-note strong {
  font-weight: 700;
  font-style: normal;
  color: #80130B;
  font-size: 16px !important;
}

/* Badges row */
.product-badges {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}

.product-badge {
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 140%;
  color: #1C1B1B;
}

.product-badge-dot {
  width: 6px;
  height: 6px;
  background-color: #1C1B1B;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.product-badge1 {
  display: flex;
  align-items: flex-start;
  flex-direction: coloumn;
  gap: 6px;
}

.product-badge,
.product-badge1 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.product-badge::before,
.product-badge1::before {
  content: '';
  width: 18px;
  height: 22px;
background: url('../images/prodimages/tick.svg') no-repeat center;
  background-size: contain;
  flex-shrink: 0;
}
/* Pricing */
.product-pricing {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 20px;
}

.product-pricing-label {
  font-family: 'Work Sans', sans-serif;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 140%;
  color: #1C1B1B;
}

.product-pricing-amount {
  font-family: 'Work Sans', sans-serif;
  font-size: 22px;
  font-weight: 600;
  color: #80130B;
  letter-spacing: -0.02em;
}

/* CTA Button — Work Sans, 16px, Capitalised, 10%, 140% */
.product-cta {
  width: 100%;
  padding: 15px 24px;
  background-color:product-cta transparent;
  border: 1.5px solid #000000;
  color: #1c1b1b;
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  line-height: 140%;
  cursor: pointer;
  text-align: center;
  transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
  display: block;
  margin-bottom: 0;
  
  & + .product-note {
  	margin: 30px 0 !important;
  }
}

/* Hover */
.product-cta:hover {
  background-color: #CCC4C4;
  color: #602622;
  border-color: #602622;
}

/* Selected */
.product-cta.active {
  background-color: #602622;
  color: #F5F4F3;
  border-color: #602622;
}

/* ── Accordion (FIXED) ───────────────────────────────────── */
.product-accordion {
  margin-top: 20px;
}

/* Clean single divider system */
.accordion-item {
  border-bottom: 1px solid rgba(0,0,0,0.15);
}

.accordion-item:first-child {
  border-top: none;
}

/* Trigger */
.accordion-trigger {
  width: 100%;
  background: none;
  border: none;
  padding: 18px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;

  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1C1B1B;

  transition: color 0.2s ease;
}

/* Active title color (matches your reference) */
.accordion-item.open .accordion-trigger {
  color: #80130B;
}

/* Chevron */
.accordion-chevron {
  width: 18px;
  height: 18px;
  transition: transform 0.25s ease;
}

.accordion-item.open .accordion-chevron {
  transform: rotate(180deg);
}

.accordion-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}

.accordion-item.open .accordion-body {
  max-height: 1000px; /* big enough buffer */
}

/* List */
.accordion-list {
  list-style: none;
  margin: 10px 0 0 0;
  padding: 0;
}

/* List items */
.accordion-list li {
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: -0.02em;
  color: #1C1B1B;

  margin-bottom: 10px;
  padding-left: 18px;
  position: relative;
}

/* Bullet style */
.accordion-list li::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 0;
  font-size: 16px;
}

/* Paragraph body */
.accordion-text {
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: -0.02em;
  margin-top: 10px;
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 960px) {
  .product-section {
    height: auto;
    padding: 60px 0;
  }

  .product-layout {
    flex-direction: column;
    align-items: center;
    gap: 40px;
    padding: 0 24px;
  }

  .product-image-col {
    justify-content: center;
  }

  .product-img {
    width: 100%;
    max-width: 360px;
    height: auto;
  }

  .product-info-col {
    width: 100%;
  }

  .product-title {
    font-size: 28px;
  }
}
/* ── Product page default header ─────────────────────────── */
.product-header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 50px;
  transition: opacity 0.3s ease;
}

.product-header .logo-container {
  position: static;
  transform: none;
}

.logo{
  width: 200px;
  height: 143px;
}



.product-header .menu-icon {
  position: absolute;
  top: 30px;
  left: 50px;
}

/* Push product section down so it doesn't sit under the header */
.product-section {
  padding-top: 120px;
}

/* ══════════════════════════════════════════════════════════
   SCIENCE BEHIND THE TREATMENT SECTION
   ══════════════════════════════════════════════════════════ */

.science-section {
  background-color: #F5F4F3;
  padding: 70px 0 80px;
  padding-top: 0px;
}

/* Container with padding for text/columns — but NOT for the timeline */
.science-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 60px;
}

.science-title {
  font-family: 'Libre Baskerville', serif;
  font-size: 30px;
  font-weight: 400;
  color: #602622;
  text-align: center;
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin-bottom: 10px;
}
.science-title em { font-style: italic; }

.science-subtitle {
  font-family: 'Work Sans', sans-serif;
  font-size: 20px;
  font-weight: 400;
  color: #1C1B1B;
  text-align: center;
  letter-spacing: -0.03em;
  margin-bottom: 50px;
}

/* ── Timeline — full bleed, edge to edge ──────────────────── */
.science-timeline-wrapper {
  width: 100%;
  padding: 0;
  margin-bottom: 70px;
}

.science-timeline {
  position: relative;
  width: 100%;
  height: 4px;
}

.science-seg {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 3px;
  background-image: radial-gradient(circle, #BEBEBE 1px, transparent 1px);
  background-size: 6px 3px;
  background-repeat: repeat-x;
  background-position: 0 center;
  z-index: 0;
}

.science-seg-full { left: 0; width: 100%; }

.science-fill {
  position: absolute;
  top: 50%;
  left: 0;
  width: 0%;
  height: 3px;
  transform: translateY(-50%);
  background-image: radial-gradient(circle, #80130B 1px, transparent 1px);
  background-size: 6px 3px;
  background-repeat: repeat-x;
  background-position: 0 center;
  z-index: 1;
  pointer-events: none;
}

/* Dots */
.science-dot {
  position: absolute;
  top: 50%;
  width: 18px;
  height: 18px;
  background-color: #BEBEBE;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  transition: all 0.3s ease;
}

.science-dot-1 { left: 20%; }
.science-dot-2 { left: 50%; }
.science-dot-3 { left: 80%; }

.science-dot.active {
  background-color: #80130B;
  box-shadow: 0 0 10px rgba(128, 19, 11, 0.6);
  filter: blur(3px);
  width: 28px;
  height: 28px;
  animation: pulseDot 1.5s infinite;
}

/* Previously visited dot — solid red, no blur, no animation */
.science-dot.visited {
  background-color: #80130B;
  box-shadow: none;
  filter: none;
  width: 18px;
  height: 18px;
  animation: none;
}

@keyframes pulseDot {
  0%   { box-shadow: 0 0 0 0 rgba(128, 19, 11, 0.7); }
  70%  { box-shadow: 0 0 0 15px rgba(128, 19, 11, 0); }
  100% { box-shadow: 0 0 0 0 rgba(128, 19, 11, 0); }
}

/* Dot titles */
.science-dot-title {
  position: absolute;
  top: 30px;
  transform: translateX(-50%);
  white-space: nowrap;
  text-align: center;
  font-family: 'Work Sans', sans-serif;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 1.8px;
  line-height: 1.4;
  text-transform: uppercase;
  color: #1C1B1B;
  transition: color 0.3s ease, font-size 0.3s ease;
}

.science-dot-title-1 { left: 20%; }
.science-dot-title-2 { left: 50%; }
.science-dot-title-3 { left: 80%; }

.science-dot-title.active {
  color: #80130B;
  font-size: 18px;
}

/* ── Two Columns ──────────────────────────────────────────── */
.science-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 25px;
  align-items: center;
  min-height: 380px;
}

.science-col {
  position: relative;
  min-height: 380px;
}

.science-item {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%) scale(0.97);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease, transform 0.5s ease, visibility 0.5s ease;
  pointer-events: none;
}

.science-item.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(-50%) scale(1);
  pointer-events: auto;
}

.science-img {
  width: 100%;
  max-width: 420px;
  height: auto;
  object-fit: contain;
  display: block;
}

.science-text-highlight {
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #80130B;
  letter-spacing: -0.03em;
  line-height: 1.5;
  margin-bottom: 20px;
}

.science-text-highlight span{
  font-size: 16px;
  font-weight: 400;
  color: #1C1B1B;
}

.science-text-body {
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #1C1B1B;
  letter-spacing: -0.03em;
  line-height: 1.6;
  margin-bottom: 14px;
}

/* Right col text — anchor to bottom of the column */
.science-right-col .science-item {
  top: auto;
  bottom: 0;
  transform: translateY(0) scale(0.97);
}

.science-right-col .science-item.active {
  transform: translateY(0) scale(1);
}

/* ── CTA — exact same size/style as .product-cta ─────────── */
.science-cta-wrapper {
  display: flex;
  justify-content: center;
  margin-top: 110px;
}

.science-cta {
  width: 465px;
  height: 57px;
  /* padding: 15px 24px; */
  background-color: transparent;
  border: 1.5px solid #1C1B1B;
  color: #1C1B1B;
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  line-height: 140%;
  cursor: pointer;
  transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
  display: block;
}


.science-cta:hover {
  background-color: #CCC4C4;
  color: #602622;
  border-color: #602622;
}

.science-cta.active {
  background-color: #602622;
  color: #F5F4F3;
  border-color: #602622;
}

@media (max-width: 768px) {
  .science-container { padding: 0 24px; }
  .science-title { font-size: 22px; }
  .science-columns { grid-template-columns: 1fr; min-height: auto; }
  .science-col { min-height: 280px; }
  .science-timeline-wrapper { margin-bottom: 80px; }
}
/* ── Journey CTA button ───────────────────────────────────── */
.journey-cta-wrapper {
  margin-top: 40px;
}

.journey-cta {
  width: 387px;
  height: 57px;
  padding: 0;
  background-color: transparent;
  border: 1.5px solid #1C1B1B;
  color: #1C1B1B;
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  cursor: pointer;
  transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
  display: block;
}

.journey-cta:hover {
  background-color: #CCC4C4;
  color: #602622;
  border-color: #602622;
}

.journey-cta.active {
  background-color: #602622;
  color: #F5F4F3;
  border-color: #602622;
}
/* ══════════════════════════════════════════════════════════
   WHAT TO EXPECT OVER TIME SECTION
   ══════════════════════════════════════════════════════════ */

.expect-section {
  background-color: #F5F4F3;
  padding: 80px 0 90px;
}

.expect-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 60px;
}

.expect-title {
  font-family: 'Libre Baskerville', serif;
  font-size: 30px;
  font-weight: 400;
  color: #602622;
  text-align: center;
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin-bottom: 55px;
}
.expect-title em { font-style: italic; }

/* ── 3-Column Grid ───────────────────────────────────────── */
.expect-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  align-items: start;
}

.expect-card {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ── Image area ─────────────────────────────────────────── */
.expect-image-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 14px;
}

.expect-image-wrap {
  width: 250px;
  height: 321px;
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
}

.expect-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Arrow + label below image — centered */
.expect-image-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  width: 187px;
}

.expect-arrow {
  width: 74px;
  height: 8px;
  display: block;
}

.expect-image-label span {
  font-family: 'Work Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.10em;
  line-height: 140%;
  text-transform: uppercase;
  color: #1C1B1B;
  text-align: center;
}

/* ── Text content ────────────────────────────────────────── */
.expect-card-content {
  padding: 18px 0 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.expect-phase-label {
  font-family: 'Work Sans', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #1C1B1B;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.expect-phase-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #1C1B1B;
  opacity: 0.25;
}

/* Phase bar — accordion trigger */
.expect-phase-bar {
  background-color: #CCC4C4;
  padding: 6px 12px;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  width: 100%;
  box-sizing: border-box;
}

.expect-phase-bar span {
  font-family: 'Work Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #602622;
}

.expect-card-body {
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.6;
  color: #1C1B1B;
  margin-bottom: 10px;
}

.expect-card-note {
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.6;
  color: #1C1B1B;
  font-style: italic;
}

/* ── Scroll reveal ───────────────────────────────────────── */
.expect-reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.expect-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Before / After Slider ───────────────────────────────── */
.ba-slider {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  cursor: col-resize;
  user-select: none;
  -webkit-user-select: none;
}

.ba-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.ba-before-img {
  z-index: 1;
  transform: scale(1) !important;
}

.ba-after-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  overflow: hidden;
  z-index: 2;
  /* NO transition — instant response on drag */
}

.ba-after-wrap img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;  /* will be overridden by JS to match slider full-width */
  height: 100%;
  object-fit: cover;
}

/* Divider line */
.ba-divider {
  position: absolute;
  top: 0;
  left: 50%;
  width: 2px;
  height: 100%;
  background: #F5F4F3;
  z-index: 3;
  transform: translateX(-50%);
  /* NO transition on divider itself — instant */
}

/* Handle knob */
.ba-handle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 36px;
  height: 36px;
  background: #F5F4F3;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
  transition: transform 0.2s ease;
}

.ba-slider:active .ba-handle,
.ba-slider.dragging .ba-handle {
  transform: translate(-50%, -50%) scale(1.12);
}

/* Month labels */
.ba-arrow-label {
  position: absolute;
  bottom: 10px;
  font-family: 'Work Sans', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #F5F4F3;
  z-index: 4;
  pointer-events: none;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
  opacity: 0;
}

.ba-arrow-left  { left: 10px; z-index: 1; }
.ba-arrow-right { right: 10px; z-index: 4; }

@media (max-width: 900px) {
  .expect-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin: 0 auto;
  }
  .expect-container { padding: 0 24px; }
  .expect-title { font-size: 22px; }
}


/* ══════════════════════════════════════════════════════════
   COMPARISON TABLE SECTION
   ══════════════════════════════════════════════════════════ */

.compare-section {
  background-color: #F5F4F3;
  padding: 90px 0 90px;
}

.compare-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 80px;
}

/* Main title — Libre Baskerville, 36px, -3%, 140%, #602622 */
.compare-title {
  font-family: 'Libre Baskerville', serif;
  font-size: 36px;
  font-weight: 400;
  color: #602622;
  text-align: center;
  letter-spacing: -0.03em;
  line-height: 140%;
  margin-bottom: 60px;
}

.compare-title em {
  font-style: italic;
}

.compare-table-wrap {
  width: 100%;
  position: relative;
}

/* Vertical divider lines — absolutely positioned */
.compare-vline {
  position: absolute;
  width: 1px;
  height: 270px;
  background-color: #000000;
  bottom: 0;
  pointer-events: none;
  z-index: 2;
  display: none;
}

/* After Meshkati col: label(340) + meshkati(148) = 488px from table left.
   Table is centered, so offset from wrapper = (wrapper - 932px) / 2 + 488px.
   Using calc with 50% trick since table is centered via margin:auto */
.compare-vline-1 {
  left: calc(50% - 932px/2 + 340px + 148px);
}

/* After Online Prescription col: 340 + 148 + 222 = 710px */
.compare-vline-2 {
  left: calc(50% - 932px/2 + 340px + 148px + 222px);
}

/* Use a wrapper div to house the table at exact 932px */
.compare-table {
  width: 932px;
  max-width: 100%;
  margin: 0 auto;
  border-collapse: collapse;
  table-layout: fixed;
}

col.col-label    { width: 340px; }
col.col-meshkati { width: 148px; }
col.col-mid      { width: 222px; }
col.col-last     { width: 222px; }

/* ── Header row ── */
.compare-header-row th {
  padding: 0 0 18px 0;
  vertical-align: bottom;
  border: none;
}

.compare-th-label {
  /* empty */
}

/* Work Sans Medium, 16px, 0% letter spacing, 130% line height */
.compare-th-meshkati {
  text-align: center;
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0em;
  line-height: 130%;
  color: #602622;
  text-transform: uppercase;
  padding-left: 10px;
  padding-right: 10px;
}

.compare-th-other {
  text-align: center;
  font-family: 'Work Sans', sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0em;
  line-height: 130%;
  color: #1C1B1B;
  padding-left: 10px;
  padding-right: 10px;
}

.compare-th-mid {
}

/* ── Body rows — no horizontal borders, only vertical dividers via box-shadow ── */
.compare-row td {
  padding: 0;
  border: none;
  height: 68px;
  vertical-align: middle;
  &.compare-td-mid {
     border-left: 1px solid #000;
     border-right: 1px solid #000;
     }
}

/* Row highlight on hover only */
.compare-row:hover td {
  background-color: #E2DDDD;
  transition: background-color 0.2s ease;
}

/* Label cell */
.compare-td-label {
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: #1C1B1B;
  letter-spacing: -0.02em;
  line-height: 1.4;
  /* padding-left: 0; */
  padding-left: 16px !important;
  vertical-align: middle;
}

/* Meshkati value cell */
.compare-td-check {
  text-align: center;
  vertical-align: middle;
}

/* Middle cell */
.compare-td-mid {
  text-align: center;
  vertical-align: middle;
}

/* Last cell — no borders */
.compare-td-last {
  text-align: center;
  vertical-align: middle;
}

/* Checkmark — dark red */
/* Tick / Cross SVG icons */
.compare-icon {
  width: 36px;
  height: 43px;
  display: inline-block;
  vertical-align: middle;
}

/* "Sometimes" / "Limited" */
.compare-text-val {
  font-family: 'Work Sans', sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: #5a5454;
  letter-spacing: 0em;
  line-height: 1;
}

@media (max-width: 768px) {
  .compare-container { padding: 0 24px; }
  .compare-title { font-size: 26px; margin-bottom: 36px; }
  .compare-table { width: 100%; }
  .compare-th-meshkati,
  .compare-th-other { font-size: 13px; }
  .compare-td-label { font-size: 12px; }
}
/* ── Expect Accordion ────────────────────────────────────── */
.expect-chevron {
  flex-shrink: 0;
  transition: transform 0.3s ease;
  color: #1C1B1B;
}

.expect-phase-bar.open .expect-chevron {
  transform: rotate(180deg);
}

.expect-accordion-body {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s ease, opacity 0.3s ease, padding-top 0.3s ease;
  padding-top: 0;
}

.expect-accordion-body.open {
  max-height: 600px;
  opacity: 1;
  padding-top: 14px;
}
/* ── Icon Features Section (below Journey) ───────────────── */
.product-features-section {
  background-color: #f0ecea;
  padding: 70px 100px 80px;
}

.product-features-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 40px;
  max-width: 1200px;
  margin: 0 auto;
}

.product-features-section .feature-item {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.product-features-section .feature-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 25px;
  height: 80px;
}

.product-features-section .feature-icon img {
  width: 75px;
  height: 75px;
  object-fit: contain;
}

.product-features-section .feature-title {
  font-family: 'Work Sans', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 1.5px;
  line-height: 1.3;
  text-transform: uppercase;
  margin-bottom: 15px;
  color: #1C1B1B;
  text-align: center;
}

.product-features-section .feature-description {
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
  color: #1C1B1B;
  text-align: justify;
  letter-spacing: -0.42px;
  max-width: 156px;
}

@media (max-width: 960px) {
  .product-features-section {
    padding: 50px 24px 60px;
  }
  .product-features-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
  .product-features-section .feature-icon {
    height: 70px;
    margin-bottom: 20px;
  }
  .product-features-section .feature-icon img {
    width: 50px;
    height: 50px;
  }
  .product-features-section .feature-title {
    font-size: 14px;
  }
  .product-features-section .feature-description {
    font-size: 13px;
    max-width: 100%;
  }
}
/* ── Footer ─────────────────────────────────────────────── */
.site-footer {
  position: relative;
  width: 100%;
  background-color: #4F1713;
  transform: translateY(0);
  will-change: auto;
}

/* .main sits above the sticky footer */
.main {
  position: relative;
  z-index: 1;
  background-color: #F5F4F3;
}

/* Each column starts invisible, slides up when footer is revealed */
.footer-col {
  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity   0.7s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.site-footer.footer-revealed .footer-col:nth-child(1) { opacity: 1 !important; transform: translateY(0); transition-delay: 0.15s; }
.site-footer.footer-revealed .footer-col:nth-child(2) { opacity: 1 !important; transform: translateY(0); transition-delay: 0.30s; }
.site-footer.footer-revealed .footer-col:nth-child(3) { opacity: 1 !important; transform: translateY(0); transition-delay: 0.45s; }
.site-footer.footer-revealed .footer-col:nth-child(4) { opacity: 1 !important; transform: translateY(0); transition-delay: 0.60s; }

/* Map fades in last */
.footer-map {
  opacity: 0;
  transform: scale(0.96);
  transition:
    opacity   0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.85s,
    transform 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.85s;
}

.site-footer.footer-revealed .footer-map {
  opacity: 1 !important;
  transform: scale(1);
}

.footer-inner {
  display: grid;
  grid-template-columns: 180px 270px 270px 360px;
  gap: 40px;
  align-items: start;
  width: 1200px;
  height: 364px;
  margin: 0 auto;
  padding: 52px 0;
  box-sizing: border-box;
}

/* Col 1 — Logo */
.footer-col-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.footer-logo {
    width: 306px;
    height: 173px;
    object-fit: contain;
}

.footer-brand-name {
  font-family: 'Work Sans', sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: #ffffff;
  text-align: center;
  margin: 0;
}

/* Groups inside cols */
.footer-group {
  margin-bottom: 28px;
}
.footer-group:last-child {
  margin-bottom: 0;
}

/* Small heading labels */
.footer-label {
  font-family: 'Work Sans', sans-serif;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.10em;
  line-height: 1.4;
  color: #ffffff;
  margin: 0 0 10px 0;
  text-transform: uppercase;
}

/* Body info text */
.footer-info {
  font-family: 'Work Sans', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: -0.03em;
  color: #ffffff;
  margin: 0;
  text-align: justify;
}

/* Footer links */
.footer-link,
.footer-nav-link,
.footer-social-link {
  color: #ffffff;
  text-decoration: none;
  display: inline-block;
  opacity: 1;
  transition: opacity 0.25s ease;
}

.footer-link:hover,
.footer-nav-link:hover {
  opacity: 0.7;
}

/* Social icons */
.footer-socials {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;
}

.footer-social-link {
  display: flex;
  align-items: center;
  transition: opacity 0.2s;
}
.footer-social-link:hover {
  opacity: 0.7;
}

/* Nav links */
.footer-links {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
}

.footer-nav-link {
  font-family: 'Work Sans', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: -0.03em;
  display: inline-block;
}

/* Map */
.footer-col-map {
  height: 100%;
}

.footer-map {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

/* Responsive */
@media (max-width: 1240px) {
  .footer-inner {
    width: 100%;
    height: auto;
    padding: 52px 32px;
  }
}

@media (max-width: 900px) {
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
    padding: 40px 24px;
  }
  .footer-col-logo {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: center;
    gap: 12px;
  }
  .footer-col-map {
    grid-column: 1 / -1;
    min-height: 200px;
  }
}

@media (max-width: 540px) {
  .footer-inner {
    grid-template-columns: 1fr;
    padding: 32px 20px;
  }
  .footer-col-logo {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* OPTIONS LAYOUT */
.product-options {
  display: flex;
  gap: 74px;
  margin: 35px 0 25px;
}

.option-group {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.option-divider {
  width: 1px;
  height: 80px;
  background: rgba(0,0,0,0.2);
  height: auto;
}

.option-title {
  font-size: 15px;
  font-weight: 500;
}

.radio-option input[type="radio"] {
  appearance: none;
  width: 16px;
  height: 16px;
  border: 1.5px solid #1C1B1B;
  border-radius: 50%;
  position: relative;
  cursor: pointer;
  margin-right: 8px;
}

.radio-option input[type="radio"]:checked {
  border-color: #80130B;
}

.radio-option input[type="radio"]:checked::after {
  content: '';
  width: 8px;
  height: 8px;
  background: #80130B;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.option-group.disabled input[type="radio"] {
  border-color: #D6D6D6;
}

.option-group.disabled input[type="radio"]:checked::after {
  background: #E3A5A1;
}

.option-subtext {
  font-size: 13px;
  color: #777;
  margin-left: 26px;
}

.product-price-dynamic {
  font-size: 26px;
  color: #80130B;
  font-weight: 600;
  padding: 12px 26px;
  border-radius: 12px;
}

/* Bold headings inside accordion */
.accordion-heading {
  font-weight: 600;
  margin: 10px 0 6px;
}

/* Remove default bullets ONLY for this version */
.accordion-list.clean li {
  list-style: none;
  padding-left: 0;
  display: flex;
  align-items: center;
  gap: 20px;
}

/* Kill the old pseudo bullet */
.accordion-list.clean li::before {
  display: none;
}
/* Disabled state (matches your first screenshot) */
.option-group.disabled {
  opacity: 1; /* keep text visible */
}

/* Grey text + radios */
.option-group.disabled .radio-option {
  color: #B9B9B9;
}

.option-group.disabled .radio-option input {
  accent-color: #E3A5A1; /* soft pink like your screenshot */
}

/* Subtext */
.option-group.disabled .option-subtext {
  color: #C7C7C7;
}

/* Title */
.option-group.disabled .option-title {
  color: #B9B9B9;
}
/* Wrapper for spacing */
.product-price-wrapper {
  margin: 28px 0 20px;
}

/* Price pill */
.product-price-dynamic {
  display: inline-block;
  background: #e6e1df;
  color: #8b1e14;
  font-family: 'Work Sans', sans-serif;
  font-weight: 500;
  font-size: 22px;
  padding: 14px 28px;
  border-radius: 14px;
  letter-spacing: 0.3px;
}

/* Secondary text */
.product-price-dynamic span {
  font-weight: 400;
  opacity: 0.9;
  margin-left: 6px;
}

.product-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.product-badge::before,
.product-badge1::before {
  transform: translateY(-2px);
}

















/*responsive.css */

    /* ============================================================
       responsive.css — Product Page Mobile (max-width: 768px)
       Desktop styles live in product.css — DO NOT touch desktop here
       ============================================================ */
    
    
    /* ── Product Page Header ────────────────────────────────────── */
    @media (max-width: 768px) {
      .product-header {
        padding: 14px 20px;
      }
    
      .product-header .menu-icon {
        top: 18px;
        left: 20px;
      }
    
      .product-header .logo {
        width: 80px;
        height: auto;
      }
    }
    
    
    /* ── Sticky Header ───────────────────────────────────────────── */
    @media (max-width: 768px) {
      .sticky-header {
        padding: 10px 16px;
        height: auto;
      }
    
      .sticky-logo {
        width: 70px;
        height: auto;
      }
    
      .sticky-button {
        padding: 7px 12px;
        font-size: 0.8rem;
      }
    
      .sticky-header-right {
        gap: 6px;
      }
    }
    
    
    /* ── Sub Menu ────────────────────────────────────────────────── */
    @media (max-width: 768px) {
      .submenu {
        width: 80%;
        left: -80%;
      }
    }
    
    
    /* ══════════════════════════════════════════════════════════════
       PRODUCT SECTION — Mobile 2-col layout
       ══════════════════════════════════════════════════════════════ */
    /* ══════════════════════════════════════════════════════════════
   PRODUCT SECTION — Mobile (FINAL FIX)
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ===== LAYOUT ===== */
  .product-layout {
    display: grid;
    grid-template-columns: 42% 1fr;
    column-gap: 14px;
    padding: 16px;
    align-items: start;
  }

  /* ===== IMAGE (LEFT) ===== */

  .product-image-col {
    float: left;
    width: 42%;
    margin-right: 10px;
  }

  .product-img {
    width: 100%;
    max-width: 200px;
    height: auto;
    object-fit: contain;
    display: block;
  }

  .product-note {
    clear: both;
  }

}

  /* ===== RIGHT SIDE ===== */
  .product-title {
    grid-column: 2;
    grid-row: 1;
    line-height: 1.2;
    margin-bottom: 4px;
  }

  .product-subtitle {
    grid-column: 2;
    grid-row: 2;
    font-size: 13px;
    margin-bottom: 8px;
    letter-spacing: 0.08em;
  }

  .product-badges {
    grid-column: 2;
    grid-row: 3;
    display: flex;
    flex-direction: column;
    gap: 6px;
  }

  .product-badge {
    display: flex;
    gap: 6px;
  }


  /* ===== BELOW HERO ===== */
  .product-note {
    grid-column: 1 / -1;
    margin-top: 16px;
    line-height: 1.55;
  }

  .product-options {
    grid-column: 1 / -1;
    margin-top: 14px;
  }

/* ===== RADIO INLINE LAYOUT ===== */

.option-group {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 24px; /* vertical + horizontal spacing */
  &:first-of-type {
  	position: relative;
	&::before {
    	content: "";
        display: block;
        width: 0;
        height: 100%;
        border-left: 1px solid #000;
        position: absolute;
        top: 0;
        right: -36px;
    }
  }
}

.option-title {
  width: 100%;
  margin-bottom: 6px;
}

.radio-option {
  display: flex;
  align-items: start;
  gap: 8px;

  width: auto;          /* important */
  margin-bottom: 0;     /* kill stacking */
}

  .option-subtext {
    font-size: 11px;
    margin-top: 4px;
    padding-left: 22px;
  }

  /* ===== PRICE ===== */
  .product-price-dynamic {
    grid-column: 1 / -1;
    width: fit-content;
    margin: 16px auto 0;
    padding: 10px 18px;
    font-size: 16px;
    background-color: #D9D4D2;
    border-radius: 14px;
    color: #80130B;
  }

  /* ===== CTA ===== */
  .product-cta {
    grid-column: 1 / -1;
    width: 100%;
    margin-top: 16px;
    font-size: 16px;
    padding: 13px 24px;
  }

    /* ══════════════════════════════════════════════════════════════
       SCIENCE SECTION — Mobile Vertical Timeline
       ══════════════════════════════════════════════════════════════ */
    
    /* Hide mobile div on desktop */
    .science-mobile-vertical { display: none; }
    
    @media (max-width: 768px) {
    
      /* ── Kill GSAP pin-spacer on mobile ──
         GSAP injects a .pin-spacer wrapper with a huge inline height.
         Force it to collapse so it doesn't create blank space.      */
      .pin-spacer {
        position: static  !important;
        height:   auto    !important;
        overflow: visible !important;
        display:  block   !important;
      }
    
      #scienceStickyContent {
        position: static !important;
        transform: none  !important;
        width:     auto  !important;
        height:    auto  !important;
        top:       auto  !important;
      }
    
      /* Hide desktop horizontal timeline + 2-col layout */
      .science-timeline-wrapper,
      .science-columns,
      .science-cta-wrapper {
        display: none !important;
      }
    
      .science-section {
        padding: 40px 0 50px;
        & > .science-container {
            padding: 10px 20px;
            z-index: 1111;
            position: sticky;
            background: #F5F4F3;
            margin-bottom: 6px;
            top: 0px;        
        }
      }
    
      .science-container {
        padding: 0 20px;     
      }
    
      .science-title {
        font-size: 18px;
        margin-bottom: 0;
      }
    
      .science-subtitle {
        display: none;
      }
    
      /* Show the mobile vertical wrapper */
      .science-mobile-vertical {
        display: flex;
        flex-direction: row;
        position: relative;
        padding-left: 36px;
        padding-bottom: 20px;
        margin: 0 20px;              /* matches section padding */
        background-color: #F5F4F3;
      }
    }
    
    
    /* ── Left timeline column ─────────────────────────────────── */
    .smob-timeline-left {
      position: absolute;
      left: 8px;
      top: 0;
      bottom: 0;
      width: 20px;
    }
    
    /* Grey dotted base line */
    .smob-vline-base {
      position: absolute;
      top: 0;
      left: 50%;
      width: 3px;
      transform: translateX(-50%);
      background-image: radial-gradient(circle, #BEBEBE 1px, transparent 1px);
      background-size: 3px 6px;
      background-repeat: repeat-y;
      background-position: center top;
      z-index: 0;
    }
    
    /* Red fill — height driven by JS scroll */
    .smob-vline-fill {
      position: absolute;
      top: 6px;
      left: 50%;
      width: 3px;
      height: 0%;
      transform: translateX(-50%);
      background-image: radial-gradient(circle, #80130B 1px, transparent 1px);
      background-size: 3px 6px;
      background-repeat: repeat-y;
      background-position: center top;
      z-index: 1;
    }
    
    /* Dots */
    .smob-dot {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      width: 18px;
      height: 18px;
      border-radius: 50%;
      background-color: #BEBEBE;
      border: 2px solid #F5F4F3;
      z-index: 3;
      cursor: pointer;
      transition: background-color 0.3s ease, width 0.3s ease, height 0.3s ease,
                  box-shadow 0.3s ease, filter 0.3s ease;
    }
    
    .smob-dot.visited {
      background-color: #80130B;
      box-shadow: none;
      filter: none;
      width: 18px;
      height: 18px;
      animation: none;
    }
    
    .smob-dot.active {
      background-color: #80130B;
      box-shadow: 0 0 10px rgba(128, 19, 11, 0.6);
      filter: blur(3px);
      width: 28px;
      height: 28px;
      animation: pulseDot 1.5s infinite;   /* keyframe already in product.css */
    }
    
    
    /* ── States container ──────────────────────────────────────── */
    .smob-states {
      flex: 1;
      min-width: 0;
    }
    
    .smob-state-block {
      padding-bottom: 44px;
    }
    .smob-state-block:last-child {
      padding-bottom: 0;
    }
    
    /* ── Accordion: content collapsed by default ── */
    .smob-state-content {
      display: grid;
      grid-template-rows: 0fr;
      overflow: hidden;
      transition: grid-template-rows 0.35s ease;
    }
    
    /* Inner div — min-height:0 required for grid trick */
    .smob-state-content-inner {
      min-height: 0;
      overflow: hidden;
    }
    
    .smob-state-block.smob-open .smob-state-content {
      grid-template-rows: 1fr;
    }
    
    /* State label */
    .smob-state-title {
      font-family: 'Work Sans', sans-serif;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: #1C1B1B;
      margin-bottom: 14px;
      line-height: 1.3;
      transition: color 0.3s;
    }
    .smob-state-title.active {
      color: #80130B;
      font-size: 13px;
    }
    
    /* Image inside state */
    .smob-state-img {
      width: 100%;
      height: auto;
      object-fit: contain;
      display: block;
      margin-bottom: 16px;
      border-radius: 2px;
    }
    
    /* Text — reuse existing science text styles, just resize */
    .smob-state-content .science-text-highlight {
      font-size: 12px;
      margin-bottom: 10px;
    }
    
    .smob-state-content .science-text-body {
      font-size: 12px;
      line-height: 1.55;
      margin-bottom: 8px;
    }
    
    
    
    /* ══════════════════════════════════════════════════════════════
       JOURNEY SECTION — Mobile
       ══════════════════════════════════════════════════════════════ */
    
    /* Hide mobile title — desktop layout used on all screen sizes */
    .journey-title-mobile { display: none; }
    .journey-title-desktop { display: flex; }
    
    
    /* ══════════════════════════════════════════════════════════════
       FEATURES — Hide grid on mobile, show rolling banner
       ══════════════════════════════════════════════════════════════ */
    
    /* Rolling section hidden on desktop */
    .features-rolling-section { display: none; }
    
    @media (max-width: 768px) {
      /* Hide the static grid */
      .product-features-section { display: none !important; }
    
      /* Show rolling banner section */
      .features-rolling-section {
        display: block;
        background-color: #f0ecea;
        padding: 40px 0;
        overflow: hidden;
      }
    
      .features-rolling-banner {
        overflow: hidden;
        width: 100%;
      }
    
      .science-text-highlight span{
      font-size: 12px;
      font-weight: 400;
      color: #1C1B1B;
    }
    
    
      .features-rolling-track {
        display: flex;
        flex-direction: row;
        gap: 0;
        width: max-content;
        animation: rollFeatures 28s linear infinite;
      }
    
      .features-rolling-track .feature-item {
        width: 160px;
        flex-shrink: 0;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        padding: 0 12px;
      }
    
      .features-rolling-track .feature-icon {
        height: 56px;
        margin-bottom: 14px;
      }
    
      .features-rolling-track .feature-icon img {
        width: 50px;
        height: 50px;
        object-fit: contain;
      }
    
      .features-rolling-track .feature-title {
        font-size: 13px;
        letter-spacing: 1px;
        margin-bottom: 8px;
        line-height: 1.3;
      }
    
      .features-rolling-track .feature-description {
        display: none;
      }
    
      @keyframes rollFeatures {
        0%   { transform: translateX(0); }
        100% { transform: translateX(-50%); } /* -50% = one full set width */
      }
    }
    
    
    /* ══════════════════════════════════════════════════════════════
       FAQ SECTION — Mobile
       ══════════════════════════════════════════════════════════════ */
    
    .faq-title-mobile-text { display: none; }
    .faq-title-desktop     { display: inline; }
    
    @media (max-width: 768px) {
      .faq-title-desktop     { display: none !important; }
      .faq-title-mobile-text { display: inline !important; }
    
      .faq-section {
        padding: 50px 20px 60px;
      }
    
      .faq-container {
        display: flex;
        flex-direction: column;
        gap: 28px;
      }
    
      .faq-left {
        position: static;
        padding-top: 0;
      }
    
      .faq-title {
        font-size: 20px;
        padding-left: 0;
        letter-spacing: -0.5px;
      }
    
      .faq-question h3 {
        font-size: 16px;
        letter-spacing: 0.8px;
      }
    
      .faq-answer p {
        font-size: 18px;
      }
    }
    
    
    /* ══════════════════════════════════════════════════════════════
       FOOTER — Mobile
       ══════════════════════════════════════════════════════════════ */
    
    @media (max-width: 768px) {
      .footer-inner {
        grid-template-columns: 1fr !important;
        width: 100% !important;
        height: auto !important;
        padding: 36px 20px !important;
        gap: 28px !important;
      }
    
      .footer-col-logo {
        grid-column: auto !important;
        flex-direction: column;
        align-items: flex-start;
      }
    
      .footer-logo {
        width: 140px;
        height: auto;
      }
    
      .footer-col-map {
        grid-column: auto !important;
        min-height: 200px;
        height: 200px;
      }
    
      .footer-label {
        font-size: 11px;
      }
    
      .footer-info,
      .footer-nav-link {
        font-size: 12px;
      }
    }
    
    
    /* ══════════════════════════════════════════════════════════════
       "A DIFFERENT STANDARD OF CARE" TABLE — Mobile overflow fix
       ══════════════════════════════════════════════════════════════ */
    
    @media (max-width: 768px) {
      .compare-section {
        padding: 40px 0 50px;
        overflow: hidden;
      }
    
      .compare-container {
        padding: 0 16px;
      }
    
      .compare-title {
        font-size: 18px;
        margin-bottom: 28px;
        letter-spacing: -0.5px;
      }
    
      /* Wrap table in scrollable container */
      .compare-table-wrap {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        /* Hide scrollbar visually but keep it functional */
        scrollbar-width: none;
      }
      .compare-table-wrap::-webkit-scrollbar {
        display: none;
      }
    
      .compare-table {
        min-width: 480px;  /* forces horizontal scroll before collapsing */
        width: 100%;
      }
    
      /* Vertical divider lines — keep them but position relative to table */
      .compare-vline {
        display: none; /* hide abs-positioned lines, table borders handle dividers */
      }
    
      .compare-th {
        font-size: 11px;
        padding: 10px 8px;
        letter-spacing: 0.05em;
      }
    
      .compare-td-label {
        font-size: 11px !important;
        padding-left: 8px !important;
        line-height: 1.35;
      }
    
      .compare-icon {
        width: 22px;
        height: 28px;
      }
    
      .compare-text-val {
        font-size: 12px;
      }
    
      .compare-row td {
        height: 52px;
      }
    }
    
    
    /* ═══════════════════════════════════════════════════════════
       JOURNEY SECTION — Mobile (same layout as desktop)
       ═══════════════════════════════════════════════════════════ */
    @media (max-width: 768px) {
      /* Prevent GSAP from keeping items invisible on mobile */
      .journey-item {
        opacity: 1 !important;
      }
    
      .journey-cta {
        font-size: 12px;
        width: 100%;
      }
    }
    
    /* ═══════════════════════════════════════════════════════════
       ROLLING BANNER — Mobile only (hidden on desktop)
       ═══════════════════════════════════════════════════════════ */
    .features-rolling-banner {
      display: none;
    }
    
    @media (max-width: 768px) {
      /* Hide the static grid on mobile */
      .product-features-grid {
        display: none !important;
      }
    
      .features-rolling-banner {
        display: block;
        overflow: hidden;
        width: 100%;
        padding: 40px 0;
        background-color: #F5F4F3;
        position: relative;
      }
    
      /* Fade edges */
      .features-rolling-banner::before,
      .features-rolling-banner::after {
        content: '';
        position: absolute;
        top: 0; bottom: 0;
        width: 60px;
        z-index: 2;
        pointer-events: none;
      }
      .features-rolling-banner::before {
        left: 0;
        background: linear-gradient(to right, #F5F4F3, transparent);
      }
      .features-rolling-banner::after {
        right: 0;
        background: linear-gradient(to left, #F5F4F3, transparent);
      }
    
      .features-rolling-track {
        display: flex;
        gap: 10px;
        width: max-content;
        animation: rollingScroll 22s linear infinite;
      }
    
      .features-rolling-track .feature-item {
        flex: 0 0 100px !important;
        width: 100px;
      }
    
      @keyframes rollingScroll {
        0%   { transform: translateX(0); }
        100% { transform: translateX(-50%); }
      }
    }
    
    /* ═══════════════════════════════════════════════════════════
       COMPARE TABLE — Mobile (A Different Standard of Care)
       ═══════════════════════════════════════════════════════════ */
    @media (max-width: 768px) {
      .compare-section {
        padding: 10px 0 48px;
      }
    
      .compare-container {
        padding: 0 20px;
        overflow: visible;
        z-index: 1111;
    	background: #F5F4F3;
        padding: 10px 20px;
      }
    
      .compare-title {
        font-size: 18px;
        margin-bottom: 0;
        letter-spacing: -0.5px;
      }
    
      /* No scroll — full width fit */
      .compare-table-wrap {
        overflow: visible;
        position: relative;
        padding: 0 20px;
      }
    
      /* Hide absolute vlines — use border instead on mobile */
      .compare-vline { display: none; }
    
      /* Full 100% width, percentage-based columns */
      .compare-table {
        width: 100%;
        min-width: unset;
        table-layout: fixed;
      }
    
      col.col-label    { width: 36%; }
      col.col-meshkati { width: 20%; }
      col.col-mid      { width: 22%; }
      col.col-last     { width: 22%; }
    
      /* Vertical dividers via border on cells */
      .compare-td-check,
      .compare-td-mid,
      .compare-th-meshkati {
        border-left: 1px solid #000;
      }
    
      .compare-th-meshkati,
      .compare-th-other {
        font-size: 11px;
        padding-left: 4px;
        padding-right: 4px;
        line-height: 1.3;
      }
    
      .compare-th-meshkati {
        font-size: 11px;
        color: #80130B;
        padding-bottom: 14px;
      }
    
      .compare-td-label {
        font-size: 11px;
        padding-left: 4px !important;
        padding-right: 4px;
        line-height: 1.4;
      }
    
      .compare-row td {
        height: auto;
        padding-top: 14px;
        padding-bottom: 14px;
      }
    
      .compare-icon {
        width: 20px;
        height: 24px;
      }
    
      .compare-text-val {
        font-size: 12px;
      }
    }
    
    /* ═══════════════════════════════════════════════════════════
       FAQ SECTION — Mobile
       ═══════════════════════════════════════════════════════════ */
    @media (max-width: 768px) {
      .faq-section {
        padding: 56px 24px;
      }
    
      .faq-container {
        display: block;
      }
    
      .faq-left {
        position: static;
        padding-top: 0;
        margin-bottom: 36px;
      }
    
      /* Show single-line mobile title, hide stacked desktop title */
      .faq-title-desktop      { display: none; }
      .faq-title-mobile-text  { display: block; }
    
      .faq-title {
        font-size: 18px;
        padding-left: 0;
        letter-spacing: -0.8px;
        line-height: 1.2;
      }
    
      .faq-question h3 {
        font-size: 13px;
        letter-spacing: 1px;
      }
    
      .faq-answer p {
        font-size: 12px;
      }
    }
    
    /* Desktop: hide mobile FAQ title text, show stacked */
    @media (min-width: 769px) {
      .faq-title-mobile-text { display: none; }
      .faq-title-desktop     { display: block; }
    }
    
    /* ═══════════════════════════════════════════════════════════
       FOOTER — Mobile
       ═══════════════════════════════════════════════════════════ */
    @media (max-width: 768px) {
      .site-footer {
        padding: 0;
      }
    
      .footer-inner {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 32px !important;
        padding: 40px 20px !important;
        height: auto !important;
        width: 100% !important;
      }
    
      .footer-col-logo {
        grid-column: 1 / -1;
        flex-direction: row;
        align-items: center;
        gap: 12px;
      }
    
      .footer-col-map {
        grid-column: 1 / -1;
        min-height: 200px;
      }
    
      .footer-label {
        font-size: 11px;
      }
    
      .footer-info {
        font-size: 12px;
      }
    }
    
    @media (max-width: 420px) {
      .footer-inner {
        grid-template-columns: 1fr !important;
      }
      .footer-col-logo {
        flex-direction: column;
        align-items: flex-start;
      }
    }
    
    
    /* ═══════════════════════════════════════════════════════════
       EXPECT SECTION — Mobile Vertical Timeline (emob-)
       ═══════════════════════════════════════════════════════════ */
    .expect-mobile-vertical { display: none; }
    
    @media (max-width: 768px) {
      /* Hide desktop grid on mobile */
      .expect-grid { display: none !important; }
    
      .expect-section {
        padding: 56px 0 48px;
      }
    
      .expect-container {
        z-index: 1111;
        position: sticky;
    	background: #F5F4F3;
        margin-bottom: 36px;
        top: 98px;
        padding: 10px;
      }
    
      .expect-title {
        font-size: 18px;
        padding: 0 24px;
        margin-bottom: 0;
      }
    
      .expect-mobile-vertical {
        display: flex;
        flex-direction: row;
        padding-left: 36px;
        padding-right: 20px;
        padding-bottom: 48px;
        position: relative;
      }
    
      /* ── Left timeline column ── */
      .emob-timeline-left {
        position: relative;
        width: 18px;
        flex-shrink: 0;
        margin-right: 20px;
      }
    
      .emob-vline-base {
        position: absolute;
        left: 7px;
        top: 0;
        width: 3px;
        background-color: transparent;
        background-image: radial-gradient(circle, #BEBEBE 1px, transparent 1px);
        background-size: 3px 6px;
        background-repeat: repeat-y;
      }
    
      .emob-vline-fill {
        position: absolute;
        left: 7px;
        top: 0;
        width: 3px;
        height: 0;
        background-color: transparent;
        background-image: radial-gradient(circle, #80130B 1px, transparent 1px);
        background-size: 3px 6px;
        background-repeat: repeat-y;
        transition: height 0.15s linear;
      }
    
      .emob-dot {
        position: absolute;
        left: 0;
        width: 18px;
        height: 18px;
        border-radius: 50%;
        background-color: #ccc;
        transition: background-color 0.3s ease, filter 0.3s ease;
      }
    
      .emob-dot.visited {
        background-color: #602622;
        filter: none;
      }
    
      .emob-dot.active {
        background-color: #80130B;
        filter: blur(2px);
        animation: pulseDot 1.5s infinite;
      }
    
      /* ── States column ── */
      .emob-states {
        flex: 1;
        display: flex;
        flex-direction: column;
      }
    
      .emob-state-block {
        margin-bottom: 28px;
      }
    
      .emob-state-block:last-child { margin-bottom: 0; }
    
      /* Time label (e.g. DAY 1 – MONTH 2) */
      .emob-time-label {
        font-family: 'Work Sans', sans-serif;
        font-size: 11px;
        font-weight: 500;
        letter-spacing: 1.2px;
        color: #999;
        text-transform: uppercase;
        margin-bottom: 4px;
      }
    
      /* Phase title — clickable header */
      .emob-state-title {
        font-family: 'Work Sans', sans-serif;
        font-size: 11px;
        font-weight: 500;
        letter-spacing: 1.2px;
        text-transform: uppercase;
        color: #aaa;
        margin-bottom: 0;
        transition: color 0.3s ease, font-size 0.2s ease;
        padding-bottom: 10px;
      }
    
      .emob-state-title.active {
        color: #602622;
        font-size: 12px;
        font-weight: 600;
      }
    
      .emob-phase-label {
        display: inline-block;
        background-color: #CCC4C4;
        padding: 5px 10px;
        margin-bottom: 12px;
        font-family: 'Work Sans', sans-serif;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: #602622;
      }
    
      /* Accordion content — grid trick */
      .emob-state-content {
        display: grid;
        grid-template-rows: 0fr;
        overflow: hidden;
        transition: grid-template-rows 0.35s ease;
      }
    
      .emob-state-content-inner {
        min-height: 0;
        overflow: hidden;
      }
    
      .emob-state-block.emob-open .emob-state-content {
        grid-template-rows: 1fr;
      }
    
      .emob-state-img {
        width: 75%;
        height: 260px;
        border-radius: 4px;
        margin-bottom: 14px;
        display: block;
        object-fit: cover;
        object-position: center top;
      }
    
      .emob-slider {
        width: 75% !important;
        height: 260px !important;
        border-radius: 4px;
        overflow: hidden;
        display: block;
        margin-bottom: 14px;
        cursor: col-resize;
      }
    
      .emob-state-content .expect-card-body {
        font-family: 'Work Sans', sans-serif;
        font-size: 12px;
        font-weight: 400;
        line-height: 1.5;
        color: #1C1B1B;
        margin-bottom: 8px;
        letter-spacing: -0.3px;
      }
      .emob-state-content .expect-card-note {
        font-family: 'Work Sans', sans-serif;
        font-size: 12px;
        color: #666;
        line-height: 1.5;
        font-style: italic;
        margin-bottom: 8px;
      }
    
      .card-button{
        border: 1px solid black !important;
      }
    
       /* journey-line-container height set dynamically by JS */
       /* .journey-line-container {
        height: calc(100% - 55px);
      } */
    }

/* ── OPTIONS (mobile placement) ───────────────── */
.product-options {
  width: 100%;
  margin-top: 16px;
}

.option-divider {
  display: none;
}

.product-price-dynamic {
  font-size: 18px;
  margin-top: 12px;
}

/* spacing fix */
.option-group {
  margin-bottom: 16px;
  flex: 1;
}

/* Stack radios tighter */
.radio-option {
  font-size: 16px;
  margin-bottom: 6px;
  gap: 0;
  span:last-child {
  	flex: 1;
  }
  
  &.disabled input[type="radio"] {
  	border-color: #928F8F;
    background: #BEBEBE;
  }
}

.option-title {
  font-size: 18px;
  margin-bottom: 8px;
}

.option-subtext {
  font-size: 11px;
}

/* Price below options */
.product-price-dynamic {
  grid-column: 1 / -1;
  grid-row: 7;
  font-size: 18px;
  margin-top: 10px;
}
    
/* ── MOBILE FIX: hero alignment + flow ───────────────── */

@media (max-width: 768px) {
    
    .product-title {
  grid-column: 2;
  grid-row: 1;
}

.product-subtitle {
  grid-column: 2;
  grid-row: 2;
}

.product-badges {
  grid-column: 2;
  grid-row: 3;
}

.product-note {
  grid-column: 1 / -1;
  grid-row: 4;
}

.product-options {
  grid-column: 1 / -1;
  grid-row: 5;
}

.product-price-dynamic {
  grid-column: 1 / -1;
  grid-row: 6;
}

.product-cta {
  grid-column: 1 / -1;
  grid-row: 7;
}

  /* Keep image clean and proportional */
.product-img {
  width: 100%;
  height: auto;
  max-height: 240px;
  object-fit: contain;
}

  /* Tighten right column spacing */
  .product-title {
    font-size: 22px !important;
    margin-bottom: 4px;
  }

  .product-subtitle {
    margin-bottom: 6px;
  }

  .product-badges {
    gap: 4px;
    margin-bottom: 10px;
  }

  /* Description should sit clean below */
  .product-note {
    margin-top: 12px;
    margin-bottom: 14px;
    padding: 0;
  }

  /* OPTIONS — stack cleanly under description */
  .product-options {
    margin-top: 10px;
  }

  .option-group {
    margin-bottom: 6px;
  }

  /* Fix radio spacing */
  .radio-option {
    margin-bottom: 6px;
    display: flex;
    align-items: flex-start;
    gap: 8px;
  }

  /* Subtext tighter */
  .option-subtext {
    margin-top: 4px;
    padding-left: 22px;
  }

  /* ── PRICE (centered pill like design) ── */
  .product-price-dynamic {
    display: block;
    width: fit-content;
    margin: 16px auto 0;
    padding: 10px 18px;

    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.02em;

    background-color: #D9D4D2;
    border-radius: 14px;
    color: #80130B;
    text-align: center;
  }

  /* CTA spacing */
  .product-cta {
    margin-top: 16px;
  }
  
  .product-title,
.product-subtitle,
.product-badges {
  grid-column: 2;
}

}
@media (max-width: 768px) {

  /* RESET ANY BROKEN GRID BEHAVIOUR */
  .product-layout {
    display: block !important;
  }

  /* ===== HERO (TOP SECTION) ===== */
  .product-image-col {
    float: left;
    width: 100%;
    margin-bottom: 30px;
    margin-right: 5px;
  }

  .product-img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }

  /* RIGHT SIDE CONTENT WRAPS NEXT TO IMAGE */
  .product-title,
  .product-subtitle,
  .product-badges {
    display: block;
  }

  /* Ensure text flows beside image */
  .product-info-col {
    display: block !important;
  }

  /* CLEAR AFTER HERO */
  .product-note {
    clear: both;
    margin-top: 5px;
  }

  /* EVERYTHING BELOW FULL WIDTH */
  .product-options,
  .product-price-dynamic,
  .product-cta,
  .product-accordion {
    clear: both;
    width: 100%;
  }

}
@media (max-width: 768px) {

  .product-options {
    display: block !important;
  }

  .option-group {
    width: 100%;
    margin-bottom: 18px;
  }

  .option-title {
    display: block;
    margin-bottom: 8px;
  }

}
@media (max-width: 768px) {

  /* ===== FORCE IMAGE SIZE ===== */
  .product-image-col {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
  }

  .product-img {
    width: 100% !important;
    max-width: 210px !important;
    height: auto !important;
    object-fit: contain !important;
  }


  /* ===== FORCE RIGHT SIDE ALIGNMENT ===== */
    .product-title,
  .product-subtitle {
    margin-top: 0 !important;
  }
  

  /* ===== FIX FONT THICKNESS ===== */
  .product-title {
    font-weight: 500 !important;
  }

  .product-subtitle,
  .product-note {
    font-weight: 400 !important;
  }


}
@media (max-width: 768px) {

  .product-layout {
    margin-top: -70px !important;
  }

}
@media (max-width: 768px) {
/* ===== UNIVERSAL TICK FIX ===== */

.product-badge::before,
.product-badge1::before {
  content: none !important;   /* kill badge pseudo ticks only */
}


/* ===== CONSISTENT LIST LAYOUT ===== */

.accordion-list li,
.product-info-col .accordion-list.clean li {
  display: flex;
  align-items: flex-start;
  gap: 10px;

  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 6px;
}


/* ===== SINGLE SOURCE OF TRUTH (REAL TICK) ===== */

.product-badge {
  width: 16px;
  height: 16px;
  flex-shrink: 0;

  background: url('../images/prodimages/tick.svg') no-repeat center;
  background-size: contain;

  margin-top: 3px;   /* THIS aligns with first line of text */
}
}

@media (max-width: 768px) {

  .radio-option input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 14px;
    height: 14px;
    border: 1.5px solid #1C1B1B;
    border-radius: 50%;
    position: relative;
    cursor: pointer;
    margin-top: 2px;
  }

  .radio-option input[type="radio"]:checked {
    border-color: #80130B;
  }

  .radio-option input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 6px;
    height: 6px;
    background-color: #80130B;
    border-radius: 50%;
    transform: translate(-50%, -50%);
  }

}

/* ===== FIX: ACCORDION LIST TICKS ALIGNMENT ===== */

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


.journey-left {
  position: relative;
  overflow: hidden;
  background-color: #F5F4F3 !important;
  flex-direction: row;
  justify-content: flex-end;
}

  .journey-image {
    width: 79% !important;
    height: 80% !important;
    object-fit: cover;
    object-position: center;
    display: block;
    position: absolute;
    top: 50% !important;
    left: 50% !important;
    transform: scale(1.08);
    transition: transform 1.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform;
    transform: translate(-50%, -50%) !important;
}

.accordion-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;

  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 6px;
  padding-left: 15px;
  position: relative;
}

/* Bullet */
.accordion-list li::before {
  content: '•';
  font-size: 16px;
  line-height: 1.4;
  flex-shrink: 0;
  color: #1C1B1B;
}
/* ===== FIX: SECOND ACCORDION (DUAL APPROACH) ===== */

.product-badges div {
  display: flex;
  align-items: flex-start;
  gap: 10px;

  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 6px;
}

.product-badges .product-badge {
  width: 14px;
  height: 14px;
  flex-shrink: 0;

  background: url('prodimages/tick.svg') no-repeat center;
  background-size: contain;

  margin-top: 4px; /* aligns with text */
}

/* ===== TIGHTEN HERO SPACING ===== */

.product-badges {
  margin-bottom: 6px; /* was too loose */
}

.product-info-col .accordion-list.clean {
  margin-bottom: 6px !important;
  padding: 10px 12px;
  
}

.product-note {
  margin-top: 6px !important;
}

/* ===== FORCE RADIO INLINE (OVERRIDE EVERYTHING) ===== */

@media (max-width: 768px) {
    
      .journey-image {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    object-position: center;
    display: block;
    position: absolute;
    top: 50% !important;
    left: 50% !important;
    transform: scale(1.08);
    transition: transform 1.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform;
    transform: translate(-50%, -50%) !important;
}

  .product-options .option-group {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 10px 20px !important;
  }

  .product-options .option-title {
    width: 100% !important;
    margin-bottom: 6px !important;
  }

  .product-options .radio-option {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;

    width: auto !important;
    margin-bottom: 0 !important;
  }

}

/* ===== TREATMENT SAME AS FREQUENCY ===== */
@media (max-width: 768px) {

  /* make both options sit on one row */
  .product-options .option-group:first-of-type {
    display: flex;
    align-items: center;
    gap: 20px;
  }

  /* keep radio + label inline */
  .product-options .option-group:first-of-type .radio-option {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 0;
  }

  /* force "(Capsules + Serum)" under Dual Approach */
  .product-options .option-group:first-of-type .radio-option em {
    display: block;
    margin-left: 5px; /* aligns under text */
    margin-top:5px;
    font-size: 12px;
  }

}

@media (max-width: 768px) {

  #frequencyGroup {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 20px;
  }

  #frequencyGroup .radio-option {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
  }


/* THIS fixes it */
  #frequencyGroup .option-subtext {
    flex-basis: 100%; /* forces new row */
    margin-top: 4px;
    padding-left: 61%; /* aligns under "Subscribe" text */
	li {
    	font-size: 10px;
    	padding-left: 8px;
		line-height: 1.2;
        position: relative;
        color: #1C1B1B;
        &::before {
        	content: "";
        }
    }
    
    li:before {
        content: "";
        display: block;
        width: 2px;
        height: 2px;
        border-radius: 50%;
        background: #1C1B1B;
        position: absolute;
        top: 50%;
        left: 0;
        transform: translateY(-50%);
	}
}

}
@media (max-width: 768px) {

  .product-options .option-group:first-of-type {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start;
    gap: 24px;
  }

  .product-options .option-group:first-of-type .radio-option {
    display: flex !important;
    align-items: center;
    gap: 8px;
    white-space: nowrap; /* KEY — prevents breaking */
    flex: 1;
  }

  /* Force the subtext under Dual Approach only */
  .product-options .option-group:second-of-type .radio-option em {
    display: block;
    white-space: normal;
    margin-left: -4px;
    margin-top: 2px;
  }

}
/* ===== TREATMENT + FREQUENCY — EXACT 2-COLUMN LAYOUT ===== */
@media (max-width: 768px) {

  /* BOTH groups behave the same */
  .product-options .option-group {
    column-gap: 24px;
    row-gap: 6px;
    align-items: start;
  }

  /* Each radio = inline */
  .radio-option {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
  }

  .radio-option input[type="radio"] {
    margin: 0;
  }

}
@media (max-width: 768px) {
  .product-options {
  	.option-group,
    .option-group:first-of-type {
        display: flex !important;
        justify-content: space-between;
        align-items: center;
        border: 1px solid #80130B;
        border-radius: 2px;
        padding: 8px 12px;
        margin-bottom: 7px;
      }
  }

}

/* ══════════════════════════════════════════════════════════════
   FIX — "Cancel anytime" sits directly below Subscribe radio,
   indented to align with the label text (not the radio button).
   ══════════════════════════════════════════════════════════════ */

/* The subtext list sits right after the Subscribe radio label.
   We need it indented past the radio dot + gap so it reads as
   a sub-note under "Subscribe", not a floating separate item. */
.option-subtext {
  list-style: none;
  padding: 0;
  margin: 0;          /* no top gap — flush under the radio above */
  margin-left: 26px;  /* aligns with label text start */
}

.option-subtext li {
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.02em;
  padding-left: 14px;
  position: relative;
  color: #1C1B1B;
  &::before {
  	content: "•";
    position: absolute;
    top: 50%;
    left: 4px;
    transform: translateY(-50%);
  }
}

/* Delivery every 2 months item — slightly more visual separation
   from the radio rows above, but Cancel anytime right beneath it */
.option-subtext li + li {
  margin-top: 2px;
}

/* Subscribe sub-note: tuck it directly under the Subscribe radio row */
.option-subtext.subscribe-subtext {
  margin-top: -16px;   /* pull up flush under Subscribe label */
  margin-bottom: 8px;
  padding-left: 26px; /* indent to align with label text */
  margin-left: 0;
}


























/* ══════════════════════════════════════════════════════════════
   MOBILE OVERRIDES (MAX-WIDTH: 768PX)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    /* Titles and Section Headers */
    .product-title {
        font-size: 22px !important;
        letter-spacing: -0.01em !important;
        font-weight: 400 !important;
    }

    .science-title, 
    .journey-section .section-title, 
    .expect-section .section-title {
        font-size: 24px !important;
        white-space: pre-line !important; /* Supports line breaks */
    }

    /* FAQ Title Specific Size */
    .faq-section h2 {
        font-size: 18px !important;
    }

    /* Subtitles */
    .product-subtitle {
        font-size: 12px !important;
        font-weight: 400 !important;
        letter-spacing: 0.05em !important;
    }

    /* Body and Description */
    .product-body {
        font-size: 14px !important;
        letter-spacing: -0.03em !important;
        font-weight: 400 !important;
        margin: 5px 0 15px;
    }

    /* Lists and Badges */
    .product-badges .product-badge {
        font-size: 13px !important;
        font-weight: 500 !important;
        letter-spacing: 0.03em !important;
        line-height: 1.2 !important;
    }
    
    .product-info-col p strong {
    	font-size: 14px !important;
        font-weight: 700 !important;
        letter-spacing: 0.03em !important;
        line-height: 1.2 !important;
    }

    /* Important Note */
    .product-note {
        font-size: 14px !important;
        letter-spacing: -0.01em !important;
        line-height: 1.3 !important;
        font-weight: 400 !important;
    }

    .product-note strong {
        font-size: 14px !important;
        font-weight: 700 !important;
    }

    /* Pricing */
    .product-pricing-label {
        font-size: 13px !important;
        letter-spacing: 0.03em !important;
        font-weight: 500 !important;
        text-transform: uppercase;
    }

    .product-pricing-amount {
        font-size: 16px !important;
        letter-spacing: 0 !important;
        font-weight: 600 !important;
    }

    /* Buttons */
    .product-cta, .product-cta a {
        font-size: 12px !important;
        letter-spacing: 0.10em !important;
    }

    /* Accordion */
    .accordion-trigger span, 
    .accordion-text, 
    .accordion-list li {
        font-size: 14px !important;
    }

    /* Journey Timeline Specifics */
    .journey-item .journey-title {
        font-size: 13px !important;
    }

    .journey-item.active .journey-title {
        font-size: 14px !important;
    }

    .journey-item .journey-desc {
        font-size: 14px !important;
    }

    /* Journey Dot States */
    .journey-dot {
        background-color: #BEBEBE !important; /* Unvisited: Grey */
        transition: all 0.3s ease !important;
    }

    .journey-item.visited .journey-dot {
        background-color: #80130B !important; /* Visited: Red */
    }

    .journey-item.active .journey-dot {
        background-color: #80130B !important;
        animation: pulseRed 1.5s infinite !important; /* Active: Pulsating Red */
    }

    @keyframes pulseRed {
        0% { box-shadow: 0 0 0 0 rgba(128, 19, 11, 0.7); }
        70% { box-shadow: 0 0 0 10px rgba(128, 19, 11, 0); }
        100% { box-shadow: 0 0 0 0 rgba(128, 19, 11, 0); }
    }

    /* Different Standard of Care Table */
    .standard-care-table .meshkati-pharmacy { font-size: 11px !important; }
    .standard-care-table .online-platforms, 
    .standard-care-table .traditional-clinic { font-size: 9px !important; }
    .standard-care-table .row-label { font-size: 12px !important; }
    .standard-care-table .status-text { font-size: 10px !important; }

    /* FAQ Question/Answer */
    .faq-question h3 { font-size: 11px !important; }
    .faq-answer p { font-size: 10px !important; }
}

.sm {
	display: none !important;
}

.md {
	display: block !important;
}

@media (max-width: 768px) {
	.sm {
    	display: block !important;
    }
    
    .md {
    	display: none !important;
    }
}


@media (max-width: 768px) {
	.product-section.is-second {
    	padding-bottom: 56px;
        
		.product-info-col .accordion-list.clean {
    	    padding: 10px 31px;
            strong {
            	font-weight: 500;
            }
            
            li {
            	margin-bottom: 0px;
            }
    	}
        
        .product-info-col .accordion-body .accordion-list.clean  {
        	padding: 10px 20px;
            ul li span {
            	flex: 1;
            }
        }
        
        .product-badge {
        	margin-top: 0;
        }
        
        .product-note {
        	font-size: 14px;
            letter-spacing: -.03em;
            line-height: 1.3;
        }
        
        .product-options {
        	margin-top: 29px;
            font-size: 13px;

            .option-group,
            .option-group:first-of-type {
            	gap: 10px 20px !important;
                gap: 2px !important;
                align-items: flex-start;
                
                .radio-option {
                	gap: 0px !important;
                    align-items: flex-start !important;
                    font-size: 13px;
                    letter-spacing: -.03em;
                    
                    em {
                    	margin-left: 0;
				        margin-top: 0;
                    }
                }
                
                span {
                	line-height: 18px;
                }
            }
        }
        
        .option-title {
        	font-size: 12px;
        	text-transform: uppercase;	
        }
        
        .radio-option input[type="radio"] {
        	width: 18px;
            height: 18px;
            margin-right: 5px;
            
            &:checked::after {
            	width: 14px;
                height: 14px;
            }
        }
        
        .accordion-trigger {
            padding: 11px 0;
            font-size: 14px;
            letter-spacing: 0;
        }
    }
    
    .science-section.is-second {
    	& > .science-container {
        	margin-bottom: 38px;
        }
        
        .science-mobile-vertical {
        	margin: 0 9px;
            padding-left: 36px;
        }
    
    	.smob-state-title {
            padding-left: 24px;
            padding-top: 7px;
			&.active {
            	font-size: 15px;
            }
        }
    }
    
    .treatment-journey.is-second {
    	.journey-item {
        	margin-bottom: 28px;
        }
        
        .journey-title {
        	font-size: 24px;
        }
        
    	.journey-step-title {
        	font-size: 14px;
            padding-top: 4px;
            margin-bottom: 5px;
        }
        
        .journey-content {
        	padding-top: 0;
        }
        
        .ba-slider {
        	height: auto;
            padding-top: 123%;
        }
        
        .journey-ba-wrap {
        	padding: 0 36px;
        }
        
        .journey-title {
        	width: 100%;
            text-align: center;
            line-height: 0.6;
            & > .char-wrap {
            	display: none;
            }
        }
        
        .journey-left {
            justify-content: flex-end;
            height: auto;
            flex-wrap: wrap;
        }
        
        .journey-ba-slide {
        	height: 90%;
        }
        
        .journey-ba-pagination {
        	justify-content: center;
            margin-top: 23px;
        }
    }
    
    .compare-section.is-second {
      	&.is-pink {
        	background-color: #F0ECEA;
            .compare-title,
            .compare-container {
            	background-color: #F0ECEA;
            }
            
            & + .faq-section {
            	background: #F5F4F3;
                .faq-title {
                	background: #F5F4F3;
                }
            }
      	}
    	.compare-container {
           	padding-left: 0;
        	padding-right: 0;
        }
        
    	.compare-title {
        	font-size: 24px;
            margin-bottom: 18px;
        }
        
        .compare-table-wrap {
        	padding: 0 12px;
        }

		.compare-table {
        	table-layout: auto;
        }

        .compare-header-row {
        	th {
                font-size: 9px;
                padding: 0 6px 32px;
                &.compare-th-meshkati {
                	font-size: 11px;
        		}
            }
        }
        
        tbody tr:first-of-type {
        	background: #EAE3E3;
        }
        
        .compare-row td {
        	padding: 6px 10px !important;
            &.compare-td-mid {
            	border-left: 1px solid #000;
                border-right: 1px solid #000;
            }
        }
        
        col.col-label {
        	width: 30%;
        }
        
        .compare-text-val {
        	font-size: 10px;
        }

		.compare-td-label {
        	font-size: 12px !important;
        }
    }
    
    .faq-section.is-second {
    	background: #F5F4F3;
        padding-left: 35px;
        padding-right: 35px;
        
        .faq-title {
        	background: #F5F4F3;
            font-size: 24px !important;
            text-align: left !important;
            margin-bottom: 24px;
        }
        
        h3 {
        	font-size: 13px !important;
            letter-spacing: .05em;
            min-height: 40px;
            padding: 10px 0;
            display: flex;
            align-items: center;
        }
        
        .faq-item {
        	border-bottom: 1px solid #000;
            padding-bottom: 0;
            
            &.active {
            	padding-bottom: 11px;
                .faq-anser {
                    padding-top: 0;
                }
            }

        }
        
        .faq-question {
        	border-bottom: none;
            padding-bottom: 0;
            &::after {
            	display: none;
            }
        }
        
        .faq-answer {
        	padding-top: 0;
        }
    }
    
    .site-footer.footer-revealed {
    	.footer-inner {
        	grid-template-columns: 1fr 1fr !important;
        }
    
        .footer-col:nth-child(4),
        .footer-bottom {
            display: none;
        }
    }
}
.cta-button,
.science-cta,
.journey-cta,
.product-cta,
.card-button,
.np-btn {
  pointer-events: auto;
}

@media (max-width: 768px) {
  .science-section {
    position: relative;
  }

 