.sectionContainer{
     min-width: fit-content; /* oder min-content, je nach gewünschtem Verhalten */
    width: 70%;
    max-width: 100%;
    backdrop-filter: blur(20px);
    color: #f0eff2;
    
    margin-top: 3%;
    margin-bottom: 0%;
    text-align: justify;

    border-radius: 25px;
    
    display: flex;  
    flex-direction: column;
    border: solid 1px var(--accent-color) ;
   
  
    
}



#vorwort-heading {
	background-color: transparent !important;
	box-shadow: none !important;

	margin-top: 55px;
	margin-bottom: 55px;
	font-size: clamp(1.2rem, 2.5vw, 3.5rem);

  position: relative;
}


.vorwort-heading-responsive {
  display: none;
}

#vorwort-text {
	    font-size: clamp(0.8rem, 1.2vw, 1.2rem);
		width: 50%;
    font-weight: 400;
    text-align: justify;
}



.freelancer-section {

  padding: 40px 20px;
  font-family: 'Segoe UI', sans-serif;
}

.freelancer-container {
  max-width: 1000px;
  margin: auto;
 border: solid 1px var(--accent-color);
  border-radius: 15px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.1);
  overflow: hidden;
}

.freelancer-flex {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch; /* macht beide gleich hoch */
}

.freelancer-info {

  padding: 15px;
}

.freelancer-info h4 {
width: 100%;
  margin-bottom: 20px;
}

.freelancer-info .highlight {
  color: var(--accent-color);
  text-decoration: underline; 
}

.freelancer-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.freelancer-list li {
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  text-align: start;
}

.freelancer-list .iconFreelancer {
  font-size: 24px;
  color: #4CAF50;
  margin-right: 10px;
}

.freelancer-target {

  background: var(--accent-color);
  color: white;
  padding: 40px;

}


.freelancer-info,
.freelancer-target {
  flex: 1 1 50%;
  box-sizing: border-box; /* wichtig für Padding */
  display: flex;
  flex-direction: column;
  justify-content: space-between; /* optional für gleichmäßigen Abstand */
}


.freelancerHeading {
	padding: 0;
	  margin-top: 0;
	  width: 100%;
}

.freelancer-target p {
font-size: clamp(0.8rem, 1.2vw, 1.2rem);
margin-bottom: 5px;
margin-top: 5px;
 
}



.freelancer-target p:last-child {
	margin-top: 15px;
  margin-bottom: 0;
}

.sectionContainerChild {
  display: flex;
  flex-direction: row;
 
}

h3 {
	text-align: center;
	border-radius: 35px;
    font-size: clamp(1.5rem, 1.5vw, 1.8rem);
    width: 40%

}

#shortInfos{
    display: flex;
    justify-content: center;
    flex-direction: column; 
    align-items: flex-start;
    width: auto ;
    
}


.shortInfoschild{
    width: 100%;
    height: 100%;
    padding-left: 100px;
  padding-right: 100px;
    margin-bottom: 45px;
    text-align: left;
 

   
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.shortInfoschild:nth-child(2){
  padding-left: 100px;
  padding-right: 100px;
  border-left: solid 2px var(--accent-color);
  
}



.info_element_ueberschrift{
    margin-bottom: 35px;
    margin-top: 15px;
    border-bottom: 2px solid var(--accent-color);
    border-radius: 0px;
    width: auto;
   

}

.info_element {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
  
    padding-left: 35px;
    width: 100%;
    border: solid 2px transparent;
   
  

    margin-top: 10px;
    margin-bottom: 10px;
    position: relative; /* Macht es möglich, das Tooltip absolut zu positionieren */
 


    border-radius: 10px;
}

#info_element_liste{

    margin-top: 10px;

}



.network {

    width: 400px;
    height: 400px;
  }

  .node {
    position: absolute;
    width: 12px;
    height: 12px;
    background: var(--accent-color);
    border-radius: 50%;
    animation: pulse 2s infinite ease-in-out;
  }

  .center-node {
    left: 50%;
    top: 50%;
    margin-left: -6px;
    margin-top: -6px;
  }

  .line {
    position: absolute;
    height: 2px;
    background: linear-gradient(90deg, var(--accent-color), transparent);
    transform-origin: left center;
    animation: draw 2s ease forwards;
  }

  @keyframes pulse {
    0%, 100% {
      transform: scale(1);
      opacity: 0.9;
    }
    50% {
      transform: scale(1.5);
      opacity: 1;
    }
  }

  @keyframes draw {
    from {
      width: 0;
    }
    to {
      width: var(--length);
    }
  }


