/* Design tokens — warm neutrals + brown / rose (no green accents) */
:root {
  --color-bg: #faf9f7;
  --color-surface: #ffffff;
  --color-text: #1a1a1a;
  --color-muted: #383838;
  --color-accent: #6e4034;
  --color-accent-contrast: #ffffff;
  --surface-brown: #865240;
  --surface-pink: #ffc4c6;
  --surface-muted: #9b9b9b;
  --surface-dark-rose: #5c3a45;
  --surface-footer: #faf7f4;
  /* Titles: Freight Sans Pro (Medium). Body: Freight Big Pro (Light). */
  --font-title: "Freight Sans Pro", "Source Sans 3", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body: "Freight Big Pro", "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --font-serif: var(--font-title);
  --font-sans: var(--font-title);
  --font-sans-light: var(--font-body);
  --max-width: 72rem;
  --header-h: 8rem;
  --content-measure: 85ch;
  /* Same pixel width as 85ch body copy — titles use a different font so ch would not match */
  --content-measure-rem: min(43.6875rem, 100%);
  --content-column: 100%;
  /* Editorial copy — ref. #mtc-base (single source for all pattern sections) */
  --copy-title-size: clamp(0.62rem, 1.36vw, 0.82rem);
  --copy-h2-extra: 3pt;
  --copy-h2-size: calc(var(--copy-title-size) + var(--copy-h2-extra));
  /* Pillar cover bands (#fertilidade, #gestacao, #ginecologia) — separate from editorial H2 */
  --copy-h2-cover-size: calc(var(--copy-hero-lead-size) * 2 + var(--copy-h2-extra));
  --copy-title-lh: 1.22;
  --copy-title-ls: 0.02em;
  --copy-title-weight: 500;
  --copy-body-size: 1.39rem;
  --copy-body-lh: 1.2;
  /* Subtitle under a section title — ref. .section__title-sub */
  --copy-title-sub-size: clamp(0.88rem, 1.75vw, 1.05rem);
  /* Pull-quote / quote variant — ref. .section__quote-text, #fechamento */
  --copy-quote-size: clamp(1.15rem, 2.5vw, 1.45rem);
  --copy-title-body-gap: 1.4rem;
  --copy-h2-space-before: var(--section-pad-y);
  --copy-para-gap: 1.3rem;
  --copy-flow-item-gap: 0.55rem;
  --copy-subhead-gap-top: 1.75rem;
  --copy-subhead-gap-top-after-block: calc(var(--copy-subhead-gap-top) + 0.875rem);
  --copy-subhead-gap-bottom: var(--copy-title-body-gap);
  /* Hero lead line — ref. #inicio .section__site-subtitle__line--lead */
  --copy-hero-lead-size: clamp(0.59rem, 1.62vw, 1.6rem);
  --copy-hero-lead-lh: 1.15;
  --copy-hero-lead-ls: 0.02em;
  --copy-hero-lead-weight: 700;
  /* Mobile editorial scale — single source for the values used inside
     @media (max-width: 640px). Edit here to retune the whole mobile scale. */
  --copy-title-size-mobile: clamp(0.59rem, 2.31vw, 0.78rem);
  --copy-body-size-mobile: clamp(1.12rem, 4.2vw, 1.35rem);
  --copy-hero-lead-size-mobile: clamp(0.51rem, 2.43vw, 0.89rem);
  /* Mobile-only layout + type tuning (ref. Orchid mobile audit) */
  --section-pad-x-mobile: 27px;
  --copy-mobile-scale: 1.1;
  --copy-body-lh-mobile: 1.49;
  --copy-title-lh-mobile: 1.32;
  --copy-hero-lead-lh-mobile: 1.28;
  --section-pad-y: 4.75rem;
  --section-pad-y-hero: 5.5rem;
  --section-pad-y-mobile: 2.75rem;
  --section-pad-y-hero-mobile: 3.5rem;
  /* Cover bands on phones — type trim + slightly taller crop (assets are 560×294) */
  --copy-mobile-band-reduce: 4pt;
  --cover-band-aspect-mobile: 560 / 330;
  /* Tighter vertical rhythm when stacked editorial bands follow each other (desktop). */
  --section-pad-y-stack: var(--section-pad-y-mobile);
  --radius: 0;
}

/* Semantic copy scale — explicit classes only (no global h2 override) */
.copy-heading {
  color: var(--surface-brown);
  font-family: var(--font-title);
  font-weight: var(--copy-title-weight);
  font-size: var(--copy-title-size);
  line-height: var(--copy-title-lh);
  letter-spacing: var(--copy-title-ls);
  text-transform: uppercase;
  text-align: left;
}

.copy-subheading,
h3.copy-subheading {
  font-family: var(--font-title);
  font-weight: 700;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: normal;
  text-transform: none;
  color: inherit;
  margin: 0;
}

.section__body--flow > .copy-subheading {
  display: block;
  margin: var(--copy-subhead-gap-top) 0 var(--copy-subhead-gap-bottom) !important;
}

.section__body--flow > .copy-subheading:first-child {
  margin-top: 0.5rem !important;
}

.section__body--flow > .copy-subheading + .section__body__run {
  margin-top: 0;
}

.section__body--flow > .copy-subheading + .section__list {
  margin-top: 0;
}

.section__body--flow > .section__list {
  margin-top: 0;
}

.section__body--flow > :is(.section__list, .section__body__run) + .copy-subheading {
  margin-top: var(--copy-subhead-gap-top-after-block) !important;
}

.section__body--flow > .copy-subheading + .copy-subheading {
  margin-top: var(--copy-subhead-gap-top) !important;
}

.section__inner > .section__title + :is(.section__body, .section__body--flow) > .copy-subheading:first-child {
  margin-top: 0 !important;
}

/* Layout patterns — one block per visual type (ref. sections listed in comments) */

/* Cover band header — ref. #inicio .section__site-subtitle__line--lead */
.layout-section-cover > .section__title,
.layout-section-cover > .section__title.copy-heading,
.section.section--surface-muted .layout-section-cover > .section__title {
  text-align: center;
  text-wrap: balance;
  width: 100%;
  max-width: none;
  margin: 0 auto;
  font-family: var(--font-title);
  font-weight: var(--copy-hero-lead-weight);
  letter-spacing: var(--copy-hero-lead-ls);
  line-height: var(--copy-hero-lead-lh);
  text-transform: uppercase;
  color: var(--surface-brown);
}

@media (min-width: 641px) {
  .layout-section-cover > .section__title.section__title--multiline {
    white-space: nowrap;
  }

  .layout-section-cover .section__title-br {
    display: none;
  }

  .layout-copy-column > .section__title.section__title--multiline {
    white-space: nowrap;
  }

  .layout-copy-column .section__title--multiline .section__title-br {
    display: none;
  }

  .layout-copy-column .section__title--multiline .section__title-sub {
    white-space: normal;
  }
}

/* Split aside — ref. #quem-atendemos, #metodo */
.layout-split-aside .section__split-aside__copy > .section__title {
  color: var(--surface-brown);
  font-family: var(--font-title);
  font-weight: var(--copy-title-weight);
  line-height: var(--copy-title-lh);
  letter-spacing: var(--copy-title-ls);
  text-transform: uppercase;
  text-align: left;
  max-width: none;
  margin: 0 0 var(--copy-title-body-gap);
}

.layout-split-aside .section__split-aside__copy .section__body,
.layout-split-aside .section__split-aside__copy .section__body p {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  color: var(--color-muted);
}

/* Body copy — ref. .layout-split-aside .section__split-aside__copy .section__body p */
.layout-split-aside .section__split-aside__copy .section__list,
.layout-split-aside .section__split-aside__copy .section__list li,
.layout-copy-column .section__body__run,
.layout-copy-column .section__body__run > p,
.layout-copy-column .section__list,
.layout-copy-column .section__list li {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  color: var(--color-muted);
  text-align: justify;
}

#metodo-cards .method-intro__line {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  color: var(--color-muted);
  text-align: justify;
}

#metodo-cards .method-card__text {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  text-align: justify;
  color: rgba(255, 255, 255, 0.95);
}

.layout-copy-column .section__body__run > p {
  line-height: var(--copy-body-lh);
}

.layout-split-aside .section__figure--aside {
  width: fit-content;
  max-width: 100%;
}

.layout-split-aside .section__figure--aside img {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: none;
  height: auto;
  object-fit: cover;
  object-position: center;
}

/* Full inner width: image + copy share the row (not squeezed into 85ch) */
.section__split-band {
  width: 100%;
}

.layout-split-aside > .section__split-aside {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

/* Split-aside — mobile: title → image → copy */
@media (max-width: 767px) {
  .layout-split-aside .section__split-aside {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
  }

  .layout-split-aside .section__split-aside__copy {
    display: contents;
  }

  .layout-split-aside .section__split-aside__copy > .section__title {
    order: 1;
  }

  .layout-split-aside .section__figure--aside {
    order: 2;
    align-self: stretch;
    width: 100%;
    max-width: none;
    margin-inline: 0;
  }

  :is(#fertilidade-lista, #quem-atendemos, #metodo) .layout-split-aside .section__figure--aside img {
    display: block;
    width: 100%;
    max-width: none;
    max-height: none;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
  }

  #fertilidade-lista .layout-split-aside .section__figure--aside img {
    aspect-ratio: 3 / 2;
  }

  .layout-split-aside .section__split-aside__copy > :is(.section__body, .section__list) {
    order: 3;
  }

  /* Sobre — intro line, photo, name, then body */
  .section--about .layout-split-aside .section__split-aside__copy .section__body {
    display: contents;
  }

  .section--about .layout-split-aside .section__split-aside__copy .section__body > p:first-child {
    order: 1;
  }

  .section--about .layout-split-aside .section__figure--aside {
    order: 2;
  }

  .section--about .layout-split-aside .section__split-aside__copy .section__body > p:nth-child(2) {
    order: 3;
  }

  .section--about .layout-split-aside .section__split-aside__copy .section__body > p:nth-child(n + 3) {
    order: 4;
  }
}

