/* poppins-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: 'Poppins';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/poppins-v22-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* poppins-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: 'Poppins';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/poppins-v22-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* poppins-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: 'Poppins';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/poppins-v22-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* poppins-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: 'Poppins';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/poppins-v22-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* poppins-600 - 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: 'Poppins';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/poppins-v22-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* poppins-700 - 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: 'Poppins';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/poppins-v22-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lily-script-one-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: 'Lily Script One';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/lily-script-one-v15-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

.wf-columns {
    display: flex;
    gap: 1rem
}

.wf-columns .wf-column {
    max-width: 100%;
    box-sizing: border-box;
    flex: 1
}

.wf-columns-stack-large,.wf-columns-stack-medium,.wf-columns-stack-small,.wf-columns-stack-xlarge {
    flex-wrap: wrap
}

.wf-columns-align-left {
    justify-content: flex-start
}

.wf-columns-align-center {
    justify-content: center
}

.wf-columns-align-right {
    justify-content: flex-end
}

.wf-columns-layout-1-2>.wf-column:last-child,.wf-columns-layout-2-1>.wf-column:first-child {
    width: calc(100% * 2 / 3.001);
    flex: none
}

.wf-columns-layout-1-1-2>.wf-column:last-child,.wf-columns-layout-1-2-1>.wf-column:nth-child(2),.wf-columns-layout-2-1-1>.wf-column:first-child {
    width: 50%;
    flex: none
}

.wf-columns-layout-1-3>.wf-column:last-child,.wf-columns-layout-3-1>.wf-column:first-child {
    width: 75%;
    flex: none
}

.wf-columns-layout-1-1-3>.wf-column:last-child,.wf-columns-layout-1-3-1>.wf-column:nth-child(2),.wf-columns-layout-2-3>.wf-column:last-child,.wf-columns-layout-3-1-1>.wf-column:first-child,.wf-columns-layout-3-2>.wf-column:first-child {
    width: 60%;
    flex: none
}

.wf-columns-layout-1-1-1-2>.wf-column:last-child,.wf-columns-layout-2-1-1-1>.wf-column:first-child {
    width: 40%;
    flex: none
}

.wf-columns-layout-1-4>.wf-column:last-child,.wf-columns-layout-4-1>.wf-column:first-child {
    width: 80%;
    flex: none
}

.wf-columns-gap-small {
    gap: .5rem
}

.wf-columns-gap-medium {
    gap: 1rem
}

.wf-columns-gap-large {
    gap: 2rem
}

.wf-columns-gap-none {
    gap: 0
}

.wf-columns-align-top {
    align-items: flex-start
}

.wf-columns-align-middle {
    align-items: center
}

.wf-columns-align-bottom {
    align-items: flex-end
}

.wf-columns-align-stretch {
    align-items: stretch
}

@media (max-width: 640px) {
    .wf-columns-stack-small>.wf-column {
        width:100%;
        flex: auto!important
    }
}

@media (max-width: 960px) {
    .wf-columns-stack-medium>.wf-column {
        width:100%;
        flex: auto!important
    }
}

@media (max-width: 1200px) {
    .wf-columns-stack-large>.wf-column {
        width:100%;
        flex: auto!important
    }
}

@media (max-width: 1600px) {
    .wf-columns-stack-xlarge>.wf-column {
        width:100%
    }
}

[data-wf-columns]>div>figure img,[data-wf-columns]>div>figure video {
    object-fit: cover;
    height: calc(100% - 2rem)
}

[data-wf-columns]>div>figure {
    margin: 0;
    display: block;
    position: relative;
    height: 100%
}

[data-wf-columns]>div>figure figcaption {
    text-align: center;
    line-height: 2rem;
    display: inline-block;
    width: 100%
}

[data-wf-columns]>div>figure>a.wfpopup+figcaption {
    pointer-events: none
}

@media all and (-ms-high-contrast:none),(-ms-high-contrast:active) {
    .wf-columns .wf-column {
        margin-left: 1rem
    }

    .wf-columns .wf-column:first-child {
        margin-left: inherit
    }

    .wf-columns .wf-column:last-child {
        margin-right: inherit
    }

    .wf-columns-gap-small .wf-column {
        margin-left: .5rem
    }

    .wf-columns-gap-medium .wf-column {
        margin-left: 1rem
    }

    .wf-columns-gap-large .wf-column {
        margin-left: 2rem
    }

    .wf-columns-gap-none .wf-column {
        margin-left: inherit
    }
}

@media all and (-ms-high-contrast:none) and (max-width: 640px),(-ms-high-contrast:active) and (max-width:640px) {
    .wf-columns-stack-small .wf-column {
        margin-left:inherit;
        margin-right: inherit;
        margin-top: 1rem
    }

    .wf-columns-stack-small .wf-column:first-child {
        margin-top: inherit!important
    }

    .wf-columns-stack-small.wf-columns-gap-none .wf-column {
        margin-top: inherit
    }

    .wf-columns-stack-small.wf-columns-gap-small .wf-column {
        margin-top: .5rem
    }

    .wf-columns-stack-small.wf-columns-gap-medium .wf-column {
        margin-top: 1rem
    }

    .wf-columns-stack-small.wf-columns-gap-large .wf-column {
        margin-top: 2rem
    }
}

@media all and (-ms-high-contrast:none) and (max-width: 960px),(-ms-high-contrast:active) and (max-width:960px) {
    .wf-columns-stack-medium .wf-column {
        margin-left:inherit;
        margin-right: inherit;
        margin-top: 1rem
    }

    .wf-columns-stack-medium .wf-column:first-child {
        margin-top: inherit!important
    }

    .wf-columns-stack-medium.wf-columns-gap-none .wf-column {
        margin-top: inherit
    }

    .wf-columns-stack-medium.wf-columns-gap-small .wf-column {
        margin-top: .5rem
    }

    .wf-columns-stack-medium.wf-columns-gap-medium .wf-column {
        margin-top: 1rem
    }

    .wf-columns-stack-medium.wf-columns-gap-large .wf-column {
        margin-top: 2rem
    }
}

@media all and (-ms-high-contrast:none) and (max-width: 1200px),(-ms-high-contrast:active) and (max-width:1200px) {
    .wf-columns-stack-large .wf-column {
        margin-left:inherit;
        margin-right: inherit;
        margin-top: 1rem
    }

    .wf-columns-stack-large .wf-column:first-child {
        margin-top: inherit!important
    }

    .wf-columns-stack-large.wf-columns-gap-none .wf-column {
        margin-top: inherit
    }

    .wf-columns-stack-large.wf-columns-gap-small .wf-column {
        margin-top: .5rem
    }

    .wf-columns-stack-large.wf-columns-gap-medium .wf-column {
        margin-top: 1rem
    }

    .wf-columns-stack-large.wf-columns-gap-large .wf-column {
        margin-top: 2rem
    }
}

@media all and (-ms-high-contrast:none) and (max-width: 1600px),(-ms-high-contrast:active) and (max-width:1600px) {
    .wf-columns-stack-xlarge .wf-column {
        margin-left:inherit;
        margin-right: inherit;
        margin-top: 1rem
    }

    .wf-columns-stack-xlarge .wf-column:first-child {
        margin-top: inherit!important
    }

    .wf-columns-stack-xlarge.wf-columns-gap-none .wf-column {
        margin-top: inherit
    }

    .wf-columns-stack-xlarge.wf-columns-gap-small .wf-column {
        margin-top: .5rem
    }

    .wf-columns-stack-xlarge.wf-columns-gap-medium .wf-column {
        margin-top: 1rem
    }

    .wf-columns-stack-xlarge.wf-columns-gap-large .wf-column {
        margin-top: 2rem
    }
}

@supports (not (scale: -1)) and (-webkit-hyphens:none) {
    .wf-columns .wf-column {
        margin-left:1rem
    }

    .wf-columns .wf-column:first-child {
        margin-left: inherit
    }

    .wf-columns .wf-column:last-child {
        margin-right: inherit
    }

    .wf-columns-gap-small .wf-column {
        margin-left: .5rem
    }

    .wf-columns-gap-medium .wf-column {
        margin-left: 1rem
    }

    .wf-columns-gap-large .wf-column {
        margin-left: 2rem
    }

    .wf-columns-gap-none .wf-column {
        margin-left: inherit
    }

    @media (max-width: 640px) {
        .wf-columns-stack-small .wf-column {
            margin-left:inherit;
            margin-right: inherit;
            margin-top: 1rem
        }

        .wf-columns-stack-small .wf-column:first-child {
            margin-top: inherit!important
        }

        .wf-columns-stack-small.wf-columns-gap-none .wf-column {
            margin-top: inherit
        }

        .wf-columns-stack-small.wf-columns-gap-small .wf-column {
            margin-top: .5rem
        }

        .wf-columns-stack-small.wf-columns-gap-medium .wf-column {
            margin-top: 1rem
        }

        .wf-columns-stack-small.wf-columns-gap-large .wf-column {
            margin-top: 2rem
        }
    }

    @media (max-width: 960px) {
        .wf-columns-stack-medium .wf-column {
            margin-left:inherit;
            margin-right: inherit;
            margin-top: 1rem
        }

        .wf-columns-stack-medium .wf-column:first-child {
            margin-top: inherit!important
        }

        .wf-columns-stack-medium.wf-columns-gap-none .wf-column {
            margin-top: inherit
        }

        .wf-columns-stack-medium.wf-columns-gap-small .wf-column {
            margin-top: .5rem
        }

        .wf-columns-stack-medium.wf-columns-gap-medium .wf-column {
            margin-top: 1rem
        }

        .wf-columns-stack-medium.wf-columns-gap-large .wf-column {
            margin-top: 2rem
        }
    }

    @media (max-width: 1200px) {
        .wf-columns-stack-large .wf-column {
            margin-left:inherit;
            margin-right: inherit;
            margin-top: 1rem
        }

        .wf-columns-stack-large .wf-column:first-child {
            margin-top: inherit!important
        }

        .wf-columns-stack-large.wf-columns-gap-none .wf-column {
            margin-top: inherit
        }

        .wf-columns-stack-large.wf-columns-gap-small .wf-column {
            margin-top: .5rem
        }

        .wf-columns-stack-large.wf-columns-gap-medium .wf-column {
            margin-top: 1rem
        }

        .wf-columns-stack-large.wf-columns-gap-large .wf-column {
            margin-top: 2rem
        }
    }

    @media (max-width: 1600px) {
        .wf-columns-stack-xlarge .wf-column {
            margin-left:inherit;
            margin-right: inherit;
            margin-top: 1rem
        }

        .wf-columns-stack-xlarge .wf-column:first-child {
            margin-top: inherit!important
        }

        .wf-columns-stack-xlarge.wf-columns-gap-none .wf-column {
            margin-top: inherit
        }

        .wf-columns-stack-xlarge.wf-columns-gap-small .wf-column {
            margin-top: .5rem
        }

        .wf-columns-stack-xlarge.wf-columns-gap-medium .wf-column {
            margin-top: 1rem
        }

        .wf-columns-stack-xlarge.wf-columns-gap-large .wf-column {
            margin-top: 2rem
        }
    }
}

[data-wf-columns].uk-flex,[data-wf-columns].uk-flex-gap-small {
    gap: .5rem
}

[data-wf-columns].uk-flex-gap-medium {
    gap: 1rem
}

[data-wf-columns].uk-flex-gap-large {
    gap: 2rem
}

[data-wf-columns].uk-flex-gap-none {
    gap: 0
}

[data-wf-columns].row {
    gap: .5rem;
    margin: 0
}

[data-wf-columns].row>[class*=col] {
    padding: 0
}

[data-wf-columns].flex-gap-sm {
    gap: .5rem
}

[data-wf-columns].flex-gap-md {
    gap: 1rem
}

[data-wf-columns].flex-gap-lg {
    gap: 2rem
}

[data-wf-columns].flex-gap-none {
    gap: 0
}

[data-wf-columns].flex-top {
    align-items: flex-start
}

[data-wf-columns].flex-middle {
    align-items: center
}

[data-wf-columns].flex-bottom {
    align-items: flex-end
}

[data-wf-columns].flex-stretch {
    align-items: stretch
}

figure[data-wf-figure] {
    display: table;
    margin-block-start:inherit;margin-block-end:inherit;margin-inline-start:inherit;margin-inline-end:inherit}

figure[data-wf-figure] figcaption {
    display: table-caption;
    caption-side: bottom
}

/** global / resets **/
:root {
    --pfs: 24px;
    --spps: 36px;
    --h1fs: 42px;
    --ch1fs: 55px;
    --h2fs: 36px;
    --h3fs: 24px;
    --h4fs: 20px;
    --page-width: 1280px;
    --hff: "Lily Script One";
    --pff: "Poppins";
    --cff: "Lily Script One";
    --pf: normal var(--pfs)/1.5em var(--pff);
    --h1f: normal var(--h1fs)/1em var(--hff);
    --h2f: normal var(--h2fs)/1em var(--hff);
    --h3f: normal var(--h3fs)/1em var(--hff);
    --h4f: normal var(--h4fs)/1em var(--hff);
    --gap: 40px;
    --dgap: calc(var(--gap) * 2);
    --hgap: calc(var(--gap) / 2);
    --h2gap: calc(var(--gap) / 4);
}

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

