/* ==========================================================================
   Clínica Pradillo — FAQ Accordion
   Estilo visual: Landing Page (tarjetas redondeadas, icono circular, sombras)
   Ruta destino: /wp-content/themes/astra/assets/css/cp-faq-accordion.css

   Especificidad alta para sobreescribir Astra.
   ========================================================================== */

.cp-faq {
  max-width: 760px;
  margin: 56px auto 40px;
  padding: 0;
}

/* ---------- Matar <p> vacíos de wpautop ---------- */
.cp-faq > p:empty,
.cp-faq__item > p:empty,
.cp-faq__answer > p:empty,
.cp-faq__answer-inner > p:empty,
.cp-faq > br,
.cp-faq__item > br {
  display: none !important;
  margin: 0 !important;
  padding: 0 !important;
  height: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
}

/* ---------- Título y subtítulo ----------
   Sin estilos propios: heredan del h2 y p del artículo. */

/* ---------- Título de categoría ---------- */
.cp-faq .cp-faq__category-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: #3c6e71;
  margin: 2rem 0 1.5rem;
  padding-left: 1rem;
  border-left: 4px solid #3c6e71;
  line-height: 1.3;
}

.cp-faq .cp-faq__category-title:first-child {
  margin-top: 0;
}

/* ---------- Item (tarjeta) ---------- */
.cp-faq .cp-faq__item {
  display: block;
  height: auto !important;
  min-height: 0 !important;
  background: white;
  border-radius: 16px;
  margin-bottom: 1rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  border: 2px solid #f7f9f7;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  padding: 0 !important;
}

.cp-faq .cp-faq__item.is-open {
  border-color: #3c6e71;
  box-shadow: 0 10px 25px rgba(60, 110, 113, 0.1);
}

/* ---------- Pregunta (button reset completo) ---------- */
.cp-faq .cp-faq__item .cp-faq__question {
  all: unset;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 1rem 1.5rem;
  gap: 1rem;
  background: white;
  cursor: pointer;
  text-align: left;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.4;
  color: #3c6e71;
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  transition: background-color 0.3s ease;
}

.cp-faq .cp-faq__item .cp-faq__question:hover {
  background: #f7f9f7;
}

.cp-faq .cp-faq__item.is-open .cp-faq__question {
  background: #f7f9f7;
}

.cp-faq .cp-faq__item .cp-faq__question:focus-visible {
  outline: 2px solid #3c6e71;
  outline-offset: -2px;
}

/* ---------- Texto de la pregunta ---------- */
.cp-faq .cp-faq__question span:first-child {
  flex-grow: 1;
  margin: 0;
  padding: 0;
}

/* ---------- Icono circular +/× ---------- */
.cp-faq .cp-faq__icon {
  flex-shrink: 0;
  display: block;
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  background: linear-gradient(135deg, #3c6e71, #2d5457);
  border-radius: 50%;
  position: relative;
  transition: transform 0.3s ease;
  padding: 0;
  margin: 0;
}

.cp-faq .cp-faq__icon::before,
.cp-faq .cp-faq__icon::after {
  content: '';
  position: absolute;
  background-color: #ffffff;
  border-radius: 1.5px;
}

.cp-faq .cp-faq__icon::before {
  top: 50%;
  left: 25%;
  right: 25%;
  height: 2px;
  transform: translateY(-50%);
}

.cp-faq .cp-faq__icon::after {
  left: 50%;
  top: 25%;
  bottom: 25%;
  width: 2px;
  transform: translateX(-50%);
}

.cp-faq .cp-faq__item.is-open .cp-faq__icon {
  transform: rotate(45deg);
}

/* ---------- Respuesta ---------- */
.cp-faq .cp-faq__answer {
  display: block;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}

.cp-faq .cp-faq__answer-inner {
  display: block;
  overflow: hidden;
  padding: 0;
  margin: 0;
}

.cp-faq .cp-faq__answer-body {
  display: block;
  padding: 0.25rem 1.5rem 1.25rem;
  margin: 0;
  font-family: 'Open Sans', sans-serif;
  font-size: 15px;
  line-height: 1.8;
  color: #404040;
}

.cp-faq .cp-faq__answer-body p {
  margin: 0 !important;
  padding: 0 !important;
}

.cp-faq .cp-faq__answer-body a {
  color: #3c6e71;
  text-decoration: none;
  border-bottom: 1px solid rgba(60, 110, 113, 0.3);
  transition: border-color 0.2s ease;
}

.cp-faq .cp-faq__answer-body a:hover {
  border-bottom-color: #3c6e71;
}

/* ---------- Responsive ---------- */
@media (max-width: 600px) {
  .cp-faq {
    margin: 40px 0 28px;
  }

  .cp-faq .cp-faq__heading {
    font-size: 19px;
    margin-bottom: 24px;
  }

  .cp-faq .cp-faq__category-title {
    font-size: 1.2rem;
    margin: 1.5rem 0 1rem;
  }

  .cp-faq .cp-faq__item {
    border-radius: 12px;
    margin-bottom: 0.75rem;
  }

  .cp-faq .cp-faq__item .cp-faq__question {
    font-size: 0.95rem;
    padding: 0.85rem 1.1rem;
    gap: 0.75rem;
  }

  .cp-faq .cp-faq__icon {
    width: 32px;
    height: 32px;
    min-width: 32px;
    min-height: 32px;
  }

  .cp-faq .cp-faq__answer-body {
    font-size: 14px;
    padding: 0.2rem 1.1rem 1rem;
  }
}