/* ============================================================
   Alejandra Gonzalez Rebolledo — estilos principales
   (index.html / sobre-mi.html)
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face {
  font-family: 'Sofia Pro';
  src: url('../fonts/SofiaPro-Light.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Mirage Regular';
  src: url('../fonts/MADE-Mirage-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* ---------- Theme tokens ---------- */
:root,
body.theme-default {
  --color-base: 255 255 255;
  --color-pearl: 219 226 234;
  --color-surface: 245 239 230;
  --color-wine: 122 74 43;
  --color-wine-dark: 94 56 32;
  --color-ink: 26 26 26;
  --color-body: 74 74 74;
  --color-brand: 139 125 107;
  --color-cta-bg: 138 90 58;
  --color-cta-bg-hover: 122 77 50;
  --color-menu-underline: 63 68 75;
  --color-highlight-bg: 138 90 58;
  --color-copy: 25 25 25;
  --color-on-primary: 255 255 255;
}

body.theme-serene {
  --color-base: 251 250 248;
  --color-pearl: 229 236 234;
  --color-surface: 240 236 230;
  --color-wine: 92 109 122;
  --color-wine-dark: 70 84 96;
  --color-ink: 31 42 50;
  --color-body: 73 84 93;
  --color-brand: 106 126 137;
  --color-cta-bg: 95 120 135;
  --color-cta-bg-hover: 73 95 109;
  --color-menu-underline: 95 120 135;
  --color-highlight-bg: 95 120 135;
  --color-copy: 38 48 56;
  --color-on-primary: 255 255 255;
}

/* Blanco + perla grisácea del CTA (229 236 234); acentos en la misma gama */
body.theme-pearl {
  --color-base: 255 255 255;
  --color-pearl: 229 236 234;
  --color-surface: 242 245 245;
  --color-wine: 92 106 116;
  --color-wine-dark: 72 86 96;
  --color-ink: 28 40 48;
  --color-body: 86 98 106;
  --color-brand: 100 114 124;
  --color-cta-bg: 86 102 114;
  --color-cta-bg-hover: 68 84 96;
  --color-menu-underline: 86 102 114;
  --color-highlight-bg: 86 102 114;
  --color-copy: 34 44 52;
  --color-on-primary: 255 255 255;
}

/* Blanco + acentos dorados/champagne (sustituye la perla fría por tonos cálidos) */
body.theme-gilded {
  --color-base: 255 255 255;
  --color-pearl: 250 243 228;
  --color-surface: 252 248 238;
  --color-wine: 118 98 72;
  --color-wine-dark: 92 76 56;
  --color-ink: 38 32 24;
  --color-body: 98 88 76;
  --color-brand: 154 132 92;
  --color-cta-bg: 132 104 58;
  --color-cta-bg-hover: 108 84 46;
  --color-menu-underline: 132 104 58;
  --color-highlight-bg: 132 104 58;
  --color-copy: 42 36 28;
  --color-on-primary: 255 255 255;
}

/* Premium “slate”: blanco puro + grises fríos y acento grafito */
body.theme-onyx {
  --color-base: 255 255 255;
  --color-pearl: 241 243 246;
  --color-surface: 247 248 250;
  --color-wine: 72 82 94;
  --color-wine-dark: 52 60 70;
  --color-ink: 18 24 32;
  --color-body: 82 90 100;
  --color-brand: 88 98 112;
  --color-cta-bg: 38 48 62;
  --color-cta-bg-hover: 28 36 48;
  --color-menu-underline: 38 48 62;
  --color-highlight-bg: 38 48 62;
  --color-copy: 26 32 40;
  --color-on-primary: 255 255 255;
}

/* Premium “navy”: blanco + azul petróleo y acentos zafiro */
body.theme-sapphire {
  --color-base: 255 255 255;
  --color-pearl: 236 240 247;
  --color-surface: 242 245 252;
  --color-wine: 62 82 108;
  --color-wine-dark: 44 60 82;
  --color-ink: 16 28 48;
  --color-body: 72 86 108;
  --color-brand: 72 96 128;
  --color-cta-bg: 36 58 92;
  --color-cta-bg-hover: 26 44 72;
  --color-menu-underline: 36 58 92;
  --color-highlight-bg: 36 58 92;
  --color-copy: 24 36 56;
  --color-on-primary: 255 255 255;
}

/* ---------- Reset (alineado con Tailwind preflight) ---------- */
*,
*::before,
*::after {
  box-sizing: border-box;
  border: 0 solid currentColor;
}

html {
  scroll-behavior: smooth;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
  /* Mínimos tipo referencia (inmente: hero ~75vh + mucho padding; aquí 100dvh para que no “encoja”).
     --section-min-fill: hero / about / reserva, descontando header fijo.
     --section-min-block: bloques de pantalla completa (sobre-mí, servicios…). */
  --site-header-offset: 7.5rem;
  --section-min-fill: max(37.5rem, calc(100dvh - var(--site-header-offset)));
  --section-min-block: max(37.5rem, 100dvh);
  --story-carousel-desktop-h: min(75dvh, 52rem);
}

/* Móvil / tablet: la barra (.site-nav con padding 1rem + marca + icono) mide bastante menos que 7.5rem;
   un #menu-container tan alto dejaba una franja vacía bajo el header fijo. */
@media (max-width: 1023px) {
  html {
    --site-header-offset: calc(5rem + env(safe-area-inset-top, 0px));
  }
}

body {
  margin: 0;
  line-height: inherit;
  min-height: 100dvh;
}

h1, h2, h3, h4, h5, h6,
p, figure, blockquote, dl, dd, pre, hr {
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
}

ul, ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  font: inherit;
  color: inherit;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}

img, svg, video {
  display: block;
  max-width: 100%;
}

img {
  height: auto;
}

strong {
  font-weight: 600;
}

/* ---------- Base ---------- */
body {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-weight: 200;
  color: rgb(var(--color-ink));
  background-color: rgb(var(--color-base));
}

/* ---------- Helpers tipograficos preservados ---------- */
.font-display {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  font-weight: 400;
}

.font-mirage {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
}

.font-allura {
  font-family: 'Allura', cursive;
}

.presentacion-title {
  line-height: 1.4em;
}

/* ============================================================
   Header / navegacion (compartido)
   ============================================================ */
.site-header {
  width: 100%;
  position: static;
}

#menu-container {
  min-height: 0;
}

@media (max-width: 1023px) {
  .site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    /* Blanco sólido: mismo tono que el panel del menú desplegado (#FFFFFF). */
    background-color: #ffffff;
    box-shadow: 0 0 0 rgb(0 0 0 / 0);
    transition: box-shadow 0.2s ease;
  }

  .site-header.is-scrolled {
    box-shadow: 0 2px 6px rgb(0 0 0 / 0.06);
  }

  /* Capa por encima del contenido (p. ej. tarifas con min-height 100vh) para que el desplegable móvil siempre pinte encima en WebKit. */
  #menu-container {
    min-height: var(--site-header-offset);
    position: relative;
    z-index: 100;
  }
}

.site-nav {
  max-width: 1500px;
  margin-inline: auto;
  padding: 1rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media (min-width: 1024px) {
  .site-nav {
    padding: 2rem 3.5rem;
  }
}

.site-nav__brand {
  font-family: 'Dancing Script', cursive;
  font-weight: 400;
  color: #7a4d32;
  font-size: 36px;
  line-height: 40px;
  letter-spacing: normal;
  transition: opacity 0.25s ease;
}

.site-nav__brand:hover,
.site-nav__brand:focus-visible {
  opacity: 0.9;
}

@media (max-width: 1023px) {
  .site-nav__brand {
    flex: 1 1 auto;
    min-width: 0;
    max-width: calc(100% - 3.25rem);
    font-size: clamp(1.2rem, 4vw + 0.45rem, 2.15rem);
    line-height: 1.1;
    white-space: nowrap;
  }
}

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgb(var(--color-ink));
}

@media (min-width: 1024px) {
  .menu-toggle { display: none; }
}

/* Lista de navegacion desktop */
.site-nav__list {
  display: none;
}

@media (min-width: 1024px) {
  .site-nav__list {
    display: flex;
    align-items: center;
    gap: 2.5rem;
    font-size: 14px;
    letter-spacing: 0.18em;
    color: rgb(var(--color-ink));
    font-weight: 500;
  }
}

@media (min-width: 1280px) {
  .site-nav__list { gap: 3.5rem; }
}

.site-nav__link {
  position: relative;
  display: inline-block;
  padding-bottom: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1px;
  color: inherit;
  transition: color 0.25s ease;
}

.site-nav__link:hover,
.site-nav__link:focus-visible {
  color: rgb(var(--color-wine));
}

.site-nav__link.is-active,
.site-nav__link[aria-current="page"] {
  color: rgb(var(--color-wine));
}

.site-nav__link::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0;
  height: 0;
  opacity: 0;
  background-color: rgb(var(--color-menu-underline));
  transition: all 0.3s cubic-bezier(0.58, 0.3, 0.005, 1);
}

.site-nav__link:hover::after,
.site-nav__link:focus-visible::after {
  left: 0;
  width: 100%;
  height: 1px;
  opacity: 1;
}

.site-nav__link.is-active::after,
.site-nav__link[aria-current="page"]::after {
  left: 0;
  width: 100%;
  height: 1px;
  opacity: 1;
}

/* CTA del nav (desktop) */
.site-nav__cta {
  display: inline-block;
  background-color: rgb(var(--color-cta-bg));
  color: rgb(var(--color-on-primary));
  padding: 10px 16px;
  border-radius: 15px;
  line-height: 1;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1px;
  transform: translateY(-3px);
  transition: background-color 0.25s ease, opacity 0.25s ease;
}

.site-nav__cta:hover,
.site-nav__cta:focus-visible {
  background-color: rgb(var(--color-cta-bg-hover));
  color: rgb(var(--color-on-primary));
  opacity: 1;
}

/* Menu mobile */
.mobile-menu {
  position: relative;
  z-index: 2;
  display: none;
  flex-direction: column;
  gap: 1rem;
  padding: 0 2rem 1.5rem;
  font-size: 14px;
  letter-spacing: 0.18em;
  font-weight: 500;
  background-color: #ffffff;
}

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

@media (max-width: 1023px) {
  .mobile-menu.is-open {
    border-bottom: 1px solid rgb(var(--color-ink) / 0.1);
    box-shadow: 0 6px 18px -6px rgb(0 0 0 / 0.14);
  }
}

@media (min-width: 1024px) {
  .mobile-menu,
  .mobile-menu.is-open {
    display: none;
  }
}

.mobile-menu__link {
  display: block;
  padding: 0.85rem 0;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(1.125rem, 4.2vw, 1.375rem);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  line-height: 1.35;
  color: inherit;
}

.mobile-menu__link.is-active,
.mobile-menu__link[aria-current="page"] {
  color: rgb(var(--color-wine));
}

.mobile-menu__cta {
  display: block;
  text-align: center;
  background-color: rgb(var(--color-cta-bg));
  color: rgb(var(--color-on-primary));
  padding: 12px 16px;
  border-radius: 15px;
  line-height: 1;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(1.125rem, 4.2vw, 1.375rem);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  transition: background-color 0.25s ease;
}

.mobile-menu__cta:hover,
.mobile-menu__cta:focus-visible {
  background-color: rgb(var(--color-cta-bg-hover));
  color: rgb(var(--color-on-primary));
}

/* ============================================================
   Botones reutilizables
   ============================================================ */
.btn-primary {
  display: inline-block;
  margin-top: 2.5rem;
  background-color: rgb(var(--color-wine));
  color: white;
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 600;
  padding: 1rem 2rem;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  transition: background-color 0.25s ease, color 0.25s ease;
}

.btn-primary:hover,
.btn-primary:focus-visible {
  background-color: rgb(var(--color-wine-dark));
  color: white;
}

.btn-primary--upper {
  text-transform: uppercase;
}

/* ============================================================
   Hero (index.html)
   ============================================================ */
.hero {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(2.75rem, 9vmin, 4rem);
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
}

@media (max-width: 1023px) {
  .hero {
    align-items: flex-start;
    min-height: 0;
    padding-block: clamp(0.5rem, 2vmin, 1rem) clamp(1.5rem, 5vmin, 2.5rem);
  }

  .hero__grid {
    gap: 0;
  }

  /* ~1/3 superior bajo el navbar; ~1/5 inferior solapada por el texto (márgenes % ≈ proporción de altura en 1:1). */
  .hero__media {
    margin-top: -33%;
    margin-bottom: -20%;
    position: relative;
    z-index: 0;
  }

  .hero .hero__content {
    transform: translateY(-12px);
  }
}

@media (min-width: 1024px) {
  .hero {
    padding-inline: 3.5rem;
  }

  .hero .hero__content {
    margin-left: -1rem;
  }
}

.hero__grid {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2.5rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .hero__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 4rem;
  }
}

.hero__media {
  width: 100%;
}

.hero__media--zoom {
  overflow: hidden;
}

.hero__media-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 1 / 1;
  box-shadow: none;
}

.hero__media-img--zoom {
  transform: scale(1.22);
  transform-origin: left center;
}

.hero__content {
  position: relative;
  z-index: 10;
  transform: translateY(-25px);
}

.hero__eyebrow {
  font-family: 'Be Vietnam Pro', sans-serif;
  color: rgb(var(--color-ink));
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 1rem;
}

@media (min-width: 640px) {
  .hero__eyebrow { font-size: 12px; }
}

@media (min-width: 1024px) {
  .hero__eyebrow { margin-bottom: 1.25rem; }
}

@media (max-width: 1023px) {
  .hero .hero__eyebrow {
    font-size: 9px;
    letter-spacing: 0.1em;
    white-space: nowrap;
  }
}

@media (max-width: 360px) {
  .hero .hero__eyebrow {
    font-size: 8px;
    letter-spacing: 0.06em;
  }
}

.hero__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-weight: 300;
  font-size: 2.25rem;
  line-height: 2.5rem;
}

@media (min-width: 640px) {
  .hero__title {
    font-size: 3rem;
    line-height: 1;
  }
}

@media (min-width: 1024px) {
  .hero__title { font-size: 3.6rem; }
}

@media (min-width: 1280px) {
  .hero__title { font-size: 4.2rem; }
}

