/* #################################################################################################### 1. */
/* font */



@font-face {
    font-family: "Logo";
    src: url(font/TheNautigal-Regular.ttf);
}

@font-face {
    font-family: "Ueberschrift";
    src: url(font/Montserrat-Medium.ttf);
}

@font-face {
    font-family: "Schrift";
    src: url(font/Montserrat-Regular.ttf);
}



/* #################################################################################################### 2. */
/* allgemein */



* {
    box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
    background-color: #FFFFFF;
    display: flex;
    flex-flow: column;
    padding: 0;
    margin: 0;
}

.container {
    max-width: 1050px;
    padding: 0;
    margin: 0 auto;
}

.bild-container {
    max-width: 850px;
    padding: 0;
    margin: 0 auto;
}

.zentral {
    text-align: center;
}



/* #################################################################################################### 3. */
/* header */



header {
    padding: 0;
    margin: 0;
}

header h1 {
    z-index: 2;
    position: absolute;
    top: 0.6rem;
    left: 1.5rem;
    color: #855843;
    font-family: "Logo";
    font-size: 2.2rem;
    padding: 0;
    margin: 0;
}

header a {
    color: inherit;
    text-decoration: none;
    padding: 0;
    margin: 0;
}

header a:hover, header a:focus {
    color: #b2aca0;
    transition: 2s;
}



/* #################################################################################################### 4. */
/* nav */



nav {
    z-index: 1;
    position: sticky;
    top: 0;
    background-color: #FFFFFF;
    min-height: 3rem;
    padding: 0;
    border-bottom: 0.03rem solid  #b2aca0;
    margin: 0;
}

nav  ul {
    display: flex;
    flex-flow: column;
    max-height: 0;
    overflow: hidden;
    list-style-type: none;
    padding: 0;
    border-top: none !important;
    border-bottom: none !important;
    margin: 0;
}

nav li {
    color: #855843;
    font-family: "Ueberschrift";
    font-size: 1.5rem;
    text-align: center;
    padding: 0.3rem;
    margin: 0 auto 0 1.5rem;
    transition: 0.8s;
}

nav li:first-child {
    margin: 1rem auto 0 1.5rem;
}

nav li:last-child {
    margin: 0 auto 1.5rem 1.5rem;
}

nav li:hover {
    text-decoration: underline;
}

nav li.aktuell {
    color: #000000;
}

nav a {
    display: block;
    color: inherit;
    text-decoration: none;
    padding: 0;
    margin: 0;
}

.menubutton {
    display: flex;
    background-color: inherit;
    cursor: pointer;
    padding: 0;
    border: none;
    margin: 1rem 1rem 1rem auto;
}

.menubutton:active, .menubutton:focus {
    outline: none
}

.menubutton::before {
    content: url(bilder/menu-open.svg);
    width: 2rem;
    height: 2rem;
}

.showmenu + ul {
    max-height: 50rem;
    overflow: initial; 
    transition: max-height 3s ease;
}

.showmenu.menubutton::before {
    content: url(bilder/menu-close.svg); 
}



/* #################################################################################################### 5. */
/* aside */



aside {
    background-color: #b2aca0;
    padding: 0;
    margin: 0;
}

.bild {
    display: block;
    width: 100%;
    height: auto;
    padding: 0;
    margin: 0;
    opacity: 0.1;
    animation: laden 3s ease-in-out forwards;
}

@keyframes laden {
    from {
        opacity: 0.1;
    }
    to {
        opacity: 1;
    }
}



/* #################################################################################################### 6. */
/* main */



main {
    padding: 0;
    margin: 0;
}

main section {
    padding: 1.5rem;
    margin: 0;
}

main h2 {
    color: #855843;
    font-family: "Ueberschrift";
    font-size: 1.5rem;
    text-align: center;
    padding: 1.5rem 0;
    margin: 0;
}

main p {
    color: #000000;
    font-family: "Schrift";
    font-size: 1.2rem;
    line-height: 1.5;
    padding: 1.5rem 0;
    margin: 0;
}

