* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}


    @font-face {
        font-family: "GravurLLWeb-CondRegular";
        src: url("GravurLLWeb-CondRegular.woff") format("woff");
      }
      
      @font-face {
        font-family: "GravurLLWeb-CondRegular";
        src: url("GravurLLWeb-CondRegular.woff2") format("woff2");
      }

      @font-face {
        font-family: "GravurLLWeb-CondBold";
        src: url("GravurLLWeb-CondBold.woff") format("woff");
      }
      
      @font-face {
        font-family: "GravurLLWeb-CondBold";
        src: url("GravurLLWeb-CondBold.woff2") format("woff2");
      }


    
body {
    display: grid;
    background-color:#F1EFEB;
    grid-gap: 2% 3%;
    grid-template-columns: 5fr 4fr 1fr;
    grid-template-rows: 15vh 78vh auto auto auto;  
}

#logo {
    position:fixed;
    right: 0;
    width: 150px;
    margin-top: 20px;
    margin-right: 30px; 
}

.overlay {
    width: 50%;
    background: #D4C3AE;
    position: fixed;
    top: 0;
    bottom:0;
    right: 100%;
    transition: right 1s;
    z-index: 99;
    overflow: auto;
}

.in {
    right:50%;
  }


h1 {
    font-family: "GravurLLWeb-CondBold", sans-serif; 
    font-weight: 100;
    color:#53821D;
    letter-spacing: 0.02em; 
    line-height: 1.25;
    font-size: 40px;
    font-size: clamp(22px, 2.6vw, 45px);
    margin-bottom: 10px;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h2 {
    font-family: "GravurLLWeb-CondBold", sans-serif; 
    font-weight: 100;
    letter-spacing: 0.02em; 
    line-height: 1.1;
    color:#53821D;
    font-size: 40px;
    font-size: clamp(22px, 2.4vw, 45px);
    margin-bottom: 10px;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


h3 {
    font-family: "GravurLLWeb-CondRegular", sans-serif;  
    font-weight: 100;
    letter-spacing: 0.02em; 
    color: #343434;
    font-size: 40px;
    font-size: clamp(22px, 2.4vw, 45px);
    margin-bottom: 10px;
}

p {
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    font-size: 25px;
    line-height: 1.25;
    letter-spacing: 0.02em; 

    color: #343434;
    font-size: clamp(22px, 2.4vw, 25px);
}

#intro {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
    margin-left: 40px;
}



#titeltabelle {
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    width: 35vw;
    margin-left: 40px;
    margin-top: 40px;
    margin-bottom:10px;
}

#tabellentext {
    color:#343434;
    margin-left: 40px;
    margin-top: 30px;
    margin-bottom: 5vh;
    width: 32vw;
}

.response {
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    width: 35vw;
    margin-left: 40px;
    margin-top: 40px;
    margin-bottom:10px;


}

#team {
    grid-column: 2 / 3;
    grid-row: 3 / 4;
    width: 35vw ;
    padding-top: 100px;
}

#foto {
    grid-column: 1 / 2;
    grid-row: 3 / 4;
    justify-self: end;
    margin-top: 50px;
    width: 35vw ;
    height: auto;
    justify-self: end;
}

#kontakt {
    grid-column: 1 / 2;
    grid-row: 4 / 5;
    padding-top: 50px;
    padding-bottom: 30px;
    width: 35vw ;
    justify-self: end;
}


footer { 
    grid-column: 1 / 2;
    grid-row: 5 / 6;
    align-self: end;
    width: 35vw ;
    justify-self: end;
    display: inline-block;

} 

#daten {
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    font-size: 15px;
    line-height: 1.2;
    margin-top: 30px;
    margin-left: 40px;
    width: 30vw;
    color: #343434;

}  

#impressum {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
    margin-left: 40px;
    width: 35vw ;
    justify-self: end;
}

a,
a:hover,
a:visited {
  color: #343434;
  text-decoration: underline;
}

li {
    grid-column: 1 / 2;
    grid-row: 5 / 6;
    display: inline-block;
    padding-right: 15px;
    color: #343434;
}

#footer {
    display: inline-block;
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    align-self: end;
    font-size: 18px;
    line-height: 1.3;
    color: #343434;
    padding-top: 18px;
    margin-bottom: 30px;
    justify-self: end;

} 

