/* zain-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Zain';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/zain-v3-latin-200.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* zain-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Zain';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/zain-v3-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* zain-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Zain';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/zain-v3-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* zain-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Zain';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/zain-v3-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* zain-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Zain';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/zain-v3-latin-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* zain-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Zain';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/zain-v3-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}






/* montserrat-100 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 100;
  src: url('../fonts/montserrat-v31-latin-100.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/montserrat-v31-latin-200.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/montserrat-v31-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/montserrat-v31-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/montserrat-v31-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/montserrat-v31-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/montserrat-v31-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/montserrat-v31-latin-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* montserrat-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/montserrat-v31-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}




:root{
    --idr-green:#09632E; /* Primärgrün */
    --idr-green-2:#09632E; /* dunkler */
    --idr-light:#e8f2ec; /* helle Akzentfläche */
    --idr-beige:#f3f4e9; /* Sekundär-Hintergrund */
    --idr-brown:#C4D380; /* Sekundär-Hintergrund */
}

.row{
    --bs-gutter-x: 0rem !important;
}


body{scroll-behavior:smooth}

/* NAV */
.navbar{
    height: 100px;
}
@media (min-width: 992px){
    .navbar{
        height: 160px;
    }
}

.logo{
    width: 100px;
}
@media (min-width: 1200px){
    .logo{
        width: 175px;
    }
}

.nav-item{
    padding-inline-end: 20px;
}
.nav-link{
    font-family: 'Zain';
    font-size: xx-large;
    font-weight: 700;
    color: #09632f;
    line-height: 25px;
}
.btn-primary{
    font-family: 'Zain';
    font-weight: bold;
    font-size: x-large;
    background-color: #09632f;
    border-color: #09632f;
    color: #ffffff;
    border-radius: 8px 8px 8px 8px;
    height: auto;
    padding-left: 2rem;
    padding-right: 2rem;
}

.btn-primary:hover{
    background-color: #ffffff;
    color: #09632f;
    border-width: 1px;
    border-color: #09632f;
}

/* HERO */
.hero{
    position: relative;
    background: url('../img/foto_collage_768x709_xs.webp') top/cover no-repeat; /* ersetze Pfad */
    min-height: 706px;
    display: flex; 
    align-items:flex-end;
    color: #fff;
}
@media (min-width: 768px){
    .hero{
        background: url('../img/foto_collage_1200x709_lg.webp') top/cover no-repeat; /* ersetze Pfad */
    }
}
@media (min-width: 1200px){
    .hero{
        background: url('../img/foto_collage_1920x709_xl.webp') top/cover no-repeat; /* ersetze Pfad */
    }
}
.hero::after{ /* leichte Überblendung für bessere Lesbarkeit */
    content:""; 
    position:absolute; 
    inset:0; 
}
.hero-content{
    position:relative; 
    z-index:2; 
    padding:4rem 0
}
#btn-img{
    height: 18px;
    margin-right: 5px;
    margin-bottom: 2px;
}

#where-text-top{
    color: #09632EC9;
    font-family: 'Montserrat';
    font-weight: 700;
    font-size: 18px;
    line-height: 25px;
}
@media (min-width: 768px){
    #where-text-top{
    color: #09632EC9;
    font-family: 'Montserrat';
    font-weight: 700;
    font-size: 18px;
}
}

#top-h2{
    font-family: 'Zain';
    font-weight: 800;
    font-size: 60px;
    letter-spacing: 0.1px;
    line-height: 50px;
    color: #09632f;
}
@media (min-width: 992px){
    #top-h2{
        font-family: 'Zain';
        font-weight: 800;
        font-size: 70px;
        letter-spacing: 0.2px;
        line-height: 70px;
        color: #09632f;
    }
}

