/*------------------------------Navbar erster Abschnitt------------------------------*/
body {
    margin: 0;
    font-family: Arial, sans-serif;
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* Höhe des Viewports mindestens 100% */
    background-color:aliceblue;

    
}

/* Stile für den Header */
.header {
    flex-shrink: 0; /* Verhindert, dass die Höhe verkleinert wird */
    
}

/* Nur Navbar-Container breiter machen */
.navbar .container {
  max-width: min(100%, 1600px);
}


/* Für kleine Geräte: wieder normal */
@media (max-width: 991px) {
  .navbar .container {
    max-width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
  }
}


.navbar-collapse.show {
  max-height: 80vh;      /* Menü max. 80 % der Bildschirmhöhe */
  overflow-y: auto;       /* Scrollbar aktivieren */
}
/*------------------------------Navbar1------------------------------*/

.fixed-top{
    padding: 20px 10px 20px 10px;
    background: linear-gradient(135deg, rgba(0, 20, 40, 1) 0%, rgba(10, 40, 80, 1) 50%, rgba(0, 10, 30, 1) 100%);
    background-size: cover;
    height: auto;
}

.logo {
  width: 200px;
  height: 80px;
  background-image: url("../media/bilder/toowie-original-logo.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  background-color: transparent;
}

.subpage .logo:hover {
  background-image: url("../media/bilder/toowie-original-logo-weiss.svg");
  background-size: contain;
}



/*------------------------------Navbar1 Schrift rechts------------------------------*/
.fixed-top .navbar-nav li a{
    font-size: 19px;
    color: white !important;

}

.fixed-top .navbar-nav li a:hover{
    color: #C69A57 !important;
}


.ml-auto {
    margin-left: auto !important;
}

/*------------------------------Navbar2------------------------------*/
#main-bar{
    width: 100%;
    height: 70px;
    top: 120px;
    align-items: center;
    z-index: 20;
    position: fixed;
    background-color: rgba(0, 20, 40, 0.8); /* Leicht transparente Hintergrundfarbe */    
}



@media (max-width: 767.98px) {
    #main-bar {
        display: none;
    }
}


/* Standardmäßig anzeigen */
.hidden-nav-lg {
    display: list-item;
}

/* Bei einer Auflösung unter 768px ausblenden */
@media (min-width: 767.98px) {
    .hidden-nav-lg {
        display: none;
    }
}


/*------------------------------Navbar2 Schrift------------------------------*/
#main-bar .nav-item {
    margin-left: 10px;
    font-size: 17px;
    
}


.navbar-it-dienstleister{
    margin-left: auto;
    margin-right: auto;
    font-size: 30px;
    padding-right: 230px;
     color: #c9842a;
text-shadow: 
    0.5px 0.5px 0 #8a5b1a,   /* ganz leicht dunkler Schatten */
    -0.5px -0.5px 0 #e6b877; /* dezenter heller Glanz */

  }

  #datev-html .navbar-it-dienstleister {
  padding-right: 180px;
}



.navbar-wir-wachsen-mit{
    font-size: 25px;
    margin-right: 10px;
    margin-top: 10px;
    color: rgba(16, 78, 139); /* Textfarbe */

}

.nav-item .nav-link[href="#"] {
    color: rgba(16, 78, 139); 
}



/*-------------Lösungen als Dropdown-------------*/

/* Container für die Dropdown-Gruppen */
.dropdown-content {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: rgba(255, 255, 255, 0.95);
    padding: 15px;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Leichter Schatten */
    gap: 20px;  /* Abstand zwischen den Blöcken */
}

/* Technische Unterstützung Block */
.dropdown-technische-unterstuetzung {
    color: black;
    font-weight: bold;
    font-size: larger;
    list-style: none;
    padding-right: 30px;
    padding-left: 15px;
}

/* Vertikale Linie zwischen den Blöcken */
.dropdown-technische-unterstuetzung:first-child {
    border-right: 2px solid #ccc;  /* Grauer Strich als Trennung */
    padding-right: 30px;  /* Zusätzlicher Abstand durch den Strich */
}

/* Header-Stil für die Kategorien */
.dropdown-header {
    text-decoration: underline;
    font-size: larger;
    display: block;
    margin-bottom: 10px;
    color: rgba(16, 78, 139); 
}

/* Dropdown-Listen-Gruppen */
.dropdown-group {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Dropdown-Items */
.dropdown-item {
    font-size: large;
    padding: 10px;
    text-decoration: none;
    color: rgba(16, 78, 139); 
    display: block;
    transition: background-color 0.3s ease, font-weight 0.3s ease;
}

.dropdown-item:hover {
    background: linear-gradient(135deg, rgba(0, 20, 40, 1) 0%, rgba(10, 40, 80, 1) 50%, rgba(0, 10, 30, 1) 100%); 
    color: white;      
    border-radius: 5px;
   
}

.show {
    display: flex;
}


.lösungen-row {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 10px;
    gap: 10px;
}

/* Beide Blöcke nehmen exakt 50% des Platzes */
.lösungs-block {
    background-color: rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    padding: 12px;
    width: 50%;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-sizing: border-box;
}

/* Gelbe fette Überschrift */
.lösungs-header {
    font-weight: bold;
    font-size: 18px;
    color: #C69A57;
    margin-bottom: 10px;
}


.text-gold {
    color: #C69A57;
}
.text-gold-weisser-hintergrund{
  color: #c9842a;
}

/* Dropdown-Items ein wenig einrücken */
.lösungs-block .dropdown-item {
    padding-left: 10px;
}


/*------------------------------Main-Area------------------------------*/



.view{
  position:relative;
  min-height:110vh;
  background:url("../media/bilder/operational.png") no-repeat center;
  background-size:cover;
  background-position:center 80px;
  background-attachment:fixed;
  position: relative;
}


@media(max-width: 767.98px){
    .view{
        min-height: 70vh;
        background: url("../media/bilder/operational.png") no-repeat center;
        background-size: cover;
        background-attachment: fixed;
    
    }

}

.hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .55);
  z-index: 5;                     
}