/* Móvil / tablet estrecha: cada frase del hero en una sola línea, tamaño fluido (prioriza ancho útil; tope más alto que antes). */
@media (max-width: 1023px) {
  .hero .hero__title {
    font-size: clamp(0.76rem, 5.25vw + 0.48rem, 3rem);
    line-height: 1.12;
    width: 100%;
    max-width: 100%;
  }

  .hero .hero__title-line {
    white-space: nowrap;
  }

  .hero .hero__highlight-wrap {
    display: block;
    width: 100%;
    max-width: 100%;
  }

  .hero .hero__highlight-wrap .title-highlight {
    font-size: clamp(0.76rem, 5.25vw + 0.48rem, 3rem);
    line-height: 1.12;
    white-space: nowrap;
    text-wrap: unset;
    padding: 0.25rem 0.35rem;
    max-width: 100%;
    box-sizing: border-box;
  }
}

.hero__title-line {
  display: block;
}

.hero__highlight-wrap {
  margin-top: 0;
  display: inline-block;
  max-width: 100%;
  padding-block: 0.625rem;
}

@media (min-width: 640px) {
  .hero__highlight-wrap { padding-block: 0.75rem; }
}

@media (min-width: 1024px) {
  .hero__highlight-wrap { padding-block: 1rem; }
}

/* Highlight inline reutilizable (hero index + about-hero sobre-mi) */
.title-highlight {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  /* En mobile permitimos que el texto se ajuste para evitar desbordamiento
     horizontal; desde 640px hay espacio suficiente y volvemos a nowrap. */
  white-space: normal;
  text-wrap: balance;
  padding: 0.25rem 1rem;
  color: white;
  font-weight: 300;
  font-size: 2.25rem;
  line-height: 2.5rem;
}

@media (min-width: 640px) {
  .title-highlight {
    padding: 0.375rem 1.25rem;
    font-size: 3rem;
    line-height: 1;
  }
}

@media (min-width: 1024px) {
  .title-highlight {
    padding: 0.375rem 1.5rem;
    font-size: 3.6rem;
  }
}

/* Mantener el highlight del hero en una sola línea en desktop ancho. */
@media (min-width: 1280px) {
  .hero .hero__highlight-wrap .title-highlight {
    white-space: nowrap;
  }
}

@media (min-width: 1280px) {
  .title-highlight { font-size: 4.2rem; }
}

/* Copy del hero (estilo "Raquel"): cuerpo del bloque introductorio */
.hero-copy-raquel {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 19px;
  line-height: 32px;
  font-weight: 400;
  color: rgb(var(--color-copy));
  margin-top: 2.5rem;
  border-left: 1px solid rgb(var(--color-ink) / 0.4);
  padding-left: 1.5rem;
  max-width: 36rem;
}

/* Hero index: unos px más de ancho útil para que el 2.º párrafo no pase a 5 líneas por “necesidades.” solo en la última. */
.hero .hero-copy-raquel {
  max-width: calc(36rem + 40px);
}

.hero-copy-raquel > * + * {
  margin-top: 1.25rem;
}

/* Animacion del highlight (replica del runtime: Tailwind sobreescribia inline-block) */
.hero-highlight-grow {
  display: inline-block;
  border-radius: 15px;
  background-image: linear-gradient(
    transparent 0%,
    rgb(var(--color-highlight-bg)) 0%,
    rgb(var(--color-highlight-bg)) 100%,
    transparent 100%
  );
  background-repeat: no-repeat;
  background-position: left 0;
  background-size: 0 100%;
  animation: hero-highlight-grow 1.1s ease-out 0.2s forwards;
}

@keyframes hero-highlight-grow {
  0% {
    background-size: 0 100%;
    background-position-x: left;
  }
  100% {
    background-size: 100% 100%;
    background-position-x: left;
  }
}

/* Solapamiento del titulo en pantallas grandes (preservado) */
@media (min-width: 1024px) {
  .hero-title-overlap {
    margin-left: -11rem;
  }
}

/* ============================================================
   Welcome Intro (index.html)
   ============================================================ */
.welcome-intro {
  padding: clamp(2.5rem, 8vmin, 4rem) clamp(1.5rem, 5vw, 2rem);
  background-color: rgb(var(--color-surface));
  min-height: var(--section-min-fill);
  display: flex;
  align-items: center;
}

@media (min-width: 1024px) {
  .welcome-intro {
    padding-inline: 3.5rem;
  }
}

.welcome-intro__grid {
  max-width: 1500px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .welcome-intro__grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: 3rem;
  }
}

.welcome-intro__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  color: rgb(var(--color-wine));
  font-weight: 400;
  font-size: clamp(2.35rem, 5vw, 3.6rem);
  line-height: 1.05;
  margin-bottom: 1.25rem;
  text-decoration: underline;
  text-decoration-color: rgb(var(--color-wine) / 0.45);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

.welcome-intro__title .story-block__title-line,
.welcome-intro__title .story-block__title-line--shout {
  white-space: normal;
}

.welcome-intro__title .story-block__title-line--shout {
  letter-spacing: 0.04em;
}

@media (min-width: 1024px) {
  .welcome-intro__title--overlap {
    position: relative;
    z-index: 4;
    margin-right: -7rem;
    width: max-content;
    max-width: min(100%, 17ch);
  }
}

.welcome-intro__content {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  color: rgb(var(--color-copy));
  font-size: clamp(1.05rem, 1.6vw, 1.2rem);
  line-height: 1.8;
}

.welcome-intro__content > * + * {
  margin-top: 1rem;
}

.welcome-intro__media {
  display: flex;
  justify-content: center;
}

.welcome-intro__img {
  width: 100%;
  max-width: 34rem;
  height: clamp(24rem, 62vh, 44rem);
  display: block;
  object-fit: contain;
  box-shadow: none;
}

/* ============================================================
   Especialidades (index.html)
   ============================================================ */
.especialidades {
  max-width: 1500px;
  margin-inline: auto;
  padding: 5rem 2rem;
}

@media (min-width: 1024px) {
  .especialidades {
    padding: 7rem 3.5rem;
  }
}

.especialidades__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 3rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .especialidades__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 5rem;
  }
}

.especialidades__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-weight: 300;
  font-size: 1.875rem;
  line-height: 2.25rem;
}

@media (min-width: 640px) {
  .especialidades__title {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
}

@media (min-width: 1024px) {
  .especialidades__title {
    font-size: 3rem;
    line-height: 1;
  }
}

.especialidades__badge-wrap {
  margin-top: 1rem;
  display: inline-block;
  background-color: rgb(var(--color-wine));
  padding: 0.75rem 1.5rem;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
}

@media (min-width: 1024px) {
  .especialidades__badge-wrap {
    padding: 1rem 2rem;
  }
}

.especialidades__badge {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  color: white;
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0.025em;
}

@media (min-width: 640px) {
  .especialidades__badge { font-size: 1.875rem; }
}

@media (min-width: 1024px) {
  .especialidades__badge { font-size: 2.25rem; }
}

@media (min-width: 1280px) {
  .especialidades__badge { font-size: 3rem; }
}

.especialidades__copy {
  margin-top: 2.5rem;
  color: rgb(var(--color-body));
  font-size: 15px;
  line-height: 1.625;
  max-width: 36rem;
}

.especialidades__copy > * + * {
  margin-top: 1.25rem;
}

.especialidades__list {
  margin-top: 3rem;
  max-width: 36rem;
  border-top: 1px solid rgb(var(--color-wine) / 0.4);
}

.especialidades__item {
  border-bottom: 1px solid rgb(var(--color-wine) / 0.4);
}

.especialidades__link {
  display: block;
  padding: 1.25rem 0;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 600;
  text-transform: uppercase;
  color: rgb(var(--color-ink));
  transition: color 0.25s ease;
}

.especialidades__link:hover,
.especialidades__link:focus-visible {
  color: rgb(var(--color-wine));
}

.especialidades__media {
  width: 100%;
}

.especialidades__media-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

/* ============================================================
   Contacto (index.html)
   ============================================================ */
.contacto {
  background-color: rgb(var(--color-pearl));
}

.contacto__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding: clamp(3.5rem, 9vmin, 6rem) 2rem;
}

@media (min-width: 1024px) {
  .contacto__inner {
    padding-inline: 3.5rem;
  }
}

.contacto__center {
  container-type: inline-size;
  container-name: contacto;
  max-width: 64rem;
  margin-inline: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.contacto__eyebrow {
  font-family: 'Be Vietnam Pro', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-wine));
  margin-bottom: 1.25rem;
}

.contacto__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  color: rgb(var(--color-ink));
  font-weight: 300;
  line-height: 1.05;
  margin: 1.5rem 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.contacto__title-script {
  font-style: italic;
  font-weight: inherit;
  color: rgb(var(--color-body));
  letter-spacing: 0;
  line-height: 1.1;
  font-size: 1.875rem;
}

.contacto__title-shout {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-weight: inherit;
  line-height: 1.05;
  font-size: 2.25rem;
}

@media (min-width: 640px) {
  .contacto__title-script {
    font-size: 2.25rem;
  }

  .contacto__title-shout {
    font-size: 3rem;
  }
}

@media (min-width: 1024px) {
  .contacto__title-script {
    font-size: 3rem;
  }

  .contacto__title-shout {
    font-size: 3.75rem;
  }
}

@media (min-width: 1280px) {
  .contacto__title-shout {
    font-size: 4.2rem;
  }
}

.contacto__copy {
  margin-top: 1.75rem;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 19px;
  line-height: 32px;
  font-weight: 400;
  color: rgb(var(--color-copy));
  max-width: 38rem;
}

.contacto__copy > * + * {
  margin-top: 1.25rem;
}

.contacto__copy strong {
  color: rgb(var(--color-wine));
  font-weight: 600;
}

@media (max-width: 639.98px) {
  .contacto__copy-br {
    display: none;
  }
}

.contacto__cta {
  margin-top: 2rem;
  text-transform: uppercase;
}

.contacto__microcopy {
  margin-top: 1.25rem;
  font-family: 'Be Vietnam Pro', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  font-size: 11px;
  font-weight: 500;
  color: rgb(var(--color-wine) / 0.85);
}

/* ============================================================
   Footer (compartido)
   ============================================================ */
.site-footer {
  background-color: rgb(var(--color-surface));
}

.site-footer--bordered {
  border-top: 1px solid rgb(var(--color-wine) / 0.4);
}

.site-footer__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding: 2.5rem 2rem;
}

@media (min-width: 1024px) {
  .site-footer__inner {
    padding: 2.5rem 3.5rem;
  }
}

.site-footer__row {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .site-footer__row {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}

.site-footer__col {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.site-footer__col--end {
  gap: 1rem;
}

@media (min-width: 1024px) {
  .site-footer__col--end {
    align-items: flex-end;
  }
}

.social {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.social__link {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 9999px;
  background-color: rgb(var(--color-wine));
  color: white;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.25s ease;
}

.social__link:hover,
.social__link:focus-visible {
  background-color: rgb(var(--color-wine-dark));
}

.legal-links {
  display: flex;
  flex-wrap: wrap;
  column-gap: 1.5rem;
  row-gap: 0.5rem;
  font-size: 12px;
  letter-spacing: 0.18em;
  font-weight: 500;
  color: rgb(var(--color-ink));
}

.legal-links a {
  transition: color 0.25s ease;
}

.legal-links a:hover,
.legal-links a:focus-visible {
  color: rgb(var(--color-wine));
}

.contact-block__email {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  font-weight: 400;
  color: rgb(var(--color-wine));
  font-size: 1.5rem;
  transition: color 0.25s ease;
  /* Permite romper el email si no cabe (evita scroll horizontal en mobile). */
  overflow-wrap: anywhere;
}

@media (min-width: 768px) {
  .contact-block__email { font-size: 1.875rem; }
}

@media (min-width: 1024px) {
  .contact-block__email { font-size: 2.25rem; }
}

/* 1024–1500px: el email largo no cabe a 2.25rem; escala en una sola línea. */
@media (min-width: 1024px) and (max-width: 1499.98px) {
  .contact-block__email {
    white-space: nowrap;
    overflow-wrap: normal;
    font-size: clamp(1.25rem, 0.5rem + 1.6vw, 2.25rem);
  }
}

.contact-block__email:hover,
.contact-block__email:focus-visible {
  color: rgb(var(--color-wine-dark));
}

.contact-block__credit {
  font-size: 12px;
  color: rgb(var(--color-ink) / 0.8);
}

/* ============================================================
   About hero (sobre-mi.html)
   ============================================================ */
.about-hero {
  background-color: rgb(var(--color-base));
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(2.75rem, 9vmin, 4rem);
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
}

.services-hero--fullheight {
  min-height: var(--section-min-block);
}

.about-hero--surface {
  position: relative;
  /* El ancho sigue limitado por .about-hero; el fondo beige va a todo el viewport */
  background-color: transparent;
  /* Recorta el pseudo full-bleed (width: 100vw) para que no genere
     scroll horizontal cuando la barra vertical reduce el viewport. */
  overflow-x: clip;
}

.about-hero--surface::before {
  content: "";
  position: absolute;
  z-index: 0;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  background-color: rgb(var(--color-surface));
  pointer-events: none;
}

.about-hero--surface > * {
  position: relative;
  z-index: 1;
}

.about-hero--surface .about-hero__media {
  background-color: rgb(var(--color-surface));
}

.about-hero--surface .about-hero__portrait {
  background: rgb(var(--color-surface));
}

.about-hero .story-block__title {
  margin: 0;
}

@media (min-width: 1024px) {
  .about-hero {
    padding-inline: 3.5rem;
  }
}

/* Sobre mí / Servicios (móvil / tablet): hero a pantalla completa centrado en vertical dejaba mucho hueco bajo el header fijo; alineamos arriba y reducimos padding superior. */
@media (max-width: 1023px) {
  body.page-sobre-mi #servicios.about-hero,
  body.page-servicios #servicios.about-hero {
    align-items: flex-start;
    /* Aprovecha parte del espaciador del header fijo (como `.booking`). */
    margin-top: -0.85rem;
    padding-top: clamp(0.2rem, 1.5vmin, 0.65rem);
    padding-bottom: clamp(2.75rem, 9vmin, 4rem);
  }
}

.about-hero__grid {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2.5rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .about-hero__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 4rem;
  }

  .about-hero__grid--image-right .about-hero__media {
    order: 2;
    z-index: 1;
  }

  .about-hero__grid--image-right .about-hero__content {
    order: 1;
  }
}

.about-hero__media {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgb(var(--color-base));
  width: 100%;
}

.about-hero__portrait {
  width: min(30rem, 94vw);
  max-width: 100%;
  aspect-ratio: 1;
  margin-block: 0;
  margin-inline: auto;
  overflow: hidden;
  flex-shrink: 0;
  background: rgb(var(--color-base));
}

.about-hero__portrait-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
}