h1{
    font-family: 'Zain';
    font-weight: 800;
    font-size: 60px;
    letter-spacing: 0.1px;
    line-height: 50px;
    color: #09632f;
}
h2{
    font-family: 'Zain';
    font-weight: 800;
    font-size: 45px;
    line-height: 45px;
    color: #09632f;
}
#ueber-uns-h3{
    font-family: 'Zain';
    font-weight: bolder;
    font-size: 50px;
    line-height: 45px;
    color: #ffffff;
}
h3{
    font-family: 'Zain';
    font-weight: bold;
    font-size: 40px;
    line-height: 45px;
    color: #09632f;
}
h4{
    font-family: 'Zain';
    font-weight: 400;
    font-size: 35px;
    line-height: 45px;
    color: #09632f;
}
h5{
    font-family: 'Zain';
    font-weight: 300;
    font-size: 30px;
    line-height: 45px;
    color: #09632f;
}
h6{
    font-family: 'Zain';
    font-weight: bolder;
    font-size: 25px;
    line-height: 45px;
    color: #09632f;
}

.h6{
    font-family: 'Zain';
    font-weight: bolder;
    font-size: 25px;
    line-height: 45px;
    color: #09632f;
}

p{
    font-family: 'Montserrat';
    font-weight: 400;
    font-size: 15px;
    line-height: 22px;
}

.kontakt-liste{
    font-family: 'Montserrat';
    font-weight: normal;
    font-size: 12px;
    line-height: 20px;
    color: #ffffff;
    margin-top: -20px;
}
.card-text{
    font-family: 'Montserrat';
    font-weight: 600;
    font-size: 12px;
    line-height: 22px;
}
.infos-1{
    font-family: 'Montserrat';
    font-weight: 500;
    font-size: 15px;
    line-height: 22px;
}
.infos-2{
    font-family: 'Montserrat';
    font-weight: 500;
    font-size: 15px;
    line-height: 22px;
    color: #ffffff;
}
a.footer{
    font-family: 'Zain';
    font-weight: bolder;
    font-size: 20px;
    color: #09632f;
}
p.small{
    font-family: 'Montserrat';
    font-weight: 500;
    font-size: 15px;
    color: #09632f;
}

#top{
    padding-bottom: 2rem;
}

.top{
    font-family: 'Montserrat';
    font-weight: 500;
    font-size: 14px;
    line-height: 25px;
}

#besuch{
    color: #ffffff;
}

.team-img{
    width: 506px;
}
@media (min-width: 992px){
    .team-img{
        margin-top: -50px;
        margin-bottom: 80px;
    }
}

.team-text{
    margin-top: 0px;
    padding-right: 25px;
}
@media (min-width: 992px){
    .team-text{
        margin-top: 0;
    }
}

.image-box {
  position: relative;       /* wichtig, damit das Kind absolut positioniert werden kann */
  display: inline-block;    /* oder block, je nach Layout */
}
.text-overlay {
    position: absolute;
    transform: translate(-0%, -0%); /* genau in die Mitte */
    background: rgba(255, 255, 255, 0.8);   /* halbtransparenter Hintergrund */
    color: rgb(0, 0, 0);
    padding: 1rem;
    border-radius: 0.5rem;
    height: auto;
}

.text-overlay p {
    line-height: 20px;
}

#ueber-uns-text-top{
    color: #C4D280;
    font-family: 'Montserrat';
    font-weight: 700;
    font-size: 18px;
}

.ueber-uns-text{
    color: #ffffff;
    font-family: 'Montserrat';
    font-weight: 300;
    line-height: 30px;
    line-height: 30px;
}

.fullwidth {
    width: 100%;
    height: auto;       /* Höhe automatisch anpassen */
}
@media (min-width: 1200px){
    .fullwidth {
        width: 760px;
        height: auto;       /* Höhe automatisch anpassen */
    }
}


/* SECTION UTILS */
section#floating-buttons{
    padding-bottom: 0px;
    padding-top: 0px;
}

#ueber-uns{
    background-color: #09632E;
    padding-bottom: 0px;
}