main figure {
    position: relative;
    padding: 0;
    margin: 1.5rem 0 3rem 0;
}

main figure img {
    width: 100%;
    height: auto;
    padding: 0;
    margin: 0;
    box-shadow: 0.5rem 0.5rem 0.2rem grey;
}

main figure figcaption {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #b2aca0;
    color: #000000;
    font-family: "Schrift";
    font-size: 1.2rem;
    text-align: center;
    padding: 0.5rem;
    margin: 0;
}

main figure figcaption.transparent {
    background-color: #FFFFFF;
    opacity: 0.5;
}

main img.capt {
    width: 12rem;
    height: 4rem;
    padding: 0;
    margin: 1rem 0;
}

main img.telefon {
    width: 16rem;
    height: 5rem;
    padding: 0;
    margin: 0;
}

main hr {
    background-color: #b2aca0;
    padding: 0;
    border: 0.05rem solid #b2aca0;
    margin: 1.5rem 0;
}

main a {
    color: inherit;
    text-decoration: none;
    font-family: "Ueberschrift";
    padding: 0;
    margin: 0;
}

main a:hover, header a:focus {
    color: #855843;
}



/* #################################################################################################### 7. */
/* footer */



footer {
    background-color: #b2aca0;
    min-height: 24rem;
    padding: 1.5rem 0 0 0;
    margin: 0;
}

footer div.fussleiste {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
    grid-gap: 1rem;
    padding: 1rem;
    margin: 0;
}

footer article.abschnitt {
    padding: 0.5rem;
    margin: 0;
}

footer article.abschnitt2 {
    padding: 0.5rem;
    margin: 0;
}

footer h3 {
    color: #000000;
    font-family: "Ueberschrift";
    font-size: 1.2rem;
    padding: 1rem 0;
    margin: 0;
}

footer p {
    color: #000000;
    font-family: "Schrift";
    font-size: 1rem;
    line-height: 2;
    padding: 1rem 0;
    margin: 0;
}

footer a {
    color: inherit;
    font-family: "Ueberschrift";
    text-decoration: none;
    padding: 0;
    margin: 0;
}

footer a:hover, footer a:focus {
    color: #855843;
}



/* #################################################################################################### 8. */
/* form */



form {
    background-color: #b2aca0;
    color: #000000;
    font-family: "Schrift";
    font-size: 1.2rem;
    line-height: 1.5;
    padding: 1.5rem;
    margin: 1.5rem 0;
    box-shadow: 0.5rem 0.5rem 0.2rem grey;
}



form div {
    padding: 0;
    margin: 0 0 1rem 0;
}

form label {
    cursor: pointer;
    padding: 0;
    margin: 0;
}

form label[for] {
    display: block;
}

form #besucher {
    font-family: "Schrift";
    font-size: 1rem;
    max-width: 99%;
    padding: 0.5rem;
    margin: 0;
}

form #adresse {
    font-family: "Schrift";
    font-size: 1rem;
    max-width: 99%;
    padding: 0.5rem;
    margin: 0;
}

form #anreise {
    font-family: "Schrift";
    font-size: 1rem;
    max-width: 99%;
    padding: 0.5rem;
    margin: 0;
}

form #abreise {
    font-family: "Schrift";
    font-size: 1rem;
    max-width: 99%;
    padding: 0.5rem;
    margin: 0;
}

form #nachricht {
    font-family: "Schrift";
    font-size: 1rem;
    line-height: 1.5;
    width: 99%;
    padding: 0.5rem;
    margin: 0;
}

form #eingabe {
    font-family: "Schrift";
    font-size: 1rem;
    max-width: 99%;
    padding: 0.5rem;
    margin: 0;
}

form button {
    background-color: #855843;
    color: #FFFFFF;
    font-family: "Schrift";
    font-size: 1.2rem;
    cursor: pointer;
    min-width: 5rem;
    padding: 0.5rem;
    border: 0.05rem solid #855843;
    border-radius: 0.3rem;
    margin: 0 1rem 0 0;
}



