:root {
    --black: #1D1B19;
    --white: #FFFEFC;
    --cream: #F7F1E5;
    --brown: #CCBFA9;
    --brown-55: #CCBFA98C;
    --red: #B54B42;
    --def-trans: .3s ease all;
    --container-width: max(1680px, 90vw);
    --grid-gap: max(16px, 0.9375vw);
    --flex-gap: max(16px, 0.9375vw);
    --grid-margin: max(
        0px,
        calc((100vw - var(--container-width) - (2 * var(--grid-gap))) / 2)
    );
    --grid-col-width: calc(
        (
            100vw - (2 * var(--grid-margin) + 2 * var(--grid-gap)) - 11 *
              var(--grid-gap)
        ) / 12
    );
    --grid-padding: calc(var(--grid-gap) + var(--grid-margin));
    --m-xs: max(15px, 1.171875vw);
    --m-sm: max(25px, 1.953125vw);
    --m-md: max(50px, 3.90625vw);
    --m-lg: max(75px, 5.859375vw);
    --m-xl: max(100px, 7.8125vw);
    --header-height: calc(max(40px, 1.953125vw) + (max(10px, 0.9375vw) * 2));
    --fs-16: max(16px, 0.625vw);
    --fs-20: max(16px, 0.78125vw);
    --fs-25: max(16px, 0.9765625vw);
    --fs-30: max(20px, 1.171875vw);
    --fs-35: max(25px, 1.3671875vw);
    --fs-80: max(40px, 3.125vw);
    --fs-100: max(50px, 3.90625vw);
    --fs-200: max(60px, 7.8125vw);
}

* {
    scroll-margin-top: calc(var(--header-height));
}

html {
    scroll-behavior: smooth;
}

body, html {
    font-family: "Figtree";
    font-weight: 300;
    font-size: var(--fs-20);
    letter-spacing: 0;
    line-height: 1;
}

body.menu-toggled {
    overflow-y: hidden;
}

.site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.site .site-main {
    flex-grow: 1;
}

body:not(:has(.intro-media-headline-btns)) .site .site-main {
    padding-top: calc(var(--header-height))
}

.entry-content p,
.text-container {
    line-height: 1.5;
    font-weight: 400;
}

.entry-content p a,
.entry-content .text-container a {
    text-decoration: underline;
}

p:last-of-type {
    margin-bottom: 0;
}

strong, b {
    font-weight: 700;
}

ul, ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

#cmplz-document ul,
.editor-styles-wrapper
.cmplz-unlinked-mode ul {
    list-style: none;
    margin-left: 0;
}

.entry-content ul {
    list-style: square;
    padding-left: 0;
    line-height: 1.2;
    display: flex;
    flex-direction: column;
    gap: .75em;
}

.entry-content ol.wp-block-list {
    list-style-type: decimal; 
    line-height: 1.2;
    padding-left: 0;
}

.entry-content ol.wp-block-list li {
    position: relative;
    padding-left: 1.25em;
}

.entry-content ol.wp-block-list li:not(:last-child) {
    margin-bottom: 1em;
}

.entry-content ul:not(.slick-dots) li {
    position: relative;
    padding-left: .5em;
    margin-left: 1em;
}

a, a:focus, a:active {
    text-decoration: none;
}

a {
    transition: color .3s ease;
    width: fit-content;
    height: fit-content;
    color: unset;
}

a:hover {
    transition: color .3s ease;
}

button {
    cursor: pointer;
    border: 0;
    border-radius: 0;
    background: none;
    padding: 0;
}

body, button, input, select, optgroup, textarea {
    color: currentColor;
}

h1, .h1  {
    font-family: "Vollkorn";
    font-size: var(--fs-80);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1;
    margin: 0;
    text-transform: uppercase;
}

h2, .h2 {
    font-family: "Vollkorn";
    font-size: var(--fs-30);
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.3;
    margin: 0;
    text-transform: uppercase;
}

h3, .h3 {
    font-family: "Vollkorn";
    font-size: var(--fs-35);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.15;
    margin: 0;
}

