/* ── Fotona 4D Laser Page ── */

/* ─ Hero ─ */
.f4-hero {
  padding-top: 112px;
  background: var(--cream);
}
.f4-hero__wrap {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  min-height: 540px;
  max-width: 1440px;
  margin: 0 auto;
  width: 100%;
}
.f4-hero__img-col {
  background: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 40px 64px 120px;
}
.f4-hero__img {
  width: 100%;
  max-height: 460px;
  object-fit: contain;
  object-position: center bottom;
  border-radius: 20px;
  background: #fff;
  display: block;
}
.f4-hero__content {
  background: var(--cream);
  padding: 80px 120px 80px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.f4-hero__h {
  font-family: var(--ff-h);
  font-size: 46px;
  font-weight: 500;
  color: #332106;
  line-height: 1.15;
  margin: 0 0 20px;
  text-wrap: balance;
}
.f4-hero__h em { font-style: italic; color: #226040; }
.f4-hero__sub {
  font-family: var(--ff-b);
  font-size: 17px;
  color: #555;
  line-height: 1.7;
  margin: 0 0 36px;
}
.f4-hero__feats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.f4-hero__feat,
.f4-hero__feats li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--ff-b);
  font-size: 14px;
  color: #332106;
  font-weight: 600;
}
.f4-hero__feat svg { flex-shrink: 0; color: #226040; }
.f4-hero__feats li::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #226040;
  flex-shrink: 0;
}

/* ─ Container ─ */
.f4-container {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 120px;
  box-sizing: border-box;
}

/* ─ Sections ─ */
.f4-section { padding: 100px 0; }
.f4-section--cream { background: var(--cream); }
.f4-section--white { background: #fff; position: relative; overflow: hidden; }
.f4-section--white::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 50%;
  height: 100%;
  background-image: url('/wp-content/uploads/2026/05/image-13-Traced-2.svg');
  background-size: auto 100%;
  background-repeat: no-repeat;
  background-position: left top;
  pointer-events: none;
  z-index: 0;
}
.f4-section--white > .f4-container { position: relative; z-index: 1; }

/* ─ Typography ─ */
.f4-label {
  font-family: var(--ff-b);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #226040;
  display: block;
  margin-bottom: 14px;
}
.f4-h {
  font-family: var(--ff-h);
  font-size: 44px;
  font-weight: 600;
  color: #332106;
  line-height: 1.2;
  margin: 0 0 24px;
}
.f4-h em { font-style: italic; color: #226040; font-weight: 400; }
.f4-h--center { text-align: center; margin-left: auto; margin-right: auto; max-width: 680px; }
.f4-text {
  font-family: var(--ff-b);
  font-size: 16px;
  color: #332106;
  line-height: 1.75;
  margin: 0 0 28px;
}

/* ─ Two-column layout ─ */
.f4-two-col {
  display: flex;
  flex-direction: row;
  gap: 80px;
  align-items: flex-start;
}
.f4-two-col__left { flex: 0 0 38%; max-width: 38%; }
.f4-two-col__right { flex: 1; }

/* ─ Modes header (heading left / text right) ─ */
.f4-modes-hdr {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
  margin-bottom: 48px;
}
.f4-modes-hdr__right { padding-top: 8px; }

/* ─ Modes grid — 4 columns ─ */
.f4-modes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.fotona-page .f4-modes-grid {
  grid-template-columns: repeat(4, 1fr);
}
.f4-mode-card {
  background: var(--cream);
  border-radius: 24px;
  padding: 40px 32px;
}
.f4-mode-card__num {
  display: block;
  font-family: var(--ff-b);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(34,96,64,.55);
  line-height: 1;
  margin: 0 0 20px;
}
.f4-mode-card__name {
  font-family: var(--ff-h);
  font-size: 20px;
  font-weight: 600;
  color: #226040;
  margin: 0 0 14px;
  line-height: 1.3;
}

.f4-mode-card__icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(34,96,64,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  color: #226040;
  flex-shrink: 0;
}
.f4-mode-card__icon svg { width: 20px; height: 20px; }
.f4-mode-card__text {
  font-family: var(--ff-b);
  font-size: 15px;
  color: #332106;
  line-height: 1.65;
  margin: 0;
}

/* ─ Checklist ─ */
.f4-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
}
.f4-checklist li {
  font-family: var(--ff-b);
  font-size: 15px;
  color: #332106;
  padding: 10px 0 10px 28px;
  position: relative;
  border-bottom: 1px solid rgba(51,33,6,0.07);
  line-height: 1.5;
}
.f4-checklist li:last-child { border-bottom: none; }
.f4-checklist li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 16px;
  width: 16px;
  height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 12' fill='none'%3E%3Cpath d='M1 6L6 11L15 1' stroke='%23226040' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}
.f4-checklist--two-col {
  columns: 2;
  gap: 0;
}

/* ─ Treats grid ─ */
.f4-treats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.f4-treats-grid--1col { grid-template-columns: 1fr; }
.f4-treat-card {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #fff;
  border-radius: 10px;
  padding: 14px 16px;
}
.f4-treat-card__icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #226040;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.f4-treat-card__icon svg { width: 12px; height: 12px; }
.f4-treat-card__text {
  font-family: var(--ff-b);
  font-size: 14px;
  font-weight: 500;
  color: #332106;
  line-height: 1.4;
}

