/* mansalva-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: 'Mansalva';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/mansalva-v14-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* tiro-kannada-italic - 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: 'Tiro Kannada';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/tiro-kannada-v6-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* ubuntu-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: 'Ubuntu';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/ubuntu-v20-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* ubuntu-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: 'Ubuntu';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/ubuntu-v20-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* ubuntu-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: 'Ubuntu';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/ubuntu-v20-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/** global / resets **/
html {
    font-size: 10px;
}

:root {
    --h1-size: 3.6rem;
    --h2-size: 3rem;
    --h3-size: 2.4rem;
    --font-size: 2rem;
    --page-width: 144rem;
}

* {
    padding: 0;
    margin: 0;
}

body {
    color: #383838;
    background-color: #fff;
}

ul {
    list-style-type: none;
}

.mceContentBody ul:not([class]), .content ul:not([class]) {
    padding-left: 1.5rem;
    list-style-type: disc;
}

.content p, .mceContentBody p {
    margin: .5rem 0;
}

img {
    border: 0;
}

iframe {
    border: 0;
}

a {
    text-decoration: none;
    color: #cba825;
}

/* body, h1, h2, span, font, td, a { */
body {
    font-size: var(--font-size);
    font-family: Ubuntu, sans-serif;
    font-weight: 300;
    line-height: 1.5em;
}

.sitebody {
    background: #e1ddbf;
}

/** for content editing **/
/* p.readmore a:before {
	content:'\00BB';
	content:'\27EB';
}
*/
.goback, .readmore a, .slider a, .cbutton {
    display: inline-block;
    font: italic 3rem/1em Mansalva;
    color: #cba825;
    padding: .5rem 0;
    border-bottom: 4px double #cba825;
    margin-right: .5rem;
    margin-bottom: .5rem;
}

.cta-button .cbutton {
    margin: 0;
}

.slider a, .goback, .readmore a {
    margin-top: 1em;
}

.splitlist {
    padding-left: 1.6rem;
    list-style-type: disc;
    column-count: 3;
    column-gap: 5.0rem;
    max-width: max-content;
}

@media screen and (max-width: 960px) {
    .splitlist {
        column-count:2;
    }
}

@media screen and (max-width: 480px) {
    .splitlist {
        column-count:1;
    }
}

.bild-links {
    position: relative;
    top: .4rem;
    float: left;
    margin-right: 1.5rem;
}

.bild-rechts {
    position: relative;
    top: .4rem;
    float: right;
    margin-left: 1.5rem;
}

.responsive-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.responsive-video {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 0;
    height: 0;
    overflow: hidden;
}

.preise {
    border-collapse: separate;
    border-spacing: 1rem;
    margin: 0 -1rem;
    width: calc(100% + 2rem);
}

.preise th, .preise-kopf, .preise-zelle, .preise-zeile {
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: .5rem;
}

tr.preise-kopf th.st-head-row {
    padding-top: 10rem;
}

.preise th.st-head-row {
    padding: .5rem 0;
}

table.preise td {
    border-bottom: 1rem solid #E5E5E5;
    padding: .6rem .6rem;
}

.preise .preise-kopf td {
    border-bottom: .2rem solid #2c2c2c;
}

a.bild-links, a.bild-rechts {
    margin: 0;
}

a.bild-links span.zoomin-img {
    right: 1.8rem !important;
    bottom: -.1rem !important;
}

a.bild-rechts span.zoomin-img {
    bottom: -.1rem !important;
}

.clr {
    clear: both;
}

.outline {
    display: none;
}

body#tinymce.mceContentBody, div.content {
}

form#userForm fieldset legend, h1 {
    color: #424037;
    font: italic var(--h1-size)/1.3em "Tiro Kannada";
    margin-bottom: 2rem;
}

.rsform-block[class*="-heading"], h2 {
    color: #424037;
    font: italic var(--h2-size)/1em "Tiro Kannada";
    margin-bottom: 2rem;
}

h3 {
    color: #424037;
    font: normal var(--h2-size)/1em "Tiro Kannada";
    margin-bottom: 2rem;
}

/*** Mainmenu ***/
.top-container {
    z-index: 10;
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
}

.top-helper {
    background: transparent url('../images/pattern-beige.webp') repeat 0 0;
    box-shadow: 0 0 .8rem rgba(0,0,0,0.8);
    border-bottom: 1rem solid rgb(224 206 108 / .95);
}