body {
    color: #826E61;
    background-color: #fff;
}


.sitebody {
    background:transparent url('../images/deko-pattern.jpg') repeat 0 0;
}

ul {
    list-style-type: none;
}

.mceContentBody ul:not([class]), .content ul:not([class]) {
    list-style-type: none;
    display: flex;
    flex-wrap: wrap;
    gap: var(--h2gap) var(--hgap);
}

.content ul:not([class]) li {
    display: flex;
    align-items: center;
    gap: var(--hgap);
    color: #826E61;
}

.content ul:not([class]) li:before {
    font-family: Iconia;
    content: '\e15c';
    font-size: 15px;
    color: #9F1823;
    -webkit-text-stroke:1px;
    font-weight:bold;
}

.tpl-shifted .content ul:not([class]) li:before {
    font-size: 28px;
}

.tpl-shifted .content ul:not([class]) li {
    color: inherit;
}

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

img {
    border: 0;
}

iframe {
    border: 0;
}

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

/* body, h1, h2, span, font, td, a { */
body {
    font: var(--pf);
}

/** for content editing **/
/* p.readmore a:before {
	content:'\00BB';
	content:'\27EB';
}
*/
.goback, .cbutton {
    display: inline-block;
    color: #9F1823 !important;
    border: 1px solid #9F1823;
    background: #fff;
    font-weight: bold;
    border-radius: 999px;
    padding: 10px 20px;
    margin: calc(1em + 1px) 6px 6px 1px;
    transition: box-shadow 0.2s;
    text-transform: uppercase;
    letter-spacing: 2px;
    line-height: 1em;
    font-size: 18px;
}

