/* Grid leve — substitui Bootstrap nos templates legados (single.php ACF) */

.container,
.container-fluid {
  width: 100%;
  margin-inline: auto;
  padding-inline: var(--f42-gutter);
}

.container {
  max-width: var(--f42-container);
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin-inline: calc(var(--f42-gutter) * -0.5);
}

[class*="col-"] {
  padding-inline: calc(var(--f42-gutter) * 0.5);
  width: 100%;
}

.text-center {
  text-align: center;
}

.text-md-right {
  text-align: right;
}

.text-sm-center {
  text-align: center;
}

@media (min-width: 768px) {
  .col-md-4 {
    width: 33.333%;
  }

  .col-md-6 {
    width: 50%;
  }

  .col-md-8 {
    width: 66.666%;
  }

  .col-md-10 {
    width: 83.333%;
  }

  .col-md-12 {
    width: 100%;
  }

  .offset-md-1 {
    margin-inline-start: 8.333%;
  }

  .offset-md-2 {
    margin-inline-start: 16.666%;
  }

  .text-md-right {
    text-align: right;
  }
}

@media (max-width: 767px) {
  .col-xs-12 {
    width: 100%;
  }

  .hidden-md-down {
    display: none !important;
  }
}

/* Layout semântico v2 */
.f42-container {
  width: min(var(--f42-container), 100% - var(--f42-gutter) * 2);
  margin-inline: auto;
}

.f42-content-narrow {
  max-width: var(--f42-content);
  margin-inline: auto;
}

.f42-section {
  padding-block: clamp(2rem, 5vw, 4rem);
}

.f42-grid-2 {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .f42-grid-2 {
    grid-template-columns: 1fr 1fr;
  }
}

.f42-grid-cards {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.card-columns {
  column-count: 1;
  column-gap: 1.25rem;
}

@media (min-width: 768px) {
  .card-columns {
    column-count: 2;
  }
}

@media (min-width: 1024px) {
  .card-columns {
    column-count: 3;
  }
}

.card-columns .card {
  break-inside: avoid;
  margin-bottom: 1.25rem;
}