.top {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/*** Buttons Top ***/
.menu-toggle:before, .email a, .telefon a {
    width: 8.1rem;
    height: 8rem;
    display: flex;
    justify-content: center;
    align-items: center;
    background: transparent url('../images/icon-bg.png') no-repeat 0 0 / contain;
}

.email img, .telefon img {
    position: relative;
    left: -.1rem;
    top: -.2rem;
}

.menu-toggle:before {
    display: inline-flex;
}

main {
    position: relative;
}

.logo img {
    height: 8rem;
    width: auto;
    transition: all 0.2s;
}

.sticky .logo img {
    height: 6.0rem;
}

.menu-toggle {
    font-size: 2.4rem;
    font-weight: 500;
    text-transform: uppercase;
    color: #424037;
    cursor: pointer;
    white-space: nowrap;
}

.menu-toggle:before {
    font-size: 2.4rem;
    position: relative;
    color: #424037;
    margin-right: 1rem;
}

.menuopen .menu-toggle.menu-open:before {
    content: '\e158';
}

/* nav { position:relative;} */
.nav .menu-toggle {
}

.nav-container {
    position: relative;
    display: none;
    background: rgb(255 255 255 / 0.95);
    z-index: 1;
    padding: 4rem 2rem 0;
    overflow: auto;
    max-height: 100vh;
    box-sizing: border-box;
}

.nav-top {
    display: none;
    justify-content: space-between
}

.nav-top .language {
    font-size: 2.4rem;
}

.mainmenu {
    position: relative;
    display: flex;
    justify-content: center;
}

.mainmenu a {
    color: #000;
}

.mainmenu > ul {
    display: flex;
    flex-wrap: wrap;
    gap: 4rem;
    margin: 0 0 2rem;
}

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

.mainmenu .submenu {
}

.mainmenu > ul > li {
    flex: 1;
    position: relative;
}

.mainmenu > ul > li > a {
    font: italic 3rem/1em "Tiro Kannada";
    margin-bottom: 2rem;
    display: block;
    white-space: nowrap;
}

.mainmenu .submenu ul > li > a {
    white-space: nowrap;
    font-size: 1.8rem;
    line-height: 2em;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .1rem;
}

.mainmenu .submenu > ul > li > a:before {
    content: '';
    display: inline-block;
    width: 1.4rem;
    height: 1.6rem;
    background: #f4dd68;
    clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
    margin-right: 1rem;
    position: relative;
    top: .2rem;
}

.mainmenu > ul > li.active > a, .mainmenu > ul > li:hover > a {
}

.mainmenu .submenu ul > li.active > a, .mainmenu .submenu ul > li:hover > a {
    color: #cba825;
}

/*** Language ***/
.language .mod-languages a {
    color: #424037;
}

.language .mod-languages {
    position: relative;
    width: 5.5rem;
    font-size: 2rem;
    height: 2em;
    cursor: pointer;
}

.language .mod-languages ul {
    transition: all .2s;
    pointer-events: none;
    padding: .5rem 1rem;
    border-radius: .5rem;
    position: absolute;
    top: -.4rem;
}

.language .mod-languages li {
    display: none;
    line-height: 2em;
}

.language .mod-languages .lang-active {
    display: block;
    position: relative;
    padding-right: 1.5rem;
}

.language .mod-languages .lang-active:after {
    content: '';
    position: absolute;
    right: 0;
    top: 1.5rem;
    display: block;
    width: .6rem;
    height: .6rem;
    border-right: .1rem solid #fff;
    border-bottom: .1rem solid #fff;
    border-color: #424037;
    transform: rotate(45deg);
}

.language .mod-languages.open {
    cursor: auto;
}

.language .mod-languages.open ul {
    pointer-events: all;
    background: #cba825;
}

.language .mod-languages.open a {
    color: #fff;
}

.language .mod-languages.open li {
    display: block;
}

.language .mod-languages.open .lang-active {
    padding: 0;
}

.language .mod-languages.open .lang-active:after {
    display: none;
}

.lang-active a {
    font-weight: 500;
}

/*** Layout ***/
.pagewidth {
    max-width: var(--page-width);
    margin: auto;
}

.mainframe {
    overflow: hidden;
}

/*** Header ***/
.header-container {
    position: relative;
    max-height: 60rem;
    overflow: hidden;
    display: flex;
    align-items: center;
}

.header {
    width: 100%;
}

.header .browse-button {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 50%;
    width: 2.8rem;
    height: 5.6rem;
    transform: translateY(-2.8rem);
    z-index: 1;
    opacity: 0.75;
    transition: all 0.2s;
    cursor: pointer;
}

.header .browse-button:hover {
    opacity: 1;
}

.header .browse-button:before {
    font-family: Iconia;
    font-size: 5.6rem;
    content: '\e15b';
    color: #fff;
}

.header .slider-right:before {
    content: '\e15c';
}

.header .slider-left {
    left: 6rem;
}

.header .slider-right {
    right: 6rem;
}

.slogan {
    font: italic 4rem/1em "Tiro Kannada";
    color: #fff;
    text-shadow: 0 0 8px rgb(0 0 0 / 0.6);
    position: absolute;
    bottom: 4rem;
    right: max(40px, calc((100vw - var(--page-width)) / 2));
    background: transparent url('../images/deko-bee.svg') no-repeat 0 0;
    padding-left: 10rem;
    z-index: 1;
}

/*** hbottom ***/
.hbottom-container {
    position: relative;
    border-bottom: 1rem solid #fff;
}

.deko-footer:before, .hbottom-container:before {
    content: '';
    display: block;
    height: 12rem;
    left: 0;
    right: 0;
    translate: 0 -50%;
    position: absolute;
    background: transparent url('../images/line.svg') repeat-x 50% 0;
    pointer-events: none;
}

.hbottom {
    position: absolute;
    display: flex;
    top: -97px;
    left: max(0px, calc((100vw - var(--page-width)) / 2 - 10px));
    z-index: 1;
    transform-origin: left center;
}

.hbottom .moduletable {
    position: relative;
    box-sizing: border-box;
    padding-top: 65px;
    text-align: center;
    background: transparent url('../images/wabe.webp') no-repeat 0 0;
    width: 184px;
    height: 209px;
}

.hbottom .linked {
    cursor: pointer;
}

.hbottom .moduletable:after {
    position: absolute;
    content: '';
    display: block;
    width: 36px;
    height: 32px;
    bottom: 50px;
    background: transparent url('../images/deko-bee-black.svg') no-repeat 0 0;
    left: calc(50% - 23px);
}

.hbottom a {
    color: #424037;
}

.hbottom p {
    font: italic 2rem/1em "Tiro Kannada";
}

.hbottom p+p {
    font: 3rem/1em Mansalva;
}

/** Media Buttons **/
.media {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 3.8rem;
}

.media ul {
    padding: 0;
    margin: 0;
    list-style-type: none;
}

.media .iconbuttons li {
    float: right;
    box-sizing: border-box;
    display: block;
    border-radius: 3.8rem;
    background: #cba825;
    max-width: 3.8rem;
    line-height: 3.8rem;
    margin: .3rem 0;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
    color: #ffffff;
    transition: all 1s linear 0s;
    padding: 0 2rem 0 .4rem;
    box-shadow: 0 0 .2rem rgba(0,0,0,0.2);
}

.media .iconbuttons li a {
    color: #ffffff;
}

.media .iconbuttons li:before {
    font-size: 2.2rem;
    display: inline-block;
    margin-right: .5rem;
    position: relative;
    text-align: center;
    width: 3rem;
    top: .3rem;
}

.media .iconbuttons li a:before {
    display: none;
}

.media .iconbuttons li:focus, .media .iconbuttons li:hover {
    max-width: 50rem;
}

/*** Showroom ***/
.sr-module {
    position: relative;
    display: flex;
}

.sr-full-bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.sr-full-bg img {
    opacity: 0;
    visibility: hidden;
    transition: all 1s;
}

.sr-full-bg img.active {
    opacity: 1;
    visibility: visible;
}

.sr-tile {
    box-sizing: border-box;
    position: relative;
    min-height: clamp(200px, 50vh, 500px);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 20px;
    transition: all 0.5s;
    border-right: 1px solid #fff;
}

.sr-tile:last-of-type {
    border: 0;
}

.sr-mc1 .sr-tile {
    flex-basis: 100%;
}

.sr-mc2 .sr-tile {
    flex-basis: calc(100% / 2);
}

.sr-mc3 .sr-tile {
    flex-basis: calc(100% / 3);
}

.sr-mc4 .sr-tile {
    flex-basis: calc(100% / 4);
}

.sr-mc5 .sr-tile {
    flex-basis: calc(100% / 5);
}

.sr-mc6 .sr-tile {
    flex-basis: calc(100% / 6);
}

.sr-tile-bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: none;
}

