:root {
	--revilodesign_white					:	255, 255, 255;
	--revilodesign_light					:	250, 249, 244;
	--revilodesign_grey						:	234, 234, 234;
	--revilodesign_dark						:	33, 46, 71;
	--revilodesign_black					:	0, 0, 0;
	--revilodesign_yellow					:	220, 150, 4;

	--revilodesign_primary					:	196, 165, 130;
	--revilodesign_secondary				:	225, 255, 160;
	
	--revilodesign_headlineColor			:	rgba( 0, 16 , 37, 1);
	--revilodesign_textColor				:	rgba( 0, 0 , 0, 1);

	--revilodesign_error					:	#ff6e6c;
	--revilodesign_errorLight				:	#ffebed;
	--revilodesign_success					:	#2ea753;
	--revilodesign_successLight				:	#ebfff0;
	--revilodesign_warning					:	#ffc107;
	--revilodesign_warningLight				:	#fff9e7;
	--revilodesign_blue						:	#3c6996;
	--revilodesign_blueLight				:	#e2f1ff;
	
	--revilodesign_gradient					:	linear-gradient(45deg, #34b3a8 0%,#3b6e73 36%,#e3abaa 100%);

	--revilodesign_boxShadow				:	0px 0px 16px rgba(25, 34, 64, 0.15);
	--revilodesign_boxShadowBig				:	0px 4px 4px 0px rgba(0, 0, 0, 0.25);
	--revilodesign_cardShadow				:	rgba(50, 50, 93, 0.11) 0px 2px 5px -1px, rgba(0, 0, 0, 0.12) 0px 1px 3px -1px;
	--revilodesign_borderRadius				:	4px;
	--revilodesign_borderRadiusBigs			:	12px;
	--revilodesign_borderColor				:	rgba( var(--revilodesign_grey), .2);
	--revilodesign_transition				:	all 0.2s ease-in-out;

	--revilodesign_maxWidth					:	1448px;
	--revilodesign_gap						:	24px;
	--revilodesign_gap_big					:	80px;

	--revilodesign_headline_hero_fontSize	:	48px;
	--revilodesign_headline_hero_lineHeight	:	calc( var(--revilodesign_headline_hero_fontSize) + 8px );
	--revilodesign_headline_hero_fontWeight	:	700;

	--revilodesign_headline_h1_fontSize		:	88px;
	--revilodesign_headline_h1_lineHeight	:	calc( var(--revilodesign_headline_h1_fontSize) + 0px );
	--revilodesign_headline_h1_fontWeight	:	900;

	--revilodesign_headline_h2_fontSize		:	32px;
	--revilodesign_headline_h2_lineHeight	:	calc( var(--revilodesign_headline_h2_fontSize) + 8px );
	--revilodesign_headline_h2_fontWeight	:	400;

	--revilodesign_headline_h3_fontSize		:	24px;
	--revilodesign_headline_h3_lineHeight	:	calc( var(--revilodesign_headline_h3_fontSize) + 8px );
	--revilodesign_headline_h3_fontWeight	:	400;

	--revilodesign_headline_h4_fontSize		:	18px;
	--revilodesign_headline_h4_lineHeight	:	calc( var(--revilodesign_headline_h4_fontSize) + 8px );
	--revilodesign_headline_h4_fontWeight	:	700;

	--revilodesign_headline_sub_fontSize	:	20px;
	--revilodesign_headline_sub_lineHeight	:	calc( var(--revilodesign_headline_sub_fontSize) + 8px );
	--revilodesign_headline_sub_fontWeight	:	400;

	--revilodesign_text_fontSize			:	16px;
	--revilodesign_text_lineHeight			:	calc( var(--revilodesign_text_fontSize) + 8px );
	--revilodesign_text_fontWeight			:	400;

	--revilodesign_text_large_fontSize		:	24px;
	--revilodesign_text_large_lineHeight	:	calc( var(--revilodesign_text_large_fontSize) + 8px );
	--revilodesign_text_large_fontWeight	:	400;

	--revilodesign_text_medium_fontSize		:	20px;
	--revilodesign_text_medium_lineHeight	:	calc( var(--revilodesign_text_medium_fontSize) + 8px );
	--revilodesign_text_medium_fontWeight	:	600;

	--revilodesign_text_small_fontSize		:	12px;
	--revilodesign_text_small_lineHeight	:	calc( var(--revilodesign_text_small_fontSize) + 8px );
	--revilodesign_text_small_fontWeight	:	300;	
	
	--revilodesign_sign_fontSize			:	40px;
	--revilodesign_sign_lineHeight			:	calc( var(--revilodesign_sign_fontSize) + 8px );
	--revilodesign_sign_fontWeight			:	400;
	
	--revilodesign_headlines_fontFamily		:	'Abhaya Libre';
	--revilodesign_text_fontFamily			:	'Inter';
	
	--revilodesign_headlines_fontFamily		:	'Abhaya Libre';
	--revilodesign_text_fontFamily			:	'Inter';
}
@media ( max-width: 768px ) {
	:root {
		--revilodesign_headline_h1_fontSize		:	48px;
		--revilodesign_headline_h2_fontSize		:	40px;
		--revilodesign_headline_h3_fontSize		:	20px;
		--revilodesign_sign_fontSize			:	32px;
	}
}
@media ( max-width: 589px ) {
	:root {
		--revilodesign_headline_h1_fontSize		:	48px;
		--revilodesign_headline_h2_fontSize		:	32px;
		--revilodesign_headline_h3_fontSize		:	17px;
		--revilodesign_sign_fontSize			:	24px;
	}
}
/* ------ */
/* GLOBAL */
/* ------ */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	background: transparent;
	border: 0;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}