.goback:hover, .cbutton:hover {
    border-width: 2px;
    box-shadow: inset 0 0 1px 1px #9F1823;
    margin: 1em 5px 5px 0;
}

.splitlist {
    padding-left: 16px;
    list-style-type: disc;
    column-count: 3;
    column-gap: 50px;
    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: 4px;
    float: left;
    margin-right: 15px;
}

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

.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: 10px;
    margin: 0 -10px;
    width: calc(100% + 20px);
}

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

tr.preise-kopf th.st-head-row {
    padding-top: 100px;
}

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

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

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

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

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

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

.clr {
    clear: both;
}

.outline {
    display: none;
}

body#tinymce.mceContentBody, div.content {
}

form#userForm fieldset legend, h1 {
    color: #9F1823;
    font: var(--h1f);
    margin-bottom: 20px;
}

.rsform-block[class*="-heading"], h2 {
    color: #9f1823;
    font: var(--h2f);
    margin-bottom: 20px;
}

h3 {
    color: #9f1823;
    font: var(--h3f);
    margin-bottom: 20px;
}

/*** Mainmenu ***/
.top-container {
    z-index: 10;
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    transition: all 0.2s;
    background:#9F1823;
}

.menuopen .top-container {
}

.menuopen .top-container:before {
    opacity: 0;
}

.top-helper {
    padding: 0 10px;
}

.top-spacer {
    height:90px;
}

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

.top, .top a {
    color: rgb(255 255 255 / 100%);
}

.top .language .mod-languages .lang-active:after {
    border-color: #fff;
}

.telefon a:before, .email a:before {
    display: none;
}

@media screen and (max-width: 800px) {
    .telefon a, .email a {
        display:block;
        width: 32px;
        overflow: hidden;
        white-space: nowrap
    }

    .telefon a:before, .email a:before {
        display: inline-block;
        font-size: 32px;
        margin-right: 20px;
    }
}

main {
    position: relative;
}

.logo {
    background:#fff;
    padding:var(--hgap) var(--gap);
    margin-bottom:-100px;
    transition:all 0.2s;
}

.logo img {
    height: 150px;
    width: auto;
    transition: all 0.2s;
    display: block;
}

.menuopen .logo,
.sticky .logo {
    margin-bottom:-30px;
    padding:10px 20px;
}
.menuopen .logo img,
.sticky .logo img {
    height: 80px;
}

@media screen and (max-width:960px) {
    .logo img { height: 100px; }
    .logo { margin-bottom:-60px; }
}

@media screen and (max-width:860px) {
    .logo { margin-bottom:-60px; }
}

@media screen and (max-width: 420px) {
    .menuopen .logo img,
    .sticky .logo img,
    .logo img {
        height:60px;
    }
    .menuopen .logo,
    .sticky .logo,
    .logo { margin-bottom:-20px; }
}