.sr-tile-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0;
    transition: all 1s;
    background: transparent url('../images/pattern-yellow.webp') no-repeat 0 0 / cover;
}

.active .sr-tile-overlay {
    opacity: 1;
}

.sr-full-bg img, .sr-tile-bg img {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.sr-title {
    font-weight: 500;
    letter-spacing: 1px;
    position: relative;
    color: #fff;
    text-transform: uppercase;
    font-size: 19px;
	text-shadow:0 0 8px rgba(0,0,0,0.8);
}

.sr-content {
    color: #fff;
    position: relative;
    transition: all 0.2s;
    opacity: 0;
}

.sr-tile.active .sr-content {
    opacity: 1;
}

.sr-tile.active .sr-content a {
    color: #fff;
}

@media screen and (max-width: 960px) {
    .sr-full-bg {
        display:none;
    }

    .sr-tile-bg {
        display: block;
    }

    .sr-module {
        flex-wrap: wrap;
    }

    .sr-module .sr-tile {
        flex: 1 0 50%;
    }
}

@media screen and (max-width: 560px) {
    .sr-tile {
        min-height:clamp(200px, 33vh, 400px);
    }

    .sr-module .sr-tile {
        flex: 1 0 100%;
    }
}

/*** Spacer ***/
.spacer {
    display: block;
    height: 12rem;
    background: transparent url('../images/line.svg') repeat-x 50% 0;
    margin: 1rem 0;
}

/*** Shortcutmodules ***/
.shortcutmodules {
    padding: 6rem 4rem 12rem ;
}

.shortcutmodules {
    display: flex;
    flex-wrap: wrap;
    gap: 6rem;
	justify-content:center;
}

.shortcutmodules .moduletable {
    position: relative;
    flex: 0 0 calc(33.33% - 12rem / 3);
    aspect-ratio: 1;
    box-shadow: 2rem 2rem 0 #d8cb7e;
}

.shortcutmodules .moduletable.linked {
    cursor: pointer;
}

.shortcutmodules .moduletable:before {
    z-index: 2;
    position: absolute;
    top: 1rem;
    left: 1rem;
    right: -1rem;
    bottom: -1rem;
    content: '';
    display: block;
    background: transparent url('../images/bg-alpenrose.svg') no-repeat 100% 100% / contain;
}

.shortcutmodules .apfelbluete:before { background-image:url('../images/bg-apfelbluete.svg'); }
.shortcutmodules .kirschbluete:before { background-image:url('../images/bg-kirschbluete.svg'); }
.shortcutmodules .schneerose:before { background-image:url('../images/bg-schneerose.svg'); }
.shortcutmodules .erika:before { background-image:url('../images/bg-erika.svg'); }
.shortcutmodules .himbeere:before { background-image:url('../images/bg-himbeere.svg'); }
.shortcutmodules .loewenzahn:before { background-image:url('../images/bg-loewenzahn.svg'); }
.shortcutmodules .holunder:before { background-image:url('../images/bg-holunder.svg'); }
.shortcutmodules .honigmanufaktur:before { background-image:url('../images/bg-manufaktur.svg'); }
.shortcutmodules .lavendel:before { background-image:url('../images/bg-lavendel.svg'); }

.shortcutmodules .module-image {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.shortcutmodules .module-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.shortcutmodules .moduletable h3 {
    font: var(--h1-size)/1em Mansalva;
    color: #fff;
    position: absolute;
    bottom: 1rem;
    right: 2rem;
    margin: 0;
}

.shortcutmodules .module-content {
	position:relative;
	z-index:3;
    font-weight: 500;
    font-size: 1.8rem;
    opacity: 0;
    position: relative;
    color: #fff;
    background: transparent url('../images/pattern-yellow.webp') repeat 0 0;
    height: 100%;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    padding: 1rem;
    transition: all 0.2s;
}

.shortcutmodules .moduletable:hover .module-content, .shortcutmodules .moduletable:hover .module-content {
    opacity: 1;
}

.shortcutmodules .module-content a {
    color: #fff;
}

/***  Slider ***/
.slider-container {
    background: #eee;
    padding: 0 1rem;
}

.slider {
    padding: 2rem 0;
}

.slider .slick-track {
    display: flex;
}

.slider .slick-slide {
    height: auto;
}

.slider .slickcontainer {
    margin: -1rem;
}

.slider .slickitem {
    background: #fff;
    color: #8b796d;
    text-align: center;
    margin: 1rem;
}

.slider .slick-padding {
}

.slider .image-intro {
}

.slider .item-text {
    padding: 1rem;
}

.slider .slickitem h3 {
    font-weight: normal;
    font-size: 2.8rem;
    margin-bottom: 1rem;
}

.slider .slickitem img {
    width: 100%;
    height: auto;
}

.slider .slickitem strong {
    font-weight: 300;
    font-size: 2.8rem;
    display: inline-block;
    margin: 0.5em 0;
}

.slider .browse-button {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 50%;
    width: 7.2rem;
    height: 7.2rem;
    transform: translateY(-3.6rem);
    z-index: 1;
    border-radius: 99rem;
    background: #adadad;
    opacity: 0.75;
    transition: all 0.2s;
}

.slider .browse-button:hover {
    opacity: 1;
}

.slider .browse-button:before {
    font-family: Iconia;
    font-size: 2.4rem;
    content: '\e15b';
    color: #fff;
}

.slider .slider-right:before {
    content: '\e15c';
}

.slider .slider-left {
    left: -10rem;
}

.slider .slider-right {
    right: -10rem;
}

.sitebody .slick-dots {
    margin-top: 2rem;
}

.sitebody .slick-dots li button:before {
    background: #0f7ab6;
}

.sitebody .slick-dots li.slick-active button:before {
    background: #fff;
    width: 1.2rem;
    height: 1.2rem;
    border: .2rem solid #0f7ab6;
}

/*** Socialwall ***/

.socialwall-container {
	padding:0 1rem 8rem;
}

/*** Contact ***/
.contact-container {
    position: relative;
    padding: 0 1rem 8rem;
}

.contact {
    position: relative;
    z-index: 1;
    display: flex;
}

.address {
    background: #fff;
    padding: 4rem;
    margin-top: 13rem;
    margin-right: -8rem;
    position: relative;
}

.address img {
    max-width:100%;
    height:auto;
}

.map {
    flex-grow: 1;
}

.map p, .map iframe {
    width: 100%;
    height: 100%;
}

/*** Footer ***/
.footer-container {
    position: relative;
    background: #fff;
    padding: 8rem 1rem 4rem;
}

.deko-footer:before {
    top: 0;
}

.footer-container:before {
    position: absolute;
    left: 0;
    bottom: 0;
    content: '';
    display: block;
    width: 234px;
    height: 516px;
    background: transparent url('../images/bg-footer-li.webp') no-repeat 0 0 / contain;
    max-height: 100%;
}

.footer-container:after {
    position: absolute;
    right: 0;
    bottom: 0;
    content: '';
    display: block;
    width: 202px;
    height: 530px;
    background: transparent url('../images/bg-footer-re.webp') no-repeat 100% 0 / contain;
    max-height: 100%;
}

.footer {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: 2rem;
}

.footer a[class*='icon']:before {
    color: #fff;
    font-size: 2rem;
    line-height: 1em;
    display: inline-flex;
    width: 4.2rem;
    height: 4.8rem;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    margin-right: 1rem;
    margin-bottom: 1rem;
    background: #f4dd68;
    clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}

.footer a {
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: .2rem;
    font-size: 1.8rem;
    color: #424037;
}

.footer a:hover, .footer .active a {
    color: #cba825;
}

.footer a:not([class*='icon']) {
    line-height: 2.5em;
}

.footer a:not([class*='icon']):before {
    content: '';
    display: inline-block;
    width: 1.8rem;
    height: 2.0rem;
    background: #f4dd68;
    clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
    margin-right: 1rem;
    position: relative;
    top: .2rem;
}

.footer h3 {
    font: italic normal 2.8rem/1em "Tiro Kannada";
    font-weight: bold;
    font-size: 2.8rem;
    text-transform: none;
    margin-bottom: 3rem;
    color: #424037;
}

/*** Logos ***/
.logos-container {
    padding: 4rem 1rem 2rem;
    background: #666255;
}

.logos .moduletable {
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-wrap: wrap;
}

.logos .moduletable > a, .logos .moduletable > img, .logos .moduletable > p {
    display: inline-block;
    margin: 0 1rem 2rem;
}

.logos img {
    max-width: 100%;
    height: auto;
}

/*** Content ***/
.content-container {
    position: relative;
    padding: 14rem 1rem 4rem;
}

.content-container:before {
    position: absolute;
    left: 0;
    top: 8rem;
    content: '';
    display: block;
    width: 215px;
    height: 525px;
    background: transparent url('../images/bg-left.webp') no-repeat 0 0;
}

.content-container:after {
    z-index: -1;
    position: absolute;
    right: 0;
    bottom: 8rem;
    content: '';
    display: block;
    width: 270px;
    height: 720px;
    background: transparent url('../images/bg-right.webp') no-repeat 0 0;
}

.content {
    position:relative;
}

.content img {
    max-width: 100%;
    height: auto;
}

.items-intro {
    display: flex;
    flex-wrap: wrap;
    gap: 8rem;
    margin-bottom: 4rem;
}

article {
    width: 100%;
}

.default article {
    position: relative;
    display: flex;
    align-items: flex-end;
}

.formResponsive, .default article.item-page {
    position: relative;
    box-sizing: border-box;
    padding: 4rem;
    background: rgb(255 255 255 / .7);
    display: block;
}

.default .article-content {
    background: rgb(255 255 255 / .7);
    height: 100%;
    box-sizing: border-box;
    flex: 0 0 100%;
	padding:4rem;
}

.default .img-intro + .article-content {
    padding: 8rem 4rem 8rem 12rem;
    flex: 0 0 calc(50% + 8rem);
}

.default .img-intro {
    height: calc(100% - 8rem);
    position: relative;
    z-index: 1;
    left: 8rem;
}

.default .img-intro img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.items-intro article:nth-of-type(2n) .img-intro {
    order: 1;
    left: initial;
    right: 8rem;
}

.items-intro article:nth-of-type(2n) .article-content {
    padding: 8rem 12rem 8rem 4rem;
}

.default .w50 {
    width: calc(50% - 4rem);
}

.default .w33 {
    width: calc(33.33% - 16rem / 3);
}

.default .w33, .default .w50 {
    display: flex;
    flex-direction: column;
}

.default .items-intro .w33 .img-intro, .default .items-intro .w50 .img-intro {
    left: initial;
    right: initial;
    margin: 0;
    height: auto;
    order: 0;
}

.default .items-intro .w33 .article-content, .default .items-intro .w50 .article-content {
    padding:4rem;
    flex:0;
}

.img-intro img {
    display: block;
}

.default .img-fulltext img {
    width: 100%;
    height: auto;
}

.mfp-link img {
    display: block;
    width: 100%;
    height: auto;
}

.mfp-link .icon-zoom {
    display: block;
    line-height: 1em;
    color: #fff;
    text-shadow: 0 0 .2rem #000;
    position: absolute;
    bottom: 1rem;
    right: 1rem;
}

ul.psgallery {
    display: block;
    margin: 1em 0;
}

@media screen and (max-width: 960px) {
    .default .items-intro {
        gap:4rem;
    }
    .default .w50 {
        width: calc(50% - 2rem);
    }
    .default .w33 {
        width: calc(50% - 2rem);
    }
}

@media screen and (max-width: 910px) {
    .menu-toggle {
        overflow: hidden;
        width: 7.8rem;
    }

    .top .email {
        display: none;
    }

    .slogan {
        bottom: initial;
        top: 4rem;
    }

    .items-intro article .img-intro {
        left: 0;
        margin-right: -4rem;
    }

    .items-intro article:nth-of-type(2n) .img-intro {
        right: 0;
        margin-left: -4rem;
    }

    .items-intro article .article-content {
        padding: 4rem 2rem 4rem 8rem;
    }

    .items-intro article:nth-of-type(2n) .article-content {
        padding: 4rem 8rem 4rem 2rem;
    }

    .shortcutmodules .moduletable {
        flex: 0 0 calc(50% - 6rem / 2)
    }
}

@media screen and (max-width: 740px) {
    .logo img {
        height: 6.0rem;
    }

    .menu-toggle:before, .email a, .telefon a {
        width: 7.1rem;
        height: 7rem;
    }
}

@media screen and (max-width: 625px) {
    .header {
        margin:0 -10rem;
        width: calc(100% + 20rem);
    }

    .top > .language {
        display: none;
    }

    .nav-container {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        max-height: 100vh;
        box-sizing: border-box;
        box-shadow: 0 0 .8rem rgba(0,0,0,0.8);
        padding-top: 1rem;
    }

    .nav-top {
        display: flex;
        align-items: center;
        margin-bottom: 2rem;
    }

    .nav-top .language {
        position: relative;
        z-index: 1;
    }

    .items-intro {
        gap: 4rem;
    }

    .items-intro article {
        display: block;
    }

    .default .items-intro article .img-intro {
        margin: 0;
        height: auto;
    }

    .default .items-intro article .article-content {
        flex: auto;
        padding: 4rem;
        height: auto;
    }

    .default .w33, .default .w50 {
        width: 100%;
    }

    .default article.item-page {
        padding:4rem 2rem;
    }

    .contact {
        display: block;
    }

    .address {
        text-align: center;
        margin: 0;
    }

    .map {
        height: 35rem;
    }

    .shortcutmodules .moduletable {
        flex: 0 0 100%;
    }
}

@media screen and (max-width: 580px) {
    :root {
        --h1-size:3rem;
    }

    .top > .cta-button {
        display: none;
    }

    .menu-toggle {
        overflow: hidden;
        width: 5.8rem;
        margin-right: 0;
    }

    .menu-toggle:before, .email a, .telefon a {
        width: 6.1rem;
        height: 6rem;
    }

    .sticky .logo img,
    .logo img {
        height: 5rem;
    }

    .hbottom {
        scale: .8;
    }

    .footer-container {
        padding-left:4rem;
        padding-right:1rem;
    }

    .footer .moduletable {
        width: 100%;
    }

}

@media screen and (max-width: 480px) {
    .slogan {
        transform-origin:top right;
        scale: .8;
    }

    .hbottom {
        scale: .7;
    }

    .content-container {
        padding-top: 8rem;
    }

    .default .items-intro article .article-content {
        padding: 2rem;
        height: auto;
    }
}

@media screen and (max-width: 400px) {
    .footer-container {
        padding-left:1rem;
        padding-right:1rem;
    }
    
    .hbottom {
        scale:.62;
    }

    .mainmenu > ul > li {
        flex-basis: 100%;
    }
}

/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*** Flatlist ***/
.flatlist ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    display: flex;
}

.flatlist ul li {
}

.flatlist ul li::after {
    position: relative;
    top: -.1rem;
    content: "|";
    padding-right: 3rem;
}

.flatlist ul li:last-child::after {
    content: none;
    padding-right: 0;
}

/* frontend editor */
div.article_row {
    position: relative;
}

div.contentpaneopen_edit {
    position: absolute;
    top: 0;
    right: 0;
}

div.tip-wrap {
    text-align: left;
    background: #eee;
    border: .1rem dotted #f00;
    padding: 1rem;
}

div.tip-wrap div.tip-title {
    color: #f00;
    font-weight: bold;
    margin-bottom: .5rem;
}

div.reset fieldset, div.remind fieldset, div.login fieldset, div.panel fieldset {
    padding: 1rem;
}

div.login-fields {
    margin-bottom: .5rem;
}

div.login-fields label {
    display: block;
    float: left;
    width: 15rem;
}

div.login-fields input {
    line-height: 1.8em;
    height: 2.4rem;
    padding: .5rem;
}

.ccms_form_element label {
    font-weight: normal !important;
}

div#ui-datepicker-div, div#ui-datepicker-div td, div#ui-datepicker-div span, div#ui-datepicker-div a {
    font: normal 1.2rem/1em Verdana,sans-serif !important;
}