h4, .h4 {
    font-family: "Vollkorn";
    font-size: var(--fs-30);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.3;
}

h1.wp-block-heading,
h2.wp-block-heading,
h3.wp-block-heading {
    margin: .8em 0 .625em;
}

.highlight-sm,
.highlight-md,
.highlight-lg {
    font-family: "Hariston";
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1;
    width: fit-content;
    height: fit-content;
    text-transform: none;
}

.highlight-sm {
    font-size: max(48px, var(--fs-80));
}

.highlight-md {
    font-size: var(--fs-100);
}

.highlight-lg {
    font-size: var(--fs-200);
}

.position-relative {
    position: relative;
}

.position-absolute {
    position: absolute;
}

.position-fixed {
    position: fixed;
}

.position-sticky {
    position: sticky;
}

.full-width-grid {
    display: grid;
    grid-template-columns: var(--grid-margin) repeat(12, 1fr) var(--grid-margin);
    grid-column-gap: var(--grid-gap);
}

.d-grid {
    display: grid;
}

.d-subgrid {
    display: grid;
    grid-template-columns: subgrid;
    grid-template-rows: subgrid;
}

.d-flex {
    display: flex;
}

.d-none {
    display: none;
}

.grid-gap {
    grid-gap: var(--grid-gap);
}

.flex-gap {
    gap: var(--grid-gap);
}

.justify-content-center {
    justify-content: center;
}
  
.justify-content-between {
    justify-content: space-between;
}
  
.justify-content-around {
    justify-content: space-around;
}
  
.justify-content-end {
    justify-content: flex-end;
}
  
.justify-self-start {
    justify-self: flex-start;
}

.justify-self-center {
    justify-self: center;
}

.justify-self-end {
    justify-self: flex-end;
}
  
.align-self-start {
    align-self: flex-start;
}
  
.align-self-center {
    align-self: center;
}
  
.align-self-end {
    align-self: flex-end;
}

.align-items-start {
    align-items: flex-start;
}

.align-items-center {
    align-items: center;
}
  
.align-items-end {
    align-items: flex-end;
}

.flex-column {
    flex-direction: column;
}

.flex-row {
    flex-direction: row;
}

.flex-wrap {
    flex-wrap: wrap;
}

.container {
    margin-left: calc(var(--grid-margin) + var(--grid-gap));
    margin-right: calc(var(--grid-margin) + var(--grid-gap));
    width: calc(100% - ((var(--grid-margin) + var(--grid-gap)) * 2));
}

@media (min-width: 992px) {
    .container.sm {
        margin-left: calc(var(--grid-margin) + var(--grid-col-width) + (var(--grid-gap) * 2));
        margin-right: calc(var(--grid-margin) + var(--grid-col-width) + (var(--grid-gap) * 2));
        width: calc(100% - ((var(--grid-margin) + var(--grid-col-width) + (var(--grid-gap) * 2)) * 2));
    }
}

.mt-xs {
    margin-top: var(--m-xs);
}

.mt-sm {
    margin-top: var(--m-sm);
}

.mt-md {
    margin-top: var(--m-md);
}

.mt-lg {
    margin-top: var(--m-lg);
}

.mt-xl {
    margin-top: var(--m-xl);
}

.mb-xs {
    margin-bottom: var(--m-xs);
}

.mb-sm {
    margin-bottom: var(--m-sm);
}

.mb-md {
    margin-bottom: var(--m-md);
}

.mb-lg {
    margin-bottom: var(--m-lg);
}

.mb-xl {
    margin-bottom: var(--m-xl);
}

.pt-xs {
    padding-top: var(--m-xs);
}

.pt-sm {
    padding-top: var(--m-sm);
}

.pt-md {
    padding-top: var(--m-md);
}

.pt-lg {
    padding-top: var(--m-lg);
}

.pt-xl {
    padding-top: var(--m-xl);
}

.pb-xs {
    padding-bottom: var(--m-xs);
}

