/* roboto-slab-regular - latin */
@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 400;
  src: local('Roboto Slab Regular'), local('RobotoSlab-Regular'),
       url('../fonts/roboto-slab-v7-latin-regular.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/roboto-slab-v7-latin-regular.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* roboto-slab-300 - latin */
@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 300;
  src: local('Roboto Slab Light'), local('RobotoSlab-Light'),
       url('../fonts/roboto-slab-v7-latin-300.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/roboto-slab-v7-latin-300.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* roboto-slab-700 - latin */
@font-face {
  font-family: 'Roboto Slab';
  font-style: normal;
  font-weight: 700;
  src: local('Roboto Slab Bold'), local('RobotoSlab-Bold'),
       url('../fonts/roboto-slab-v7-latin-700.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/roboto-slab-v7-latin-700.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

* {
    box-sizing: border-box;
}
html {
    background-color: #fff;
    color: #333;
    font-family: "roboto slab", Rockwell, "Helvetica Neue", arial, sans-serif;
    font-size: 0.9375em;
    font-weight: 300;
    line-height: 1.5;
    height: 100%;
}
body {
    background-color: #f5f5f5;
    min-height: 100%;
    margin: 0 30px 0 12.5%;
    border-bottom: 30px solid #fff;
    border-left: 30px solid #fff;
}
img {
    max-width: 100%;
    height: auto;
}
ul {
    padding-left: 1em;
    margin-left: 0;
}
.inner {
    width: 90%;
    max-width: 800px;
    margin: 2em auto;
}
.cols {
    -webkit-columns: 2;
    -moz-columns: 2;
    columns: 2;
    -webkit-column-gap: 2em;
    -moz-column-gap: 2em;
    column-gap: 2em;
    text-align: left;
}
.cols p {
    margin-top: 0;
}
strong {
    font-weight: 400;
}

body > div {
    border-top: 30px solid #fff;
}
#start {
    display: table;
    width: 100%;
    height: 400px;
    background: url(../img/dkl.jpg) no-repeat center/cover #61838d;
    color: #fff;
    font-size: 1.67em;
}
#start .cell {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}
#start blockquote {
    background: url(../img/quote.png) no-repeat;
    text-shadow: 1px 2px 1px rgba(0,0,0,0.25);
    padding-left: 150px;
    padding-right: 60px;
}
blockquote p {
    text-align: left;
    margin: 0;
}
cite {
    display: block;
    text-align: right;
    font-size: 0.8rem;
}

#profil {
    text-align: center;
}
#profil img {
    border: 20px solid #fff;
}
#slider {
    margin-bottom: 30px;
}
#slider ul,
#slider li {
    padding: 0;
    margin: 0;
    list-style: none;
}
h1 {
    font-size: 2.4em;
    font-weight: 300;
    letter-spacing: 0.05em;
    text-align: center;
    margin: 1.5em 0;
}
h2 {
    font-size: 1.333em;
}
h3 {
    font-size: 1em;
}
h2, a {
    color: #6e8f99;
}
h4 {
    font-weight: normal;
    margin-bottom: -0.5em;
}

#drop {
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -15px;
    margin-top: -40px;
}
#anfahrt {
    position: relative;
    width: 100%;
    height: 430px;
    background: url(../img/karte-blass.png) no-repeat center/cover;
}
.maplinks {
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    font-size: 0.85em;
    text-align: center;
    padding: 0.25em;
    margin: 0;
    background: #fafafa88;
    backdrop-filter: blur(2px);
}
.maplinks a { display: inline-block; }
@media (min-width: 750px) {
    .maplinks {
        margin: 0 calc(50vw - 21em);
    }
@media (min-width: 1080px) {
    .maplinks {
        margin: 0 calc(50vw - 25em);
    }
}
/*.gm-style img {
    max-width: none;
}
.gm-style-cc,
a[href*=maps] {
    display: none !important;
}*/
            
#kontakt {
    padding-bottom: 300px;
}

#impressum p,
#impressum li {
    font-size: 0.85em;
}
#leer {
    height: 400px;
}
nav {
    position: fixed;
    background-color: #517681;
    top: 0;
    left: 0;
    bottom: 0;
    width: 12.5%;
    min-width: 120px;
    padding-top: 30px;
    padding-bottom: 20px;
    -webkit-font-smoothing: subpixel-antialiased;
}
nav ul {
    padding: 0; margin: 0; list-style: none; line-height: normal;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    height: 100%;
}
nav li:nth-child(4) {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
}
nav a {
    display: block;
    color: #fff;
    text-decoration: none;
    padding: 10px 20px;
    text-shadow: 1px 2px 1px rgba(0,0,0,0.35);
}
nav a:hover {
    background-color: rgba(0,0,0,0.10);
    box-shadow: 0 0 25px rgba(0,0,0,0.10) inset;
}

@media screen and (max-width: 960px) {
    body {
        margin-left: 120px;
    }
}

@media screen and (max-width: 767px) {
    .cols {
        -webkit-columns: 1;
        -moz-columns: 1;
        columns: 1;
    }
    #start {
        font-size: 1.5em;
    }
}

@media screen and (max-width: 550px) {
    body {
        margin: 0 5% 30px;
    }
    nav {
        display:none;
    }
}
@media screen and (max-width: 479px) {
    #start blockquote {
        background: none;
        padding: 0 5%;
    }
}