/*-----------------Hero-Toowie------------------------------
:root {
  --octa-size: 18.75rem;   
   --overlap: -1.375rem;   
  --env-size: 9rem;      
    --line: rgba(255,255,255,.55);
}


.octagon-overlay {
  position: absolute;
  top: 60%;
  left: 63%;
  transform: translate(-50%, -50%) scale(0.95);
  transform-origin: center center;
  z-index: 10;
  text-align: center;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 4rem;
  border-radius: 1.5rem;
  transition: transform 0.3s ease;
}


.octa-graph {
  position: relative;
  width: 90vw;       
  max-width: 900px; 
  aspect-ratio: 3 / 2; 
  margin: 0 auto;
  overflow: visible;  
}


.octa-pair {
  position: absolute;
  top: 84%;
  left: 25%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.octa {
  clip-path: polygon(
    30% 0%, 70% 0%,
    100% 30%, 100% 70%,
    70% 100%, 30% 100%,
    0% 70%, 0% 30%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  color: #fff;
  text-decoration: none;
  width: var(--octa-size);
  height: var(--octa-size);
  font-size: 1.5rem;
  margin: 0 var(--overlap);
}

.octa.technical { background: rgba(16,78,139,.78); }
.octa.operational { background: rgba(198,154,87,.8); }

.or-badge {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  padding: .45rem .75rem;
  font-weight: 900;
  font-size: 1rem;
  color: #fff;
  background: rgba(0,0,0,.65);
  border-radius: 999px;
  z-index: 3;
}


.env-bus {
  position: absolute;
  top: 13%;
  left: 56.5%;
  --env-angle: 45deg;
}

.env-nodes {
  width: 100%;   
  display: flex;
  justify-content: center;
  align-items: center;
  transform: rotate(var(--env-angle));
}


.octa.env-node {
  width: var(--env-size);
  height: var(--env-size);
  font-size: .95rem;
  background: rgba(58, 125, 42,.75);
  text-shadow: 0 1px 3px rgba(0,0,0,.35);
  transform: rotate(calc(-1 * var(--env-angle)));
  position: relative;
}

.env-line {
  position: relative;
  width: 90px;
  height: 0.55rem;
}

.env-line::before {
  content: "";
  position: absolute;
  width: 53%;   
  height: 100%;
  background: var(--line);
  left: 50%;
  transform: translateX(-50%);
}


.line-vertical1 {
  position: absolute;
  left: 10.85%;
  top: 1.66%;
  transform: translateX(-50%);
  width: 0.5rem;
  height: 57.4%;
  background: var(--line);
}

.line-horizontal1 {
  position: absolute;
  bottom: 95.67%;
  left: 11.25%;
  width: 49%;
  height: 0.5rem;
  background: var(--line);
  transform: translateY(-0.5rem);
}


.line-vertical2 {
  position: absolute;
  left: 39.2%;
  top: 24.3%;
  transform: translateX(-50%);
  width: 0.5rem;
  height: 34.7%;
  background: var(--line);
}

.line-horizontal2 {
  position: absolute;
  bottom: 73.02%;
  left: 39.64%;
  width: 35.53%;
  height: 0.5rem;
  background: var(--line);
  transform: translateY(-0.5rem);
}

--------------------*/

/*-----------------Wir_wachsen_mit-ausblenden+IT-Dienstleister-Nach_rechts------------------------------*/
@media screen and (max-width: 1400px) {
    .navbar-wir-wachsen-mit {
        display: none;
    }

    .navbar-it-dienstleister {
        margin-left: auto;
        margin-right: 0; /* Entfernt das zentrierte Styling */
        text-align: right; /* Positioniert den Text rechtsbündig */
        padding-right: 20px; /* Optional: fügt etwas Abstand zum rechten Rand hinzu */
    }

    #datev-html .navbar-it-dienstleister {
        margin-left: auto;
        margin-right: 0; /* Entfernt das zentrierte Styling */
        text-align: right; /* Positioniert den Text rechtsbündig */
        padding-right: 20px; /* Optional: fügt etwas Abstand zum rechten Rand hinzu */
    }
}

@media screen and (max-width: 767.98px) {
    .navbar-it-dienstleister{
        display: none;
    }
    .navbar-nav {
        margin-left: 0 !important;
        margin-right: auto !important;
    }

    .navbar-collapse {
        margin-top: 20px; /* Abstand nach unten */
    }

}




/*---------------------------------index - Unsere_Leistungen--------------------------------------------*/
/* Dienstleistungen / Unsere Leistungen */
.technical-section,
.operativ-section {
    padding: 60px 0;

}

.technical-section h2,
.operativ-section h2 {
    text-align: center;
    font-size: 2.5rem;
    color: #104e8b;
    margin-bottom: 40px;
}

.services-grid {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}


