/* =====================================================
   ALTIMEA.COM — SERVICE PAGE STYLESHEET
   Patrón reusable para las 6 páginas de servicio:
     - /desarrollo-a-medida (piloto, accent = mint)
     - /ia-automatizacion      (pendiente)
     - /modernizacion-cloud    (pendiente)
     - /equipos-dedicados      (pendiente)
     - /auditoria-tech         (pendiente)
     - /consultoria-ux-cx      (pendiente)

   Para cambiar accent por página: override en :root dentro del HTML:
     :root { --service-accent: var(--blue);
             --service-accent-strong: var(--blue-a11y);
             --service-accent-soft: var(--blue-soft); }

   Tokens globales (navy, mint, blue, shadows, radii, container…) vienen
   de /assets/css/main.css — no se duplican aquí.

   Fuente: Desarrollo-a-Medida-Mockup.html + Design-System-Altimea-V2.html
   ===================================================== */


/* =====================================================
   SCOPE: .service-page wrapper en <main>
   Evita colisiones con Astra/Elementor y otras landings (lr, rb, cto, blog).
   ===================================================== */
.service-page {
  /* Padding base por sección, override por id específico */
}

.service-page h1,
.service-page h2,
.service-page h3,
.service-page h4 {
  font-family: 'Montserrat', sans-serif;
  color: var(--navy);
  line-height: 1.15;
}
.service-page h1 {
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 800;
  letter-spacing: -1.2px;
  line-height: 1.02;
}
.service-page h2 {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 800;
  margin-bottom: 16px;
  letter-spacing: -0.6px;
}
.service-page h3 { font-size: 22px; font-weight: 700; margin-bottom: 12px; }
.service-page h4 { font-size: 18px; font-weight: 700; }
.service-page p  { font-size: 16px; line-height: 1.8; color: var(--gray-700); }

/* La clase .service-page vive en <main> (no en <body>). El selector se
   compone como `main.service-page` — `.service-page main` no matchearía.
   La .megamenu del header queda excluida porque vive en <header.site-header>,
   no en <main>. */
main.service-page section { padding: 112px 40px; }
.service-page .sp-container { max-width: var(--container); margin: 0 auto; }
.service-page .section-head { max-width: 780px; margin-bottom: 64px; }
.service-page .section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.service-page .section-head p.lead { font-size: 18px; color: var(--gray-700); margin-top: 16px; }

.service-page .bg-white { background: var(--white); }
.service-page .bg-gray  { background: var(--gray-50); }


/* =====================================================
   EYEBROW EDITORIAL (reemplaza el pill tradicional)
   ===================================================== */
.service-page .eyebrow-editorial {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: 28px;
}
.service-page .eyebrow-editorial::before {
  content: '';
  width: 36px;
  height: 2px;
  background: var(--service-accent);
}
.service-page .eyebrow-editorial.on-dark { color: var(--white); }
.service-page .eyebrow-editorial.on-dark::before { background: var(--service-accent); }
.service-page .eyebrow-editorial .eyebrow-path { color: var(--gray-500); font-weight: 500; }
.service-page .eyebrow-editorial.on-dark .eyebrow-path { color: var(--text-on-dark-3); }


/* =====================================================
   BUTTONS (service page override — btn base viene de main.css)
   Variant secondary sobre fondos dark
   ===================================================== */
.service-page .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 32px;
  border-radius: var(--radius-pill);
  font-family: 'Montserrat', sans-serif;
  font-size: 16px; font-weight: 700;
  transition: all 0.3s ease;
  white-space: nowrap;
  text-decoration: none;
}
.service-page .btn-primary { background: var(--blue); color: var(--white); }
.service-page .btn-primary:hover {
  background: var(--blue-hover);
  box-shadow: 0 8px 24px rgba(0, 103, 255, 0.3);
  transform: translateY(-2px);
}
.service-page .btn-secondary {
  background: transparent;
  color: var(--white);
  border: 2px solid rgba(255, 255, 255, 0.4);
}
.service-page .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--white);
}
.service-page .btn-ghost {
  background: transparent;
  color: var(--navy);
  border: 2px solid var(--gray-200);
}
.service-page .btn-ghost:hover { border-color: var(--navy); }
.service-page .btn-lg { padding: 16px 40px; font-size: 18px; }

.service-page .icon {
  stroke-width: 1.5;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: currentColor;
}


/* =====================================================
   STICKY TOC (desktop ≥1440px only)
   Frosted card legible sobre cualquier fondo
   ===================================================== */