.pb-sm {
    padding-bottom: var(--m-sm);
}

.pb-md {
    padding-bottom: var(--m-md);
}

.pb-lg {
    padding-bottom: var(--m-lg);
}

.pb-xl {
    padding-bottom: var(--m-xl);
}

.fs-16 {
    font-size: var(--fs-16);
}

.fw-300 {
    font-weight: 300;
}

.fw-400 {
    font-weight: 400;
}

.fw-500 {
    font-weight: 500;
}

.fw-600 {
    font-weight: 600;
}

.fw-700 {
    font-weight: 700;
}

.text-italic {
    font-style: italic;
}

.text-left,
.text-left p {
    text-align: left;
}

.text-center,
.text-center p,
.has-text-align-center {
    text-align: center;
}

.text-right,
.text-right p {
    text-align: right;
}

.text-justify,
.text-justify p {
    text-align: justify;
}

.text-uppercase {
    text-transform: uppercase;
}

.text-lowercase {
    text-transform: lowercase;
}

.text-balance {
    text-wrap: balance;
}

.page-content,
.entry-content, 
.entry-summary,
.post, .page {
    margin: 0;
}

.img-container,
.media-container {
    display: flex;
    background: #ccc;
}

.img-container img,
.img-container picture,
.media-container img,
.media-container picture,
.media-container video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.icon-container {
    display: flex;
}