/* ─ Card contrast: auto-adjust bg when card matches section ─ */
.f4-section--white .f4-treat-card { background: var(--cream); }
.f4-section--cream .f4-mode-card  { background: #fff; }
.f4-section--white .f4-step        { background: var(--cream); border-color: rgba(51,33,6,.08); }
.f4-section--cream .f4-step        { background: #fff; border-color: rgba(51,33,6,.08); }

/* ─ Benefits (dark section) ─ */
.f4-benefits {
  position: relative;
  padding: 100px 0;
  overflow: hidden;
}
.f4-benefits__bg {
  position: absolute;
  inset: 0;
  background-image: url('/wp-content/uploads/2026/05/view-from-rejuvenation-beautiful-woman-enjoying-cosmetology-procedures-beauty-salon-dermatology-hands-blue-glows-healthcare-therapy-botox-1.webp');
  background-size: cover;
  background-position: center;
}
.f4-benefits__overlay {
  position: absolute;
  inset: 0;
  background: rgba(24,45,30,.82);
}
.f4-benefits__hdr {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: end;
  margin-bottom: 64px;
}
.f4-benefits__sub {
  font-family: var(--ff-b);
  font-size: 16px;
  color: rgba(255,255,255,.75);
  line-height: 1.7;
  margin: 0;
  align-self: end;
}
.f4-ben-cards {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 120px;
  box-sizing: border-box;
}
.f4-ben-card {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: 32px 28px;
  backdrop-filter: blur(4px);
}
.f4-ben-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  color: #fff;
}
.f4-ben-card__icon svg { width: 22px; height: 22px; }
.f4-ben-card__title {
  font-family: var(--ff-h);
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 10px;
  line-height: 1.3;
}
.f4-ben-card__text {
  font-family: var(--ff-b);
  font-size: 14px;
  color: rgba(255,255,255,.7);
  line-height: 1.65;
  margin: 0;
}

/* ─ Steps / What to Expect ─ */
.f4-steps {
  display: grid;
  grid-template-columns: repeat(var(--steps, 3), 1fr);
  gap: 28px;
  margin-top: 48px;
}
@media (max-width: 1024px) { .f4-steps { grid-template-columns: repeat(3, 1fr); } }
.f4-step {
  background: var(--cream);
  border-radius: 20px;
  padding: 36px 32px;
}
.f4-step__num {
  display: block;
  font-family: var(--ff-h);
  font-size: 32px;
  font-weight: 600;
  color: rgba(34,96,64,.2);
  line-height: 1;
  margin: 0 0 16px;
}
.f4-step__title {
  font-family: var(--ff-h);
  font-size: 18px;
  font-weight: 600;
  color: #226040;
  margin: 0 0 12px;
  line-height: 1.3;
}
.f4-step__text {
  font-family: var(--ff-b);
  font-size: 14px;
  color: #555;
  line-height: 1.65;
  margin: 0;
}

/* ─ Timeline ─ */
.f4-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.f4-tl-item {
  padding: 0 0 32px 24px;
  border-left: 2px solid #226040;
  position: relative;
}
.f4-tl-item:last-child { padding-bottom: 0; }
.f4-tl-item::before {
  content: '';
  position: absolute;
  left: -5px;
  top: 4px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #226040;
}
/* Remove tail above first dot */
.f4-tl-item:first-child {
  border-left-color: transparent;
}
.f4-tl-item:first-child::after {
  content: '';
  position: absolute;
  left: -2px;
  top: 8px;
  bottom: 0;
  width: 2px;
  background: #226040;
}
.f4-tl-item__label {
  font-family: var(--ff-b);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #226040;
  display: block;
  margin-bottom: 4px;
}
.f4-tl-item__title {
  font-family: var(--ff-h);
  font-size: 18px;
  font-weight: 600;
  color: #332106;
  margin: 0 0 8px;
  line-height: 1.4;
}
.f4-tl-item__text {
  font-family: var(--ff-b);
  font-size: 14px;
  color: #555;
  line-height: 1.65;
  margin: 0;
}

/* ─ FAQ ─ */
.f4-faq {
  max-width: 820px;
  margin-top: 48px;
}
.f4-faq__item {
  border-bottom: 1px solid rgba(51,33,6,0.12);
}
.f4-faq__item:first-child { border-top: 1px solid rgba(51,33,6,0.12); }
.f4-faq__btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: none;
  border: none;
  padding: 24px 0;
  cursor: pointer;
  text-align: left;
}
.f4-faq__q {
  font-family: var(--ff-h);
  font-size: 18px;
  font-weight: 500;
  color: var(--heading);
  line-height: 1.4;
  transition: color 0.25s ease;
}
.f4-faq__item.is-open .f4-faq__q { color: var(--green); }
.f4-faq__chevron {
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
.f4-faq__item.is-open .f4-faq__chevron { transform: rotate(180deg); }
.f4-faq__body { padding-bottom: 20px; }
.f4-faq__a {
  font-family: var(--ff-b);
  font-size: 15px;
  color: #555;
  line-height: 1.75;
  margin: 0;
}


/* 50/50 equal columns */
.f4-two-col--feat .f4-two-col__left,
.f4-two-col--feat .f4-two-col__right { flex: 1 1 0; max-width: none; }
/* ─ Two-col treats variant ─ */
.f4-two-col--treats .f4-two-col__left { flex: 0 0 35%; max-width: 35%; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .f4-container { padding: 0 80px; }
  .f4-hero__wrap { grid-template-columns: 1fr 1fr; min-height: 480px; }
  .f4-hero__img-col { padding: 48px 24px 64px 80px; }
  .f4-hero__content { padding: 60px 80px 60px 40px; }
  .f4-hero__h { font-size: 38px; }
  .f4-h { font-size: 38px; }
  .f4-section { padding: 80px 0; }
  .f4-benefits { padding: 80px 0; }
  .f4-benefits__hdr { grid-template-columns: 1fr; }
  .f4-ben-cards { padding: 0 80px; grid-template-columns: repeat(4, 1fr); }
  .f4-two-col { gap: 48px; }
  .f4-two-col__left { flex: 0 0 40%; max-width: 40%; }
  .f4-modes-hdr { gap: 40px; }
}
@media (max-width: 900px) {
  .f4-container { padding: 0 40px; }
  .f4-hero__wrap { grid-template-columns: 1fr 1fr; min-height: 480px; }
  .f4-hero__img-col { padding: 32px 20px 40px 40px; }
  .f4-hero__content { padding: 48px 40px 48px 32px; }
  .f4-hero__h { font-size: 34px; }
  .f4-h { font-size: 32px; }
  .f4-section { padding: 72px 0; }
  .f4-benefits { padding: 72px 0; }
  .f4-two-col { flex-direction: column; gap: 36px; }
  .f4-two-col__left { flex: none; max-width: none; }
  .f4-two-col--treats .f4-two-col__left { flex: none; max-width: none; }
  .f4-two-col--feat .f4-two-col__left,
  .f4-two-col--feat .f4-two-col__right { flex: none; max-width: none; width: 100%; }
  .f4-modes-hdr { grid-template-columns: 1fr; gap: 16px; margin-bottom: 32px; }
  .fotona-page .f4-modes-grid { grid-template-columns: 1fr 1fr; }
  .f4-modes-grid { grid-template-columns: 1fr 1fr; }
  .f4-treats-grid { grid-template-columns: 1fr 1fr; }
  .f4-ben-cards { padding: 0 40px; grid-template-columns: repeat(2, 1fr); }
  .f4-benefits__hdr { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .f4-container { padding: 0 20px; }
  .f4-hero { padding-top: 88px; }
  .f4-hero__wrap { grid-template-columns: 1fr; min-height: unset; }
  .f4-hero__img-col { height: 360px; padding: 20px; }
  .f4-hero__img { border-radius: 16px; height: 100%; object-fit: contain; object-position: center center; background: #fff; }
  .f4-hero__content { padding: 48px 20px; }
  .f4-hero__h { font-size: 32px; }
  .f4-hero__sub { max-width: none; }
  .f4-hero__feats { grid-template-columns: 1fr; }
  .f4-h { font-size: 30px; }
  .f4-section { padding: 60px 0; }
  .f4-benefits { padding: 60px 0; }
  .f4-two-col { flex-direction: column; gap: 32px; }
  .f4-two-col__left { flex: none; max-width: none; }
  .f4-two-col--treats .f4-two-col__left { flex: none; max-width: none; }
  .f4-two-col--feat .f4-two-col__left,
  .f4-two-col--feat .f4-two-col__right { flex: none; max-width: none; width: 100%; }
  .f4-section--white { overflow-x: hidden; }
  .f4-section--white::before {
    width: 52vw;
    height: calc(52vw * 2.082);
    background-size: contain;
    background-position: left top;
    top: 0;
    transform: none;
  }
  .fotona-page .f4-modes-grid {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    touch-action: pan-x;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 16px;
    width: 100vw;
    margin-left: -20px;
    padding: 0 20px 6px;
    box-sizing: border-box;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .fotona-page .f4-modes-grid::-webkit-scrollbar { display: none; }
  .fotona-page .f4-mode-card {
    flex: 0 0 78vw;
    scroll-snap-align: start;
  }
  .f4-modes-grid {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    touch-action: pan-x;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 16px;
    width: 100vw;
    margin-left: -20px;
    padding: 0 20px 6px;
    box-sizing: border-box;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .f4-modes-grid::-webkit-scrollbar { display: none; }
  .f4-modes-grid .f4-mode-card {
    flex: 0 0 78vw;
    scroll-snap-align: start;
  }
  .f4-checklist--two-col { columns: 1; }
  .f4-treats-grid { grid-template-columns: 1fr; }
  .f4-ben-cards {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    touch-action: pan-x;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 16px;
    padding: 0 20px 6px;
    max-width: none;
    margin: 0;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .f4-ben-cards::-webkit-scrollbar { display: none; }
  .f4-ben-card {
    flex: 0 0 78vw;
    scroll-snap-align: start;
  }
  .f4-h--center { margin-bottom: 16px; }
  .f4-faq { max-width: none; }
  .f4-faq__q { font-size: 16px; }
}

/* ─ 2-column grid modifier (ICOONE, etc.) ─ */
.f4-modes-grid--2col {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 767px) {
  .f4-modes-grid--2col {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    touch-action: pan-x;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 16px;
    width: 100vw;
    margin-left: -20px;
    padding: 0 20px 6px;
    box-sizing: border-box;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .f4-modes-grid--2col::-webkit-scrollbar { display: none; }
  .f4-modes-grid--2col .f4-mode-card {
    flex: 0 0 78vw;
    scroll-snap-align: start;
  }
}

/* ─ 4-column grid modifier (EBOO, etc.) ─ */
.f4-modes-grid--4col {
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 900px) {
  .f4-modes-grid--4col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .f4-modes-grid--4col {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    touch-action: pan-x;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 16px;
    width: 100vw;
    margin-left: -20px;
    padding: 0 20px 6px;
    box-sizing: border-box;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .f4-modes-grid--4col::-webkit-scrollbar { display: none; }
  .f4-modes-grid--4col .f4-mode-card {
    flex: 0 0 78vw;
    scroll-snap-align: start;
  }
}

/* ── Endospheres vs ICOONE comparison ── */
.en-compare-section{padding-top:clamp(60px,8vw,110px);padding-bottom:clamp(60px,8vw,110px)}
.en-compare-hdr{margin:0 0 18px}
.en-compare-hdr__title{margin:0 0 4px}
.en-compare-hdr__sub{margin:0;color:var(--green);font-weight:400;font-family:inherit;font-size:inherit;line-height:1.15}
.en-compare-hdr__sub em{font-style:italic}
.en-compare-intro{max-width:760px;margin-bottom:40px}

.en-cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.en-cmp-card{position:relative;display:flex;flex-direction:column;padding:40px 36px 36px;border-radius:20px;background:#fff;border:1px solid rgba(34,96,64,.12);box-shadow:0 6px 28px rgba(34,96,64,.06);transition:transform .25s ease,box-shadow .25s ease}
.en-cmp-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(34,96,64,.1)}
.en-cmp-card--primary{background:linear-gradient(180deg,#f3f7f2 0%,#fff 70%);border-color:rgba(34,96,64,.28)}
.en-cmp-card__hdr{margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid rgba(34,96,64,.1)}
.en-cmp-card__badge{display:inline-block;padding:5px 12px;border-radius:999px;background:rgba(34,96,64,.1);color:var(--green);font-size:.66rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.en-cmp-card__badge--alt{background:rgba(51,33,6,.06);color:rgba(51,33,6,.55)}
.en-cmp-card__brand{font-family:var(--ff-h,"Playfair Display",Georgia,serif);font-size:2rem;line-height:1.1;color:var(--heading);font-weight:500;margin:0 0 8px}
.en-cmp-card__tag{margin:0;font-size:.85rem;color:var(--heading);opacity:.65;letter-spacing:.02em}
.en-cmp-card__attrs{margin:0;display:flex;flex-direction:column;gap:18px;flex:1}
.en-cmp-attr{display:flex;flex-direction:column;gap:4px}
.en-cmp-attr dt{font-size:.68rem;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:var(--green);margin:0}
.en-cmp-card:not(.en-cmp-card--primary) .en-cmp-attr dt{color:rgba(51,33,6,.55)}
.en-cmp-attr dd{margin:0;font-size:1rem;line-height:1.5;color:var(--heading)}
.en-cmp-pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-right:6px;vertical-align:1px}
.en-cmp-pill--yes{background:rgba(34,96,64,.14);color:#226040}
.en-cmp-pill--no{background:rgba(51,33,6,.07);color:rgba(51,33,6,.55)}
.en-cmp-note{margin-top:32px;font-style:italic;color:var(--heading);opacity:.78;max-width:760px}

@media(max-width:767px){
  .en-cmp-grid{grid-template-columns:1fr}
}

/* ── Sylfirm X treatment menu ── */
.sx-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.sx-menu-card{background:#fff;border-radius:16px;padding:28px 24px}
.sx-menu-card__num{font-family:var(--ff-b);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(34,96,64,.5);display:block;margin-bottom:10px}
.sx-menu-card__name{font-family:var(--ff-h);font-size:17px;font-weight:600;color:#226040;margin:0 0 10px;line-height:1.3}
.sx-menu-card__text{font-family:var(--ff-b);font-size:14px;color:#555;line-height:1.6;margin:0}
@media(max-width:1024px){.sx-menu-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.sx-menu-grid{grid-template-columns:1fr}}


/* ═══════════════════════════════════
   Animations — Fotona 4D page (scoped to .fotona-page)
   ═══════════════════════════════════ */

/* Hero auto-play entrance */
@keyframes f4FadeUp {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: none; }
}
@keyframes f4FadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes f4SlideLeft {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: none; }
}

.fotona-page .f4-hero__img-col  { animation: f4FadeIn   1s   ease both .1s; }
.fotona-page .f4-hero__h        { animation: f4SlideLeft .75s ease both .25s; }
.fotona-page .f4-hero__sub      { animation: f4FadeUp   .75s  ease both .45s; }
.fotona-page .f4-hero__feats    { animation: f4FadeUp   .75s  ease both .6s; }

/* Stagger helpers */
.fotona-page .f4-s1 { transition-delay: .05s !important; }
.fotona-page .f4-s2 { transition-delay: .15s !important; }
.fotona-page .f4-s3 { transition-delay: .25s !important; }
.fotona-page .f4-s4 { transition-delay: .35s !important; }

/* Card reveal */
.fotona-page .f4-mode-card,
.fotona-page .f4-ben-card {
  opacity: 0;
  transform: translateY(20px) scale(.98);
  transition: opacity .6s ease, transform .6s ease, box-shadow .3s ease;
}
.fotona-page .f4-mode-card.is-visible,
.fotona-page .f4-ben-card.is-visible {
  opacity: 1;
  transform: none;
}

/* Treat cards */
.fotona-page .f4-treat-card {
  opacity: 0;
  transform: translateX(-14px);
  transition: opacity .5s ease, transform .5s ease;
}
.fotona-page .f4-treat-card.is-visible { opacity: 1; transform: none; }

/* Steps */
.fotona-page .f4-step {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .55s ease, transform .55s ease;
}
.fotona-page .f4-step.is-visible { opacity: 1; transform: none; }

/* Section label underline */
.fotona-page .f4-label {
  position: relative;
  overflow: hidden;
}
.fotona-page .f4-label::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: #226040;
  transition: width .6s ease .2s;
}
.fotona-page .f4-label.is-visible::after { width: 100%; }

/* Timeline step animation */
.fotona-page .f4-tl-item {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .5s ease, transform .5s ease;
}
.fotona-page .f4-tl-item.f4-tl-visible {
  opacity: 1;
  transform: none;
}
/* Growing vertical line */
.fotona-page .f4-timeline::before {
  transform-origin: top center;
  transform: scaleY(0);
  transition: transform .8s ease .1s;
}
.fotona-page .f4-timeline.f4-tl-running::before {
  transform: scaleY(1);
}
/* Dots pop in */
.fotona-page .f4-tl-item::before {
  transition: transform .3s ease, opacity .3s ease;
  transform: scale(0);
  opacity: 0;
}
.fotona-page .f4-tl-item.f4-tl-visible::before {
  transform: scale(1);
  opacity: 1;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .fotona-page .f4-hero__img-col,
  .fotona-page .f4-hero__h,
  .fotona-page .f4-hero__sub,
  .fotona-page .f4-hero__feats { animation: none; }
  .fotona-page .f4-mode-card,
  .fotona-page .f4-ben-card,
  .fotona-page .f4-treat-card,
  .fotona-page .f4-step { opacity: 1; transform: none; transition: none; }
  .fotona-page .f4-label::after { width: 100%; transition: none; }
  .fotona-page .f4-tl-item { opacity: 1; transform: none; transition: none; }
  .fotona-page .f4-tl-item::before { transform: scale(1); opacity: 1; }
}\n
/* feat-cards */
.f4-feat-stack{display:flex;flex-direction:column;gap:0}
.f4-feat-card{background:var(--cream);border-radius:16px;padding:24px 28px;margin-bottom:16px}.f4-feat-card:last-child{margin-bottom:0}
.f4-section--cream .f4-feat-card,.f4-section--dark .f4-feat-card{background:#fff}
.f4-feat-card__title{font-family:var(--ff-h);font-size:1.0625rem;font-weight:700;color:#226040;margin:0 0 10px;line-height:1.3}
.f4-feat-card__body{font-family:var(--ff-b);font-size:.9375rem;color:#555;line-height:1.65;margin:0}
.fotona-page .f4-feat-card{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.fotona-page .f4-feat-card.is-visible{opacity:1;transform:none}

/* ── Feature panel — "Why Choose Us" style cards (sage panel, dark first card) ── */
.f4-wpanel {
  width: calc(100% - 40px);
  max-width: 1440px;
  margin: 0 auto;
  background: var(--sage);
  border-radius: 28px;
  padding: clamp(40px, 5vw, 80px) clamp(24px, 8.333vw, 120px);
}
.f4-wpanel__head { max-width: 720px; margin-bottom: clamp(30px, 4vw, 52px); }
.f4-wpanel__head .f4-label { margin-bottom: 14px; }
.f4-wpanel__head .f4-h { margin: 0; }
.f4-wpanel__head .f4-text { margin: 16px 0 0; font-size: 15px; }
/* centered header variant (Why Choose Us composition) */
.f4-wpanel--center .f4-wpanel__head { max-width: 760px; margin-left: auto; margin-right: auto; text-align: center; }
.f4-wpanel--center .f4-wpanel__head .f4-label { display: block; }
.f4-wcards {
  display: grid;
  grid-template-columns: repeat(var(--wc, 4), minmax(0, 1fr));
  gap: 16px;
}
.f4-wcard {
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(34,96,64,.12);
  border-radius: 18px;
  padding: 32px 26px;
  display: flex;
  flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease;
}
.f4-wcard:hover { transform: translateY(-4px); box-shadow: 0 18px 42px rgba(16,42,28,.10); }
.f4-wcard__icon { color: var(--green); margin-bottom: 22px; line-height: 0; }
.f4-wcard__icon svg { width: 30px; height: 30px; }
.f4-wcard__title {
  font-family: var(--ff-h);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--heading);
  margin: 0 0 12px;
  line-height: 1.25;
}
.f4-wcard__text {
  font-family: var(--ff-b);
  font-size: .9rem;
  line-height: 1.6;
  color: #5a5142;
  margin: 0 0 24px;
}
.f4-wcard__btn { margin-top: auto; }
.f4-wcard .btn { align-self: flex-start; padding: 11px 22px; font-size: .7rem; }
.f4-wcard--dark {
  background: var(--green-d);
  border-color: transparent;
}
.f4-wcard--dark .f4-wcard__icon,
.f4-wcard--dark .f4-wcard__title { color: #fff; }
.f4-wcard--dark .f4-wcard__text { color: rgba(255,255,255,.78); }
.f4-wcard--dark .btn--dark { background: #fff; color: var(--heading); border-color: #fff; }
.f4-wcard--dark .btn--dark:hover { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }

@media (max-width: 1024px) { .f4-wcards { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 600px)  {
  .f4-wcards { grid-template-columns: 1fr; }
  .f4-wpanel__head { flex-direction: column; gap: 20px; }
}
@media (prefers-reduced-motion: reduce) { .f4-wcard:hover { transform: none; } }

/* ── Why-choose split (intro left + 2-col feature list w/ hairline dividers) ── */
.f4-why2 {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
}
.f4-why2__intro .f4-label { margin-bottom: 18px; }
.f4-why2__intro .f4-h { margin: 0 0 30px; }
.f4-why2__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: clamp(28px, 3.5vw, 52px);
}
.f4-why2__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: start;
  padding: clamp(20px, 2.4vw, 30px) 0;
  border-top: 1px solid rgba(51,33,6,.12);
}
.f4-why2__item:nth-child(1),
.f4-why2__item:nth-child(2) { border-top: none; padding-top: 0; }
.f4-why2__item:nth-child(even) { border-left: 1px solid rgba(51,33,6,.12); padding-left: clamp(24px, 3vw, 48px); }
.f4-why2__ic {
  width: 46px; height: 46px;
  border: 1px solid rgba(34,96,64,.35);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--green); flex-shrink: 0;
}
.f4-why2__ic svg { width: 22px; height: 22px; }
.f4-why2__t { font-family: var(--ff-h); font-size: 1.2rem; font-weight: 600; color: var(--green); margin: 2px 0 8px; line-height: 1.25; }
.f4-why2__d { font-family: var(--ff-b); font-size: .92rem; line-height: 1.6; color: #5a5142; margin: 0; }
@media (max-width: 900px) {
  .f4-why2 { grid-template-columns: 1fr; gap: 40px; }
  .f4-why2__list { grid-template-columns: 1fr; }
  .f4-why2__item:nth-child(2) { border-top: 1px solid rgba(51,33,6,.12); padding-top: clamp(20px,2.4vw,30px); }
  .f4-why2__item:nth-child(even) { border-left: none; padding-left: 0; }
}

/* ── "Define" section: split header + numbered cards (icon bottom) ── */
.f4-define__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: start;
  margin-bottom: clamp(40px, 5vw, 72px);
}
.f4-define__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--ff-b);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
}
.f4-define__eyebrow svg { width: 16px; height: 16px; flex-shrink: 0; }
.f4-define__main .f4-h { margin: 0 0 22px; }
.f4-define__main .f4-text { margin: 0; max-width: 540px; }
.f4-numcards {
  display: grid;
  grid-template-columns: repeat(var(--numcols, 5), 1fr);
  gap: 14px;
}
.f4-numcard {
  background: #fff;
  border: 1px solid rgba(51,33,6,.10);
  border-radius: 16px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  min-height: 248px;
}
.f4-numcard__n { display: block; font-family: var(--ff-h); font-size: 1.1rem; font-weight: 500; color: rgba(34,96,64,.55); line-height: 1; margin: 0 0 16px; }
.f4-numcard__t { font-family: var(--ff-h); font-size: 1.12rem; font-weight: 600; color: var(--green); line-height: 1.22; margin: 0 0 10px; }
.f4-numcard__d { font-family: var(--ff-b); font-size: .85rem; line-height: 1.55; color: #5a5142; margin: 0; }
.f4-numcard__ic { margin-top: auto; padding-top: 24px; color: var(--green); line-height: 0; }
.f4-numcard__ic svg { width: 28px; height: 28px; }
@media (max-width: 1100px) {
  .f4-define__head { grid-template-columns: 1fr; gap: 20px; }
  .f4-numcards { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px)  { .f4-numcards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 767px) {
  .f4-numcards,
  .f4-steps--scroll {
    display: flex;
    grid-template-columns: none;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 14px;
    margin: 44px -20px 0;
    padding: 0 20px 6px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .f4-numcards::-webkit-scrollbar,
  .f4-steps--scroll::-webkit-scrollbar { display: none; }
  .f4-numcards .f4-numcard,
  .f4-steps--scroll .f4-step { flex: 0 0 80%; scroll-snap-align: start; min-height: 0; }
}
/* mobile horizontal-overflow guard */
.longevity-page { overflow-x: clip; }
@media (prefers-reduced-motion: reduce) { .f4-numcard:hover { transform: none; } }

/* ── Intro strip — dark green variant ── */
.pt-intro.pt-intro--dark { background: #102a1c; border-bottom: none; }
.pt-intro--dark .pt-intro__text { color: rgba(255,255,255,.9); }
@media (min-width: 768px) { .pt-intro--dark { padding-top: 52px; padding-bottom: 52px; } }

/* ── Taller hero variant (longevity pages) ── */
.pt-hero--tall { min-height: 720px; }
@media (max-width: 767px) { .pt-hero--tall { min-height: 80vh; padding-top: 120px; padding-bottom: 60px; align-items: flex-end; } }

/* ── Hero layout: 1200 container, space-between heading/text ── */
/* match f4-container (max-width 1440 / 120 padding = 1200 content) so all sections align */
.pt-hero--tall .pt-hero__inner { justify-content: space-between; gap: 60px; }
.pt-hero--tall .pt-hero__heading-col,
.pt-hero--tall .pt-hero__text-col { flex: 0 1 auto; }
@media (max-width: 900px) { .pt-hero--tall .pt-hero__inner { padding: 0 40px; } }
@media (max-width: 767px) {
  .pt-hero--tall .pt-hero__inner { flex-direction: column; gap: 0; padding: 0 20px; }
  .pt-hero--tall .pt-hero__heading-col,
  .pt-hero--tall .pt-hero__text-col { flex: none; width: 100%; }
}

/* ── Hero text: smaller, two-paragraph w/ bold ── */
.pt-hero--tall .pt-hero__sub { font-size: 16px; line-height: 1.6; max-width: 520px; }
.pt-hero--tall .pt-hero__sub p { margin: 0 0 14px; }
.pt-hero--tall .pt-hero__sub p:last-child { margin: 0; }
.pt-hero--tall .pt-hero__sub strong { font-weight: 700; color: #fff; }

/* ── Hero: top-align heading with text + darker overlay for readability ── */
.pt-hero--tall .pt-hero__inner { align-items: flex-start; }
.pt-hero--tall::before { background: rgba(0,0,0,.62); }

/* ── Benefits as numbered 2-col editorial list ── */
.f4-numlist { columns: 2; column-gap: clamp(40px, 6vw, 90px); margin-top: 44px; }
.f4-numlist__item {
  break-inside: avoid;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 22px;
  align-items: baseline;
  padding: 22px 0;
  border-bottom: 1px solid rgba(51,33,6,.12);
}
.f4-numlist__n { font-family: var(--ff-h); font-size: 1.55rem; font-weight: 500; color: var(--green); line-height: 1; }
.f4-numlist__t { font-family: var(--ff-b); font-size: 1rem; line-height: 1.55; color: var(--heading); margin: 0; }
@media (max-width: 760px) { .f4-numlist { columns: 1; } }

/* ── Step icon (replaces number in What-to-Expect) ── */
.f4-step__icon {
  width: 50px; height: 50px;
  border-radius: 12px;
  background: rgba(34,96,64,.1);
  display: flex; align-items: center; justify-content: center;
  color: var(--green);
  margin-bottom: 20px;
}
.f4-step__icon svg { width: 24px; height: 24px; }

/* ── "Who" candidates: heading on top, dense icon list below (no cards) ── */
.f4-who-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 36px;
  max-width: 760px;
}
.f4-who-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 11px 0;
  border-bottom: 1px solid rgba(51,33,6,.08);
}
.f4-who-item__icon {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(34,96,64,.55);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.f4-who-item__icon svg { width: 12px; height: 12px; }
.f4-who-item__text {
  font-family: var(--ff-b);
  font-size: 15px;
  color: var(--heading);
  line-height: 1.4;
}
@media (max-width: 760px) { .f4-who-list { grid-template-columns: 1fr; gap: 0; } }

/* ── What-to-Expect steps: white card + gray border (no beige) ── */
.f4-steps--scroll .f4-step { background: #fff; border: 1px solid rgba(51,33,6,.10); }

/* ── Protocols (dark): split intro left + 2-col cards right ── */
.f4-protocols {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}
.f4-protocols .f4-h em,
.f4-benefits .f4-h em { color: #fff; }   /* dark sections: heading always fully white */
.f4-protocols__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 900px) { .f4-protocols { grid-template-columns: 1fr; gap: 36px; } }
@media (max-width: 540px) { .f4-protocols__cards { grid-template-columns: 1fr; } }

/* ── Protocol card number (replaces icon) ── */
.f4-ben-card__num {
  font-family: var(--ff-h);
  font-size: 2.1rem;
  font-weight: 500;
  color: rgba(255,255,255,.92);
  line-height: 1;
  margin-bottom: 20px;
}

/* ── Formula cards (light grid, highlighted "Best for") ── */
.f4-formulas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 48px; }
.f4-formula {
  background: #fff;
  border: 1px solid rgba(51,33,6,.10);
  border-radius: 16px;
  padding: 30px 26px;
  display: flex;
  flex-direction: column;
}
.f4-formula__name { font-family: var(--ff-h); font-size: 1.2rem; font-weight: 600; color: var(--green); margin: 0 0 12px; line-height: 1.25; }
.f4-formula__text { font-family: var(--ff-b); font-size: .9rem; line-height: 1.6; color: #5a5142; margin: 0 0 20px; }
.f4-formula__best {
  margin-top: auto;
  font-family: var(--ff-b);
  font-size: .82rem;
  line-height: 1.5;
  color: var(--green);
  background: rgba(34,96,64,.09);
  border-radius: 10px;
  padding: 12px 14px;
}
.f4-formula__best b { font-weight: 700; }
@media (max-width: 980px) { .f4-formulas { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .f4-formulas { grid-template-columns: 1fr; } }

/* ── Process flow timeline (animated connector line) ── */
.f4-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(var(--flow, 5), 1fr);
  gap: 20px;
  margin-top: 56px;
}
.f4-flow__line {            /* animated horizontal line (desktop) */
  position: absolute;
  top: 25px;
  left: calc(50% / var(--flow, 5));
  right: calc(50% / var(--flow, 5));
  height: 1.5px;
  background: rgba(34,96,64,.28);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 1.5s cubic-bezier(.4,0,.2,1);
}
.f4-flow.is-visible .f4-flow__line { transform: scaleX(1); }
.f4-flow__step { position: relative; text-align: center; padding-top: 78px; }
.f4-flow__marker {
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 52px; height: 52px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid rgba(34,96,64,.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--green);
  z-index: 1;
}
.f4-flow__marker svg { width: 24px; height: 24px; }
.f4-flow__t { font-family: var(--ff-h); font-size: 1.18rem; font-weight: 600; color: var(--green); margin: 0 0 9px; line-height: 1.25; }
.f4-flow__d { font-family: var(--ff-b); font-size: .88rem; line-height: 1.55; color: #5a5142; margin: 0 auto; max-width: 215px; }

/* tablet + mobile → vertical timeline with animated vertical line */
@media (max-width: 1024px) {
  .f4-flow { grid-template-columns: 1fr; gap: 0; margin-top: 44px; }
  .f4-flow__step { text-align: left; padding: 0 0 36px 74px; min-height: 52px; }
  .f4-flow__step:last-child { padding-bottom: 0; }
  .f4-flow__marker { left: 0; transform: none; }
  .f4-flow__t { margin-bottom: 6px; }
  .f4-flow__d { max-width: none; margin: 0; }
  .f4-flow__line {
    top: 26px; bottom: 40px; left: 25px; right: auto;
    width: 1.5px; height: auto;
    transform: scaleY(0);
    transform-origin: center top;
  }
  .f4-flow.is-visible .f4-flow__line { transform: scaleY(1); }
}
@media (prefers-reduced-motion: reduce) {
  .f4-flow__line { transition: none; transform: none; }
}

/* ── Best-for chip on dark cards (e.g. The Peptides) ── */
.f4-ben-card__best {
  margin-top: 16px;
  font-family: var(--ff-b);
  font-size: .82rem;
  line-height: 1.5;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  padding: 12px 14px;
}
.f4-ben-card__best b { color: #fff; font-weight: 700; }

/* ── FAQ +/- toggle sign ── */
.f4-faq__pm { position: relative; width: 20px; height: 20px; flex-shrink: 0; margin-top: 4px; }
.f4-faq__pm::before, .f4-faq__pm::after { content: ''; position: absolute; background: var(--green); transition: transform .3s ease, opacity .3s ease; }
.f4-faq__pm::before { top: 9px; left: 1px; width: 18px; height: 1.5px; }
.f4-faq__pm::after { left: 9px; top: 1px; width: 1.5px; height: 18px; }
.f4-faq__item.is-open .f4-faq__pm::after { transform: scaleY(0); opacity: 0; }

/* ── Comparison (IV vs Local) — 2 cards, on dark section ── */
.f4-compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:48px;position:relative;z-index:1}
.f4-compare__col{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:32px 30px}
.f4-compare__col--primary{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.34)}
.f4-compare__title{font-family:var(--ff-h);font-size:1.3rem;font-weight:600;color:#fff;margin:0 0 18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.f4-compare__badge{font-family:var(--ff-b);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#15321f;background:var(--gold,#c9a96e);border-radius:100px;padding:4px 11px}
.f4-compare__row{padding:13px 0;border-top:1px solid rgba(255,255,255,.1)}
.f4-compare__row:first-of-type{border-top:none;padding-top:4px}
.f4-compare__k{display:block;font-family:var(--ff-b);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:5px}
.f4-compare__v{font-family:var(--ff-b);font-size:.95rem;line-height:1.55;color:rgba(255,255,255,.9)}
@media(max-width:767px){.f4-compare{grid-template-columns:1fr;gap:14px;margin-top:36px}}

/* ── Category cards (conditions grid) ── */
.f4-catgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.f4-catcard{background:#fff;border:1px solid rgba(51,33,6,.10);border-radius:16px;padding:28px 26px}
.f4-section--cream .f4-catcard{background:#fff}
.f4-catcard__title{font-family:var(--ff-h);font-size:1.12rem;font-weight:600;color:var(--green);margin:0 0 14px}
.f4-catcard__list{list-style:none;margin:0;padding:0}
.f4-catcard__list li{position:relative;padding:6px 0 6px 22px;font-family:var(--ff-b);font-size:.9rem;line-height:1.5;color:#5a5142}
.f4-catcard__list li::before{content:'';position:absolute;left:0;top:13px;width:7px;height:7px;border-radius:50%;background:rgba(34,96,64,.5)}
@media(max-width:980px){.f4-catgrid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.f4-catgrid{grid-template-columns:1fr}}

/* ── Vertical timeline of cards (alternating, center line) ── */
.f4-vtimeline{position:relative;margin-top:56px}
.f4-vtimeline__line{position:absolute;left:50%;margin-left:-1px;top:12px;bottom:12px;width:2px;background:rgba(34,96,64,.22);transform:scaleY(0);transform-origin:top center;transition:transform 1.6s cubic-bezier(.4,0,.2,1)}
.f4-vtimeline.is-visible .f4-vtimeline__line{transform:scaleY(1)}
.f4-vitem{position:relative;width:50%;box-sizing:border-box;margin-bottom:28px}
.f4-vitem:last-child{margin-bottom:0}
.f4-vitem:nth-of-type(odd){left:0;padding-right:50px}
.f4-vitem:nth-of-type(even){left:50%;padding-left:50px}
.f4-vitem__marker{position:absolute;top:10px;width:46px;height:46px;border-radius:50%;background:#fff;border:2px solid rgba(34,96,64,.32);display:flex;align-items:center;justify-content:center;font-family:var(--ff-h);font-size:1rem;font-weight:600;color:var(--green);z-index:2}
.f4-vitem:nth-of-type(odd) .f4-vitem__marker{right:-23px}
.f4-vitem:nth-of-type(even) .f4-vitem__marker{left:-23px}
.f4-vcard{background:#fff;border:1px solid rgba(51,33,6,.10);border-radius:16px;padding:24px 28px}
.f4-vcard__title{font-family:var(--ff-h);font-size:1.12rem;font-weight:600;color:var(--green);margin:0 0 12px}
.f4-vcard__list{list-style:none;margin:0;padding:0}
.f4-vcard__list li{position:relative;padding:5px 0 5px 22px;font-family:var(--ff-b);font-size:.9rem;line-height:1.5;color:#5a5142}
.f4-vcard__list li::before{content:'';position:absolute;left:0;top:12px;width:7px;height:7px;border-radius:50%;background:rgba(34,96,64,.5)}
@media(max-width:768px){
  .f4-vtimeline__line{left:21px;margin-left:0}
  .f4-vitem,.f4-vitem:nth-of-type(odd),.f4-vitem:nth-of-type(even){width:100%;left:0;padding:0 0 0 62px}
  .f4-vitem:nth-of-type(odd) .f4-vitem__marker,.f4-vitem:nth-of-type(even) .f4-vitem__marker{left:0;right:auto}
  .f4-vitem__marker{width:42px;height:42px}
}
@media(prefers-reduced-motion:reduce){.f4-vtimeline__line{transition:none;transform:none}}