.toc-sticky {
  position: fixed;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 40;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
  display: none;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(14, 43, 103, 0.08);
  border-radius: var(--radius-md);
  box-shadow: 0 12px 32px rgba(14, 43, 103, 0.1), 0 2px 8px rgba(14, 43, 103, 0.06);
  padding: 14px 12px;
  min-width: 140px;
}
@media (min-width: 1440px) { .toc-sticky { display: block; } }
.toc-sticky.visible { opacity: 1; pointer-events: auto; }
.toc-sticky::before {
  content: 'En esta página';
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 800;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--gray-500);
  margin-bottom: 12px;
  padding-left: 2px;
}
.toc-sticky ul { display: flex; flex-direction: column; gap: 10px; }
.toc-sticky a {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 600; letter-spacing: 0.3px;
  color: var(--gray-600);
  padding: 3px 0;
  transition: color 0.2s ease;
}
.toc-sticky a::before {
  content: '';
  display: block;
  width: 16px; height: 2px;
  background: var(--gray-300);
  border-radius: 1px;
  transition: all 0.25s ease;
  flex-shrink: 0;
}
.toc-sticky a:hover { color: var(--navy); }
.toc-sticky a:hover::before { width: 24px; background: var(--gray-500); }
.toc-sticky a.active { color: var(--navy); font-weight: 700; }
.toc-sticky a.active::before {
  width: 32px;
  background: var(--service-accent-strong);
  height: 3px;
  box-shadow: 0 0 0 1px rgba(var(--service-accent-strong-rgb), 0.2);
}


/* =====================================================
   HERO — Editorial asymmetric (5fr / 7fr grid)
   ===================================================== */
.service-page #hero {
  /* Gradient suave para fundir con el header sticky (var(--navy) plano):
     se mantiene en navy durante ~12% para dar zona de fusión, luego
     transiciona a navy-deep. Evita el "corte" visual bajo el nav. */
  background: linear-gradient(180deg,
    var(--navy) 0%,
    var(--navy) 12%,
    var(--navy-deep) 70%);
  padding: 160px 40px 120px;
  position: relative;
  overflow: hidden;
  min-height: 92vh;
  display: flex;
  align-items: center;
}
.service-page #hero::after {
  content: '';
  position: absolute;
  inset: 0;
  /* Radial overlays bajados para no pintar cerca del borde superior
     (evita crear un contraste que parezca un "corte" bajo el header). */
  background-image:
    radial-gradient(circle at 18% 55%, rgba(var(--service-accent-rgb), 0.06) 0%, transparent 45%),
    radial-gradient(circle at 85% 70%, rgba(0, 103, 255, 0.08) 0%, transparent 40%);
  pointer-events: none;
}
.service-page .hero-grid {
  max-width: var(--container-wide);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 72px;
  align-items: center;
  position: relative;
  z-index: 2;
  width: 100%;
}
.service-page .hero-text { color: var(--white); }
.service-page .hero-text h1 { color: var(--white); margin-bottom: 28px; }
.service-page .hero-text h1 .accent-word { color: var(--service-accent); }

.service-page .hero-subtitle {
  color: var(--text-on-dark-2);
  font-size: clamp(17px, 1.5vw, 20px);
  line-height: 1.65;
  margin-bottom: 40px;
  max-width: 520px;
}
.service-page .hero-meta {
  display: flex;
  gap: 32px;
  margin-bottom: 36px;
  flex-wrap: wrap;
}
.service-page .hero-meta-item {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--white);
  display: flex; align-items: center; gap: 10px;
}
.service-page .hero-meta-item .icon {
  width: 16px; height: 16px;
  color: var(--service-accent);
}
.service-page .hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; }