.menu-toggle {
    font-size: 28px;
    cursor: pointer;
    white-space: nowrap;
    display: flex;
    align-items: center;
    text-transform:uppercase;
    letter-spacing:2px;
}

.menu-toggle:before {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    position: relative;
    top: 1px;
    margin-right: 10px;
}

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

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

.nav-container {
    position: relative;
    display: none;
    z-index: 1;
    padding: var(--gap);
    padding-top:60px;
    overflow: auto;
    max-height: 100vh;
    box-sizing: border-box;
}

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

.nav-top .language {
    font-size: 24px;
}

.nav-top, .nav-top a {
    color: #fff;
}

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

.mainmenu a {
    color: #fff;
}

.mainmenu > ul {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap);
}

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

.mainmenu .submenu {
    margin-top: var(--hgap);
}

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

.mainmenu > ul > li > a {
    font: var(--h1f);
    font-size: 36px;
    display: block;
    line-height: 40px;
    white-space: nowrap;
}

.mainmenu .submenu ul > li > a {
    white-space: nowrap;
    font-size: 22px;
    line-height: 2em;
}

.mainmenu .submenu > ul > li > a:before {
    font-family: Iconia;
    content: '\e15c';
    padding-right: 20px;
    color: rgb(255 255 255 / 50%);
    transition: all 0.2s;
    font-size: 16px;
}

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

.mainmenu .submenu ul > li > a {
    text-transform: none;
}

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

/*** Top Icons ***/
.top-icons ul {
    display: flex;
    align-items: center;
    gap: var(--gap);
}

.top-icons a {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    aspect-ratio: 1;
    border-radius: 999px;
    background:#fff;
    padding: 10px;
}

.top-icons img {
    display: block;
}

.top-icons .image-title {
    opacity: 0;
    position: absolute;
    top: calc(100% + 30px);
    left: 50%;
    translate: -50%;
    border-radius: 999px;
    padding: 10px;
    transition: all 0.2s;
    visibility: hidden;
    background:#9F1823;
}

.top-icons a:hover .image-title {
    opacity: 1;
    visibility: visible;
}

.menuopen .top-icons a:hover .image-title {
    visibility: hidden;
}

/*** Language ***/
.language .mod-languages a {
    font-size: 28px;
}

.language .mod-languages {
    position: relative;
    width: 75px;
    font-size: 20px;
    height: 2em;
    cursor: pointer;
    text-transform:uppercase;
    letter-spacing:2px;
}

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

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

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

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

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

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

.nav-top .language .mod-languages.open ul {
    background: #9f1823;
}

.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;
}

.contact.pagewidth, .tpl-shifted .content.pagewidth {
}

.tpl-shifted.fullarticle .pagewidth {
    /* max-width: var(--page-width); */
}

.mainframe {
    overflow: hidden;
}

/*** Header ***/
.header-container {
    position: relative;
    max-height: 800px;
    overflow: hidden;
    display: flex;
    align-items: center;
    translate: none!important;
}

.ribbon {
    height:22px;
    background:transparent url('../images/deko-porte.svg') repeat-x 0 0;
}

.header {
    width: 100%;
}

.header img { display:block; }

.header .browse-button {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 50%;
    width: 36px;
    height: 72px;
    transform: translateY(-36px);
    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: 72px;
    content: '\e15b';
    color: #fff;
}

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

.header .slider-left {
    left: 60px;
}

.header .slider-right {
    right: 60px;
}

.header .slickcontainer > .slickitem:not(:first-child) {
    display: none;
}

.overlay {
    position: absolute;
    bottom: 80px;
    left: 120px;
}

.overlay h3 {
    color: #fff;
    font: var(--pf);
    font-size: 42px;
    font-weight: 300;
}

.overlay {
    color: #fff;
    font: var(--h1f);
    font-size: 64px;
    text-shadow:0 0 8px rgb(0 0 0 / 50%);
}

/*** Header Bottom ***/
.h-bottom-container {
    position: relative;
    z-index: 1;
    padding: 0 var(--hgap);
}

.h-bottom {
    display: flex;
    justify-content: flex-end;
}

.h-bottom-helper {
    position: absolute;
    display: flex;
    gap: var(--gap);
    translate: 0 calc(-50% + 5px);
    justify-content: flex-end;
}

.ss {
    position: relative;
    background: transparent url('../images/bg-green.jpg') repeat 0 0;
    border-radius: 999px;
    padding: 10px;
    width: 180px;
    align-self: center;
}

.ss ul {
    display: flex;
    justify-content: space-between;
    background: rgb(246 244 239 / 80%);
    border-radius: 999px;
}

.ss ul:before {
    content: '';
    display: block;
    position: absolute;
    top: 10px;
    left: 10px;
    width: 70px;
    height: 70px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 0 8px rgba(0,0,0,0.3);
    transition: all 0.2s;
}

.ss.hover-winter ul:before, .sp-winter .ss ul:before {
    margin-left: calc(100% - 90px);
}

.ss.hover-summer ul:before {
    margin-left: 0;
}

.ss li a {
    display: inline-block;
    position: absolute;
    z-index: 2;
    bottom: -2em;
    text-transform: uppercase;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 2px;
}

.ss li:first-of-type a {
    left: 0;
    color: #D3A549;
}

.ss li:last-of-type a {
    right: 0;
    color: #9f1823;
}

.ss li:first-of-type:before, .ss li:last-of-type:before {
    position: relative;
    content: '';
    display: block;
    width: 70px;
    height: 70px;
    background: transparent url('../images/icon-summer.svg') no-repeat 50%;
    cursor: pointer;
}

.ss li:last-of-type:before {
    background: transparent url('../images/icon-winter.svg') no-repeat 50%;
}

/*** CTA Button ***/
.cta-button {
    width: 151px;
    height: 151px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    background: transparent url('../images/bg-cta-button.svg') no-repeat 0 0;
    line-height: 1em;
}