:is(#quem-atendemos, #sobre, #metodo) .section__split-band.layout-split-aside {
  width: 100%;
  max-width: var(--content-measure);
  margin-inline: auto;
  font-size: var(--copy-body-size);
}

.layout-split-aside .section__split-aside__copy > .section__title {
  max-width: none;
}

/* About profile intro — ref. split-aside title scale (#sobre p[0], p[1]) */
.section--about .layout-split-aside .section__split-aside__copy .section__body > p:first-child,
.section--about .layout-split-aside .section__split-aside__copy .section__body > p:nth-child(2) {
  color: var(--surface-brown);
  font-family: var(--font-title);
  font-weight: var(--copy-title-weight);
  font-size: var(--copy-title-size);
  line-height: var(--copy-title-lh);
  letter-spacing: var(--copy-title-ls);
  text-align: left;
  margin: 0 0 var(--copy-title-body-gap);
}

.section--about .layout-split-aside .section__split-aside__copy .section__body > p:first-child {
  text-transform: uppercase;
}

.section--about .layout-split-aside .section__split-aside__copy .section__body > p:nth-child(2) {
  text-transform: uppercase;
  font-weight: 700;
}

/* Copy column — ref. #mtc-base */
.layout-copy-column {
  display: grid;
  grid-template-columns: minmax(0, 1fr) min(var(--content-measure), 100%) minmax(0, 1fr);
  font-size: var(--copy-body-size);
}

.layout-copy-column > :is(.section__title, .section__body, .section__body--flow, .section__eyebrow) {
  grid-column: 2;
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.layout-copy-column > :not(.section__title, .section__body, .section__body--flow, .section__eyebrow) {
  grid-column: 1 / -1;
}

.layout-copy-column > .section__title {
  margin: 0 0 var(--copy-title-body-gap);
  max-width: none;
}

.layout-copy-column:not(:has(> .section__title)) > .section__body > p:first-child {
  color: var(--surface-brown);
  font-family: var(--font-title);
  font-weight: var(--copy-title-weight);
  font-size: var(--copy-title-size);
  line-height: var(--copy-title-lh);
  letter-spacing: var(--copy-title-ls);
  text-transform: uppercase;
  text-align: left;
  margin: 0 0 var(--copy-title-body-gap);
}

.layout-copy-column .section__body,
.layout-copy-column .section__body--flow {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  color: var(--color-muted);
}

.layout-copy-column :is(.section__body, .section__body--flow) > p {
  margin: 0;
}

.layout-copy-column > .section__title + :is(.section__body, .section__body--flow) > p:first-child,
.layout-copy-column:not(:has(> .section__title)) > .section__body > p:not(:first-child),
.layout-copy-column .section__body--flow > p {
  margin: 0 0 var(--copy-para-gap);
}

/* Block subheadings — ref. #mtc-base .section__body > p:first-child */
.layout-copy-column .section__body-heading:not(.section__title),
.layout-copy-column .copy-subheading,
.layout-copy-column h3.copy-subheading,
.layout-copy-column .section__body > p > strong {
  color: var(--surface-brown);
  font-family: var(--font-title);
  font-weight: var(--copy-title-weight);
  font-size: var(--copy-title-size);
  line-height: var(--copy-title-lh);
  letter-spacing: var(--copy-title-ls);
  text-transform: uppercase;
  text-align: left;
}

.layout-copy-column h3.copy-subheading {
  font-weight: 700;
}

.layout-copy-column .section__body-heading:not(.section__title) {
  max-width: none;
}

.layout-copy-column .section__body--flow > .section__title.section__body-heading {
  max-width: none;
  margin-bottom: var(--copy-title-body-gap);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 0.5rem);
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  margin: 0;
  font-family: var(--font-sans-light);
  font-weight: 300;
  font-synthesis: none;
  color: var(--color-text);
  background: #ffffff;
  line-height: 1.55;
  hyphens: none;
  overflow-wrap: break-word;
}

body.no-scroll {
  overflow: hidden;
}

strong,
b {
  font-weight: 700;
}

.material-symbols-outlined {
  font-family: "Material Symbols Outlined", sans-serif;
  font-weight: normal;
  font-style: normal;
  font-size: 1.35rem;
  line-height: 1;
  display: inline-block;
  vertical-align: middle;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

a {
  color: var(--color-accent);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  height: var(--header-h);
  background: var(--color-surface);
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.header-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding-block: 0;
  padding-inline: max(1.25rem, env(safe-area-inset-left)) max(1.25rem, env(safe-area-inset-right));
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.logo {
  flex-shrink: 1;
  min-width: 0;
  line-height: 0;
}

.logo__link {
  display: block;
  text-decoration: none;
  color: var(--color-text);
}

.logo__img {
  display: block;
  width: auto;
  height: clamp(3.64rem, 8.4vw, 5.88rem);
  max-width: min(58vw, 17rem);
  object-fit: contain;
  object-position: left center;
}

.logo a {
  text-decoration: none;
  color: var(--color-text);
}

.nav-desktop {
  display: none;
  flex-wrap: wrap;
  gap: 0.25rem 1.25rem;
  align-items: center;
}

.nav-link {
  text-decoration: none;
  color: var(--color-muted);
  font-family: var(--font-title);
  font-size: 0.935rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.nav-link:hover,
.nav-link:focus-visible {
  color: var(--surface-brown);
}

.nav-link--active {
  color: var(--surface-brown);
  position: relative;
}

.nav-link--active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.1rem;
  height: 2px;
  background: var(--surface-brown);
  border-radius: var(--radius);
}

.nav-link--home.nav-link--active { color: var(--surface-brown); }

.nav-mobile .nav-link--active {
  background: rgba(134, 82, 64, 0.06);
}
.nav-mobile .nav-link--active::after { display: none; }

.nav-link--home {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
}

.nav-link__symbol {
  font-size: 2rem;
}

.nav-link:hover .nav-link__symbol,
.nav-link:focus-visible .nav-link__symbol {
  color: inherit;
}

.mobile-menu-toggle:hover,
.mobile-menu-toggle:focus-visible {
  color: var(--surface-brown);
}

.mobile-menu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  margin-right: -0.5rem;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--color-text);
  border-radius: var(--radius);
}

.mobile-menu-toggle:focus-visible {
  outline: 2px solid var(--surface-brown);
  outline-offset: 2px;
}

.mobile-menu-toggle .material-symbols-outlined {
  font-size: 2.25rem;
}

/* Icon reflects open/closed state (driven by aria-expanded, set in main.js) */
.mobile-menu-toggle__icon { display: block; }
.mobile-menu-toggle__icon--close { display: none; }
.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon--open { display: none; }
.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon--close { display: block; }

.nav-mobile {
  display: none;
  position: absolute;
  top: var(--header-h);
  right: max(1.25rem, env(safe-area-inset-right));
  left: auto;
  width: max-content;
  max-width: calc(100% - max(1.25rem, env(safe-area-inset-left)) - max(1.25rem, env(safe-area-inset-right)));
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  background: var(--color-surface);
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-top: none;
  border-radius: var(--radius);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.1);
  padding: 0;
  z-index: 41;
}

.nav-mobile.is-open {
  display: flex;
}

.nav-mobile .nav-link {
  padding: 0.75rem 1rem 0.75rem 1.35rem;
  text-align: right;
  white-space: nowrap;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.nav-mobile .nav-link:last-child {
  border-bottom: none;
}

.nav-mobile .nav-link--home {
  justify-content: flex-end;
}

@media (min-width: 900px) {
  .nav-desktop {
    display: flex;
  }
  .mobile-menu-toggle {
    display: none;
  }
  .nav-mobile {
    display: none !important;
  }
}

main,
#sections-root {
  min-width: 0;
  overflow-x: clip;
}

main {
  min-height: calc(100vh - var(--header-h) - 8rem);
  background: #ffffff;
}

.section {
  padding: 0;
  background: transparent;
  scroll-margin-top: calc(var(--header-h) + 0.5rem);
  width: 100%;
}

/* Colored bands: background edge-to-edge; content stays in .section__inner */
.section.section--surface-brown,
.section.section--surface-pink,
.section.section--surface-muted,
.section.section--surface-darkRose,
.section--hero.section--surface-default,
.section--hero.section--surface-muted {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.section__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--section-pad-y) max(1.25rem, env(safe-area-inset-left)) var(--section-pad-y)
    max(1.25rem, env(safe-area-inset-right));
  border-radius: 0;
}

.section--hero .section__inner,
.section--contact .section__inner {
  padding-top: var(--section-pad-y-hero);
  padding-bottom: var(--section-pad-y-hero);
}

.section--hero.section--surface-default {
  background: linear-gradient(165deg, var(--color-surface) 0%, #f4ebe4 100%);
}

.section--hero.section--surface-muted {
  background-color: var(--surface-muted);
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.section__site-subtitle {
  margin: 0;
  max-width: 48rem;
  text-align: justify;
}

.section__site-subtitle__line {
  margin: 0 0 1rem;
  font-family: var(--font-body);
  font-size: clamp(1.1rem, 2.4vw, 1.4rem);
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: -0.01em;
  text-align: justify;
}

.section__site-subtitle__line:last-child {
  margin-bottom: 0;
}

.section.section--surface-muted .section__site-subtitle__line {
  color: rgba(255, 255, 255, 0.92);
}

.section.section--surface-default .section__site-subtitle__line {
  color: var(--color-text);
}

.section.section--surface-brown .section__site-subtitle__line,
.section.section--surface-pink .section__site-subtitle__line {
  color: inherit;
}

/* Centered hero taglines + selected section headings/copy */
#inicio.section--hero {
  min-height: 0;
  display: block;
}

#inicio.section--hero.section--surface-muted {
  background-color: transparent;
}