@media (min-width: 1024px) {
  .about-hero__media {
    justify-content: flex-start;
  }

  .about-hero__portrait {
    width: min(38rem, 52vw);
    margin-inline: 0;
  }
}

.about-hero__content {
  position: relative;
  z-index: 10;
  padding-left: 0;
  padding-right: 0;
  /* Ancho real de columna para fluid type (título «Soy…» móvil) */
  container-type: inline-size;
  container-name: about-hero-content;
}

.about-hero__title {
  position: relative;
  z-index: 20;
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-weight: 300;
  font-size: 2.25rem;
  line-height: 2.5rem;
}

@media (min-width: 640px) {
  .about-hero__title {
    font-size: 3rem;
    line-height: 1;
  }
}

@media (min-width: 1024px) {
  .about-hero__title { font-size: 3.6rem; }
}

@media (min-width: 1280px) {
  .about-hero__title { font-size: 4.2rem; }
}

.about-hero__title-line {
  display: block;
}

/* Sobre mí (móvil): «Soy» + nombre en una línea; sombreado solo en el nombre */
@media (max-width: 639px) {
  .about-hero__title:has(.about-hero__title-lead) {
    /* Fallback sin cqi: techo bajo para no salirse del viewport */
    font-size: clamp(1.45rem, 3.5vw + 0.7rem, 2.05rem);
    line-height: 1.2;
  }

  @supports (font-size: 1cqi) {
    .about-hero__title:has(.about-hero__title-lead) {
      /* % del ancho real de columna (`.about-hero__content`) */
      font-size: clamp(1.45rem, 6.5cqi + 0.55rem, 2.05rem);
    }
  }

  .about-hero__title:has(.about-hero__title-lead) .title-highlight {
    font-size: inherit;
    line-height: inherit;
    white-space: nowrap;
    text-wrap: unset;
    padding-inline: 0.65rem;
  }

  .about-hero__title-lead {
    display: inline-block;
    max-width: 100%;
    white-space: nowrap;
  }
}

/* Copy del about-hero (replica `.servicios-raquel .hero-copy-raquel`) */
.about-hero__copy {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 19px;
  line-height: 1.68;
  font-weight: 400;
  color: rgb(var(--color-copy));
  margin-top: 2.5rem;
  border-left: 1px solid rgb(var(--color-ink) / 0.4);
  padding-left: 1.5rem;
  max-width: 760px;
}

.about-hero__copy p {
  margin-bottom: 0.55em;
}

.about-hero__copy > * + * {
  margin-top: 1.25rem;
}

.about-hero__copy--no-divider {
  border-left: 0;
  padding-left: 0;
}

@media (max-width: 1280px) {
  .about-hero__copy {
    font-size: 18px;
  }
}

@media (max-width: 1023px) {
  .about-hero__copy {
    font-size: 19px;
    line-height: 1.45;
  }
}

/* Fila de CTAs del about-hero (CTA primario + secundario) */
.about-hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-top: 2.5rem;
}

.about-hero__cta-row .btn-primary,
.about-hero__cta-row .btn-ghost {
  margin-top: 0;
}

@media (max-width: 480px) {
  .about-hero__cta-row {
    gap: 0.75rem;
  }

  .about-hero__cta-row .btn-primary,
  .about-hero__cta-row .btn-ghost {
    width: 100%;
    text-align: center;
  }
}

/* ============================================================
   Sobre mí (index.html · #sobre-mi con vídeo vertical)
   ============================================================ */
.about-mi {
  background-color: rgb(var(--color-base));
}

.about-mi__grid {
  align-items: center;
}

@media (min-width: 1024px) {
  .about-mi__grid {
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: 4.5rem;
  }
}

.about-mi__media {
  background-color: transparent;
}

/* Contenedor del vídeo en formato vertical (9:16) */
.about-mi__video-portrait {
  width: min(22rem, 88vw);
  max-width: 100%;
  aspect-ratio: 9 / 16;
  margin-inline: auto;
  overflow: hidden;
  background: rgb(var(--color-surface));
  position: relative;
}

.about-mi__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* VideoAsk embebido (sustituye al vídeo local en #sobre-mi) */
.about-mi__videoask-portrait {
  width: min(22rem, 88vw);
  max-width: 100%;
  margin-inline: auto;
  overflow: hidden;
  border-radius: 1.5rem;
  background: rgb(var(--color-surface));
}

.about-mi__videoask {
  display: block;
  width: 100%;
  height: clamp(22rem, 58svh, 36rem);
  border: 0;
  border-radius: 1.5rem;
}

@media (min-width: 1024px) {
  .about-mi__videoask-portrait {
    width: min(26rem, 90%);
    margin-inline: 0;
  }

  .about-mi__videoask {
    /* Más alto que en móvil: el widget suele pedir ~700–800px; capamos para no desbordar la rejilla */
    height: clamp(28rem, 68svh, 44rem);
  }
}

.about-mi__video-play {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5.75rem;
  height: 5.75rem;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
  pointer-events: none;
  z-index: 2;
}

.about-mi__video-play::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-40%, -50%);
  width: 0;
  height: 0;
  border-top: 0.9rem solid transparent;
  border-bottom: 0.9rem solid transparent;
  border-left: 1.4rem solid rgb(var(--color-wine));
}

@media (min-width: 1024px) {
  .about-mi__media {
    justify-content: center;
  }

  .about-mi__video-portrait {
    width: min(26rem, 90%);
    margin-inline: 0;
  }
}

/* Eyebrow "Sobre mí" alineado al estilo del bloque */
.about-mi__eyebrow {
  margin-bottom: 0.85rem;
}

/* Título: misma tipografía que el resto de secciones (story-block__title) */
.about-mi__title {
  margin: 0;
  line-height: 1.05;
}

.about-mi__title .story-block__title-line {
  display: inline;
  white-space: normal;
}

.about-mi__title-script {
  display: inline;
  font-family: 'Dancing Script', cursive;
  color: rgb(var(--color-wine));
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1;
  font-size: 3.25rem;
  margin-top: 0;
  margin-left: 0.35rem;
}

@media (min-width: 640px) {
  .about-mi__title-script { font-size: 4.25rem; }
}

@media (min-width: 1024px) {
  .about-mi__title-script { font-size: 5.5rem; }
}

@media (min-width: 1280px) {
  .about-mi__title-script { font-size: 6.25rem; }
}

.about-mi__divider {
  margin-top: 1.75rem;
}

.about-mi__copy {
  margin-top: 2rem;
}

.about-mi__stats-row {
  display: flex;
  align-items: flex-start;
  gap: 3rem;
  margin-top: 2.5rem;
}

.about-mi__cta-row {
  margin-top: 0;
  flex: 0 0 auto;
}

/* Estadísticas (mismo lenguaje tipográfico que landing-steps) */
.about-mi__stats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  max-width: 32rem;
  flex: 1 1 auto;
}

.about-mi__stat {
  text-align: left;
}

.about-mi__stat-num {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 300;
  color: rgb(var(--color-wine));
  font-size: 2.25rem;
  line-height: 1;
  margin: 0;
}

@media (min-width: 1024px) {
  .about-mi__stat-num { font-size: 2.75rem; }
}

.about-mi__stat-label {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', 'Montserrat', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(var(--color-copy));
  margin: 0.5rem 0 0;
  line-height: 1.3;
}

/* Vista tablet/móvil y paneles estrechos: CTA arriba, métricas debajo (evita solapamiento). */
@media (max-width: 1023px) {
  .about-mi__stats-row {
    flex-direction: column;
    align-items: stretch;
    gap: 2rem;
  }

  .about-mi__cta-row {
    align-self: flex-start;
  }

  .about-mi__stats {
    gap: 1rem;
    width: 100%;
    max-width: none;
  }
}

@media (max-width: 480px) {
  .about-mi__stat-label {
    font-size: 10px;
    letter-spacing: 0.14em;
  }
}

/* ============================================================
   Story block (sobre-mi.html: experiencias-dificiles, artes-marciales)
   ============================================================ */
.story-block {
  min-height: var(--section-min-block);
  background-color: rgb(var(--color-base));
}

.story-block--surface {
  background-color: rgb(var(--color-surface));
}

.story-block--cta {
  background-color: rgb(var(--color-pearl));
}

.story-block--cta .story-block__title--wine,
.story-block--cta .story-block__copy {
  color: rgb(var(--color-copy));
}

.story-block--cta .story-block__divider {
  border-top-color: rgb(var(--color-ink) / 0.2);
}

/* Centra el bloque en altura dentro de --section-min-block (p. ej. servicios: Peritaje, Talleres) */
.story-block--center-content {
  display: flex;
  flex-direction: column;
}

.story-block--center-content .story-block__inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (min-width: 1024px) {
  .story-block--center-content .story-block__grid {
    align-items: center;
  }
}

.story-block__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding: clamp(3.75rem, 11vmin, 5rem) clamp(1.5rem, 5vw, 2rem);
}

@media (min-width: 1024px) {
  .story-block__inner {
    padding: 5rem 3.5rem;
  }
}

.story-block__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2.5rem;
  align-items: flex-start;
}

@media (min-width: 1024px) {
  .story-block__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 5rem;
  }
}

.story-block__media {
  width: 100%;
}

/* Móvil / tablet: sin foto lateral en bloques texto+imagen (no afecta rejillas tipo terapia). */
@media (max-width: 1023.98px) {
  .story-block__media:not(.story-block__media-grid) {
    display: none !important;
  }
}

.story-block__media-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.story-block__media-img--taller {
  aspect-ratio: 4 / 5;
  object-fit: contain;
  background-color: rgb(var(--color-sand-light));
}


.story-block__media-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  perspective: 1200px;
}

.story-block__media-grid-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  display: block;
  object-fit: cover;
  box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.therapy-card {
  position: relative;
  aspect-ratio: 1 / 1;
  min-height: 0;
}

.therapy-card__inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.6s ease;
}

.therapy-card__face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
}

.therapy-card__face--back {
  transform: rotateY(180deg);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.8rem;
  padding: 1rem;
  background: rgb(var(--color-surface));
  border: 1px solid rgb(var(--color-wine) / 0.2);
  box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.therapy-card__title {
  margin: 0;
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  color: rgb(var(--color-wine));
  font-size: 1.6rem;
  line-height: 1.1;
  text-align: center;
}

.therapy-card__list {
  margin: 0;
  width: 100%;
  max-width: 19rem;
  padding-left: 1.2rem;
  list-style: disc;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 0.95rem;
  line-height: 1.45;
  color: rgb(var(--color-copy));
}

.therapy-card__list li + li {
  margin-top: 0.35rem;
}

/* Flip en táctil: la clase .therapy-grid--tap la asigna JS (hover:none o pointer:coarse) */
.story-block__media-grid.therapy-grid--tap .therapy-card {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.story-block__media-grid.therapy-grid--tap .therapy-card.is-flipped .therapy-card__inner {
  transform: rotateY(180deg);
}

.story-block__media-grid.therapy-grid--tap.has-open-card .therapy-card:not(.is-flipped) {
  filter: grayscale(1);
}

/* Terapia individual (servicios): cuadrícula estática; color solo en la tarjeta activa.
   El grid es siempre cuadrado (aspect-ratio 1:1) — condición necesaria para que la celda
   activa sea también cuadrada cuando cols y filas usan las mismas fracciones. */
.story-block__media-grid--with-tabs {
  perspective: none;
  aspect-ratio: 1 / 1;
  width: 100%;
  height: auto;
  grid-template-rows: 1fr 1fr;
  min-height: 0;
  transition: grid-template-columns 0.5s ease, grid-template-rows 0.5s ease;
}

.story-block__media-grid--with-tabs .therapy-card {
  overflow: hidden;
  aspect-ratio: auto;
  min-height: 0;
  min-width: 0;
  height: 100%;
}

.story-block__media-grid--with-tabs .therapy-card__image {
  filter: grayscale(1);
  transition: filter 0.4s ease;
  width: 100%;
  height: 100%;
  min-height: 0;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: center;
}

/* Ajuste de encuadre para la imagen de adultos (sujeto en zona superior) */
#therapy-card-adultos .therapy-card__image {
  object-position: top center;
}

.story-block__media-grid--with-tabs .therapy-card.is-therapy-active .therapy-card__image {
  filter: grayscale(0);
}

/* Celda activa cuadrada: mismas fracciones en cols y filas → activa = 65% × 65% del total */
/* Adultos = col 1, fila 1 */
.story-block__media-grid--with-tabs[data-active-therapy="adultos"] {
  grid-template-columns: 1.3fr 0.7fr;
  grid-template-rows: 1.3fr 0.7fr;
}
/* Jóvenes = col 2, fila 1 */
.story-block__media-grid--with-tabs[data-active-therapy="jovenes"] {
  grid-template-columns: 0.7fr 1.3fr;
  grid-template-rows: 1.3fr 0.7fr;
}
/* Adolescentes = col 1, fila 2 */
.story-block__media-grid--with-tabs[data-active-therapy="adolescentes"] {
  grid-template-columns: 1.3fr 0.7fr;
  grid-template-rows: 0.7fr 1.3fr;
}
/* Especialidades = col 2, fila 2 */
.story-block__media-grid--with-tabs[data-active-therapy="especialidades"] {
  grid-template-columns: 0.7fr 1.3fr;
  grid-template-rows: 0.7fr 1.3fr;
}

/* Terapia individual: mismo margen bajo el hr que .story-block__copy (p. ej. terapia de pareja) */
.terapia-individual .story-block__divider + .therapy-copy-panels {
  margin-top: 2.5rem;
}

/* Terapia individual (servicios): layout de dos columnas en escritorio */
@media (min-width: 1024px) {
  .terapia-individual .story-block__grid {
    align-items: center;
    gap: clamp(2.25rem, 3.5vw, 3.5rem);
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  }

  .terapia-individual .story-block__media.story-block__media-grid--with-tabs {
    gap: clamp(0.75rem, 1.2vw, 1rem);
  }

  /* Los 4 tabs siempre en una sola fila en escritorio */
  .terapia-individual .therapy-inline-nav {
    flex-wrap: nowrap;
  }
}

/* Terapia individual (servicios): variante estática — mosaico 2×2 a color */
.terapia-individual__photo-mosaic {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: clamp(0.5rem, 1.2vw, 0.75rem);
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: min(100%, 28rem);
  margin-inline: auto;
}

.terapia-individual__photo-mosaic-img {
  width: 100%;
  height: 100%;
  min-height: 0;
  min-width: 0;
  display: block;
  object-fit: cover;
  object-position: center;
  aspect-ratio: 1 / 1;
  box-shadow: none;
  filter: none;
}

.terapia-individual__photo-mosaic-img:only-child {
  grid-column: 1 / -1;
  grid-row: 1 / -1;
  aspect-ratio: unset;
}

@media (min-width: 1024px) {
  .terapia-individual .terapia-individual__photo-mosaic {
    max-width: none;
    margin-inline: 0;
  }
}

/* Escritorio con ratón: hover + foco por teclado */
@media (hover: hover) and (pointer: fine) {
  .story-block__media-grid:not(.therapy-grid--tap):not(.story-block__media-grid--with-tabs):hover .therapy-card {
    filter: grayscale(1);
  }

  .story-block__media-grid:not(.therapy-grid--tap):not(.story-block__media-grid--with-tabs) .therapy-card:hover,
  .story-block__media-grid:not(.therapy-grid--tap):not(.story-block__media-grid--with-tabs) .therapy-card:focus-within {
    filter: grayscale(0);
  }

  .story-block__media-grid:not(.therapy-grid--tap):not(.story-block__media-grid--with-tabs) .therapy-card:hover .therapy-card__inner,
  .story-block__media-grid:not(.therapy-grid--tap):not(.story-block__media-grid--with-tabs) .therapy-card:focus-within .therapy-card__inner {
    transform: rotateY(180deg);
  }
}

/* Menú horizontal de perfiles (terapia individual, servicios) */
.therapy-inline-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0.35rem 0.5rem;
  margin-top: clamp(1rem, 2.5vw, 1.5rem);
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
  max-width: 100%;
}