.service-item {
    display: flex;
    flex-direction: column;
    justify-content: end;   /* Vertikal zentrieren */
    align-items: center;       /* Horizontal zentrieren */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    width: 300px;
    min-height: 300px;
    position: relative;
    text-align: left; /* Behalte linksbündigen Text */
    transition: transform 0.5s ease-in-out, background-size 0.3s ease-in-out, background-position 0.3s ease-in-out;
}




.text-background {
    background-color: rgba(0, 0, 0, 0.7); /* Grauer Streifen */
    padding: 10px; /* Abstand um den Text */
    border-radius: 5px; /* Optionale abgerundete Ecken */
    color: white; /* Textfarbe */
}



/* Entferne die Pseudo-Klasse ::before */
.service-item img {
    width: 80px;
    height: 80px;
    margin-bottom: 20px;
}


/* Stellt sicher, dass der Text über dem Overlay angezeigt wird */
.service-item h3,
.service-item p {
    text-align: center;
    z-index: 2; /* Text wird über dem Overlay angezeigt */
    color: #fff; /* Weißer Text bleibt sichtbar */
}

.service-item h3 {
    margin-bottom: 20px; /* Abstand zwischen Überschrift und dem Rest */

}

.service-item p {
    width: 100%;      /* Stellt sicher, dass der Text nicht zu schmal ist */
    margin: 0;        /* Entfernt unerwünschte Margen */
}


.service-item:hover {
    transform: scale(1.05); /* Vergrößert das gesamte Element */
    background-position: center 20%; /* Verschiebt das Bild leicht nach oben */
    cursor: pointer; /* Ändert den Mauszeiger zu einer Hand */
}


/* Animation des Hintergrundbildes für einen coolen Effekt */
.service-item:hover::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: inherit; /* Nutzt das Hintergrundbild */
    background-position: center;
    z-index: 2;
    border-radius: 10px;
    
}
.clickable-background {
    position: absolute; /* Erlaubt es, den Link über dem Inhalt zu positionieren */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 5; /* Stellt sicher, dass der Link über anderen Inhalten liegt */
    display: block; /* Stellt sicher, dass der Link den gesamten Raum einnimmt */
}



/* Spezifische Hintergrundbilder für die Leistungen */
.cloud {
    background-image: url('../media/bilder/cloud.png'); /* Bild für datev */
}

.it-sicherheit {
    background-image: url('../media/bilder/it-sicherheit-octagon.png'); /* Bild für datev */
}

.managed-service {
    background-image: url('../media/bilder/managed-service-octagon.png'); /* Bild für Managed-Service */
}

.it-infrastruktur {
    background-image: url('../media/bilder/it-infrastruktur-octagon.png'); /* Bild für IT-Infrastruktur */
}


.datev-fuer-stb {
    background-image: url('../media/bilder/datev-fuer-steuerberater.png'); /* Bild für datev */
}

.datev-fuer-ra {
    background-image: url('../media/bilder/datev-fuer-rechtsanwaelte.png'); /* Bild für datev */
}

.zukunftssichere-it {
    background-image: url('../media/bilder/zukunftssicher-it.png'); /* Bild für datev */
}



/*---------------------------------Octagon_Technical+Operative--------------------------------------------*/

.main-small, .main-large {
    padding-top: 50px;
    padding-bottom: 50px;
    background-color: white;
}


/*--------Text-Container--------*/
.text-container {
    color: rgba(16, 78, 139); 
    display: flex;
    justify-content: space-between;
    gap: 20px;

}

.text-container-technisch,
.text-container-operativ{
    width: 100%;
    margin-left: 7vh;
    margin-right: 7vh;
}


.text-container h2 {
    font-family: 'Arial', sans-serif; 
    font-size: 3rem; 
    text-align: center;
    color: rgba(16, 78, 139); 
    text-shadow: 2px 4px 6px rgba(16, 78, 139, 0.2); 
    border-bottom: 3px solid rgba(16, 78, 139, 0.6); /* Blaue Linie unter der Überschrift */
}


.text-container p {
    font-family: 'Arial', sans-serif; /* Schriftart für Absätze */
    font-size: 1.25em; /* Größere Schriftgröße */
    color: rgba(16, 78, 139); /* Textfarbe */
    line-height: 1.8; /* Erhöhter Zeilenabstand für bessere Lesbarkeit */
    margin-bottom: 15px; 
    margin-top: 30px;
    text-align: center;


}

.text-container p strong {
    font-weight: bold; 
}




/*--------Octagon-Container--------*/

    .octagon-container {
        display: flex;
        justify-content: space-between; /* Sorgt für gleichen Abstand zwischen den Containern */
        gap: 5%; /* 5% Abstand zwischen den beiden Containern */
        margin: 0 auto;
        padding: 20px; /* Optional: zusätzlicher innerer Abstand */
        max-width: 100%; /* Begrenzt die Container-Breite auf 100% */
    }


.octagon-container-technisch,
.octagon-container-operativ{
    width: 40%; /* Halbierte Größe */
    max-width: 300px;
    min-width: 300px;
    margin: 0 auto; /* Zentriert den Container */
    border-radius: 5%;
    overflow: hidden; /* Verhindern, dass der Schatten den Inhalt überlappt */
    transition: box-shadow 0.3s ease; /* Hinzufügen einer Übergangseffekt auf den Schatten */
    z-index: 1;

  }
  
  .operativ-octagon-container,
  .technisch-octagon-container {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom:100%;
    clip-path: polygon(
      30% 0%,
      70% 0%,
      100% 30%,
      100% 70%,
      70% 100%,
      30% 100%,
      0% 70%,
      0% 30%
    );
  }

  .text-overlay-red {
    position: absolute;
    bottom: 35%;
    left: 50%;
    transform: translateX(-50%);
    background-color: rgba(167, 28, 28, 0.85); /* kräftigeres Rot, etwas weniger transparent */
    padding: 15px 40px;
    border-radius: 8px;
    font-size: 1.6rem; /* größer */
    font-weight: bold;
    color: white;
    text-align: center;
    white-space: nowrap; /* Verhindert Zeilenumbruch */
    z-index: 3;
}