#inicio.section--hero .section__inner {
  flex: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  max-width: none;
  min-height: 0;
  aspect-ratio: 560 / 294;
  background-color: #f3e8e4;
  background-image: url("../images/floral-hero.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: clamp(2rem, 7vh, 4.5rem) clamp(1.25rem, 5vw, 4rem);
}

#inicio .section__site-subtitle {
  width: 100%;
  max-width: none;
  margin: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: clamp(0.5rem, 2vh, 1rem);
  text-align: center;
}

#inicio .section__site-subtitle__line {
  width: 100%;
  margin: 0;
  text-align: center;
  text-wrap: balance;
}

#inicio .section__site-subtitle__line--lead {
  font-family: var(--font-title);
  font-weight: var(--copy-hero-lead-weight);
  font-size: calc(var(--copy-hero-lead-size) * 2);
  letter-spacing: var(--copy-hero-lead-ls);
  line-height: var(--copy-hero-lead-lh);
  text-transform: uppercase;
  color: var(--surface-brown);
}

#inicio .section__site-subtitle__line:not(.section__site-subtitle__line--lead) {
  font-family: var(--font-body);
  font-size: clamp(1.12rem, 3.24vw, 3.16rem);
  font-weight: 300;
  line-height: 1.2;
  color: var(--color-muted);
}

#estagios .section__body > p {
  padding-top: 5px;
}

#estagios .section__body--flow > .section__body__lead {
  margin-top: 0.5rem;
  margin-bottom: 0.25rem;
}

#estagios .section__body--flow > .section__body__lead + .section__body__run {
  margin-top: 0;
  margin-bottom: 1rem;
}

#estagios .section__body--flow > .section__body__lead + .section__body__run:has(+ .section__title) {
  margin-bottom: 0;
}

#estagios .section__body--flow > .section__body-heading {
  margin-bottom: var(--copy-title-body-gap);
}

#estagios .section__body--flow > .section__body-heading + .copy-subheading {
  margin-top: calc(var(--copy-title-body-gap) + 0.15rem) !important;
}

#estagios .section__body--flow > .copy-subheading + .section__body__run {
  margin-top: 0;
}

#estagios .section__body--flow > .copy-subheading + .section__body__run > p {
  margin-top: 0;
  margin-bottom: 0.35rem;
}

@media (min-width: 641px) {
  body.page-home #estagios > .section__inner > .section__title {
    white-space: nowrap;
  }

  body.page-home #estagios .section__title .section__title-br {
    display: none;
  }
}

#fertilidade-lista .section__split-aside__copy > :is(.section__title, .section__body, .section__body--flow, .section__list) {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.layout-copy-column > .section__title + .section__body > p:not(:first-child) {
  margin: 0 0 var(--copy-para-gap);
}

/* Tratamentos — bloco fertilidade-lista: alinhado ao eixo das demais seções */
#fertilidade-lista .section__inner {
  max-width: var(--max-width);
  width: 100%;
}

#fertilidade .section__decor {
  max-width: min(38%, 11rem);
}

#citacao .section__quote {
  margin-left: auto;
  margin-right: auto;
  max-width: min(42rem, 92vw);
}

#citacao .section__quote-text {
  max-width: none;
  text-align: center;
  text-wrap: balance;
}

/* Text column — --content-measure; diagrams/grids/images stay full inner width */
.section__inner > :is(
  .section__title,
  .section__eyebrow
) {
  width: 100%;
  max-width: var(--content-measure-rem);
  margin-inline: auto;
}

.section__inner > :is(
  .section__body,
  .section__body--flow,
  .section__list,
  .method-intro,
  .section__two-col,
  .section__actions
) {
  width: 100%;
  max-width: var(--content-measure);
  margin-inline: auto;
}

.section__split-aside__copy {
  width: 100%;
  max-width: none;
  min-width: 0;
}

.section__inner.layout-copy-column > :is(
  .section__title,
  .section__eyebrow,
  .section__body,
  .section__body--flow,
  .section__list
) {
  max-width: none;
  margin-inline: 0;
}

.section__inner.layout-copy-column {
  display: grid;
  grid-template-columns: minmax(0, 1fr) min(var(--content-measure), 100%) minmax(0, 1fr);
  font-size: var(--copy-body-size);
}

/* Section copy column layout (ref. #quem-atendemos) */
:is(
  #fechamento
) > .section__inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

:is(
  #fechamento
) > .section__inner > :is(.section__title, .section__eyebrow, .section__body, .section__body--flow) {
  text-align: left;
}

#conectado > .section__inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

#conectado > .section__inner > :is(.section__title, .section__eyebrow, .section__body, .section__body--flow) {
  text-align: center;
}

:is(
  #fechamento
) > .section__inner > :is(.section__body, .section__body--flow) {
  max-width: var(--content-measure);
}

#conectado > .section__inner > :is(.section__body, .section__body--flow) {
  max-width: var(--content-measure);
  margin-inline: auto;
}

#estagios > .section__inner > .section__body,
#estagios .section__body p {
  text-align: justify;
}

#mtc-base > .section__inner > .section__body,
#mtc-base .section__body > p:not(:first-child) {
  text-align: justify;
}

:is(#fiv, #gestacao-corpo, #ginecologia-corpo) > .section__inner > :is(.section__body, .section__body--flow),
:is(#fiv, #gestacao-corpo, #ginecologia-corpo) .section__body__run,
:is(#fiv, #gestacao-corpo, #ginecologia-corpo) .section__body__run > p,
:is(#fiv, #gestacao-corpo, #ginecologia-corpo) .section__body--flow > p {
  text-align: justify;
}

/* Tratamentos — #preparo-natural followed by #fiv: tighter gap before FIV title */
#preparo-natural:has(+ #fiv) > .section__inner {
  padding-bottom: var(--copy-subhead-gap-top);
}

#preparo-natural + #fiv > .section__inner {
  padding-top: var(--copy-subhead-gap-top);
}

#conectado .section__title {
  color: var(--surface-pink);
}

#fertilidade-lista .section__split-aside__copy > .section__title {
  max-width: none;
  width: 100%;
  text-align: left;
}

#fertilidade-lista .section__split-aside__copy > .section__body,
#fertilidade-lista .section__split-aside__copy > .section__list {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

/* Section corner decor (line art florals, WebP @560px) */
.section__inner--has-decor {
  position: relative;
  overflow: hidden;
}

.section__inner--has-cover {
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: none;
}

.section__cover-fill {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  pointer-events: none;
}

.section__inner--has-cover > :not(.section__cover-fill) {
  position: relative;
  z-index: 1;
}

#fertilidade.section--surface-muted,
#gestacao.section--surface-muted,
#ginecologia.section--surface-muted {
  background-color: transparent;
  border-block: none;
}

.section__decor {
  position: absolute;
  z-index: 0;
  width: auto;
  max-width: min(46%, 16rem);
  height: auto;
  pointer-events: none;
  opacity: 0.88;
}

.section__decor--bottom-right {
  right: 0;
  bottom: 0;
}

.section__decor--bottom-left {
  left: 0;
  bottom: 0;
}

.section__decor--top-right {
  right: 0;
  top: 0;
}

.section__decor--top-left {
  left: 0;
  top: 0;
}

.section__inner--has-decor > :not(.section__decor) {
  position: relative;
  z-index: 1;
}

#fertilidade .section__decor,
#gestacao .section__decor,
#ginecologia .section__decor {
  max-width: min(52%, 14rem);
}

#citacao .section__decor {
  max-width: min(40%, 11rem);
  opacity: 0.75;
}

#fiv .section__decor-inline__img,
#preparo-natural .section__decor {
  max-width: min(44%, 13rem);
  opacity: 0.82;
}

.section__decor-inline {
  margin: 0 auto 1rem;
  text-align: center;
}

.section__decor-inline__img {
  display: block;
  width: auto;
  max-width: min(100%, 16rem);
  height: auto;
  margin: 0 auto;
  opacity: 0.9;
}

#fiv .section__decor-inline {
  margin-bottom: 0.75rem;
}

#fiv .section__decor-inline__img {
  max-width: min(100%, 13.5rem);
  opacity: 0.88;
}

#conectado .section__decor {
  max-width: min(38%, 9.5rem);
  max-height: min(55vh, 22rem);
  object-fit: contain;
  object-position: bottom left;
}

.image-preview-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.25rem;
  margin-top: 1.5rem;
  width: 100%;
  max-width: 56rem;
}

.image-preview-grid__item {
  margin: 0;
  line-height: 0;
  border-radius: var(--radius);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.04);
}

.image-preview-grid__item img {
  display: block;
  width: auto;
  max-width: min(42vw, 14rem);
  max-height: 10rem;
  height: auto;
  object-fit: contain;
}

.section.section--surface-muted .image-preview-grid__item {
  background: rgba(255, 255, 255, 0.12);
}

@media (max-width: 767px) {
  .section__decor {
    max-width: min(58%, 10.5rem);
    opacity: 0.72;
  }

  #fertilidade .section__decor,
  #gestacao .section__decor,
  #ginecologia .section__decor {
    max-width: min(62%, 9.5rem);
  }
}