/* ---- Hero orbital graphic ---- */
.service-page .hero-graphic {
  position: relative;
  width: 100%;
  max-width: 560px;
  aspect-ratio: 1 / 1;
  margin: 0 auto;
}
.service-page .hero-graphic::before {
  content: '';
  position: absolute;
  inset: -5%;
  background: radial-gradient(circle at center, rgba(var(--service-accent-rgb), 0.28) 0%, rgba(var(--service-accent-rgb), 0) 60%);
  border-radius: 50%;
  pointer-events: none;
  animation: sp-halo-pulse 5s ease-in-out infinite;
}
@keyframes sp-halo-pulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.04); }
}
.service-page .hero-graphic-inner {
  position: absolute; inset: 0;
  animation: sp-floatY 6s ease-in-out infinite;
}
@keyframes sp-floatY {
  0%, 100% { transform: translateY(-6px); }
  50%      { transform: translateY(6px); }
}
.service-page .hero-icon-central {
  position: absolute;
  top: 50%; left: 50%;
  width: 160px; height: 160px;
  transform: translate(-50%, -50%);
  color: var(--service-accent);
  filter: drop-shadow(0 4px 24px rgba(var(--service-accent-rgb), 0.35));
  z-index: 3;
}
.service-page .orbital-module {
  position: absolute;
  width: 112px; height: 60px;
  border-radius: 12px;
  background: rgba(14, 43, 103, 0.6);
  border: 1.5px solid var(--service-accent);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(var(--service-accent-rgb), 0.2);
  display: flex; flex-direction: column; justify-content: center;
  gap: 6px;
  padding: 12px 14px;
  backdrop-filter: blur(4px);
  z-index: 2;
}
.service-page .orbital-module::before,
.service-page .orbital-module::after,
.service-page .orbital-module .mod-line {
  content: '';
  display: block;
  height: 3px;
  border-radius: 2px;
  background: var(--service-accent);
  opacity: 0.85;
}
.service-page .orbital-module::before { width: 65%; }
.service-page .orbital-module .mod-line { width: 82%; opacity: 0.55; }
.service-page .orbital-module::after { width: 42%; opacity: 0.35; }
.service-page .orbital-module.mod-top { top: 4%; left: 50%; transform: translateX(-50%); }
.service-page .orbital-module.mod-right {
  bottom: 14%; right: 0;
  border-color: var(--blue);
  background: rgba(0, 92, 230, 0.32);
}
.service-page .orbital-module.mod-right::before,
.service-page .orbital-module.mod-right::after,
.service-page .orbital-module.mod-right .mod-line { background: var(--white); }
.service-page .orbital-module.mod-left {
  bottom: 14%; left: 0;
  border-color: var(--white);
  background: rgba(255, 255, 255, 0.06);
}
.service-page .orbital-module.mod-left::before,
.service-page .orbital-module.mod-left::after,
.service-page .orbital-module.mod-left .mod-line {
  background: var(--white);
  opacity: 0.7;
}
.service-page .orbital-svg-lines {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 0;
}
.service-page .orbital-svg-lines line {
  stroke: var(--service-accent);
  stroke-width: 1;
  stroke-opacity: 0.4;
  stroke-dasharray: 4 4;
}


/* =====================================================
   WHY — asymmetric 2 col + stats + history
   ===================================================== */
.service-page #why .why-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 64px;
  align-items: start;
}
.service-page #why .why-title h2 { margin-bottom: 0; }
.service-page #why .why-body p + p { margin-top: 18px; }

/* Cita de mercado — bloque destacado entre why-grid y stats-row.
   Reusable: DAM (DORA), IA (McKinsey), Nosotros (Bain), futuros servicios. */
.service-page .why-callout,
.nosotros .why-callout {
  max-width: 780px;
  margin: 48px 0 0;
  padding: 24px 28px;
  background: var(--service-accent-soft);
  border-left: 4px solid var(--service-accent-strong);
  border-radius: 4px;
}
.nosotros .why-callout { margin: 48px auto 0; }
.service-page .why-callout p,
.nosotros .why-callout p {
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: var(--gray-700);
}
.service-page .why-callout p strong,
.nosotros .why-callout p strong { color: var(--navy); }
.service-page .why-callout cite,
.nosotros .why-callout cite {
  display: block;
  margin-top: 8px;
  font-size: 13px;
  font-style: italic;
  color: var(--gray-600);
}

.service-page #why .stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 64px;
  padding-top: 48px;
  border-top: 1px solid var(--gray-200);
}
.service-page .stat .stat-num {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(40px, 5.5vw, 60px);
  font-weight: 800;
  color: var(--blue-a11y);
  line-height: 1;
  margin-bottom: 10px;
  letter-spacing: -1px;
}
.service-page .stat .stat-label {
  font-size: 14px;
  color: var(--gray-600);
  font-weight: 600;
}


/* ---- History timeline (5 steps) ---- */
.service-page .history-timeline {
  margin-top: 48px;
  padding: 36px 40px 32px;
  background: var(--gray-50);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--service-accent);
}
.service-page .history-timeline .ht-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 800;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--gray-500);
  margin-bottom: 22px;
}
.service-page .history-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  position: relative;
}
.service-page .history-steps::before {
  content: '';
  position: absolute;
  top: 8px;
  left: 6%; right: 6%;
  height: 2px;
  background: linear-gradient(90deg, var(--service-accent) 0%, var(--blue) 60%, var(--navy) 100%);
  opacity: 0.35;
  z-index: 0;
}
.service-page .history-step { position: relative; z-index: 1; }
.service-page .history-step .hs-dot {
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--white);
  border: 3px solid var(--service-accent);
  margin-bottom: 12px;
}
.service-page .history-step:nth-child(2) .hs-dot { border-color: var(--blue); }
.service-page .history-step:nth-child(3) .hs-dot { border-color: var(--blue-a11y); }
.service-page .history-step:nth-child(4) .hs-dot { border-color: var(--navy); }
.service-page .history-step:nth-child(5) .hs-dot {
  border-color: var(--navy-dark);
  background: var(--navy-dark);
}
.service-page .history-step .hs-year {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800; font-size: 16px;
  color: var(--navy);
  letter-spacing: -0.2px;
}
.service-page .history-step .hs-place {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--blue-a11y);
  margin-top: 2px;
}
.service-page .history-step .hs-caption {
  font-size: 13px;
  color: var(--gray-700);
  margin-top: 6px;
  line-height: 1.4;
}


