/* =============================================================================
   Servicios — Áreas en acordeón
   Split 50/50: imagen redondeada (izquierda) + lista de details/summary (derecha).
   Cada item separado por un borde fino. Indicador con + / − en burgundy.
   ========================================================================== */

.serv-areas {
  padding-block: var(--section-pad-y);
}

.serv-areas__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
  align-items: start;
}

@media (min-width: 768px) {
  .serv-areas__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-9);
  }
}

/* === Imagen lateral === */
.serv-areas__imagen {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  margin: 0;
}

.serv-areas__imagen img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* === Acordeón === */
.serv-areas__accordion {
  display: flex;
  flex-direction: column;
}

.serv-areas__item {
  border-bottom: 1px solid var(--color-border);
}
.serv-areas__item:first-child {
  border-top: 1px solid var(--color-border);
}

.serv-areas__summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  font-size: var(--fs-p-l);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  transition: color var(--t-fast);
}

.serv-areas__summary::-webkit-details-marker { display: none; }
.serv-areas__summary:hover { color: var(--color-burgundy); }

.serv-areas__titulo {
  flex: 1;
}

/* Icono +/− construido con dos líneas. La vertical desaparece al abrir. */
.serv-areas__icon {
  position: relative;
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
  color: var(--color-burgundy);
}
.serv-areas__icon::before,
.serv-areas__icon::after {
  content: '';
  position: absolute;
  background: currentColor;
  border-radius: 1px;
  transition: transform var(--t-base), opacity var(--t-base);
}
.serv-areas__icon::before { /* horizontal */
  top: 50%;
  left: 0;
  right: 0;
  height: 2px;
  transform: translateY(-50%);
}
.serv-areas__icon::after { /* vertical */
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  transform: translateX(-50%);
}
.serv-areas__item[open] .serv-areas__icon::after {
  transform: translateX(-50%) rotate(90deg);
  opacity: 0;
}

/* Contenido del acordeón */
.serv-areas__contenido {
  padding: 0 0 var(--space-5);
  color: var(--color-text-muted);
  font-size: var(--fs-p-m);
  line-height: var(--lh-p-m);
}
.serv-areas__contenido p + p,
.serv-areas__contenido p + ul,
.serv-areas__contenido ul + p {
  margin-top: var(--space-3);
}
.serv-areas__contenido ul {
  margin: 0;
  padding-left: 1.25rem;
  list-style: disc;            /* el reset global pone list-style:none; lo restauramos */
}
.serv-areas__contenido li {
  margin-bottom: var(--space-1);
}