/***** editor *****/
ul.actions {
    padding: 0;
    margin: 0;
    list-style-type: none;
    text-align: right;
}

ul.actions li {
    display: inline-block;
}

.btn-group {
    display: inline-block;
}

.btn-group button {
    color: #fff;
    background: #aaa;
    border: 0;
    padding: .5rem 1rem;
    border-radius: .5rem;
    cursor: pointer;
}

form#adminForm fieldset {
    border: 0;
}

/** RS form **/
p.formRed {
    color: #CF4D4D;
}

p.formDescription {
    font-size: 1rem;
    font-weight: bold;
}

.formContainer {
    border: 0;
    margin-bottom: 4rem;
}

.formRow {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.formRow > div {
    width: calc(50% - 4rem);
}

.formControls div.formBody {
    float: none;
}

.rsform-block[class*="-heading"] {
    margin-top: 2rem;
}

.rsform-block input {
    font: inherit;
}

.rsform-block input:not([size]) {
    width: 100%;
}

.rsform-block input[type="checkbox"], .rsform-block input[type="submit"] {
    width: auto;
}

.rsform-block input[type="checkbox"] {
    margin-right: 1rem;
}

.rsform-block {
    margin-bottom: 1rem;
}

.rsform-block textarea {
    width: 100%;
}

.rsform-block .rsform-submit-button {
    all: initial;
    font: inherit;
    background: #eee;
    padding: 1rem 2rem;
    border-radius: .3rem;
    cursor: pointer;
    -webkit-text-stroke: 0.02rem;
    font-size: 1.8rem;
}

.formValidation {
    display: block;
}

img.ui-datepicker-trigger {
    position: relative;
    top: .3rem;
    left: .5rem;
}

.has-margin-bottom {
    margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
    .formRow > div {
        width:100%;
    }
}

.rsform-block-email2 {
    display: none;
}

/*** contact form ***/
div.contact-form fieldset {
    padding: 1rem;
}

table#recaptcha_table.recaptchatable {
    border: 0 !important;
}