.text-overlay-green {
    position: absolute;
    bottom: 35%;
    left: 50%;
    transform: translateX(-50%);
    background-color: rgba(35, 167, 28, 0.85); /* kräftigeres Rot, etwas weniger transparent */
    padding: 15px 40px;
    border-radius: 8px;
    font-size: 1.6rem; /* größer */
    font-weight: bold;
    color: white;
    text-align: center;
    white-space: nowrap; /* Verhindert Zeilenumbruch */
    z-index: 3;
}

.schild-stiel {
    width: 15px;
    height: 180px;
    background-color: #104e8b; /* gleiche Farbe wie der Button */
    margin: 0 auto;
    margin-top: -5px;
    border-radius: 3px;
    z-index: 2;
}


  .operativ-octagon-container img,
  .technisch-octagon-container img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    transition: transform 0.5s;
    cursor: pointer; /* Ändern Sie den Mauszeiger, um anzuzeigen, dass das Bild klickbar ist */
  }
    
  .technisch-octagon-ueberschrift,
  .operativ-octagon-ueberschrift {
    text-align: center;
    font-size: 1.5rem;
    height: auto;
    font-weight: bold;    
    padding-top: 15px;
    padding-left: 20px;
    padding-right: 20px;  
    color: rgba(16, 78, 139); /* Textfarbe */
  }



/*--------Button-Container--------*/

.button-container{
    display: flex;
    justify-content: space-around;
    margin: 0 auto;
    gap: 5%; /* 5% Abstand zwischen den beiden Containern */
    padding: 20px; /* Optional: zusätzlicher innerer Abstand */
    max-width: 100%; /* Begrenzt die Container-Breite auf 100% */
    margin-top: -45px;
    z-index: 1;
}


.button-technisch, 
.button-operativ {
    display: inline-block;
    font-family: 'Arial', sans-serif; 
    font-size: 1.125em; 
    color: #fff; 
    background-color: rgb(16, 78, 139); 
    padding: 15px 20px; 
    border-radius: 5px; 
    text-decoration: none; /* Kein Unterstrich */
    transition: background-color 0.3s ease, transform 0.3s ease; /* Übergangseffekte */
    margin: 0 auto;    
}


.button-technisch:hover, 
.button-operativ:hover {
    background-color: rgb(16, 78, 139); 
    transform: scale(1.05); /* Vergrößert den Button leicht beim Hover */
}

.button-technisch:focus, 
.button-operativ:focus {
    outline: 2px solid;
}



/*--------Unter-135767px-geschieht-folgendes--------*/

/* Standardmäßig wird das Layout für große Bildschirme angezeigt */
.main-large {
    display: block; /* Sichtbar */
}

.main-small {
    display: none; /* Unsichtbar */
}


@media (max-width: 1135px) {
    .main-large {
        display: none; /* Versteckt das Layout für große Bildschirme */
    }

    .main-small {
        display: block; /* Zeigt das Layout für kleine Bildschirme */
    }
    .text-container-operativ{
        margin-top: 100px;
    }
}

@media(max-width: 769px){
    .text-container-technisch,
    .text-container-operativ{
        width: 100%;
        margin-left: 2vh;
        margin-right: 2vh;
    }
}

  /*---------------------------------Geschäftsführer--------------------------------------------*/

  .geschaeftsfuehrer{
    background: linear-gradient(135deg, rgba(0, 40, 80, 0.5) 0%, rgba(16, 78, 139, 0.8) 50%, rgba(0, 40, 80, 0.5) 100%);
  }

  .card{
    margin-top: 3.3rem;
}

  .card-img-top {
    border-radius: 0.5rem 0.5rem 0 0;
}

.card-body {
    text-align: start;
    color: rgba(16, 78, 139); /* Textfarbe */
}

.contact-info {
    margin-top: 1rem;
}

.card-container {
    display: flex;
    align-items: flex-start;
    flex-wrap: nowrap;
}

.card-wrapper {
    flex: 0 0 350px; /* Fixed width for the card */   
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 50px), calc(100% - 50px) 100%, 0 100%);
}


.text-wrapper {
    border-radius: 20px; /* Leichte Abrundung für modernere Optik */
    color: white; /* Textfarbe */
    max-width: 800px; /* Maximale Breite für bessere Lesbarkeit */
    margin: 40px auto; /* Zentrierung und Abstand von anderen Elementen */
    font-family: 'Arial', sans-serif; /* Saubere, professionelle Schrift */
    padding-left: 20px;
    
}

@media(min-width: 1399.1px){
    .hrcustom{
        display: none;
    }
}

@media(max-width: 1399px){
    .card-container{
        flex-wrap: wrap;
    }

    .card-container{
        justify-content: center;
    }

    .hrcustom{
        margin: 1rem 0;
        color: inherit;
        border: 0;
        border-top: var(--bs-border-width) solid;
        opacity: 1.50;
    }
    .text-wrapper {
padding-left: 2vh;
padding-right: 2vh;        
    }
       
}


