

/* Text-Links im Fließtext: sichtbar & barrierefrei */
.content a {
  color: var(--ci-dunkelblau);
  text-decoration: none;
  border-bottom: 1px solid var(--ci-dunkelblau);
  transition: color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
  font-weight: 600;
}

.content a:hover {
  opacity: 0.8;
}

.content a:focus-visible {
  outline: 2px solid var(--ci-hellblau, #5da7ff);
  outline-offset: 2px;
}

.content ol li::marker {
  font-weight: bold;
}

.highlighting {
  border-left: 4px solid var(--ci-dunkelblau);
  padding-left: 1rem;

}

.highlighting.is-white {
  border-left-color: #fff !important;
}

.highlighting p:first-child {
  font-size: 1.1rem;
}

.highlighting span {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.85rem;
  margin-right: 0.5rem;
}

.content img {
  max-width: 100%;
  height: auto !important;
}

.accordion-content {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.35s ease, opacity 0.25s ease;
}

.accordion-content.is-open {
  opacity: 1;
}

.accordion-trigger.button {
  display: flex;              /* flex aktiv */
  flex-wrap: nowrap;          /* Items NICHT umbrechen */
  align-items: flex-start;    /* Icon oben an der ersten Textzeile ausrichten */
  justify-content: flex-start;
  gap: 0.2rem;
  white-space: normal;        /* Text darf umbrechen */
  text-align: left;
}

.accordion-trigger .has-text-weight-bold {
  flex: 1 1 auto;             /* nimmt restliche Breite */
  min-width: 0;               /* verhindert Überlauf in Flex-Container */
}



.tips-grid-columns > .column {
  display: flex;
}

.tips-grid-columns > .column > .card {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}

.tips-grid-columns > .column > .card .card-content {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}


/*TEXT STYLES*/
.content {
  margin-bottom: 0;
}

.content > p,
.content > h1,
.content > h2,
.content > h3,
.content > h4,
.content > h5 {
  padding-left: 0;
  padding-right: 0;
}

/* Quote component */
.quote {
  --quote-highlight: var(--ci-dunkelblau);
  --quote-gap: 0em;
  line-height: 2;
  font-weight: 700;
  color: #fff;
  display: inline;
  padding-block: 0.14em;
  padding-inline: 0.2em !important;
  background-image: linear-gradient(var(--quote-highlight), var(--quote-highlight));
  background-repeat: no-repeat;
  background-size: 100% calc(100% - var(--quote-gap));
  background-position: 0 calc(var(--quote-gap) / 2);
  box-shadow: 0.25em 0 0 var(--quote-highlight), -0.25em 0 0 var(--quote-highlight);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.quote,
.narrow {
  line-height: 2 !important;
  padding-block: 0.15em !important;
}

.quote-section {
  position: relative;
  max-width: 100%;
  margin-left: 20%;
  margin-right: 20%;
}

.quote-section__text {
  max-width: 32rem;
}

.header-quote-section {
  position: relative;
  max-width: 30rem !important;
  margin: 0;
}

.quote-author {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.quote-author__image {
  border-radius: 50%;
  overflow: hidden;
}

.quote-author__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.quote-author__role {
  color: var(--ci-dunkelblau);
  line-height: 1.4;
  max-width: 20rem;
}

.quote-author .image.is-rounded img {
  border-radius: 50%;
  object-fit: cover;
  height: 100%;
  width: 100%;
}

@media (max-width: 640px) {
  .quote-section {
    margin: 0 5%;
    max-width: 100%;
  }

  .header-quote-section {
    max-width: 100%;
  }

.quote,
.narrow {
  line-height: 1.8 !important;
  padding-block: 0.1em !important;
}

.quote-author__role {
  max-width: 80%;
}
}

/* ----------------------------------------
   Feature Showcase Module
----------------------------------------- */
.feature-showcase {
  background-color: #fbf7f3;
  position: relative;
  overflow: hidden;
}

.feature-showcase.is-fullvw {
  padding-left: 0;
  padding-right: 0;
}

.feature-showcase__content {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.feature-showcase__header {
  margin: 0 auto 2.5rem auto;
}

.feature-showcase__header .feature-showcase__title {
  color: var(--ci-dunkelblau, #384887);
  letter-spacing: 0;
}

.feature-showcase__subtitle {
  color: rgba(56, 72, 135, 0.85);
  display: inline-block;
}

.feature-showcase__hero {
  position: relative;
  overflow: hidden;
  min-height: 280px;
  width: 90%;
  margin: 0 auto;
  background: linear-gradient(120deg, #241f5b, #4a5a93);
}

.feature-showcase__background,
.feature-showcase__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.feature-showcase__background {
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}

.feature-showcase__overlay {
  background: linear-gradient(180deg, rgba(4, 12, 24, 0.6) 0%, rgba(4, 12, 24, 0.3) 55%, rgba(4, 12, 24, 0.0) 100%);
}

.feature-showcase__hero-cta {
  position: absolute;
  max-width: 280px;
  color: #fff;
  z-index: 2;
}

.feature-showcase__hero-text {
  font-weight: 700;
  line-height: 1.3;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
}


.feature-showcase__hero-link span {
  font-size: 1.25rem;
  line-height: 1;
}

.feature-showcase__cards {
  position: relative;
  z-index: 3;
  margin-top: -120px;
}

.feature-showcase__cards .columns {
  justify-content: center;
}

.square_box.feature-card-color--dunkelblau {
  background-color: var(--ci-dunkelblau);
}
.square_box.feature-card-color--petrol {
  background-color: var(--ci-petrol);
}
.square_box.feature-card-color--backsteinrot {
  background-color: var(--ci-backsteinrot);
}
.square_box.feature-card-color--schilfgruen {
  background-color: var(--ci-schilfgruen);
}
.square_box.feature-card-color--sonnengelb {
  background-color: var(--ci-sonnengelb);
}
.square_box.feature-card-color--sand {
  background-color: var(--ci-sand);
}

body.theme-high-contrast .feature-showcase {
  background: #ffffff !important;
  color: #000000 !important;
}

body.theme-high-contrast .feature-showcase__background,
body.theme-high-contrast .feature-showcase__overlay {
  display: none !important;
}

body.theme-high-contrast .feature-card {
  border: 1px solid #000000;
  box-shadow: none;
}


.image-gradient-30-height {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 30%;
  background: linear-gradient(180deg, rgba(10, 10, 10, 0) 0%, rgba(10, 10, 10, 0.8) 100%);
  pointer-events: none;
  z-index: 2;
}

.image-gradient-70-height {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 90%;
  background: linear-gradient(180deg, rgba(10, 10, 10, 0) 0%, rgba(10, 10, 10, 0.9) 100%);
  pointer-events: none;
  z-index: 1;
}

.logo-left {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.logo-right {
  max-width: 100%;
  height: auto;
  display: block;
}

.section-divider {
  width: 100%;
  min-width: 80px;
  height: 1px;
  margin-top: -0.2rem;
  background-color: var(--ci-dunkelblau);
  opacity: 1;
}

.section-divider-20 {
  width: 20% !important;
  min-width: 80px;
  height: 1px;
  margin-top: -0.2rem;
  background-color: var(--ci-dunkelblau);
  opacity: 1;
}
.section-divider-20.is-centered {
  margin-left: auto;
  margin-right: auto;
}

.section-divider-10 {
  width: 10% !important;
  min-width: 80px;
  height: 1px;
  margin-top: -0.2rem;
  background-color: var(--ci-dunkelblau);
  opacity: 1;
}
.section-divider-10.is-centered {
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 768px) {
  .section-divider-20 {
    width: 30% !important;
  }
}

/* Info box */
.info-box {
  color: var(--ci-dunkelblau, #384887);
  position: relative;
}


.info-box__media {
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-color: transparent;
}

.info-box__media--circle {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  padding: 0.65rem;
  background-color: #ffffff;
}

.info-box__media--rect {
  padding: 0;
}

.info-box__media img,
.info-box__image {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.info-box__image--circle {
  height: 100%;
}

.info-box__media--mobile {
  width: 180px;
  height: 180px;
}

.info-box__content {
  flex: 1 1 260px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
}

.info-box__aside {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.info-box__aside--circle {
  flex: 0 0 200px;
}

.info-box__aside--rect {
  max-width: 100%;
  align-items: stretch;
  margin-bottom: auto;
}

.info-box__title {
  color: var(--ci-dunkelblau, #384887);
}

.info-box__text p:last-child {
  margin-bottom: 0;
}

.info-box__cta {
  margin-top: auto;
  align-self: flex-end;
  text-align: right;
  display: inline-flex;
}

.info-box__cta .button {
  box-shadow: none;
  display: inline-flex;
  align-items: center;
}

.info-box__caption {
  color: var(--ci-dunkelblau, #384887);
}

.info-box__media-mobile {
  display: none;
  width: 100%;
  justify-content: center;
}

.info-box__media-mobile--rect .info-box__media--rect {
  max-width: 100%;
}

.info-box__media-mobile--rect .info-box__caption {
  text-align: center;
}

@media (max-width: 768px) {
  .info-box.columns {
    --columnGap: 1.25rem;
  }



  .info-box__aside {
    display: none;
  }

  .info-box__content {
    align-items: flex-start;
    text-align: left;
  }

  .info-box__cta {
    display: flex;
    align-self: flex-end;
  }

  .info-box__media-mobile {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: center;
  }
}

/* Link/info lists */
.faminfo-info-section {
  border-radius: 8px;
}

.faminfo-info-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.faminfo-info-item {
  margin-bottom: 1.75rem;
}

.faminfo-info-item:last-child {
  margin-bottom: 0;
}

.faminfo-info-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}

.faminfo-info-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.faminfo-info-icon {
  margin-right: 0.5rem;
}

.faminfo-info-badge {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

.faminfo-info-download {
  display: inline-flex;
  align-items: center;
}

.faminfo-info-meta,
.faminfo-info-description {
  margin: 0.5rem 0 0;
}
/* Callout steps list variants */
.callout-list {
  margin-top: 1.5rem !important;
}

.callout-list__item {
  margin-top: 0.5rem !important;
}

.callout-list__item:last-child {
  margin-bottom: 0;
}

.callout-list--checklist {
  list-style: none;
  margin-left: 0;
  padding-left: 0;
}

.callout-list--checklist .callout-list__item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding-left: 0;
}

.callout-list__icon {
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  background-color: var(--ci-dunkelblau);
  color: #fff;
  font-size: 0.8rem;
}

.callout-list--numbered {
  list-style: none;
  margin-left: 0;
  padding-left: 0;
  counter-reset: callout-counter;
}

.callout-list--numbered .callout-list__item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  counter-increment: callout-counter;
  padding-left: 0;
}

.callout-list--numbered .callout-list__item::before {
  content: counter(callout-counter);
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  background-color: var(--ci-dunkelblau);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  line-height: 1;
}

.callout-list__icon i {
  color: inherit;
  line-height: 1;
}

.callout-list__content,
.callout-list__title,
.callout-list__text {
  display: block;
}

.callout-list__text {
  margin-bottom: 0.3rem !important;
}

/* Lightweight tooltip styling for auto-enhanced article links */
.link-tooltip {
  position: relative;
}

.link-tooltip[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 0;
  bottom: 80%;
  transform: translateY(-0.4rem);
  /*background: rgba(var(--fi-color-primary-rgb), 0.9);*/
  background: var(--fi-color-primary);
  color: #fff;
  font-size: 0.75rem;
  line-height: 1.2;
  padding: 0.25rem 0.5rem;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s ease-in-out, visibility 0.15s ease-in-out;
  z-index: 10;
}

.link-tooltip[data-tooltip]:hover::after,
.link-tooltip[data-tooltip]:focus-visible::after {
  opacity: 1;
  visibility: visible;
}
