/* Optional: Schriftart auf bestimmte Bootstrap-Elemente anwenden */
.navbar,
.navbar-nav .nav-link {
  font-family: 'IBM Plex Sans', sans-serif;
}

@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../font/IBMPlexSans-Regular.ttf') format('truetype');
}


html,
body {
  overflow-x: hidden;
  scroll-behavior: smooth;


}

#partner {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 3rem;
  color: #46618D;
  text-align: left;
  text-transform: uppercase;

}

#contact {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 3rem;
  color: white;
  text-align: left;
  text-transform: uppercase;
  padding-left: 7%;
  font-weight: bold;
}

.contacttxt {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1rem;
  color: white;
  text-align: left;
  font-weight: 400;
  width: 60%;
  line-height: 180%;
}

.contacttxt2 {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1.4rem;
  color: white;
  text-align: left;
  font-weight: 400;
  font-style: italic;
  line-height: 180%;
}

.contacttxtsmall {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1rem;
  color: white;
  text-align: left;
  font-weight: 400;
}

#contacttxtname {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1.6rem;
  color: white;
  text-align: left;
  text-transform: uppercase;
  line-height: 120%;
  letter-spacing: 0.1em;
  font-weight: bold;
  margin-bottom: 30px;

}

.contacttxtpos {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1rem;
  color: white;
  text-align: left;
  font-weight: 400;
}

#copyright {
  color: #46618D;
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1rem;
  text-decoration: none;
}


#copyright2 {
  color: #46618D;
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1rem;
  text-decoration: none;
}

.footer {
  background-color: white !important;

}

#customLink {
  color: #46618D !important;
  text-decoration: none;
}

#customLink2 {
  color: #46618D !important;
  text-decoration: none;
}

#customLink3 {
  color: #46618D !important;
  text-decoration: none;
}

#customLink4 {
  color: #46618D !important;
  text-decoration: none;
}

#customLink5 {
  color: #46618D !important;
  text-decoration: none;
}

#customLink6 {
  color: #46618D !important;
  text-decoration: none;
}

a {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1rem;
  color: white;
  text-align: left;
  font-weight: 400;
  letter-spacing: 0.05em;
}

#contactlinks {
  margin-left: 1%;
  margin-top: 1%;
}
#contactlinks2 {
  margin-left: 1%;
  margin-top: 1%;
}

.icon {
  width: 24px;
}

.containercontact {
  background-color: #46618D;
  padding: 7%;
}

.p-3 {
  background-color: #46618D;
}

.diagonal-sectionone {
  width: 100vw;
  /* Breite über den gesamten Bildschirm */
  height: 100px;
  /* Höhe des Divs */
  background-color: #46618D;
  /* Hintergrundfarbe */
  clip-path: polygon(0 80%, 0 0, 100% 0);
  padding: 0;
  margin-top: -1px;
}


.diagonal-section {
  width: 100vw;
  /* Breite über den gesamten Bildschirm */
  height: 100px;
  /* Höhe des Divs */
  background-color: #46618D;
  /* Hintergrundfarbe */
  clip-path: polygon(0 80%, 0 0, 100% 0);
  padding: 0;
  margin-top: -49px;
  margin-right: o;

}

#linkscontact {
  font-family: 'IBM Plex Sans', sans-serif;

  color: white;

  padding-left: 7%;

}


#rightcontact {
  font-family: 'IBM Plex Sans', sans-serif;

  color: white;

  padding-left: 7%;

}

#customLink:hover {
  text-decoration: underline;

}

#contactlinks:hover {
  text-decoration: underline !important;

}

.card-text {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1em;
  color: #46618D;
  text-align: left;
  font-weight: 400;
  padding-right: 10%;

}

.nav-link:hover {
  text-decoration: underline;

}


/* Sicherstellen, dass diese Regel nur für kleinere Bildschirme gilt */
@media (max-width: 991.98px) {

  /* Gilt für Bildschirme unterhalb von 'lg' */
  #navbarNavAltMarkup .nav-item .nav-link {
    padding-left: 20px;
    /* Vertikale Abstände für die Links im Burger-Menü */

  }
}

.containerpartner {
  background-color: #D5E1E5;
}

.nav-link {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 1em;
  color: #46618D;
}

.navbar-toggler {
  border: none;
}

