/* sponsor logos schwarz */

html {
    font-family: Roboto, Arial, sans-serif;
    box-sizing: border-box;
    height: -webkit-fill-available;
}
*, *:before, *:after {
  box-sizing: inherit;
}
body {
    margin:0;
    font-size: 18px;
    min-height: 100vh;
    /* mobile viewport bug fix */
    min-height: -webkit-fill-available;
}
h1 {
    font-weight: normal;
    font-size: 2em;
    margin:0;
    line-height: 1em;
}
.nr h1 {
    position:relative;
/*    padding-left: 1rem;*/
    hyphens: auto;
}
/*.nr h1 span {
    display:inline-block;
    width:2rem;
    margin-right:12px;
    font-size:2rem;
    color:hsla(81, 48%, 59%, 1);
}*/
.nr h1 span {
    display:none;
}
pre {
    font-size: 0.8em;
}

a {
    color: hsl(98.4, 96.1%, 30%);
    text-decoration: none;
}
hr {
    border: 0;
    height: 1px;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0), hsl(98.4, 96.1%, 30%), rgba(0, 0, 0, 0));
}
a:hover {
    text-decoration: underline;
}
a[href $='.pdf'] {
    padding-right: 28px;
    background: url(imgs/pdf.nr.svg) no-repeat center right;
    background-size: 24px;
}

ul {
    margin: 0;
    padding:0;
}
li {
    list-style: none;
}

header .wrapper {
    padding: 12px;
}
header .handy {
    padding: 0;
}
header .handy img {
    width:100%
}
/*
#0083b3

rgba(0, 131, 179, 1)
*/
header nav {
    background-color: hsla(196, 100%, 35%, 1);
}
header nav .main {
    position: absolute;
    top: 112px;
    left: -12em;
    z-index: 100;
    width: 12em;
    background-color: #fff;
    box-shadow: 2px 0 15px rgba(0, 0, 0, 0.15);
    transition: left 0.25s;
    display:block;
/*    overflow-y: scroll;*/
}
header nav .meta {
    display: flex;
    justify-content: space-between;
    padding:8xp 12px;
}
header nav .meta li {
    padding:8px 8px 10px 8px;
}
header nav .main li a {
    display: block;
    text-align: center;
    padding:8px 6px;
    border: 1px solid hsl(90, 48%, 49.8%);
    color: hsla(90, 40%, 49.8%, 1);
    border-radius: 19px 0 19px 0;
    transition: 0.3s;
}
header nav  .main  li.active a,
header nav  .main  li a:hover {
    background-color: hsla(90, 48%, 49.8%, 1);
    color:#fff;
    border-radius: 0 22px  0 22px;
}

/*.nav-toggle-handle {
    position: fixed;
    transition: left 0.25s;
    left: 0;
    top: 6.5rem;
    z-index: 100;
    padding: 10px;
    color: #fff;
    background-color: #af23ff;
    cursor: pointer;
}*/

nav.active ul {
    left: 0;
    flex-wrap: wrap;
    padding:4px;
    display: flex;
}

nav.active .main li {
    /*! display:block; */
    /*! width: 44px; */
    flex: 0 0 24%;
    margin: 8px;
}
nav.active ul li a {
    margin:0;
    line-height: 2.2rem;
}

.medium {
    font-size: 1.2rem;
    line-height: 1.4rem;
}

.small {
    font-size: 0.76rem;
}

.wrapper {
    background-color:#fff;
        overflow-x: hidden;
}
.error {
    color: red;
}
main .wrapper {
    min-height: 60vh;
}
footer h3 {
    margin: 12px 0 6px 0;
}

footer nav.wrapper {
    display:none
}
footer nav a{
    display:block;
    color:#fff;
}
footer div.wrapper {
    background-color: hsl(80, 60%, 86.3%);
}
footer .wrapper .col {
    padding: 0 8px;
}
footer .col .handy {
    padding: 12px 0;
}
footer .handy li {
    margin: 0 0 8px 0;
}
footer .handy img {
    width:60%;
}
footer img.migros {
    width:45%;
}

.accordion>h3 {
    cursor: pointer;
    padding-left:12px;
    background-color: green;
    background: url('imgs/closed.gif') no-repeat center left;
}
.accordion>ul {
    display: none;
}
h3.open {
    background-color: yellow;
    background: url('imgs/open.gif') no-repeat center left;
}