body,
input,
select,
textarea {
	line-height: var(--revilodesign_text_lineHeight);
	font-size: var(--revilodesign_text_fontSize);
	font-weight: var(--revilodesign_text_fontWeight);
	font-family: var(--revilodesign_text_fontFamily);
	color: var(--revilodesign_textColor);
}
body,
html {
	width: 100%;
	min-height: 100%;
}
/*----------------*/
/* !GLOBAL STYLES */
/*----------------*/
a {
	color: rgba( var(--revilodesign_dark), 1);
	text-decoration: none;
	transition: all 0.2s ease-in-out;
	font-weight: var(--revilodesign_text_large_fontWeight);
}
a:hover {
	text-decoration: underline;
}
a:hover i {
	text-decoration: none;
}
/*---------*/
/* INPUT  */
/*---------*/
form {
	gap: 16px;
	display: flex;
	flex-direction: column;
}
label {
	padding-bottom: 2px;
	text-align: left;
	width: 100%;
	display: block;
	font-size: var(--revilodesign_text_small_fontSize);
	font-weight: var(--revilodesign_text_small_fontWeight);
	line-height: var(--revilodesign_text_small_lineHeight);
}
input,
select,
textarea {
	border: 1px solid rgba( var(--revilodesign_grey), 1);
	background: rgba( var(--revilodesign_white), 1);
	border-radius: var(--revilodesign_borderRadius);
	padding: 4px 16px;
	width: 100%;
	font-size: var(--revilodesign_text_fontSize);
	font-weight: var(--revilodesign_text_fontWeight);
	line-height: var(--revilodesign_text_lineHeight);
}
input:focus,
select:focus,
textarea:focus {
	outline: none;
	border: 1px solid rgba( var(--revilodesign_primary), 1);
}
input[type="radio"],
input[type="checkbox"] {
	width: auto;
}
/*-------------*/
/* BORDER BOX  */
/*-------------*/
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
/*-----------*/
/* ADDRESS  */
/*-----------*/
address {
	font-style: italic;
	padding: 0 0 24px 0;
}
/*-------*/
/* MARK  */
/*-------*/
mark {
	background-color: rgba( var(--revilodesign_primary), 1);
	padding: 0 2px;
}
/*-------------*/
/* WP CAPTION  */
/*-------------*/
div.wp-caption {
	display: inline-block;
	background: rgba( var(--revilodesign_white), 1);
	padding: 5px;
	margin-bottom: 24px;
	border: 1px solid rgba( var(--revilodesign_grey), 1);
}
div.wp-caption img {
	max-width: 100%;
	height: auto;
	margin: 0 0 5px 0;
}
div.wp-caption p {
	width: 100%;
	text-align: center;
	padding: 0;
}
/*----------*/
/* !CONTENT */
/*----------*/
.content {
	max-width: var(--rdgb-maxw, var(--revilodesign_maxWidth, 1448px));
	width: 100%;
	padding: 0 24px;
}
/*---------*/
/* TABLE  */
/*---------*/
table {
	width: 100%;
	margin: 0 0 24px 0;
	border-collapse: collapse;
	border-spacing: 0;
}
table thead,
table tbody,
table tfoot,
table tr {
	width: 100%;
}
table td,
table th {
	text-align: left;
	padding: 12px 8px;
}
table th {
	padding: 12px 8px;
	background: rgba( var(--revilodesign_primary), 1);
	color: rgba( var(--revilodesign_white), 1);
}
table tr:nth-child(even) td {
	background: rgba( var(--revilodesign_black), 0.032);
}
table th:first-of-type,
table tr:nth-child(even) td:first-of-type {
	border-radius: var(--revilodesign_borderRadius) 0 0 var(--revilodesign_borderRadius);
}
table th:last-of-type,
table tr:nth-child(even) td:last-of-type {
	border-radius: 0 var(--revilodesign_borderRadius) var(--revilodesign_borderRadius) 0;
}
table tr:hover td {
	background: rgba( var(--revilodesign_black), 0.088);
}
table td+td,
table th+th,
table th+td {
	border-left: 1px solid rgba( var(--revilodesign_white), 1);
}
table th+th {
	border-color: rgba( var(--revilodesign_white), .2);
}
table td span.logo {
	width: 88px;
	height: 40px;
	display: flex;
}
table td span.logo picture,
table td span.logo picture img {
	width: 100%;
	height: 100%;
	display: flex;
	object-fit: contain;
	object-position: center;
}
/*--------------*/
/* !TABLE SMALL */
/*--------------*/
table.table-small th,
table.table-small td {
	padding: 8px;
	font-size: var(--revilodesign_text_small_fontSize);
	line-height: var(--revilodesign_text_small_lineHeight);
	font-weight: var(--revilodesign_text_small_fontWeight);
}
@media ( max-width: 768px ) {
	table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}