/* =====================================================
   PULLQUOTE — full-bleed editorial break (gradient permitido en hero-ish)
   ===================================================== */
.service-page #pullquote {
  background: var(--navy-deep);
  padding: 140px 40px;
  position: relative;
  overflow: hidden;
  color: var(--white);
}
.service-page #pullquote::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 520px; height: 520px;
  background: radial-gradient(circle at center, rgba(var(--service-accent-rgb), 0.08) 0%, transparent 70%);
  pointer-events: none;
}
.service-page #pullquote .quote-mark {
  position: absolute;
  top: 48px;
  left: 50%;
  transform: translateX(-50%);
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 220px;
  line-height: 1;
  color: var(--service-accent);
  opacity: 0.18;
  font-weight: 700;
  user-select: none;
  pointer-events: none;
}
.service-page #pullquote .quote-inner {
  max-width: 960px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 2;
}
.service-page #pullquote blockquote {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(28px, 3.8vw, 48px);
  line-height: 1.25;
  font-weight: 700;
  color: var(--white);
  letter-spacing: -0.6px;
  margin-top: 56px;
  margin-bottom: 28px;
}
.service-page #pullquote blockquote .highlight { color: var(--service-accent); }
.service-page #pullquote cite {
  font-family: 'Montserrat', sans-serif;
  font-style: normal;
  font-size: 13px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--service-accent);
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.service-page #pullquote cite::before {
  content: '';
  width: 36px; height: 2px;
  background: var(--service-accent);
}


/* =====================================================
   BENEFITS — 4 cards grid
   ===================================================== */
.service-page #benefits .benefit-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.service-page .benefit-card {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
  border-top: 3px solid var(--service-accent);
}
.service-page .benefit-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.service-page .benefit-card .icon-wrap {
  width: 52px; height: 52px;
  background: var(--service-accent-soft);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  color: var(--blue-a11y);
  margin-bottom: 20px;
}
.service-page .benefit-card h3 { font-size: 20px; }
.service-page .benefit-card p { font-size: 15px; line-height: 1.7; }


/* =====================================================
   HOW — 3 tracks continuous + Day 1/30/90 milestones
   ===================================================== */
.service-page #how { background: var(--white); }
.service-page #how .how-lead { max-width: 880px; margin-bottom: 72px; }
.service-page #how .how-lead h2 {
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.15;
  letter-spacing: -1px;
  margin-bottom: 20px;
}
.service-page #how .how-lead h2 .highlight { color: var(--service-accent-strong); } /* editorial accept Gate 5 — identity over WCAG AA */
.service-page #how .how-lead p.lead {
  font-size: 18px;
  color: var(--gray-700);
  max-width: 680px;
}

.service-page .tracks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 72px;
  position: relative;
}
.service-page .tracks::before {
  content: '';
  position: absolute;
  top: 92px;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--gray-200) 15%, var(--gray-200) 85%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}
