/* ======================================================
   COACHING.CSS
   Estilos personalizados para /acompanamientos/coaching.html
   ====================================================== */

/* ======================================================
   HERO COACHING - versión estable con degradado lateral
   ====================================================== */

.hero-coaching {
  position: relative;
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: stretch;
  overflow: hidden;
  isolation: isolate;
  background: var(--color-fondo, #000);
}

/* Contenedor principal */
.hero-coaching .hero-content {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  width: 100%;
  height: 100%;
}

/* Bloque de texto */
.hero-coaching .hero-text {
  background: linear-gradient(180deg, #000 0%, #111 100%);
  color: #fff;
  padding: clamp(80px, 12vh, 160px) clamp(40px, 6vw, 100px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 2;
}

.hero-coaching .hero-text h1 {
  font-family: var(--fuente-secundaria);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: var(--space-4);
  color: #e8ebff;
}

.hero-coaching .hero-text p {
  font-size: var(--fs-md);
  color: #f0f0f0;
  margin-bottom: var(--space-3);
  max-width: 480px;
}

.hero-coaching .hero-text .secondary {
  font-size: var(--fs-sm);
  opacity: 0.9;
  margin-bottom: var(--space-6);
}

.hero-coaching .hero-text .btn-primario {
  background-color: var(--color-secundario);
  color: #fff;
  padding: var(--space-3) var(--space-8);
  border-radius: var(--radius-md);
  font-weight: 600;
  transition: var(--transicion-base);
  align-self: flex-start;
}

.hero-coaching .hero-text .btn-primario:hover {
  background-color: var(--color-primario);
  transform: translateY(-2px);
}

/* Imagen con degradado lateral */
.hero-coaching .hero-imagen {
  position: relative;
  background: url("../img/coaching/hero.jpg") center center / cover no-repeat;
  overflow: hidden;
}

.hero-coaching .hero-imagen::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 35%;
  background: linear-gradient(
    270deg,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.75) 100%
  );
  z-index: 2;
}

.hero-coaching .hero-imagen::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.2);
  z-index: 1;
}

/* ======================================================
   Responsividad HERO
   ====================================================== */
@media (max-width: 900px) {
  .hero-coaching .hero-content {
    grid-template-columns: 1fr;
  }

  .hero-coaching .hero-text {
    padding: clamp(60px, 15vh, 120px) var(--space-6);
    text-align: center;
    align-items: center;
    background: linear-gradient(180deg, #000 0%, #141414 100%);
  }

  .hero-coaching .hero-text p,
  .hero-coaching .hero-text .secondary {
    max-width: 90%;
  }

  .hero-coaching .hero-text .btn-primario {
    align-self: center;
  }

  .hero-coaching .hero-imagen {
    height: 50vh;
  }

  .hero-coaching .hero-imagen::before {
    display: none;
  }
}

/* ======================================================
   SECCIÓN PROCESO - Íconos SVG con color original
   ====================================================== */

.proceso {
  background-color: #f7f9fc;
  padding: clamp(80px, 10vh, 140px) var(--space-4);
  text-align: center;
}

.proceso h2 {
  color: var(--color-primario, #1b2a64);
  font-family: var(--fuente-secundaria);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 700;
  margin-bottom: var(--space-3);
}

.proceso .intro {
  color: #444;
  font-size: var(--fs-md);
  margin-bottom: var(--space-10);
}

.proceso .pasos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
  justify-content: center;
}

.paso {
  background: #fff;
  border-radius: var(--radius-md);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  padding: var(--space-8) var(--space-6);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.paso:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
}

.paso .icono {
  width: 80px;
  height: 80px;
  margin: 0 auto var(--space-5);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 2px solid var(--color-secundario, #e6b10a);
  border-radius: 50%;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04);
}

.paso .icono img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  filter: none;
}

.paso h3 {
  color: var(--color-primario, #1b2a64);
  font-size: var(--fs-lg);
  font-weight: 700;
  margin-bottom: var(--space-3);
}

.paso p {
  color: #333;
  font-size: var(--fs-md);
  line-height: 1.6;
}

/* Responsivo PROCESO */
@media (max-width: 768px) {
  .proceso {
    padding: var(--space-10) var(--space-5);
  }
  .paso {
    padding: var(--space-6);
  }
  .paso .icono {
    width: 68px;
    height: 68px;
  }
  .paso .icono img {
    width: 38px;
    height: 38px;
  }
}

/* ======================================================
   SECCIÓN: Servicios (Calendly popup)
   ====================================================== */

.servicios {
  background: #fff;
}

.servicios h2 {
  text-align: center;
  margin-bottom: var(--space-10);
}

.grid-servicios {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
  gap: var(--space-8);
}

.card {
  background: #fff;
  border-radius: var(--radius-md);
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.06);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
}