.cta-button a {
    font:var(--h1f);
    color: #fff;
    font-size: 24px;
    font-weight: normal;
}

.cta-button p:first-of-type+p a {
    font-size: 32px;
}

/***  Slider ***/
.slider-container {
    position: relative;
    padding: var(--gap) var(--gap);
    background:transparent url('../images/deko-pattern.jpg') repeat 0 0;
}

.slider-container:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    background:rgb(255 255 255 / 40%);
}

.slider {
    padding: calc(var(--gap) / 1) 0;
}

.slider .moduletable {
    clear:both;
}

.slider .moduletable:first-of-type:before {
    content:'';
    display:block;
    float:left;
    width: 119px;
    height: 233px;
    background: transparent url('../images/deko-signet.svg') no-repeat 0 0;
    margin-right:20px;
}

.slider h1 {
    color: #9F1823;
    font-size: var(--ch1fs);
    max-width: 800px;
    padding-top:40px;
}

.slider h4 {
    text-transform: uppercase;
    font-size: 18px;
    line-height:1.3em;
    letter-spacing: 2px;
    color: #B7866C;
}

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

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

.slider .slickcontainer {
    margin: calc(var(--gap) / -2);
}

.slider .slickitem {
    margin: calc(var(--gap) / 2);
}

.slider .slick-padding {
}

.slider .image-intro {
    position: relative;
    padding: var(--hgap);
}

.slider .image-intro:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    background: transparent url('../images/deko-pattern-dark.jpg') no-repeat 50% / cover;
    opacity: 0;
    transition: all 0.5s;
}

.slider .slickitem:hover .image-intro:before {
    opacity: .5;
}

.slider .item-text {
    position: relative;
    display: block;
    margin-top: calc(var(--gap) * -1);
}

.slider a {
    display: inline-block;
    padding: 10px;
    background: #826E61;
    color: #fff;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 2px;
}

.slider .slickitem h3 {
    font-weight: normal;
    font-size: 28px;
    margin-bottom: 10px;
}

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

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

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

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

.slider .browse-button:before {
    font-family: Iconia;
    font-size: 72px;
    content: '\e15b';
    color: #72310B;
}

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

.slider .slider-left {
    left: -70px;
}

.slider .slider-right {
    right: -70px;
}

.sitebody .slick-dots {
    margin-top: 20px;
}

.sitebody .slick-dots li button:before {
    background: #9F1823;
}

.sitebody .slick-dots li.slick-active button:before {
    background: #fff;
    border: 2px solid #9F1823;
}

/*** Imagefilm ***/
.imagefilm-container {
    padding: var(--dgap) var(--gap) 180px;
}

.imagefilm { 
    position:relative;
}

.imagefilm .video {
    padding: var(--hgap);
}

.imagefilm img,
.imagefilm video {
    display: block;
    aspect-ratio: 16 / 9;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.imagefilm h3 {
    display: inline-block;
    padding: 20px 30px;
    background: #9F1823;
    color: #fff;
    font: var(--pf);
    line-height: 1.8em;
    font-weight:bold;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 3px;
}

.imagefilm .moduletable + .moduletable {
    margin-top: calc(var(--gap) * -1.5);
    color: #826E61;
}

.imagefilm .moduletable + .moduletable p {
    line-height: 1.4em;
    font-size: var(--spps);
}

/*** Highlights ***/
.sw-container,
.highlights-container {
    padding: var(--dgap) var(--gap);
    background: rgb(255 255 255 / 40%);
}

.highlights-heading:has(h1) {
    text-align: center;
    margin-bottom: 60px;
}

.highlights-heading h1 {
    color: #9f1823;
}

.highlights-modules {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 40px;
}

.highlights-modules .module:not(.bild) .module-image {
    width: 180px;
    aspect-ratio: 1;
    border-radius: 999px;
    background:#9F1823;
    padding: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    position:relative;
}

.highlights-modules .module:not(.bild) .module-image:before {
    content:'';
    display:block;
    position:absolute;top:0;left:0;right:0;bottom:0;
    border-radius:999px;
    margin:10px;
    border:2px dashed #b2a59c;
}

.highlights-modules img {
    display: block;
    width: 70px;
    height: auto;
    max-height:70px;
}

.highlights-modules .bild img {
    width: 180px;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 999px;
    border: 10px solid #9F1823;
}

.highlights-modules h3 {
    font: var(--pf);
    font-size: 18px;
    color: #9F1823;
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom:var(--h2gap);
}

.highlights-modules .module {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    text-align: center;
    font-size: 16px;
    line-height: 1.3em;
    color: #826E61;
}
.highlights-modules .module a {
    color:#826E61;
}

.highlights-modules .linked {
    cursor:pointer;
}

@media screen and (max-width: 1200px) {
    .highlights-modules {
        grid-template-columns:repeat(3, 1fr);
    }
}

@media screen and (max-width: 768px) {
    .highlights-modules {
        grid-template-columns:repeat(2, 1fr);
    }
}

@media screen and (max-width: 500px) {
    .highlights-modules {
        grid-template-columns:repeat(1, 1fr);
    }
}

@media screen and (max-width: 480px) {
    .highlights-modules .module {
        flex-direction:column;
        text-align: center;
    }
}

/*** Socialwall ***/

.sw .moduletable:not(:last-of-type) {
	margin-bottom:var(--gap);
}

/*** Contact ***/
.contact-container {
    position: relative;
    padding: var(--dgap) var(--gap);
}

.contact {
    position: relative;
}

.address {
    margin-top: calc(var(--hgap) * -1);
    font-size: 28px;
    line-height:1.3em;
    color: #826E61;
}

.address h3 {
    display: inline-block;
    padding: 20px 30px;
    background: #9F1823;
    color: #fff;
    font: var(--pf);
    font-weight:bold;
    line-height: 1.8em;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 2px;
    margin-bottom:var(--gap);
}

.address h4 {
    color: #9F1823;
    font-family:var(--hff);
    font-size: var(--ch1fs);
    font-weight:normal;
}

.address a {
    color: #9F1823;
}

.map {
    border: var(--hgap) solid rgb(255 255 255 / 40%);
}

.map p, .map iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 9;
    min-height: 400px;
    display: block;
}