/* Tratamentos — end of “preparo natural” block */
#preparo-natural .section__inner.layout-copy-column::after {
  content: "";
  display: block;
  grid-column: 2;
  align-self: start;
  width: 100%;
  height: 2px;
  margin-top: 1rem;
  background: var(--surface-brown);
  border-radius: var(--radius);
}

/* Leading • * ● in JSON → round marker (glyph stripped in JS) */
.section__body__bullet {
  position: relative;
  padding-left: 1.15rem;
}

.section__body__bullet::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background: currentColor;
}


.section__figure {
  margin: 0;
}

.section__figure img {
  display: block;
  height: auto;
}

.section__split-aside {
  display: grid;
  gap: 2rem;
  align-items: start;
  min-width: 0;
  max-width: 100%;
}

.section__split-aside > * {
  min-width: 0;
  max-width: 100%;
}

.section__split-aside > .section__figure--aside {
  width: fit-content;
}

@media (min-width: 768px) {
  .section--about .section__split-aside {
    grid-template-columns: max-content minmax(0, 1fr);
    gap: clamp(0.75rem, 1.5vw, 1.25rem);
    align-items: start;
  }

  .section--about .section__split-aside > .section__figure--aside {
    width: fit-content;
    max-width: none;
    justify-self: start;
  }

  .section--about .section__figure--aside.section__figure--portrait {
    max-width: none;
  }

  .section--about .section__figure--aside.section__figure--portrait img {
    width: auto;
    max-width: 14rem;
    max-height: none;
    aspect-ratio: 3 / 4;
    object-fit: cover;
  }
}

@media (min-width: 768px) {
  .section__split-aside {
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
    gap: clamp(1rem, 2vw, 1.5rem);
    align-items: start;
  }

  .section__split-aside > .section__figure--aside {
    width: 100%;
    max-width: 22rem;
    justify-self: start;
  }

  :is(#fertilidade-lista, #quem-atendemos, #metodo) .layout-split-aside .section__figure--aside img {
    aspect-ratio: 4 / 3;
  }

  #fertilidade-lista .layout-split-aside .section__figure--aside img {
    aspect-ratio: 3 / 2;
  }
}

/* Sobre — same content column as #quem-atendemos (.section__inner max-width) */
.section--about .section__inner {
  max-width: var(--max-width);
  width: 100%;
}

.section__figure--aside {
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
  line-height: 0;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12);
}

.section__figure--aside img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  max-height: min(28rem, 72vh);
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

#fertilidade-lista .section__figure--aside {
  background: var(--surface-brown);
  padding: 0.5rem 0.65rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.section__figure--aside.section__figure--portrait {
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.2);
}

.section__figure--aside.section__figure--portrait img {
  width: auto;
  max-width: 17rem;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  max-height: none;
}

.section--about .section__figure--aside.section__figure--portrait img {
  max-width: 14rem;
}

.section--split {
  background: transparent;
}

.section__eyebrow {
  margin: 0 0 0.65rem;
  font-family: var(--font-sans);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-accent);
  font-weight: 600;
  text-align: left;
}

.section.section--surface-muted .section__eyebrow,
.section.section--surface-brown .section__eyebrow {
  color: rgba(255, 255, 255, 0.95);
}

.section.section--surface-pink .section__eyebrow {
  color: var(--surface-brown);
}

.section__title {
  margin: 0 0 1.35rem;
  font-family: var(--font-title);
  font-weight: 500;
  line-height: 1.22;
  max-width: 40ch;
  text-align: left;
}

.section__title:not(.copy-heading) {
  font-size: clamp(1.55rem, 3.4vw, 2.05rem);
}

.layout-copy-column > .section__title {
  max-width: none;
}

.section__title-sub {
  display: block;
  margin-top: 0.3rem;
  font-family: var(--font-body);
  font-size: var(--copy-title-sub-size);
  font-weight: 300;
  letter-spacing: 0.02em;
  line-height: 1.3;
}

/* No side image: text in --content-measure; grids/diagrams full width */
.section__inner:not(:has(.section__split-aside)):not(.layout-copy-column):not(.layout-section-cover) {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.section__inner:not(:has(.section__split-aside)) > .section__quote {
  max-width: 52ch;
}

.section__inner:not(:has(.section__split-aside)) > .section__actions {
  justify-content: center;
}

.section__inner:not(:has(.section__split-aside)) > .pillars-grid,
.section__inner:not(:has(.section__split-aside)) > .method-cards,
.section__inner:not(:has(.section__split-aside)) > .faq-grid,
.section__inner:not(:has(.section__split-aside)) > .section__contact-block,
.section__inner:not(:has(.section__split-aside)) > .section__contact-extra,
.section__inner:not(:has(.section__split-aside)) > .technique-map,
.section__inner:not(:has(.section__split-aside)) > .section-diagram {
  align-self: stretch;
  width: 100%;
  max-width: none;
}

.section-diagram {
  margin-top: 1.25rem;
  margin-bottom: 1.75rem;
  min-width: 0;
  max-width: 100%;
}

.section-diagram__img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.section-diagram--responsive .section-diagram__img--desktop {
  aspect-ratio: 960 / 240;
}

.section-diagram--responsive .section-diagram__img--mobile {
  display: none;
  aspect-ratio: 520 / 760;
}

@media (max-width: 640px) {
  .section-diagram--responsive .section-diagram__img--desktop {
    display: none;
  }

  .section-diagram--responsive .section-diagram__img--mobile {
    display: block;
  }
}

#atendimento-modalidades > .section__inner {
  container-type: inline-size;
  container-name: atendimento-modalidades-inner;
}

#atendimento-modalidades > .section__inner > .section-diagram {
  width: 130%;
  max-width: calc(var(--content-measure) * 1.3);
  margin-inline: auto;
}

#atendimento-modalidades .section-diagram picture,
#atendimento-modalidades .section-diagram {
  display: block;
  width: 100%;
}

#atendimento-modalidades .section-diagram__img {
  width: 100%;
  max-width: 100%;
}

@media (min-width: 641px) {
  /* Same content width as #metodo .method-cards (full .section__inner) */
  #atendimento-modalidades > .section__inner > .section-diagram {
    width: 100cqi;
    max-width: 100cqi;
    justify-self: center;
  }
}

@media (max-width: 640px) {
  #atendimento-modalidades > .section__inner > .section-diagram {
    width: 100%;
    max-width: min(100%, 20rem);
  }
}

@media (min-width: 641px) {
  #atendimento-modalidades:has(+ #primeira-consulta) > .section__inner {
    padding-bottom: var(--section-pad-y-stack);
  }

  #atendimento-modalidades + #primeira-consulta > .section__inner:has(> h2.section__title:first-child) {
    padding-top: var(--copy-h2-space-before);
  }
}

.section--hero .section__title {
  max-width: 22ch;
}

.section h1.section__title {
  font-size: clamp(1.85rem, 4.5vw, 2.45rem);
}

.section--rich-en .section__body--rich {
  font-size: 1rem;
}

.section--pillars .section__title {
  text-align: center;
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.5rem;
  font-size: clamp(1.45rem, 3vw, 1.95rem);
  line-height: 1.18;
}

/* Section headings — hero lead (#tratamentos pillars only) */
:is(
  #tratamentos.section--pillars .section__title
) {
  font-family: var(--font-title);
  font-weight: var(--copy-hero-lead-weight);
  letter-spacing: var(--copy-hero-lead-ls);
  line-height: var(--copy-hero-lead-lh);
  text-transform: uppercase;
}

#tratamentos.section--pillars .section__title {
  text-align: center;
  width: 100%;
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
}

#fiv .section__title-sub {
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
}

/* Fixed desktop-scale title — intentionally NOT the responsive --copy-title-size
   (which shrinks under @media max-width:640px). Kept as a literal on purpose. */
#conectado .section__title {
  font-family: var(--font-title);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.22;
  text-transform: uppercase;
}

.pillars-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  margin-top: 0;
}

@media (min-width: 640px) {
  .pillars-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }
}

.pillar-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.65rem;
  padding: 1.5rem 1.15rem 1.35rem;
  text-align: center;
  text-decoration: none;
  color: var(--color-text);
  background: #faf6f3;
  border: 1px solid rgba(110, 64, 52, 0.18);
  border-radius: var(--radius);
  transition: background 0.15s ease, border-color 0.15s ease;
}

#tratamentos .pillar-card {
  border: none;
  border-radius: 0;
}

.pillar-card:hover {
  background: #f2e8e0;
  border-color: var(--surface-brown);
}

.pillar-card__label {
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent);
  opacity: 0.9;
}

.pillar-card__title {
  font-family: var(--font-title);
  font-weight: 500;
  font-size: clamp(1.05rem, 2.2vw, 1.2rem);
  line-height: 1.3;
  white-space: pre-line;
  text-align: center;
}

.pillar-card__cta {
  margin-top: 0.15rem;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--surface-brown);
}

.section__list {
  margin: 1rem 0 0;
  padding-left: 1.25rem;
  width: 100%;
  max-width: var(--content-measure);
  margin-inline: auto;
  font-family: var(--font-sans-light);
  font-weight: 300;
  color: var(--color-muted);
  text-align: justify;
}

.section__list li {
  margin-bottom: var(--copy-flow-item-gap);
  text-align: justify;
}

.section__two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  margin-top: 1.5rem;
}

.section__two-col--after-body {
  margin-top: 2.25rem;
}

/* Métodos — 6 equal columns (4 presencial + 2 virtual), one outer frame */
#metodo .technique-map {
  margin-top: 1.75rem;
  max-width: none;
}