.service-page .track {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  position: relative;
  z-index: 1;
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}
.service-page .track:hover {
  border-color: var(--service-accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.service-page .track-number {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px; font-weight: 800;
  letter-spacing: 2px;
  color: var(--service-accent-strong); /* editorial accept Gate 5 — identity over WCAG AA */
  margin-bottom: 14px;
}
.service-page .track-head h3 { font-size: 22px; margin-bottom: 12px; color: var(--navy); }
.service-page .track-head > p {
  font-size: 15px;
  color: var(--gray-700);
  line-height: 1.65;
  margin-bottom: 20px;
  min-height: 64px;
}
.service-page .track-artifacts {
  margin: 0;
  padding: 0;
  border-top: none;
}
.service-page .artifacts-label {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 800;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--gray-500);
  margin-bottom: 14px;
  padding-top: 20px;
  border-top: 1px solid var(--gray-200);
}
.service-page .track-artifacts li {
  font-size: 14px;
  line-height: 1.55;
  color: var(--navy);
  font-weight: 600;
  padding: 8px 0 8px 24px;
  position: relative;
}
.service-page .track-artifacts li::before {
  content: '';
  position: absolute;
  left: 0;
  /* Alineación vertical con el CENTRO de la primera línea del texto
     (padding-top 8px + line-height 21.7/2 ≈ 18.8px, menos mitad del dash). */
  top: 18px;
  width: 14px; height: 2px;
  background: var(--service-accent);
  border-radius: 1px;
}


/* ---- Milestones ---- */
.service-page .milestones {
  background: var(--gray-50);
  border-radius: var(--radius-lg);
  padding: 48px;
}
.service-page .milestones-head {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 36px;
}
.service-page .milestones-head h3 { font-size: 20px; margin-bottom: 0; color: var(--navy); }
.service-page .milestones-head .sub {
  font-size: 14px;
  color: var(--gray-600);
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
}
.service-page .milestones-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  position: relative;
}
.service-page .milestones-grid::before {
  content: '';
  position: absolute;
  top: 16px;
  left: 10%; right: 10%;
  height: 2px;
  background: linear-gradient(90deg, var(--service-accent) 0%, var(--blue) 100%);
  opacity: 0.4;
  z-index: 0;
}
.service-page .milestone { position: relative; z-index: 1; }
.service-page .milestone-dot {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--white);
  border: 3px solid var(--service-accent);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 800;
  color: var(--navy);
  margin-bottom: 16px;
}
.service-page .milestone:nth-child(2) .milestone-dot { border-color: var(--blue); }
.service-page .milestone:nth-child(3) .milestone-dot {
  border-color: var(--navy);
  background: var(--navy);
  color: var(--service-accent);
}
.service-page .milestone .milestone-when {
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 800;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--service-accent-strong); /* editorial accept Gate 5 — identity over WCAG AA (nth-child 2+3 usan blue-a11y/navy que sí pasan) */
  margin-bottom: 8px;
}
.service-page .milestone:nth-child(2) .milestone-when { color: var(--blue-a11y); }
.service-page .milestone:nth-child(3) .milestone-when { color: var(--navy); }
.service-page .milestone h4 { font-size: 17px; margin-bottom: 8px; color: var(--navy); }
.service-page .milestone p { font-size: 14px; line-height: 1.6; color: var(--gray-700); }


/* =====================================================
   CENTERS OF EXCELLENCE (CoE) — dark band 3 pillars
   ===================================================== */
.service-page #coe {
  background: var(--navy-deep);
  color: var(--white);
  padding: 110px 40px;
}
.service-page #coe .sp-container { max-width: 1200px; }
.service-page #coe .coe-head {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 48px;
  margin-bottom: 56px;
  align-items: end;
}
.service-page #coe h2 {
  color: var(--white);
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.15;
  letter-spacing: -0.4px;
}
/* Mint sobre navy-deep: contraste ≥10:1 (AAA). */
.service-page #coe h2 .highlight { color: var(--service-accent); }
/* Mint-strong sobre blanco: decisión editorial de identidad (Eric validó). editorial accept Gate 5 — identity over WCAG AA */
.service-page #case .section-head h2 .highlight { color: var(--service-accent-strong); }
.service-page #coe .coe-intro {
  color: var(--text-on-dark-2);
  font-size: 17px;
  line-height: 1.65;
  max-width: 520px;
}
.service-page #coe .coe-intro strong { color: var(--white); }

.service-page .coe-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.service-page .coe-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(var(--service-accent-rgb), 0.15);
  border-radius: var(--radius-md);
  padding: 40px 32px 36px;
  position: relative;
  transition: border-color 0.25s ease, transform 0.25s ease;
  /* Flex column + margin-top:auto en .coe-proof alinea las líneas y el
     texto de proof al fondo, independientemente de cuánto texto tenga
     la descripción de cada CoE (cards ya son igual alto por grid). */
  display: flex;
  flex-direction: column;
}
.service-page .coe-card:hover {
  border-color: var(--service-accent);
  transform: translateY(-3px);
}
.service-page .coe-card .coe-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 800;
  letter-spacing: 2px;
  color: var(--service-accent);
  margin-bottom: 20px;
}
.service-page .coe-card .coe-icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  background: rgba(var(--service-accent-rgb), 0.1);
  display: flex; align-items: center; justify-content: center;
  color: var(--service-accent);
  margin-bottom: 22px;
}
.service-page .coe-card .coe-icon svg { width: 26px; height: 26px; }
.service-page .coe-card h3 {
  color: var(--white);
  font-size: 22px;
  margin-bottom: 12px;
  letter-spacing: -0.2px;
}
.service-page .coe-card p {
  color: var(--text-on-dark-2);
  font-size: 15px;
  line-height: 1.65;
  margin-bottom: 20px;
}
.service-page .coe-card .coe-proof {
  font-family: 'Montserrat', sans-serif;
  font-size: 12px; font-weight: 700;
  color: var(--service-accent);
  padding-top: 18px;
  border-top: 1px solid rgba(var(--service-accent-rgb), 0.18);
  letter-spacing: 0.3px;
  margin-top: auto;                                /* alinea al fondo de la card */
}


/* =====================================================
   STACK — 4 clusters 2x2
   ===================================================== */
