@font-face {
    font-family: 'Chauncy Pro';
    src: url('../fonts/ChauncyPro-Regular.eot');
    src: url('../fonts/ChauncyPro-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/ChauncyPro-Regular.woff2') format('woff2'),
        url('../fonts/ChauncyPro-Regular.woff') format('woff'),
        url('../fonts/ChauncyPro-Regular.ttf') format('truetype'),
        url('../fonts/ChauncyPro-Regular.svg#ChauncyPro-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'chauncy_proitalic';
    src: url('../fonts/chauncypro-italic.woff2') format('woff2'),
         url('../fonts/chauncypro-italic.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}


:root{
	--primary-color				: #2C1C26;
	--secondary-color			: #4D1E32;
	--text-color				: #F0EBEB;
	--accent-color				: #957081;
	--white-color				: #FFFFFF;
	--green-color				: #857E3D;
	--blue-color				: #9FAEC1;
	--greige-color				: #B3AD9E;
	
	--default-font				: "Public Sans", sans-serif;
  --accent-font       : "Instrument Serif", serif;
	--chauncy-font				: 'chauncy_proitalic', serif;
}

html, body{
	overflow-x: clip;
	overscroll-behavior-y: none;
}

body{
	font-family: var(--default-font);
	font-size: 16px;
	font-weight: 300;
	line-height: 1.8em;
	background-color: var(--primary-color);
	color: var(--text-color);
}

p{
/*	font-family: var(--default-font);*/
	line-height: 1.8em;
	margin-bottom: 1.5em;
}


p strong{
	font-weight: 700;
}

p a,
ul li a {
	position: relative;
	text-decoration: none;
}

p a::after,
.page-content ul:not([class]) li a::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 1px;
	background-color: currentColor;
	opacity: 0;
	transform: translateY(-7px);
	transition: opacity 0.3s ease, transform 0.3s ease;
}

p a:hover::after,
.page-content ul:not([class]) li a:hover::after {
	opacity: 1;
	transform: translateY(0);
}

h1, h2, h3, h4, h5, h6{
	margin: 0;
	font-family: var(--accent-font);
	font-weight: 400;
	line-height: 1em;
	color: var(--text-color);
}

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

figure{
	margin: 0;
	line-height: 0;
}

a,
a:hover,
a:focus{
	text-decoration: none;
	outline: 0;
}

.container{
	max-width: 1360px;
}

.container,
.container-fluid,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl{
	position: relative;
    padding-right: 20px;
    padding-left: 20px;
	z-index: 1;
}

.row{
    margin-right: -20px;
    margin-left: -20px;
}

.row > *{
	padding-right: 20px;
	padding-left: 20px;
}

.row.no-gutters{
    margin-right: 0px;
    margin-left: 0px;
}

.row.no-gutters > *{
    padding-right: 0px;
    padding-left: 0px;
}

.btn-default{
	position: relative;
    display: inline-block;
	font-family: var(--default-font);
    font-size: 12px;
    font-weight: 600;
	line-height: 1em;
    color: var(--secondary-color);
	background: var(--text-color);
	text-transform: uppercase;
	border-radius: 30px;
    padding: 20px 25px 18px;
    border: none;
    overflow: hidden;
	outline: none;
	transition: all 0.5s ease-in-out;
    z-index: 0;
}

.btn-default:hover,
.btn-default:focus{
	color: var(--secondary-color);
	background: var(--white-color);
}

.btn-default.btn-border{
	color: var(--text-color);
	padding: 19px 25px 17px;
	border: 1px solid var(--text-color);
	background: transparent;
}

.btn-default.btn-border:hover{
	color: var(--secondary-color);
	border-color: var(--text-color);
	background: var(--text-color);
}

.btn-line {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--chauncy-font);
    font-size: 24px;
    font-weight: 400;
    line-height: 1.6em;
    color: var(--dynamic-text-color, var(--primary-color));
    background: transparent;
    text-transform: uppercase;
    border-radius: 0;
    padding: 0 0 2px;
    text-decoration: none;
    position: relative;
    overflow: initial;
}

.btn-line .btn-line-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease-in-out;
}

.btn-line .btn-line-icon svg {
    display: block;
    width: 24px;
    height: 24px;
}

.btn-line .btn-line-text {
    display: inline-block;
    position: relative;
}

.btn-line .btn-line-box {
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    width: 100%;
    height: 14px;
    pointer-events: none;
}

.btn-line .btn-line-box svg {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    overflow: visible !important;
}