li{
    margin: 5px;
}


.info_element_img{
    width: 36px;
    height: 36px;
    margin-right: 10px;
    filter: brightness(0) invert(1);
  opacity: 0.91; /* 0.41 ≈ 0x69/255 für die Transparenz */

}

.info_element:hover{
    
    right: 10px;
    margin-top: 30px;
      transition: right 0.3s, margin-top 0.3s;
      transition: margin-top 0.3s, margin-top 0.3s;


}

.info_element_text{
    font-size: clamp(1rem, 1vw, 2rem);
 

}

.vorwortContentParent
{
  display: flex;
  flex-direction: row;
  justify-content: space-around;
  padding: 5%;
}


.facts-grid {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}

.fact-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 140px;
  width: 70%;
  min-height: 110px;
  background: var(--accent-color);
  border-radius: 18px;
  box-shadow: 0 4px 18px -8px var(--accent-color);
  padding: 1.2rem 1.5rem;
  margin-bottom: 1rem;
  transition: transform 0.18s, box-shadow 0.18s;
}
.fact-item:hover {
  transform: translateY(-6px) scale(1.04);
  box-shadow: 0 8px 24px -8px var(--accent-color);
}

.fact-title {
  font-size: 0.93rem;
  color: #b3b3c9;
  letter-spacing: 0.5px;
  margin-bottom: 0.2rem;
  text-align: center;
  font-weight: 500;
  text-transform: uppercase;
  opacity: 0.85;
}

.fact-number {
  font-size: 1.8rem;
  font-weight: 700;
  color: #f0eff2;
  letter-spacing: 1px;
  text-align: center;
  line-height: 1.1;
  margin-top: 0.2rem;
}

#zertifikate_link{
    font-size: clamp(1.5rem, 1.5vw, 2rem);

}

.tooltip {
    visibility: hidden; /* Versteckt das Tooltip standardmäßig */
    opacity: 0; /* Unsichtbar durch Transparenz */
    background-color: #f0eff2; /* Hintergrundfarbe des Tooltips */
    color: #2d2c2f; /* Textfarbe */
    text-align: center;
    padding: 5px 10px;
    border-radius: 5px;
    position: absolute;
    bottom: 120%; /* Positioniert das Tooltip über dem Element */
    left: 50%; /* Zentriert das Tooltip horizontal */
    transform: translateX(-50%);
    white-space: nowrap;
    z-index: 10;
 
    transition: opacity 0.3s ease; /* Weicher Übergang beim Einblenden */
}

.tooltip::after {
    content: ""; /* Pfeil hinzufügen */
    position: absolute;
    top: 100%; /* Unterhalb des Tooltips */
    left: 50%;
    transform: translateX(-50%);
    border-width: 5px;
    border-style: solid;
    border-color: #333 transparent transparent transparent;
}


.info_element:hover .tooltip {
    visibility: visible; /* Zeigt das Tooltip an */
    opacity: 1; /* Macht das Tooltip sichtbar */
}


.readMoreZertifikate {
 width: 100%;
min-height: 100px;
 display: flex;
 justify-content: center;
 margin-top: 0px;
       transition: height 5.5s cubic-bezier(0.76, 0, 0.24, 1); /* Sanftes Wachsen */
     
}

.readMoreZertifikate details{
    width: 100%;
    display: block;

  
   }



.readMoreZertifikate summary {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 25%;
  padding: 10px;
  background-color: var(--accent-color);
  color: #ffffff !important;
  border-radius: 25px;
  text-align: center;
  font-size: clamp(0.8rem, 1.2vw, 1rem);
  cursor: pointer;
  overflow: hidden;      /* Hinzugefügt: ::before bleibt im Button */
  position: relative;    /* Hinzugefügt: für ::before */
}

.readMoreZertifikate summary::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 40%;
  height: 100%;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 50%, rgba(255, 255, 255, 0) 100%);
  animation: shine 2s ease-in-out infinite;
  pointer-events: none;
  border-radius: 25px; /* Passend zum Button */
}

.readMore {

  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
	border-radius: 0px !important;
}