.button {
    letter-spacing: .5px;
    background:transparent;
    line-height: 2px;
    padding: 1.2em .7em 1.1em .7em;
    border-radius: 4px;
    border: 1.5px solid #343434;
    color:  #343434;
    background-color:#F1EFEB;
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    font-size: 18px;
    margin-top: 40px;
    margin-bottom:50px;
    margin-left: 40px;
  }
  
.button:visited {
    background:transparent;
    line-height: 2px;
    border: 1px solid #343434;
    color:  #343434;
  }
  
.button:hover {
    background:#53821D;
    line-height: 2px;
    border: 1px solid #53821D;
    color: white;   
  }

#detegolino {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
    justify-self: center;
    align-self: end;
    max-height: 70vh;

}

label {
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    margin-left: 40px;

}

input[type=text] {
    border: none;
    width: 32vw;
    line-height: 1;
    padding-right: 0px;
    padding-left: 0px;
    margin-bottom: 12px;
    border-bottom: 1px solid #343434;
    background-color: transparent;
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    font-size: 18px;
    color: #343434;
    font-size: clamp(20px, 2.4vw, 22px);
    margin-left: 40px;
    margin-right: 30px;

  }

  input[type=submit ] {
    background:transparent;
    line-height: 2px;
    padding: 1.2em .7em 1.1em .7em;
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    margin-left: 40px;
    margin-top: 50px;
    letter-spacing: .5px;
    border-radius: 4px;
    border: 1.5px solid #343434;
    color:  #343434;
    font-family: "GravurLLWeb-CondRegular", sans-serif; 
    font-size: 18px;


  }

  ::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color:#343434;
    opacity: .5; /* Firefox */
  }
  
  :-ms-input-placeholder { /* Internet Explorer 10-11 */
    color:#343434;
    opacity: .5; 
  }
  
  ::-ms-input-placeholder { /* Microsoft Edge */
    color:#343434;
    opacity: .5; 
  }

  #close {

      width: 45px;
      height: 45px;
      position: absolute;
      right: 15px;
      top: 15px;
      cursor: pointer;
  }


    @media (min-width: 1700px) {

        #logo {
            position:fixed;
            grid-column: 2 / span 2;
            grid-row: 1 / 2;
            justify-self: end;
            width: 160px;
            margin-top: 20px;
            margin-right: 30px; 
        
        }

    h1 {
        font-size: 50px;
        font-size: clamp(22px, 2.5vw, 50px);
    }

    h2 {
        font-size: 43px;
        font-size: clamp(22px, 2.4vw, 45px);
    }

    h3 {
        font-size: 43px;
        font-size: clamp(22px, 2.4vw, 45px);
    }

    p {
        font-size: 28px;
        font-size: clamp(22px, 2.4vw, 28px);
    }

    }
  
    
    @media (max-width: 1200px) {

    #close {
        width: 40px;
        height: 40px;
    }

    #logo { 
        width: 140px;
    }  

    h1 {
        font-family: "GravurLLWeb-CondBold", sans-serif; 
        font-weight: 100;
        font-size: 32px;
        font-size: clamp(22px, 2.8vw, 45px);
    }

    h2 {
        font-family: "GravurLLWeb-CondBold", sans-serif; 
        font-weight: 100;
        font-size: 32px;
        font-size: clamp(22px, 2.8vw, 45px);
    }

    h3 {
        font-family: "GravurLLWeb-CondBold", sans-serif; 
        font-weight: 100;
        font-size: 32px;
        font-size: clamp(22px, 2.8vw, 45px);
    }

    p {
        font-size: 22px;
        font-size: clamp(22px, 2.4vw, 25px);
    }


    #foto {

        margin-top: 20px;

    }

    #team {

        width: 35vw ;
        padding-top: 40px;
    }