#team-animation{
    transform: translate(54vw, 1rem);
    width: 265px;
    margin-top: -76px;
}
@media (min-width: 768px){
    #team-animation{
        transform: translate(58vw, 2rem);
        width: 328px;
    }
}
@media (min-width: 1200px){
    #team-animation{
        transform: translate(76vw, 4rem);
        width: 501px;
        margin-top: -177px;
    }
}

/* KACHELN */
#leistungen{
    background-color: #F9FDF2;
    padding-top: 6rem;
    padding-bottom: 4rem;
}
.idr-badge{
    height: 70px;
}
.service-card{
    height:420px;
    border:0;
    box-shadow:0 10px 24px rgba(0,0,0,.06);
    border-radius:0.5rem
}
.card-top-text{
    color: #09632f;
    font-family: 'Montserrat';
    font-weight: 800;
    font-size: 18px;
    line-height: 25px;
}


.service-card#unterdorf{
    height: 650px;
}
@media (min-width: 768px){
    .service-card#unterdorf{
        height:500px;
    }
}
@media (min-width: 992px){
    .service-card#unterdorf{
        height:680px;
    }
}
@media (min-width: 1200px){
    .service-card#unterdorf{
        height:420px;
    }
}

.service-card .card-body{
    padding:1.5rem
}

.box-1 {
  position: relative;
  height: 100%;
  background-color: #C4D380; /* bleibt vollständig undurchsichtig */
  overflow: hidden;
}

/* Halbtransparentes Hintergrundbild über ein Pseudo-Element */
.box-1::before {
  content: "";
  position: absolute;
  inset: 0; /* top:0; right:0; bottom:0; left:0 */
  background-image: url('/assets/img/fingerabdruck_teil2.png');
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: left;
  opacity: 0.5; /* <-- Nur das Bild ist halb durchsichtig */
  z-index: 0;
}
@media (min-width: 1200px){
    .box-1::before {
        opacity: 1; /* <-- Nur das Bild ist halb durchsichtig */
    }
}

/* Inhalt bleibt darüber sichtbar */
.box-1 > * {
  position: relative;
  z-index: 1;
}

.box-2 {
  position: relative;
  height: 100%;
  background-color: #09632E; /* bleibt vollständig undurchsichtig */
  overflow: hidden;
}

/* Halbtransparentes Hintergrundbild über ein Pseudo-Element */
.box-2::before {
  content: "";
  position: absolute;
  inset: 0; 
  background-image: url('/assets/img/abdruck.png');
  background-repeat: no-repeat;
  background-size: 26% auto;
  background-position: right;
  z-index: 0;
  margin-right: 3rem;
  margin-bottom: 10rem;
}
@media (min-width: 768px){
    .box-2::before {
        content: "";
        position: absolute;
        inset: 0; 
        background-image: url('/assets/img/abdruck.png');
        background-repeat: no-repeat;
        background-size: 26% auto;
        background-position: right;
        z-index: 0;
        margin-right: 2rem;
        margin-bottom: 12rem;
    }
}
@media (min-width: 1200px){
    .box-2::before {
        content: "";
        position: absolute;
        inset: 0; 
        background-image: url('/assets/img/abdruck.png');
        background-repeat: no-repeat;
        background-size: 16% auto;
        background-position: right;
        z-index: 0;
        margin-right: 30rem;
        margin-bottom: -17rem;
    }
}

/* Inhalt bleibt darüber sichtbar */
.box-2 > * {
  position: relative;
  z-index: 1;
}


#programm-namen{
    z-index: 1;
    position: relative;
}

#fingerabdruck-stueck{
    opacity: 0.5;
}
@media (min-width: 992px){
    #fingerabdruck-stueck{
        opacity: 1;
    }
}

#info-1 {
    background-color: #C4D380;
}

#info-2 {
    background-color: #09632E;
}

ul{
    list-style-type: none;
    padding-left: 0;
}

/* Info-Panels (grüne Bühne) */
.info-panels-2{
    background: #09632E;
    color:#fff; position:relative;
    overflow: hidden;
    padding: 5.5rem;
    padding-bottom: 0px !important;
}