.therapy-inline-nav__sep {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-weight: 400;
  font-size: clamp(0.75rem, 1.8vw, 0.9rem);
  color: rgb(var(--color-ink) / 0.35);
  user-select: none;
}

.therapy-inline-nav__tab {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-weight: 600;
  font-size: clamp(0.7rem, 1.6vw, 0.8125rem);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgb(var(--color-ink));
  background: transparent;
  border: 0;
  padding: 0.65rem 0.75rem;
  cursor: pointer;
  transition: background-color 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
  border-radius: 2px;
  white-space: nowrap;
}

.therapy-inline-nav__tab:hover:not(.is-active) {
  color: rgb(var(--color-wine));
}

.therapy-inline-nav__tab:focus-visible {
  outline: 2px solid rgb(var(--color-wine));
  outline-offset: 2px;
}

/* Misma base visual que .btn-primary */
.therapy-inline-nav__tab.is-active {
  background-color: rgb(var(--color-wine));
  color: white;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
}

.therapy-inline-nav__tab.is-active:hover,
.therapy-inline-nav__tab.is-active:focus-visible {
  background-color: rgb(var(--color-wine-dark));
  color: white;
}

/* Misma fila que los tabs, pero solo texto (sin sombra ni estado activo) */
.therapy-inline-nav--static {
  margin-top: 0;
}

#formacion-experiencia .therapy-inline-nav--static {
  margin-top: -0.75rem;
  margin-bottom: 1rem;
}

.therapy-inline-nav--static .therapy-inline-nav__tab--static {
  display: inline-block;
  cursor: default;
  pointer-events: none;
  box-shadow: none;
  background: transparent;
  color: rgb(var(--color-ink));
  transition: none;
}

.therapy-inline-nav--static .therapy-inline-nav__tab--static:hover,
.therapy-inline-nav--static .therapy-inline-nav__tab--static:focus-visible {
  color: rgb(var(--color-ink));
  background: transparent;
  box-shadow: none;
  outline: none;
}

/* Fila corta (p. ej. Adultos | Jóvenes | Adolescentes): una sola línea en móvil */
@media (max-width: 1023px) {
  .therapy-inline-nav--single-line {
    flex-wrap: nowrap;
    gap: 0.2rem 0.3rem;
    min-width: 0;
  }

  .therapy-inline-nav--single-line .therapy-inline-nav__tab--static {
    padding: 0.45rem 0.35rem;
    font-size: clamp(0.58rem, 2.85vw, 0.75rem);
    letter-spacing: 0.1em;
  }

  .therapy-inline-nav--single-line .therapy-inline-nav__sep {
    font-size: clamp(0.55rem, 2.5vw, 0.85rem);
    flex-shrink: 0;
  }
}

/* Texto descriptivo sincronizado con pestañas (terapia individual, servicios) */
.therapy-copy-panels {
  margin-top: 0;
  margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
  max-width: 36rem;
}

.therapy-copy-panel__intro {
  margin: 0;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 19px;
  line-height: 32px;
  font-weight: 400;
  color: rgb(var(--color-copy));
}

.therapy-copy-panel__list-title {
  margin: 1.25rem 0 0.65rem;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(0.9375rem, 2.1vw, 1.0625rem);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgb(var(--color-ink) / 0.72);
}

.therapy-copy-panel__list {
  margin: 0;
  padding-left: 1.2rem;
  list-style: disc;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(1.0625rem, 2.5vw, 1.1875rem);
  line-height: 1.55;
  color: rgb(var(--color-copy));
}

.therapy-copy-panel__list li + li {
  margin-top: 0.4rem;
}

/* Acordeón de especialidades (terapia > pestaña Especialidades) */
.therapy-specialty-accordion {
  margin-top: 1.25rem;
  max-width: 36rem;
  border-top: 1px solid rgb(var(--color-wine) / 0.4);
}

.therapy-specialty-accordion__item {
  border-bottom: 1px solid rgb(var(--color-wine) / 0.4);
}

.therapy-specialty-accordion__trigger {
  display: block;
  width: 100%;
  margin: 0;
  padding: 1.25rem 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 600;
  text-transform: uppercase;
  color: rgb(var(--color-ink));
  transition: color 0.25s ease;
}

.therapy-specialty-accordion__trigger:hover,
.therapy-specialty-accordion__trigger:focus-visible {
  color: rgb(var(--color-wine));
}

.therapy-specialty-accordion__trigger:focus-visible {
  outline: 2px solid rgb(var(--color-wine));
  outline-offset: 2px;
}

.therapy-specialty-accordion__item.is-open .therapy-specialty-accordion__trigger {
  color: rgb(var(--color-wine));
}

.therapy-specialty-accordion__panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.35s ease;
}

.therapy-specialty-accordion__item.is-open .therapy-specialty-accordion__panel {
  grid-template-rows: 1fr;
}

.therapy-specialty-accordion__panel-inner {
  min-height: 0;
  overflow: hidden;
}

.therapy-specialty-accordion__list {
  margin: 0 0 1.25rem;
  padding-top: 0.15rem;
}

@media (prefers-reduced-motion: reduce) {
  .therapy-specialty-accordion__panel {
    transition: none;
  }
}

@media (max-width: 1023px) {
  .therapy-card__face--back {
    padding: 0.75rem;
  }

  .therapy-card__title {
    font-size: 1.35rem;
  }

  .therapy-card__list {
    font-size: 0.82rem;
    line-height: 1.35;
  }
}

/* En lg, el bloque "Artes marciales" invierte el orden: imagen a la izquierda */
@media (min-width: 1024px) {
  .story-block--reverse .story-block__media {
    order: 1;
  }
  .story-block--reverse .story-block__content {
    order: 2;
  }
}

.story-block__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  color: rgb(var(--color-ink));
  line-height: 1.4em;
  font-size: 2.25rem;
}

@media (min-width: 640px) {
  .story-block__title { font-size: 3rem; }
}

@media (min-width: 1024px) {
  .story-block__title { font-size: 3.75rem; }
}

/* Titulo solapado sobre la imagen (servicios.html) */
@media (min-width: 1024px) {
  .story-block__title--overlap {
    position: relative;
    z-index: 12;
  }

  .story-block__title--overlap-right {
    margin-right: -7.5rem;
  }

  .story-block__title--overlap-left {
    margin-left: -7.5rem;
  }
}

.story-block__title--wine {
  color: rgb(var(--color-wine));
}

.story-block__title-line {
  display: block;
  white-space: nowrap;
}

.story-block__title-line--shout {
  display: block;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}

/* En mobile (<640px) los títulos no caben en una línea: permitimos
   envolver para evitar scroll horizontal. Desde 640px se restablece
   el comportamiento de diseño (una sola línea). */
@media (max-width: 639.98px) {
  .story-block__title-line,
  .story-block__title-line--shout {
    white-space: normal;
    text-wrap: balance;
  }
}

@media (min-width: 1024px) {
  .story-block__title-line--shout {
    display: inline-block;
    margin-right: -8rem;
    position: relative;
    z-index: 10;
  }
}

/* 1024–1500px: el shout con margen negativo desborda la columna o invade la imagen.
   Reducimos solo el shout para mantener una línea sin tocar el tamaño fuera de esta franja. */
@media (min-width: 1024px) and (max-width: 1499.98px) {
  .story-block__title-line--shout {
    display: block;
    margin-right: 0;
    max-width: 100%;
    white-space: nowrap;
    font-size: clamp(2.125rem, 1rem + 2.2vw, 3.75rem);
  }
}

.story-block__divider {
  margin-top: 0;
  border: 0;
  border-top: 1px solid rgb(var(--color-ink) / 0.2);
}

.story-block__copy {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 19px;
  line-height: 32px;
  font-weight: 400;
  color: rgb(var(--color-copy));
  margin-top: 2.5rem;
  max-width: 36rem;
}

.story-block__copy > * + * {
  margin-top: 1.5rem;
}

.story-block__values-list {
  list-style: disc;
  padding-left: 1.5rem;
  margin-top: 1.5rem;
  margin-left: 0;
}

.story-block__values-list li {
  margin-left: 1rem;
}

.story-block__values-list li + li {
  margin-top: 0.9rem;
}

/* Carrusel horizontal (sobre-mí: experiencias + artes marciales) */
.story-carousel.story-block {
  /* Altura mínima: mantiene presencia visual sin recortar contenido en pantallas bajas. */
  min-height: var(--story-carousel-desktop-h);
  height: auto;
  max-height: none;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  overflow: visible;
}

.story-carousel .story-block__inner {
  padding-block: 2rem;
}

.story-carousel.story-carousel--viewport-centered {
  min-height: 100dvh;
}


@media (min-width: 1024px) {
  .story-carousel .story-block__inner {
    padding-block: 2.5rem;
  }

  .story-carousel.story-carousel--viewport-centered {
    min-height: 100dvh;
  }

  .story-carousel.story-carousel--viewport-centered .story-carousel__viewport {
    justify-content: center;
  }

  .story-carousel.story-carousel--viewport-centered .story-carousel__slide {
    display: flex;
    align-items: center;
  }

  .story-carousel.story-carousel--viewport-centered .story-block__inner {
    width: 100%;
    padding-block: clamp(2rem, 4vh, 3.5rem);
  }
}

.story-carousel__viewport {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  width: 100%;
  max-width: 100%;
  touch-action: pan-y;
  cursor: grab;
}

.story-carousel__viewport.is-story-dragging {
  cursor: grabbing;
  user-select: none;
}

.story-carousel__track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  flex: 1 1 auto;
  min-height: 0;
  width: 200%;
  max-width: none;
  transition: transform 0.55s ease;
  will-change: transform;
}

.story-carousel__slide {
  flex: 0 0 50%;
  width: 50%;
  min-width: 0;
  max-width: 50%;
  min-height: 0;
  height: auto;
  align-self: stretch;
  box-sizing: border-box;
  overflow-x: hidden;
  overflow-y: hidden;
}

/* Móvil: altura según contenido (sin imagen lateral ni relleno tipo pantalla completa). */
@media (max-width: 1023px) {
  .story-carousel.story-block {
    height: auto;
    max-height: none;
    min-height: unset;
  }

  .story-carousel.story-carousel--viewport-centered {
    min-height: unset;
  }

  .story-carousel__viewport {
    flex: 0 1 auto;
  }

  /* Track: sin estirar todas las slides a la altura de la más larga (p. ej. Valores vs Experiencias). */
  .story-carousel__track {
    flex: 0 1 auto;
    align-items: flex-start;
  }

  .story-carousel__slide {
    align-self: flex-start;
  }
}