#metodo .technique-map__frame {
  --technique-cols: 6;
  padding: 0.85rem 0.65rem 0.55rem;
}

#metodo .technique-map__layout {
  position: relative;
}

#metodo .technique-map__borders {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
}

#metodo .technique-map__border-outer {
  stroke: var(--surface-brown);
}

#metodo .technique-map__border-virtual {
  stroke: var(--color-accent);
}

#metodo .technique-map__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(var(--technique-cols, 6), minmax(0, 1fr));
  grid-template-rows: auto auto;
  column-gap: 0;
  row-gap: 0.45rem;
  align-items: start;
}

#metodo .technique-map__chip {
  z-index: 1;
  display: flex;
  grid-row: 1;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  height: 2.75rem;
  padding: 0.5rem 0.35rem;
  font-size: clamp(0.72rem, 1.8vw, 0.88rem);
  font-weight: 600;
  line-height: 1.2;
  text-align: center;
  color: #ffffff;
  background: var(--surface-muted);
  border-radius: var(--radius);
}

#metodo .technique-map__label {
  z-index: 1;
  margin: 0;
  padding-top: 0.1rem;
  font-size: clamp(0.62rem, 1.6vw, 0.72rem);
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.2;
  text-transform: uppercase;
  color: var(--color-text);
}

#metodo .technique-map__label--inPerson {
  grid-row: 2;
  text-align: left;
}

#metodo .technique-map__label--virtual {
  grid-row: 2;
  text-align: right;
}

/* Métodos — pink band: split-aside only (#metodo); white band: intro + cards (#metodo-cards) */
#metodo.section--surface-pink {
  background-color: var(--surface-pink);
  border-bottom: none;
}

#metodo-cards {
  background-color: #fff;
  border-block: none;
}

#metodo-cards > .section__inner {
  padding-top: 0;
}

#metodo-cards .method-intro {
  --method-intro-pad-b: calc(var(--section-pad-y) * 0.65);
  margin-top: 0;
  padding-top: calc(var(--method-intro-pad-b) * 2);
  padding-bottom: var(--method-intro-pad-b);
  max-width: none;
  text-align: center;
  background: #fff;
}

#metodo-cards .method-intro__line {
  margin: 0;
  font-style: normal;
  text-align: justify;
}

#metodo-cards .method-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 0;
  padding-bottom: var(--section-pad-y);
  background: #fff;
}

#atendimento-modalidades.section--surface-pink {
  background-color: #fff;
  border-block: none;
}

#atendimento-modalidades.section--surface-pink .section__title {
  color: var(--surface-brown);
}

#atendimento-modalidades.section--surface-pink .section__body,
#atendimento-modalidades.section--surface-pink .section__body--rich,
#atendimento-modalidades.section--surface-pink .section__body p {
  color: var(--color-muted);
}

@media (min-width: 640px) {
  #metodo-cards .method-cards {
    grid-template-columns: 1fr 1fr;
  }
}

#metodo-cards .method-card {
  margin: 0;
  padding: 1.25rem calc(1.1rem * 1.5);
  background: var(--surface-brown);
  border-radius: 0;
  color: #ffffff;
}

/* Fixed desktop-scale title — intentionally NOT the responsive --copy-title-size
   (which shrinks under @media max-width:640px). Kept as a literal on purpose. */
#metodo-cards .method-card__title {
  margin: 0 0 0.75rem;
  font-family: var(--font-title);
  font-size: clamp(0.62rem, 1.36vw, 0.82rem);
  font-weight: 700;
  line-height: 1.22;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.98);
}

@media (min-width: 768px) {
  .section__two-col {
    grid-template-columns: 1fr 1fr;
  }
}

.section__col {
  padding: 1rem 0;
  border-top: 2px solid var(--color-accent);
  font-size: 0.98rem;
  color: var(--color-muted);
}

.section__col[lang="en"] {
  font-family: "Georgia", serif;
}

.section__quote {
  margin: 1.5rem 0 0;
  padding: 0;
  border: none;
  max-width: 48ch;
}

.section__quote-text {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--copy-quote-size);
  font-style: italic;
  line-height: 1.45;
  color: var(--color-text);
  white-space: pre-wrap;
  text-align: justify;
}

.section__body {
  width: 100%;
  max-width: var(--content-measure);
  margin-inline: auto;
  font-family: var(--font-sans-light);
  font-weight: 300;
  color: var(--color-muted);
  font-size: 1.02rem;
  line-height: 1.62;
  text-align: justify;
}

.section__split-aside__copy .section__body {
  width: 100%;
  max-width: none;
  font-family: var(--font-sans);
  font-weight: 300;
  line-height: 1.62;
}

.section__body--rich {
  text-align: justify;
}

.section__body p {
  margin: 0 0 var(--copy-para-gap);
}

.section__body p:last-child {
  margin-bottom: 0;
}

/* bodyFlow: "tight" — lines between **titles** stack with no paragraph gap */
/* Legacy flow spacing — block subheadings are h3.copy-subheading (see top of file) */
.section__body--flow > .copy-subheading + .section__body__run,
.section__body--flow > .copy-subheading + .section__list {
  margin-top: 0;
}

.section__body__run {
  display: block;
  margin: 0;
  padding: 0;
}

#conectado > .section__inner > .section__body,
#conectado .section__body p {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  text-align: center;
}

.section__body__run > p {
  display: block;
  margin: 0 0 var(--copy-flow-item-gap) !important;
  padding: 0;
}

.section__body__run > p::after {
  content: none;
}

.section__body__run > p:last-child {
  margin-bottom: 0 !important;
}

.section__body--flow > .section__body__run + .section__body__run {
  margin-top: var(--copy-flow-item-gap);
}

.section__body--flow > .section__list + .section__body__run,
.section__body--flow > .section__body__run + .section__list {
  margin-top: var(--copy-flow-item-gap);
}

.section__body__run > p.section__body__bullet {
  padding-left: 1.15rem;
}

.section__col p {
  text-align: justify;
}

.section__address {
  font-style: normal;
  margin-top: 1rem;
  color: var(--color-muted);
  text-align: justify;
}

.section__address a {
  font-weight: 600;
}

.section__cta {
  margin: 1.5rem 0 0;
}

.section__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem 1.5rem;
  margin-top: 1.35rem;
  align-items: center;
  justify-content: flex-start;
}

.section__inner:not(:has(.section__split-aside)) > .section__actions {
  justify-content: center;
}

.link-arrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-accent);
  transition: color 0.15s ease, opacity 0.15s ease;
}

.link-arrow:hover,
.link-arrow:focus-visible {
  color: var(--surface-brown);
  text-decoration: underline;
  outline: none;
}

.section.section--surface-brown .link-arrow,
.section.section--surface-muted .link-arrow,
.section.section--surface-darkRose .link-arrow {
  color: rgba(255, 255, 255, 0.9);
}

.section.section--surface-brown .link-arrow:hover,
.section.section--surface-brown .link-arrow:focus-visible,
.section.section--surface-muted .link-arrow:hover,
.section.section--surface-muted .link-arrow:focus-visible,
.section.section--surface-darkRose .link-arrow:hover,
.section.section--surface-darkRose .link-arrow:focus-visible {
  color: #fff;
}

.section__cta .link-arrow {
  margin-top: 0.25rem;
}

.btn {
  display: inline-block;
  padding: 0.65rem 1.35rem;
  background: var(--color-accent);
  color: var(--color-accent-contrast);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
  border-radius: var(--radius);
  text-align: center;
}

.btn:hover {
  filter: brightness(1.08);
}

.section__error {
  padding: 2rem;
  text-align: center;
  color: #8b2942;
}

.site-footer {
  padding: 2.5rem 1.25rem 1rem;
  text-align: center;
  font-size: 0.9rem;
  color: var(--color-muted);
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  background: var(--surface-footer);
}

.site-footer__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.site-footer__brand {
  margin: 1.15rem auto 0;
  line-height: 0;
  text-align: center;
}

.site-footer__logo {
  display: inline-block;
  width: auto;
  height: auto;
  max-width: min(32.2rem, 92vw);
  max-height: 20.7rem;
  object-fit: contain;
}

.site-footer__copy {
  margin: 1.25rem 0 0;
  font-size: 0.8rem;
  opacity: 0.85;
}

.site-footer__address {
  display: inline-block;
  margin: 0.35rem 0 0;
  max-width: 26rem;
  margin-inline: auto;
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 300;
  line-height: 1.35;
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.15s ease;
}

.site-footer__address:hover,
.site-footer__address:focus-visible {
  color: var(--surface-brown);
  text-decoration: underline;
  outline: none;
}

.site-footer__address[hidden] {
  display: none;
}

.site-footer__chips,
.site-footer__contact {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.15rem 0.5rem;
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.4;
  color: var(--color-accent);
}

.site-footer__chips:empty {
  display: none;
}

.site-footer__contact-sep {
  color: currentColor;
  opacity: 0.45;
  font-weight: 300;
  user-select: none;
}

.site-footer__link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: inherit;
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.15s ease;
}

.site-footer__link-icon {
  font-size: 1rem;
  line-height: 1;
  opacity: 0.85;
}

.site-footer__link-icon--whatsapp {
  display: inline-block;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  background-color: currentColor;
  mask-image: url("../images/icons/whatsapp-light.png");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-image: url("../images/icons/whatsapp-light.png");
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
}

.site-footer__link:hover,
.site-footer__link:focus-visible {
  color: var(--surface-brown);
  text-decoration: underline;
  outline: none;
}

.section--contact .section__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.section__contact-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  margin-top: 0;
  padding: 0.5rem 0;
  width: 100%;
  max-width: 26rem;
  text-align: center;
}