/*** Footer ***/
.footer-container {
    background: rgb(255 255 255 / 40%);
    padding: var(--dgap) var(--gap);
}

.footer {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px;
}

.footer a[class*='icon']:before {
    color: #fff;
    font-size: 32px;
    display: inline-flex;
    width: 72px;
    aspect-ratio:1;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    border-radius: 999px;
    margin-right: 10px;
    margin-bottom: 10px;
    background: #9F1823;
}

.footer a {
    font-size: 24px;
    color: #826E61;
    transition: all 1s;
}

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

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

.footer a:not([class*='icon']):before {
    font-family: Iconia;
    content: '\e15c';
    padding-right: 10px;
    color: #9F1823;
    -webkit-text-stroke:1px;
}

.footer h3 {
    display: inline-block;
    padding: 15px 30px;
    background: #9F1823;
    color: #fff;
    font: var(--pf);
    font-weight:bold;
    line-height: 2em;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 2px;
}

/*** Logos ***/
.logos-container {
    padding: var(--dgap) var(--gap) 80px;
    background: #BBAEA5;
}

.logos {
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--gap);
}

.logos p:has(img) {
    position: relative;
}

.logos p:has(img):before {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    content: '';
    background: #BBAEA5;
    z-index: 1;
    mix-blend-mode: color;
    transition: all 0.5s;
	pointer-events:none;
}

.logos p:has(img):hover:before {
    opacity: 0;
}

.logos img {
    display: block;
    max-width: 100%;
    height: auto;
    filter: grayscale(1);
}

/*** CTA Leiste ***/
.cta-bar-container {
    z-index: 1;
    position: fixed;
    bottom: -50px;
    left: 0;
    right: 0;
    background: #9F1823;
    transition: all 1s;
    padding: 8px 10px 5px;
}

.sticky .cta-bar-container {
    bottom: 0;
}

.cta-bar {
    max-width: var(--page-width);
    margin: auto;
}

.cta-bar ul {
    display: flex;
    gap: var(--dgap);
}

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

.cta-bar a {
    display: flex;
    align-items: center;
    gap: var(--hgap)
}

.cta-bar, .cta-bar a {
    color: #fff;
    font-size: 16px;
    text-transform: uppercase;
    letter-spacing: 1px;
    line-height: 1em;
}

.cta-bar a:before {
    font-size: 24px;
    padding-right: 10px;
    vertical-align: middle;
    position: relative;
    top: -3px;
}

@media screen and (max-width: 480px) {
    .cta-bar li:nth-of-type(3) {
        display:none;
    }
}

/*** Content ***/
.content-container {
    position: relative;
    padding: var(--gap) var(--gap) 200px;
}

.contact-container:before,
.imagefilm-container:before,
.content-container:before {
    content:'';display:block;
    position:absolute;right:0;bottom:0;
    width:100%;
    height:300px;
    transform:translate(20%);
    background:transparent url('../images/deko-mountain-re.png') no-repeat 100% 100% / contain;
    background-size:
}

.content-container {
    padding-top: clamp(40px, 10%, 120px);
}

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

/*** Shifted Content Template ***/
.items-leading-container {
    margin-bottom: var(--gap);
}

.tpl-shifted .items-leading {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap);
}

.tpl-shifted .items-leading article {
    flex: 0 0 calc(50% - var(--hgap));
}

.tpl-shifted.leading .items-leading article {
    flex: 0 0 100%;
}

.tpl-shifted .items-intro {
    display: flex;
    flex-wrap: wrap;
    gap: var(--dgap);
}

.tpl-shifted .items-intro article {
    flex: 0 0 calc(50% - var(--gap));
}

.tpl-shifted .items-intro article:nth-of-type(2n+2) {
    position: relative;
    margin-top: -20%;
}

.tpl-shifted.leading .items-intro article:nth-of-type(2n+2) {
    margin-top: 25%;
    margin-bottom: -25%;
}

.tpl-shifted.leading .items-intro {
    padding-bottom: 25%;
}

.default .items-leading h1:before, .tpl-shifted .items-leading h1:before, .fullarticle h1:before {
    content: '';
    display: block;
    width: 119px;
    height: 233px;
    background: transparent url('../images/deko-signet.svg') no-repeat 0 0;
    position:absolute;
    top:-50px;
    left:-160px;
}

.default .items-leading h1:before, .slider h1:before, .tpl-shifted .items-leading h1:before, .fullarticle h1:before {
    margin-bottom: var(--hgap );
}

.default .items-leading h1, .tpl-shifted .items-leading h1, .fullarticle h1 {
    color: #9f1823;
    font-size: var(--ch1fs);
}

.tpl-shifted .items-leading h4 {
    font-size: 18px;
    color: #826E61;
    opacity: .6;
    margin-bottom: 1em;
    line-height:1.3em;
}

.tpl-shifted .article-image:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    background:transparent url('../images/deko-pattern-dark.jpg') no-repeat 0 0;
    opacity: 0;
    transition: all 0.5s;
}

.tpl-shifted .article-image {
    position: relative;
    padding: var(--hgap);
}

.article-image.linked {
    cursor:pointer;
}

.tpl-shifted article .article-image:after {
    content: '';
    display: block;
    width: 150px;
    height: 137px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform:translate(-50%, -50%);
    background: transparent url('../images/deko-signet-round.svg') no-repeat 0 0 / cover;
    transition: all 0.5s;
    opacity: 0;
}

.tpl-shifted article:hover .article-image:before, .tpl-shifted article:hover .article-image:after {
    opacity: .8;
}

.tpl-shifted .article-image img {
    display: block;
}

