/* ===========================
   LAYOUT — IKP Redesign
   =========================== */

/* ── Container ── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 40px;
}

/* ── Seções ── */
.section {
  padding: var(--section-padding);
  overflow-x: hidden;
}

.section--cream {
  background-color: var(--cream);
}

.section--dark {
  background-color: var(--charcoal);
  color: var(--white);
}

.section--white {
  background-color: var(--white);
}

/* ── Grid 2 colunas ── */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap-xl);
  align-items: center;
}

/* ── Grid 3 colunas ── */
.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-lg);
}

/* ── Grid galeria (3x2) ── */
.grid-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-md);
}

/* ── Flex utilitários ── */
.flex {
  display: flex;
}

.flex--center {
  align-items: center;
  justify-content: center;
}

.flex--between {
  align-items: center;
  justify-content: space-between;
}

.flex--column {
  flex-direction: column;
}

.flex--gap-sm {
  gap: var(--gap-sm);
}

.flex--gap-md {
  gap: var(--gap-md);
}

.flex--gap-lg {
  gap: var(--gap-lg);
}

/* ── Texto centralizado ── */
.text-center {
  text-align: center;
}

/* ── Margin/padding utilitários ── */
.mb-sm {
  margin-bottom: var(--gap-sm);
}

.mb-md {
  margin-bottom: var(--gap-md);
}

.mb-lg {
  margin-bottom: var(--gap-lg);
}

.mb-xl {
  margin-bottom: var(--gap-xl);
}

.mt-lg {
  margin-top: var(--gap-lg);
}

.mt-xl {
  margin-top: var(--gap-xl);
}

/* ── Responsividade Geral ── */
@media (max-width: 768px) {
  body {
    overflow-x: hidden;
  }

  .container {
    padding: 0 20px;
  }

  .grid-2,
  .grid-3:not(.grid-3--scroll),
  .grid-gallery {
    grid-template-columns: 1fr;
    gap: var(--gap-lg);
  }

  /* Horizontal scroll grid - for articles */
  .grid-3--scroll {
    display: flex;
    overflow-x: auto;
    gap: var(--gap-md);
    padding-bottom: var(--gap-md);
    margin: 0 calc(20px * -1);
    /* Using 20px for container padding */
    padding: 0 20px var(--gap-md);
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .grid-3--scroll::-webkit-scrollbar {
    display: none;
  }

  .grid-3--scroll>* {
    flex: 0 0 85%;
    scroll-snap-align: center;
    scroll-snap-stop: always;
  }
}