div.contact h3 {
    margin-top: 1rem;
}

/*** acymailing ***/
.acysubbuttons {
    padding-top: 1rem !important;
    text-align: right !important;
}

div.acymailing_module_form p.fieldacyemail input {
    width: 100%;
    padding: .2rem;
}

/*** system message ***/
div.error {
    color: #CF4D4D;
    font-size: 1.6rem;
}

a.close {
    display: none;
}

dl#system-message {
    border: .1rem dotted #CF4D4D;
    padding: 1rem;
    margin-bottom: 2rem;
}

dt.message {
    margin-bottom: 1rem;
    font-weight: bold;
}

/* contact */
div.contact h2 span {
    font-size: 2.4rem;
}

div.contact h3 {
    margin-top: 3rem;
    margin-bottom: 1rem;
}

span.address {
    display: block;
    margin-top: 1rem;
}

p.telephone {
    padding: 1rem 0;
}

div.muted {
    display: none;
}

/* +++++++++++++++++++++++ pagenav +++++++++++++++++++++++  */
.pagination {
    text-align: center;
    margin-top: 1em;
}

.pagenav {
    text-align: right
}

.pagenav ul {
    display: inline-block;
    *display: inline;
    /* IE7 inline-block hack */
    list-style-type: none;
    margin-left: 0;
    margin-bottom: 0;
}