/*----------*/
/* LIST UL  */
/*----------*/
ul {
	padding: 0 0 24px 40px;
	color: var(--revilodesign_textColor);
}
ul li {
	list-style: disc;
}
ul.check,
ul.pro,
ul.contra,
ul.icon {
	padding: 0 0 24px 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	flex-direction: column;
	gap: 32px;
}
ul.check li,
ul.pro li,
ul.contra li,
ul.icon li {
	list-style: none;
	position: relative;
	padding-left: 32px;
	text-align: left;
}
ul.check li::before,
ul.pro li::before,
ul.contra li::before {
	content: '\f00c';
	font-family: "Font Awesome 6 Pro"; 
	font-weight: 600;
	width: 20px;
	height: 20px;
	border: 1px solid rgba( var(--revilodesign_black), 1);
	color: rgba( var(--revilodesign_black), 1);
	font-size: 10px;
	display: flex;
	justify-content: center;
	align-content: center;
	align-items: center;
	border-radius: var(--revilodesign_borderRadius);
	position: absolute;
	left: 0;
	top: 2px;
}
ul.pro li::before {
	content: '\f164';
}
ul.contra li::before {
	content: '\f165';
	background: var(--revilodesign_error);
	color: var(--revilodesign_errorLight);
}
ul.social {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-end;
	gap: 8px;
}
ul.social li a {
	border-radius: var(--revilodesign_borderRadius);
	padding: 6px 12px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	border: 1px solid rgba(var(--revilodesign_primary), 1);
	color: rgba( var(--revilodesign_primary), 1);
	font-size: var(--revilodesign_text_fontSize);
	gap: 8px;
}
ul.social li a:hover {
	text-decoration: none;
	background: rgba(var(--revilodesign_primary), 1);
	color: rgba(var(--revilodesign_white), 1);
}
@media ( max-width: 768px ) {
	ul.social {
		align-items: flex-start;
	}
}
/*----------*/
/* !UL LIST */
/*----------*/
ul.list {
	padding: 0 0 24px 0;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: space-between;
}
ul.list li {
	list-style: none;
	width: calc( 50% - 4px);
	background: rgba( var(--revilodesign_black), 1);
	color: rgba( var(--revilodesign_white), 1);
	display: flex;
	flex-direction: row;
	gap: 16px;
	border-radius: var(--revilodesign_borderRadius);
	padding: 8px 16px;
	position: relative;
}
ul.list li::before{
	content: '';
	width: 4px;
	height: 8px;
	border-bottom: 1px solid rgba( var(--revilodesign_white), 1);
	border-right: 1px solid rgba( var(--revilodesign_white), 1);
	transform: rotate(45deg) translateX(6px) translateY(4px);
}
ul.list li p {
	padding: 0;
}
ul.list li span {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
ul.list li .headline {
	padding: 0;
}
@media ( max-width: 768px ) {
	ul.list li {
		width: 100%;
		min-width: 100%;
	}
}
/*------------*/
/* !LIST ICON */
/*------------*/
ul.icon {
	gap: 24px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding: 0;
}
ul.icon li {
	padding-left: 0;
	position: relative;
	min-height: 24px;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 12px;
}
ul.icon li i,
ul.icon li .icon {
	position: absolute;
	left: 0;
	top: 0;
	height: 24px;
	width: 24px;
	color: rgba( var(--revilodesign_black), .72);
	font-size: var(--revilodesign_text_small_fontSize);
	line-height: var(--revilodesign_text_small_lineHeight);
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
}
ul.icon li i {
	font-size: 18px;
}
ul.icon li span {
	display: flex;
	flex-direction: column;
}
ul.icon li .headline {
	padding: 0;
	font-weight: 700;
	font-size: var(--revilodesign_text_medium_fontSize);
	line-height: var(--revilodesign_text_medium_lineHeight);
}
ul.icon li p {
	padding: 0;
}
ul.icon li p+p {
	padding-top: 8px;
}
/*----------*/
/* !LIST OL */
/*----------*/
ol {
	padding: 0 0 24px 40px;
	color: var(--revilodesign_textColor);
	list-style-type: none;
	counter-reset: item;
	margin: 0;
	padding: 0;
}
ol > li {
	display: table;
	counter-increment: item;
	margin-bottom: 0.6em;
}
ol > li:before {
	content: counters(item, ".") ". ";
	display: table-cell;
	padding-right: 0.6em;
}
ol li ol > li:before {
	content: counters(item, ".") " ";
}
/*-------------*/
/* BLOCKQUOTE  */
/*-------------*/
blockquote {
	position: relative;
	color: rgba( var(--revilodesign_grey), 1);
	padding: 24px 0 0 24px;
	border-left: 2px solid rgba( var(--revilodesign_secondary), 1 );
	margin-bottom: 24px;
}
blockquote p {
	font-style: italic;
}
/*------------*/
/* SELECTION  */
/*------------*/
::selection {
	background: rgba( var(--revilodesign_primary), 1 );
	color: rgba( var(--revilodesign_white), 1 );
}
::-moz-selection {
	background: rgba( var(--revilodesign_primary), 1 );
	color: rgba( var(--revilodesign_white), 1 );
}
/*-----------*/
/* OVERLAYER */
/*-----------*/
div.overlayer {
	z-index: 997;
	position: fixed;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0,0,0,0.6);
	display: flex;
	justify-content: center;
	align-content: center;
	align-items: center;
	padding: 24px;
	display: none;
}
div.overlayer div.overlayerBg {
	position: absolute;
	z-index: 1;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vw;
}
div.overlayer div.overlayerContent {
	position: relative;
	z-index: 9;
	background: rgba( var(--revilodesign_white), 1);
	border-radius: var(--revilodesign_borderRadius);
	box-shadow: var(--revilodesign_boxShadow);
	padding: 24px;
	max-width: 600px;
	width: 100%;
}
div.overlayer div.overlayerContent h2 {
	padding-bottom: 16px;
}
div.overlayer div.overlayerContent div.overlayerCross {
	position: absolute;
	right: 12px;
	top: 12px;
	width: 24px;
	height: 24px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: var(--revilodesign_borderRadius);
	color: var(--revilodesign_error);
	transition: var(--revilodesign_transition);
	transform: rotate(0);
}
div.overlayer div.overlayerContent div.overlayerCross:hover {
	background: var(--revilodesign_errorLight);
	transform: rotate(360deg);
}
/*----------------*/
/* IFRAME / VIDEO */
/*----------------*/
div.video {
	border-radius: var(--revilodesign_borderRadiusBigs);
	overflow: hidden;
	display: inline-flex;
	height: 72vh;
	justify-self: center;
	max-width: 100%;
}
div.video.video-frame-smartphone {
	aspect-ratio: 1 / 1.72;
}
div.video video {
	max-width: 100%;
	max-height: 100%;
	object-fit: cover;
	position: relative;
	z-index: 9;
}
/*----------*/
/* PICTURE  */
/*----------*/
picture.picture {
	max-width: 100%;
	position: relative;
	display: inline-flex;
}
picture.picture img {
	width: 100%;
	height: 100%;
}
picture.greyscale {
	filter: grayscale(1);
}
picture.picture.cover,
picture.picture.fill {
	width: 100%;
	height: 100%;
	position: relative;
}
picture.picture.cover img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
picture.picture.fill img {
	object-fit: contain;
	width: 100%;
	height: 100%;
}
picture.picture.fill.left img {
	object-position: left;
}
picture.picture.fill.center img {
	object-position: center;
}
picture.picture.fill.right img {
	object-position: right;
}
/*----------*/
/* PICTURES */
/*----------*/
picture.icon {
	width: 80px;
	height: 80px;
	display: block;
}
picture.icon img {
	width: 100%;
	height: 100%;
}
picture.logo {
	display: inline-flex;
}
picture.logo img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
}
picture.vector.logo {
	width: 100%;
	height: 100%;
}
picture.invert {
	filter: invert(1);
}
/*---------*/
/* !FIGURE */
/*---------*/
figure {
	margin: 0;
	padding: 0;
	position: relative;
}
figure.fine-lines::after {
	content: '';
	position: absolute;
	left: 16px;
	top: 16px;
	height: calc( 100% - (2 * 16px ) );
	width: calc( 100% - (2 * 16px ) );
	border: 1px solid rgba( var(--revilodesign_white), .6);
	z-index: 999;
}
/*----------*/
/* !WRAPPER */
/*----------*/
#wrapper {
	position: relative;
	padding-top: 0;
	overflow: hidden;
}
@media ( max-width: 768px ) {
	#wrapper {
		padding-top: 64px;
	}	
}
/*-------------*/
/* BREADCRUMB  */
/*-------------*/
div#breadcrumb {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: wrap;
	position: relative;
	z-index: 9;
	padding: 12px 0 ;
}
div#breadcrumb div,
div#breadcrumb span {
	display: inline-flex;
	align-items: center;
}
div#breadcrumb > span+span::before {
	content: "\f054";
	font-family: "Font Awesome 6 Pro"; 
	font-weight: 900;
	font-size: 8px;
	margin: 0 8px;
}
div#breadcrumb a {
	color: rgba(var(--revilodesign_black), .6);
	font-size: 12px;
	line-height: 16px;
	padding: 3px 8px;
	position: relative;
	display: inline-flex;
	border-radius: var(--revilodesign_borderRadius);
}
div#breadcrumb a:hover {
	background: rgba( var(--revilodesign_primary), 1 );
	color: rgba( var(--revilodesign_white), 1);
	text-decoration: none;
}
div#breadcrumb a picture {
	display: inline-flex;
	height: auto;
	width: auto;
}
div#breadcrumb a picture img {
	height: 14px;
	padding: 2px 0;
}
div#breadcrumb a:hover picture img {
	filter: brightness(0) invert(1);
}
/*-------------*/
/* SUBHEADLINE */
/*-------------*/
.subheadline {
	padding-bottom: 8px;
}
/*------*/
/* MENU */
/*------*/
div#menu {
	display: none;
}
@media (max-width: 768px) {
	div#menu {
		display: inline-block;
		width: 32px;
		min-width: 32px;
		height: 40px;
		margin-left: auto;
		position: relative;
		z-index: 999;
	}
	div#menu::before,
	div#menu::after {
		content: '';
		width: 100%;
		height: 2px;
		background: rgba( var(--revilodesign_light), 1);
		position: absolute;
		left: 0;
		top: 50%;
	}
	.openMenu div#menu::before,
	.openMenu div#menu::after {
	}
	div#menu::before {
		margin-top: -4px;
	}
	div#menu::after {
		margin-top: 4px;
	}
	div#menu.active::before {
		animation-name: menuTop;
		animation-duration: 0.5s;
		animation-fill-mode: forwards;
		animation-iteration-count: 1;
		animation-timing-function: ease-in-out;
		background: rgba( var(--revilodesign_black), 1);
	}
	div#menu.active::after {
		animation-name: menuBottom;
		animation-duration: 0.5s;
		animation-fill-mode: forwards;
		animation-iteration-count: 1;
		animation-timing-function: ease-in-out;
		background: rgba( var(--revilodesign_black), 1);
	}
	div#menu.close::before {
		animation-name: closeMenuTop;
		animation-duration: 0.5s;
		animation-fill-mode: forwards;
		animation-iteration-count: 1;
		animation-timing-function: ease-in-out;
		background: rgba( var(--revilodesign_light), 1);
	}
	div#menu.close::after {
		animation-name: closeMenuBottom;
		animation-duration: 0.5s;
		animation-fill-mode: forwards;
		animation-iteration-count: 1;
		animation-timing-function: ease-in-out;
		background: rgba( var(--revilodesign_light), 1);
	}
}
/* OPEN */
@keyframes menuTop {
	0% {
		margin-top: -4px;
	} 50% {
		margin-top: -1px;
		transform: rotate(0deg);
	} 100% {
		transform: rotate(45deg);
		margin-top: 0;
	}
}
@keyframes menuBottom {
	0% {
		margin-top: 4px;
	} 50% {
		margin-top: -1px;
		transform: rotate(0deg);
	} 100% {
		transform: rotate(-45deg);
		margin-top: 0;
	}
}
/* CLOSE */
@keyframes closeMenuTop {
	0% {
		transform: rotate(45deg);
		margin-top: 0;
	} 50% {
		margin-top: -1px;
		transform: rotate(0deg);
	} 100% {
		margin-top: -4px;
	}
}
@keyframes closeMenuBottom {
	0% {
		transform: rotate(-45deg);
		margin-top: 0;
	} 50% {
		margin-top: -1px;
		transform: rotate(0deg);
	} 100% {
		margin-top: 4px;
	}
}
/*---------*/
/* HEADER  */
/*---------*/
header#header {
	width: 100%;
	left: 0;
	top: 0;
	z-index: 99;
	height: 64px;
	padding: 0;
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: stretch;
	box-shadow: none;
}