.card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
}

.card h3 {
  color: var(--color-primario);
  font-family: var(--fuente-secundaria);
  font-weight: 600;
  font-size: 1.2rem;
  margin: 0 var(--space-4) var(--space-3);
}

.card p {
  margin: 0 var(--space-4) var(--space-4);
  color: #333;
  font-size: var(--fs-sm);
  line-height: 1.6;
}

.card ul {
  list-style: none;
  padding-left: 0;
  margin: 0 var(--space-4) var(--space-4);
}

.card ul li {
  font-size: var(--fs-sm);
  margin-bottom: var(--space-1);
  color: #444;
}

.card button {
  margin: 0 var(--space-4) var(--space-5);
  background-color: var(--color-primario);
  color: #fff;
  border: none;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-weight: 500;
  transition: var(--transicion-base);
}

.card button:hover {
  background-color: var(--color-secundario);
  transform: translateY(-2px);
}

/* ======================================================
   SECCIÓN: Testimonios
   ====================================================== */
.testimonios {
  background-color: var(--color-gris-claro);
  text-align: center;
}

.testimonios h2 {
  margin-bottom: var(--space-10);
}

.testimonios blockquote {
  font-style: italic;
  font-size: var(--fs-md);
  color: var(--color-texto);
  margin-bottom: var(--space-8);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.testimonios span {
  display: block;
  margin-top: var(--space-2);
  color: var(--color-primario);
  font-weight: 600;
}

/* ======================================================
   SECCIÓN: Beneficios
   ====================================================== */
.beneficios {
  background: #fff;
}

.beneficios h2 {
  text-align: center;
  margin-bottom: var(--space-8);
}

.beneficios ul {
  max-width: 700px;
  margin: 0 auto;
  list-style: none;
  padding-left: 0;
}

.beneficios li {
  position: relative;
  padding-left: 2rem;
  margin-bottom: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-texto);
}

.beneficios li::before {
  content: "✔";
  position: absolute;
  left: 0;
  color: var(--color-secundario);
  font-weight: bold;
}

/* ======================================================
   SECCIÓN: FAQ
   ====================================================== */
.faq {
  background-color: var(--color-fondo);
}

.faq h2 {
  text-align: center;
  margin-bottom: var(--space-8);
}

.faq details {
  background: #fff;
  border-radius: var(--radius-md);
  box-shadow: var(--sombra-suave);
  margin-bottom: var(--space-4);
  padding: var(--space-4) var(--space-6);
  transition: var(--transicion-base);
}

.faq summary {
  font-weight: 600;
  cursor: pointer;
  color: var(--color-primario);
  font-size: var(--fs-sm);
  list-style: none;
  position: relative;
}

.faq summary::after {
  content: "+";
  position: absolute;
  right: 0;
  font-weight: bold;
  transition: transform 0.3s ease;
}

.faq details[open] summary::after {
  content: "–";
}

.faq details p {
  margin-top: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-texto);
  line-height: 1.5;
}

/* ======================================================
   CTA FINAL
   ====================================================== */
.cta-final {
  background: linear-gradient(135deg, var(--color-primario), var(--color-secundario));
  color: #fff;
  text-align: center;
  padding: var(--space-16) var(--space-4);
}

.cta-final h2 {
  color: #fff;
  margin-bottom: var(--space-4);
}

.cta-final p {
  color: #f5f5f5;
  margin-bottom: var(--space-6);
}

.cta-final .btn-primario {
  background-color: #fff;
  color: var(--color-primario);
  border: none;
  padding: var(--space-3) var(--space-8);
  border-radius: var(--radius-md);
  font-weight: 600;
  transition: var(--transicion-base);
}

.cta-final .btn-primario:hover {
  background-color: var(--color-dorado);
  color: #fff;
  transform: translateY(-2px);
}

/* ======================================================
   RESPONSIVO GENERAL
   ====================================================== */
@media (max-width: 768px) {
  .grid-servicios {
    gap: var(--space-6);
  }
  .card {
    padding: var(--space-5);
  }
  .pasos {
    gap: var(--space-6);
  }
}
