/* ============================================
   ANA CABALLERO COACH — Estilos principales
   Versión 1.0 — Marzo 2026
   ============================================ */

/* --- Variables --- */
:root {
  --color-white:            #FFFFFF;
  --color-perla:            #F9FBFC;
  --color-card:             #DDE6EC;
  --color-azul-medio:       #7A94A0;
  --color-azul-gris:        #4F6F86;
  --color-azul-oscuro:      #3E5A6D;
  --color-texto:            #2E2E2E;
  --color-credential-bg:    #EDF1F3;
  --color-credential-border:#D0DAE0;
  --font-heading:           'Playfair Display', Georgia, serif;
  --font-body:              'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --max-width:              1200px;
  --section-padding:        5rem 1.5rem;
  --radius:                 8px;
  --shadow-card:            0 2px 16px rgba(79,111,134,.08);
  --transition:             0.25s ease;
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
  overflow-x: hidden;
}

body {
  font-family: var(--font-body);
  color: var(--color-texto);
  background: var(--color-white);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* --- Typography --- */
h1, h2, h3 {
  font-family: var(--font-heading);
  line-height: 1.2;
  color: var(--color-texto);
}
h1 { font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 700; }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); font-weight: 700; }
h3 { font-size: clamp(1.1rem, 2vw, 1.35rem); font-weight: 600; }
h4 { font-family: var(--font-body); font-size: 1rem; font-weight: 600; }
p  { font-size: 1rem; line-height: 1.75; }

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-azul-medio);
  display: block;
  margin-bottom: 0.75rem;
}

/* --- Layout helpers --- */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
}

.section { padding: var(--section-padding); }
.section--white  { background: var(--color-white); }
.section--perla  { background: var(--color-perla); }
.section--dark   { background: var(--color-azul-oscuro); }

.section-header { text-align: center; margin-bottom: 3rem; }
.section-header h2 { margin-bottom: 1rem; }
.section-header p  { max-width: 680px; margin: 0 auto; color: #555; }

/* H2 azul gris en secciones */
.section--white .section-header h2,
.section--white h2 { color: var(--color-azul-gris); }
.section--perla .section-header h2,
.section--perla h2 { color: var(--color-azul-gris); }

/* ============================================
   NAVEGACIÓN
   ============================================ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(208,218,224,0.4);
  transition: box-shadow var(--transition);
}
.nav.scrolled { box-shadow: 0 2px 12px rgba(62,90,109,.1); }

.nav__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.nav__logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.nav__logo-img {
  height: 42px;
  width: auto;
}
.nav__logo span {
  display: block;
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-azul-medio);
  margin-top: 2px;
}

.nav__links {
  display: flex;
  gap: 2rem;
  align-items: center;
}
.nav__links a {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-texto);
  transition: color var(--transition);
  white-space: nowrap;
}
.nav__links a:hover { color: var(--color-azul-gris); }
.nav__links a[aria-current="page"] { color: var(--color-azul-gris); font-weight: 600; }

.nav__cta {
  background: var(--color-azul-gris);
  color: var(--color-white) !important;
  padding: 0.5rem 1.15rem;
  border-radius: var(--radius);
  font-size: 0.82rem !important;
  white-space: nowrap;
  transition: background var(--transition) !important;
}
.nav__cta:hover { background: var(--color-azul-oscuro) !important; }

.nav__toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  background: none;
  border: none;
}
.nav__toggle span {
  width: 24px; height: 2px;
  background: var(--color-texto);
  border-radius: 2px;
  transition: all var(--transition);
  display: block;
}
.nav__toggle.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.nav__toggle.open span:nth-child(2) { opacity: 0; }
.nav__toggle.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* Mobile nav */
@media (max-width: 900px) {
  .nav__links { display: none; }
  .nav__toggle { display: flex; }

  .nav__links.open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 68px; left: 0; right: 0;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-credential-border);
    padding: 1.5rem;
    gap: 1.25rem;
    box-shadow: 0 8px 24px rgba(62,90,109,.1);
  }
  .nav__links.open a { font-size: 1rem; }
}

/* ============================================
   HERO
   ============================================ */
.hero {
  min-height: 100vh;
  padding: 7rem 1.5rem 4rem;
  background: var(--color-white);
  display: flex;
  align-items: center;
}

.hero__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 4rem;
  align-items: center;
  width: 100%;
}

.hero__content { max-width: 560px; }

.hero__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 1.5rem 0 2rem;
}
.hero__pill {
  font-size: 0.8rem;
  font-weight: 500;
  padding: 0.35rem 0.85rem;
  border: 1.5px solid var(--color-azul-medio);
  color: var(--color-azul-gris);
  border-radius: 100px;
  white-space: nowrap;
}

.hero__cta-group { display: flex; flex-direction: column; gap: 0.5rem; align-items: flex-start; }
.hero__microcopy { font-size: 0.78rem; color: #888; }

.hero__image { position: relative; height: 100%; display: flex; flex-direction: column; }
.hero__img-wrap {
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  height: 100%;
  min-height: 400px;
  max-height: 540px;
}
.hero__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: top center;
}

.hero__badge {
  position: absolute;
  bottom: 1.5rem;
  left: -1.5rem;
  background: var(--color-azul-gris);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  padding: 0.6rem 1rem;
  border-radius: var(--radius);
  box-shadow: 0 4px 16px rgba(62,90,109,.3);
  white-space: nowrap;
}

@media (max-width: 900px) {
  .hero {
    overflow: hidden;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .hero__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    text-align: center;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }
  .hero__content { max-width: 100%; width: 100%; overflow: hidden; }
  .hero h1 { font-size: 2rem; }
  .hero__pills { justify-content: center; flex-direction: column; align-items: center; }
  .hero__pill { text-align: center; }
  .hero__cta-group { align-items: center; width: 100%; }
  .hero__cta-group .btn { width: auto; max-width: 90%; justify-content: center; box-sizing: border-box; padding: 0.85rem 2rem; font-size: 0.95rem; }
  .hero__badge {
    position: relative;
    bottom: auto;
    left: auto;
    transform: none;
    display: block;
    width: fit-content;
    margin: 0.75rem auto 0;
    text-align: center;
    white-space: normal;
    font-size: 0.8rem;
  }
  .hero__image { padding-bottom: 0; }
  .hero__img-wrap { aspect-ratio: 3/4; max-width: 320px; margin: 0 auto; }
}

@media (max-width: 900px) {
  .cta-final { padding: 4rem 1.5rem; }
  .cta-final .btn--lg,
  .cta-final .btn--white {
    width: auto;
    max-width: 90%;
    box-sizing: border-box;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    font-size: 0.9rem;
  }
  .servicios__cta-comun .btn--outline {
    padding: 0.7rem 1.4rem;
    font-size: 0.88rem;
  }
}

/* ============================================
   BUTTONS
   ============================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.8rem 1.75rem;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.92rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition);
  border: 2px solid transparent;
  white-space: nowrap;
  text-decoration: none;
}

.btn--primary {
  background: var(--color-azul-gris);
  color: var(--color-white);
  border-color: var(--color-azul-gris);
}
.btn--primary:hover {
  background: var(--color-azul-oscuro);
  border-color: var(--color-azul-oscuro);
}

.btn--outline {
  background: transparent;
  color: var(--color-azul-gris);
  border-color: var(--color-azul-medio);
}
.btn--outline:hover {
  background: var(--color-azul-gris);
  color: var(--color-white);
  border-color: var(--color-azul-gris);
}

.btn--white {
  background: var(--color-white);
  color: var(--color-azul-oscuro);
  border-color: var(--color-white);
}
.btn--white:hover {
  background: var(--color-perla);
}

.btn--lg { padding: 0.95rem 2.2rem; font-size: 1rem; }

/* ============================================
   SECCIÓN 2: POR QUÉ CONMIGO
   ============================================ */