@media (max-width: 900px) {

    body {
        grid-template-columns: 2fr 2fr;
        grid-template-rows: 120px auto auto auto auto auto auto auto; 
    }

    header {
        height: 105px;
        width: 1000vw;
        position: fixed;
        background-color:#F1EFEB;
    }

    #intro {
        grid-column: 1 / 3;
        grid-row: 2 / 3;
        width: 80vw;
        height: auto;

    }

    #close {
        width: 40px;
        height: 40px;
    }

    h1 {
        font-size: 34px;
        font-size: clamp(22px, 3.4vw, 45px);
    }

    h2 {
        font-size: 28px;
        font-size: clamp(22px, 3.4vw, 45px);
    }

    h3 {
        font-size: 28px;
        font-size: clamp(22px, 3.4vw, 45px);
    }

    p {
        font-size: 20px;
        font-size: clamp(22px, 2.4vw, 25px);
    }


    #detegolino {
        grid-column: 2 / 3;
        grid-row: 3 / 4;
        justify-self: center;
        align-self: auto;
        width: 80%;
        max-height: 70vh;
    
    }

    
    #team {
        grid-column: 2 / 3;
        grid-row: 4 / 5;
        width: 38vw ;
        justify-self: start;
        padding-top: 40px;

    }
    
    #kontakt {
        grid-column: 1 / 2;
        grid-row: 5 / 6;
        justify-self: start;
        width: 38vw ;
        margin-left: 12vw;
        padding-top: 40px;
    }

    #foto {
        grid-column: 1 / 2;
        grid-row: 4 / 5;
        justify-self: start;
        width: 38vw ;
        margin-left: 6vw;
        margin-top: 20;
    }


    footer { 
        grid-column: 1 / 2;
        grid-row: 6 / 7;
        align-self: end;
        width: 40vw ;
        justify-self: start;
        margin-left: 12vw;
    
    }   

    #daten {
        font-family: "GravurLLWeb-CondRegular", sans-serif; 
        font-size: 15px;
        line-height: 1.2;
        margin-top: 30px;
        margin-left: 40px;
        width: 60vw;
        color: #343434;
    
    }  

    input[type=text] {
        width: 70vw;
        padding-right: 0px;
        padding-bottom: 1px;
        padding-left: 0px;
      }
    

    #tabellentext {
        color:#343434;
        margin-left: 40px;
        margin-top: 40px;
        margin-bottom: 5vh;
        width: 70vw;
    }

    .response {
        color:#343434;
        margin-left: 40px;
        margin-top: 40px;
        margin-bottom: 5vh;
        width: 70vw;
    }
    
    .overlay {
        width: 100%;
        top: 0;
        bottom:0vmax;
        right: 100%;
        transition: right 1s;
    }
    
    .in {
      right:0;
    }


}

@media (max-width: 700px) {

        body {
        grid-template-columns: 2fr 2fr;
        grid-template-rows: 100px auto auto auto auto auto auto auto; 
    } 

    header {
        height: 105px;
        width: 1000vw;
        position: fixed;
        background-color:#F1EFEB;
    }

    h1 {
        font-size: 28px;
        font-size: clamp(22px, 4.4vw, 45px);
    }

    h2 {
        font-size: 28px;
        font-size: clamp(22px, 4.4vw, 45px);
     }
     
    h3 {
        font-size: 28px;
        font-size: clamp(22px, 4.4vw, 45px);
     }

     p {
        font-size: 18px;
        font-size: clamp(22px, 2.4vw, 25px);
    }

    #intro {
        grid-column: 1 / 3;
        grid-row: 2 / 3;
        width: 80vw;
    }

    #team {
        grid-column: 2 / 3;
        grid-row: 4 / 5;
        width: 42vw;
        padding-right: 20px;        
        justify-self: start;

    }
    
    #kontakt {
        grid-column: 1 / 2;
        grid-row: 5 / 6;
        width: 42vw;
        margin-left: 40px;
        margin-bottom: 20px;
        
    }

    #foto {
        grid-column: 1 / 2;
        grid-row: 4 / 5;
        margin-bottom: 20px;
        justify-self: start;
        margin-left: 20px;
        width: 40vw;
    }



    footer {
        grid-column: 1 / 3;
        grid-row: 6 / 7;
        margin-left: 40px;
    }



    #logo { 
        width: 120px;
        margin-left: 20px;
        margin-top: 20px;
        grid-column: 1 / 2; 
        grid-row: 1 / 2 ;
    }
    
    #detegolino {
        margin-right: 15px;
        grid-column: 2 / 3;
        grid-row: 3 / 4;
 

    } 

    #impressum {
        grid-column: 1 / 2;
        grid-row: 2 / 3;
        margin-left: 40px;
        width: 80vw ;
        justify-self: end;
    }

    
    .overlay {
        width: 100%;
        top: 0;
        height: 100%;
        right: 100%;
        transition: right 1s;
    }
    
    .in {
      right:0;
    }
    
    #close {
        width:35px;
        height: 35px;
        position: absolute;
        right: 14px;
        top: 21px;
        cursor: pointer;
    }


    #tabellentext {
        color:#343434;
        margin-left: 40px;
        margin-top: 40px;
        margin-bottom: 20px;
        width: 70vw;
    }

    .response {
        color:#343434;
        margin-left: 40px;
        margin-top: 40px;
        margin-bottom: 20px;
        width: 70vw;
    }

    input[type=text] {
        width: 70vw;
        margin-left: 40px;
      }

      label {
        font-family: "GravurLLWeb-CondRegular", sans-serif; 
        font-size: 15px;
        margin-left: 40px;
    
    }
    
    
      .button {
        font-size: 18px;
        margin-left: 40px;

      }

      input[type=submit ] {
        margin-left: 40px;
        margin-top: 50px;
        font-size: 18px;
  
    
      }

      

    }