.nahreisen,
.editorial,
.kalender,
.kontakt,
.basket,
.baketempty {
    color:transparent;
    display: inline-block;
    width:2.4rem;
    background: url(./imgs/click.svg) no-repeat center center;
    background-size: 2rem 2rem;
    line-height:2rem;
}
.kontakt {
    background-image: url(./imgs/kontakt.svg);
}
.editorial {
    background-image: url(./imgs/editorial.svg);
}
.kalender {
    background-image: url(./imgs/kalender.svg);
}
.basket {
    background-image: url(./imgs/basket.svg);
}
.basketempty {
    background-image: url(./imgs/basket.empty.svg);
}
main article {
    position:relative;
}

main .wrapper {
    padding: 24px 8px;
}

main aside {
    padding: 8px
}
main aside h1 {
    margin-top: 14px;
    font-size:2rem;
}
main aside h3 {
    font-size:1rem;
    margin-bottom: 0;
}
main aside h4 {
    margin-bottom: 0;
    font-weight: normal;
    font-style:italic;
}
main aside p {
    margin:0;
}

main aside .calendar li:last-child {
    margin-top:12px;
}
main aside .termin {
    padding: 12px 24px 12px 4px;
    margin-left: 24px;
    line-height: 2rem;
    background: url(imgs/calendar.nr.svg);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: 80%;
}


main aside .links li {
    padding-left: 1rem;
    text-indent: -0.8rem;
    margin-top: 8px;
}
main aside .links li::before {
    content:"• ";
    color: hsla(195, 96%, 30%, 1);
}
/* alle buttons, send, reset etc. */
.btn  {
    border: none;
    border-radius: 4px;
    display: inline-block;
    height: 36px;
    line-height: 36px;
    padding: 0 2rem;

    vertical-align: middle;
    -webkit-tap-highlight-color: transparent;

    font-size: 1rem;
    outline: 0;
    text-decoration: none;
    color: #fff;
    background-color: hsla(90, 48%, 49.8%, 1);
    text-align: center;
    letter-spacing: .5px;

    transition: .2s ease-out;
    cursor: pointer;
    margin-top:12px;
    margin-right: 12px;
}
.btn.anmeldung {
    margin:0 0 12px 0;
}

/* arrow box */
.facts, .links, .dates {
    position: relative;
    background: hsla(81, 48%, 59%, 0.3);
    border: 1px solid hsla(81, 48%, 59%, 0.3);
    border-radius: 24px 0 24px 0;
    margin-top: 24px;
    padding:4px 12px 8px 12px;
}
.facts {
   border-radius: 0 24px 0 24px; 
}
main aside h3:first-child {
    margin-top:8px;
}


.facts:after {
    border-color: rgba(255, 255, 255, 0);
  /*  border-bottom-color: #fff;*/
    border-right-color: #fff;
    border-width: 1rem;
/*  margin-left: -1rem; */
    margin-top: -1rem;
}
.facts:before {
    border-color: rgba(24, 76, 245, 0);
/*    border-bottom-color: hsla(195, 96%, 30%, 1);*/
    border-right-color: hsla(195, 96%, 30%, 1);
    border-width: calc(1rem + 1px); /* 1.08rem; */
 /*   margin-left: -1.08rem;*/
    margin-top: calc(-1 * (1rem + 1px)); /* -1.08em; */
}

.screen {
    display: none;
}

#popup-bg {
    position: fixed;
    top: 0;
    background: black;
    width: 100%;
    height: 100%;
    opacity: .5;
    display: none;
}

.swiper-container {
    /*! width: 351px; */ /*
    box-sizing: content-box; */

    height: 350px;
    position:relative;
}
.swiper-container figure {
    margin:12px 0;
    width:100%;
}
figure img {
    width:100%;
    display: block;
    margin: 0 auto;
}

.swiper-container-horizontal>.swiper-pagination-bullets,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: 0;
    left: 0;
    width: 100%;
}

.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 24px;
}

.swiper-slide figcaption {
    font-size:0.8rem;
    text-align: center;
}

.swiper-pagination-bullet {
    width: 24px;
    height: 24px;
    background-color: hsla(90, 48%, 49.8%, 1);
}