/* Desktop: la altura de la fila la marca solo el texto+botón; la imagen recorta (cover) en esa caja. */
@media (min-width: 1024px) {
  .story-carousel .story-block__grid {
    display: block;
    position: relative;
    box-sizing: border-box;
  }

  .story-carousel .story-carousel__slide:not(.story-carousel__slide--reverse) .story-block__grid {
    padding-right: calc(50% + 2.5rem);
  }

  .story-carousel .story-carousel__slide--reverse .story-block__grid {
    padding-left: calc(50% + 2.5rem);
  }

  .story-carousel .story-block__media {
    position: absolute;
    top: 0;
    width: calc(50% - 2.5rem);
    height: 100%;
    overflow: hidden;
    margin: 0;
  }

  .story-carousel .story-carousel__slide:not(.story-carousel__slide--reverse) .story-block__media {
    right: 0;
    left: auto;
  }

  .story-carousel .story-carousel__slide--reverse .story-block__media {
    left: 0;
    right: auto;
  }

  .story-carousel .story-block__media-img {
    width: 100%;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .story-carousel .story-block__media-img.story-block__media-img--taller {
    object-fit: contain;
  }

  .story-carousel .story-carousel__slide--media-tall .story-block__grid {
    min-height: clamp(30rem, 54vw, 40rem);
  }

}

.story-carousel__arrow {
  position: absolute;
  top: 50%;
  z-index: 3;
  transform: translateY(-50%);
  width: 3rem;
  height: 3rem;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  color: rgb(var(--color-wine));
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.story-carousel__arrow:hover {
  opacity: 0.85;
  transform: translateY(-50%) scale(1.06);
}

.story-carousel__arrow:focus-visible {
  outline: 2px solid rgb(var(--color-wine));
  outline-offset: 4px;
}

.story-carousel__arrow--prev {
  left: 0.35rem;
}

.story-carousel__arrow--next {
  right: 0.35rem;
}

@media (min-width: 1024px) {
  .story-carousel__arrow--prev {
    left: 1rem;
  }

  .story-carousel__arrow--next {
    right: 1rem;
  }

  /* Flechas del viewport (sobre-mí): triángulos un poco más grandes en escritorio. */
  .story-carousel__viewport > .story-carousel__arrow {
    width: 3.5rem;
    height: 3.5rem;
  }

  .story-carousel__viewport > .story-carousel__arrow .story-carousel__triangle--left {
    border-width: 0.8rem 1.25rem 0.8rem 0;
  }

  .story-carousel__viewport > .story-carousel__arrow .story-carousel__triangle--right {
    border-width: 0.8rem 0 0.8rem 1.25rem;
  }
}

.story-carousel__triangle {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
}

.story-carousel__triangle--left {
  border-width: 0.65rem 1rem 0.65rem 0;
  border-color: transparent currentColor transparent transparent;
}

.story-carousel__triangle--right {
  border-width: 0.65rem 0 0.65rem 1rem;
  border-color: transparent transparent transparent currentColor;
}

@media (max-width: 639px) {
  .story-carousel__arrow {
    width: 2.25rem;
    height: 2.25rem;
  }

  .story-carousel__triangle--left {
    border-width: 0.5rem 0.75rem 0.5rem 0;
  }

  .story-carousel__triangle--right {
    border-width: 0.5rem 0 0.5rem 0.75rem;
  }
}

/* Foto solo en móvil, entre copy y CTA (p. ej. slide «Experiencias»); en escritorio sigue la columna .story-block__media. */
.story-carousel__inline-photo {
  display: none;
  margin: 0;
}

/* Carrusel sobre-mí: en <lg las flechas van junto al título y al CTA (no flotan sobre el texto). */
@media (max-width: 1023.98px) {
  .story-carousel__viewport > .story-carousel__arrow {
    display: none !important;
  }

  .story-carousel__head-row,
  .story-carousel__cta-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    justify-items: center;
    column-gap: 0.35rem;
  }

  .story-carousel__head-row {
    margin-bottom: 0.25rem;
  }

  /* Sin imagen lateral: el copy tiene max-width global; centrado en el ancho disponible. */
  .story-carousel .story-block__copy {
    margin-inline: auto;
  }

  .story-carousel__head-row .story-block__title {
    text-align: center;
    min-width: 0;
    width: 100%;
    /* Más compacto que el título global: cabe en ~2 líneas con flechas a los lados. */
    font-size: clamp(1.28rem, 3.2vw + 0.62rem, 1.95rem);
    line-height: 1.18;
  }

  /* Primera línea puede envolver; la “shout” en una sola línea → 2 líneas totales típicas. */
  .story-carousel__head-row .story-block__title-line--shout {
    white-space: nowrap;
  }

  .story-carousel__inline-photo {
    display: block;
    width: 100%;
    margin-top: clamp(1.25rem, 3vw, 2rem);
  }

  .story-carousel__inline-photo-img {
    width: 100%;
    display: block;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: center;
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  }

  .story-carousel__inline-photo + .story-carousel__cta-row {
    margin-top: clamp(1rem, 2.5vw, 1.5rem);
  }

  .story-carousel__cta-row {
    margin-top: clamp(1.5rem, 4vw, 2.5rem);
  }

  /* El margen superior del botón desalinea las flechas respecto al centro del rectángulo. */
  .story-carousel__cta-row .btn-primary {
    margin-top: 0;
  }

  .story-carousel__arrow--in-slide {
    position: static;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
  }

  .story-carousel__arrow--in-slide:hover {
    opacity: 0.85;
    transform: scale(1.06);
  }

  .story-carousel__arrow--in-slide:focus-visible {
    transform: scale(1.06);
  }
}

/* Pantallas muy estrechas: títulos shout largos no deben desbordar. */
@media (max-width: 359.98px) {
  .story-carousel__head-row .story-block__title-line--shout {
    white-space: normal;
    text-wrap: balance;
  }
}

@media (min-width: 1024px) {
  .story-carousel__arrow--in-slide {
    display: none !important;
  }
}

/* ============================================================
   Sobre mí: Formación / Experiencia (pestañas + panel)
   ============================================================ */
.fe-split.story-block {
  min-height: var(--section-min-block);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.fe-split .story-block__inner.fe-split__inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 0;
}

.fe-split {
  --fe-gold: #9a7b4f;
  --fe-gold-line: rgb(184 148 63 / 0.45);
  --fe-tab-hover-bg: rgb(var(--color-surface));
}

.fe-split__inner.story-block__inner {
  /* Misma caja que `.about-hero` para que padding y centro coincidan con el hero */
  max-width: 1500px;
  padding-top: clamp(2.75rem, 9vmin, 4rem);
  padding-bottom: clamp(2.75rem, 9vmin, 4rem);
}

.fe-split__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(2.5rem, 5vw, 4rem);
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
  padding-inline: clamp(0.25rem, 1.5vw, 0.75rem);
  align-items: start;
  flex: 0 0 auto;
  min-height: 0;
}

.fe-split__hero-title {
  margin: 0 0 clamp(1.25rem, 3vw, 2rem);
}

.fe-split__hero-title.about-hero__title {
  margin-left: 0;
}

.fe-split__title-row {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  margin-bottom: clamp(0.5rem, 1.4vw, 0.9rem);
}

.fe-split__title-row .fe-split__hero-title {
  margin-bottom: 0;
}

.fe-split__hero-prefix {
  white-space: pre;
}

@media (min-width: 1024px) {
  .fe-split__grid {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.15fr);
    column-gap: clamp(3.25rem, 8vw, 7rem);
    /* Padding horizontal ya en `.story-block__inner`; alinea con el hero */
    padding-inline: 0;
  }
}

/* Sobre mí (#formacion): móvil — estadísticas tras los dos primeros párrafos; CTA al cierre */
@media (max-width: 1023px) {
  #formacion.fe-split .fe-split__grid {
    display: flex;
    flex-direction: column;
    /* Menos aire entre bloques reordenados; el gap grande + márgenes de copy/nav
       separaba demasiado título → colegiatura → primer párrafo. */
    gap: clamp(1.25rem, 3.5vw, 2rem);
    align-items: stretch;
    width: 100%;
  }

  #formacion.fe-split .fe-split__aside,
  #formacion.fe-split .fe-split__panels,
  #formacion.fe-split .fe-split__panel {
    display: contents;
  }

  #formacion .fe-split__title-row {
    order: 1;
    width: 100%;
    margin-bottom: 0.25rem;
  }

  #formacion .fe-split__aside > .therapy-inline-nav {
    order: 2;
    width: 100%;
    margin-top: 0;
    margin-bottom: 0.5rem;
  }

  #formacion .fe-split__aside > .about-hero__copy {
    order: 3;
    width: 100%;
    margin-top: 0.75rem;
  }

  #formacion .fe-split__panel > .about-hero__copy.about-hero__copy--no-divider {
    order: 4;
    width: 100%;
    /* Evita sumar el margin-top global de `.about-hero__copy` (2.5rem) al `gap` del flex. */
    margin-top: 0.5rem;
  }

  /* El `.about-mi__stats-row` lleva margin-top 2.5rem: en móvil quedaba mucho aire antes de los números. */
  #formacion .fe-split__panel > .about-hero__copy--no-divider .about-mi__stats-row {
    margin-top: 0;
  }

  #formacion .fe-split__panel > .about-hero__copy:not(.about-hero__copy--no-divider) {
    order: 5;
    width: 100%;
    margin-top: 0.75rem;
  }

  #formacion .fe-split__aside > .fe-split__cta-wrap {
    order: 6;
    width: 100%;
    /* El `.btn-primary` lleva margin-top global (2.5rem) + el wrap su propio margin;
       en móvil eso dejaba un hueco enorme respecto al último párrafo del panel. */
    margin-top: 0;
  }

  #formacion .fe-split__aside > .fe-split__cta-wrap .btn-primary {
    margin-top: 0;
  }
}

.fe-split__tabs {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 28rem;
  border-top: 1px solid var(--fe-gold-line);
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
}

.fe-split__tab {
  display: block;
  width: 100%;
  text-align: left;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-weight: 600;
  font-size: clamp(0.8rem, 1.1vw, 0.9rem);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgb(var(--color-ink));
  background-color: transparent;
  border: 0;
  border-bottom: 1px solid var(--fe-gold-line);
  padding: 1rem 0.75rem 1rem 0;
  cursor: pointer;
  transition: color 0.25s ease;
}

.fe-split__tab:last-child {
  border-bottom: 0;
}

.fe-split__tab:hover:not(.is-active) {
  color: rgb(var(--color-wine));
}

.fe-split__tab:focus-visible:not(.is-active) {
  color: rgb(var(--color-wine));
}

/* La sección activa se lee en el titular; aquí solo el enlace a la otra parte */
.fe-split__tab.is-active {
  display: none;
  color: rgb(var(--color-wine));
}

.fe-split__tab:focus-visible {
  outline: 2px solid rgb(var(--color-wine));
  outline-offset: 2px;
  z-index: 1;
}

.fe-split__title-icon {
  width: clamp(4.8rem, 9vw, 6.8rem);
  height: auto;
  fill: rgba(138, 90, 58, 0.38);
  flex: 0 0 auto;
}

.fe-split__panels {
  position: relative;
  min-height: min(12rem, 40vh);
}

.fe-split__panel {
  padding: clamp(0.25rem, 1vw, 0.5rem) 0;
}

@media (min-width: 1024px) {
  .fe-split__panel[data-fe-panel='psicologa'] {
    padding-top: clamp(6rem, 11vw, 8rem);
  }

  .fe-split__panel[data-fe-panel='corporativa'] {
    padding-top: clamp(7rem, 12vw, 9rem);
  }

  /* Alinea el inicio del texto del panel derecho con el primer parrafo
     de la columna izquierda (compensa titulo + pill de la aside). */
  .fe-split__panel.is-active:not([data-fe-panel]) {
    padding-top: clamp(6.5rem, 11vw, 9rem);
  }
}

.fe-split__panel[hidden] {
  display: none;
}

.fe-split__role {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-weight: 700;
  font-size: clamp(0.9rem, 1.35vw, 1.05rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgb(var(--color-ink));
  margin: 0 0 0.5rem;
}

.fe-split__role--secondary {
  margin-top: 1.75rem;
}

.fe-split__period + .fe-split__period {
  margin-top: 1.25rem;
}

.fe-split__period .fe-split__list {
  margin-bottom: 0.25rem;
}

.fe-split__workplace {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: clamp(1.05rem, 1.55vw, 1.2rem);
  color: rgb(55 65 85);
  margin: 0 0 0.35rem;
}

.fe-split__meta {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(0.95rem, 1.35vw, 1.1rem);
  color: rgb(var(--color-ink));
  margin: 0 0 1.25rem;
}

.fe-split__list {
  list-style: disc;
  padding-left: 1.35rem;
  margin: 0;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(1.05rem, 1.45vw, 1.1875rem);
  font-weight: 400;
  line-height: 1.65;
  color: rgb(var(--color-copy));
}

.fe-split__list li {
  padding-left: 0.35rem;
}

.fe-split__list li + li {
  margin-top: 0.65rem;
}

.fe-split__cta-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: clamp(1rem, 2.8vw, 1.75rem);
  padding-inline: clamp(0.25rem, 1.5vw, 0.75rem);
}

.fe-split__cta-wrap--aside {
  justify-content: flex-start;
  padding-inline: 0;
  margin-top: clamp(1rem, 2.2vw, 1.4rem);
}

@media (min-width: 1024px) {
  .fe-split__cta-wrap {
    padding-inline: 0;
  }
}

/* ============================================================
   Reservar cita (reservar-cita.html)
   ============================================================ */

.booking {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(2.75rem, 9vmin, 4rem);
  min-height: 100vh;
  min-height: 100svh;
  box-sizing: border-box;
  display: flex;
  align-items: center;
}

/* Móvil / tablet: el bloque quedaba centrado en la pantalla y generaba mucho hueco bajo el menú fijo.
   El offset del header (--site-header-offset) suele dejar margen extra; un margin-top negativo
   moderado acerca el título sin invadir la barra fija. */
@media (max-width: 1023px) {
  .booking {
    align-items: flex-start;
    margin-top: -1.35rem;
    padding-top: 0.2rem;
    padding-bottom: clamp(1.5rem, 6vmin, 2.5rem);
  }
}

@media (min-width: 1024px) {
  .booking {
    padding-inline: 3.5rem;
  }
}

.booking__inner {
  width: 100%;
}

.booking__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2.5rem;
  align-items: start;
}

.booking__info {
  padding-top: 0;
}

@media (min-width: 1024px) {
  .booking__grid {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 3rem;
  }
}

.booking__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-weight: 300;
  font-size: 2.25rem;
  line-height: 1.15;
}

.booking__title .hero__title-line {
  display: block;
  margin-top: 0.18em;
}

.booking__title .hero__highlight-wrap {
  margin-top: 0.35rem;
}

.booking__title .title-highlight {
  white-space: nowrap;
  text-wrap: nowrap;
}

@media (min-width: 640px) {
  .booking__title {
    font-size: 3rem;
  }
}

@media (min-width: 1280px) {
  .booking__title {
    font-size: 3.6rem;
  }
}

.booking__subtitle {
  margin-top: 1.5rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgb(var(--color-ink));
}

.booking__lead {
  margin-top: 0.75rem;
  font-size: 19px;
  line-height: 1.55;
  color: rgb(var(--color-copy));
  max-width: 32rem;
}

/* Stats de reserva: misma jerarquía que about-mi (número/valor + etiqueta caps), más compactas e icono */
.booking__stats {
  margin-top: 1.75rem;
  max-width: none;
  width: 100%;
  gap: 1.25rem;
}

.booking__stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
}

.booking__stat-icon {
  display: flex;
  margin-bottom: 0.35rem;
  color: rgb(var(--color-wine));
}

.booking__stat-icon svg {
  display: block;
}

/* Tamaño por debajo de las stats del home (about-mi__stat-num 2.25rem / 2.75rem) */
.booking__stats .about-mi__stat-num {
  font-size: 1.35rem;
  line-height: 1.15;
  letter-spacing: 0.02em;
}

.booking__stats .about-mi__stat-label {
  margin-top: 0.4rem;
  font-size: 10px;
  letter-spacing: 0.16em;
}