.pagenav li {
    display: inline;
    margin: 0;
    padding: 0
}

.pagenav a,span.pagenav {
    padding: 0 1.4rem;
    margin: 0;
    line-height: 1.9em;
    text-decoration: none;
    border: .1rem solid #ddd;
    border-left: 0 solid #ddd;
    display: inline-block;
    line-height: 1.9em;
}

.pagenav li:first-child a,.pagination-start span {
    -webkit-border-radius: .3rem 0 0 .3rem;
    -moz-border-radius: .3rem 0 0 .3rem;
    border-radius: .3rem 0 0 .3rem;
    border-left: solid .1rem #ddd
}

.pagenav li:last-child a,.pagination-end span {
    -webkit-border-radius: 0 .3rem .3rem 0;
    -moz-border-radius: 0 .3rem .3rem 0;
    border-radius: 0 .3rem .3rem 0;
}

.pagination ul {
    margin: 1rem 1rem 1rem 0;
    padding: 0
}

.pagination li {
    display: inline;
}

.pagination a {
    padding: 0 1.4rem;
    line-height: 2em;
    text-decoration: none;
    border: .1rem solid #ddd;
    border-left: 0 solid #ddd;
    display: inline-block
}

.pagination .active a {
    cursor: default;
}

.pagination span,.pagination span a:hover {
    cursor: default;
    padding: 0 1.4rem;
    line-height: 2em;
}