.text-wrapper h2 {
    color: white;
    font-size: 2.5rem; /* Größere Schrift für die Überschrift */
    margin-bottom: 20px; /* Abstand zur nächsten Zeile */
    text-align: center; /* Zentrierung der Überschrift */
 
}

.text-wrapper p {
    font-size: 1.0rem; /* Angenehme Schriftgröße für Lesbarkeit */
    line-height: 1.8; /* Erhöhter Zeilenabstand für bessere Lesbarkeit */
    color: white;
}

.text-wrapper p strong {
    font-weight: bold; /* Fettgedruckte Schrift für Hervorhebungen */
    color: rgba(16, 78, 139); /* Textfarbe */
}



.card-icon{
    padding-right: 5px;
}




/*---------------------------------Kontaktformular--------------------------------------------*/

.kontaktformular-ueberschrift{
margin-top: 50px;
color: rgba(16, 78, 139); 
margin-bottom: -20px;
padding-bottom: 0px;
font-size: 2.5rem; /* Größere Schrift für die Überschrift */
font-weight: bold;
text-align: center; /* Zentrierung der Überschrift */
}

.container{
    color: rgba(16, 78, 139); /* Textfarbe */
    
  }


  .btn{
    background-color: rgb(16, 78, 139); 
  }

  /*------Nur in Kombination mit HTML Style möglich gewesen------*/
  textarea::placeholder,
  input::placeholder {
    color: rgba(16, 78, 139)!important; /* Blau für den Platzhaltertext*/
  }

  .nachricht-erfolgreich-versand{
    margin-top: 50px;
    color: rgb(16,78,139);
    font-size: 2.5rem;
    font-weight: bold;
    text-align: center;
  }
  .nachricht-fehlerhaft{
    margin-top: 50px;
    color: rgb(230,0,0);
    font-size: 2.5rem;
    font-weight: bold;
    text-align: center;
  }

/*---------------------------------Footer--------------------------------------------*/


.nav {
    --bs-nav-link-color: unset; /* (AGB, Datenschutz und Impressum) weiß  */
}

.nav-link{
  color: rgba(16, 78, 139);
}

.nav-link:hover {
    color: white;
    border-radius: 5px;
}

.nav-link-footer{
  color: white;
}
.nav-link-footer:hover {
    color: #C69A57 !important;
    border-radius: 5px;
}

.nav-link-background:hover {
    background: linear-gradient(135deg, rgba(0, 20, 40, 1) 0%, rgba(10, 40, 80, 1) 50%, rgba(0, 10, 30, 1) 100%);
    transition: background 0.3s ease, border-radius 0.2s ease;
    border-radius: 5px;
}




.nav-link li a:hover {
    text-decoration: underline;
}


.footer-toowie{
    font-size: 20px;
}

  
.container-footer {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4%;
  }

  .footer{
    background: linear-gradient(135deg, rgba(0, 20, 40, 1) 0%, rgba(10, 40, 80, 1) 50%, rgba(0, 10, 30, 1) 100%);
    color: white;

  }
  
/*---------------------------------Das ist Toowie / Gewusst wie / Service--------------------------------------------*/
  .footer-unternehmensprofil-toowie {
    justify-content: flex-start;
  }

  
  .footer-unternehmensprofil-toowie,
  .footer-gewusst-wie,
  .footer-service {
    text-align: left;
    margin-top: 2%;
  }

  @media(max-width: 580px){
    .footer-gewusst-wie{
        display: none;
    }

  }

  .footer-unternehmensprofil-toowie ul a,
  .footer-gewusst-wie ul a,
  .footer-service ul a{
    font-weight: bold;
    color:white;
    font-size: 1.5rem;
    margin-bottom: 4%;
  }
  
  .footer-unternehmensprofil-toowie section li,
  .footer-gewusst-wie section li,
  .footer-service section li {
  list-style: none;
  margin-top: 4%;
  color: white;

  }
  
  .footer-unternehmensprofil-toowie section li a,
  .footer-gewusst-wie section li a,
  .footer-service section li a{
    text-decoration: none;
    color: white;
  }



  
/*----------------Map----------------*/
.address-container {
    display: flex;
    align-items: center; /* Vertikal zentrieren */
}


.address-container i {
    margin-right: 20px; /* Platz zwischen dem Symbol und dem Text */
}

.address-container a {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
}


.address-text {
    display: flex;
    flex-direction: column; /* Text in zwei Zeilen */
    line-height: 1.5; /* Zeilenabstand für bessere Lesbarkeit */
}

/*----------------Kontaktdaten----------------*/
.kontaktdaten {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
}

.kontaktdaten i {
    margin-right: 10px; /* Platz zwischen dem Symbol und dem Text */
}

.kontaktdaten:hover {
    text-decoration: underline;
}

/*---------------------------------Tobias Meyer--------------------------------------------*/
  .text-center{
    margin-bottom: 0;
    padding-bottom: 15px
  }


  /* =========================================== >> Über uns << =============================================== */
/* ===== PCB HERO ===== */
.pcb-hero {
  position: relative;
  min-height: calc(100vh - 160px);
  display: grid;
  place-items: center;
  padding: 8rem 2rem 4rem;
  /* Blau wie zuvor */
  background: radial-gradient(1200px 600px at 70% 30%, rgba(0,40,80,.35), transparent 60%),
              linear-gradient(135deg, rgba(0, 20, 40, 1) 0%, rgba(10, 40, 80, 1) 50%, rgba(0, 10, 30, 1) 100%);
  overflow: hidden;
  color: #fff;
}
.pcb-hero__svg{ position:absolute; inset:0; width:100%; height:100%; }

