/* ==== Galerie-Karten (Übersicht) ==== */
:root {
  --ms-card-radius: 14px;
  --ms-gap: 16px;
  --ms-cover-height: 34%;
}

/* Grundlayout & Abstände im Grid */
.views-view-grid.horizontal {
  margin: calc(-1 * var(--ms-gap) / 2);
}

.views-view-grid.horizontal .views-row {
  display: flex;
  flex-wrap: wrap;
}

.views-view-grid.horizontal .views-row > .views-col {
  box-sizing: border-box;
  padding: calc(var(--ms-gap) / 2);
}

/* Größere Karten auf Desktop: 2 Spalten statt 4 */
@media (min-width: 769px) {
  .views-view-grid.horizontal.cols-4 .views-row > .views-col {
    width: 50% !important;
  }
}

/* Mobile: Karten untereinander, mit Abstand */
@media (max-width: 768px) {
  .views-view-grid.horizontal.cols-4 .views-row > .views-col {
    width: 100% !important;
  }
}

/* Karten-Optik */
.ms-galcard {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--ms-card-radius);
  background: #000;
}

.ms-galcard__img img {
  display: block;
  width: 100%;
  height: auto;
  transition: transform .35s ease;
}

.ms-galcard:hover .ms-galcard__img img,
.ms-galcard:focus-visible .ms-galcard__img img {
  transform: scale(1.04);
}

/* Overlay: Basis + Hover transparenter */
.ms-galcard__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--ms-cover-height);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.6) 0%,
    rgba(0, 0, 0, 0.35) 60%,
    rgba(0, 0, 0, 0) 100%
  );
  color: #fff;
  padding: 14px 16px 20px;
  transition:
    height .35s ease,
    background .35s ease,
    padding-bottom .2s ease;
}

.ms-galcard:hover .ms-galcard__overlay,
.ms-galcard:focus-visible .ms-galcard__overlay {
  height: 100%;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.6) 0%,
    rgba(0, 0, 0, 0.55) 40%,
    rgba(0, 0, 0, 0.25) 100%
  );
  padding-bottom: 72px;
}

.ms-galcard__title {
  font-weight: 800;
  letter-spacing: .2px;
  line-height: 1.15;
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}

.ms-galcard__cta {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 14px;
  display: flex;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .25s ease, transform .25s ease;
}

.ms-galcard:hover .ms-galcard__cta,
.ms-galcard:focus-visible .ms-galcard__cta {
  opacity: 1;
  transform: none;
}

.ms-galcard__cta > span {
  background: #fff;
  color: #0f3a2b;
  border-radius: 999px;
  padding: .55rem 1rem;
  font-weight: 800;
  letter-spacing: .2px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.16);
}

/* Bewegungen für Nutzer mit reduzierter Bewegungseinstellung abschalten */
@media (prefers-reduced-motion: reduce) {
  .ms-galcard__img img,
  .ms-galcard__overlay,
  .ms-galcard__cta {
    transition: none;
  }
}

/* ==== Einzel-Galerie (Node) ==== */
.ms-gallery-grid,
.ms-gallery {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

.ms-gitem {
  display: block;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
  background: #f6f7f8;
}

.ms-gitem__img img {
  display: block;
  width: 100%;
  height: auto;
  transform: scale(1.001);
  transition: transform .25s ease, filter .25s ease;
}

.ms-gitem:hover .ms-gitem__img img {
  transform: scale(1.03);
  filter: contrast(1.02);
}

/* optionaler Fokusrahmen */
.ms-gitem:focus-visible {
  outline: 3px solid #2e7d5a;
  outline-offset: 2px;
}