.readMore summary {
  
    padding: 15px 30px 15px 30px;
    background-color: var(--accent-color);;
    color: #ffffff !important;
    border-radius: 25px;
    text-align: center;
    border-radius: 25px;
    color: #f0eff2;
    font-size: clamp(1rem, 0.8vw, 1rem);
    position: absolute;
    bottom: 25px;
    box-shadow: rgb(38, 57, 77) 0px 20px 30px -10px;

    cursor: pointer; 
  
  
  
    
}

.readMore details {
    width: 100%;
    margin: 0px 0px 0px 0px;
  
   
    border-bottom-left-radius: 10px; /* Ecke unten links */
	border-bottom-right-radius: 10px; /* Ecke unten rechts */

    font-size: clamp(1rem, 1.5vw, 1.7rem);
    color: #f0eff2;

    text-align: justify; /* Setzt den Text im Blocksatz */
    display:flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-top: none;
    line-height: 1.5; 
   
} 

.readMore details[open] {
    width: 100%;
    padding-bottom: 25px;
	padding: 35px;
      background-color: #000000;
    color: #FFFFFF;
    border: solid 2px var(--accent-color);
    
}

.network {
    position: relative;
    bottom: 0px;
    left: 50%;
    transform: translateX(-50%);
    width: 100px;
    height: 100px;
    background-color: var(--accent-color)949c9;
    border-radius: 50%;
    margin-bottom: 25px;
    margin-top: 50px;
    margin-bottom: 50px;
  }

  .node {
    position: absolute;
    width: 6px;
    height: 6px;
    background: #000000b5;
    border-radius: 50%;
    animation: pulse 2s infinite ease-in-out;
  }

  .center-node {
    left: 50%;
    top: 50%;
    margin-left: -3px;
    margin-top: -3px;
  }

  .line {
    position: absolute;
    height: 2px;
    background: linear-gradient(90deg, #000000b5, transparent);
    transform-origin: left center;
    animation: draw 1.5s ease forwards;
    opacity: 0.9;
  }

  @keyframes pulse {
    0%, 100% {
      transform: scale(1);
      opacity: 0.9;
    }
    50% {
      transform: scale(1.4);
      opacity: 1;
    }
  }

  @keyframes draw {
    from {
      width: 0;
      opacity: 0;
    }
    to {
      width: var(--length);
      opacity: 0.9;
    }
  }


@keyframes pulse {
    0% {
		
		
        transform: scale(1); /* Normalgröße */
    }
    50% {
        transform: scale(1.02); /* 20% größer */
    }
    100% {
        transform: scale(1); /* Zurück zur Normalgröße */
    }
}






.bubble-container {
    position: absolute;
    width: 100%;
    height: 1080px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
      transition: height 3.5s cubic-bezier(0.76, 0, 0.24, 1); /* Sanftes Wachsen */
     
}

.bubble {
    position: relative;
    width: 200px;
    height: 200px;
    background-color: var(--accent-color);
    border-radius: 50%;
    transition: background-color 5s ease;
    box-shadow: 0px 20px 20px -10px #26394d7b, inset 30px -10px 20px -10px #26394d7b, inset -25px 20px 30px -15px #ffffffbb;
  z-index: -100;
   
}

.loading-bubbles {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  gap: 5px;
  z-index: 2;
  /* background: #000000;  <-- ENTFERNEN! */
}

.loading-bubble {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0px 2px 4px -1px #26394d22, 
              inset 2px -1px 3px -2px #26394d11, 
              inset -2px 2px 4px -3px #ffffff22;
  animation: loading-bubble-move 0.8s infinite ease-in-out;
}
.loading-bubble:nth-child(2) {
  animation-delay: 0.2s;
}
.loading-bubble:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes loading-bubble-move {
  0%, 100% {
    transform: translateY(0) scale(1);
    opacity: 0.7;
  }
  50% {
    transform: translateY(-10px) scale(1.15); /* Weniger hoch */
    opacity: 1;
  }
}

.offerButton.white-flash {
  background: #000000 !important;
  color: #ffffff !important;
  border-color: #000000 !important;
  transition: background 0.2s, color 0.2s;
}


@keyframes growShrink {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  
  50% {
    transform: scale(1);
    opacity: 1;

  }

  100% {
    transform: scale(0);
    opacity: 0;
  }
}




.testimonial-arrow {

	
	 width: 35px;
	   filter: brightness(0) invert(1);
  height: 35px;
  
}

.left-arrow {
	 transform: rotate(180deg);
	
}



#bubble1,
#bubble2 {
  width: 125px;
  height: 125px;
  position: absolute;
  top: 40%;
  left: 2%; /* oder right: 1% für #bubble2 */
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 0px 20px 20px -10px #26394d7b, inset 30px -10px 20px -10px #26394d7b, inset -25px 20px 30px -35px #ffffffbb;
  transition: none;
  z-index: 100;
  overflow: hidden; /* <-- wichtig! */
}