@media (min-width: 640px) {
  .booking__stats .about-mi__stat-num {
    font-size: 1.5rem;
  }
}

@media (min-width: 1024px) {
  .booking__stats .about-mi__stat-num {
    font-size: 1.65rem;
  }

  .booking__stats .about-mi__stat-label {
    font-size: 11px;
    letter-spacing: 0.18em;
  }
}

.booking__contact {
  margin-top: 1.75rem;
  max-width: 100%;
}

.booking__contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  line-height: 1.5;
}

.booking__contact-item + .booking__contact-item {
  margin-top: 1rem;
}

.booking__schedule {
  color: rgb(var(--color-copy));
}

.booking__schedule p {
  margin: 0;
}

.booking__schedule p + p {
  margin-top: 0.35rem;
}

.booking__contact-item svg {
  margin-top: 0.15rem;
  color: rgb(var(--color-wine));
  flex: 0 0 auto;
}

.booking__contact-item a {
  color: rgb(var(--color-copy));
  text-decoration: none;
  transition: color 0.2s ease;
}

.booking__contact-item a:hover,
.booking__contact-item a:focus-visible {
  color: rgb(var(--color-wine));
}

.booking__calendly .calendly-inline-widget {
  width: 100%;
  border-radius: 8px;
  overflow: hidden;
}

/* Reservar-cita, dos columnas: mismo criterio que `.booking__form` — borde derecho alineado
   con el CTA del header; ancho capado porque el embed de Calendly suele ser más estrecho que la celda. */
@media (min-width: 1024px) {
  .booking__grid > .booking__calendly {
    justify-self: end;
    width: min(100%, 44rem);
    margin-top: clamp(-2.5rem, -5.5vmin, -2.5rem);
  }
}

/* Contacto: formulario (sustituye Calendly en contacto.html) */
.booking__form {
  width: 100%;
  max-width: 36rem;
}

/* Alinear el bloque del formulario a la derecha (misma línea vertical que el CTA del header) */
@media (min-width: 1024px) {
  .booking__grid > .booking__form {
    justify-self: end;
  }
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: 1.5rem;
  border-radius: 8px;
  background: rgb(var(--color-base));
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 8px 24px rgba(122, 74, 43, 0.06);
  border: 1px solid rgb(var(--color-pearl));
}

@media (min-width: 1024px) {
  .contact-form {
    padding: 1.75rem 2rem;
  }
}

.contact-form__row--split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 480px) {
  .contact-form__row--split {
    grid-template-columns: 1fr 1fr;
    gap: 1rem 1.25rem;
  }
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  min-width: 0;
}

.contact-form__label {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(var(--color-wine));
}

.contact-form__input,
.contact-form__textarea {
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  line-height: 1.45;
  color: rgb(var(--color-copy));
  background: rgb(var(--color-surface));
  border: 1px solid rgb(var(--color-pearl));
  border-radius: 6px;
  padding: 0.65rem 0.85rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.contact-form__input::placeholder,
.contact-form__textarea::placeholder {
  color: rgb(var(--color-body));
  opacity: 0.65;
}

.contact-form__input:hover,
.contact-form__textarea:hover {
  border-color: rgb(var(--color-brand));
}

.contact-form__input:focus-visible,
.contact-form__textarea:focus-visible {
  outline: none;
  border-color: rgb(var(--color-wine));
  box-shadow: 0 0 0 3px color-mix(in srgb, rgb(var(--color-wine)) 22%, transparent);
}

.contact-form__textarea {
  min-height: 10.5rem;
  resize: vertical;
}

.contact-form__submit {
  align-self: flex-start;
  margin-top: 0.25rem;
  display: inline-block;
  background-color: rgb(var(--color-cta-bg));
  color: rgb(var(--color-on-primary));
  padding: 12px 22px;
  border-radius: 15px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: background-color 0.25s ease;
}

.contact-form__submit:hover,
.contact-form__submit:focus-visible {
  background-color: rgb(var(--color-cta-bg-hover));
}

.contact-form__submit:focus-visible {
  outline: 2px solid rgb(var(--color-wine));
  outline-offset: 2px;
}

.booking-map {
  padding: 0 2rem 4rem;
}

@media (min-width: 1024px) {
  .booking-map {
    padding: 0 3.5rem 5rem;
  }
}

.booking-map__inner {
  width: min(1500px, 80%);
  margin-inline: auto;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

/* ============================================================
   Tarifas (tarifas.html)
   ============================================================ */
.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;
}

.pricing {
  background-color: rgb(var(--color-base));
  min-height: 100vh;
  min-height: 100dvh;
}

.pricing__inner {
  max-width: 1500px;
  min-height: inherit;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3rem, 9vmin, 5.5rem);
}

/* Tarifas (móvil / tablet): menos aire bajo el header fijo para que la primera card suba. */
@media (max-width: 1023px) {
  body.page-tarifas #tarifas.pricing .pricing__inner {
    margin-top: -0.85rem;
    padding-top: clamp(0.35rem, 2vmin, 1rem);
    padding-bottom: clamp(3rem, 9vmin, 5.5rem);
  }
}

@media (min-width: 1024px) {
  .pricing__inner {
    padding-inline: 3.5rem;
  }
}

.pricing__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  .pricing__grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2rem;
    min-height: min(72vh, 760px);
  }
}

@media (min-width: 768px) {
  #tarifas .pricing__grid--two-by-two {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    column-gap: 5rem;
    row-gap: 5rem;
    min-height: 0;
  }
}

@media (min-width: 1024px) {
  #tarifas .pricing-card--pair .pricing-card__body {
    padding-top: 5rem;
  }
}

.pricing-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-width: 0;
  padding: clamp(2rem, 4vw, 3.25rem);
  position: relative;
}

.pricing-card[hidden] {
  display: none !important;
}

.pricing-card--featured {
  background-color: rgb(var(--color-surface));
}

.pricing-card--outlined {
  background-color: rgb(var(--color-base));
  border: 1px solid rgb(var(--color-wine) / 0.18);
}

.pricing-card__eyebrow {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: rgb(var(--color-wine));
  margin: 0 0 1.25rem;
}

@media (min-width: 640px) {
  .pricing-card__eyebrow {
    font-size: 12px;
  }
}

.pricing-card__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  letter-spacing: 0.01em;
  color: rgb(var(--color-ink));
  font-weight: 400;
  font-size: 1.875rem;
  line-height: 1.15;
  margin: 0 0 1.75rem;
}

.pricing-card__title-row {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.4rem;
  margin: 0 0 1.75rem;
  max-width: 100%;
}

.pricing-card__title-row .pricing-card__title {
  margin: 0;
}

.pricing-card__icon {
  width: 1.9rem;
  height: 1.9rem;
  flex: 0 0 auto;
  color: #bcbcbc;
}

.pricing-card__icon svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.pricing-card--featured .pricing-card__icon {
  color: #baab97;
}

@media (min-width: 640px) {
  .pricing-card__title {
    font-size: 2.25rem;
  }

  .pricing-card__icon {
    width: 2.2rem;
    height: 2.2rem;
  }
}

@media (min-width: 1024px) {
  .pricing-card__title {
    font-size: 2.625rem;
  }
}

.pricing-inline-nav {
  margin-top: 0;
  margin-bottom: 0;
  /* Móvil: sin scroll horizontal; row-gap amplio para que text-underline-offset: 1.5em no cruce la siguiente línea */
  gap: clamp(0.75rem, 3vw, 1.1rem) 0.3rem;
  flex-wrap: wrap;
  max-width: 100%;
}

.pricing-inline-nav .therapy-inline-nav__tab {
  padding: 0.1rem 0.15rem;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  font-size: clamp(0.6rem, 2.2vw, 0.8125rem);
  letter-spacing: 0.1em;
}

.pricing-inline-nav .therapy-inline-nav__sep {
  font-size: clamp(0.6rem, 2.2vw, 0.8125rem);
}

.pricing-inline-nav .therapy-inline-nav__tab.is-active,
.pricing-inline-nav .therapy-inline-nav__tab.is-active:hover,
.pricing-inline-nav .therapy-inline-nav__tab.is-active:focus-visible {
  background: transparent;
  color: rgb(var(--color-wine));
  box-shadow: none;
  text-decoration: underline;
  text-underline-offset: 1.5em;
  text-decoration-thickness: 1px;
}

/* Una sola fila solo si la tarjeta es ancha (p. ej. tablet en 2 columnas → seguir con wrap) */
@container pricing-card-body (min-width: 27rem) {
  .pricing-inline-nav {
    gap: 0.25rem 0.45rem;
    flex-wrap: nowrap;
  }

  .pricing-inline-nav .therapy-inline-nav__tab {
    padding: 0.1rem 0.2rem;
    letter-spacing: 0.18em;
    flex-shrink: 0;
  }

  .pricing-inline-nav .therapy-inline-nav__sep {
    flex-shrink: 0;
  }
}

.pricing-card__rule {
  border: 0;
  border-top: 1px solid rgb(var(--color-wine) / 0.32);
  margin: 0 0 0.45rem;
  max-width: 18rem;
}

.pricing-card__body {
  flex: 1;
  min-width: 0;
  container-type: inline-size;
  container-name: pricing-card-body;
}

.pricing-copy-panels {
  margin-top: clamp(2.4rem, 5.8vw, 4.25rem);
}

@media (min-width: 1024px) {
  .pricing-card--pair .pricing-card__body {
    padding-top: clamp(4.8rem, 8vw, 6rem);
  }
}

.pricing-card__price {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  margin: 0 0 0.4rem;
}

.pricing-card__amount {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(4rem, 9vw, 6rem);
  line-height: 1;
  color: rgb(var(--color-wine));
  letter-spacing: 0.01em;
}

.pricing-card__currency {
  display: inline-block;
  font-size: 0.55em;
  line-height: 1;
  vertical-align: top;
  margin-left: 0.05em;
  margin-top: 0.05em;
}

.pricing-card__per {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 0.95rem;
  color: rgb(var(--color-body));
  font-weight: 400;
}

.pricing-card__price-alt {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(2.25rem, 5.5vw, 3.25rem);
  line-height: 1;
  color: rgb(var(--color-wine));
  margin: 0 0 0.5rem;
}

.pricing-card__meta {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(var(--color-ink) / 0.65);
  font-weight: 500;
  margin: 0 0 clamp(1.75rem, 4vmin, 2.25rem);
}

.pricing-card__meta-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.55rem;
  margin: 0 0 clamp(1.75rem, 4vmin, 2.25rem);
}

.pricing-card__meta-row .pricing-card__meta {
  margin: 0;
}

.pricing-monthly {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  position: relative;
}

.pricing-monthly__checkbox {
  width: 1rem;
  height: 1rem;
  accent-color: rgb(var(--color-wine));
  cursor: pointer;
}

.pricing-monthly__label {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgb(var(--color-ink) / 0.72);
  font-weight: 500;
}

.pricing-tooltip {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.pricing-tooltip__trigger {
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 999px;
  border: 1px solid rgb(var(--color-wine) / 0.45);
  color: rgb(var(--color-wine));
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background-color: transparent;
}

.pricing-tooltip__trigger:focus-visible {
  outline: 2px solid rgb(var(--color-wine));
  outline-offset: 2px;
}

.pricing-tooltip__content {
  position: absolute;
  top: 50%;
  left: calc(100% + 0.55rem);
  width: min(24rem, 78vw);
  background-color: rgb(var(--color-base));
  border: 1px solid rgb(var(--color-wine) / 0.2);
  box-shadow: 0 8px 20px rgb(0 0 0 / 0.12);
  padding: 0.8rem 0.9rem;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 0.875rem;
  line-height: 1.45;
  color: rgb(var(--color-copy));
  text-transform: none;
  letter-spacing: normal;
  opacity: 0;
  pointer-events: none;
  transform: translate(-0.25rem, -50%);
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 5;
}

.pricing-tooltip.is-open .pricing-tooltip__content {
  opacity: 1;
  pointer-events: auto;
  transform: translate(0, -50%);
}

@media (hover: hover) and (pointer: fine) {
  .pricing-tooltip:hover .pricing-tooltip__content,
  .pricing-tooltip:focus-within .pricing-tooltip__content {
    opacity: 1;
    pointer-events: auto;
    transform: translate(0, -50%);
  }
}

@media (max-width: 767px) {
  .pricing-card__meta-row {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .pricing-tooltip__content {
    top: calc(100% + 0.55rem);
    left: 0;
    transform: translateY(-0.25rem);
    width: min(21rem, 85vw);
  }

  .pricing-tooltip.is-open .pricing-tooltip__content,
  .pricing-tooltip:hover .pricing-tooltip__content,
  .pricing-tooltip:focus-within .pricing-tooltip__content {
    transform: translateY(0);
  }
}

.pricing-card__description {
  margin: 0 0 1rem;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(1.0625rem, 2.5vw, 1.1875rem);
  line-height: 1.55;
  font-weight: 400;
  color: rgb(var(--color-copy));
}

.pricing-card__list {
  margin: 0 0 clamp(2rem, 5vmin, 2.75rem);
  padding: 0;
  list-style: none;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(1.0625rem, 2.5vw, 1.1875rem);
  line-height: 1.55;
  font-weight: 400;
  color: rgb(var(--color-copy));
}

.pricing-card__list li {
  position: relative;
  padding-left: 1.6rem;
}

.pricing-card__list li + li {
  margin-top: 0.4rem;
}

.pricing-card__list li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: rgb(var(--color-wine) / 0.55);
  font-weight: 400;
}

.pricing-card__list-link {
  color: inherit;
  text-decoration: underline;
  text-decoration-color: rgb(var(--color-wine) / 0.35);
  text-underline-offset: 0.15em;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.pricing-card__list-link:hover,
.pricing-card__list-link:focus-visible {
  color: rgb(var(--color-wine));
  text-decoration-color: rgb(var(--color-wine) / 0.65);
}

/* Tarjeta con un solo CTA: el enlace sigue pegado al pie del flex */
.pricing-card > .pricing-card__cta {
  margin-top: auto;
  align-self: flex-start;
}

.pricing-card__cta-row {
  margin-top: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  column-gap: 0.75rem;
  row-gap: 0.75rem;
}

.pricing-card__cta {
  display: inline-block;
  text-decoration: none;
  border: 1px solid transparent;
  background-color: rgb(var(--color-cta-bg));
  color: rgb(var(--color-on-primary));
  padding: 0.95rem 1.6rem;
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease;
}

.pricing-card__cta:hover,
.pricing-card__cta:focus-visible {
  background-color: rgb(var(--color-cta-bg-hover));
  color: rgb(var(--color-on-primary));
}

.pricing-card__cta--secondary {
  background-color: transparent;
  color: rgb(var(--color-wine));
  border-color: rgb(var(--color-wine) / 0.4);
}

.pricing-card__cta--secondary:hover,
.pricing-card__cta--secondary:focus-visible {
  background-color: rgb(var(--color-wine) / 0.08);
  border-color: rgb(var(--color-wine) / 0.65);
  color: rgb(var(--color-wine));
}

.pricing-reimbursement {
  margin: 1rem 0 0.85rem;
}

.pricing-reimbursement__summary {
  list-style: none;
  cursor: pointer;
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 0.8rem;
  line-height: 1.45;
  letter-spacing: 0.04em;
  color: rgb(var(--color-ink) / 0.62);
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.pricing-reimbursement__summary::-webkit-details-marker {
  display: none;
}

.pricing-reimbursement__summary::before {
  content: "▾";
  font-size: 1.2em;
  color: rgb(var(--color-wine));
  transition: transform 0.2s ease;
  line-height: 1;
}

.pricing-reimbursement[open] .pricing-reimbursement__summary::before {
  transform: rotate(180deg);
}

.pricing-reimbursement__summary:focus-visible {
  outline: 2px solid rgb(var(--color-wine) / 0.55);
  outline-offset: 2px;
}

.pricing-reimbursement__content {
  margin-top: 0.55rem;
  max-width: 31rem;
  border-left: 1px solid rgb(var(--color-ink) / 0.28);
  padding-left: 0.8rem;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 0.93rem;
  line-height: 1.5;
  color: rgb(var(--color-copy));
}

.pricing-reimbursement__title {
  margin: 0 0 0.45rem;
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 0.76rem;
  line-height: 1.4;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgb(var(--color-ink) / 0.78);
  font-weight: 600;
}

.pricing-reimbursement__content p {
  margin: 0;
}

.pricing-reimbursement__content p + p {
  margin-top: 0.55rem;
}

/* ============================================================
   Bonos y descuentos (tarifas.html)
   ============================================================ */
.savings {
  background-color: rgb(var(--color-surface));
}

.savings__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3rem, 9vmin, 5.5rem);
}

@media (min-width: 1024px) {
  .savings__inner {
    padding-inline: 3.5rem;
  }
}

.savings__header {
  margin-bottom: clamp(2.25rem, 5vmin, 3.25rem);
}

/* Mismo bloque tipográfico que about-hero (servicios): línea + highlight animado */
.savings__hero-title {
  margin: 0;
}

.savings__hero-title .about-hero__title-line {
  margin-bottom: clamp(0.35rem, 1.5vw, 0.75rem);
}

.savings__hero-title .title-highlight {
  white-space: normal;
  text-wrap: balance;
}

.savings__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  .savings__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 2rem;
  }
}

