/* =============================================================
   RECÓ Estudi — Layout (revisión 2)
============================================================= */

.section { padding-block: var(--sp-16); }
.section--warm { background: var(--paper-warm); }
.section--dark  { background: var(--ink); color: var(--paper); }

@media (max-width: 768px) {
  .section { padding-block: var(--sp-8); }
}

.section__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--rule);
}

.section__title {
  font-size: var(--text-lg);
  font-weight: 200;
  color: var(--ink);
  letter-spacing: -0.01em;
}


@media (max-width: 768px) {
  .section__header {
    margin-bottom: var(--sp-4);
    padding-bottom: var(--sp-2);
  }
}
/* Grid 2 col */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}

.grid-2--asymmetric { grid-template-columns: 4fr 6fr; }

@media (max-width: 768px) {
  .grid-2, .grid-2--asymmetric { grid-template-columns: 1fr; }
}

/* Imagen */
.grid-img img { width: 100%; object-fit: cover; }
.grid-img--portrait img  { aspect-ratio: 3/4; object-position: top; }
.grid-img--landscape img { aspect-ratio: 4/3; }
.grid-img--square img    { aspect-ratio: 1/1; }

/* Eyebrow */
.eyebrow {
  font-size: var(--text-xs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-light);
  display: block;
  margin-bottom: var(--sp-3);
}

/* Prose */
.prose { display: flex; flex-direction: column; gap: var(--sp-3); }
.prose p {
  font-size: var(--text-sm);
  font-weight: 300;
  line-height: 1.85;
  color: var(--ink-mid);
  max-width: 60ch;
}

/* About layout — sin sticky */
.about-layout {
  display: grid;
  grid-template-columns: 45fr 55fr;
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: start;
}

@media (max-width: 768px) {
  .about-layout { grid-template-columns: 1fr; }
  /* Nunca sticky en mobile */
  .about-layout [style*="sticky"] {
    position: static !important;
    top: auto !important;
  }
}

/* Pasos — 2 columnas en desktop */
.steps {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 clamp(2rem, 5vw, 5rem);
}

.step {
  display: grid;
  grid-template-columns: 2.5rem 1fr;
  gap: var(--sp-3);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--rule);
  align-items: start;
}

/* Evitar que la última fila en 2 col muestre doble border */
.step:nth-last-child(-n+2) {
  border-bottom: none;
}

/* Si el total es impar, el último sí lleva borde */
.step:last-child:nth-child(odd) {
  border-bottom: 1px solid var(--rule);
  grid-column: 1 / -1;
}

.step__num {
  font-size: 1.1rem;
  font-weight: 200;
  font-style: italic;
  color: var(--ink-light);
  line-height: 1;
  padding-top: 0.3rem;
}

.step__title {
  font-size: var(--text-base);
  font-weight: 400;
  color: var(--ink);
  margin-bottom: var(--sp-1);
}

.step__text {
  font-size: var(--text-sm);
  font-weight: 300;
  color: var(--ink-mid);
  line-height: 1.8;
}

@media (max-width: 768px) {
  .steps { grid-template-columns: 1fr; }
  .step {
    border-bottom: 1px solid var(--rule);
    padding: var(--sp-3) 0;
  }
  .step:nth-last-child(-n+2) { border-bottom: 1px solid var(--rule); }
  .step:last-child { border-bottom: none; }
}

/* Interludio entre servicios */
.interlude {
  padding: var(--sp-8) 0;
  border-bottom: 1px solid var(--rule);
  text-align: center;
}

.interlude__text {
  font-size: clamp(1rem, 2vw, 1.5rem);
  font-weight: 200;
  font-style: italic;
  color: var(--ink);
  line-height: 1.4;
  max-width: 30ch;
  margin-inline: auto;
}

@media (max-width: 768px) {
  .interlude { padding: var(--sp-4) 0; }
  .interlude__text { font-size: 0.95rem; }
}

/* Proceso en columna única — para listas impares donde 2 col queda desigual */
.steps--single {
  grid-template-columns: 1fr;
}

.steps--single .step {
  border-bottom: 1px solid var(--rule);
}

.steps--single .step:last-child {
  border-bottom: none;
}

/* Anular la regla de nth-last-child que quitaba border en 2col */
.steps--single .step:nth-last-child(-n+2) {
  border-bottom: 1px solid var(--rule);
}
.steps--single .step:last-child {
  border-bottom: none;
  grid-column: auto;  /* anular el 1/-1 del paso impar */
}