.btn-line:hover .btn-line-icon {
    transform: translateX(-4px);
}

@media only screen and (max-width: 1280px) {
    .btn-line {
        font-size: 20px;
    }

    .btn-line .btn-line-icon svg {
        width: 20px;
        height: 20px;
    }
}



.section-row{
	margin-bottom: 40px;
}

.section-row .section-title{
	margin-bottom: 0;
}

.section-title{
	margin-bottom: 30px;
}

.section-title h1{
	color: var(--text-color);
	font-size: 64px;
	font-weight: 400;
	line-height: 1em;
}

.section-title h2{
	color: var(--text-color);
	font-size: 40px;
	font-weight: 400;
	line-height: 1em;
}

.section-title p{
	margin-top: 25px;
	margin-bottom: 0;
}

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

	.section-title h1{
		font-size: 48px;
	}

	.section-title h2{
		font-size: 32px;
	}	
}

@media only screen and (max-width: 1024px){
	
	.section-row{
		margin-bottom: 30px;
	}
	
	.section-title{
		margin-bottom: 20px;
	}
}

@media only screen and (max-width: 767px){
	
	.section-title h1{
		font-size: 40px;
	}

	.section-title h2{
		font-size: 28px;
	}
}


/*
 * Header CSS
 * */
.main-header{
	position: fixed;
	top: 0;
	left: 0;
	right: auto;
	padding: 35px 30px 0 30px;
	z-index: 99;
}

.main-header .header-logo a{
	display: inline-block;
}

.main-header .header-logo svg{
	width: 100px;
	height: 100px;
}

.navigation-main{
	position: fixed;
	top: 0;
	right: -100%;
	bottom: 0;
	width: 100%;
	background: var(--text-color);
	padding: 90px 0;
	transition: right 0.4s ease-in-out;
	z-index: 999;
}

body.nav-open .navigation-main{
	right: 0;
}

body.nav-hovered .navigation-main{
	right: calc(-100% + 20px);
}

.navigation-open-handler{
	position: fixed;
	top: 50%;
	right: -80px;
	transform: translateY(-50%);
	transition: right 0.4s ease-in-out;
	z-index: 99;
}

body.nav-open .navigation-open-handler{
	right: calc(100% - 80px);
}

body.nav-hovered .navigation-open-handler{
	right: -60px;
}

.nav-open-btn{
	width: 160px;
	height: 160px;
	border-radius: 50%;
	background: url("../images/nav-open-icon.svg") no-repeat center center;
	background-size: 100% auto;
	border: none;
	padding: 0;
}

.nav-open-btn span{
	position: absolute;
	left: 45px;
	width: 25px;
	height: 2px;
	border-radius: 6px;
	background: var(--secondary-color);
	transform: translateX(-50%);
	transition: all 0.3s ease-in-out;
}

.nav-open-btn span:first-child{
	top: calc(50% - 5px);
}

.nav-open-btn span:last-child{
	top: calc(50% + 5px);
}

body.nav-open .nav-open-btn span{
	opacity: 0;
	visibility: hidden;
}

.navigation-close-handler{
	position: fixed;
	top: 50%;
	right: -160px;
	transform: translateY(-50%);
	transition: all 0.7s ease-in-out;
	opacity: 0;
	visibility: hidden;
	z-index: 9999;
}

body.nav-open .navigation-close-handler{
	right: -80px;
	opacity: 1;
	visibility: visible;
}

.nav-close-btn{
	width: 160px;
	height: 160px;
	border-radius: 50%;
	background: url("../images/nav-close-icon.svg") no-repeat center center;
	background-size: 100% auto;
	border: none;
	padding: 0;
}

.nav-close-btn span{
	position: absolute;
	top: 50%;
	left: 45px;
	width: 25px;
	height: 2px;
	border-radius: 6px;
	background: var(--text-color);
	transform: translate(-50%, -50%) rotate(0deg);
	transition: all 0.4s ease;
}

.nav-close-btn span:last-child{
	opacity: 0;
}

body.nav-open .nav-close-btn span:first-child{
	transform: translate(-50%, -50%) rotate(45deg);
}

body.nav-open .nav-close-btn span:last-child{
	opacity: 1;
	transform: translate(-50%, -50%) rotate(-45deg);
}

.nav-open-btn:hover,
.nav-close-btn:hover,
.nav-open-btn:focus,
.nav-close-btn:focus,
.nav-open-btn:focus-visible,
.nav-close-btn:focus-visible{
    background-color: transparent !important;
    border-color: transparent !important;
    outline: 0;
    box-shadow: none;
}