.tpl-shifted .items-intro h1 {
    font: var(--pf);
    font-size: 18px;
    line-height: 1em;
    background: #9f1823;
    display: inline-block;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #fff;
    padding: 20px;
}

.tpl-shifted .items-intro .article-content {
    font-size: var(--spps);
    line-height: 1.3em;
    color: #826E61;
}

.tpl-shifted .items-intro .page-header {
    margin-top: calc(var(--hgap) * -1);
}

.standard .readmore a, .default .readmore a, .tpl-shifted .readmore a {
    padding: 0;
    font-size: 26px;
    background: 0;
    color: #9F1823!important;
    letter-spacing:1px;
    font-style:italic;
}

.standard .readmore a:before, .default .readmore a:before, .tpl-shifted .readmore a:before {
    content: '\e15c';
    font-family:Iconia;
    font-weight:bold;
    -webkit-text-stroke:1px;
    display: inline-block;
    width: 25px;
    height: 20px;
    margin-right: var(--hgap);
    font-style:normal;
}

/*** Default Content Template ***/
.default .items-intro article {
    padding: var(--hgap);
    background: rgb(255 255 255 / 40%);
    margin-bottom: var(--gap);
    color: #826E61;
}

.default .items-intro h1 {
    display: inline-block;
    padding: 10px;
    background: #9F1823;
    color: #fff;
    font: var(--pf);
    line-height: 2em;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 2px;
    line-height:1.5em;
}

.default .items-intro .page-header {
    position: relative;
    margin-left: calc(var(--hgap) * -1);
    margin-top: calc(var(--hgap) * -1);
}

.default .items-intro h4 {
    font-size: 20px;
    font-weight: normal;
    text-transform: uppercase;
    color: #9F1823;
    margin-bottom: .5em;
}

.default .sis-frame button {
    width: auto;
    height: auto;
    margin-top: 0;
    translate: 0 -50%;
}

.default .sis-frame button:before {
    font-family: Iconia;
    font-size: 72px;
}

.default .sis-frame button:first-of-type:before {
    content: "\e15b";
}

.default .sis-frame button:last-of-type:before {
    content: "\e15c";
}

/*** Standard Content Template ***/
.standard .items-leading-container {
    margin-bottom: var(--gap);
}

.standard .items-leading, .standard .items-intro {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap);
}

.standard article {
    flex-basis: 100%;
}

.standard .centered {
    text-align: center;
}

.standard .w50 {
    width: calc(50% - var(--gap) / 2);
}

.standard .w33 {
    width: calc(33.33% - var(--gap) * 2 / 3);
}

.standard .article-content {
    z-index: 1;
}

.standard .img-intro {
    position: relative;
    z-index: 1;
    box-sizing: border-box;
    width: calc(33.33% - var(--gap) * 2 / 3);
    margin-bottom: 5px;
}

.standard .img-intro-left {
    float: left;
    margin-right: var(--gap);
}

.standard .img-intro-right {
    float: right;
    margin-left: var(--gap);
}

.standard .img-intro + .article-content > h2 {
    text-align: left;
}

.standard .w33 .img-intro-left, .standard .w50 .img-intro-left {
    margin: 0 0 10px;
    float: none;
    width: 100%;
}

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

/*** Misc content styles ***/
.linked .img-intro {
    cursor: pointer;
}

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

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

.item-separator, div.items-row {
    clear: both;
}

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

.icon-list {
    margin: 1em 0;
}

.icon-list li:has(img), .icon-list li[class^="icon"] {
    display: flex;
    gap: 20px;
    align-item: center;
    padding: 1em 0;
    border-bottom: 1px solid #000;
}

.icon-list li[class^="icon"]:before {
    display: block;
    font-size: 28px;
    width: 28px;
}

.icon-list li:has(img) img {
    width: 28px;
    height: auto;
}

.icon-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: space-around;
    list-style-type: none;
    padding: 0;
}

.icon-bar li {
    text-align: center;
}

.icon-bar img {
    display: block;
    margin: .5em auto;
}

@media screen and (max-width: 960px) {
    .top-icons ul {
        gap:var(--hgap);
    }

    .overlay h3 {
        font-size: 32px;
        margin-bottom: 0;
    }

    .overlay {
        font-size: 48px;
    }

    .standard .w33 {
        width: calc(50% - var(--gap) / 2);
    }
}

@media screen and (max-width: 860px) {
    :root {
        --ch1fs:48px;
        --spps:28px;
        --gap:20px;
    }
    .header {
        margin:0 -100px;
        width: calc(100% + 200px);
    }

    .overlay {
        left: var(--gap);
    }

    .top > .menu-toggle {
        overflow: hidden;
        width: 30px;
        padding-bottom: 1px;
    }

    .top > .menu-toggle:before {
        flex-shrink: 0;
    }

    .tpl-shifted .items-intro article:nth-of-type(2n+2) {
        margin-top:0%;
        position:relative;
        top:-150px;
    }
    .tpl-shifted.leading .items-intro article:nth-of-type(2n+2) {
        margin:0;
        top:100px;
    }
    .tpl-shifted.leading .items-intro {
        padding-bottom:calc(var(--gap) + 100px);
    }
}

@media screen and (max-width: 650px) {
    :root {
        --pfs:20px;
    }
    .nav-container {
        position:fixed;
        top: 0;
        left: 0;
        right: 0;
        height: 100dvh;
        box-sizing: border-box;
        background: #9F1823;
        padding: var(--hgap);
    }

    .top > .language {
        display: none;
    }

    .menuopen {
        overflow-y: hidden;
    }

    .nav-top {
        display: flex;
        align-items: center;
        margin-bottom: 20px;
    }

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

    .tpl-shifted .content-container {
        padding-top:80px;
    }

    .tpl-shifted .items-leading article {
        flex:0 0 100%;
    }

    .tpl-shifted .items-intro article {
        flex:0 0 100%;
    }

    .tpl-shifted .items-intro article:nth-of-type(2n+2) {
        position:static;
    }

    .slider .image-intro:before,
    .tpl-shifted .article-image:before,
    .tpl-shifted article .article-image:after {
        opacity:1;
    }

    .standard .img-intro {
        width: 100%;
        float: none;
        margin: 0 0 1em;
    }

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

    .contact {
        display: block;
    }

    .address {
    }

    .contact-container:before {
        bottom: auto;
    }

    .footer .moduletable {
        flex:1 0 100%;
    }
    .footer a:not([class*='icon']) {
        line-height:1.8em;
    }
}