.section__contact-location {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.75rem;
  padding: 0.25rem 0;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.94);
  transition: color 0.15s ease, opacity 0.15s ease;
}

.section__contact-location:hover,
.section__contact-location:focus-visible {
  color: #fff;
  opacity: 0.95;
}

.section__contact-location__icon {
  flex-shrink: 0;
  margin-top: 0.1rem;
  font-size: 1.35rem;
  font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;
  opacity: 0.92;
}

.section__contact-location__text {
  font-family: var(--font-title);
  font-weight: 500;
  font-size: clamp(0.95rem, 2.1vw, 1.1rem);
  line-height: 1.45;
  letter-spacing: 0.01em;
  text-align: center;
}

.section__contact-directions {
  margin-top: 0.35rem;
}

.contact-back {
  display: inline-block;
  margin: 0 0 1.75rem;
  font-family: var(--font-title);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4;
  color: var(--color-muted);
  text-decoration: none;
  transition: color 0.15s ease;
}

.contact-back:hover,
.contact-back:focus-visible {
  color: var(--surface-brown);
}

body.page-contato main {
  min-height: auto;
}

body.page-contato #contato.section--contact > .section__inner {
  align-items: stretch;
  padding-top: 1rem;
  padding-bottom: 4rem;
}

.contact-page {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
}

.contact-page__stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100%;
  max-width: var(--content-measure);
  margin: 0 auto;
}

.contact-page__address {
  margin: 0;
  max-width: 26rem;
  font-family: var(--font-body);
  font-size: 1.02rem;
  font-weight: 300;
  line-height: 1.35;
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.15s ease;
}

.contact-page__address:hover,
.contact-page__address:focus-visible {
  color: var(--surface-brown);
  text-decoration: underline;
  outline: none;
}

.contact-page__channels {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
  margin-top: 1.1rem;
}

.contact-page__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-title);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.15s ease;
}

.contact-page__link:hover,
.contact-page__link:focus-visible {
  color: var(--surface-brown);
  text-decoration: underline;
}

.contact-page__map {
  width: 100%;
  max-width: 22rem;
  margin-top: 2rem;
  aspect-ratio: 4 / 3;
  min-height: 11rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.03);
}

.contact-page__map-iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.contact-page__directions {
  margin: 1rem 0 0;
  text-align: center;
}

#contato.section--surface-darkRose .contact-back {
  color: rgba(255, 255, 255, 0.72);
}

#contato.section--surface-darkRose .contact-back:hover,
#contato.section--surface-darkRose .contact-back:focus-visible {
  color: #fff;
}

#contato.section--surface-darkRose .contact-page__address {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--copy-body-size);
  line-height: var(--copy-body-lh);
  color: rgba(255, 255, 255, 0.9);
}

#contato.section--surface-darkRose .contact-page__address:hover,
#contato.section--surface-darkRose .contact-page__address:focus-visible {
  color: #fff;
}

#contato.section--surface-darkRose .contact-page__link {
  color: rgba(255, 255, 255, 0.9);
}

#contato.section--surface-darkRose .contact-page__link:hover,
#contato.section--surface-darkRose .contact-page__link:focus-visible {
  color: #fff;
}

#contato.section--surface-darkRose .contact-page__map {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(0, 0, 0, 0.15);
}

.whatsapp-fab {
  position: fixed;
  right: max(1rem, env(safe-area-inset-right));
  left: auto;
  bottom: max(1rem, env(safe-area-inset-bottom));
  z-index: 45;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.22);
  text-decoration: none;
  transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
}

.whatsapp-fab[hidden] {
  display: none;
}

.whatsapp-fab:hover,
.whatsapp-fab:focus-visible {
  filter: brightness(1.05);
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.26);
  outline: none;
}

.whatsapp-fab__icon {
  width: 1.75rem;
  height: 1.75rem;
}

.section__contact-extra {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.65rem;
  margin-top: 1.5rem;
  width: 100%;
  max-width: 26rem;
}

.section--contact.section--surface-brown .section__contact-icon {
  color: rgba(255, 255, 255, 0.9);
}

.section--contact.section--surface-brown .section__address--contact a {
  color: rgba(255, 255, 255, 0.94);
}

.section.section--surface-brown .pillar-card__label,
.section.section--surface-brown .pillar-card__cta {
  color: rgba(255, 255, 255, 0.88);
}

.section.section--surface-brown .pillar-card__cta:hover {
  color: #fff;
}

.section__contact-wa {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.section__contact-line {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
  margin: 0 0 0.65rem;
  text-align: left;
}

.section__contact-line:last-child {
  margin-bottom: 0;
}

.section__contact-icon {
  flex-shrink: 0;
  margin-top: 0.12rem;
  font-size: 1.25rem;
  color: var(--surface-brown);
}

.section--contact .section__contact-line {
  justify-content: center;
  text-align: center;
}

.section__address--contact {
  font-style: normal;
  text-align: left;
}

.section__address--contact .section__contact-line {
  text-align: left;
}

/* Surfaces: #865240 (4-15 exc. 6), #ffc4c6 (6), #9b9b9b (2,16,18) */
.section.section--surface-default {
  background-color: var(--color-surface);
  color: var(--color-text);
}

.section.section--surface-brown {
  background-color: var(--surface-brown);
  color: rgba(255, 255, 255, 0.94);
  border-block: 1px solid rgba(0, 0, 0, 0.08);
}

.section.section--surface-brown .section__title {
  color: #fff;
}

.section.section--surface-brown .section__body,
.section.section--surface-brown .section__body--rich,
.section.section--surface-brown .section__list {
  color: rgba(255, 255, 255, 0.88);
}

.section.section--surface-brown a {
  color: #ffe8d4;
}

.section.section--surface-brown .section__quote-text {
  color: rgba(255, 255, 255, 0.95);
}

.section.section--surface-brown .pillar-card {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.35);
  color: #fff;
}

.section.section--surface-brown .pillar-card:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: #fff;
}

.section.section--surface-brown .btn {
  background: #ffe8d4;
  color: #3d2418;
}

.section.section--surface-pink {
  background-color: var(--surface-pink);
  color: #1f1f1f;
  border-block: 1px solid rgba(134, 82, 64, 0.15);
}

.section.section--surface-pink .section__title:not(.copy-heading) {
  color: #3d2418;
}

.section.section--surface-pink .section__body,
.section.section--surface-pink .section__body--rich,
.section.section--surface-pink .section__list {
  color: #3a3330;
}

.section.section--surface-pink a {
  color: #6b3a2e;
}

.section.section--surface-pink .btn {
  background: var(--surface-brown);
  color: #fff;
}

.section.section--surface-darkRose {
  background-color: var(--surface-dark-rose);
  color: rgba(255, 255, 255, 0.94);
  border-block: 1px solid rgba(0, 0, 0, 0.12);
}

.section.section--surface-darkRose .section__title {
  color: #fff;
}

.section.section--surface-darkRose .section__body,
.section.section--surface-darkRose .section__body--rich,
.section.section--surface-darkRose .section__list {
  color: rgba(255, 255, 255, 0.9);
}

.section.section--surface-darkRose a {
  color: #ffd6e0;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.section.section--surface-darkRose .section__quote-text {
  color: rgba(255, 255, 255, 0.96);
}

.section.section--surface-darkRose .section__col {
  border-top-color: rgba(255, 255, 255, 0.4);
  color: rgba(255, 255, 255, 0.9);
}

.section.section--surface-darkRose .btn {
  background: #ffe8f0;
  color: #3d1f28;
}

.section.section--surface-muted {
  background-color: var(--surface-muted);
  color: rgba(255, 255, 255, 0.94);
  border-block: 1px solid rgba(0, 0, 0, 0.06);
}

.section.section--surface-muted .section__title:not(.copy-heading) {
  color: #fff;
}

.section.section--surface-muted .section__body,
.section.section--surface-muted .section__body--rich,
.section.section--surface-muted .section__list {
  color: rgba(255, 255, 255, 0.9);
}

.section.section--surface-muted a {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.section.section--surface-muted .section__quote-text {
  color: rgba(255, 255, 255, 0.96);
}

.section.section--surface-muted .section__col {
  border-top-color: rgba(255, 255, 255, 0.45);
  color: rgba(255, 255, 255, 0.9);
}

.section.section--surface-muted .btn {
  background: #fff;
  color: #333;
}

/* Sobre page — footer-tint sections, muted HR dividers, gray closing band */
body.page-sobre {
  --sobre-section-gap: calc(var(--section-pad-y) * 0.75);
  background: var(--surface-footer);
}

body.page-sobre main {
  background: var(--surface-footer);
}

body.page-sobre #sections-root > .section:not(#fechamento) {
  background-color: var(--surface-footer);
  color: var(--color-text);
  border-block: none;
}

body.page-sobre #sections-root > .section:not(#fechamento) .section__body,
body.page-sobre #sections-root > .section:not(#fechamento) .section__body--rich {
  color: var(--color-muted);
}

body.page-sobre #sobre .section__figure--aside,
body.page-sobre #sobre .section__figure--aside.section__figure--portrait {
  box-shadow: none;
}

body.page-sobre #sobre .section__split-aside__copy .section__body > p:first-child {
  color: var(--surface-brown);
}

body.page-sobre #sobre .section__split-aside__copy .section__body p:nth-child(2) {
  color: var(--surface-brown);
}

/* Sobre bands — color only (typography/spacing: Editorial copy block) */
body.page-sobre #proposito .section__title,
body.page-sobre #proposito .section__body-heading {
  color: var(--surface-brown);
}