.nav-floating-logo{
	position: absolute;
	top: 35px;
	left: 30px;
}

.nav-floating-logo .navbar-brand{
	display: inline-block;
}

.nav-floating-logo .navbar-brand svg{
	width: 100px;
	height: 100px;
}

.navigation-content-box{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 30px;
	max-width: 1300px;
	height: calc(100vh - 180px);
	overflow-y: auto;
	margin: 0 auto;
	padding: 0 20px;
}

.navigation-content-box::-webkit-scrollbar-track{
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);
	border-radius: 10px;
	background-color: #F5F5F5;
}

.navigation-content-box::-webkit-scrollbar{
	width: 5px;
	background-color: #F5F5F5;
}

.navigation-content-box::-webkit-scrollbar-thumb{
	border-radius: 10px;
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);
	background-color: var(--secondary-color);
}

.navigation-content-box .navigation-content-left{
	width: calc(62% - 15px);
}

.navigation-content-box .navigation-content-right{
	width: calc(38% - 15px);
}

.navigation-menu ul{
	margin: 0;
	padding: 0;
	list-style: none;
}

.navigation-menu ul li:not(:last-child){
	margin-bottom: 10px;
}

.navigation-menu ul li a{
	display: inline-flex;
	align-items: center;
	gap: 24px;
	transition: transform 0.4s ease-in-out;
}

.navigation-menu ul li a:hover{
	transform: translateX(24px);
}

.navigation-menu ul li:nth-child(even) a{
	flex-direction: row-reverse;
}

.navigation-menu ul li a .menu-title{
	display: inline-block;
	font-family: var(--accent-font);
	color: var(--green-color);
    font-size: clamp(1.25rem, 0.9167rem + 0.6944vw, 1.75rem);
	font-weight: 400;
	font-style: italic;
    line-height: 1em;
}

.navigation-menu ul li:nth-child(odd) a .menu-title{
	text-align: right;
}

.navigation-menu ul li a .menu-name{
	display: inline-block;
	font-family: var(--accent-font);
	color: var(--secondary-color);
    font-size: clamp(1.25rem, -0.3333rem + 3.2986vw, 3.625rem);
    font-weight: 400;
    line-height: 1.1em;
	text-transform: uppercase;
}

.navigation-contact-info{
	margin-bottom: 40px;
}

.navigation-contact-info ul{
	padding: 0;
	margin: 0;
	list-style: none;
}

.navigation-contact-info ul li{
	
}

.navigation-contact-info ul li {
	position: relative;
	color: var(--secondary-color);
	font-family: var(--accent-font);
    font-size: clamp(1.125rem, 0.875rem + 0.5208vw, 1.5rem);
    font-weight: 400;
	font-style: italic;
    line-height: 1.3em;
	text-align: center;
	margin-bottom: 0;
}

.navigation-contact-info ul li a {
	display: inline-block;
	position: relative;
	color: var(--secondary-color);
	font-family: var(--accent-font);
    font-size: clamp(1.125rem, 0.875rem + 0.5208vw, 1.5rem);
    font-weight: 400;
	font-style: italic;
    line-height: 1.3em;
	text-align: center;
	color: inherit;
}

.navigation-contact-info ul li ul.contact-detail{
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 25px;
}

.navigation-contact-info ul li ul.contact-detail li:not(:last-child):after{
	content: '•';
	position: absolute;
	top: 50%;
	left: auto;
	right: -15px;
	font-family: var(--accent-font);
	font-size: 20px;
	font-style: inherit;
	font-weight: inherit;
	color: var(--secondary-color);
	line-height: 0.5em;
	transform: translateY(-50%);
}

.navigation-opening-hours .opening-hours-title{
	color: var(--secondary-color);
	font-size: 16px;
	font-weight: 600;
	line-height: 1.5em;
	text-transform: uppercase;
	text-align: center;
	margin-bottom: 15px;
}

.navigation-opening-hours .opening-hours-content p{
	color: var(--secondary-color);
    font-family: var(--accent-font);
    font-size: 24px;
    font-weight: 400;
    font-style: italic;
    line-height: 1.3em;
    text-align: center;
}

.navigation-opening-hours .opening-hours-content > *:last-child{
	margin-bottom: 0;
}

.nav-floating-icon{
	margin-top: 80px;
	text-align: center;
}

.nav-floating-icon span{
	display: inline-block;
}

.nav-floating-icon svg{
	width: 200px;
	height: 175px;
	fill: var(--secondary-color);
}