.card-img-top {
  background-color: #D5E1E5;
  padding-top: 10%;
  padding-bottom: 10%;
  width: 80%;

}

#leistungbeschreibungbold {
 font-weight: 700;
  font-size: 1.5em;
  color: #46618D;
}


#beratungdescriptionbold {
  font-weight: 700;
   font-size: 1.5em;
   color: #46618D;
 }

#landingPage {
  background: linear-gradient(to top, rgba(70, 97, 141, 1) 0%, rgba(70, 97, 141, 0.8) 30%, rgba(70, 97, 141, 0.4) 60%, rgba(70, 97, 141, 0) 100%), url('../img/leiterplatte.webp');
  background-size: cover;
  background-position: center;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #46618D;

}

.card {
  border: none;
  background-color: #D5E1E5;

}

.card-body {
  background-color: #D5E1E5;
  padding: 0;

}


.container {
  max-width: fit-content;
}

.impressum {
  color: #46618D;
  line-height: 100%;
}

.container2 {
  background: white;
  width: 100%;
  padding-left: 20%;
  padding-right: 20%;
}

/* Responsive layout adjustments */
#landing-content {
  display: flex;
  flex-wrap: wrap;

}

#logo-div {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5%;
  text-align: center;
  margin-top: 10%;

}

.img-fluid2 {
  max-width: 100%;


}

#text-div {
  margin-top: 18%;

  padding-left: 5%;
  padding-right: 5%;
  padding-bottom: 10%;

  text-align: left;
  color: White;

}

@media screen and (max-width: 768px) {
  #text-div {
    margin-top: 0;
    /* Margin oben für mobile Geräte entfernen */
    padding-left: 10%;
    padding-right: 10%;

  }

  .img-fluid {
    margin-top: 10%;
    /* Margin oben für mobile Geräte entfernen */

    padding-left: 10%;
    padding-right: 10%;

  }

  .narrower-container {
    max-width: 85% !important;
}

.card-text { 
  font-size: 1.5em;
}

.narrower-container2 {
  max-width: 85% !important;
  padding-top: 15% !important;
  padding-bottom: 20% !important;

}

.container2 {
  padding-left: 0% !important;
  padding-right: 10% !important;
}

.text-block p {
  font-size: 1.4em !important;
}

.text-block h3 {
  font-size: 1.7em !important;
}

.contacttxt {
  font-size: 1.4rem;
  width: 100%;
}

#contacttxtname {
  font-size: 2rem;
}

a {
  font-size: 1.2rem;
}

#copyright2 {
  font-size: 1.2rem;

}

#copyright3 {
  font-size: 1.2rem;

}

#copyright4 {
  font-size: 1.2rem;

}

.section-title2 {
  margin-left: 5% !important;
}

.nav-link {
  padding-top: 5% !important;
  font-size: 1.2rem;
}

}

#head {
  margin-top: 15%;

  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 2em;
  line-height: 1.8em;

  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

/* Full-Screen Image Container Styling */
.full-screen-image {
  width: 100vw;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  margin: 0;
  padding: 0;
  margin-top: -30px;
}

.navbar-brand {
  padding-left: 20px;
}

/* Leistungen Section Styling */
.leistungen-section {
  padding: 40px 0;
  display: flex;
  justify-content: center;
  align-items: center;
}




/* Container mit schmalerer Breite */
.narrower-container {
  max-width: 70%;
  /* Maximale Breite des Containers */
  margin: 0 auto;
  /* Zentrierung des Containers */
  background-color: white;
}

/* Container mit schmalerer Breite */
.narrower-container2 {
  max-width: 70%;
  /* Maximale Breite des Containers */
  margin: 0 auto;
  /* Zentrierung des Containers */
  background-color: #D5E1E5;
  padding-top: 5%;
  padding-bottom: 10%;
}


