/* ========================================
   Info Karte Block - Frontend Styles
   ======================================== */

/* AOS Wrapper - behält Position, verhindert Layout-Verschiebungen */
.kss-infocard-wrapper {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

/* Desktop & Tablet: 32% Breite mit Gap für Wrapper */
@media (min-width: 769px) {
  .kss-infocard-wrapper {
    width: calc(32% - 1rem);
    flex: 0 0 calc(32% - 1rem);
  }
  
  /* Volle Breite Wrapper */
  .kss-infocard-wrapper--full-width {
    width: 100%;
    flex: 0 0 100%;
  }
}

/* Mobile: 100% Breite für Wrapper */
@media (max-width: 768px) {
  .kss-infocard-wrapper {
    width: 100%;
    flex: 0 0 100%;
  }
}

.kss-infocard {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: transparent;
  cursor: pointer;
  height: 100%;
  width: 100%;
}

/* Ohne AOS-Wrapper: Direkte Breiten-Einstellungen */
@media (min-width: 769px) {
  .kss-infocard:not(.kss-infocard-wrapper > .kss-infocard) {
    width: calc(32% - 1rem);
    flex: 0 0 calc(32% - 1rem);
  }
  
  /* Volle Breite ohne Wrapper */
  .kss-infocard--full-width:not(.kss-infocard-wrapper > .kss-infocard) {
    width: 100%;
    flex: 0 0 100%;
  }
}

/* Mobile: 100% Breite */
@media (max-width: 768px) {
  .kss-infocard:not(.kss-infocard-wrapper > .kss-infocard) {
    width: 100%;
    flex: 0 0 100%;
  }
}

/* Bild-Container */
.kss-infocard__image {
  position: relative;
  width: 100%;
  height: 300px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}

/* Bild-Overlay (Abdunklung) */
.kss-infocard__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  pointer-events: none;
  z-index: 1;
}

/* Hauptcontent (Headline + Text) */
.kss-infocard__content {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.kss-infocard__content h3 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--kss-copy-text-color-primary, #212529);
  line-height: 1.3;
}

.kss-infocard__content p {
  margin: 0;
  font-size: 1rem;
  color: var(--kss-copy-text-color-secondary, #6c757d);
  line-height: 1.6;
}

/* Hover-Content (im Bild positioniert, fährt nach oben) */
.kss-infocard__hover-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.9);
  color: var(--kss-color-white, #fff);
  padding: 1.5rem;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 10;
  height: auto;
  display: block;
}

.kss-infocard__hover-inner {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
}

.kss-infocard__hover-content p {
  margin: 0;
  color: var(--kss-color-white, #fff);
  font-size: 0.95rem;
  line-height: 1.6;
  white-space: pre-wrap;
}

.kss-infocard__hover-content h3,
.kss-infocard__hover-content h4 {
  margin: 0;
  color: var(--kss-color-white, #fff);
}

/* Hover-Effekt nur für Content */
.kss-infocard__hover-content {
  transform: translateY(100%);
}

.kss-infocard:hover .kss-infocard__hover-content {
  transform: translateY(0);
}

/* ========================================
   Border Radius Varianten - nur für Bild
   ======================================== */

/* Small: 0.5x Layout Gap - nur obere Ecken */
.kss-infocard--rounded-small .kss-infocard__image {
  border-top-left-radius: 0.25rem; /* Fallback */
  border-top-left-radius: calc(var(--kss-page-layout-gap,2rem ) * 0.25);
  border-top-right-radius: 0.25rem; /* Fallback */
  border-top-right-radius: calc(var(--kss-page-layout-gap,2rem ) * 0.25);
  border-bottom-left-radius: calc(var(--kss-page-layout-gap,2rem ) * 0.25);
  border-bottom-right-radius: calc(var(--kss-page-layout-gap,2rem ) * 0.25);
}

/* Medium: 1x Layout Gap - nur obere Ecken */
.kss-infocard--rounded-medium .kss-infocard__image {
  border-top-left-radius: 1rem; /* Fallback */
  border-top-left-radius: calc(var(--kss-page-layout-gap, 2rem) * 0.5);
  border-top-right-radius: 1rem; /* Fallback */
  border-top-right-radius: calc(var(--kss-page-layout-gap, 2rem) * 0.5);
  border-bottom-left-radius: calc(var(--kss-page-layout-gap, 2rem) * 0.5);
  border-bottom-right-radius: calc(var(--kss-page-layout-gap, 2rem) * 0.5);
}

/* Large: 2x Layout Gap - nur obere Ecken */
.kss-infocard--rounded-large .kss-infocard__image {
  border-top-left-radius: 2rem; /* Fallback */
  border-top-left-radius: calc(var(--kss-page-layout-gap, 2rem) * 1.25);
  border-top-right-radius: 2rem; /* Fallback */
  border-top-right-radius: calc(var(--kss-page-layout-gap, 2rem) * 1.25);
  border-bottom-left-radius: calc(var(--kss-page-layout-gap, 2rem) * 1.25);
  border-bottom-right-radius: calc(var(--kss-page-layout-gap, 2rem) * 0.5);
}

/* ========================================
   Responsive Anpassungen
   ======================================== */

@media (max-width: 768px) {
  .kss-infocard__image {
    height: 250px;
  }

  .kss-infocard__content {
    padding: 1.25rem;
  }

  .kss-infocard__content h3 {
    font-size: 1.25rem;
  }

  .kss-infocard__hover-content {
    padding: 1.25rem;
  }
}

@media (max-width: 480px) {
  .kss-infocard__image {
    height: 220px;
  }

  .kss-infocard__content {
    padding: 1rem;
  }

  .kss-infocard__content h3 {
    font-size: 1.125rem;
  }

  .kss-infocard__hover-content {
    padding: 1rem;
  }
}

/* ========================================
   Accessibility
   ======================================== */

.kss-infocard:focus-visible {
  outline: 2px solid var(--kss-primary-color, #0066cc);
  outline-offset: 2px;
}

/* Prefers Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .kss-infocard,
  .kss-infocard__hover-content {
    transition: none;
  }
}

.kss-infocard.kss-infocard--full-width{
  width: 100%;
  max-width: 100%;
}