@media screen and (max-width: 560px) {

    .h-bottom-container {
        padding: 0 var(--gap);
    }

    .h-bottom-helper {
        gap: var(--gap);
    }
}

@media screen and (max-width:480px) {
    :root{
        --ch1fs:34px;
    }

    .top-icons li:has(.optional) {
        display: none;
    }

}

@media screen and (max-width: 400px) {

    .overlay h3 {
        font-size:28px;
    }

    .overlay {
        font-size: 38px;
        bottom:70px;
    }

    .h-bottom-container {
        padding: 0 var(--hgap);
    }

    .h-bottom-helper {
        gap: var(--hgap);
    }

    .footer-container {
        padding: var(--gap);
    }

    .footer .moduletable {
        width: 100%;
    }

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

/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*########################################################################################*/
/*** Animations ***/
.animatedParent {
    opacity: 0;
    transition: opacity 1s;
}

.animatedParent.visible {
    translate: 0px;
    opacity: 1;
}

.animated {
    transition: all 1s;
}

.fadeInLeft {
    translate: -100px;
}

.visible .fadeInLeft {
    translate: 0;
}

.fadeInRight {
    translate: 100px;
}

.visible .fadeInRight {
    translate: 0;
}

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

.flatlist ul li {
}

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

.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: 1px dotted #f00;
    padding: 10px;
}

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

div.reset fieldset, div.0pxind fieldset, div.login fieldset, div.panel fieldset {
    padding: 10px;
}

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

div.login-fields label {
    display: block;
    float: left;
    width: 150px;
}

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

.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 12px/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: 5px 10px;
    border-radius: 5px;
    cursor: pointer;
}

form#adminForm fieldset {
    border: 0;
}

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

p.formDescription {
    font-size: 10px;
    font-weight: bold;
}

.formContainer {
    border: 0;
    margin-bottom: 40px;
}

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

.formRow > div {
    width: calc(50% - 40px);
}

.formControls div.formBody {
    float: none;
}

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

.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: 10px;
}

.rsform-block {
    margin-bottom: 10px;
}

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

.rsform-block .rsform-submit-button {
    all: initial;
    font: inherit;
    background: #eee;
    padding: 10px 20px;
    border-radius: 3px;
    cursor: pointer;
    -webkit-text-stroke: 0.020px;
    font-size: 18px;
}

.formValidation {
    display: block;
}

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

.has-margin-bottom {
    margin-bottom: 40px;
}

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

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

/*** contact form ***/
div.contact-form fieldset {
    padding: 10px;
}

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

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

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

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

a.close {
    display: none;
}

dl#system-message {
    border: 1px dotted #CF4D4D;
    padding: 10px;
    margin-bottom: 20px;
}

dt.message {
    margin-bottom: 10px;
    font-weight: bold;
}

/* contact */
div.contact h2 span {
    font-size: 24px;
}

div.contact h3 {
}

span.address {
    display: block;
    margin-top: 10px;
}

p.telephone {
    padding: 10px 0;
}

div.muted {
    display: none;
}

/*** Pagination ***/
.pagination ul {
    display: flex;
}

.pagination li {
    display: flex;
    align-items: center;
    border: 1px solid #ccc;
    border-right-width: 0;
}

.pagination .page-link {
    display: block;
    padding: 5px 12px 4px;
}

.pagination .active a {
    pointer-events: none;
    color: unset;
}

.pagination li:first-of-type {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}

.pagination li:last-of-type {
    border-right-width: 1px;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
}

.pagination .icon-angle-double-left:before, .pagination .icon-angle-left:before, .pagination .icon-angle-double-right:before, .pagination .icon-angle-right:before {
    display: flex;
    align-items: center;
    font-family: inherit;
    font-size: 1.5em;
    line-height: 0;
    position: relative;
    top: -2px;
}

.pagination .icon-angle-double-left:before {
    content: '\00AB';
}

.pagination .icon-angle-left:before {
    content: '\2039';
}

.pagination .icon-angle-double-right:before {
    content: '\00bb';
}

.pagination .icon-angle-right:before {
    content: '\203A';
}

@media screen and (max-width: 500px) {
    .pagination .page-item {
        display:none;
    }

    .pagination .page-item:nth-of-type(1), .pagination .page-item:nth-of-type(2), .pagination .page-item:nth-last-of-type(1), .pagination .page-item:nth-last-of-type(2), .pagination .page-item.active, .pagination .page-item.active + .page-item {
        display: flex;
    }

    .pagination .page-item:has(+ .active) {
        display: flex;
    }
}

/* Responsive Tabs */
.content .r-tabs {
    border-radius: 0;
    border: 0;
    background: #9f1823;
    padding: 10px;
}

.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: 5px;
    font-weight: bold;
    text-shadow: none;
}

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

.content .r-tabs .r-tabs-accordion-title.r-tabs-state-active .r-tabs-anchor {
    border-bottom: 1px solid #000;
}

.content .rtab-name { color:#9f1823; background:transparent; border-bottom:1px solid #826E61; padding:10px 0; }
.content .rtab-icon:before {
	flex-shrink:0;
	align-self:center;
	font-family:Iconia;
	content:"\e15c";
	transition:all 0.2s;
	margin-left:auto;
}
.content .rtab-item.rtab-open .tab-open .rtab-icon:before {
	rotate:90deg;
}
.content .rtab-item.rtab-open .rtab-name { background:transparent; }
.content .rtab-content { background:transparent; border:0; }

/*** JCE ***/
.wf-columns {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

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

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