/* Kupfer-Leiterbahnen */
.pcb-hero__traces path,
.pcb-hero__traces-path {
  fill: none;
  stroke: #c69a57;            /* Kupfer/Gold */
  stroke-width: 3;
  stroke-linecap: butt;
  stroke-linejoin: bevel;
}

/* Pads */
.pcb-hero__pads circle,
.pcb-hero__pad-oct {
  fill: #c69a57;              /* Kupfer */
}
.pcb-hero__pads .hole {       /* Bohrung für Through-Hole */
  fill: rgba(0, 20, 40, 1);
}

/* Silkscreen (weißer Text für "Toowie") */
.pcb-hero__silk-text {
  fill: #eaf2f2;
  font: 800 132px/1 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: .5px;
}

/* Fahrendes Bit */
.pcb-hero__bit{ fill:#fff; transition:transform .2s ease; }
.pcb-hero__bit--idle{ animation: pcbPulse 1.6s ease-in-out infinite; }
@keyframes pcbPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.25)} }

/* Copy-Box */
.pcb-hero__copy{
  position: relative; z-index: 2; text-align: left; max-width: 820px;
  padding: 1rem 1.25rem; background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.18); border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25); backdrop-filter: blur(3px);
}
.pcb-hero__headline{ margin:0 0 .25rem; font-size:clamp(2.2rem,4.5vw,4rem); font-weight:800; letter-spacing:.3px; }
.pcb-hero__sub{ margin:0 0 1rem; font-size:clamp(1.05rem,1.5vw,1.35rem); color:rgba(255,255,255,.85); }
.pcb-hero__cta{
  display:inline-block; margin-top:.25rem; padding:.75rem 1.1rem; border-radius:10px;
  text-decoration:none; background:rgb(16,78,139); color:#fff; font-weight:700;
  transition:transform .2s ease, box-shadow .2s ease;
}
.pcb-hero__cta:hover{ transform:translateY(-2px); box-shadow:0 10px 18px rgba(0,0,0,.25); }

