/* Angebote (Beratungsinhalte) – Nav-Hover-Verhalten justieren
   Anforderung: Wenn man auf dieser Unterseite über den Menüpunkt
   "Beratungsinhalte" hovert, darf er nicht orange werden, sondern
   schwarz bleiben. Dies gilt unabhängig davon, ob die Jugenhilfe-
   Sektion gerade aktiv ist. */

/* Normaler Headerzustand – nur schwarz halten, wenn "Beratungsinhalte" aktiv ist */
.site-header .nav-link[href$="angebote.php"].is-active:hover {
  color: var(--color-text);
}

/* Over-hero (transparenter Header ganz oben) – gleiche Logik */
.site-header.is-over-hero .nav-link[href$="angebote.php"].is-active:hover {
  color: var(--color-text);
}

/* Angebote – Kartengrid: 4 Kästchen in einer Reihe (wie Startseite) */
.offer-grid .offer-columns {
  display: grid;
  gap: clamp(1.4rem, 3vw, 2.4rem);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

@media (min-width: 960px) {
  .offer-grid .offer-columns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Karten-Inhalt ident zu Startseite */
.offer-card {
  display: grid;
  gap: 0.9rem;
  min-height: 100%;
}
.offer-card h3 { margin-bottom: 0.3rem; }
.offer-card p { color: var(--color-text-muted); }
.offer-card .no-break {
  white-space: nowrap;
  hyphens: manual;
  overflow-wrap: normal;
}

/* Lange Wörter/Komposita sauber umbrechen (de) */
.offer-card h3,
.offer-card p {
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: auto;
}

.offer-media {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  display: grid;
}

@supports (aspect-ratio: 1) {
  .offer-media::before {
    content: none;
  }

  .offer-media > .image-cover {
    position: static;
    inset: auto;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

/* Überschriften mit manuellen Zeilenumbrüchen sauber stapeln */
.heading-stacked span { display: block; }
.heading-stacked .no-break { white-space: nowrap; }

/* Bildfokus-Utilities für sauberes Zuschneiden im Kasten */
.image-frame.is-focus-top .image-cover,
.offer-media.is-focus-top .image-cover { object-position: center 30%; }
.image-frame.is-focus-low .image-cover,
.offer-media.is-focus-low .image-cover { object-position: center 70%; }

.offer-specials .card-subtitle {
  font-size: clamp(1.05rem, 1.3vw, 1.2rem);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 0.4rem;
}