#bubble2 {
  left: auto;
  right: 2%;
}

#bubble1::before,
#bubble2::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 40%;
  height: 100%;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.3) 50%, rgba(255,255,255,0) 100%);
  animation: shine 2s ease-in-out infinite;
  border-radius: 50%;
  z-index: 1;
}

#VorwortSection {
  min-width: 70%;
}

#bubble1:hover {
background-color: rgb(0, 0, 0);
    color: rgb(255, 255, 255);
    border: solid 2px var(--accent-color) !important;
}

#bubble2:hover {
	background-color: rgb(0, 0, 0);
    color: rgb(255, 255, 255);
    border: solid 2px var(--accent-color) !important;
}


#bubble1:active {
	background-color: transparent;
}

#bubble2:active {
	background-color:  transparent;;
}





#bubble1Vorwort {
  width: 300px;
  height: 300px;
  position: absolute;
  top: 60%;
  left: 10%;
 
  
  
  
}

#bubble2Vorwort {
  width: 100px;
  height: 100px;
  position: absolute;
  top: 40%;
  right: 12%;

  
}

#bubble3Vorwort {
  width: 400px;
  height: 400px;
  position: absolute;
  top: 35%;
  left: 20%;

}

#bubble4Vorwort {
  width: 600px;
  height: 600px;
  position: absolute;
  top: 30%;
  right: 20%;
}

#bubble5Vorwort {
  width: 400px;
  height: 400px;
  position: absolute;
  top: 75%;
  right: 20%;
}

#bubble6Vorwort {
  width: 300px;
  height: 300px;
  position: absolute;
  bottom: -20%;
  right: 50%;
}

#bubble7Vorwort {
  width: 200px;
  height: 200px;
  position: absolute;
  bottom: -10%;
  left: 10%;
}



#bubble1sec1 {
  width: 500px;
  height: 500px;
  position: absolute;
  top: 35%;
  left: 10%;
  
  
}

#bubble2sec1 {
  width: 200px;
  height: 200px;
  position: absolute;
  top: -2%;
  right: 20%;
}

#bubble3sec1 {
  width: 350px;
  height: 350px;
  position: absolute;
  top: 15%;
  right: 25%;

}

#bubble4sec1 {
  width: 400px;
  height: 400px;
  position: absolute;
  top: 30%;
  right: 42.5%;
}





.bubble-container-transition{

  width: 100%;
  height: 40vh;

  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
}



.trainsition-bubble-one{
  width: 100px;
  height: 100px;
;
  animation: growShrink 5s ease-in-out infinite ;
  animation-delay: 0.5s;
  box-shadow: 0px 20px 20px -10px #26394d7b, inset 30px -10px 20px -10px #26394d7b, inset -25px 20px 30px -35px #ffffffbb;
    
}
.trainsition-bubble-two{
  width: 100px;
  height: 100px;
 
  animation: growShrink 5s ease-in-out infinite ;
  animation-delay: 1s;
  box-shadow: 0px 20px 20px -10px #26394d7b, inset 30px -10px 20px -10px #26394d7b, inset -25px 20px 30px -35px #ffffffbb;
    
}
.trainsition-bubble-three{
  width: 100px;
  height: 100px;

  animation: growShrink 5s ease-in-out infinite ;
  animation-delay: 2s;
  box-shadow: 0px 20px 20px -10px #26394d7b, inset 30px -10px 20px -10px #26394d7b, inset -25px 20px 30px -35px #ffffffbb;
}

.offerButton {
  position: relative;
  overflow: hidden;
}



.offerButton .loading-bubbles {
  display: none;
}

.offerButton.loading .button-text {
  visibility: hidden;
}

.offerButton.loading .loading-bubbles {
  display: flex !important;
}