.sub-navigation{
	position: absolute;
	left: 40px;
	bottom: 30px;
}

.sub-navigation-menu ul{
	display: flex;
	flex-wrap: wrap;
    align-items: center;
    justify-content: center;
	gap: 10px 20px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.sub-navigation-menu ul li{
	position: relative;
	color: var(--greige-color);
	font-size: 13px;
	font-weight: 300;
	line-height: 1.5em;
}

.sub-navigation-menu ul li:not(:last-child):after{
	content: '•';
    position: absolute;
    top: calc(50% + 2px);
    left: auto;
    right: -13px;
    font-family: var(--default-font);
    font-size: 16px;
    font-weight: 300;
	line-height: 0.5em;
    color: var(--greige-color);
    transform: translateY(-50%);
}

.sub-navigation-menu ul li a{
	display: inline-block;
	color: inherit;
}

.sub-navigation-menu ul li a:not([href]){
	cursor: default;
	pointer-events: none;
}

@media only screen and (max-width: 1440px){
	
	.navigation-content-box{
		max-width: 1100px;
	}

}

@media only screen and (max-width: 1280px){
	
	.main-header{
		padding: 25px 25px 0 25px;
	}

	.main-header .header-logo svg{
		width: 70px;
		height: 70px;
	}

	.navigation-main{
		padding: 80px 0;
	}
	
	.navigation-open-handler{
		right: -60px;
	}

	body.nav-open .navigation-open-handler{
		right: calc(100% - 60px);
	}
	
	.nav-open-btn{
		width: 120px;
		height: 120px;
	}

	.nav-open-btn span{
		left: 35px;
		width: 20px;
	}

	.navigation-close-handler{
		right: -120px;
	}

	body.nav-open .navigation-close-handler{
		right: -60px;
	}
	
	.nav-close-btn{
		width: 120px;
		height: 120px;
	}

	.nav-close-btn span{
		left: 35px;
		width: 20px;
	}
	
	.nav-floating-logo{
		top: 25px;
		left: 25px;
	}

	.nav-floating-logo .navbar-brand svg{
		width: 70px;
		height: 70px;
	}

	.navigation-content-box{
		max-width: 800px;
		height: calc(100vh - 160px);
	}

	.navigation-content-box .navigation-content-left{
		width: calc(55% - 15px);
	}

	.navigation-content-box .navigation-content-right{
		width: calc(45% - 15px);
	}

	.navigation-menu ul li a{
		gap: 20px;
	}

	.navigation-contact-info ul li p{
		font-size: 20px;
	}

	.navigation-contact-info ul li ul.contact-detail li:not(:last-child):after{
		font-size: 18px;
	}

	.navigation-opening-hours .opening-hours-content p{
		font-size: 20px;
	}

	.nav-floating-icon{
		margin-top: 45px;
	}

	.nav-floating-icon svg{
		width: 120px;
		height: 100px;
	}

	.sub-navigation{
		left: 0;
		right: 0;
		width: 100%;
		padding: 0 25px;
	}	
}

@media only screen and (max-width: 1023px){
	
	.navigation-main{
		padding: 100px 0;
		overflow-y: auto;
	}
	
	.navigation-content-box{
		flex-direction: column;
		gap: 60px 30px;
		max-width: 500px;
		height: initial;
		overflow-y: initial;
	}

	.navigation-content-box .navigation-content-left,
	.navigation-content-box .navigation-content-right{
		width: 100%;
	}

	.navigation-menu ul{
		text-align: center;
	}
	
	.navigation-menu ul li:not(:last-child){
		margin-bottom: 8px;
	}

	.navigation-menu ul li a{
		flex-direction: column;
	}

	.navigation-menu ul li a .menu-title{
		display: none;
	}

	.navigation-contact-info{
		margin-bottom: 20px;
	}

	.nav-floating-icon{
		margin-top: 0;
		display: none;
	}

	.sub-navigation-menu ul{
		gap: 5px 20px;
	}

	.sub-navigation-menu ul li{
		font-size: 14px;
		text-align: center;
	}
	
	.sub-navigation-menu ul li:last-child{
		width: 100%;
	}
	
	.sub-navigation-menu ul linth-last-child(2):after{
		display: none;
	}
}

@media only screen and (max-width: 767px){
	
	.main-header{
		position: absolute;
		padding: 20px 20px 0 20px;
	}

	.navigation-main{
		padding: 80px 0;
	}
	
	.navigation-open-handler{
		right: -45px;
	}

	body.nav-open .navigation-open-handler{
		right: calc(100% - 45px);
	}
	
	.nav-open-btn{
		width: 90px;
		height: 90px;
	}

	.nav-open-btn span{
        left: 27px;
        width: 18px;
    }
	
	.navigation-close-handler{
		right: -90px;
	}

	body.nav-open .navigation-close-handler{
		right: -45px;
	}
	
	.nav-close-btn{
		width: 90px;
		height: 90px;
	}
	
	.nav-close-btn span{
		left: 27px;
		width: 18px;
	}
	
	.nav-floating-logo{
		top: 20px;
		left: 20px;
	}
	
	.nav-floating-logo .navbar-brand svg{
		width: 50px;
		height: 50px;
	}

	.navigation-content-box{
		gap: 20px;
		padding: 0 60px;
	}

	.navigation-menu ul li:not(:last-child){
		margin-bottom: 0;
	}

	.navigation-contact-info{
		margin-bottom: 20px;
	}

	.navigation-contact-info ul li ul.contact-detail{
		flex-direction: column;
		gap: 0;
	}

	.navigation-contact-info ul li ul.contact-detail li:not(:last-child):after{
		display: none;
	}

	.navigation-contact-info ul li p,
	.navigation-opening-hours .opening-hours-content p{
		font-size: 16px;
	}
	
	.navigation-opening-hours .opening-hours-title{
		font-size: 14px;
	}
	
	.navigation-opening-hours .opening-hours-title{
		margin-bottom: 10px;
	}
	
	.sub-navigation{
		bottom: 25px;
	}
}

/*
 * Footer CSS
 * */
.footer-contact-info{
	position: fixed;
	top: auto;
	left: 30px;
	right: auto;
	bottom: 40px;
	z-index: 99;
}

.footer-contact-info ul{
	padding: 0;
	margin: 0;
	list-style: none;
}

.footer-contact-info ul li{
	position: relative;
}

.footer-contact-info ul li,
.footer-contact-info ul a {
	color: var(--text-color);
	font-family: var(--accent-font);
    font-size: 20px;
    font-weight: 400;
	font-style: italic;
    line-height: 1.3em;
	margin-bottom: 0;
}

.footer-contact-info ul li a{
	display: inline-block;
	position: relative;
	color: inherit;
}

.footer-contact-info ul li ul.contact-detail{
	display: flex;
	align-items: center;
	gap: 20px;
}

.footer-contact-info ul li ul.contact-detail li:not(:last-child):after{
	content: '•';
	position: absolute;
	top: calc(50% + 2px);
	left: auto;
	right: -12px;
	font-family: var(--accent-font);
	font-size: inherit;
	font-style: inherit;
	font-weight: inherit;
	color: inherit;
	line-height: 0.5em;
	transform: translateY(-50%);
}

.footer-action{
	position: fixed;
	top: auto;
	left: auto;
	right: 30px;
	bottom: ;
	z-index: 9999;
	line-height: 0;
}

.footer-actions {
  display: flex;
  gap: .5rem;
  align-items: center;
  position: fixed;
	top: auto;
	left: auto;
	right: clamp(0.9375rem, 0.3125rem + 1.3021vw, 1.875rem);
	bottom: clamp(0.9375rem, -0.1042rem + 2.1701vw, 2.5rem);
	z-index: 9999;
	line-height: 0;
}

.footer__action--reserveren {
  box-shadow: 0px 0px 8px rgb(from #000000 r g b / 16%);
}

.footer__action--cadeau {
  width: 50px;
	height: 50px;
	font-size: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background-color: var(--accent-color);
}

.footer__action--cadeau svg {
	width: 1em;
	height: 1em;
	fill: var(--text-color);
}

.footer-action .reserveren-btn a{
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.footer-action .reserveren-btn span.btn-default{
	box-shadow: 0px 0px 8px rgb(from #000000 r g b / 16%);
}

.footer-action .reserveren-btn span.icon{
	width: 50px;
	height: 50px;
	font-size: 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background-color: var(--accent-color);
}

.footer-action .reserveren-btn svg{
	width: 1em;
	height: 1em;
	fill: var(--text-color);
}

.socialmedia-info{
	position: fixed;
	top: 50%;
	left: 30px;
	height: auto;
	transform: translateY(-50%);
	z-index: 100;
}
 
.socialmedia-info ul{
	display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.socialmedia-info ul li a{
	position: relative;
	color: var(--text-color);
	fill: var(--text-color);
	font-size: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	width: 60px;
	height: 60px;
	z-index: 1;
}

.socialmedia-info ul li a svg{
	width: 1em;
	height: 1em;
	fill: inherit;
}

.socialmedia-info ul li a::after{
	content: '';
	position: absolute;
	display: inline-block;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	background-image: url("../images/social-media-outline1.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 60px auto;
}

.socialmedia-info ul li:nth-child(even) a::after{
	background-image: url("../images/social-media-outline2.svg");
}

@media only screen and (max-width: 1280px){
	
	.footer-contact-info{
		display: none;
		left: 20px;
		bottom: 25px;
		z-index: 99;
	}
	
	.footer-contact-info ul li p{
		font-size: 16px;
	}
	
	.footer-action{
		z-index: 99;
	}
	
	.socialmedia-info ul li a{
		font-size: 20px;
		width: 48px;
		height: 48px;
	}
	
	.socialmedia-info ul li a::after{
		background-size: 48px auto;
	}
}

@media only screen and (max-width: 1023px){
	
	body:not(.home) .socialmedia-info{
		top: 460px;
		transform: translateY(0);
	}
}

@media only screen and (max-width: 767px){
	
	.footer-action{
		right: 20px;
    	bottom: 25px;
	}
	
	.socialmedia-info,
	body:not(.home) .socialmedia-info{
		position: absolute;
		top: 30px;
		left: auto;
		right: 20px;
		bottom: auto;
		transform: translateY(0);
	}
	
	.socialmedia-info ul{
		flex-direction: row;
	}
	
	.socialmedia-info ul li a{
		font-size: 16px;
		width: 40px;
		height: 40px;
	}
	
	.socialmedia-info ul li a::after{
		background-size: 40px auto;
	}
}


/*
 * 404 Page CSS
 * */
.error-page-main{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	align-content: center;
	padding: 120px 0;
    z-index: 1;
}

.error-page-main .container{
	max-width: 980px;
}

.error-template-box h1{
	font-size: 120px;
}

.error-template-box p{
	font-size: 18px;
	margin-top: 30px;
}

.error-template-box .error-btn .btn-default{
	font-family: var(--chauncy-font);
    font-size: 24px;
    font-weight: 400;
    line-height: 1.6em;
	color: var(--text-color);
    background: transparent;
    text-transform: uppercase;
    border-radius: 0;
    padding: 0 0 2px;
	overflow: initial;
}

.page-block[style*="--bg-color: #4D1E32"] .btn-default:after,
.error-template-box .error-btn .btn-default:after{
	content: '';
	display: inline-block;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 3px;
	background-image: url("../images/btn-hover-line-light.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 100% 2px;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease-in-out;
}

.error-template-box .error-btn .btn-default:hover:after{
	opacity: 1;
	visibility: visible;
}

@media only screen and (max-width: 1024px){
	
	.error-page-main{
		padding: 100px 10px;
	}

	.error-page-main .container{
		max-width: 540px;
	}

	.error-template-box h1{
		font-size: 100px;
	}

	.error-template-box p{
		font-size: 16px;
		margin-top: 25px;
	}

	.error-template-box .error-btn .btn-default{
		font-size: 20px;
	}
}

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

	.error-page-main .container{
		max-width: 300px;
	}
	
	.error-template-box h1{
		font-size: 54px;
	}

	.error-template-box p{
		font-size: 14px;
	}

	.error-template-box .error-btn .btn-default{
		font-size: 18px;
	}
}


/*
 * GSAP animatie hulpklassen
 * */
.gsap-word {
    display: inline-block;
    will-change: opacity, filter, transform;
}


/*
 * Impressie pagina — achtergrondkleur body gelijkgetrokken met het blok
 * zodat er geen kleursprong zichtbaar is bij overscroll op Mac
 * */
body:has(.impressie-block) {
	background-color: var(--secondary-color);
}



.content-flow > * + * {
  margin-block-start: var(--flow-space, 1em) !important;
}
 .content-flow :is(h1, h2, h3, h4, h5, h6, blockquote) {
  --flow-space: 2rem;
}
 .content-flow :is(h1, h2, h3, h4, h5, h6) + * {
  --flow-space: 1rem;
}

/*
 * Hover-effecten uitschakelen op touch devices
 * */
@media (hover: none) {

	.navigation-menu ul li a:hover {
		transform: none;
	}

	body.nav-hovered .navigation-main {
		right: -100%;
	}

	body.nav-hovered .navigation-open-handler {
		right: -45px;
	}
}