.service-page #stack .stack-clusters {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 40px;
}
.service-page .cluster {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px 30px;
  box-shadow: var(--shadow-sm);
  border-top: 3px solid var(--service-accent);
  display: flex;
  flex-direction: column;
}
.service-page .cluster-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.service-page .cluster-icon {
  width: 22px; height: 22px;
  color: var(--blue-a11y);
  flex-shrink: 0;
}
.service-page .cluster h3 {
  font-size: 14px; font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--blue-a11y);
  margin: 0;
}
.service-page .cluster-proof {
  font-size: 14px;
  color: var(--gray-700);
  line-height: 1.5;
  margin-bottom: 18px;
}
.service-page .tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}
.service-page .tech-tag {
  display: inline-block;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px; font-weight: 700;
  color: var(--navy);
  background: var(--gray-100);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
}
.service-page #stack .stack-note {
  font-size: 15px;
  color: var(--gray-700);
  max-width: 760px;
}


/* =====================================================
   CASE STUDY — 2-col hero de caso
   ===================================================== */
.service-page #case .case-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 48px;
  box-shadow: var(--shadow-md);
  border-left: 4px solid var(--service-accent);
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 48px;
  align-items: start;
}
.service-page .case-client-logo {
  height: 36px;
  margin-bottom: 20px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 22px;
  color: var(--navy);
  letter-spacing: -0.3px;
}
.service-page .case-block { margin-bottom: 20px; }
.service-page .case-block h4 {
  font-size: 13px; text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--blue-a11y);
  margin-bottom: 6px;
}
.service-page .case-block p { font-size: 15px; }
.service-page .case-metrics {
  background: var(--gray-50);
  border-radius: var(--radius-md);
  padding: 28px;
}
.service-page .case-metrics h4 {
  font-size: 13px; text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--blue-a11y);
  margin-bottom: 20px;
}
.service-page .metric {
  display: flex;
  gap: 14px;
  margin-bottom: 16px;
  align-items: flex-start;
}
.service-page .metric:last-child { margin-bottom: 0; }
.service-page .metric .ck-badge {
  width: 26px; height: 26px;
  background: var(--mint-soft);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 0;
}
.service-page .metric .ck-badge svg {
  width: 14px; height: 14px;
  color: var(--service-accent-strong);
  stroke: var(--service-accent-strong);
  stroke-width: 3;
  fill: none;
  stroke-linecap: round; stroke-linejoin: round;
}
.service-page .metric span {
  font-size: 14px;
  color: var(--navy);
  font-weight: 600;
  line-height: 1.5;
}


/* =====================================================
   TESTIMONIALS — 3 card grid con badge absolute top-right
   ===================================================== */
.service-page .testimonial-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.service-page .testimonial-card {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 36px 32px 30px;
  box-shadow: var(--shadow-sm);
  position: relative;
  display: flex;
  flex-direction: column;
}
.service-page .testimonial-card::before {
  content: '\201C';
  position: absolute;
  top: 12px; left: 26px;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 84px;
  line-height: 1;
  color: var(--service-accent);
  opacity: 0.28;
  font-weight: 700;
}
.service-page .testimonial-card blockquote {
  position: relative;
  font-size: 16px;
  line-height: 1.65;
  color: var(--navy);
  font-weight: 500;
  margin-top: 36px;
  margin-bottom: 24px;
  flex-grow: 1;
}
.service-page .testimonial-card .t-author {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 20px;
  border-top: 1px solid var(--gray-200);
}
.service-page .testimonial-card .t-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--service-accent-soft);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 15px;
  color: var(--navy);
  flex-shrink: 0;
}
.service-page .testimonial-card .t-meta .t-name {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 14px;
  color: var(--navy);
  line-height: 1.2;
}
.service-page .testimonial-card .t-meta .t-title {
  font-size: 12px;
  color: var(--gray-600);
  margin-top: 3px;
  line-height: 1.3;
}
.service-page .testimonial-card .t-badge {
  position: absolute;
  top: 22px;
  right: 24px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px; font-weight: 800;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--blue-a11y);
  background: var(--blue-soft);
  padding: 4px 10px;
  border-radius: 4px;
  z-index: 2;
}


/* =====================================================
   TRUST — logo strip + mini-cases
   ===================================================== */