.calendar h2 {
    padding: 8px 12px;
    background-color: hsla(90, 48%, 49.8%, 1);
    color: #fff;
    margin-bottom: 0;
}
.calendar ul {
    border-top: 1px hsla(90, 48%, 49.8%, 1);
}

.calendar li {
  padding:8px 0;
  border-bottom: 1px solid hsla(90, 48%, 49.8%, 1);
  font-size:1rem;
  display:flex;
}
/*.kalender li:after {
  content:'';
  display:table;
  clear:left;
}*/
.calendar a {
  color: hsl(98.4, 96.1%, 30%);
}
.calendar .tag {
  display:inline-block;
  width:30%;
}
.calendar .long,
.calendar .time {
    display:none;
}
.calendar .event {
  display:inline-block;
  padding-right:8px;
}
.calendar li span strong {
  color:hsl(98.4, 96.1%, 30%);
}
.sunday {
    background-color: hsla(81, 48%, 59%, 0.3);
}

/* formular */
#person .number {
    width:3rem;
}
#person .zip {
    width:6rem;
}
.nickname {
    color: transparent;
    font-size:1px;
    height:1px;
    margin-top:-12px;
}
.nickname input{
    border:0;
    height:1px;
}
#home #home_title {
    display:inline-block;
    width:70%;
    margin:12% auto;
}

#home .wrapper {
    background: url(../imgs/background.1024.jpg) no-repeat top center fixed;
    display:flex;
    flex-direction: column-reverse;
}

#home .covid {
    background-color: hsla(0, 28.6%, 97.3%, 0.79);
    width: 100%;
    padding: 12px;
}
#home .wrapper img {
    display:block;
    width:200%;
}
#editorial img {
    display:block;
    width:100%;
    margin: 0 auto 38px auto;
}
#editorial h1, #editorial h2 {
    text-align: center;
}

#start .wrapper img {
    display:block;
    width: 100%;
    margin: 40px auto 60px auto;
}

/* reservationen */
#form .nores {
    display: block;
}
.reservationen .termine {
  display:flex;
/*  justify-content: space-between;*/
  align-items: center;
  margin-bottom: 12px;
}
.reservationen .termine .btn {
    margin: 0;
    padding:0 0.8rem;
    margin-right: 1rem;
}
.reservationen .termine .savereservation {
    margin: 0;
    padding:0 0.6rem;
}
.reservationen .termine * {
    display:inline-block;
    margin-right: 8px;
}
.reservationen .termine strong {
    width: 220px;
}
.reservationen .termine input {
    width: 38px;
}
.reservationen .termine time {
    width: 180px;
}
.reservation_events {
    width: 100%;
}
.guestlist {
    width: 100%;
    margin: 0 0 12px 0;
}
.guestlist input {
    display:block;
    width:100%;
    background-color: hsla(81.2, 47.8%, 59.4%, 0.16);
    border:0;
    border-bottom: 1px solid green !important;
    padding: 2px;
    height:40px;
    font-size: 1rem;
    margin-right:4px;
}
/* iPhone 414 px */
/* iPad 768 px */
@media screen and (min-width: 660px) {
    .swiper-container {
        /*! width: 551px; */
        /*! box-sizing: content-box; */
        height: 560px;
    }


    #editorial img {
        width:90%;
    }
}
@media screen and (min-width: 760px) {

    main .wrapper {
        padding: 24px
    }
    #home .wrapper {
        flex-direction: row;
    }
    #home .covid {
        width: 60%;
    }
    #home #home_title {
        width:30%;
        margin:12% 8% 24% 8%;
    }
    /*
    .nr h1 {
        text-indent: 1.4rem;
    }
    .nr h1 span {
        position:absolute;
        width:2rem;
        text-align:right;
        margin-left:-4rem;
    }
    */
    #start .wrapper {
        background-image:none;
        background-color: hsla(350  , 100%, 100%, 0.5);
    }

    #start .wrapper img {
        display:block;
        margin: 120px auto 160px auto;
        width:70%;
    }
    .medium {
        font-size: 0.86rem;
        line-height:1.2rem;
    }
    .calendar .wrapper {
        padding-left: 72px;
        padding-right: 72px;
    }

    .calendar .short {
        display:none;
    }
    .calendar .long,
    .calendar .time {
        display:inline-block;
    }
    .swiper-container {
       width: 450px;
       /*!   box-sizing: content-box; */
        height: 420px;
    }
    .nr .wrapper {
        display: flex;
        padding-bottom:24px;
        flex-direction: row-reverse;
    }
    .nr article {
        flex:3;
        width:auto;
        position: relative;
    }
    .nr aside {
        flex:1;
        padding: 0 24px 0 0;
    }
    main aside .termin {
        margin-left: 12px;
    }
    #editorial img {
        width:80%;
    }
    .guestlist {
        display: flex;

    }
    .guestlist input {
        width:31%;
        background-color: hsla(81.2, 47.8%, 59.4%, 0.16);
    }
}