/* Section Title */
.section-title {
  font-size: 2.5rem;
  color: #46618D;
  text-align: left;
  text-transform: uppercase;
  font-weight: 700;

  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

/* Leistung Styling */
.leistung {
  display: flex;
  align-items: flex-start;
  margin-bottom: 7%;

}

#textleistungen {
  text-transform: uppercase;
  font-size: 2em;
  color: #46618D;
  font-weight: 700;
  word-break: break-word;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

.textleistungen {
  text-transform: uppercase;
  font-size: 2em;
  color: #46618D;
  font-weight: 700;
  word-break: break-word;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}


#textleistungen1 {
  text-transform: uppercase;
  font-size: 2em;
  color: #46618D;
  font-weight: 700;

  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

#textleistungen2 {
  text-transform: uppercase;
  font-size: 2em;
  color: #46618D;
  font-weight: 700;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

.leistung-title h2 {
  font-size: 2em;
  color: #46618D;
  margin-bottom: 7%;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;

}

.leistung-title2 {
  font-size: 1em;
  color: #46618D;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;

}

.leistung-description p {
  font-size: 1.5em;
  color: #46618D;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

.leistung-description2 p {
  font-size: 1em;
  color: #46618D;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}


.leistung-description p strong {
  color: #46618D;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
  /* Optionale Farbe für den fettgedruckten Satz */
}

/* Divider Styling */
.divider {
  border-top: 1px solid #46618D;

  margin: 7% 0;
}

/* Rectangle Image Section Styling */
.rectangle-image-section {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  margin-top: -50px;
}

/* Container to ensure full width and set height */
.rectangle-image-container {
  width: 100%;
  height: 300px;
  /* Festgelegte Höhe, die du anpassen kannst */
  overflow: hidden;

}

/* Image Styling */
.rectangle-image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Das Bild bleibt proportional und deckt die gesamte Fläche */
}



/* Left-Right Section Styling */
.left-right-section {
  padding: 40px 0;
  margin-left: 5%;

}

/* Left Box Styling (20% width) */
.left-box {
  text-align: center;

}

.left-image {
  width: 100%;
  height: 900px;
  border-radius: 8px;
  margin-top: 20%;
  content: url('../img/linien_2.svg');

}


/* Mobile Styles */
@media (max-width: 768px) {
  .left-image {
    width: 100%;
    height: 1100px;
    content: url('../img/linien_mobile_2.svg');
    /* Neues Bild für mobile Geräte */
  }
}

/* Mobile Styles */
@media (max-width: 700px) {
  .left-image {
    height: 1100px;
    content: url('../img/linien_mobile_2.svg');
    /* Neues Bild für mobile Geräte */
  }
  .left-box {
    text-align: center;
    width: 20%;
  }
}

/* Mobile Styles */
@media (max-width: 600px) {
  .left-image {
    height: 1300px;
    content: url('../img/linien_mobile_2.svg');
    /* Neues Bild für mobile Geräte */
  }
  .left-box {
    text-align: center;
    width: 20%;
  }
}

/* Mobile Styles */
@media (max-width: 500px) {
  .left-image {
    height: 1400px;
    content: url('../img/linien_mobile_2.svg');
    /* Neues Bild für mobile Geräte */
  }
  .left-box {
    text-align: center;
    width: 20%;
  }
}

/* Mobile Styles */
@media (max-width: 420px) {
  .left-image {
    width: 200%;
    height: 1500px;
    content: url('../img/linien_mobile_2.svg');
    /* Neues Bild für mobile Geräte */
  }
  .left-box {
    text-align: center;
    width: 20%;
  }
}

/* Mobile Styles */
@media (max-width: 350px) {
  .left-image {
    display: none;
}
.left-box {
  display: none;

}
}

/* Right Box Styling (80% width) */
.right-box {
  padding-left: 20px;
  width: 80%;
  padding-left: 10%;
  padding-right: 10%;
}

/* Text Block Styling */
.text-block {
  margin-bottom: 20px;
  padding: 2%;
}

.text-block h3 {
  font-size: 1.5em;
  color: #46618D;
  text-align: left;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 10px;
  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

.text-block p {
  font-size: 1.2em;
  color: #46618D;
  text-align: left;
}

/* Section Title Styling */
.section-title2 {
  font-size: 2.5rem;
  color: #46618D;
  text-align: left;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 3%;
  padding-top: 5%;
  margin-left: 15%;
  margin-right: 20%;

  word-wrap: break-word; 
  overflow-wrap: break-word; 
  hyphens: auto;
}

.footer {
  padding: 20px 0;
}

.fade-in {
  opacity: 0;
  transform: translateY(30px); /* Startposition */
  transition: opacity 1.2s ease-out, transform 1.2s ease-out;
}

.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}