.service-page #trust .trust-h3 {
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 32px;
  color: var(--gray-700);
}
.service-page .logo-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  align-items: center;
  margin-bottom: 48px;
}
.service-page .logo-cell {
  display: flex; align-items: center; justify-content: center;
  padding: 14px 18px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700; font-size: 13px;
  color: var(--gray-500);
  letter-spacing: 0.4px;
  background: var(--white);
  border-radius: var(--radius-sm);
  border: 1px solid var(--gray-200);
  aspect-ratio: 2 / 1;
  transition: border-color 0.2s ease, transform 0.2s ease;
}
.service-page .logo-cell:hover {
  border-color: var(--gray-300);
  transform: translateY(-1px);
}
.service-page .logo-cell img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}
.service-page .logo-cell.logo-placeholder {
  background: var(--gray-50);
  color: var(--gray-500);             /* Contraste ≥4.5:1 sobre gray-50 (antes gray-400 fallaba) */
  border-style: dashed;
  font-style: italic;
  font-weight: 600;
  font-size: 12px;
}
.service-page .mini-cases {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.service-page .mini-case {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 24px;
  border-top: 2px solid var(--service-accent);
}
.service-page .mini-case h4 {
  font-size: 15px;
  margin-bottom: 8px;
  color: var(--navy);
}
.service-page .mini-case p {
  font-size: 14px;
  color: var(--gray-700);
  line-height: 1.6;
}


/* =====================================================
   FAQ — native <details> con schema FAQPage en HTML
   ===================================================== */
.service-page #faq .faq-wrap { max-width: 860px; margin: 0 auto; }
.nosotros #faq .faq-list { max-width: 860px; margin: 0 auto; }
.service-page .faq-item,
.nosotros .faq-item {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-md);
  margin-bottom: 12px;
  overflow: hidden;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.service-page .faq-item[open],
.nosotros .faq-item[open] {
  box-shadow: var(--shadow-sm);
  border-color: var(--service-accent);
}
.service-page .faq-item summary,
.nosotros .faq-item summary {
  cursor: pointer;
  padding: 20px 24px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
  list-style: none;
}
.service-page .faq-item summary::-webkit-details-marker,
.nosotros .faq-item summary::-webkit-details-marker { display: none; }
.service-page .faq-item summary h3,
.nosotros .faq-item summary h3 {
  font-size: 17px; font-weight: 700;
  margin: 0;
  color: var(--navy);
}
.service-page .faq-item summary .faq-icon,
.nosotros .faq-item summary .faq-icon {
  width: 22px; height: 22px;
  color: var(--blue-a11y);
  transition: transform 0.2s ease;
  flex-shrink: 0;
  stroke-width: 2.2;
  stroke-linecap: round;
  fill: none;
  stroke: currentColor;
}
.service-page .faq-item[open] summary .faq-icon,
.nosotros .faq-item[open] summary .faq-icon { transform: rotate(45deg); }
.service-page .faq-answer,
.nosotros .faq-answer { padding: 0 24px 24px; }
.service-page .faq-answer p,
.nosotros .faq-answer p { font-size: 15px; color: var(--gray-700); }


/* =====================================================
   CROSS-SELL
   ===================================================== */
.service-page #cross-sell .cross-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.service-page .cross-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-md);
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  transition: all 0.25s ease;
}
.service-page .cross-card:hover {
  border-color: var(--service-accent);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.service-page .cross-card .icon-wrap {
  width: 44px; height: 44px;
  background: var(--service-accent-soft);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--blue-a11y);
  flex-shrink: 0;
}
.service-page .cross-card h4 { font-size: 15px; margin-bottom: 2px; }
.service-page .cross-card p { font-size: 13px; color: var(--gray-600); }
.service-page .cross-card .cross-arrow {
  margin-left: auto;
  color: var(--blue-a11y);
  font-weight: 700;
}


/* =====================================================
   CTA FINAL (gradient navy — patrón permitido para hero-like blocks)
   ===================================================== */
.service-page #cta-final {
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 100%);
  color: var(--white);
  text-align: center;
  padding: 100px 40px;
}
.service-page #cta-final .cta-inner { max-width: 760px; margin: 0 auto; }
.service-page #cta-final h2 { color: var(--white); margin-bottom: 20px; }
.service-page #cta-final p.cta-lead {
  color: var(--text-on-dark-2);
  font-size: 18px;
  margin-bottom: 32px;
}
.service-page #cta-final .micro {
  font-size: 13px;
  color: var(--text-on-dark-3);
  margin-top: 20px;
}


/* =====================================================
   RESPONSIVE — 1440 / 1280 / 1024 / 768
   ===================================================== */