.icon-container img,
.icon-container picture {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.sticky-container {
    position: relative;
}

.sticky-item {
    position: sticky;
    top: calc(var(--header-height) + 16px);
}

/* Design ELement */
.bg-black {
    background: var(--black);
    color: var(--white);
}

.bg-white {
    background: var(--white);
}

.bg-cream {
    background: var(--cream);
}

.bg-brown {
    background: var(--brown);
}

.bg-brown-55 {
    background: var(--brown-55);
}

.bg-red {
    background: var(--red);
}

.text-black {
    color: var(--black);
}

.text-white {
    color: var(--white);
}

.text-cream {
    color: var(--cream);
}

.text-brown {
    color: var(--brown);
}

.text-brown-55 {
    color: var(--brown-55);
}

.text-red {
    color: var(--red);
}

.br-50 {
    border-radius: max(24px, 1.953125vw);
    overflow: hidden;
}

.br-20 {
    border-radius: max(10px, 0.78125vw);
    overflow: hidden;
}

.filter-item.hidden {
    visibility: hidden;
    opacity: 0;
}

.filter-item.animate {
    animation: zoomIn 0.6s ease-out forwards;
}

@keyframes zoomIn {
    0% {
        opacity: 0;
        transform: scale(0.85);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

/* Buttons */
.btns-container {
    display: flex;
    flex-wrap: wrap;
    gap: var(--grid-gap);
}

.default-btn,
.default-slider-btn {
	display: flex;
	width: fit-content;
	height: fit-content;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-family: "Vollkorn";
	font-size: var(--fs-25);
	font-weight: 600;
	letter-spacing: .0;
	line-height: 1.4;
    text-transform: uppercase;
	color: var(--white);
    background: var(--red);
	padding: .45em max(16px, 1.875vw) .25em;
    border-radius: max(10px, 0.78125vw);
    transition: var(--def-trans);
    min-width: max(162px, 9.375vw);
}

.default-btn:hover {
    background: var(--black);
    transition: var(--def-trans);
}

.default-slider-btn {
    color: var(--black);
    background: transparent;
}

.default-slider-btn:first-child:last-child {
    cursor: default;
}

.default-slider-btn:not(:first-child:last-child):hover,
.default-slider-btn.active:not(:first-child:last-child) {
    color: var(--white);
    background: var(--red);
}

.bg-black .default-btn:hover {
    color: var(--black);
    background: var(--white);
}

.default-btn.black {
    background: var(--black);
}

.default-btn.black:hover {
    background: var(--red);
}

.default-btn.brown {
    background: var(--brown);
    color: var(--black);
}

.default-btn.brown:hover {
    background: var(--red);
    color: var(--white);
}

.arrow-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: max(30px, 1.953125vw);
    aspect-ratio: 1/1;
    background: var(--black);
    border-radius: max(10px, 0.5859375vw);
    transition: var(--def-trans);
}

.arrow-btn:hover,
.hover-container:hover .arrow-btn,
.hover-container.active .arrow-btn {
    background: var(--red);
    z-index: 1;
}

.arrow-btn::after {
    content: "";
    display: block;
    width: 60%;
    height: 50%;
    background: var(--white);
    mask: url(../img/arrow-right.svg) no-repeat center/contain;
    -webkit-mask: url(../img/arrow-right.svg) no-repeat center/contain;
    transform: rotate(-45deg);
    transition: var(--def-trans);
}

.arrow-btn:hover::after,
.hover-container:hover .arrow-btn::after,
.hover-container.active .arrow-btn::after {
    transform: rotate(0deg);
}

.arrow-btn.rotate-down:hover::after {
    transform: rotate(90deg);
}


.hover-container:hover {
    cursor: pointer;
}

.back-btn {
    display: flex;
    align-items: center;
    gap: max(16px, 1.25vw);
    font-family: "Figtree";
    font-size: var(--fs-20);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.25;
}

.back-btn::before {
    content: "";
    display: block;
    height: 1.5em;
    aspect-ratio: 4/3;
    mask: url(../img/arrow-left.svg) no-repeat center/contain;
    -webkit-mask: url(../img/arrow-left.svg) no-repeat center/contain;
    background: currentColor;
    transition: var(--def-trans);
}

.back-btn:hover::before {
    transform: translateX(-25%);
}

.filter-btns-container {
    display: flex;
    gap: var(--grid-gap);
}

.filter-btns-container:not(.flex-column) {
    justify-content: center;
}

.filter-btns-container.flex-column {
    
}

.filter-btn {
    font-family: "Vollkorn";
    font-size: var(--fs-30);
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
    background: var(--black);
    color: var(--white);
    border-radius: 100vmin;
    padding: max(16px, 1.25vw) max(8px, .625vw);
    position: relative;
    display: flex;
    align-items: center;
    transition: var(--def-trans);
}

.filter-btn.icon.active {
    background: var(--red);
    padding: max(16px, 1.25vw);
}

.filter-btn.icon::before {
    content: "";
    display: block;
    aspect-ratio: 2/1;
    width: max(48px, 2.5vw);
    background: currentColor;
    text-indent: 20px;
}

.filter-btn.icon.filter-btn.sommer::before,
.filter-btn.icon.filter-btn.summer::before {
    mask: url(../img/icon-sunglasses.svg) no-repeat center/contain;
    -webkit-mask: url(../img/icon-sunglasses.svg) no-repeat center/contain;
    order: 1;
}

.filter-btn.icon.filter-btn.winter::before {
    mask: url(../img/icon-ski-goggles.svg) no-repeat center/contain;
    -webkit-mask: url(../img/icon-ski-goggles.svg) no-repeat center/contain;
    order: 0;
}

.filter-btn .text {
    width: fit-content;
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    white-space: nowrap;
    transition: var(--def-trans);
}

.filter-btn.active .text {
    max-width: 8ch;
    opacity: 1;
}

.filter-btn.icon.filter-btn.sommer.active .text,
.filter-btn.icon.filter-btn.summer.active .text {
    margin-right: var(--grid-gap);
}

.filter-btn.icon.filter-btn.winter.active .text {
    margin-left: var(--grid-gap);
}


/* Social Buttons */
.icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: max(30px, 1.953125vw);
    aspect-ratio: 1/1;
    background: var(--cream);
    border-radius: max(10px, 0.5859375vw);
    transition: var(--def-trans);
}

.icon-btn.webcam {
    display: none;
}

.icon-btn:hover {
    background: var(--brown);
    transition: var(--def-trans);
}

.icon-btn.dark {
    background: var(--black);
    color: var(--brown);
}

.icon-btn.dark:hover {
    background: var(--red);
    color: var(--white);
}

.icon-btn.border {
    background: transparent;
    border: 1px solid var(--white);
}

.icon-btn::after {
    content: "";
    display: block;
    width: 68%;
    height: 60%;
    background: currentColor;
}

.icon-btn.facebook::after {
    mask: url(../img/icon-facebook.svg) no-repeat center/contain;
    -webkit-mask: url(../img/icon-facebook.svg) no-repeat center/contain;
}

.icon-btn.instagram::after {
    mask: url(../img/icon-instagram.svg) no-repeat center/contain;
    -webkit-mask: url(../img/icon-instagram.svg) no-repeat center/contain;
}

.icon-btn.tripadvisor::after {
    mask: url(../img/icon-tripadvisor.svg) no-repeat center/contain;
    -webkit-mask: url(../img/icon-tripadvisor.svg) no-repeat center/contain;
}

.icon-btn.webcam::after {
    mask: url(../img/icon-webcam.svg) no-repeat center/contain;
    -webkit-mask: url(../img/icon-webcam.svg) no-repeat center/contain;
}

.icon-btn.holidaycheck {
    width: 137px;
    aspect-ratio: 137/50;
    background: var(--black);
}

.icon-btn.holidaycheck:hover {
    background: var(--red);
}

.icon-btn.holidaycheck::after {
    background: transparent url(../img/icon-holidaycheck.svg) no-repeat center / contain;
}
  
/* Slick Slider */
.default-slider-nav {
    display: flex;
    align-items: center;
    width: fit-content;
    height: fit-content;
    gap: max(32px, 4.0625vw);
}

.default-slider-nav.flex-column {
    gap: max(20px, 1.5625vw);
}

.default-slider-prev,
.default-slider-next {
    display: flex;
    align-items: center;
    justify-content: center;
    width: max(24px, 1.5625vw);
    aspect-ratio: 30/39;
    flex: 0 0 auto;
    transition: var(--def-trans);
    position: relative;
    z-index: 1;
    background: currentColor;
}

.default-slider-prev:hover,
.default-slider-next:hover {
    transform: scale(1.05);
}

.default-slider-prev {
    mask: url(../img/arrow-left.svg) no-repeat center/contain;
    -webkit-mask: url(../img/arrow-left.svg) no-repeat center/contain;
}

.default-slider-next {
    mask: url(../img/arrow-right.svg) no-repeat center/contain;
    -webkit-mask: url(../img/arrow-right.svg) no-repeat center/contain;
}

/* Accordion */
.accordion {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--m-sm);
}