@media (max-width: 500px) {

    body {
        grid-template-columns: 2fr 2fr;
        grid-template-rows: 120px auto auto auto auto auto auto auto; 
    } 

    header {
        height: 105px;
        width: 1000vw;
        position: fixed;
        background-color:#F1EFEB;
    }
 

    h1 {
       font-size: 25px;
       font-size: clamp(25px, 4.4vw, 45px);
    }

    h2 {
        font-size: 25px;
        font-size: clamp(25px, 4.4vw, 45px);
     }
     
    h3 {
        font-size: 25px;
        font-size: clamp(25px, 4.4vw, 45px);

     }
    
    p {
        font-size: 20px;
        font-size: clamp(20px, 4.4vw, 25px);
        line-height: 1.3;
    }
    
    #tabellentext {
        width: 80vw;
        margin-left: 30px;
        margin-bottom: 10px;

    }

    .response {
        width: 80vw;
        margin-left: 30px;
        margin-bottom: 10px;
    }
   

    input[type=text] {
        width: 80vw;
        margin-left: 30px;
      }
      
    label {
        font-family: "GravurLLWeb-CondRegular", sans-serif; 
        margin-left: 30px;
    
    }

    input[type=submit ] {
        margin-left: 30px;
        font-size: 15px;
      }
    
    .button {
        font-size: 17px;
        margin-left: 20px;
        line-height: 2px;
        padding: 1.1em .7em  1em .7em;
      }

    #daten {
        font-family: "GravurLLWeb-CondRegular", sans-serif; 
        font-size: 15px;
        line-height: 1.2;
        margin-top: 30px;
        margin-left: 30px;
        width: 80vw;
        color: #343434;

    }  

    #intro {
          margin-left: 20px;
          margin-right: 20px;
          width: 90vw;
      }

    
    #team {
        grid-column: 1 / 3;
        grid-row: 4 / 5;
        font-size: 26px;
        width: 90vw ;
        margin-top: 0px;
        justify-self: start;
        margin-left: 20px;
        padding-top: 0;
    }
    
    #kontakt {
        grid-column: 1 / 3;
        grid-row: 6 / 7;
        align-self: end;
        width: 80vw ;
        margin-left: 20px;
        padding-bottom: 0;
    }

    #foto {
        grid-column: 1 / 3;
        grid-row: 5 / 6;
        margin-bottom: 0;
        margin-top: 10px;
        justify-self: start;
        margin-left: 10px;
        margin-right: 30px;
        width: 88vw;

    }

    footer { 
        grid-column: 1 / 3;
        grid-row: 7 / 8;
        display: inline-block;
        margin-left: 20px;
        width: 90vw;
    
    } 
    
    #detegolino {
        padding-right: 10px;
        grid-column: 2 / 3;
        grid-row: 3 / 4;
        align-self: auto;
        padding-bottom: 0;
        width: 100%;
 

    } 

}





@media (max-width: 320px) {

    h1 {
        font-size: 22px;
        font-size: clamp(22px, 4.4vw, 45px);
     }
 
     h2 {
         font-size: 22px;
         font-size: clamp(22px, 4.4vw, 45px);
      }
      
     h3 {
         font-size: 22px;
         font-size: clamp(22px, 4.4vw, 45px);
 
      }
     
     p {
         font-size: 22px;
         font-size: clamp(22px, 4.4vw, 25px);
         line-height: 1.3;
     }

    #intro {
        margin-left: 20px;
        margin-right: 0px;
    }
}
    }