/* ==========================================================================
   Frame Base – Layout-Grundgerüst für Footer-Frames.
   Section-Header (label + h2 + p) liegt direkt im .section > .container —
   wird global gestylt. Innen plain h3/img/p/a; Spalten-Layout über die
   .frame__columns--*-Klassen.
   ========================================================================== */

.frame__columns--2 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-3xl);
  align-items: start;
}

.frame__columns--2-1 {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--space-xl);
  align-items: center;
}

.frame__col {
  min-width: 0;
}

.frame__col > img {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: var(--space-md);
}

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

.frame__text {
  max-width: 50rem;
}

/* Mid-Desktop (1024–1399): kleinerer Spaltengap als Default. */
@media (min-width: 1024px) and (max-width: 1399px) {
  .frame__columns--2 {
    gap: var(--space-xl);
  }
  .frame__columns--2-1 {
    gap: var(--space-lg);
  }
}

/* 2-Spalter unter 1024px komplett auf 1 Spalte umbrechen — bei Tablet-Breite
   ist sonst zu wenig Platz. */
@media (max-width: 1023px) {
  .frame__columns--2,
  .frame__columns--2-1 {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .frame__col--icon {
    order: -1;
  }
}