/* Mobile */
@media (max-width:768px){
  .pcb-hero{ min-height:70vh; padding:6.5rem 1rem 3rem; }
  .pcb-hero__copy{ text-align:center; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .pcb-hero__bit, .pcb-hero__bit--idle{ animation:none !important; }
}



  /* =========================================== >> IMPRESSUM / AGB / Datenschutz << =============================================== */

.rechtsseite-section h1{
    padding-top: 14rem;
}

/* Ab 768px: Padding wieder entfernen */
@media (max-width: 768px) {
    .rechtsseite-section h1{
        padding-top: 0;
    }
}


.small-text {
    font-size: 0.9rem; /* oder z.B. 14px */
}


.text-right{
 text-align: right;
}


/*------------PDF Button------------------*/

.pdf-download-wrapper {
  text-align: center;
  margin-top: 2rem;
  margin-bottom: 2rem; /* Für Abstand zum unteren Rand */
}

.pdf-button {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

.pdf-button i {
  color: #dc3545;
  transition: transform 0.2s ease, color 0.2s ease;
}

.pdf-button:hover i {
  transform: scale(1.15);
  color: #a71d2a;
}


.pdf-column {
  flex: 2 1 0%;                 
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 200px;            
}


/*-------------------------*/

.contact-table {
  font-size: 0.95rem;
  border-collapse: collapse;
  margin-left: 0 auto;
}

.contact-table td {
  padding: 0.2rem 0.5rem;
  vertical-align: top;
}

.contact-table .label {
  font-weight: bold;
  text-align: left;
  white-space: nowrap;
}

.contact-table .colon {
  width: 1rem;
  text-align: center;
}

.contact-table .heading {
  font-weight: bold;
  padding-bottom: 0.8rem;
  text-align: left;
  font-size: 1.2rem;
  letter-spacing: 0.5px;
}


.contact-mobile {
  display: none;
  text-align: center;
}


/* Damit das ab 400px auch noch gut aussieht wird die linke Spalte entfernt */

@media (max-width: 400px) {
  .info-flex-container {
    flex-direction: column;
    align-items: center;
  }

  .contact-table .label,
  .contact-table .colon {
    display: none;
  }

  .info-flex-container,
  .table-column,
  .contact-table {
    margin: 0;
    padding: 0;
  }

  .table-column {
    min-width: 0 !important;
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .contact-table {
    width: 100%;
    text-align: center;
    margin: 0 auto;
  }


  .contact-table td {
    text-align: center;
    padding: 0;
  }


  .contact-table .heading {
    text-align: center;
  }
}



/* Damit sich das ab 538px zentriert */

@media (max-width: 538px) and (min-width: 401px) {
  .table-column {
    display: flex;
    justify-content: center;
  }

  .contact-table {
    text-align: center;
  }

  .contact-table td {
    text-align: center;
  }

  .contact-table .heading {
    text-align: center;
  }
}



.contact-table a {
  color: #104e8b;
  text-decoration: none;
  font-weight: 500;
  transition: color 0.3s ease, text-decoration 0.3s ease;
}

.contact-table a:hover {
  color: #0c3c6e;
  text-decoration: underline;
}





/* Etwas kleiner für Mobile */
.contact-mobile p {
  margin: 0.25rem 0;
  font-size: 0.95rem; 
}


.info-flex-container {
  display: flex;
  flex-wrap: wrap;             
  margin-top: 3rem;
  margin-bottom: 3rem;
}


.table-column {
  flex: 1 1 0%;                 
  min-width: 250px;           
}


/* ======================= DATEV Auswahlbereich =================*/


.datev-hero {
  margin-top: calc(120px + 70px);
  width: 100vw;
  height: auto;
  background: radial-gradient(circle at 45% 45%, #0a3c78 0%, #002850 30%, #001428 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  
}

@media (max-width: 767.98px) {
  .datev-hero {
    margin-top: 113px;
  }
}





.datev-container {
  margin-top: 20px;
  width: 60rem;          /* zoomfähig */
  height: 65rem;         /* beliebig anpassen */
  margin: 1vh auto;
  aspect-ratio: 16 / 9;
  position: relative;
  container-type: size;
  top: 10%;
}


@media (max-width: 770px) {
.datev-container{
  width: 45rem;
  height: 50rem;
}

}


@media (max-width: 500px) {
  .datev-container{
  width: 22rem;
  height: 25rem;
}
}





/* ================== DATEV WOLKE ================== */

.datev-wolke {
  position: absolute;
  top: 12cqh;
  left: 0cqw;
  transform: translateX(-50%);
  filter:
    drop-shadow(0 0 0.35cqh rgba(255,255,255,0.8))
    drop-shadow(0 0 0.9cqh rgba(220,232,244,0.35));
  z-index: 5;
}


.datev-wolke-kreis {
  position: absolute;
  background: white;
  border-radius: 50%;
  /* vorher: filter: blur(0.18cqh) brightness(1.03); */
  filter: none;              /* wichtig */
}



/* Obere Wolkenreihe */
/* Obere Wolkenreihe */
.c1  { width: 15cqw; height: 12cqh;  top: -1cqh; left: 0cqw; }
.c2  { width: 20cqw; height: 15cqh;  top: -4.5cqh; left: 8cqw; }
.c3  { width: 17cqw; height: 9cqh;  top: -5cqh; left: 23cqw; }
.c4  { width: 18cqw; height: 15cqh; top: -8cqh; left: 35cqw; }
.c5  { width: 24cqw; height: 17cqh; top: -10cqh; left: 42cqw; }
.c6  { width: 12cqw; height: 13cqh; top: -7cqh; left: 60cqw; }
.c7  { width: 12cqw; height: 17cqh; top: -7cqh; left: 64cqw; }
.c8  { width: 14cqw; height: 15cqh; top: -7cqh; left: 70cqw; }
.c9  { width: 18cqw; height: 15cqh;  top: -5cqh; left: 77cqw; }
.c10 { width: 13cqw; height: 14cqh;  top: -2cqh; left: 86.8cqw; }

/* Untere Wolkenreihe – neue Kreise */
/* Untere Wolkenreihe (neu) */
.c11 { width: 15cqw; height: 10cqh;  top: 2.4cqh; left: 22cqw; }
.c12 { width: 13cqw; height: 11cqh;  top: 2.8cqh; left: 30cqw; }
.c13 { width: 15cqw; height: 12cqh;  top: 3.2cqh; left: 40cqw; }
.c14 { width: 15cqw; height: 8.5cqh; top: 3.0cqh; left: 50cqw; }
.c15 { width: 17cqw; height: 12cqh;  top: 2.8cqh; left: 60cqw; }
.c16 { width: 15cqw; height: 13cqh;  top: 2.6cqh; left: 70cqw; }
.c17 { width:  17cqw; height: 12cqh; top: 2.4cqh; left: 78.8cqw; }


/*========Cloud-Schrift==========*/


/* === Schriftzug "DATEV Cloud" in der Wolke === */
.datev-cloud-title {
  position: absolute;
  top: -1.5cqh;             /* leicht oberhalb der Wolkenmitte */
  left: 50cqw;           /* exakt horizontal mittig */
  transform: translateX(-50%);
  font-family: 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
  font-weight: 700;
  font-size: 6cqw;     /* skaliert mit Containergröße */
  letter-spacing: 0.05em;
  white-space: nowrap;
  z-index: 12;
  text-align: center;
}

/* Farben */
.datev-cloud-title .datev-green {
  color: #00A77E; /* Offizielle DATEV-Farbe */
}

.datev-cloud-title .datev-bronze {
  color: #C69A57; /* Toowie-Bronze */
  margin-left: 0.4cqw;
}

/* sanftes Einblenden / Aufscheinen */
@keyframes fadeInCloudText {
  0%   { opacity: 0; transform: translateX(-50%) translateY(2cqh); }
  100% { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.datev-cloud-title {
  animation: fadeInCloudText 1.2s ease-out 0.3s forwards;
}




/*========Cloud-Linien==========*/


.cloud-line {
  position: absolute;
  width: 0.4cqw;
  background: linear-gradient(to top, #c69a57 0%, rgba(198,154,87,0.2) 100%);
  z-index: 4;
  pointer-events: none;
  overflow: visible; /* damit Ovale nicht abgeschnitten werden */
}

/* Zwei vertikale Ovale */
.cloud-line::before,
.cloud-line::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(50%);
  width: 0.4rem;      /* schmal */
  height: 1.2rem;      /* hoch = oval nach oben */
  background-color: #c69a57;
  border-radius: 50% / 35%;
  pointer-events: none;
}

/* 2 Impulse mit leichtem Versatz */
.cloud-line::before { animation: flowUp 2.5s linear infinite; }
.cloud-line::after  { animation: flowUp 2.5s linear 1.25s infinite; }

@keyframes flowUp {
  0%   { bottom: 0; opacity: 1; }
  100% { bottom: 100%; opacity: 0; }
}






/* ===== Linien-Positionen (angepasst an die cqw/cqh-Logik) ===== */

.cloud-line.left {
  left: 18cqw;
  top: 22cqh;
  height: 13cqh;
}

.cloud-line.center {
  left: 50cqw;
  top: 26.5cqh;
  height: 38.5cqh;
}

.cloud-line.right {
  left: 82cqw;
  top: 26cqh;
  height: 9cqh;
}

/*========Oktagon==========*/



/* ===== Positionierung der drei Oktagons ===== */
/* ============================= */
/* === OKTAGONS INTERAKTIV ===== */
/* ============================= */

/* Ganze Oktagons als klickbare Links */
.octagon-link {
  position: absolute;
  display: block;
  text-decoration: none;
  color: inherit;
  z-index: 3;
}

/* Basis der Oktagons (Position & Form hast du bereits definiert) */
.octagon-item-left,
.octagon-item-center,
.octagon-item-right {
  position: absolute;
  transform: translate(-50%);
  width: 36cqw;
  height: 36cqw;
  clip-path: polygon(
    30% 0%,
    70% 0%,
    100% 30%,
    100% 70%,
    70% 100%,
    30% 100%,
    0% 70%,
    0% 30%
  );
  z-index: 2;
  overflow: hidden;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  cursor: pointer;
}

/* Positionierung der drei Oktagons */
.octagon-item-left {
  top: 35cqh;
  left: 18cqw;
}

.octagon-item-center {
  top: 65cqh;
  left: 50cqw;
}

.octagon-item-right {
  top: 35cqh;
  left: 82cqw;
}

/* ===== Bild im Oktagon ===== */
.octagon-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.2s ease, box-shadow 0.2s ease;

}

/* ===== Inhalt (unterer Balken) ===== */
.octagon-content {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30%;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 0.5cqh;
  text-align: center;
  transition: background 0.4s ease;
  z-index: 3;
}

.octagon-content h2 {
  font-size: 3cqw;
  color: #c69a57;
  font-weight: 800;
  margin: 0;
  padding-top: 1cqw;
  text-shadow: 0 0.4cqh 0.8cqh rgba(0, 0, 0, 0.6);
  transition: color 0.3s ease;
}

/* ============================= */
/* === HOVER-EFFEKTE =========== */
/* ============================= */

.octagon-item-left:hover,
.octagon-item-center:hover,
.octagon-item-right:hover {
  transform: translate(-50%) scale(1.08); /* leichtes Herauszoomen */
  box-shadow: 0 0 3cqw #c69a57, 0 0 6cqw rgba(198,154,87,0.5);
  z-index: 4;
}

.octagon-item-left:hover .octagon-img img,
.octagon-item-center:hover .octagon-img img,
.octagon-item-right:hover .octagon-img img {
  transform: scale(1.1); /* Bild leicht vergrößern */
}

.octagon-item-left:hover .octagon-content,
.octagon-item-center:hover .octagon-content,
.octagon-item-right:hover .octagon-content {
  background: rgba(198,154,87,0.85); /* goldener Balken */
}

.octagon-item-left:hover h2,
.octagon-item-center:hover h2,
.octagon-item-right:hover h2 {
  color: #ffffff; /* Text wird weiß */
}







/* ======================= DATEV Info-Bereich (blau-weiß) ======================= */
.datev-info {
  /* sanfter Verlauf wie oben: hell → Toowie-Blau */
  background: linear-gradient(180deg, #ffffff 0%, #eaf1fa 35%, rgba(10, 40, 80, 0.92) 100%);
  padding: 60px 0 120px;
  color: #104e8b;
  position: relative;
  overflow: hidden;
}

/* Intro-Panel */
.datev-info-panel {
  background: #eaf1fa;                 /* helles Blau wie gewünscht */
  border: 1px solid rgba(16, 78, 139, .12);
  border-left: 6px solid #C69A57;      /* goldener Akzent */
  border-radius: 16px;
  padding: 28px 28px;
  margin-bottom: 36px;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
}

.datev-info-heading {
  margin: 0 0 6px 0;
  font-size: 1.9rem;
  font-weight: 800;
  letter-spacing: .3px;
  color: #104e8b;
}

.datev-info-lead {
  margin: 0;
  font-size: 1.06rem;
  color: rgba(0,0,0,.75);
  line-height: 1.6;
}

/* Drei Boxen */
.datev-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  margin-top: 22px;
}

.datev-info-card {
  background: #ffffff;
  border: 1px solid rgba(16, 78, 139, .08);
  border-top: 4px solid #C69A57;       /* dezenter Gold-Akzent pro Box */
  border-radius: 14px;
  padding: 22px 22px 24px;
  box-shadow: 0 6px 16px rgba(0,0,0,.10);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.datev-info-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 28px rgba(0,0,0,.18);
  border-color: #C69A57;
}

.datev-info-card h3 {
  margin: 0 0 8px 0;
  font-size: 1.25rem;
  font-weight: 800;
  color: #104e8b;
}

.datev-info-card p {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.65;
  color: rgba(0,0,0,.78);
}