.porque__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}

.porque__text-block { max-width: 480px; }
.porque__text-block h2 { color: var(--color-azul-gris); margin-bottom: 1.5rem; }
.porque__text-block p { margin-bottom: 1rem; color: #555; }

.porque__cards { display: flex; flex-direction: column; gap: 1rem; }
.porque__card {
  background: var(--color-white);
  border-left: 3px solid var(--color-azul-medio);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 1.25rem 1.5rem;
  box-shadow: var(--shadow-card);
}
.porque__card h4 { color: var(--color-azul-gris); margin-bottom: 0.4rem; font-size: 0.95rem; }
.porque__card p { font-size: 0.875rem; color: #555; line-height: 1.65; }

.porque__image {
  border-radius: 12px;
  overflow: hidden;
  position: relative;
}
.porque__image img {
  width: 100%; height: 100%;
  object-fit: cover;
  min-height: 420px;
}

@media (max-width: 900px) {
  .porque__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .porque__image { display: none; } /* hide on mobile, content is enough */
  .porque__text-block { max-width: 100%; }
}

/* ============================================
   SECCIÓN 3: ¿TE RECONOCES? (Tabs)
   ============================================ */
.reconoces__tabs {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 2rem;
}

.tab-btn {
  padding: 0.6rem 1.2rem;
  border: 2px solid var(--color-credential-border);
  background: transparent;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  color: var(--color-azul-medio);
  transition: all var(--transition);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.tab-btn .tab-num { color: var(--color-azul-medio); font-weight: 700; }
.tab-btn:hover {
  border-color: var(--color-azul-gris);
  color: var(--color-azul-gris);
}
.tab-btn.active {
  border-color: var(--color-azul-gris);
  border-left-width: 4px;
  color: var(--color-azul-gris);
  background: rgba(79,111,134,.05);
}

.reconoces__content { max-width: 800px; margin: 0 auto; }

.tab-panel { display: none; }
.tab-panel.active { display: block; }

.tab-panel__intro {
  font-style: italic;
  color: #666;
  margin-bottom: 1.25rem;
  padding: 1rem 1.25rem;
  border-left: 3px solid var(--color-azul-medio);
  background: rgba(122,148,160,.04);
  border-radius: 0 var(--radius) var(--radius) 0;
}

.tab-panel__list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 2rem;
}
.tab-panel__list li {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  font-size: 0.95rem;
  line-height: 1.65;
}
.tab-panel__list li::before {
  content: "→";
  color: var(--color-azul-medio);
  flex-shrink: 0;
  font-size: 0.85rem;
}

.reconoces__cta { text-align: center; margin-top: 2.5rem; }

/* ============================================
   SECCIÓN 4: QUÉ LOGRARÁS
   ============================================ */
.logras__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: var(--max-width);
  margin: 0 auto;
}

.logras__card {
  background: var(--color-card);
  border-radius: var(--radius);
  padding: 2rem 1.75rem;
  box-shadow: var(--shadow-card);
}
.logras__card h3 {
  color: var(--color-azul-gris);
  margin-bottom: 1rem;
  font-size: 1.1rem;
}
.logras__card ul { display: flex; flex-direction: column; gap: 0.6rem; }
.logras__card li {
  font-size: 0.9rem;
  color: #555;
  display: flex;
  gap: 0.6rem;
  align-items: baseline;
  line-height: 1.6;
}
.logras__card li::before {
  content: "✓";
  color: var(--color-azul-medio);
  flex-shrink: 0;
  font-size: 0.8rem;
}

@media (max-width: 900px) { .logras__grid { grid-template-columns: 1fr; max-width: 520px; } }
@media (min-width: 901px) and (max-width: 1100px) { .logras__grid { grid-template-columns: repeat(2, 1fr); } }

/* ============================================
   SECCIÓN 5: CÓMO TRABAJO
   ============================================ */
.como__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}
.como__subtitle { max-width: 700px; margin: 0 auto 3rem; text-align: center; color: #555; }

.como__timeline {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
  margin-bottom: 1.25rem;
}
.como__timeline::before {
  content: '';
  position: absolute;
  top: 32px;
  left: calc(16.67% + 1rem);
  right: calc(16.67% + 1rem);
  height: 2px;
  background: var(--color-azul-medio);
  z-index: 0;
}

.fase {
  padding: 0 1.5rem 2rem;
  cursor: pointer;
  transition: all var(--transition);
  position: relative;
}
.fase__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.5rem;
}
.fase__num {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--color-white);
  border: 2px solid var(--color-credential-border);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-azul-medio);
  letter-spacing: 0.05em;
  position: relative; z-index: 1;
  transition: all var(--transition);
  margin-bottom: 0.75rem;
}
.fase.active .fase__num {
  background: var(--color-azul-gris);
  color: var(--color-white);
  border-color: var(--color-azul-gris);
}
.fase__title {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-azul-oscuro);
  text-align: center;
}

.fase__content { display: none; }
.fase.active .fase__content { display: block; }