.pagination li:first-child a {
    border-left-width: .1rem;
    -webkit-border-radius: .3rem 0 0 .3rem;
    -moz-border-radius: .3rem 0 0 .3rem;
    border-radius: .3rem 0 0 .3rem;
}

.pagination li:last-child a {
    -webkit-border-radius: 0 .3rem .3rem 0;
    -moz-border-radius: 0 .3rem .3rem 0;
    border-radius: 0 .3rem .3rem 0;
}

/* Responsive Tabs */
.content .r-tabs {
    border-radius: 0;
    border: 0;
    background: #0864a9;
    padding: 1rem;
}

.content .r-tabs .r-tabs-accordion-title .r-tabs-anchor, .content .r-tabs .r-tabs-nav .r-tabs-tab {
    background: transparent;
}

.content .r-tabs .r-tabs-panel {
    border-radius: 0;
    background: #fff;
}

.content .r-tabs .r-tabs-nav .r-tabs-state-active .r-tabs-anchor {
    border-radius: 0;
}

.content .r-tabs .r-tabs-nav .r-tabs-anchor {
    background: transparent;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .5rem;
    font-weight: bold;
    text-shadow: none;
}

.content .r-tabs .r-tabs-tab.r-tabs-state-active .r-tabs-anchor {
    color: #2C2C2C;
    background: #fff;
}

.content .rtab-name { color:#424037; background:transparent; border-bottom:1px solid #424037; padding:10px 0; }
.content .rtab-icon:before { content:'+'; }
.content .rtab-item.rtab-open .rtab-name { background:transparent; }
.content .rtab-content { background:transparent; border:0; padding:1rem 0; }

/*** JCE ***/
.wf-columns {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
}

/*** easybooking fix ***/
#ebApp .fadeIn {
    opacity: 1;
}

#content .fa:before {
    font-family: FontAwesome!important;
}