.accordion .accordion-item .accordion-title {
    font-family: "Vollkorn";
	font-size: var(--fs-30);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.35;
	color: currentColor;
	display: flex;
	justify-content: space-between;
	gap: var(--grid-gap);
	cursor: pointer;
	position: relative;
	transition: var(--def-trans);
	padding-right: 2em;
}

.accordion .accordion-item.active .accordion-title {
    text-decoration-color: currentColor;
}

.accordion .accordion-item .accordion-title::before,
.accordion .accordion-item .accordion-title::after {
    content: "";
    display: block;
    height: max(25px, 1.171875vw);
    position: absolute;
    top: .175em;
    right: 0;
    aspect-ratio: 1/1;
    transition: var(--def-trans);
    border-radius: 10px;
}

.accordion .accordion-item .accordion-title::before {
    mask: url(../img/arrow-top-right.svg) no-repeat center/45% 45%;
    -webkit-mask: url(../img/arrow-top-right.svg) no-repeat center/45% 45%;
    background-color: var(--white);
    z-index: 1;
}

.accordion .accordion-item.active .accordion-title::before {
    transform: rotate(135deg);
}

.accordion .accordion-item .accordion-title::after {
    background-color: currentColor;
}

.accordion .accordion-item .accordion-content {
	font-weight: 300;
	letter-spacing: 0;
	line-height: 1.5;
	padding: 3em 0 0;
}

.accordion .accordion-item .accordion-content a {
	color: var(--red);
}