@media screen and (min-width: 900px) {
    html {font-size: 18px;}

    body {
        background-color: #fbfbfc;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='88' height='24' viewBox='0 0 88 24'%3E%3Cg fill-rule='evenodd'%3E%3Cg id='autumn' fill='%237fbc42' fill-opacity='0.29'%3E%3Cpath d='M10 0l30 15 2 1V2.18A10 10 0 0 0 41.76 0H39.7a8 8 0 0 1 .3 2.18v10.58L14.47 0H10zm31.76 24a10 10 0 0 0-5.29-6.76L4 1 2 0v13.82a10 10 0 0 0 5.53 8.94L10 24h4.47l-6.05-3.02A8 8 0 0 1 4 13.82V3.24l31.58 15.78A8 8 0 0 1 39.7 24h2.06zM78 24l2.47-1.24A10 10 0 0 0 86 13.82V0l-2 1-32.47 16.24A10 10 0 0 0 46.24 24h2.06a8 8 0 0 1 4.12-4.98L84 3.24v10.58a8 8 0 0 1-4.42 7.16L73.53 24H78zm0-24L48 15l-2 1V2.18A10 10 0 0 1 46.24 0h2.06a8 8 0 0 0-.3 2.18v10.58L73.53 0H78z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");        
    }
    .wrapper, header nav {
        background-color:#fff;
        width:1024px;
        margin:0 auto;
    }
    header nav .meta {
        display:none;
    }
    header nav .main {
        position: static;
        background-color:#fff;
        width:100%;
        display: flex;
        margin: 0 auto 0 auto;
        box-shadow: none;
        padding:12px 12px;
        justify-content: space-between;
    }

    header nav ul li {
        flex: 1;
        margin:0 6px;
    }

    header nav ul li:first-child {
        margin-left:0;
    }
    header nav ul li:last-child {
        margin-right:0;
    }
    header nav ul li a {
        margin:0;
    }

    footer div.wrapper {
        display: flex;
        justify-content: space-between;
    }
    footer .wrapper .col {
        width: 32%;
    }

    footer nav.wrapper {
        display:block;
        background-color: hsla(90, 48%, 49.8%, 1);
    }
    footer nav ul {
        display:flex;
        padding:12px 0;
    }
    footer nav li {
        flex:1 0 auto;
        text-align: center;
    }
    footer nav li:first-child {
        text-align: left;
    }
    footer nav li:last-child {
        text-align: right;
    }
    footer nav li:first-child a {
        padding-left:2rem;
    }
    footer nav li:last-child a {
        padding-right: 2rem;
    }
    footer nav a span {
        display:inline;
        font-size:1.2rem;
    }


    main article {
        flex:3;
        width:auto;
    }
    main aside {
        flex:1;
        padding: 0 24px 0 0;
    }

    main .nr {
        margin: 0 24px;
    }
    .handy {
        display: none;
    }
    .screen {
        display:flex;
    }
    .screen>a {
        flex:4;
        position:relative;
    }
   .screen>div {
        flex:1;
        padding-left:24px;
        display:flex;
        flex-wrap: wrap;
        align-content: flex-end;
    }
    .screen>div a {
        width:100%;
        display:block;
        text-align:right;
        vertical-align: bottom;
        margin-top:8px
    }
    .screen img {
        display:block;
        width:100%
    }

    .screen .migros {
        width: 98%;
    }

    /* bullshit */    
    .brand-logo img {
        position:absolute;
        bottom: 0;
    }
    
    .swiper-container {
        height: 530px;
        width: 600px;
        /* box-sizing: content-box; */
    }
}

@media screen and (min-width: 1200px) {
    /*body {font-size: 20px;}*/
}