.savings-card {
  background-color: rgb(var(--color-base));
  padding: clamp(1.75rem, 3.5vw, 2.75rem);
  border-left: 2px solid rgb(var(--color-wine));
}

.savings-card__eyebrow {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  color: rgb(var(--color-wine));
  margin: 0 0 1rem;
}

@media (min-width: 640px) {
  .savings-card__eyebrow {
    font-size: 12px;
  }
}

.savings-card__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(1.6rem, 3.5vw, 2.1rem);
  color: rgb(var(--color-ink));
  margin: 0 0 1rem;
  line-height: 1.15;
}

.savings-card__subtitle {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(1.4rem, 3vw, 1.85rem);
  color: rgb(var(--color-wine));
  margin: 0 0 1.5rem;
  line-height: 1.15;
}

.savings-card__price {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin: 0 0 1.5rem;
}

.savings-card__amount {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  font-size: clamp(2.25rem, 5vw, 3rem);
  line-height: 1;
  color: rgb(var(--color-wine));
}

.savings-card__per {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 0.9rem;
  color: rgb(var(--color-body));
}

.savings-card__rule {
  border: 0;
  border-top: 1px solid rgb(var(--color-wine) / 0.22);
  margin: 0 0 1.5rem;
}

.savings-card__copy {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(1.0625rem, 2.5vw, 1.1875rem);
  line-height: 1.55;
  color: rgb(var(--color-copy));
  margin: 0;
}

.savings-card__copy + .savings-card__copy {
  margin-top: 1rem;
}

.savings__cta-wrap {
  margin-top: clamp(2.25rem, 5vmin, 3rem);
  text-align: center;
}

.savings__cta-wrap .btn-primary {
  margin-top: 0;
}

/* ============================================================
   Preguntas frecuentes (preguntas-frecuentes.html)
   ============================================================ */
.faq {
  background-color: rgb(var(--color-base));
}

.faq--surface {
  position: relative;
  background-color: transparent;
  /* Recorta el pseudo full-bleed (width: 100vw) para que no genere
     scroll horizontal cuando la barra vertical reduce el viewport. */
  overflow-x: clip;
}

.faq--surface::before {
  content: "";
  position: absolute;
  z-index: 0;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  background-color: rgb(var(--color-surface));
  pointer-events: none;
}

.faq--surface > * {
  position: relative;
  z-index: 1;
}

.faq__inner {
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3rem, 9vmin, 5.5rem);
}

@media (min-width: 1024px) {
  .faq__inner {
    padding-inline: 3.5rem;
    padding-block: clamp(4rem, 8vmin, 6rem);
  }
}

.faq__header {
  text-align: center;
  margin-bottom: clamp(2.5rem, 6vmin, 4rem);
}

.faq__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  line-height: 1.15;
  margin: 0;
}

.faq__title .faq__title-text--short {
  display: none;
}

@media (max-width: 1023px) {
  .faq__title .faq__title-text--full {
    display: none;
  }

  .faq__title .faq__title-text--short {
    display: inline;
  }

  /* Alinea el bloque con `.booking` en móvil: menos aire bajo el header fijo que el padding grande de `.faq__inner`. */
  #preguntas-frecuentes.faq {
    margin-top: -1.35rem;
    padding-top: 0.2rem;
  }

  #preguntas-frecuentes.faq .faq__inner {
    padding-top: 0;
    padding-bottom: clamp(3rem, 9vmin, 5.5rem);
  }
}

.faq__list {
  column-count: 1;
  column-gap: clamp(2rem, 5vw, 4.5rem);
}

@media (min-width: 768px) {
  .faq__list {
    column-count: 2;
  }
}

.faq-item {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  margin-bottom: clamp(1.5rem, 3.5vmin, 2.5rem);
  display: block;
  width: 100%;
}

.faq-item__summary {
  list-style: none;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
  padding-block: 0.25rem 1rem;
  border-bottom: 1px solid rgb(var(--color-ink) / 0.25);
  -webkit-tap-highlight-color: transparent;
  transition: color 0.2s ease;
}

.faq-item__summary::-webkit-details-marker {
  display: none;
}

.faq-item__summary::marker {
  content: '';
}

.faq-item__summary:focus-visible {
  outline: 2px solid rgb(var(--color-wine) / 0.5);
  outline-offset: 4px;
}

.faq-item__question {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: rgb(var(--color-ink));
  font-size: clamp(1.25rem, 2.4vw, 1.75rem);
  line-height: 1.25;
  margin: 0;
  text-wrap: balance;
  flex: 1 1 auto;
  min-width: 0;
}

.faq-item__icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.35rem;
  color: rgb(var(--color-wine));
  transition: transform 0.25s ease;
}

.faq-item[open] .faq-item__icon {
  transform: rotate(180deg);
}

.faq-item__body {
  padding-top: 1rem;
}

.faq-item__answer {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(1rem, 2vw, 1.0625rem);
  line-height: 1.65;
  font-weight: 400;
  color: rgb(var(--color-copy));
  margin: 0;
}

@media (min-width: 768px) {
  /* En tablet/desktop el bloque queda siempre expandido (vía JS) y sin interactividad */
  .faq-item__summary {
    cursor: default;
    pointer-events: none;
  }

  .faq-item__icon {
    display: none;
  }
}

/* ============================================================
   Pullquote band — sección de cita
   ============================================================ */
.pullquote-band {
  background-color: rgb(var(--color-pearl));
  padding-top: clamp(3.25rem, 10vw, 2rem);
  padding-bottom: clamp(2rem, 5vw, 2rem);
}

.pullquote-band__inner {
  max-width: 1180px;
  margin-inline: auto;
  padding: 0 clamp(1.5rem, 5vw, 3rem);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3rem);
}

.pullquote {
  position: relative;
  margin: 0;
  padding: clamp(1.25rem, 3vmin, 2rem) 0;
  text-align: center;
  flex: 1 1 auto;
  min-width: 0;
}

/* Cita sola (sin imagen): bloque centrado y ancho de lectura */
.pullquote-band__inner > .pullquote:only-child {
  flex: 0 1 auto;
  max-width: min(42rem, 100%);
  margin-inline: auto;
}

.pullquote-band__image {
  position: relative;
  margin: 0;
  order: -1;
  /* Imagen cuadrada (800×800): ancho acotado + max-height para no imponer más altura que el texto */
  flex: 0 0 auto;
  width: clamp(200px, 34%, 380px);
  max-width: 100%;
  aspect-ratio: 1 / 1;
  display: block;
  align-self: center;
  max-height: clamp(220px, 42vmin, 400px);
}

.pullquote-band__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.pullquote-band__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgb(var(--color-pearl) / 0.32);
  pointer-events: none;
}

.pullquote__mark {
  display: block;
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-size: clamp(4rem, 8vw, 6rem);
  line-height: 0.6;
  color: rgb(var(--color-wine) / 0.25);
  margin-bottom: 0.5rem;
  user-select: none;
}

.pullquote__text {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-size: clamp(1.35rem, 3.2vw, 2rem);
  line-height: 1.55;
  color: rgb(var(--color-ink));
  margin: 0 0 1.25rem;
  font-style: italic;
}

.pullquote__footer {
  margin-top: 0;
}

.pullquote__author {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(var(--color-wine));
  font-style: normal;
}

.pullquote__author::before {
  content: "— ";
}

@media (max-width: 767px) {
  .pullquote-band__inner {
    flex-direction: column;
    text-align: center;
  }

  .pullquote-band__image {
    width: min(100%, 320px);
    margin-inline: auto;
    order: -1;
    flex: 0 0 auto;
    aspect-ratio: 1 / 1;
    max-height: min(72vw, 360px);
  }

  .pullquote-band__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 18%;
  }
}

/* ============================================================
   Landing index.html — nuevas secciones
   ============================================================ */

/* --- Botón ghost (secundario) --- */
.btn-ghost {
  display: inline-block;
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 600;
  padding: 1rem 2rem;
  color: rgb(var(--color-wine));
  border: 1.5px solid rgb(var(--color-wine) / 0.45);
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.06), 0 2px 4px -2px rgb(0 0 0 / 0.06);
  transition: background-color 0.25s ease, border-color 0.25s ease;
}

.btn-ghost:hover,
.btn-ghost:focus-visible {
  background-color: rgb(var(--color-wine) / 0.07);
  border-color: rgb(var(--color-wine));
}

.btn-ghost--upper {
  text-transform: uppercase;
}

/* --- Hero: fila de CTAs y microcopy --- */
.hero__cta-block {
  margin-top: 2rem;
  width: fit-content;
  max-width: 100%;
}

.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-top: 2rem;
}

.hero__cta-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
}

.hero__cta-block .hero__cta-row {
  margin-top: 0;
}

.hero__cta-row .btn-primary {
  margin-top: 0;
}

.hero__cta-row .btn-ghost {
  text-transform: uppercase;
}

.hero__microcopy {
  margin-top: 1rem;
  font-family: 'Be Vietnam Pro', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  font-size: 11px;
  font-weight: 500;
  color: rgb(var(--color-wine) / 0.7);
  text-align: center;
}

.hero__cta-block .hero__microcopy {
  width: 100%;
  text-align: justify;
  text-align-last: justify;
  letter-spacing: 0.18em;
}

/* --- Especialidades landing --- */
.especialidades-landing {
  background-color: rgb(var(--color-surface));
}

.especialidades-landing__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3rem, 9vmin, 5rem);
}

@media (min-width: 1024px) {
  .especialidades-landing__inner {
    padding-inline: 3.5rem;
  }
}

.especialidades-landing__header {
  text-align: center;
  margin-bottom: clamp(2rem, 5vmin, 3.5rem);
}

.especialidades-landing__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  line-height: 1.15;
}

.especialidades-landing__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 540px) {
  .especialidades-landing__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .especialidades-landing__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.especialidades-landing__card {
  background-color: rgb(var(--color-base));
  border: 1px solid rgb(var(--color-wine) / 0.12);
  padding: clamp(1.5rem, 3vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.especialidades-landing__icon {
  display: block;
  width: 2rem;
  height: 2rem;
  color: rgb(var(--color-wine));
}

.especialidades-landing__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.especialidades-landing__card-title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: rgb(var(--color-ink));
  font-size: clamp(1.25rem, 2.5vw, 1.625rem);
  line-height: 1.2;
}

.especialidades-landing__card-desc {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 15px;
  line-height: 1.6;
  font-weight: 400;
  color: rgb(var(--color-body));
}

.especialidades-landing__cta-wrap {
  text-align: center;
}

/* --- Cómo funciona — 4 pasos (cards con badge) --- */
.landing-steps {
  background-color: rgb(var(--color-pearl));
}

.landing-steps__inner {
  max-width: 1300px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3.5rem, 10vmin, 7rem);
}

@media (min-width: 1024px) {
  .landing-steps__inner {
    padding-inline: 3.5rem;
  }
}

.landing-steps__header {
  text-align: center;
  max-width: 640px;
  margin-inline: auto;
  margin-bottom: clamp(2.5rem, 6vmin, 4rem);
}

.landing-steps__header--process-title {
  max-width: none;
}

.landing-steps__eyebrow {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', 'Montserrat', sans-serif;
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgb(var(--color-wine));
  font-weight: 500;
  margin: 0;
}

.landing-steps__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 300;
  color: rgb(var(--color-ink));
  font-size: clamp(2rem, 5vw, 3.75rem);
  line-height: 1.05;
  letter-spacing: 0;
  margin: 1.25rem 0 0;
}