#fingerabdruck{
    height: 120px;
}

.kontakt-png{
    transform: translate(20vw, 4rem);
    width: 345px;
    margin-top: -177px;
}

.finger-print{
    transform: translate(67vw, -21rem);
}
@media (min-width: 768px){
    .finger-print{
        transform: translate(15vw, -18rem);
    }
}
@media (min-width: 1200px){
    .finger-print{
        transform: translate(16vw, 3rem);
    }
}

.form-check a{
    color: #09632E;
}

input, textarea, select{
  border: 1.5px solid #09632E !important; /* grüne Border */
}

.img-size{
    margin-top: 170px;
    width: 350px;
}

.img-contact{
    margin-top: 100px !important;
}

.form-control{
    color: black;
}

#passwordHelpBlock{
    color: black;
    opacity: 0.54;
}

.form-text{
    font-family: 'Montserrat';
    font-weight: 600;
    font-size: 12px;
    line-height: 22px;
}
#form-text{
    font-size: 10px;
    line-height: 20px;
    color: #08632E;
}

.form{
    border-color: #08632E;
}

.contact-icons {
    background: #08632E;
    padding: 2rem;
    padding-top: 0rem !important;
    color: #ffffff;
}
@media (min-width: 992px){
    .contact-icons {
        background: #08632E;
        padding-top: 2rem !important;
        padding: 5.5rem;
        color: #ffffff;
        height: 300px;
    }
}








.kontakt-animation {
    position: relative;
    width: 100%;
    background-color: #09632E;
}

.kontakt-animation #img-logo {
    max-width: 200px;
}

@media (min-width: 768px){
    .kontakt-animation {
        position: relative;
    }

    .kontakt-animation #img-logo {
        max-width: 300px;
    }
}
@media (min-width: 1200px){
    .kontakt-animation {
        position: relative;
        overflow: hidden;
    }
}


/* Halbtransparentes Hintergrundbild über ein Pseudo-Element */
@media (min-width: 1200px){
    .kontakt-animation::before {
        content: "";
        position: absolute;
        inset: 0;
        background-image: url('/assets/img/fingerabdruck_teil3.png');
        background-repeat: no-repeat;
        background-size: 20% auto;
        background-position: right;
        z-index: 0;
        margin-right: -1rem;
        margin-bottom: -3rem;
    }
}

/* Inhalt bleibt darüber sichtbar */
.kontakt-animation > * {
  position: relative;
  z-index: 1;
  padding-top: 2rem;
  padding-bottom: 2rem;
}














.img-size-icon{
    width: 35px;
}

.icon-box{
    display: flex;
    justify-content: center; /* horizontal */
    align-items: center; /* vertikal */
}

/* Footer */
footer{
    background:#ffffff; 
    color:#09632f;
    margin-top: 2rem;
}
footer a{
    color:#09632f;
    text-decoration: none;
    font-weight: bolder;
}

@media (min-width: 768px){
    .finger-print{
        margin-left: 18vw;
    }
}

/* kleine runde Punkte zentriert unter Carousel */
#servicesCarousel .carousel-indicators {
  justify-content: center;
  margin-top: 1rem;
  gap: 0.4rem;
}

#servicesCarousel .carousel-indicators [data-bs-target] {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #ccc;
  opacity: 1;
  transition: background-color 0.3s ease;
}

#servicesCarousel .carousel-indicators .active {
  background-color: #333; /* aktive Farbe */
}

#kontakt{
    margin-top: 4rem;
    margin-bottom: 4rem;
}


/* Sticky Kontaktleiste rechts */
.floating-actions{
    position:fixed; 
    right:1rem; 
    bottom:1rem; 
    z-index:1030; 
    display:flex; 
    flex-direction:column; 
    gap:.5rem;
}
.floating-actions .btn{
    width:3rem; 
    height:3rem; 
    display:flex; 
    align-items:center; 
    justify-content:center
}
.logo-unten{
    width: 50vw;
    align-self: center;
}