.fase__intro { font-style: italic; color: #666; margin-bottom: 1rem; font-size: 0.9rem; }
.fase__list { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1rem; }
.fase__list li { font-size: 0.875rem; color: #555; display: flex; gap: 0.6rem; align-items: baseline; }
.fase__list li::before { content: "→"; color: var(--color-azul-medio); flex-shrink: 0; font-size: 0.8rem; }
.fase__resultado {
  background: var(--color-card);
  border-radius: var(--radius);
  padding: 0.85rem 1rem;
  font-size: 0.85rem;
  color: var(--color-azul-gris);
  font-weight: 500;
}
.fase__resultado strong { display: block; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 0.25rem; }

.como__active-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  align-items: start;
  background: var(--color-perla);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.5rem;
}
.como__active-text h3 {
  color: var(--color-azul-oscuro);
  margin-bottom: 0.5rem;
}
.como__active-image img {
  border-radius: var(--radius);
  width: auto;
  max-width: 100%;
  max-height: 300px;
  display: block;
}

.como__encaja {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  max-width: 860px;
  margin: 0 auto;
}
.encaja__col {
  background: var(--color-card);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.encaja__col h4 {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid;
}
.encaja__col--si h4 { color: var(--color-azul-gris); border-color: var(--color-azul-gris); }
.encaja__col--no h4 { color: #aaa; border-color: #ddd; }
.encaja__col ul { display: flex; flex-direction: column; gap: 0.5rem; }
.encaja__col li { font-size: 0.875rem; color: #555; display: flex; gap: 0.6rem; }
.encaja__col--si li::before { content: "✓"; color: var(--color-azul-medio); }
.encaja__col--no li::before { content: "✗"; color: #ccc; }

@media (max-width: 900px) {
  .como__timeline { grid-template-columns: 1fr; }
  .como__timeline::before { display: none; }
  .fase { padding: 1rem 0; border-bottom: 1px solid var(--color-credential-border); }
  .fase__header { flex-direction: row; align-items: center; gap: 1rem; }
  .fase__num { margin-bottom: 0; width: 48px; height: 48px; }
  .como__active-content { grid-template-columns: 1fr; }
  .como__encaja { grid-template-columns: 1fr; }
}

/* ============================================
   SECCIÓN 6: TESTIMONIOS
   ============================================ */
.testimonios__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

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

.testimonio {
  background-color: #DDE6EC;
  border-radius: 8px;
  padding: 1.25rem 1.5rem;
  font-size: 0.88rem;
  line-height: 1.6;
  position: relative;
}
.testimonio__quote {
  display: none;
}
.testimonio p {
  font-size: 0.88rem;
  line-height: 1.6;
  color: #2E2E2E;
  margin: 0 0 0.75rem;
}
.testimonio__author {
  font-size: 0.8rem;
  font-weight: 600;
  color: #3E5A6D;
  margin-top: 0.5rem;
}
.testimonio__role { font-weight: 400; color: #7A94A0; }

@media (max-width: 900px) {
  .testimonios__grid { grid-template-columns: 1fr; }
}

/* ============================================
   SECCIÓN 7: SERVICIOS
   ============================================ */
.servicios__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  max-width: var(--max-width);
  margin: 0 auto;
}
.servicios__grid--3col {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1100px) {
  .servicios__grid--3col {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Tarjeta base */
.servicio-card {
  background-color: #DDE6EC;
  border-radius: 10px;
  border: 1px solid #C8DCE8;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.2s;
}
.servicio-card:hover {
  box-shadow: 0 4px 16px rgba(62, 90, 109, 0.12);
}

/* Inner con padding */
.servicio-card__inner {
  padding: 1.5rem 1.5rem 0.5rem;
}

/* Tipo / etiqueta superior */
.servicio-card__tipo {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  color: #4F6F86;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.4rem;
}

/* Título H3 */
.servicio-card h3 {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  color: #3E5A6D;
  margin-top: 0.25rem;
  margin-bottom: 0.5rem;
  line-height: 1.25;
}

/* Frase descriptiva */
.servicio-card__frase {
  font-size: 0.9rem;
  color: #4F6F86;
  font-style: italic;
  margin-top: 0;
  margin-bottom: 0.75rem;
  line-height: 1.4;
}

/* Separador */
.servicio-card__divider {
  border: none;
  border-top: 1px solid #C8DCE8;
  margin: 0.75rem 0;
}

/* Para quién */
.servicio-card__para {
  font-size: 0.85rem;
  color: #3E5A6D;
  line-height: 1.5;
  margin-bottom: 0.75rem;
}
.servicio-card__para strong {
  font-weight: 600;
}

/* Lista de qué incluye */
.servicio-card__items {
  list-style: none;
  padding: 0;
  margin: 0 0 0.75rem 0;
}
.servicio-card__items li {
  font-size: 0.83rem;
  color: #3E5A6D;
  padding: 0.2rem 0 0.2rem 1rem;
  position: relative;
  line-height: 1.4;
}
.servicio-card__items li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: #7A94A0;
  font-weight: 700;
}

/* Duración */
.servicio-card__duracion {
  font-size: 0.78rem;
  color: #7A94A0;
  font-weight: 500;
  margin-bottom: 0;
  padding-bottom: 1rem;
}

/* Footer de la tarjeta — botón */
.servicio-card__footer {
  padding: 0.75rem 1.5rem 1.25rem;
  border-top: 1px solid #C8DCE8;
  margin-top: auto;
}

/* Botón pequeño para tarjetas */
.btn--sm {
  font-size: 0.85rem;
  padding: 0.5rem 1.1rem;
}

/* Badge "Más solicitado" */
.servicio-card__badge {
  position: absolute;
  top: 0;
  right: 0;
  background-color: #3E5A6D;
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.3rem 0.75rem;
  border-bottom-left-radius: 8px;
  letter-spacing: 0.04em;
}

/* Tarjeta destacada — mismo color que las demás, solo badge diferente */
.servicio-card--destacado {
  background-color: #DDE6EC;
  border-color: #C8DCE8;
}
.servicio-card--destacado .servicio-card__tipo,
.servicio-card--destacado h3,
.servicio-card--destacado .servicio-card__frase,
.servicio-card--destacado .servicio-card__para,
.servicio-card--destacado .servicio-card__items li,
.servicio-card--destacado .servicio-card__duracion {
  color: #3E5A6D;
}
.servicio-card--destacado .servicio-card__divider,
.servicio-card--destacado .servicio-card__footer {
  border-color: #C8DCE8;
}
.servicio-card--destacado .servicio-card__items li::before {
  color: #7A94A0;
}
/* Badge mantiene el azul oscuro para que "Más solicitado" siga destacando */
.servicio-card--destacado .servicio-card__badge {
  background-color: #3E5A6D;
  color: #ffffff;
}

/* Tarjeta empresas — más clara */
.servicio-card--org {
  background-color: #F0F6F9;
  border-color: #C8DCE8;
}
.servicio-card--org .servicio-card__tipo {
  color: #4F6F86;
}
.servicio-card--org h3 {
  color: #3E5A6D;
}
.servicio-card--org .servicio-card__footer {
  border-top-color: #C8DCE8;
}

/* Grid 4 columnas */
.servicios__grid--4col {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  align-items: stretch;
  margin-bottom: 2.5rem;
}

/* Responsive servicios */
@media (max-width: 768px) { .servicios__grid { grid-template-columns: 1fr; } }
@media (max-width: 1024px) {
  .servicios__grid--4col {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .servicios__grid--4col {
    grid-template-columns: 1fr;
  }
  .servicio-card__inner {
    padding: 1.25rem 1.25rem 0.5rem;
  }
  .servicio-card__footer {
    padding: 0.75rem 1.25rem 1rem;
  }
}

/* ============================================
   SECCIÓN 8: SOBRE MÍ
   ============================================ */
.sobre__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 4rem;
  align-items: start;
}

.sobre__image {
  border-radius: 12px;
  overflow: hidden;
  position: sticky;
  top: 5rem;
}
.sobre__image img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  object-position: top;
}

.sobre__content .eyebrow { margin-bottom: 0.5rem; }
.sobre__content h2 { color: var(--color-azul-gris); margin-bottom: 1.5rem; }

.sobre__stats {
  display: flex;
  gap: 1.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}
.sobre__stat .num {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-azul-gris);
  line-height: 1;
}
.sobre__stat .label {
  font-size: 0.75rem;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.sobre__content p { margin-bottom: 1rem; color: #555; font-size: 0.95rem; }

.sobre__link-more {
  display: inline-block;
  margin-top: 0.75rem;
  margin-bottom: 1.25rem;
  color: var(--color-azul-gris);
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid var(--color-azul-medio);
  padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
}
.sobre__link-more:hover {
  color: var(--color-azul-oscuro);
  border-color: var(--color-azul-oscuro);
}

.sobre__credentials {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1.5rem;
}
.credential-tag {
  background: #EDF1F3;
  border: 1px solid #D0DAE0;
  color: #4F6F86;
  font-size: 0.78rem;
  font-weight: 500;
  padding: 0.3rem 0.75rem;
  border-radius: 100px;
}

@media (max-width: 900px) {
  .sobre__inner { grid-template-columns: 1fr; }
  .sobre__image { max-width: 360px; margin: 0 auto; position: static; }
}

/* ============================================
   SECCIÓN 9: FAQ
   ============================================ */
.faq__inner {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid var(--color-credential-border);
}
.faq-item:first-child { border-top: 1px solid var(--color-credential-border); }

.faq-question {
  width: 100%;
  background: none;
  border: none;
  padding: 1.25rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-texto);
  transition: color var(--transition);
}
.faq-question:hover { color: var(--color-azul-gris); }
.faq-question[aria-expanded="true"] { color: var(--color-azul-gris); }

.faq-icon {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 1.5px solid var(--color-azul-medio);
  color: var(--color-azul-medio);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  transition: all var(--transition);
}
.faq-question[aria-expanded="true"] .faq-icon {
  background: var(--color-azul-gris);
  border-color: var(--color-azul-gris);
  color: var(--color-white);
  transform: rotate(45deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease, padding 0.2s ease;
}
.faq-answer.open { max-height: 600px; }
.faq-answer p {
  padding-bottom: 1.25rem;
  font-size: 0.92rem;
  color: #555;
  line-height: 1.75;
}

/* ============================================
   SECCIÓN 10: CTA FINAL
   ============================================ */
.cta-final {
  background-color: #F9FBFC;
  padding: 6rem 1.5rem;
  text-align: center;
}
.cta-final__inner { max-width: 680px; margin: 0 auto; }
.cta-final h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  color: #3E5A6D;
  margin-bottom: 1rem;
}
.cta-final p {
  color: #4F6F86;
  font-size: 1.05rem;
  margin-bottom: 2rem;
}
.cta-final__microcopy { font-size: 0.85rem; color: #7A94A0; margin-top: 0.75rem; }
.cta-final .btn--white,
.cta-final .btn--lg {
  background-color: #3E5A6D;
  color: #ffffff;
  border: 2px solid #3E5A6D;
}
.cta-final .btn--white:hover,
.cta-final .btn--lg:hover {
  background-color: #2E4A5C;
  border-color: #2E4A5C;
}

/* ============================================
   FOOTER
   ============================================ */
.footer {
  background-color: #3E5A6D;
  color: #EDF1F3;
  padding: 4rem 1.5rem 2rem;
}

.footer__grid {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--color-credential-border);
}

.footer__brand-name {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 700;
  color: #EDF1F3;
  display: block;
  margin-bottom: 0.25rem;
}
.footer__tagline {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #B8CDD8;
  display: block;
  margin-bottom: 1rem;
}
.footer__desc { font-size: 0.875rem; color: #B8CDD8; line-height: 1.7; margin-bottom: 1.25rem; }

.footer__social { display: flex; gap: 0.75rem; }
.footer__social a {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1.5px solid #4F6F86;
  display: flex; align-items: center; justify-content: center;
  color: #B8CDD8;
  transition: all var(--transition);
}
.footer__social a:hover {
  border-color: #EDF1F3;
  color: #EDF1F3;
  background: rgba(255,255,255,.08);
}
.footer__social svg { width: 16px; height: 16px; }

.footer__col h5 {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #EDF1F3;
  margin-bottom: 1rem;
  font-weight: 600;
}
.footer__col ul { display: flex; flex-direction: column; gap: 0.5rem; }
.footer__col a {
  font-size: 0.875rem;
  color: #B8CDD8;
  transition: color var(--transition);
}
.footer__col a:hover { color: #ffffff; }

.footer__contact-item {
  display: flex;
  gap: 0.6rem;
  align-items: flex-start;
  font-size: 0.875rem;
  color: #B8CDD8;
  margin-bottom: 0.5rem;
}
.footer__contact-icon { stroke: #B8CDD8; flex-shrink: 0; margin-top: 2px; }

.footer__bottom {
  max-width: var(--max-width);
  margin: 2rem auto 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  border-top: 1px solid #4F6F86;
  padding-top: 1.5rem;
}
.footer__bottom p { font-size: 0.8rem; color: #96AAB5; }
.footer__bottom-links {
  display: flex; gap: 1.5rem;
}
.footer__bottom-links a {
  font-size: 0.8rem;
  color: #96AAB5;
  transition: color var(--transition);
}
.footer__bottom-links a:hover { color: #ffffff; }

@media (max-width: 900px) {
  .footer__grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer__bottom { flex-direction: column; text-align: center; }
}

/* ============================================
   COOKIE BANNER
   ============================================ */
.cookie-banner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 2000;
  background: var(--color-white);
  border-top: 1px solid var(--color-credential-border);
  box-shadow: 0 -4px 24px rgba(62,90,109,.12);
  padding: 1.25rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
  transform: translateY(100%);
  transition: transform 0.4s ease;
}
.cookie-banner.visible { transform: translateY(0); }
.cookie-banner.hidden { display: none; }

.cookie-banner__text { flex: 1; min-width: 260px; }
.cookie-banner__text p { font-size: 0.85rem; color: #555; }
.cookie-banner__text a { color: var(--color-azul-gris); text-decoration: underline; }

.cookie-banner__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.cookie-banner__actions .btn { padding: 0.55rem 1.15rem; font-size: 0.82rem; }

/* ============================================
   PÁGINA CONTACTO
   ============================================ */
.contacto-page {
  padding: 8rem 1.5rem 5rem;
  min-height: 100vh;
  background: var(--color-white);
}
.contacto-page__inner {
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 4rem;
  align-items: start;
}

.contacto-page h1 { color: var(--color-azul-gris); margin-bottom: 1rem; }
.contacto-page .subtitle { font-size: 1.05rem; color: #555; margin-bottom: 2rem; }

.contact-form { display: flex; flex-direction: column; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: 0.4rem; }
.form-group label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-texto);
}
.form-group input,
.form-group select,
.form-group textarea {
  padding: 0.75rem 1rem;
  border: 1.5px solid var(--color-credential-border);
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-texto);
  background: var(--color-white);
  transition: border-color var(--transition);
  outline: none;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--color-azul-gris); }
.form-group textarea { resize: vertical; min-height: 120px; }

.form-consent { font-size: 0.8rem; color: #888; }
.form-consent a { color: var(--color-azul-gris); text-decoration: underline; }

.contact-aside { display: flex; flex-direction: column; gap: 1.5rem; }

.contact-aside__box {
  background: var(--color-perla);
  border-radius: var(--radius);
  padding: 1.75rem;
}
.contact-aside__box h3 { color: var(--color-azul-gris); font-size: 1.05rem; margin-bottom: 0.75rem; }
.contact-aside__box p { font-size: 0.875rem; color: #555; margin-bottom: 1rem; }

.contact-aside__item {
  display: flex; gap: 0.75rem; align-items: center;
  font-size: 0.875rem; margin-bottom: 0.6rem;
}
.contact-aside__item svg { color: var(--color-azul-medio); flex-shrink: 0; }
.contact-aside__item a { color: var(--color-texto); }
.contact-aside__item a:hover { color: var(--color-azul-gris); }

@media (max-width: 768px) {
  .contacto-page { padding: 5.5rem 1.5rem 4rem; }
  .contacto-page__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    max-width: 100%;
    width: 100%;
  }
  .contacto-page .subtitle { font-size: 0.95rem; }
  .contact-form { width: 100%; max-width: 100%; }
  .contact-aside { width: 100%; max-width: 100%; }
  .contact-aside__box { padding: 1.25rem; }
  .contact-aside__box a.btn {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    justify-content: center;
    display: flex;
    white-space: normal;
    text-align: center;
  }
}

/* ============================================
   PÁGINAS LEGALES
   ============================================ */
.legal-page {
  padding: 8rem 1.5rem 5rem;
  min-height: 100vh;
  background: var(--color-white);
}
.legal-page__inner { max-width: 800px; margin: 0 auto; }
.legal-page h1 { color: var(--color-azul-gris); margin-bottom: 0.5rem; }
.legal-page .updated { font-size: 0.8rem; color: #aaa; margin-bottom: 3rem; }
.legal-page h2 { font-size: 1.2rem; color: var(--color-azul-gris); margin: 2.5rem 0 0.75rem; }
.legal-page p, .legal-page li { font-size: 0.95rem; color: #555; line-height: 1.75; }
.legal-page ul { list-style: disc; padding-left: 1.5rem; display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1rem; }
.legal-page a { color: var(--color-azul-gris); text-decoration: underline; }

.servicio-detalle {
  padding-top: 1.25rem;
  margin-top: 0.75rem;
  border-top: 1px solid var(--color-credential-border);
}
.servicio-detalle p { margin-bottom: 0.75rem; }
.servicio-card__subhead {
  font-weight: 600;
  color: var(--color-azul-gris);
  font-size: 0.88rem;
  margin-top: 0.5rem;
}
.servicio-card__entregable {
  background: var(--color-credential-bg);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  margin: 0.75rem 0;
  font-size: 0.85rem;
}
.servicio-card__diferenciadora {
  font-size: 0.85rem;
  color: #666;
  border-left: 3px solid var(--color-azul-medio);
  padding-left: 1rem;
  margin-top: 0.75rem;
}
.servicios__organizaciones {
  background: var(--color-perla);
  border-radius: var(--radius);
  padding: 2.5rem;
  margin-top: 2rem;
}
.servicios__org-inner {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  justify-content: space-between;
}
.servicios__org-content { flex: 1; }
.servicios__org-content h3 {
  color: var(--color-azul-gris);
  font-size: 1.15rem;
  margin-bottom: 0.75rem;
}
.servicios__org-cta {
  flex-shrink: 0;
  align-self: center;
}
.servicios__cta-comun {
  text-align: center;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-credential-border);
}
.servicios__cta-comun p {
  font-size: 1rem;
  color: #555;
  margin-bottom: 1.25rem;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 768px) {
  .servicios__organizaciones { padding: 1.75rem; }
  .servicios__org-inner { flex-direction: column; gap: 1.25rem; }
}

/* ============================================
   PÁGINA SOBRE MÍ
   ============================================ */
.sobre-page__hero {
  padding: 7rem 1.5rem 4rem;
  background: var(--color-perla);
}

.sobre-page__prose {
  max-width: 720px;
}
.sobre-page__prose p {
  margin-bottom: 1.5rem;
  line-height: 1.75;
  color: #555;
}
.sobre-page__prose p:last-child { margin-bottom: 0; }

.sobre-page__subblock {
  margin-top: 2.5rem;
}
.sobre-page__subblock h3 {
  color: var(--color-azul-gris);
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  margin-bottom: 0.75rem;
}

.sobre-page__audience {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr 1fr;
  margin-top: 2rem;
}
.sobre-page__audience-item {
  background: var(--color-white);
  border: 1px solid var(--color-credential-border);
  border-radius: var(--radius);
  padding: 1.75rem;
}
.sobre-page__audience-item h3 {
  font-size: 1rem;
  color: var(--color-azul-gris);
  margin-bottom: 0.75rem;
}
.sobre-page__audience-item p {
  font-size: 0.95rem;
  color: #555;
  line-height: 1.7;
}

@media (max-width: 768px) {
  .sobre-page__audience { grid-template-columns: 1fr; }
}

/* ============================================
   SOBRE MÍ — block title
   ============================================ */
.sobre__block-title {
  color: var(--color-azul-gris);
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

/* ============================================
   PÁGINA SERVICIOS
   ============================================ */
.servicios-page__hero {
  padding: 9rem 1.5rem 4rem;
  background: var(--color-white);
  border-bottom: 1px solid var(--color-credential-border);
}
.servicios-page__hero h1 {
  color: var(--color-azul-gris);
  max-width: 700px;
  margin-bottom: 1rem;
}
.servicios-page__intro {
  max-width: 620px;
  color: #555;
  font-size: 1.05rem;
}

.servicios-page__item {
  padding: 5rem 1.5rem;
}
.servicios-page__item + .servicios-page__item {
  border-top: 1px solid var(--color-credential-border);
}

.sp__item-inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.sp__item-header {
  margin-bottom: 3rem;
}
.sp__tipo {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-azul-medio);
  margin-bottom: 0.75rem;
}
.sp__tipo--destacado {
  color: var(--color-azul-gris);
  background: rgba(79,111,134,.08);
  padding: 0.2rem 0.6rem;
  border-radius: 100px;
}
.sp__item-header h2 {
  color: var(--color-azul-gris);
  margin-bottom: 0.5rem;
}
.sp__frase {
  font-size: 1.1rem;
  color: #555;
  font-weight: 400;
}

.sp__item-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}

.sp__col-title {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-azul-medio);
  margin-top: 2rem;
  margin-bottom: 0.85rem;
}
.sp__col-title:first-child { margin-top: 0; }

.sp__col > p {
  font-size: 0.95rem;
  color: #555;
  line-height: 1.75;
  margin-bottom: 0;
}

.sp__list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.sp__list li {
  font-size: 0.9rem;
  color: #555;
  display: flex;
  gap: 0.75rem;
  align-items: baseline;
  line-height: 1.65;
}
.sp__list li::before {
  content: "→";
  color: var(--color-azul-medio);
  flex-shrink: 0;
  font-size: 0.8rem;
}
.sp__list--bold li {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--color-credential-border);
}
.sp__list--bold li:last-child { border-bottom: none; padding-bottom: 0; }
.sp__list--bold li::before { display: none; }
.sp__list--bold strong {
  color: var(--color-azul-gris);
  font-size: 0.9rem;
}

.sp__entregable {
  background: var(--color-credential-bg);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  margin: 1.5rem 0;
  font-size: 0.88rem;
  color: #555;
  line-height: 1.65;
}
.sp__entregable strong { color: var(--color-azul-gris); }

.sp__diferenciadora {
  font-size: 0.88rem;
  color: #666;
  border-left: 3px solid var(--color-azul-medio);
  padding-left: 1rem;
  line-height: 1.7;
  font-style: italic;
  margin-top: 1.5rem;
}

/* Caja lateral "Incluye" */
.sp__incluye-box {
  background: var(--color-white);
  border-radius: 12px;
  padding: 2rem;
  box-shadow: var(--shadow-card);
  position: sticky;
  top: 90px;
}
.sp__incluye-box--destacado {
  border: 2px solid var(--color-azul-gris);
}
.section--perla .sp__incluye-box {
  background: var(--color-white);
}

.sp__incluye-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.sp__incluye-list li {
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
}
.sp__check {
  color: var(--color-azul-gris);
  font-weight: 700;
  font-size: 0.9rem;
  flex-shrink: 0;
  margin-top: 1px;
}
.sp__incluye-list li > div {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.sp__incluye-list li strong {
  font-size: 0.88rem;
  color: var(--color-texto);
}
.sp__incluye-list li span {
  font-size: 0.8rem;
  color: #888;
  line-height: 1.5;
}

.sp__duracion {
  font-size: 0.82rem;
  color: var(--color-azul-medio);
  font-weight: 600;
  padding: 0.5rem 0;
  border-top: 1px solid var(--color-credential-border);
  border-bottom: 1px solid var(--color-credential-border);
  margin-bottom: 1.25rem;
}

.sp__precio-box {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-top: 1.25rem;
}
.sp__precio-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #aaa;
}
.sp__precio {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--color-azul-oscuro);
  font-family: var(--font-heading);
}

/* Spacing entre textos en las cards de home */
.servicio-card__paraquien { margin-top: 0.5rem; margin-bottom: 1rem; }

@media (max-width: 900px) {
  .sp__item-body { grid-template-columns: 1fr; gap: 2.5rem; }
  .sp__incluye-box { position: static; }
  .servicios-page__hero { padding: 8rem 1.5rem 3rem; }
}

/* ============================================
   UTILIDADES
   ============================================ */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.text-center { text-align: center; }
.mb-1 { margin-bottom: 1rem; }
.mb-2 { margin-bottom: 2rem; }
.mt-2 { margin-top: 2rem; }

/* Scroll anchor offset (fixed nav) */
[id] { scroll-margin-top: 80px; }

/* Lazy loading fade */
img.lazy { opacity: 0; transition: opacity 0.4s ease; }
img.lazy.loaded { opacity: 1; }

/* Focus visible */
:focus-visible {
  outline: 2px solid var(--color-azul-gris);
  outline-offset: 3px;
  border-radius: 4px;
}


/* ── Servicios página: bloques ── */
.servicios-page__lista {
  background-color: #ffffff;
}
.sp__bloque {
  background-color: #DDE6EC;
  border-radius: 10px;
  padding: 2.5rem;
  margin-bottom: 2rem;
  border: 1px solid #C8DCE8;
}
.sp__bloque--destacado {
  background-color: #DDE6EC;
  border-color: #C8DCE8;
}
.sp__bloque--destacado .sp__tipo--destacado {
  background-color: #7A94A0;
  color: #ffffff;
}
.sp__bloque--destacado .sp__duracion {
  color: #B8CDD8;
}
.sp__bloque--org {
  background-color: #EEF4F7;
  border: 1px solid #C8DCE8;
}
.sp__bloque h2 {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  font-size: 1.5rem;
  color: #3E5A6D;
  line-height: 1.25;
}
.sp__bloque--destacado h2 {
  color: #ffffff;
}
.sp__frase {
  font-size: 1.05rem;
  color: #4F6F86;
  margin-top: 0;
  margin-bottom: 0;
  font-style: italic;
}
.sp__tipo {
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #888;
  background: #f2f2f0;
  padding: 2px 10px;
  border-radius: 20px;
  white-space: nowrap;
}
.sp__tipo--destacado {
  background-color: #7A94A0;
  color: #ffffff;
}
.sp__bloque-header {
  padding-bottom: 1.25rem;
  border-bottom: 1px solid #C8DCE8;
  margin-bottom: 0;
}
.sp__bloque--destacado .sp__bloque-header {
  border-bottom-color: #4F6F86;
}
.sp__bloque-body {
  display: grid;
  grid-template-columns: 1fr 1.6fr 1fr;
  gap: 0;
  margin-top: 0;
  margin-bottom: 0;
}
.sp__bloque-body--org {
  grid-template-columns: 1fr 1fr;
}
.sp__col {
  padding: 1.25rem 1.5rem;
  border-right: 1px solid #C8DCE8;
  font-size: 0.88rem;
  color: #3E5A6D;
  line-height: 1.55;
}
.sp__col:last-child {
  border-right: none;
}
.sp__col p {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-size: 0.88rem;
  color: #3E5A6D;
  line-height: 1.6;
}
.sp__col p + p {
  margin-top: 0.75rem;
}
.sp__col-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: #4F6F86;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.75rem;
  margin-top: 0;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid #C8DCE8;
}
.sp__bloque--destacado .sp__col-label {
  color: #B8CDD8;
}
.sp__bloque--destacado .sp__col p {
  color: #EDF1F3;
}
.sp__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.sp__list li {
  font-size: 0.88rem;
  color: #3E5A6D;
  display: block;
  line-height: 1.45;
  padding-left: 1.1rem;
  position: relative;
}
.sp__bloque--destacado .sp__list li {
  color: #EDF1F3;
}
.sp__list li::before {
  content: "✓";
  font-size: 0.75rem;
  color: #4F6F86;
  position: absolute;
  left: 0;
  top: 0.25em;
}
.sp__bloque--destacado .sp__list li::before {
  color: #B8CDD8;
}
.sp__duracion {
  font-size: 0.85rem;
  color: #7A94A0;
  font-weight: 500;
  margin-top: 0.75rem;
}
.sp__bloque-footer {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid #C8DCE8;
  margin-top: 1.5rem;
}
.sp__bloque--destacado .sp__bloque-footer {
  border-top-color: #4F6F86;
}
.sp__microcopy {
  font-size: 0.85rem;
  color: #7A94A0;
}
.sp__bloque--destacado .sp__microcopy {
  color: #B8CDD8;
}
@media (max-width: 900px) {
  .sp__bloque-body,
  .sp__bloque-body--org {
    grid-template-columns: 1fr;
  }
  .sp__col {
    border-right: none;
    border-bottom: 1px solid #C8DCE8;
    padding: 1rem 1.25rem;
  }
  .sp__col:last-child {
    border-bottom: none;
  }
}
@media (max-width: 768px) {
  .sp__bloque {
    padding: 1.5rem;
  }
  .sp__bloque-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
  .sp__bloque h2 {
    font-size: 1.3rem;
  }
  .sp__frase {
    font-size: 0.95rem;
  }
  .sp__col > p,
  .sp__col p,
  .sp__list li {
    font-size: 0.875rem;
  }
  .sp__subtema {
    font-size: 0.875rem;
  }
  .sp__asi-consigues {
    font-size: 0.85rem;
  }
}

/* ============================================
   PÁGINA SOBRE MÍ v3
   ============================================ */

/* Imágenes generadas con IA */
.img-ai {
  filter: contrast(0.96) brightness(1.02) saturate(0.95);
  border-radius: 8px;
  object-fit: cover;
  display: block;
}

/* Hero de la página */
.sm-page-hero {
  padding: 7rem 1.5rem 0;
  background: var(--color-white);
}
.sm-hero {
  display: grid;
  grid-template-columns: 45% 55%;
  gap: 4rem;
  align-items: start;
  padding: 2rem 0 4rem;
}
.sm-hero__image img {
  width: 100%;
  max-height: 580px;
  object-fit: cover;
  object-position: top center;
  border-radius: 4px;
  display: block;
}
.sm-hero__content .eyebrow { margin-bottom: 0.75rem; }
.sm-hero__content h1 {
  color: var(--color-azul-oscuro);
  margin-bottom: 1.25rem;
}
.sm-intro {
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--color-texto);
  margin-bottom: 2rem;
}
.sm-hero hr {
  border: none;
  border-top: 1px solid var(--color-credential-border);
  margin: 1.75rem 0;
}
.sm-hero .sobre__credentials { margin-top: 0; }

@media (max-width: 768px) {
  .sm-page-hero { padding: 5.5rem 1.5rem 0; }
  .sm-hero {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 1.5rem 0 3rem;
  }
  .sm-hero__image img { max-height: 420px; }
}

/* Stats */
.sm-stats {
  display: flex;
  flex-wrap: nowrap;
  gap: 2rem;
  margin-bottom: 2rem;
}
.sm-stat__num {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  color: var(--color-azul-gris);
  line-height: 1;
  font-weight: 700;
}
.sm-stat__label {
  font-size: 0.85rem;
  color: var(--color-azul-medio);
  margin-top: 0.25rem;
  line-height: 1.3;
}
@media (max-width: 480px) {
  .sm-stat__num { font-size: 1.8rem; }
  .sm-stats { gap: 1.25rem; }
}

/* Secciones de contenido */
.sm-section {
  padding: 5rem 1.5rem;
}
.sm-section h2 {
  margin-top: 0;
  margin-bottom: 1.75rem;
  line-height: 1.25;
  color: var(--color-azul-gris);
}
.sm-section h3 {
  margin-top: 2.5rem;
  margin-bottom: 1.25rem;
  color: var(--color-azul-oscuro);
}
.sm-section p {
  margin-bottom: 1.25rem;
  line-height: 1.75;
  color: #555;
}
.sm-section ul {
  margin-bottom: 1.5rem;
  padding-left: 1.25rem;
  list-style: disc;
}
.sm-section li {
  margin-bottom: 0.65rem;
  line-height: 1.7;
  color: #555;
}
.sm-prose {
  max-width: 780px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .sm-section { padding: 3.5rem 1.5rem; }
  .sm-section h2 { font-size: 1.45rem; margin-bottom: 1.25rem; }
  .sm-section h3 { font-size: 1.1rem; margin-top: 2rem; }
  .sm-section p { font-size: 1rem; line-height: 1.7; }
}

/* Bloque 3 — grid texto / imagen */
.sm-coaching-grid {
  display: grid;
  grid-template-columns: 62% 38%;
  gap: 3rem;
  align-items: start;
  max-width: 980px;
  margin: 0 auto;
}
/* Bloque 3 — imagen coaching sticky */
.sm-coaching-img {
  position: sticky;
  top: 6rem;
  align-self: start;
}
.sm-coaching-img img {
  width: 100%;
  max-width: 420px;
  height: 500px;
  object-fit: cover;
  object-position: center center;
  border-radius: 8px;
  display: block;
  margin: 0 auto;
  filter: contrast(0.96) brightness(1.02) saturate(0.95);
}
@media (max-width: 768px) {
  .sm-coaching-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .sm-coaching-img {
    position: static;
    margin-bottom: 2rem;
  }
  .sm-coaching-img img {
    max-width: 100%;
    height: 260px;
    object-position: center 30%;
  }
}

/* Bloque 1 — Quién soy: imagen + texto */
.sm-quien-grid {
  display: grid;
  grid-template-columns: 38% 62%;
  gap: 3.5rem;
  align-items: start;
}
.sm-quien-img {
  position: sticky;
  top: 5rem;
  align-self: start;
}
.sm-quien-img img {
  width: 100%;
  max-height: 560px;
  object-fit: cover;
  object-position: center top;
  border-radius: 6px;
  display: block;
}
@media (max-width: 768px) {
  .sm-quien-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .sm-quien-img {
    position: static;
    order: -1;
  }
  .sm-quien-img img {
    max-height: 360px;
    width: 100%;
    object-position: center 20%;
  }
}

/* Bloque 4 — A quién acompaño */
.sm-a-quien-titulo {
  text-align: center;
  max-width: 780px;
  margin: 0 auto 2.5rem;
}
.sm-a-quien-intro {
  display: grid;
  grid-template-columns: 35% 65%;
  gap: 2.5rem;
  align-items: start;
  margin-bottom: 3.5rem;
}
.sm-a-quien-intro--simple {
  grid-template-columns: 1fr;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.sm-a-quien-img {
  align-self: start;
}
.sm-a-quien-img img {
  width: 100%;
  max-width: 340px;
  height: auto;
  max-height: 320px;
  object-fit: cover;
  object-position: center center;
  border-radius: 8px;
  display: block;
  filter: contrast(0.96) brightness(1.02) saturate(0.95);
}
.sm-a-quien-texto p {
  font-size: 1.05rem;
  line-height: 1.75;
  margin-bottom: 1.25rem;
  color: var(--color-text);
}
.sm-perfiles-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-bottom: 3rem;
}
.sm-perfil-card {
  background: var(--color-card, #DDE6EC);
  border-radius: 8px;
  padding: 2rem;
  border-left: 3px solid var(--color-azul-gris, #4F6F86);
}
.sm-perfil-card h3 {
  margin-top: 0;
  margin-bottom: 1.25rem;
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-azul-oscuro, #3E5A6D);
  line-height: 1.3;
  border-bottom: 1px solid var(--color-credential-border, #D0DAE0);
  padding-bottom: 0.875rem;
}
.sm-perfil-card p {
  margin-bottom: 0.9rem;
  line-height: 1.7;
  font-size: 0.97rem;
}
.sm-perfil-card p:last-child {
  margin-bottom: 0;
}
.sm-a-quien-cta {
  text-align: center;
  padding-top: 1rem;
}
.sm-a-quien-cta .sm-cta-pregunta {
  color: #3E5A6D;
  font-size: 1.1rem;
  font-weight: 500;
  margin-bottom: 1.25rem;
}
@media (max-width: 768px) {
  .sm-a-quien-intro {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .sm-a-quien-img {
    order: -1;
  }
  .sm-a-quien-img img {
    max-width: 100%;
    max-height: 220px;
    object-position: center 30%;
  }
  .sm-perfiles-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .sm-perfil-card {
    padding: 1.5rem;
  }
}

/* ============================================
   TARJETAS HORIZONTALES — SECCIÓN SERVICIOS (index)
   ============================================ */

/* Lista vertical de tarjetas horizontales */
.servicios__lista {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2.5rem;
}

/* Tarjeta horizontal base */
.servicio-card-h {
  background-color: #DDE6EC;
  border: 1px solid #C8DCE8;
  border-radius: 10px;
  display: grid;
  grid-template-columns: 42% 58%;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.2s;
}
.servicio-card-h:hover {
  box-shadow: 0 4px 16px rgba(62, 90, 109, 0.1);
}

/* Columna izquierda */
.servicio-card-h__left {
  padding: 1.5rem 1.75rem 1.5rem 1.5rem;
  border-right: 1px solid #C8DCE8;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.servicio-card-h__left .btn {
  margin-top: auto;
  align-self: flex-start;
  padding-top: 1rem;
}

/* Columna derecha */
.servicio-card-h__right {
  padding: 1.5rem 1.5rem 1.5rem 1.75rem;
  background-color: rgba(255,255,255,0.35);
}

/* Label de sección dentro de columna derecha */
.servicio-card-h__label {
  font-size: 0.75rem;
  font-weight: 600;
  color: #4F6F86;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.4rem;
  margin-top: 0;
}

/* Badge "Más solicitado" */
.servicio-card__badge-h {
  position: absolute;
  top: 0;
  right: 0;
  background-color: #3E5A6D;
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.3rem 0.85rem;
  border-bottom-left-radius: 8px;
  letter-spacing: 0.04em;
}

/* Tarjeta empresas — más clara */
.servicio-card-h--org {
  background-color: #F0F6F9;
  border-color: #C8DCE8;
}
.servicio-card-h--org .servicio-card-h__right {
  background-color: rgba(255,255,255,0.5);
}
.servicio-card-h--org .servicio-card-h__left {
  border-right-color: #C8DCE8;
}

/* Tipo / etiqueta */
.servicio-card-h .servicio-card__tipo {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  color: #4F6F86;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.1rem;
}

/* Título */
.servicio-card-h h3 {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  color: #3E5A6D;
  margin: 0.1rem 0 0.3rem;
  line-height: 1.25;
}

/* Frase */
.servicio-card-h .servicio-card__frase {
  font-size: 0.875rem;
  color: #4F6F86;
  font-style: italic;
  margin: 0 0 0.4rem;
  line-height: 1.4;
}

/* Para quién */
.servicio-card-h .servicio-card__para {
  font-size: 0.83rem;
  color: #3E5A6D;
  line-height: 1.5;
  margin: 0 0 0.4rem;
}

/* Duración */
.servicio-card-h .servicio-card__duracion {
  font-size: 0.78rem;
  color: #7A94A0;
  font-weight: 500;
  margin: 0;
}

/* Lista items */
.servicio-card-h .servicio-card__items {
  list-style: none;
  padding: 0;
  margin: 0 0 0.5rem 0;
}
.servicio-card-h .servicio-card__items li {
  font-size: 0.83rem;
  color: #3E5A6D;
  padding: 0.18rem 0 0.18rem 1rem;
  position: relative;
  line-height: 1.4;
}
.servicio-card-h .servicio-card__items li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: #7A94A0;
  font-weight: 700;
}

/* Responsive */
@media (max-width: 768px) {
  .servicio-card-h {
    grid-template-columns: 1fr;
  }
  .servicio-card-h__left {
    border-right: none;
    border-bottom: 1px solid #C8DCE8;
    padding: 1.25rem;
  }
  .servicio-card-h__right {
    padding: 1.25rem;
  }
  .servicio-card-h__left .btn {
    padding-top: 0.75rem;
  }
}

/* ============================================
   TARJETAS SERVICIOS HOME — 3 columnas
   ============================================ */

.servicios__lista {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  margin-bottom: 2.5rem;
}

/* ---- 4 columnas verticales (home) ---- */
.sv-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  margin-bottom: 2.5rem;
}

.sv-card {
  background: #ffffff;
  border: 2px solid #3E5A6D;
  border-radius: 10px;
  padding: 1.5rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.sv-card--org {
  border-color: #7A94A0;
}

.sv-card__tipo {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: #3E5A6D;
}
.sv-card--org .sv-card__tipo {
  color: #7A94A0;
}

.sv-card__title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  color: var(--color-azul-oscuro);
  margin: 0;
  line-height: 1.2;
}

.sv-card__frase {
  font-size: 0.82rem;
  color: #4F6F86;
  font-style: italic;
  margin: 0;
  line-height: 1.4;
}

.sv-card__list {
  list-style: none;
  padding: 0;
  margin: 0.25rem 0 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  flex: 1;
}
.sv-card__list li {
  font-size: 0.8rem;
  color: #3E5A6D;
  padding-left: 0.9rem;
  position: relative;
  line-height: 1.4;
}
.sv-card__list li::before {
  content: "·";
  position: absolute;
  left: 0;
  font-weight: 700;
  color: #7A94A0;
}

.sv-card__incluye {
  font-size: 0.72rem;
  color: #7A94A0;
  font-weight: 500;
  margin: 0.25rem 0 0;
  border-top: 1px solid #DDE6EC;
  padding-top: 0.5rem;
}

.sv-card__cta {
  display: inline-block;
  margin-top: 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #3E5A6D;
  text-decoration: none;
  border: 1.5px solid #3E5A6D;
  border-radius: 6px;
  padding: 0.4rem 0.9rem;
  text-align: center;
  transition: background 0.15s, color 0.15s;
  align-self: flex-start;
}
.sv-card__cta:hover {
  background: #3E5A6D;
  color: #fff;
}
.sv-card--org .sv-card__cta {
  color: #7A94A0;
  border-color: #7A94A0;
}
.sv-card--org .sv-card__cta:hover {
  background: #7A94A0;
  color: #fff;
}

@media (max-width: 900px) {
  .sv-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .sv-grid {
    grid-template-columns: 1fr;
  }
}

/* Bloque base — 1:1, azul más oscuro */
.sp-home__bloque {
  background-color: #B8CEDB;
  border: 1px solid #9BBCCA;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
  transition: box-shadow 0.2s;
}
.sp-home__bloque:hover {
  box-shadow: 0 3px 12px rgba(62, 90, 109, 0.15);
}

/* Bloque empresas — más claro (mismo tono original) */
.sp-home__bloque--org {
  background-color: #DDE6EC;
  border-color: #C8DCE8;
}

/* Header del bloque */
.sp-home__header {
  padding: 0.875rem 1.5rem 0.875rem;
  border-bottom: 1px solid #C8DCE8;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
}
.sp-home__bloque--badge .sp-home__header {
  padding-top: 1.5rem;
}
.sp-home__header-text {
  flex: 1;
  min-width: 0;
}
.sp-home__header-cta {
  flex-shrink: 0;
  padding-bottom: 0.1rem;
}
.sp-home__header h3 {
  font-family: var(--font-heading);
  font-size: 1rem;
  color: #3E5A6D;
  margin-top: 0.15rem;
  margin-bottom: 0.55rem;
  line-height: 1.2;
}
/* Botón azul oscuro en header */
.sp-home__header-cta .btn--primary {
  background-color: #3E5A6D;
  color: #ffffff;
  border: 2px solid #3E5A6D;
  font-size: 0.82rem;
  padding: 0.45rem 1rem;
  white-space: nowrap;
}
.sp-home__header-cta .btn--primary:hover {
  background-color: #2E4A5C;
  border-color: #2E4A5C;
}
.sp-home__bloque--org .sp-home__header {
  border-bottom-color: #C8DCE8;
}

/* Tipo */
.sp-home__tipo {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  color: #7A94A0;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.2rem;
}

/* Título H3 */
.sp-home__bloque h3 {
  font-family: var(--font-heading);
  font-size: 1rem;
  color: #3E5A6D;
  margin: 0;
  line-height: 1.2;
}

/* Frase */
.sp-home__frase {
  font-size: 0.82rem;
  color: #4F6F86;
  font-style: italic;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0.6rem;
  line-height: 1.4;
}

/* Body — 2 columnas */
.sp-home__body {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 0;
}

/* Columna */
.sp-home__col {
  padding: 0.875rem 1.25rem;
  border-right: 1px solid #C8DCE8;
  font-size: 0.83rem;
  color: #3E5A6D;
  line-height: 1.5;
}
.sp-home__col:last-child {
  border-right: none;
}
.sp-home__col p {
  margin: 0;
  font-size: 0.83rem;
  line-height: 1.5;
  color: #3E5A6D;
}

/* Columna que ocupa 2 espacios (empresas) */
.sp-home__col--span2 {
  grid-column: span 2;
  border-right: none;
}

/* Label de columna */
.sp-home__label {
  font-size: 0.72rem;
  font-weight: 600;
  color: #4F6F86;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.4rem;
  margin-top: 0;
}
.sp-home__label--mt {
  margin-top: 0.75rem;
}

/* Lista */
.sp-home__list {
  list-style: none;
  padding: 0;
  margin: 0 0 0.4rem 0;
}
.sp-home__list li {
  font-size: 0.82rem;
  color: #3E5A6D;
  padding: 0.15rem 0 0.15rem 0.875rem;
  position: relative;
  line-height: 1.4;
}
.sp-home__list li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: #7A94A0;
  font-weight: 700;
}

/* Lista en 2 columnas para empresas */
.sp-home__list--2col {
  columns: 2;
  column-gap: 1rem;
}
.sp-home__list--2col li {
  break-inside: avoid;
}

/* Duración */
.sp-home__duracion {
  font-size: 0.75rem;
  color: #7A94A0;
  font-weight: 500;
  margin-top: 0.4rem;
  margin-bottom: 0;
}

/* Badge */
.sp-home__badge {
  position: absolute;
  top: 0;
  right: 0;
  background-color: #3E5A6D;
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.25rem 0.75rem;
  border-bottom-left-radius: 6px;
  letter-spacing: 0.04em;
}

/* Responsive */
@media (max-width: 768px) {
  .sp-home__header {
    padding: 0.875rem 1.25rem 0.75rem;
  }
  .sp-home__body {
    grid-template-columns: 1fr;
  }
  .sp-home__col {
    border-right: none;
    border-bottom: 1px solid #C8DCE8;
    padding: 0.75rem 1.25rem;
  }
  .sp-home__col:last-child {
    border-bottom: none;
  }
  .sp-home__col--span2 {
    grid-column: span 1;
  }
  .sp-home__list--2col {
    columns: 1;
  }
}

/* Responsive: en móvil el botón baja debajo del texto */
@media (max-width: 600px) {
  .sp-home__header {
    flex-wrap: wrap;
  }
  .sp-home__header-cta {
    width: 100%;
  }
}

/* ============================================
   v14 — AJUSTES ADICIONALES
   ============================================ */

/* sp__bloque--destacado: ahora mismo fondo que las demás tarjetas */
.sp__bloque--destacado h2,
.sp__bloque--destacado .sp__col p,
.sp__bloque--destacado .sp__list li {
  color: #3E5A6D;
}
.sp__bloque--destacado .sp__col-label {
  color: #4F6F86;
  border-bottom-color: #C8DCE8;
}
.sp__bloque--destacado .sp__list li::before {
  color: #4F6F86;
}
.sp__bloque--destacado .sp__duracion,
.sp__bloque--destacado .sp__microcopy {
  color: #7A94A0;
}
.sp__bloque--destacado .sp__bloque-header {
  border-bottom-color: #C8DCE8;
}
.sp__bloque--destacado .sp__bloque-footer {
  border-top-color: #C8DCE8;
}

/* Label home con más separación */
.sp-home__col .sp-home__label {
  font-size: 0.72rem;
  font-weight: 600;
  color: #4F6F86;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 0.6rem;
  margin-top: 0;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid #C8DCE8;
}

/* ============================================
   v15 — SUBTEMAS Y ASÍ CONSIGUES (servicios.html)
   ============================================ */

.sp__subtema {
  margin-top: 1.25rem;
  margin-bottom: 0.2rem;
  font-size: 0.88rem;
}
.sp__subtema:first-of-type {
  margin-top: 0;
}
.sp__asi-consigues {
  font-size: 0.83rem;
  color: #4F6F86;
  background-color: rgba(255,255,255,0.45);
  border-left: 2px solid #7A94A0;
  padding: 0.3rem 0.75rem;
  margin-top: 0.2rem;
  margin-bottom: 0.5rem;
  border-radius: 0 4px 4px 0;
  line-height: 1.5;
}
.sp__microcopy--italic {
  font-style: italic;
  font-size: 0.85rem;
  color: #4F6F86;
  max-width: 420px;
  line-height: 1.5;
}