header#header.sticky {
	box-shadow: 0 4px 8px 0 rgba(46,43,56,0.16), 0 8px 16px 0 rgba(46,43,56,0.08), 0 16px 32px 0 rgba(46,43,56,0.04);
	position: fixed;
	transform: translateY(-200%);
	animation-name: showMenu;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-iteration-count: 1;
	padding-top: 0;
	background-color: rgba( var(--revilodesign_dark), 1 );
}
@keyframes showMenu {
	0% {
		transform: translateY(-200%);
	} 100% {
		transform: translateY(0%);
	}
}
header#header div.content {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: nowrap;
	position: relative;
}
header#header div.content a.logo {
	display: inline-flex;
	align-content: center;
	align-items: center;
	flex-wrap: nowrap;
	height: 32px;
	width: auto;
	position: relative;
	z-index: 999;
	max-width: 70%;
	margin-right: 24px;
}
header#header div.content a.logo picture {
	width: 100%;
	height: 100%;
	transition: var(--revilodesign_transition);
}
header#header div.content a.logo picture img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
/*--------------*/
/* !HEADER MENU */
/*--------------*/
header#header div.content .menu {
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
}
@media ( max-width: 768px ) {
	header#header {
		height: 64px;
		position: fixed;
		background-color: rgba( var(--revilodesign_dark), 1 );
	}
	header#header div.content a.logo {
		margin-right: 0;
		overflow: hidden;
		max-height: 100%;
	}
	header#header div.content a.logo picture img {
		height: auto;
	}
	header#header div.content .menu {
		flex-direction: row;
		border: none;
	}
}
/*------------*/
/* NAVIGATION */
/*------------*/
nav#nav {
	display: inline-flex;
	justify-content: flex-end;
	align-items: center;
	gap: 8px;
	height: 100%;
	position: relative;
}
nav#nav ul {
	display: flex;
	gap: 8px;
	align-items: center;
	padding: 0;
	height: 100%;
}
nav#nav li {
	list-style: none;
	position: relative;
	height: 100%;
	padding: 12px 0;
}
nav#nav ul li a:not(.btn) {
	color: rgba( var(--revilodesign_white), 1);
	display: inline-flex;
	gap: 8px;
	align-items: center;
	height: 100%;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-size: var(--revilodesign_text_small_fontSize);
	line-height: var(--revilodesign_text_small_lineHeight);
	border-radius: var(--rdgb-btn-radius, 4px);
	border: none;
	padding: 6px 12px;
}
nav#nav ul li a:hover,
nav#nav ul li a.highlight,
nav#nav ul > li.current-menu-parent > a,
nav#nav ul > li.current-menu-item a,
nav#nav ul > li a.current-page-ancestor {
	text-decoration: none;
	background: rgba( var(--revilodesign_primary), 1);
	color: rgba( var(--revilodesign_white), 1);
}
nav#nav ul li.current-menu-item a {
	
}
nav#nav ul li a picture {
	height: 24px;
	width: 24px;
	display: inline-flex;
	justify-content: center;
}
nav#nav ul li a picture img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
nav#nav ul > li.menu-item-has-children > a::after {
	content: "\f078";
	font-family: "Font Awesome 6 Pro"; 
	font-weight: 900;
	font-size: 10px;
}
@media ( max-width: 768px ) {
	nav#nav {
		display: flex;
		align-items: center;
		justify-content: center;
		position: fixed;
		width: 100%;
		height: 100vh;
		background: rgba( var(--revilodesign_light ), 1);
		top: 0;
		left: 0;
		z-index: 800;
		transform: translateX(100%);
		visibility: hidden;
		transition: transform 0.35s ease, visibility 0s linear 0.35s;
	}
	nav#nav.active {
		transform: translateX(0);
		visibility: visible;
		transition: transform 0.35s ease, visibility 0s linear 0s;
	}
	nav#nav ul {
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 24px;
		max-width: 100%;
	}
	nav#nav ul li {
		height: initial;
		padding: 0;
	}
	nav#nav ul li a:not(.btn) {
		padding: 12px 40px;
	}
	nav#nav ul li a {
		font-size: var(--revilodesign_headline_h4_fontSize);
		line-height: var(--revilodesign_headline_h4_lineHeight);
	}
	nav#nav ul li a i {
		font-size: var(--revilodesign_headline_h4_fontSize);
		line-height: var(--revilodesign_headline_h4_lineHeight);
	}
	nav#nav ul li a:not(.btn) {
		font-size: var(--revilodesign_headline_h4_fontSize);
		line-height: var(--revilodesign_headline_h4_lineHeight);
		color: rgba( var(--revilodesign_black), 1);
		font-family: "Instrument Serif", serif;
		font-weight: 400;
		font-style: italic;
		border: 2px solid transparent;
	}
	nav#nav ul li a:not(.btn):hover,
	nav#nav ul li.current-menu-item a:not(.btn) {
		background: none;
		border-color: rgba( var(--revilodesign_primary), 1 );
	}
}
/*---------------------*/
/* !NAVIGATION SUBMENU */
/*---------------------*/
nav#nav ul li ul {
	top: calc( 100% - 16px);
	left: 50%;
	position: absolute;
	border-radius: var(--revilodesign_borderRadiusBigs);
	background: rgba( var(--revilodesign_white), 1 );
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 4px;
	height: auto;
	padding: 8px;
	transform: translateY(-10%) translateX(-50%);
	opacity: 0;
	pointer-events: none;
	box-shadow: var(--revilodesign_boxShadowBig);
}
nav#nav ul li:hover ul {
	animation-name: showSubMenu;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	animation-iteration-count: 1;
}
@keyframes showSubMenu {
	0% {
		transform: translateY(-10%) translateX(-50%);
		opacity: 0;
		pointer-events: none;
	} 100% {
		transform: translateY(0%) translateX(-50%);
		opacity: 1;
		pointer-events: auto;
	}
}
nav#nav ul li ul li {
	padding: 0;
}
nav#nav ul li ul li a {
	color: rgba( var(--revilodesign_black), .5 );
	padding: 12px 32px;
	text-wrap: nowrap;
	width: 100%;
}
nav#nav ul li ul li a:hover,
nav#nav ul li ul li.current-menu-item a {
	color: rgba( var(--revilodesign_light), 1 );
	background: rgba( var(--revilodesign_primary), 1 );
}
/*--------------*/
/* !NAV BUTTONS */
/*--------------*/
nav#nav ul li a.revilodesign-btn {
	color: rgba( var(--revilodesign_white), 1);
	justify-content: center;
	aspect-ratio: 1 / 1;
	font-size: 20px;
}
nav#nav ul li a.revilodesign-btn.btn-outlined {
	color: rgba( var(--revilodesign_primary), 1);
}
nav#nav ul li a.revilodesign-btn::after {
	display: none;
}
nav#nav ul li a.revilodesign-btn:hover {
	transform: initial;
	background: rgba( var(--revilodesign_primary), 1);
}
nav#nav ul li a.revilodesign-btn.btn-outlined:hover {
	color: rgba( var(--revilodesign_light), 1);
}
/*---------*/
/* !ACTION */
/*---------*/
header#header div.action {
	display: flex;
}
/*---------------*/
/* !ROTATET TEXT */
/*---------------*/
.rotated-text {
	position: absolute;
	z-index: 99;
	left: 70px;
	bottom: 8px;
	transform: rotate(-90deg);
	transform-origin: left bottom;
	white-space: nowrap;
}
/*--------------*/
/* SCROLL WIDTH */
/*--------------*/
div#scrollWidth {
	width: 100vw;
	height: 6px;
	position: fixed;
	left: 0;
	top: 64px;
	z-index: 90;
	background: rgba( var(--revilodesign_black), 1);
}
div#scrollWidth div {
	width: 0;
	height: 6px;
	background: rgba( var(--revilodesign_white), 1);
	position: absolute;
	left: 0;
	top: 0;
	transition: var(--revilodesign_transition);
	border-radius: 0 var(--revilodesign_borderRadius) var(--revilodesign_borderRadius) 0;
}
/*----------*/
/* THROBBER */
/*----------*/
div#throbber {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba( var(--revilodesign_white), 1);
	color: rgba( var(--revilodesign_black), 1);
	font-weight: 500;
	z-index: 999;
	display: flex;
	justify-content: center;
	align-content: center;
	align-items: center;
	flex-direction: column;
	gap: 16px;
}
div#throbber picture,
div#throbber picture img {
	height: 160px;
	width: 160px;
}
/*---------*/
/* FOOTER */
/*---------*/
footer {
	display: flex;
	flex-direction: column;
	font-size: 14px;
	background: var(--rdgb-btn-bg, var(--rdgb-color-primary, #0078ff));
	padding: 0 24px;
}
footer div.flex {
	padding: 16px 0;
	display: flex;
	justify-content: space-between;
}
footer a,
footer i {
	color: rgba( var(--revilodesign_white), 1);
}
footer p {
	font-size: var(--revilodesign_text_small_fontSize);
	line-height: var(--revilodesign_text_small_lineHeight);
	font-weight: var(--revilodesign_text_small_fontWeight);
	padding: 0;
	color: rgba( var(--revilodesign_white), 1);
}
footer ul {
	display: flex;
	flex-direction: row;
	gap: 8px;
	padding: 0;
}
footer ul li {
	list-style: none;
	font-size: var(--revilodesign_text_small_fontSize);
	line-height: var(--revilodesign_text_small_lineHeight);
	font-weight: var(--revilodesign_text_small_fontWeight);
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 0;
	color: rgba( var(--revilodesign_white), 1);
}
footer ul li a {
	display: block;
	color: rgba( var(--revilodesign_white), 1);
}
footer ul li.current-menu-item a {
	color: rgba( var(--revilodesign_black), 1);
	font-weight: 700;
}
footer .logo {
	height: 24px;
}
@media ( max-width: 768px ) {
	footer .flex {
		flex-direction: column;
		align-content: center;
		justify-content: center;
		text-align: center;
	}
	footer .logo {
		order: -1;
		height: 40px;
		display: flex;
		justify-content: center;
	}
	footer ul {
		display: flex;
		justify-content: center;
	}
}
.dynamic-lines {
	position : relative; 
}
.dynamic-lines::before {
	content      : '';
	position     : absolute;
	inset        : 0 0 auto 0; /* top:0, right:0, left:0 – bottom:auto */
	height       : var(--dl-right-h, 35%);
	border-top   : 1px solid var(--dl-color, rgba(255, 255, 255, 0.55));
	border-right : 1px solid var(--dl-color, rgba(255, 255, 255, 0.55));
	pointer-events : none;
}
.dynamic-lines::after {
	content       : '';
	position      : absolute;
	inset         : 0 auto 0 0; /* top:0, bottom:0, left:0 – right:auto */
	width         : var(--dl-bottom-w, 35%);
	border-left   : 1px solid var(--dl-color, rgba(255, 255, 255, 0.55));
	border-bottom : 1px solid var(--dl-color, rgba(255, 255, 255, 0.55));
	pointer-events : none;
}
.aos-init.dynamic-lines::before {
	clip-path  : inset(0 0 100% 100%); /* versteckt – nur top-right-Ecke sichtbar */
	transition : clip-path 0s;
}
.aos-init.dynamic-lines::after {
	clip-path  : inset(100% 100% 0 0); /* versteckt – nur bot-left-Ecke sichtbar */
	transition : clip-path 0s;
}

.aos-animate.dynamic-lines::before {
	clip-path  : inset(0 0 0 0);
	transition : clip-path 0.55s ease 0.45s;
}
.aos-animate.dynamic-lines::after {
	clip-path  : inset(0 0 0 0);
	transition : clip-path 0.55s ease 0.65s;
}
.rd-photo-gallery .rdgal-item > img, .rd-photo-gallery .rdgal-item > picture {
	height: 100%;
}