.landing-steps__title-italic {
  font-family: inherit;
  font-style: italic;
  font-weight: inherit;
  color: rgb(var(--color-wine));
}

.landing-steps__title--single-line {
  white-space: nowrap;
  font-size: clamp(1.2rem, 3.8vw + 0.65rem, 3.75rem);
}

.landing-steps__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.75rem;
  list-style: none;
  padding: 0;
  margin: 0;
  max-width: none;
}

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

@media (min-width: 1024px) {
  .landing-steps__list {
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
  }
}

.landing-steps__item {
  background-color: rgb(var(--color-base));
  padding: 3rem 2.2rem 2.3rem;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.85rem;
  text-align: left;
  min-height: clamp(17rem, 55vw, 19.5rem);
}

.landing-steps__item + .landing-steps__item::before {
  content: none;
}

.landing-steps__badge {
  position: absolute;
  top: -1.25rem;
  left: 2rem;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  background-color: rgb(var(--color-wine));
  color: rgb(var(--color-on-primary));
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.landing-steps__kicker {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', 'Montserrat', sans-serif;
  font-size: clamp(0.68rem, 1.15vw, 0.74rem);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgb(var(--color-wine));
  font-weight: 600;
  margin: 0;
}

.landing-steps__step-title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  color: rgb(var(--color-ink));
  font-size: clamp(1.65rem, 2.25vw, 1.9rem);
  line-height: 1.2;
  margin: 0.25rem 0 0;
}

.landing-steps__step-desc {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: clamp(0.96rem, 1.35vw, 1.06rem);
  line-height: 1.7;
  font-weight: 400;
  color: rgb(var(--color-body));
  max-width: none;
  margin: 0.25rem 0 0;
}

@media (max-width: 767px) {
  .landing-steps__step-desc {
    font-size: 18px;
  }
}

@media (min-width: 1024px) {
  .landing-steps__item {
    min-height: 21rem;
  }
}

.landing-steps__cta-wrap {
  text-align: center;
}

.landing-steps__cta-wrap .btn-primary {
  margin-top: clamp(2rem, 5vmin, 3rem);
}

/* --- Mini bio landing --- */
.landing-bio {
  background-color: rgb(var(--color-base));
}

.landing-bio__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(2.75rem, 9vmin, 4.5rem);
}

@media (min-width: 1024px) {
  .landing-bio__inner {
    padding-inline: 3.5rem;
  }
}

.landing-bio__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .landing-bio__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
    gap: 4rem;
  }
}

.landing-bio__img {
  width: min(28rem, 90vw);
  height: auto;
  margin-inline: auto;
  display: block;
  object-fit: contain;
}

@media (min-width: 1024px) {
  .landing-bio__img {
    width: 100%;
    margin-inline: 0;
  }
}

.landing-bio__credentials {
  margin-top: 1.5rem;
  border-left: 1px solid rgb(var(--color-wine) / 0.28);
  padding-left: 1.25rem;
}

.landing-bio__credentials li {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: rgb(var(--color-wine));
  text-transform: uppercase;
  line-height: 1.5;
}

.landing-bio__credentials li + li {
  margin-top: 0.5rem;
}

.landing-bio__content .btn-primary {
  margin-top: 2rem;
}

/* --- Tarifas carrusel landing --- */
.landing-pricing {
  background-color: rgb(var(--color-surface));
}

.landing-pricing__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3rem, 9vmin, 5rem);
}

@media (min-width: 1024px) {
  .landing-pricing__inner {
    padding-inline: 3.5rem;
  }
}

.landing-pricing__header {
  text-align: center;
  margin-bottom: clamp(2rem, 5vmin, 3.5rem);
}

.landing-pricing__title {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: rgb(var(--color-wine));
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  line-height: 1.15;
}

.landing-pricing__carousel {
  position: relative;
  overflow: hidden;
}

@media (min-width: 768px) {
  .landing-pricing__carousel {
    overflow: visible;
  }
}

.landing-pricing__track {
  display: flex;
  transition: transform 0.35s ease;
}

@media (min-width: 768px) {
  .landing-pricing__track {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    max-width: 900px;
    margin-inline: auto;
    transform: none !important;
  }
}

.landing-pricing__slide {
  flex: 0 0 100%;
  min-width: 0;
}

@media (min-width: 768px) {
  .landing-pricing__slide {
    flex: none;
    min-width: 0;
  }
}

.landing-pricing__arrow {
  position: absolute;
  top: 50%;
  z-index: 3;
  transform: translateY(-50%);
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgb(var(--color-wine));
  opacity: 0.65;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.landing-pricing__arrow:hover {
  opacity: 1;
  transform: translateY(-50%) scale(1.08);
}

.landing-pricing__arrow:focus-visible {
  outline: 2px solid rgb(var(--color-wine) / 0.5);
  outline-offset: 4px;
}

.landing-pricing__arrow--prev {
  left: 0.25rem;
}

.landing-pricing__arrow--next {
  right: 0.25rem;
}

@media (min-width: 768px) {
  .landing-pricing__arrow {
    display: none;
  }
}

.landing-pricing__cta-wrap {
  text-align: center;
}

.landing-pricing__cta-wrap .btn-primary {
  margin-top: clamp(2rem, 4vmin, 3rem);
}

/* --- FAQ: CTA inferior y override de column-count en landing --- */
.faq__cta-wrap {
  margin-top: clamp(2rem, 4vmin, 3rem);
  text-align: center;
}

.faq__cta-wrap .btn-primary {
  margin-top: 0;
}

/* --- CTA final: doble botón --- */
.contacto__ctas {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin-top: 2rem;
}

@media (min-width: 540px) {
  .contacto__ctas {
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
  }
}

.contacto__cta-primary {
  margin-top: 0;
}

.contacto__cta-ghost {
  margin-top: 0;
}

/* --- Mapa landing: barra de dirección --- */
.landing-map {
  padding-top: 0;
}

.landing-map__address-bar {
  max-width: 1500px;
  margin-inline: auto;
  padding: 1.5rem clamp(1.5rem, 5vw, 2rem) 1.25rem;
  text-align: center;
}

@media (min-width: 1024px) {
  .landing-map__address-bar {
    padding-inline: 3.5rem;
  }
}

.landing-map__address-bar p {
  font-family: 'Be Vietnam Pro', sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.08em;
  color: rgb(var(--color-body));
  line-height: 1.7;
}

.landing-map__address-bar a {
  color: rgb(var(--color-wine));
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ============================================================
   Síntomas (#sintomas) — listado «¿Te identificas?»
   ============================================================ */
.sintomas {
  position: relative;
  background-color: rgb(var(--color-surface));
  overflow: hidden;
}

.sintomas__inner {
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3.5rem, 10vmin, 7rem);
  position: relative;
}

@media (min-width: 1024px) {
  .sintomas__inner {
    padding-inline: 3.5rem;
  }
}

.sintomas__header {
  max-width: 760px;
  text-align: center;
  margin-inline: auto;
}

.sintomas__title {
  margin: 1.25rem 0 0;
}

.sintomas__divider {
  margin-top: 1.5rem;
}

.sintomas__list {
  list-style: none;
  padding: 0;
  margin: clamp(2.75rem, 7vmin, 5rem) auto 0;
  max-width: 64rem;
}

.sintomas__item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 1.25rem;
  padding-block: 1.5rem;
  border-top: 1px solid rgb(var(--color-wine) / 0.2);
}

.sintomas__item:first-child {
  border-top: 0;
}

@media (min-width: 1024px) {
  .sintomas__item {
    gap: 2.5rem;
    padding-block: 2rem;
  }
}

.sintomas__icon {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 9999px;
  border: 1px solid rgb(var(--color-wine) / 0.3);
  background-color: rgb(var(--color-base) / 0.4);
  color: rgb(var(--color-wine));
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sintomas__icon svg {
  width: 22px;
  height: 22px;
  display: block;
}

.sintomas__body {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
}

@media (min-width: 1024px) {
  .sintomas__body {
    flex-direction: row;
    align-items: baseline;
    gap: 2rem;
  }
}

.sintomas__heading {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-weight: 400;
  color: rgb(var(--color-ink));
  font-size: 1.625rem;
  line-height: 1.2;
  margin: 0;
}

@media (min-width: 1024px) {
  .sintomas__heading {
    font-size: 2rem;
    width: 22rem;
    flex-shrink: 0;
    white-space: nowrap;
  }
}

.sintomas__text {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 19px;
  line-height: 1.65;
  font-weight: 400;
  color: rgb(var(--color-body));
  margin: 0;
}

.sintomas__closing {
  margin-top: clamp(2.5rem, 6vmin, 4rem);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
}

.sintomas__rule {
  display: none;
  height: 1px;
  width: 4rem;
  background-color: rgb(var(--color-wine) / 0.4);
  flex-shrink: 0;
}

@media (min-width: 640px) {
  .sintomas__rule {
    display: block;
  }
}

.sintomas__closing-text {
  font-family: 'Mirage Regular', 'Cormorant Garamond', serif;
  font-style: italic;
  color: rgb(var(--color-ink));
  font-size: 1.5rem;
  line-height: 1.3;
  text-align: center;
  margin: 0;
}

@media (min-width: 1024px) {
  .sintomas__closing-text {
    font-size: 1.875rem;
  }
}

.sintomas__closing-link {
  color: rgb(var(--color-wine));
  text-decoration: underline;
  text-decoration-color: rgb(var(--color-wine) / 0.4);
  text-underline-offset: 4px;
  transition: text-decoration-color 0.2s ease;
}

.sintomas__closing-link:hover,
.sintomas__closing-link:focus-visible {
  text-decoration-color: rgb(var(--color-wine));
}

/* ============================================================
   Mapa landing (index.html) — sección «Cómo llegar»
   ============================================================ */
.home-map {
  background-color: rgb(var(--color-base));
}

.home-map__inner {
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: clamp(1.5rem, 5vw, 2rem);
  padding-block: clamp(3rem, 8vmin, 5rem);
}

@media (min-width: 1024px) {
  .home-map__inner {
    padding-inline: 3.5rem;
  }
}

.home-map__header {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2rem;
}

@media (min-width: 1024px) {
  .home-map__header {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
  }
}

.home-map__heading {
  display: flex;
  flex-direction: column;
}

.home-map__title {
  margin-top: 0.75rem;
  font-size: clamp(1.875rem, 4vw, 3rem);
  line-height: 1.05;
}

.home-map__address {
  margin-top: 0.75rem;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', 'Montserrat', sans-serif;
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  line-height: 1.5;
  color: rgb(var(--color-charcoal));
}

.home-map__link {
  align-self: flex-start;
  font-family: 'Sofia Pro', 'Be Vietnam Pro', 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: rgb(var(--color-wine));
  text-decoration: none;
  transition: color 0.2s ease;
}

@media (min-width: 1024px) {
  .home-map__link {
    align-self: auto;
  }
}

.home-map__link:hover,
.home-map__link:focus-visible {
  color: rgb(var(--color-wine-dark));
}

.home-map__frame {
  width: 100%;
  overflow: hidden;
  border: 1px solid rgb(var(--color-wine) / 0.2);
  box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.home-map__frame iframe {
  display: block;
  width: 100%;
  height: 320px;
  border: 0;
}

@media (min-width: 768px) {
  .home-map__frame iframe {
    height: 400px;
  }
}

@media (min-width: 1024px) {
  .home-map__frame iframe {
    height: 450px;
  }
}

/* ---------- Contenedor de página (alineado con .site-nav) ---------- */
.container {
  width: 100%;
  max-width: 1500px;
  margin-inline: auto;
  padding-inline: 2rem;
  box-sizing: border-box;
}

@media (min-width: 1024px) {
  .container {
    padding-inline: 3.5rem;
  }
}

/* ---------- Páginas legales / políticas (.politica-page) ---------- */
.politica-page {
  /* Sin duplicar la altura del nav: en desktop el header ya ocupa flujo; en móvil #menu-container aporta el hueco bajo nav fijo. */
  padding-top: 1.25rem;
  padding-bottom: 1.5rem;
}

@media (min-width: 1024px) {
  .politica-page {
    padding-top: 1.35rem;
  }
}

@media (max-width: 1023px) {
  /* Header inyectado: el contenedor ya tiene min-height = --site-header-offset */
  #menu-container + main.politica-page {
    padding-top: 0.65rem;
  }

  /* Aviso legal: header en el body sin #menu-container — evitar que el título quede bajo el nav fijo */
  .site-header + main.politica-page {
    padding-top: calc(var(--site-header-offset, 5rem) + 0.5rem);
  }
}

.politica-page article {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  font-size: 1.125rem;
  font-weight: 300;
  line-height: 1.65;
  color: rgb(var(--color-body));
}

.politica-page h2,
.politica-page h3 {
  font-family: 'Sofia Pro', 'Be Vietnam Pro', sans-serif;
  line-height: 1.35;
  color: rgb(var(--color-ink));
}

/* Mismo bloque titular que contacto/reservar (Mirage + highlight animado); títulos largos pueden partir línea */
.politica-page .booking__title {
  margin-top: 0;
  margin-bottom: 0.85em;
}

.politica-page .booking__title .hero__highlight-wrap {
  margin-top: 0;
}

.politica-page .booking__title .title-highlight {
  white-space: normal;
  text-wrap: balance;
}

.politica-page h2 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-top: 1.5em;
  margin-bottom: 0.45em;
}

.politica-page h3 {
  font-size: 1.1875rem;
  font-weight: 500;
  margin-top: 1.15em;
  margin-bottom: 0.35em;
}

/* Sangría bajo cada h3: el propio h3 y los hermanos siguientes hasta el próximo h2 (:not(h2) en la cadena). */
.politica-page article > div > h3,
.politica-page article > div > h3 + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
.politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) {
  padding-inline-start: 1.125rem;
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .politica-page article > div > h3,
  .politica-page article > div > h3 + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2),
  .politica-page article > div > h3 + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) + :not(h2) {
    padding-inline-start: 1.35rem;
  }
}

.politica-page p {
  margin-bottom: 1em;
}

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

.politica-page ul {
  list-style: disc;
  padding-left: 1.35em;
  margin: 0 0 1em;
}

.politica-page li {
  margin-bottom: 0.35em;
}

.politica-page article a {
  color: rgb(var(--color-wine-dark));
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

.politica-page article a:hover,
.politica-page article a:focus-visible {
  color: rgb(var(--color-wine));
}