@media (max-width: 1024px) {
  .service-page #hero { padding: 130px 40px 90px; min-height: auto; }
  .service-page .hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .service-page .hero-graphic { max-width: 420px; order: 2; }
  .service-page .hero-text { order: 1; }
  .service-page .hero-subtitle { max-width: 100%; }

  .service-page #why .why-grid { grid-template-columns: 1fr; gap: 32px; }

  .service-page #benefits .benefit-grid { grid-template-columns: 1fr 1fr; }

  .service-page .tracks { grid-template-columns: 1fr; gap: 16px; }
  .service-page .tracks::before { display: none; }
  .service-page .track-head > p { min-height: auto; }
  .service-page .milestones { padding: 36px 28px; }

  /* Header en 2 líneas: título arriba, subtítulo debajo (no en columnas
     que aprietan el texto en mobile). */
  .service-page .milestones-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    margin-bottom: 28px;
  }
  .service-page .milestones-head .sub { font-size: 13px; line-height: 1.4; }

  .service-page .milestones-grid { grid-template-columns: 1fr; gap: 32px; }

  /* Línea VERTICAL conectora — pasa por los centros de los dots.
     z-index: -1 y dots con position:relative + z-index:1 para que la línea
     quede DETRÁS y sea enmascarada por el relleno blanco de cada dot. */
  .service-page .milestones-grid::before {
    display: block;
    top: 16px;
    bottom: 16px;
    left: 15px;
    right: auto;
    width: 2px;
    height: auto;
    background: linear-gradient(180deg, var(--service-accent) 0%, var(--blue) 50%, var(--navy) 100%);
    opacity: 0.4;
    z-index: 0;
  }
  /* Dot absoluto + padding-left en el milestone deja el texto a la
     derecha de la línea vertical, sin cruzarse. */
  .service-page .milestone {
    padding-left: 48px;
    min-height: 48px;
  }
  .service-page .milestone-dot {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    margin-bottom: 0;
  }

  .service-page #coe { padding: 80px 40px; }
  .service-page #coe .coe-head { grid-template-columns: 1fr; gap: 24px; }
  .service-page .coe-grid { grid-template-columns: 1fr; gap: 18px; }

  .service-page #stack .stack-clusters { grid-template-columns: 1fr 1fr; }
  .service-page #case .case-card { grid-template-columns: 1fr; gap: 32px; }

  /* Logo de cliente: el height fijo (36px) cortaba la lista de marcas
     "Belcorp · Ésika · L'Bel · Cyzone" cuando wrappeaba a 2 líneas en mobile,
     superponiéndose al texto siguiente. Dejamos el alto auto y bajamos un
     punto la tipografía para que respire. */
  .service-page .case-client-logo {
    height: auto;
    font-size: 18px;
    line-height: 1.3;
    margin-bottom: 24px;
  }

  .service-page .testimonial-grid { grid-template-columns: 1fr; gap: 20px; }

  .service-page .logo-strip { grid-template-columns: repeat(4, 1fr); }
  .service-page .mini-cases { grid-template-columns: 1fr; }

  .service-page #cross-sell .cross-grid { grid-template-columns: 1fr; }

  .service-page #pullquote { padding: 100px 40px; }

  .service-page .history-timeline { padding: 28px 24px; }
  .service-page .history-step .hs-caption { font-size: 12px; }
}

@media (max-width: 768px) {
  main.service-page section { padding: 72px 24px; }
  .service-page #hero { padding: 100px 24px 72px; }
  .service-page .hero-graphic { max-width: 320px; }
  .service-page .hero-meta { gap: 20px; }
  .service-page .hero-ctas { flex-direction: column; align-items: stretch; }
  .service-page .btn { width: 100%; }

  /* Breadcrumb eyebrow: en mobile permitimos wrap limpio entre "Servicios /"
     y el nombre del servicio, reducimos letter-spacing para que el texto
     respire sin romper palabras a la mitad. */
  .service-page .eyebrow-editorial {
    flex-wrap: wrap;
    gap: 8px 12px;
    letter-spacing: 1.5px;
    font-size: 11px;
    margin-bottom: 20px;
  }
  .service-page .eyebrow-editorial::before { width: 24px; }

  .service-page #why .stats-row { grid-template-columns: 1fr; gap: 20px; }

  .service-page #benefits .benefit-grid { grid-template-columns: 1fr; }

  .service-page #pullquote { padding: 80px 24px; }
  .service-page #pullquote .quote-mark { font-size: 140px; top: 20px; }

  /* En mobile la cita queda cramped con la línea mint inline: ponemos la
     línea encima del texto y dejamos respirar el ALTIMEA · Desde Lima. */
  .service-page #pullquote cite {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
    letter-spacing: 1.5px;
    font-size: 12px;
  }
  .service-page #pullquote cite::before { width: 48px; }

  .service-page #coe { padding: 64px 24px; }
  .service-page .coe-card { padding: 32px 24px 28px; }

  .service-page #stack .stack-clusters { grid-template-columns: 1fr; }
  .service-page #case .case-card { padding: 32px 24px; }

  .service-page .logo-strip { grid-template-columns: repeat(2, 1fr); }
  .service-page .milestones { padding: 28px 20px; }

  .service-page .testimonial-card { padding: 32px 24px 26px; }
  .service-page .testimonial-card::before { font-size: 64px; top: 8px; left: 18px; }

  .service-page .history-steps { grid-template-columns: repeat(2, 1fr); gap: 20px; row-gap: 24px; }
  .service-page .history-steps::before { display: none; }
}