body.page-sobre #proposito .section__body,
body.page-sobre #proposito .section__body--flow {
  color: var(--color-muted);
}

body.page-sobre #proposito .section__body--flow > .section__body-heading {
  margin-top: var(--copy-h2-space-before);
}

body.page-sobre #sections-root > .section > .section__inner {
  padding-top: var(--sobre-section-gap);
  padding-bottom: var(--sobre-section-gap);
}

body.page-sobre #sections-root > .section > .section__inner:has(> h2.section__title:first-child) {
  padding-top: var(--copy-h2-space-before);
}

body.page-sobre #sections-root > .section:first-child > .section__inner {
  padding-top: var(--section-pad-y);
}

body.page-sobre #proposito > .section__inner {
  padding-top: var(--section-pad-y);
}

body.page-sobre #sections-root > .section:last-child > .section__inner {
  padding-bottom: var(--section-pad-y);
}

body.page-sobre #sections-root .section__body,
body.page-sobre #sections-root .section__body--rich,
body.page-sobre #sections-root .section__body p,
body.page-sobre #sections-root .section__body__run,
body.page-sobre #sections-root .section__body__run > p {
  text-align: justify;
}

body.page-sobre #sections-root .section__title,
body.page-sobre #sobre .section__split-aside__copy .section__body > p:first-child,
body.page-sobre #sobre .section__split-aside__copy .section__body p:nth-child(2) {
  text-align: left;
}

body.page-sobre #fechamento.section--surface-muted {
  background-color: var(--surface-muted);
  color: rgba(255, 255, 255, 0.94);
  border-block: 1px solid rgba(0, 0, 0, 0.06);
}

body.page-sobre #fechamento .section__body--flow {
  max-width: min(42rem, 92vw);
  margin-inline: auto;
}

body.page-sobre #fechamento .section__body__run,
body.page-sobre #fechamento .section__body__run > p {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--copy-quote-size);
  font-style: italic;
  font-weight: 300;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.96);
  text-align: center;
  text-wrap: balance;
}

body.page-sobre #fechamento .section__body--flow > .copy-subheading {
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--copy-quote-size);
  font-style: italic;
  font-weight: 300;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.96);
  text-transform: none;
}

.section__split-aside__copy .section__list {
  margin-top: 1rem;
}

.faq-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  margin: 1.5rem auto 0;
  max-width: 48rem;
  width: 100%;
}

