/* =========================================================
   logos Wrapper – Layout
   ========================================================= */
.logos-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--block-margin) / 2); /* Abstand zwischen den logo-Blöcken */
}

/* Alle direkten Kinder von logos-wrapper: entweder a.logo-link oder .logo */
.logos-wrapper > a.logo-link,
.logos-wrapper > .logo {
  display: flex; /* Flex, damit Zentrierung funktioniert */
  justify-content: center;
  align-items: center;
  width: calc(33.333% - calc(var(--block-margin)/3)); /* 3 Spalten + Abstand */
  text-decoration: none;
  color: inherit;
  aspect-ratio: 1 / 1; /* quadratisch */
}

/* logo-Block selbst braucht nur noch relative Position für Overlay */
.logo {
  position: relative;
  width: 100%;        /* füllt Flex-Kind aus */
  height: 100%;       /* füllt Flex-Kind aus */
  overflow: hidden;
  display: flex;      /* Bild zentrieren */
  justify-content: center;
  align-items: center;
}

/* Bild */
.logo img {
  width: 50%;       /* immer 70% des Containers */
  height: auto;     /* proportional */
  object-fit: contain;
  display: block;
}


/* Overlay: standardmäßig unsichtbar */
.logo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #181f32;
  mix-blend-mode: color;
  opacity: 0;           /* standardmäßig kein Filter */
  pointer-events: none; /* Klicks gehen ans Bild durch */
  transition: opacity 0.3s ease;
}

/* Hover: Overlay wird sichtbar */
.logo:hover::after {
  opacity: 1;
}

/* Overlay-Text */
.logo .overlay {
  position: absolute;
  bottom: 10px;
  right: 10px;
  text-align: right;
  color: #fff; /* nur weiße Schrift, kein Hintergrund */
}

.logo .overlay .title {
  margin: 0;
  line-height: 1.2;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto; /* optional: Bindestriche bei Umbruch */
}

.logo .overlay h3 {
  font-size: 15px;
}

.logo .overlay h2 {
  font-weight: 300 !important;
}

/* Farbvarianten */
.logo.weiss .overlay .title {
  color: #fff;
}

.logo.dunkelblau .overlay .title {
  color: var(--primary-color);
}

/* Schlagschatten bei Text */
.logo.textschatten .overlay .title {
  text-shadow: 2px 2px 4px rgba(0,0,0,0.7);
}

/* Sicherstellen, dass Link den ganzen Block abdeckt */
.logo-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* =========================================================
   Responsive Anpassungen
   ========================================================= */
@media (max-width: 921px) {
  .logos-wrapper > a.logo-link,
.logos-wrapper > .logo {
    width: calc(50% - calc(var(--block-margin)/4)); /* 2 Spalten + Abstand */
  }
}
/*
@media (max-width: 600px) {
  .logos-wrapper > a.logo-link,
.logos-wrapper > .logo {
    width: 100%; /* Link nimmt ganze Breite 
  }
}
*/