/* =========================================================
 * layout.css
 * Sistema de contenedores, secciones base y breakpoints
 * mobile-first del sitio WSG.cl.
 * ========================================================= */

/* ---------- Contenedores ---------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.container--narrow {
  max-width: var(--container-narrow);
}

/* ---------- Hero layout (mobile-first) ---------- */
.hero__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

/* ---------- Footer layout ---------- */
.footer__inner {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: 1fr;
  padding-top: var(--space-8);
  padding-bottom: var(--space-7);
}
@media (min-width: 700px) {
  .footer__inner {
    grid-template-columns: 1.4fr repeat(3, 1fr);
  }
}

/* ---------- Ajuste fino en pantallas grandes (laptops) ---------- */
@media (max-width: 1100px) {
  .container {
    padding: 0 var(--space-5);
  }
}

/* ---------- Tablet / mobile mid ---------- */
@media (max-width: 900px) {
  /* placeholder para futuras reglas tablet */
}

/* ---------- Mobile estrecho ---------- */
@media (max-width: 600px) {
  .section {
    padding: var(--space-8) 0;
  }
  .section__header {
    margin-bottom: var(--space-6);
  }
}

/* ---------- Teléfonos pequeños (≤420px) ---------- */
@media (max-width: 420px) {
  .container {
    padding: 0 var(--space-4);
  }
  .section {
    padding: var(--space-7) 0;
  }
  .hero {
    padding-top: calc(var(--header-height) + var(--space-6));
    padding-bottom: var(--space-7);
  }
  .hero__cta .btn {
    flex: 1 1 100%;
  }
}