@media (min-width: 640px) {
  .faq-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.faq-grid__btn {
  margin: 0;
  padding: 1rem 0.75rem;
  font: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  text-align: center;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.faq-grid__btn:hover,
.faq-grid__btn:focus-visible {
  background: #faf0eb;
  border-color: var(--surface-brown);
  outline: none;
}

.faq-modal {
  max-width: min(34rem, 94vw);
  width: 100%;
  max-height: 90dvh;
  padding: 0;
  border: none;
  border-radius: var(--radius);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.28);
  overflow: hidden;
}

.faq-modal::backdrop {
  background: rgba(0, 0, 0, 0.45);
}

.faq-modal__inner {
  position: relative;
  padding: 1.75rem 1.5rem 1.5rem;
  max-height: 90dvh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.faq-modal__close {
  position: absolute;
  top: 0.65rem;
  right: 0.65rem;
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  font-size: 1.35rem;
  line-height: 1;
  color: var(--color-muted);
  background: transparent;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
}

.faq-modal__close:hover,
.faq-modal__close:focus-visible {
  color: var(--color-text);
  background: rgba(0, 0, 0, 0.06);
}

.faq-modal__title {
  margin: 0 2.25rem 1rem 0;
  font-family: var(--font-title);
  font-size: clamp(1.2rem, 3vw, 1.45rem);
  font-weight: 700;
  line-height: 1.25;
  text-align: left;
}

.faq-modal__body {
  margin: 0;
  color: var(--color-muted);
  font-size: 1rem;
  line-height: 1.55;
  text-align: justify;
  white-space: pre-wrap;
}

/* Full-bleed bands: 100vw causes horizontal scroll on narrow viewports */
@media (max-width: 899px) {
  .section.section--surface-brown,
  .section.section--surface-pink,
  .section.section--surface-muted,
  .section.section--surface-darkRose,
  .section--hero.section--surface-default,
  .section--hero.section--surface-muted {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

/* Mobile overrides — layout, overflow, images, tap targets */
@media (max-width: 767px) {
  .section__figure--aside:not(.section__figure--portrait) img {
    max-height: min(13.5rem, 36vh);
  }

  :is(#fertilidade-lista, #quem-atendemos, #metodo) .layout-split-aside .section__figure--aside img {
    width: 100%;
    max-width: none;
    max-height: none;
    aspect-ratio: 4 / 3;
    object-fit: cover;
  }

  #fertilidade-lista .layout-split-aside .section__figure--aside img {
    aspect-ratio: 3 / 2;
  }

  .section__figure--aside.section__figure--portrait img {
    max-width: min(12.5rem, 68vw);
    max-height: min(17rem, 48vh);
  }
}

/* Tratamentos — mobile pillar index (sticky below header after intro scrolls away) */
.tratamentos-pillar-nav {
  display: none;
}

@media (max-width: 640px) {
  html:has(body.page-tratamentos) {
    --tratamentos-pillar-nav-h: 0px;
    scroll-padding-top: calc(var(--header-h) + var(--tratamentos-pillar-nav-h) + 0.5rem);
  }

  body.page-tratamentos #fertilidade,
  body.page-tratamentos #gestacao,
  body.page-tratamentos #ginecologia {
    scroll-margin-top: calc(var(--header-h) + var(--tratamentos-pillar-nav-h) + 0.5rem);
  }

  body.page-tratamentos .tratamentos-pillar-nav:not([hidden]) {
    display: block;
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    z-index: 39;
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
      transform 0.2s ease,
      opacity 0.2s ease,
      visibility 0.2s ease;
  }

  body.page-tratamentos .tratamentos-pillar-nav.tratamentos-pillar-nav--visible {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .tratamentos-pillar-nav__inner {
    display: flex;
    background: var(--surface-brown);
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }

  .tratamentos-pillar-nav__link {
    flex: 1;
    min-width: 0;
    padding: 0.55rem 0.4rem;
    font-family: var(--font-sans);
    font-size: calc(0.62rem * var(--copy-mobile-scale));
    font-weight: 600;
    letter-spacing: 0.06em;
    line-height: 1.25;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
  }

  .tratamentos-pillar-nav__link--active {
    color: #fff;
    background: rgba(0, 0, 0, 0.14);
  }

  .tratamentos-pillar-nav__link:focus-visible {
    outline: 2px solid #fff;
    outline-offset: -2px;
  }
}

@media (max-width: 640px) {
  /* Shorter sticky header on phones (the logo also shrinks at this breakpoint).
     --header-h is a token, so anchor offsets, scroll-padding and the mobile menu
     position all follow automatically. */
  :root {
    --header-h: 4.75rem;
    --copy-h2-space-before: var(--section-pad-y-mobile);
    --copy-h2-size: calc(var(--copy-text-heading-size-mobile) + var(--copy-h2-extra));
    --copy-h2-cover-size: calc(var(--copy-text-heading-size-mobile) * 2 + var(--copy-h2-extra));
    --copy-body-lh: var(--copy-body-lh-mobile);
    --copy-title-lh: var(--copy-title-lh-mobile);
    --copy-hero-lead-lh: var(--copy-hero-lead-lh-mobile);
    --copy-title-size-mobile: calc(clamp(0.59rem, 2.31vw, 0.78rem) * var(--copy-mobile-scale));
    --copy-body-size-mobile: calc(clamp(1.12rem, 4.2vw, 1.35rem) * var(--copy-mobile-scale));
    --copy-hero-lead-size-mobile: calc(clamp(0.51rem, 2.43vw, 0.89rem) * var(--copy-mobile-scale));
    --copy-title-sub-size: calc(clamp(0.88rem, 1.75vw, 1.05rem) * var(--copy-mobile-scale));
    --copy-quote-size: calc(clamp(1.15rem, 2.5vw, 1.45rem) * var(--copy-mobile-scale));
    --copy-text-heading-size-mobile: calc(var(--copy-title-size-mobile) + 2pt);
    --copy-title-body-gap: calc(1.4rem * var(--copy-mobile-scale));
  }

  .section__inner {
    padding: var(--section-pad-y-mobile) max(var(--section-pad-x-mobile), env(safe-area-inset-left))
      var(--section-pad-y-mobile) max(var(--section-pad-x-mobile), env(safe-area-inset-right));
  }

  body.page-sobre {
    --sobre-section-gap: calc(var(--section-pad-y-mobile) * 0.75);
  }

  body.page-sobre #sections-root > .section > .section__inner {
    padding-top: var(--sobre-section-gap);
    padding-bottom: var(--sobre-section-gap);
  }

  body.page-sobre #sections-root > .section > .section__inner:has(> h2.section__title:first-child) {
    padding-top: var(--copy-h2-space-before);
  }

  body.page-sobre #sections-root > .section:first-child > .section__inner {
    padding-top: var(--section-pad-y-mobile);
  }

  body.page-sobre #proposito > .section__inner {
    padding-top: var(--section-pad-y-mobile);
  }

  body.page-sobre #sections-root > .section:last-child > .section__inner {
    padding-bottom: var(--section-pad-y-mobile);
  }

  .section--hero .section__inner,
  .section--contact .section__inner {
    padding-top: var(--section-pad-y-hero-mobile);
    padding-bottom: var(--section-pad-y-hero-mobile);
  }

  .section__inner:not(:has(.section__split-aside)) > .section__title,
  .section__inner:not(:has(.section__split-aside)) > .section__eyebrow,
  .section__title--multiline {
    max-width: var(--content-measure-rem);
  }

  :is(
    #preparo-natural,
    #fiv,
    #gestacao-corpo,
    #ginecologia-corpo,
    #atendimento-modalidades,
    #primeira-consulta,
    #proposito
  ) > .section__inner > .section__title {
    max-width: none;
  }

  body.page-home #estagios > .section__inner > .section__title {
    max-width: none;
  }

  .section__title {
    margin-bottom: 1rem;
    font-size: calc(clamp(1.4rem, 5.5vw, 1.85rem) * var(--copy-mobile-scale));
  }

  .section--pillars .section__title {
    margin-bottom: 1.15rem;
    font-size: calc(clamp(1.35rem, 4.5vw, 1.75rem) * var(--copy-mobile-scale));
  }

  :is(
    #tratamentos.section--pillars .section__title
  ) {
    line-height: var(--copy-title-lh-mobile);
  }

  #citacao .section__quote {
    max-width: 100%;
  }

  .section-diagram {
    width: 100%;
    margin-inline: 0;
    overflow: hidden;
  }

  .section-diagram__img {
    width: 100%;
    max-width: 100%;
  }

  .section__body p {
    margin-bottom: var(--copy-para-gap);
  }

  .section__body,
  .section__body--rich,
  .section__list,
  .section__list li,
  .section__address,
  .section__address--contact,
  .section__col p,
  .faq-modal__body {
    text-align: justify;
  }

  .section__site-subtitle,
  .section__site-subtitle__line {
    text-align: left;
  }

  #inicio.section--hero .section__inner {
    aspect-ratio: var(--cover-band-aspect-mobile);
    padding: clamp(1.5rem, 5vh, 2.5rem) max(var(--section-pad-x-mobile), env(safe-area-inset-left))
      clamp(1.5rem, 5vh, 2.5rem) max(var(--section-pad-x-mobile), env(safe-area-inset-right));
  }

  :is(#fertilidade, #gestacao, #ginecologia) .section__inner.layout-section-cover.section__inner--has-cover {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    aspect-ratio: var(--cover-band-aspect-mobile);
    padding: clamp(1.5rem, 5vh, 2.5rem) max(var(--section-pad-x-mobile), env(safe-area-inset-left))
      clamp(1.5rem, 5vh, 2.5rem) max(var(--section-pad-x-mobile), env(safe-area-inset-right));
  }

  #inicio .section__site-subtitle,
  #inicio .section__site-subtitle__line {
    text-align: center;
  }

  .layout-section-cover > .section__title,
  .layout-section-cover > .section__title.copy-heading,
  .section.section--surface-muted .layout-section-cover > .section__title {
    line-height: var(--copy-title-lh-mobile);
  }

  #inicio .section__site-subtitle__line--lead {
    font-size: calc(var(--copy-text-heading-size-mobile) * 2 - var(--copy-mobile-band-reduce));
    line-height: var(--copy-title-lh-mobile);
  }

  #inicio .section__site-subtitle__line:not(.section__site-subtitle__line--lead) {
    font-size: calc(
      clamp(0.94rem, 4.68vw, 1.72rem) * var(--copy-mobile-scale) - var(--copy-mobile-band-reduce)
    );
    line-height: var(--copy-title-lh-mobile);
  }

  .section__quote-text {
    font-size: var(--copy-quote-size);
    line-height: var(--copy-body-lh-mobile);
    text-align: left;
  }

  .section__split-aside {
    gap: 1.25rem;
  }

  .section__split-aside .section__title {
    max-width: 100%;
    text-align: left;
  }

  .section--about .layout-split-aside .section__split-aside__copy .section__body > p:first-child,
  .section--about .layout-split-aside .section__split-aside__copy .section__body > p:nth-child(2) {
    font-size: var(--copy-text-heading-size-mobile);
  }

  .layout-copy-column,
  .layout-split-aside,
  #fertilidade-lista {
    --copy-title-size: var(--copy-text-heading-size-mobile);
    --copy-body-size: var(--copy-body-size-mobile);
    --copy-body-lh: var(--copy-body-lh-mobile);
  }

  .section__body,
  .section__list {
    font-size: var(--copy-body-size-mobile);
    line-height: var(--copy-body-lh-mobile);
  }

  body.page-sobre #proposito .section__body,
  body.page-sobre #sobre .section__split-aside__copy .section__body p:nth-child(n + 3) {
    font-size: var(--copy-body-size-mobile);
    line-height: var(--copy-body-lh-mobile);
  }

  .layout-split-aside .section__split-aside__copy .section__body,
  .layout-split-aside .section__split-aside__copy .section__body p,
  .layout-split-aside .section__split-aside__copy .section__list li,
  .layout-copy-column .section__body,
  .layout-copy-column .section__body--flow,
  .layout-copy-column .section__body__run,
  .layout-copy-column .section__body__run > p,
  .layout-copy-column .section__list li,
  #metodo-cards .method-intro__line,
  #metodo-cards .method-card__text,
  #conectado > .section__inner > .section__body,
  #conectado .section__body p {
    font-size: var(--copy-body-size-mobile);
    line-height: var(--copy-body-lh-mobile);
  }

  #metodo-cards .method-intro {
    --method-intro-pad-b: calc(var(--section-pad-y-mobile) * 0.65);
    padding-top: calc(var(--method-intro-pad-b) * 2);
    padding-bottom: var(--method-intro-pad-b);
  }

  #metodo-cards .method-cards {
    gap: 0.85rem;
  }

  #metodo-cards .method-card {
    padding: calc(1rem * 1.5) calc(0.9rem * 1.5);
  }

  #metodo-cards .method-card__title {
    font-size: var(--copy-text-heading-size-mobile);
  }

  .logo__img {
    height: clamp(2.97rem, 13vw, 3.78rem);
    max-width: min(62vw, 14rem);
  }

  .nav-mobile {
    max-height: calc(100dvh - var(--header-h));
    overflow-y: auto;
  }

  .nav-mobile .nav-link {
    padding: 0.9rem 1rem 0.9rem 1.35rem;
    font-size: calc(1rem * var(--copy-mobile-scale));
  }

  .contact-page__address {
    font-size: calc(1.02rem * var(--copy-mobile-scale));
    line-height: var(--copy-body-lh-mobile);
  }

  .contact-page__link {
    font-size: calc(1rem * var(--copy-mobile-scale));
  }

  .site-footer {
    padding: 2rem max(var(--section-pad-x-mobile), env(safe-area-inset-left)) 0.75rem
      max(var(--section-pad-x-mobile), env(safe-area-inset-right));
    font-size: calc(0.9rem * var(--copy-mobile-scale));
  }

  .site-footer__copy {
    font-size: calc(0.8rem * var(--copy-mobile-scale));
  }

  .site-footer__chips,
  .site-footer__contact,
  .site-footer__address {
    font-size: calc(0.88rem * var(--copy-mobile-scale));
  }

  .layout-copy-column .section__body-heading:not(.section__title),
  .layout-copy-column .copy-subheading,
  .layout-copy-column h3.copy-subheading,
  .layout-copy-column .section__body > p > strong,
  .section__body--flow > .copy-subheading,
  .section__body--flow > .section__body-heading:not(.section__title) {
    font-size: var(--copy-text-heading-size-mobile);
    line-height: var(--copy-title-lh-mobile);
  }

  .whatsapp-fab {
    right: max(var(--section-pad-x-mobile), env(safe-area-inset-right));
  }

  .pillar-card {
    padding: 1.1rem 0.9rem;
  }

  .pillar-card__label {
    font-size: calc(0.68rem * var(--copy-mobile-scale));
  }

  .pillar-card__title {
    font-size: calc(clamp(1.05rem, 2.2vw, 1.2rem) * var(--copy-mobile-scale));
  }

  .pillar-card__cta {
    font-size: calc(0.78rem * var(--copy-mobile-scale));
  }

  .faq-grid__btn {
    min-height: 3rem;
    padding: 0.9rem 0.75rem;
    font-size: calc(0.95rem * var(--copy-mobile-scale));
    line-height: var(--copy-body-lh-mobile);
  }

  h2.section__title.copy-heading {
    line-height: var(--copy-title-lh-mobile);
  }

  :is(#fertilidade, #gestacao, #ginecologia) .layout-section-cover > h2.section__title.copy-heading {
    font-size: calc(var(--copy-h2-cover-size) - var(--copy-mobile-band-reduce));
    line-height: var(--copy-hero-lead-lh-mobile);
  }
}

/* Editorial H2 — one size (+3pt via --copy-h2-size). Cover pillars excluded below. */
h2.section__title.copy-heading {
  font-size: var(--copy-h2-size);
}

:is(#fertilidade, #gestacao, #ginecologia) .layout-section-cover > h2.section__title.copy-heading {
  font-size: var(--copy-h2-cover-size);
  line-height: var(--copy-hero-lead-lh);
}

/* H2 lead space — same band as #fiv (section inner pad when H2 opens the block) */
h2.section__title {
  margin-top: var(--copy-h2-space-before);
}

.section__inner > h2.section__title:first-child,
.section__inner.layout-copy-column > h2.section__title:first-child,
.section__inner.layout-section-cover > h2.section__title:first-child,
.layout-split-aside .section__split-aside__copy > h2.section__title:first-child {
  margin-top: 0;
}

/* Consistent focus ring on interactive surfaces */
.nav-link:focus-visible,
.pillar-card:focus-visible,
.btn:focus-visible,
.faq-grid__btn:focus-visible {
  outline: 2px solid var(--surface-brown);
  outline-offset: 2px;
}
