/* ============================================================
   layout.css — Contenedores, grids, secciones y animaciones
   Descentralizados
   ============================================================ */

/* ── Contenedor principal ──────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ── Sección base ──────────────────────────────────────────── */
section {
  position: relative;
  overflow: hidden;
}

/* ── Secciones con bordes redondeados y efecto stacking ──────
   Cada sección (excepto el hero) "emerge" sobre la anterior
   con las esquinas superiores redondeadas.
   ─────────────────────────────────────────────────────────── */
section:not(#hero) {
  border-radius: 2rem 2rem 0 0;
  margin-top: -2rem;
}

/* Z-index para la pila — cada sección queda encima de la anterior */
#hero           { z-index: 1; }
#manifiesto     { z-index: 2; }
#lo-que-hacemos { z-index: 3; }
#testimonios    { z-index: 4; }
#la-promesa     { z-index: 5; }
#nosotros       { z-index: 6; }
#faqs           { z-index: 7; }
.site-footer    { z-index: 8; border-radius: 0; margin-top: -2rem; }

/* Colores de sección */
.section--dark {
  background-color: var(--color-black);
  color: var(--color-white);
}

.section--light {
  background-color: var(--color-gray);
  color: var(--color-black);
}

/* Padding vertical de sección */
.section-inner {
  padding-block: var(--section-pad-v);
}

/* Sección centrada */
.section-inner--center {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-6);
}

/* ── Cabecera de sección ───────────────────────────────────── */
.section-header {
  margin-bottom: var(--space-12);
}

/* ── Grids ─────────────────────────────────────────────────── */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8);
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

/* ── Flex utilitarios ──────────────────────────────────────── */
.flex         { display: flex; }
.flex-center  { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-col     { display: flex; flex-direction: column; }

/* ── Animaciones de entrada (IntersectionObserver) ───────────
   Scale + fade para un efecto de aparición más expresivo.
   ─────────────────────────────────────────────────────────── */
.fade-in {
  opacity: 0;
  transform: translateY(32px) scale(0.97);
  transition:
    opacity  0.8s var(--ease-out),
    transform 0.8s var(--ease-out);
}

.fade-in.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Delays escalonados para elementos hermanos */
.fade-in:nth-child(1) { transition-delay:   0ms; }
.fade-in:nth-child(2) { transition-delay: 100ms; }
.fade-in:nth-child(3) { transition-delay: 200ms; }
.fade-in:nth-child(4) { transition-delay: 300ms; }
.fade-in:nth-child(5) { transition-delay: 400ms; }
.fade-in:nth-child(6) { transition-delay: 500ms; }

/* ── Divisor de acento ─────────────────────────────────────── */
.divider {
  width: 36px;
  height: 2px;
  background-color: var(--color-accent);
  margin-block: var(--space-6);
}

.divider--center { margin-inline: auto; }