/* @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ A. */ /*-----------------------------------*/
/* @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ A. */ /*-----------------------------------*/
@media screen and (min-width: 1100px) {



/* #################################################################################################### 3. */
/* header */



header h1 {
    position: absolute;
    top: 0.7rem;
    left: 1.5rem;
    font-size: 2.3rem;
}



/* #################################################################################################### 4. */
/* nav */



nav {
    min-height: 3.8rem;
    border-bottom: 0.05rem solid  #b2aca0;
}

nav ul {
    flex-flow: row;
    max-height: none !important;
}

nav li {
    font-size: 1.75rem;
    padding: 0 1.5rem;
    margin: 1rem 0;
}

nav li:first-child {
    margin: 1rem 0 1rem auto;
}

nav li:last-child {
    margin: 1rem auto 1rem 0;
}

.menubutton {
    display: none !important;
}



/* #################################################################################################### 6. */
/* main */



main section {
    padding: 2rem;
}

main h2 {
    font-size: 2rem;
    padding: 2rem 0;
}

main p {
    font-size: 1.5rem;
    line-height: 1.7;
    padding: 2rem 0;
}

main figure {
    margin: 2rem 0 4rem 0;
}

main figure img {
    box-shadow: 1rem 1rem 0.4rem grey;
}

main figure figcaption {
    font-size: 1.5rem;
    padding: 0.7rem;
}

main img.capt {
    width: 15rem;
    height: 5rem;
    margin: 2rem 0;
}

main img.telefon {
    width: 19rem;
    height: 6rem;
    padding: 0;
    margin: 0;
}

main hr {
    margin: 2rem 0;
}



/* #################################################################################################### 7. */
/* footer */



footer {
    padding: 3rem 0 0 0;
}

footer div.fussleiste {
    grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
    grid-gap: 1rem;
    padding: 1.5rem;
}

footer article.abschnitt {
    padding: 1rem;
}

footer article.abschnitt2 {
    padding: 1rem;
}

footer h3 {
    font-size: 1.4rem;
}

footer p {
    font-size: 1.1rem;
}

footer img {
    width: 5rem;
    height: 5rem;
}



/* #################################################################################################### 8. */
/* form */



form {
    font-size: 1.5rem;
    line-height: 1.7;
    padding: 2rem;
    margin: 2rem 0;
    box-shadow: 1rem 1rem 0.4rem grey;
}

form div {
    margin: 0 0 2rem 0;
}

form #besucher {
    font-size: 1.5rem;
    padding: 0.7rem;
}

form #adresse {
    font-size: 1.5rem;
    padding: 0.7rem;
}

form #anreise {
    font-size: 1.5rem;
    padding: 0.7rem;
}

form #abreise {
    font-size: 1.5rem;
    padding: 0.7rem;
}

form #nachricht {
    font-size: 1.5rem;
    line-height: 1.7;
    width: 99%;
    padding: 0.7rem;
}

form #eingabe {
    font-size: 1.5rem;
    padding: 0.7rem;
}

form button {
    font-size: 1.5rem;
    min-width: 8rem;
    margin: 0 2rem 0 0;
}



} /* Ende - @media */



/* @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ B. */ /*-----------------------------------*/
/* @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ B. */ /*-----------------------------------*/
@media screen and (min-width: 1300px) {



/* #################################################################################################### 3. */
/* header */



header h1 {
    position: absolute;
    top: 1rem;
    left: 2rem;
    font-size: 2.6rem;
}



/* #################################################################################################### 4. */
/* nav */



nav {
    min-height: 4.5rem;
    border-bottom: 0.05rem solid  #b2aca0;
}

nav ul {
    flex-flow: row;
    max-height: none !important;
}

nav li {
    font-size: 2rem;
    padding: 0 2rem;
    margin: 1.25rem 0;
}

nav li:first-child {
    margin: 1.25rem 0 1.25rem auto;
}

nav li:last-child {
    margin: 1.25rem auto 1.25rem 0;
}

.menubutton {
    display: none !important;
}



} /* Ende - @media */
