/*
Theme Name: Franziska-von-Aachen
Theme URI: http://www.xiqit.de
Author: XIQIT GmbH
Author URI: http://www.xiqit.de
Version: 1.0
Text Domain: blank
*/


@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap');

@font-face {
    font-family: 'Renner';
    src: url('fonts/Renner-it-Medium.eot');
    src: url('fonts/Renner-it-Medium.eot?#iefix') format('embedded-opentype'),
        url('fonts/Renner-it-Medium.woff2') format('woff2'),
        url('fonts/Renner-it-Medium.woff') format('woff'),
        url('fonts/Renner-it-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Renner';
    src: url('fonts/Renner-it-Bold.eot');
    src: url('fonts/Renner-it-Bold.eot?#iefix') format('embedded-opentype'),
        url('fonts/Renner-it-Bold.woff2') format('woff2'),
        url('fonts/Renner-it-Bold.woff') format('woff'),
        url('fonts/Renner-it-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Droid Sans Mono';
    src: url('fonts/DroidSansMono-webfont.eot');
    src: url('fonts/DroidSansMono-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/DroidSansMono-webfont.woff2') format('woff2'),
         url('fonts/DroidSansMono-webfont.woff') format('woff'),
         url('fonts/DroidSansMono-webfont.ttf') format('truetype'),
         url('fonts/DroidSansMono-webfont.svg#droid_sans_monoregular') format('svg');
    font-weight: normal;
    font-style: normal;

}






html, 
body {
	padding: 0px;
	margin: 0px;
	height: 100%;
	background:#F3EDEB;
	font-family: 'Open Sans', Verdana, sans-serif;
	font-size: 15px;
	line-height: 1em;
	font-weight: 400;
	color: black;
}

div.wp-block-kadence-accordion { 
	font-family: 'Open Sans'; 
	font-weight: 400; 
}

*,
*::before,
*:after {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.clearfix::before,
.clearfix:after {
	content: " ";
	display: table;
	clear: both;
}

.clear {
	clear: both;
	display: block;
}

.wrapper{
	position: relative;
	width:100%;
	max-width:1580px;
	padding:0 20px 0 20px;
	margin:0 auto;
}

.magwrapper {
    width: fit-content;
    max-width: 1580px;
    padding: 0 14px;
    margin: 0 30px;
    background-color: rgb(229, 9, 127);
}

.magwrapper .p1 {
    font-size: 15px;
    line-height: 1;
    padding: 9px 4px 6px 0;
}

.magwrapper .h1 {
    font-size: 48px;
    line-height: 1.2em;
    padding: 0 4px 3px 0;
}

.zfs{
	font-size: 0px;
}

.onehalf, .onethird, .onefourth, .onefith{
	display: inline-block;
	vertical-align: top;
}

.onehalf{
	width:50%;
}

.onethird{
	width:33.33%;
}

.onefourth{
	width:25%;
}

.onefith{
	width:20%;
}

.table{
	display: table;
	width: 100%;
	height: 100%;
}

.table-cell{
	display: table-cell;
	width: 100%;
	height: 100%;
	vertical-align: middle;
}



#subpage .content .wp-block-image,
.fullscreen{
	width: 100vw;
	height: auto;
	margin-left: calc(-50vw + 50%);
	max-width: none;
}




/* Header */

header{
	position: absolute;
	top:0px;
	left: 0;
	right: 0;
	min-height: 80px;
	padding:10px 0px;
	z-index: 100;

	transition: border-bottom 400ms ease-out;
	-moz-transition: border-bottom 400ms ease-out;
	-webkit-transition: border-bottom 400ms ease-out;

	box-shadow: 0px 0px 8px rgba(0,0,0,0);
}

header.open{
	background: #F3EDEB;
	box-shadow: 0px 0px 8px rgba(0,0,0,0.25);
}

header #logo{
	display: inline-block;
	vertical-align: top;
	position: absolute;
	top:12px;
	left:20px;
	width: 208px;
	height: 45px;
	background-image: url(img/fva-logo.png);
	background-size: 100% auto;
	background-position: top left;
	background-repeat: no-repeat;
}
/*
header #logo img{
	display: inline-block;
	vertical-align: middle;
	width: 208px;
	height: auto;
}*/

header #logo h2{
	display: inline-block;
	vertical-align: middle;
	margin: 0px 0 0 15px;
	font-weight: 600;
}



/* Menu */

nav#main{
	display: block;
	font-size: 0;
}

nav#main ul{
	display: block;
	margin: 0 0 0 300px;
	padding: 18px 0 0 0;
}

nav#main ul li{
	display: inline-block;
	vertical-align: top;
	margin: 0;
	padding: 0;
	width: 16.66%;
}

nav#main a{
	display: inline-block;
	vertical-align: top;
	font-size:15px;
	max-width: 120px;
}


nav#main ul li.page_item_has_children{
	position:relative;
}

nav#main ul.submenu{
	display: none;
}


/* Submenu */

header .menu{
	display: none;
	background: #F3EDEB;
}

header .menu .wrapper{
	padding-top: 25px;
	padding-left: 320px;
	padding-bottom: 30px;
	font-size: 0px;
}

header .menu .cell{
	display: inline-block;
	vertical-align: top;
	width: 16.66%;
	padding-right: 10px;
	margin-bottom: 20px;
}

header .menu .cell > a{
	display: none;
	font-size: 15px;
	font-weight: 500;
	margin-bottom: 5px;
}


header .menu ul{
	display: block;
	margin: 0;
	padding: 0;
	list-style: none;
}

header .menu ul li{
	position: relative;
	display: block;
	margin: 0 0 8px 0;
	padding: 0;
    line-height: 1.1;
}

header .menu ul li a{
	display: block;
	font-size: 15px;
	font-weight: 200;
}

header .menu ul li a[aria-current="page"],
header .menu ul li a:hover{
	font-weight: 500;
}


header .menu ul li.menu-item-has-children:after{
	content: "";
	position: absolute;
	top: 1px;
	right: 0px;
	width: 15px;
	height: 15px;

	background-image: url(img/arrow-down.png);
	background-position: top right;
	background-size: 15px auto;
	background-repeat: no-repeat;
}

header .menu ul li.menu-item-has-children.open:after{
	transform: rotate(180deg);
	-moz-transform: rotate(180deg);
	-webkit-transform: rotate(180deg);
}

header .menu ul li .submenu{
	padding-top: 5px;
	padding-bottom: 10px;
}

header .menu ul li:not(.open) .submenu{
	display: none;
}








#search{
	display: block;
	width: 100%;
	text-align: right;
}

#search input[type="search"]{
	width: 100%;
	background: None;
	border: none;
	border-bottom: 1px solid black;
	padding: 0 0 1px 0;
	position: relative;
	max-width: 200px;
	font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, Verdana, sans-serif;
	font-size: 14px;
	position: relative;
	top: -1px;
	outline: none;
}

#search input[type="submit"]{
	display: none;
}



/* Main */

main{
	min-height: 100vh;
	overflow-x: hidden;
}

body.page main{
	margin-top: 60px;
	padding: 50px 0 0 0;
}


/* Section */
section{
	display: block;
	margin:0;
}

section.nomargin{
	margin-top: 0 !important;
}



/* Intro */

section#intro{
	position: relative;
	background-size:cover !important;
	background-repeat: no-repeat !important;
	background-position: center center !important;
	height:100vh;
	margin-top:0px;
	margin-bottom: 20px;
	cursor: pointer !important;
}

section#intro .wrapper{
	position: relative;
	height: 100%;
}

section#intro .image{
	position: absolute;
	right: 20px;
	bottom: 20px;
	left: calc(316px + (100% - 316px) / 6);
	height: calc(100vh - 120px);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	object-position: 10% 60%	;
}

section#intro .caption{
	position: absolute;
	bottom: 20px;
	left: 20px;
	width: calc(300px + (100% - 300px) / 6);
	padding-right: 40px;
}

section#intro .caption .title{
	margin-bottom: 20px;
}

section#intro .caption .text{
	display: block;
	max-width: 420px;
}

/* Formular KV-Wahl */

nf-form-content .nf-field-element .ninja-forms-field:not(select), .nf-form-content .nf-field-label label {
    font-size: 15px !important; 
}

.field-wrap input[type=submit] {
 	font-family: 'Open Sans', sans-serif;
	font-size: 15px!important; 
	background-color: rgb(229, 9, 127);
	border-radius: 100px;
	padding: 10px 20px;
	border: 0;
	color: white;
}

/* Slideshow */

section#slideshow{
	background: #222222;
	margin-bottom: 70px;
	position: relative;
}

section#slideshow .caption{
	position: absolute;
	top: 0px;
	right: 0px;
	bottom: 0px;
	left: 0px;
	margin: auto 0;
}

section#slideshow .wrapper{
	height: 100%;
	position: relative;
	padding: 0;
}

section#slideshow .caption .inner{
	width: 100%;
	height: 100%;
	width: calc(300px + (100% - 300px) / 6);
	padding-left: 20px;
}

section#slideshow .caption .paginator{
	position: absolute;
	width: 15px;
	left: -20px;
	top: 0px;
	bottom: 0px;
}

section#slideshow .caption .paginator .dot{
	display: block;
	width: 15px;
	height: 15px;
	border: 2px solid #F0A992;
	border-radius: 100%;
	margin: 10px 0;
	cursor: pointer;
}

section#slideshow .caption .paginator .dot.selected{
	background: #F0A992;
}

section#slideshow .caption .h1{
	display: block;
	margin-bottom: 20px;
}

section#slideshow .caption .text{
	display: block;
	max-width: 420px;
}

section#slideshow .caption .more{
	display: block;
	padding-top: 16px;
	max-width: 420px;
}



section#slideshow .container{
	display: block;
	margin-left: calc(316px + (100% - 316px) / 6);
}

section#slideshow .slide{
	width: 100%;
	padding-top: 50%;
	background-size: cover !important;
	background-position: center center !important;
}

section#slideshow .slideshow{

}

.flickity-viewport{
	height: 7vh;
}

.flickity-slider{
	height: 7vh;
}







/* Information */

section#information{

}

section#information .container{
	display: block;
	padding-right: 100px;
}

section#information h2{
	margin-bottom: 20px;
}


.wp-block-columns{
	display: block;
	font-size: 0px;
}

.wp-block-columns .wp-block-column{
	display: inline-block;
	vertical-align: top;
	margin: 0;
	padding: 0;
	padding-right: 50px;

	width: calc( (100% - (300px + (100% - 300px) / 6)) / 2 );
}

.wp-block-columns .wp-block-column h2{
	margin-bottom: 30px;
}

.location.w1,
.wp-block-columns .wp-block-column:nth-child(1){
	width: calc(300px + (100% - 300px) / 6);
}

.wp-block-columns .wp-block-column p{
	max-width: 420px;
}





/* dienstleistungen */
section.dienstleistungen{


}

section.dienstleistungen .dienste{
	display: block;
	margin-left: -20px;
}

section.dienstleistungen .preview{
	display: inline-block;
	vertical-align: top;
	width: 25%;
	padding-left: 20px;
	margin-bottom: 20px;
}

section.dienstleistungen .preview .inner{
	display: inline-block;
	vertical-align: top;
	width: 100%;
	padding-top: 100%;
	position: relative;
	background-size: cover !important;
	background-position: center center !important;
	background-repeat: no-repeat !important;

}

section.dienstleistungen .preview .overlay{
	position: absolute;
	left: 0px;
	right: 0px;
	bottom: 0px;
	padding: 15px 15px 0px 15px;
	min-height: 45px;
}

section.dienstleistungen .preview .overlay .title{
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
}

section.dienstleistungen .preview .overlay .more {
	position: relative;
	display: block;
	overflow: hidden;
	height: 0px;
	transition: all 400ms ease-in-out;
}

section.dienstleistungen .preview .overlay .more:before,
div.gottesdienstspalte div.more:before {
	content: "";
	position: absolute;
	top: 20px;
	left: 0px;
	width: 15px;
	height: 15px;
	font-family: 'Renner';
	font-size: 25px;
	color: black;
}

section.dienstleistungen .preview .overlay .more span,
div.gottesdienstspalte div.more {
	display: block;
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
	text-align: right;
	padding-top: 20px;
}

section.dienstleistungen .preview .inner:hover .overlay .more{
	height: 50px;
}


div.breadcrumbs {
	padding-bottom: 10px;
}


/* Highlights */

.highlights{

}

.highlights .wrapper{
	padding-right: 0px;
}

.highlights .inner{
	display: block;
	white-space: nowrap;
	text-align: right;
}

.highlights .highlight{
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: 100px;
	height: 580px;
	overflow: hidden;

	transition: width 400ms ease-in-out;
}

.highlights .highlight .image{
	display: block;
	height: 150px;
	background-size: 1024px !important;
	background-position: center center !important;
	background-repeat: no-repeat !important;
}

.highlights .highlight .title{
	position: absolute;
	top: 180px;
	left: 100%;
	left: calc(100% - 10px);
	width: 320px;
	white-space: normal;
	text-align: left;
	text-transform: uppercase;
	transform-origin: top left;
	transform: rotate(90deg);

	transition: left 200ms ease-in-out;
	-moz-transition: left 200ms ease-in-out;
	-webkit-transition: left 200ms ease-in-out;
}


.highlights .highlight .bigtitle{
	font-family: 'Renner';
	font-size: 120px;
	font-weight: 700;
	position: absolute;
	top: 170px;
	right: 10px;
	text-transform: uppercase;
	line-height: 1em;

	opacity: 0;


	transition: opacity 100ms ease-in-out, right 0ms linear;
	-moz-transition: opacity 100ms ease-in-out, right 0ms linear;
	-webkit-transition: opacity 100ms ease-in-out, right 0ms linear;

	transition-delay: 100ms;
	-moz-transition-delay: 100ms;
	-webkit-transition-delay: 100ms;

}





/* Soziale Projekte */
section.soziale-projekte{

}

section.soziale-projekte .projekte{
	display: block;
	margin-left: -20px;
}

section.soziale-projekte .tile{
	display: inline-block;
	vertical-align: top;
	width: 33.33%;
	padding-left: 20px;
}

section.soziale-projekte .tile .inner{
	display: inline-block;
	vertical-align: top;
	width: 100%;
	padding-top: 40%;
	position: relative;
}

section.soziale-projekte .tile .title{
	position: absolute;
	top: 20px;
	left: 20px;
	right: 20px;
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
	max-width: 400px;
	line-height: 1.3;
}


.overlay.more{
	position: absolute;
	left: 0px;
	right: 0px;
	bottom: 0px;
	padding: 15px 15px 0px 15px;
}

.overlay.more div{
	position: relative;
	display: block;
	overflow: hidden;
	height: 0px;
	transition: all 400ms ease-in-out;
}

.overlay.more div:before{
	content: "";
	position: absolute;
	top: 20px;
	left: 0px;
	width: 15px;
	height: 15px;
	background: url(img/plus-black.svg);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;

	/*
	opacity: 0;
	transform: rotate(-180deg);

	transition: all 400ms ease-in-out;

	transition-delay: 200ms;
	*/
	
}

.overlay.more span{
	display: block;
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
	text-align: right;
	padding-top: 20px;
}

.post:hover .overlay.more div,
.highlight:hover .overlay.more div,
.aktuelles .onefith .inner:hover .overlay.more div,
section.soziale-projekte .tile .inner:hover .overlay.more div{
	height: 50px;
}




/* Aktuelles */
section#aktuelles{

}

.aktuelles{
	display: block;
}

.aktuelles .onefith{
	padding-top: 40%;
	position: relative;
}

.aktuelles .onefith .inner{
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
}

.aktuelles .onefith .image{
	position: relative;
	width: 100%;
	height: 250px;
	overflow: hidden;
}

.aktuelles .onefith .image img{
	position: absolute;
	top: 0px;
	right: 0px;
	bottom: 0px;
	left: 0px;
	width: 100%;
	height: 100%;	
	margin: auto;
	object-fit: cover;
}

.aktuelles .onefith .date{
	font-family: 'Renner';
	font-weight: 400;
	text-transform: uppercase;
	font-size: 15px;
	margin: 20px;
	text-align: right;
	display: none;
}

.aktuelles .onefith .title{
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.2em;
	margin: 10px 20px 20px 20px;

}

.aktuelles .onefith .termin{
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.2em;
	margin: 10px 20px 0px 20px;

}
/* Aktuelles Übersicht */

.post{
	display: block;
	margin-bottom: 20px;
	position: relative;
}

.post .image{
	display: inline-block;
	vertical-align: top;
	width: 240px;
	height: 150px;
	background-size: cover !important;
	background-position: center center !important;
	background-repeat: no-repeat !important;
}

.post .details{
	display: inline-block;
	vertical-align: top;
	width: calc(100% - 240px);
	padding: 20px;
}

.post .details .title{
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.2em;
}

.post .details .date{
	font-family: 'Renner';
	text-transform: uppercase;
	font-size: 17px;
	margin-bottom: 10px;
}

.post .overlay{
	left: 240px;
}



/* Spenden */

section#spenden{

}

section#spenden .inner{
	position: relative;
	display: block;
	padding-top: 100%;
	background-size: cover !important;
	background-repeat: no-repeat !important;
	background-position: center center !important;
}

section#spenden .inner:after{
	content: "";
	position: absolute;
	top: 70px;
	left: 70px;
	width: 70px;
	height: 70px;
	background: url(img/plus.svg);
	background-size: 100% auto;
	background-position: center center;
	background-repeat: no-repeat;
}

section#spenden .inner .bottom{
	position: absolute;
	bottom: 0px;
	left: 0px;
	right: 0px;
	padding: 70px;
}

section#spenden .inner .bottom .title{
	display: block;
	font-family: 'Renner';
	font-size: 80px;
	line-height: 1em;
	font-weight: 700;
	color: #F3EDEB;
	text-transform: uppercase;
	padding-left: 10px;
	padding-top: 16px;
	max-width: 920px;
}

section#spenden .inner .bottom .text{
	display: block;
	font-size: 30px;
	line-height: 1.3em;
	color: #F3EDEB;
	padding-top: 30px;
	padding-left: 10px;
	padding-bottom: 10px;
	max-width: 920px;
}





/* Kontakt */

section#kontakt{

}

#map{
	height: calc(100vw * 0.5);
}

.mapMarker{
	position: relative;
	width: 30px;
	height: 30px;
}

.mapMarker .marker{
	position: relative;
	width: 50px;
	height: 50px;
	background-image: url(img/map-rose.png);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;

	transform: scale(1);
	-moz-transform: scale(1);
	-webkit-transform: scale(1);

	transition: transform 200ms ease-in-out;
	-moz-transition: transform 200ms ease-in-out;
	-webkit-transition: transform 200ms ease-in-out;
}

.mapMarker.selected .marker{
	z-index: 5;
	transform: scale(1.1);
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
}

.mapMarker[data-cat="1"] .marker{
	background-image: url(img/map-red.png);
}

.mapMarker[data-cat="2"] .marker{
	background-image: url(img/map-blue.png);
}

.mapMarker .map-info{
	position: absolute;
	top: 100%;
	left: 20px;
	margin-top: 35px;
	min-width: 360px;
	background: #fff;	
	padding: 25px 50px 25px 30px;
	border-left: 10px solid #FFCFC4;
	transform: translateX(-50%);
	z-index: 100;

	display: none;
}

.mapMarker .map-info:after{
	content: "";
	position: absolute;
	top: -15px;
	left: 0px;
	right: 0px;
	width: 30px;
	height: 15px;
	margin: 0 auto;
	border-style: solid;
	border-width: 0 15px 15px 15px;
	border-color: transparent transparent #ffffff transparent;
}

.mapMarker.selected .map-info{
	display: block;
}

.mapMarker[data-cat="1"] .map-info{
	border-left-color: #FFA2B1;
}

.mapMarker[data-cat="2"] .map-info{
	border-left-color: #B1DEFF;
}

.mapMarker .map-info .title{
	margin-bottom: 3px;
	font-weight: 500;
}

.mapMarker .map-info .link:before{
	content: "";
	display: inline-block;
	vertical-align: middle;
	width: 15px;
	height: 15px;
	background: url(img/marker.png);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	margin-right: 5px;
	position: relative;
	top: -2px;
}

.mapMarker .map-info .close{
	position: absolute;
	top: 27px;
	right: 20px;
	width: 23px;
	height: 23px;
	background: url(img/plus-black.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;

	opacity: 0.75;

	transform: rotate(45deg) scale(1);
	-moz-transform: rotate(45deg) scale(1);
	-webkit-transform: rotate(45deg) scale(1);

	transition: all 400ms ease-in-out;
	-moz-transition: all 400ms ease-in-out;
	-webkit-transition: all 400ms ease-in-out;
}

.mapMarker .map-info .close:hover{
	opacity: 1;

	transform: rotate(45deg) scale(1.1);
	-moz-transform: rotate(45deg) scale(1.1);
	-webkit-transform: rotate(45deg) scale(1.1);
}



section#kontakt .wrapper.second{
	margin-top: 50px;
}

.btn-cat{
	cursor: pointer;
}

.external:hover,
h2.btn-cat:hover,
h2.btn-cat.selected{
	border-left-width: 16px;
}


/* Gemeinden */

section#gemeinden{
	margin-top: 50px;
	margin-bottom: 200px;
}

.locations{
	display: block;
	font-size: 0px;
	margin-top: 20px;
}

.location{
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: 33.33%;
	margin-bottom: 30px;
	padding-left: 40px;
	cursor: pointer;
}

.location:before{
	content: "";
	position: absolute;
	top: 0px;
	left: 0px;
	width: 30px;
	height: 30px;
	margin: auto 0;
	background-image: url(img/map-rose.png);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

.location[data-cat="1"]:before{
	background-image: url(img/map-red.png);
}

.location[data-cat="2"]:before{
	background-image: url(img/map-blue.png);
}



/* Partner */

section#partner{
	margin-top: 100px;
	margin-bottom: 100px;
}

section#partner .partners{
	display: flex;
	justify-content: space-between;
	flex-direction: row;
	align-items: baseline;
}
/*
section#partner .partners .partner{
	display: inline-block;
	vertical-align: middle;
	height: 70px;
	margin: 0 30px 30px 0;
}

section#partner .partners .partner:last-child{
	margin-right: 0px;
}

section#partner .partners .partner img{
	width: auto;
	height: 100%;
}*/

section#partner .partners .wp-block-image{
	display: inline-block;
	vertical-align: middle;
	height: 70px;
	margin: 0 30px 30px 0;
}


section#partner .partners .kb-image8fdaee-5b {
	padding-right: 15px !important;
}

section#partner .partners .wp-block-image:last-child{
	margin-right: 0px;
}

section#partner .partners .wp-block-image img{
/*	width: auto; *.
	/* height: 100%; */
	object-fit: contain;
}

section#partner .partners .partnericon {
	vertical-align: baseline;
}

.partnericonwide img {
   padding-bottom: 20px;
}

/* body.home  */
.external,
h2,
.h2{
	padding-left: 15px;
	border-left: 8px solid #FFCFC4;

	transition: border-left 400ms ease-in-out;
	-moz-transition: border-left 400ms ease-in-out;
	-webkit-transition: border-left 400ms ease-in-out;
}

h2.red,
.h2.red{
	border-left-color: #FFA2B1;
}

h2.blue,
.h2.blue{
	border-left-color: #B1DEFF;
}





.kalender{
	font-size: 15px;
	line-height: 1.7em;
}

.kalendershort {
	line-height: 1.5em;
}

.kalender .event{
	display: inline-block;
	vertical-align: top;
	width: 50%;
	margin-bottom: 40px;
	padding-right: 0px;
}

.termine:not(.withDays) .kalender .event{
	display: block;
	width: auto;
}

.kalender[data-when="today"] .event{
	display: block;
	width: auto;
	margin-bottom: 0px;
}

.kalender .date{
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: 100px;
	height: 100px;
	background: #F0A992;	
}

.kalender .event.col-2 .date{
	background: #D3757C;
}

.kalender .event.col-3 .date{
	background: #8FC0E0;
}


.kalender[data-when="today"] .date{
	display: none;
}

.kalender .date .month{
	display: block;
	font-size: 20px;
	font-family: 'Open Sans';
	margin-top: 20px;
	text-align: center;
	text-transform: uppercase;
}

.kalender .date .day{
	display: block;
	font-size: 36px;
	font-family: 'Renner';
	margin-top: 6px;	
	text-align: center;
}

.kalender .details{
	display: inline-block;
	vertical-align: top;
	width: calc(100% - 100px);
	padding-left: 20px;
}

.kalender[data-when="today"] .details{
	display: block;
	width: auto;
	padding-left: 0px;
}

.kalender .details .kal-entry{
	position: relative;
	cursor: pointer;
}

.kalender .time{
	display: inline-block;
	vertical-align: top;
	width: 120px;
	font-family: 'Droid Sans Mono', 'Open Sans', Helvetica, Arial;
}

.kalender .title{
	display: inline-block;
	vertical-align: top;
	width: calc(100% - 120px);
}

.kalender .extra{
	position: absolute;
	top: 100%;
	top: calc(100% + 15px);
	left: 140px;
	background: rgb(255, 255, 255) none repeat scroll 0% 0%;
	padding: 25px 30px 25px 30px;
	font-style: italic;
	z-index: 2;
	border-left: 10px solid #FFCFC4;

	transform: translateX(-50%);
	-moz-transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}

.kalender .extra:after{
	content: "";
	position: absolute;
	top: -15px;
	left: 0px;
	right: 0px;
	width: 30px;
	height: 15px;
	margin: 0 auto;
	border-style: solid;
	border-width: 0 15px 15px 15px;
	border-color: transparent transparent #ffffff transparent;
}


















.color-1{
	background: #F0A992;
}

.color-2{
	background: #D3757C;
}

.color-3{
	background: #8FC0E0;
}

.color-4{
	background: #FBE786;
}








/* Page */

#subpage{
	display: block;
	margin-bottom: 100px;
}

#subpage .intro{
	display: block;
	position: relative;
	width: 100%;
	padding-top: 56%;
}

#subpage .intro .image{
	position: absolute;
	top: 100px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	overflow: hidden;
}

#subpage .intro .image img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#subpage .intro .overlay{
	position: absolute;
	bottom: 20px;
	left: 0px;
	right: 0px;
}

#subpage .intro .title, #subpage .intro .date {
	max-width: 920px;
}

.magentaback { background-color: rgb(229,9,127); }

#subpage .intro.noimage{
	padding-top: 0px;
	margin-top: 150px;
}

#subpage .intro.noimage .overlay{
	position: relative;
	bottom: auto;
}

#subpage .intro.noimage .overlay h1,
#subpage .intro.noimage .overlay div{
	color: black;
}



#subpage .content{
	display: block;
	margin-top: 20px;
}

#subpage .content p{
	font-size: 18px;
	line-height: 1.7em;
	margin-bottom: 18px;
	width: 85%;
}

#subpage .content h2{
	margin-top: 70px;
}

body.home  .wrapper p a:not(.kb-button),
body.home  .wrapper :not(nav,div.cell) ul  a:not(.kb-button),
#subpage .content .wrapper p a:not(.kb-button),
#subpage .content .wrapper ul a:not(.kb-button) {

		outline: none;
	text-decoration: none;
    border-bottom: 1px dotted black;
	color: black;
    transition: color 0.3s ease-in-out;
    cursor: pointer;
}

ody.home .wrapper p a:not(.kb-button):hover,
body.home .wrapper :not(nav,div.cell) ul a:not(.kb-button):hover,
#subpage .content .wrapper p a:not(.kb-button):hover,
#subpage .content .wrapper ul a:not(.kb-button):hover{
    color: #e5097f;
    border-bottom: 1px dotted #e5097f;
}



#subpage .content ul.submenu a {
	outline: none;
	text-decoration: none;
	color: black;
}


#subpage .content .wp-block-image{
	display: block;
	margin-top: 20px;
	margin-bottom: 20px;
}

#subpage .content .wp-block-image img{
	width: 100%;
	height: auto;
}



#subpage .content blockquote.wp-block-quote{
	margin: 70px 0 70px 0;
	padding: 0 0 5px 15px;
	border-left: 8px solid #B1DEFF;
}

#subpage .content blockquote.wp-block-quote p{
	font-family: 'Renner';
	font-size: 28px;
	font-weight: 500;
	line-height: 1.2em;
	max-width: 1400px;
}

#subpage .content blockquote.wp-block-quote cite{
	font-style: normal;
}



#subpage .content ul:not(.submenu){
	list-style: none;
	margin: 25px 0 25px 0;
	padding: 0 0 0 25px;
}

#subpage .content ul li{
	position:relative;
	margin: 0;
	padding: 0;
	font-size: 18px;
	line-height: 1.7em;
}

/* #subpage .content ul:not(.submenu) li:before{
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 100%;
	background: black;
	position:absolute;
	top: 12px;
	left: -18px;
} */

#subpage .content ol{
	margin: 20px 0;
	padding: 0 0 0 17px;
}

figcaption {
	line-height: 1.4;
}

/* Search */

body.search #subpage{
	margin-top: 150px;
}

body.search h2{
	border-left-color: #FFA2B1;
}

body.search article{
	padding-left: 15px;
	border-left: 8px solid #FFCFC4;
	margin-bottom: 30px;
	width: 80%;
}

body.search article .title{
	display: block;
	margin-bottom: 5px;
}

body.search .margintop{
	margin-top: 70px;
}

body.search article .readmore{
	font-weight: 500;
}




.external{
	display: block;
	width: 80%;
	margin-top: 50px;
	margin-bottom: 50px;
}

.external .title{
	margin-bottom: 5px !important;
}

.external .title{
	display: block;
}

.external .url{
	font-size: 18px;
	line-height: 1.7em;
}

#subpage #weitere-beitraege{
	margin-top: 200px;
}





/* Footer */

footer{
	border-top: 1px dashed black;
}

footer .row.first{
	padding: 40px 0 70px 0;
}

footer .row.second{
	padding: 20px 0;
	border-top: 1px dashed black;
}


footer .onethird.first{
	width: 50%;
}

footer .onethird.second{
	width: 25%;
}

footer .onethird.third{
	width: 25%;	
}



footer .logo{
	display: inline-block;
	vertical-align: top;
	margin-top: -10px;
	width: 250px;
	height: auto;
}

footer img{
	width: 100%;
	height: auto;
}

footer .content{
	display: block;
	font-size: 17px;
	margin-left: 70px;
	line-height: 1.5em;
	font-weight: 300;
}

footer .content p{
	margin-bottom: 20px;
}

footer nav a{
	display: inline-block;
	vertical-align: top;
	font-size: 17px;
	margin-bottom: 15px;
}

footer h3{
	margin-bottom: 20px;
}

footer .copyright{
	display: block;
	margin-left: 70px;
	font-weight: 300;
}







.btn.more{
	position: relative;
	display: block;
	padding: 30px;
	background: #fff;
	text-transform: uppercase;
	text-align: right;
	margin-top: 50px;
	font-size: 15px;
}

.btn.more:after{
	content: "";
	position: absolute;
	top: 29px;
	left: 30px;
	width: 20px;
	height: 20px;
	margin: auto 0;
	background-image: url(img/plus-black.svg);
	background-size: 100% auto;
	background-repeat: no-repeat;
	background-position: center center;
}

.btn.more.back:after{
	background-image: url(img/arrow-left.png);
}

.indent{
	display: inline-block;
	vertical-align: top;
	min-width: 50px;
}





.wp-block-hs-space{
	border: none;
	background: none;
	height: 200px;
}

#subpage .wp-block-hs-indent span{
	font-size: 18px;
	line-height: 1.7em;
}

#subpage .wp-block-hs-indent span.title{
	font-weight: 500;
}

body.single-post {
	max-width: 1600px !important;
	margin-left: auto;
	margin-right: auto;
	overflow-x: hidden;
}

.singe-post .content {
	max-width: 1600px !important;
}

.single-post #subpage .content .wp-block-image {
	max-width: 1600px;
	margin-left: auto;
	margin-right: auto;
}


/* Mobile */

#mobile{
  position: absolute;
  top:22px;
  right:15px;
  width:30px;
  height:30px;
  cursor:pointer;
  z-index: 1000;

  -webkit-transition: all 400ms ease;
  -moz-transition: all 400ms ease;
  transition: all 400ms ease;

  display: none;
}

#mobile .line{ 
	position: absolute; 
	left:0px;
	height:2px;
	width:30px; 
	background: #fff;
	display: block; 

	transition: all 400ms ease-in-out; 
	-moz-transition: all 400ms ease-in-out; 
	-webkit-transition: all 400ms ease-in-out; 

	transform-origin: center; 
	-moz-transform-origin: center; 
	-webkit-transform-origin: center; 
}

body:not(.home) #mobile .line{
	background: black;
}


#mobile .line:nth-child(1) { top: 0px; }
#mobile .line:nth-child(2) { top: 10px; }
#mobile .line:nth-child(3) { top: 20px; }

#mobile.active .line:nth-child(1){
   transform: translateY(10px) rotate(-45deg);
}

#mobile.active .line:nth-child(2){
   opacity:0;
   width:0px;
   left:17px;
}

#mobile.active .line:nth-child(3){
   transform: translateY(-10px) rotate(45deg);
}







/* General */

.tagnr, .hidden{
	display: none !important;
}

::-webkit-input-placeholder { /* WebKit, Blink, Edge */
    color:    black;
}
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
   color:    black;
   opacity:  1;
}
::-moz-placeholder { /* Mozilla Firefox 19+ */
   color:    black;
   opacity:  1;
}
:-ms-input-placeholder { /* Internet Explorer 10-11 */
   color:    black;
}

.white{
	color: #fff;
}

.rose{
	color: #F0A992;
}


a {
	outline: none;
	text-decoration: none;
	color: inherit;
    cursor: pointer;

}

a > img{
	border: 0;
	display: block;
}

h1, h2, h3, .h1, .h2, .h3{
	font-family: 'Renner';
}

h1, h3{
	font-weight: 300;
	padding:0px;
	margin:0px;
}

.h1{
	font-size: 48px;
	line-height: 1.2em;
	padding-top: 8px;
}

.h2,
h2,
.external .title,
.map-info .title{
	font-size: 24px;
	font-weight: 500;
	line-height: 1.2em;
	margin-bottom:40px;
}

#subpage h2{
	margin-bottom: 30px;
}


h3, .h3{
	font-size: 20px;
	line-height: 1em;
	margin: 0;
	padding: 0;
}





p{
	padding:0px;
	margin:0px;
}

.p1{
	font-size: 15px;
	line-height: 1.7em;
}

body.home main p,
.p2{
	font-size: 15px;
	line-height: 1.7em;
}

body.home main p{
	margin-bottom: 25px;
}

/* Submenü */

#subpage .content ul.submenu { list-style-type: none;  padding-inline-start: 0;   }
#subpage .content ul.submenu li {  display: inline; list-style-type: none; margin: 0 4px 0 0; background: none;  padding: 0 5px 0 0;     }
#subpage .content ul.submenu a { padding: 1px 5px; background-color: #CCCCCC; color: black; margin-bottom: 5px;display: inline-block;}
#subpage .content ul.submenu a:hover { border-bottom: none; background-color: #D7D7D7; }

#subpage .content ul.deepmenu {  list-style-type: none; margin: 0 0 30px 0; padding: 0; }
#subpage .content ul.deepmenu li { display: inline; margin: 0 1px 0 0; background: none;  padding: 0;    }
#subpage .content  ul.deepmenu a { padding: 1px 5px; background-color: #CCCCCC; color: black;     }
#subpage .content ul.deepmenu a:hover { border-bottom: none; background-color: #D7D7D7; }
#subpage .content ul.deepmenu ul.children {      display: none; }



/*--------------------------------------------------------------
	5.0 Responsive 
--------------------------------------------------------------*/

/* RESPONSIVE */


@media (min-width:1580px) {


	#search{
		width: calc(100% + (100vw - 1580px) / 2);
	}
	section#intro .image{
		right: calc(((100vw - 1580px) / 2) * -1 + 20px);
	}

	section#slideshow .container{
		margin-right: calc(((100vw - 1580px) / 2) * -1);
	}

	.highlights .inner{
		margin-right: calc(((100vw - 1580px) / 2) * -1);
	}

}


@media (min-width:961px) {


	header .menu ul li.open > a{
		font-weight: 500;
	}


	.highlights .highlight.open{
		/*width: calc(100% - 100px * 6);*/
	}

	.highlights .highlight.open .title{
		left: calc(100% + 50px);
	}

	.highlights .highlight.open .bigtitle{
		opacity: 1;
	}

	.highlights.initialized .highlight.open .bigtitle{
		right: 10px !important;
	}


}

@media (max-width:961px) {

	body.home header:not(.open) #logo{
		background-image: url(img/fva-logo-invert.png);
	}

	header nav#main{
		display: none;
	}

	header{
		padding: 0;
	}

	header.open{
		position: fixed;
		height: 100vh !important;
	}

	header .menu{
		position: absolute;
		top: 80px;
		right: 0px;
		bottom: 60px;
		left: 80px;
		max-height: 100%;
		overflow-y: scroll;
		padding-bottom: 20px;
		background: none;
	}

	header.open .menu{
		display: block;
	}

	header .menu .wrapper{
		padding: 0 50px 20px 0;
		max-width: 480px;
		margin: 0;
	}

	header .menu .cell{
		display: block;
		width: auto;
	}

	header .menu .cell > a{
		display: block !important;
	}


	header > .wrapper{
		padding: 0 20px;
		height: 100%;
	}

	header #search{
		display: none;
		position: absolute;
		left: 0px;
		right: 0px;
		bottom: 0px;
		height: 60px;
		overflow: hidden;
	}

	header.open #search{
		display: block;
	}

	#search input[type="search"]{
		display: block;
		padding: 20px;
		background: black;
		color: #fff;
		max-width: 100%;
		top: auto;
		padding-left: 80px;
	}


	header ::-webkit-input-placeholder { /* WebKit, Blink, Edge */
	    color:    #fff;
	}
	header :-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	   color:    #fff;
	   opacity:  1;
	}
	header ::-moz-placeholder { /* Mozilla Firefox 19+ */
	   color:    #fff;
	   opacity:  1;
	}
	header :-ms-input-placeholder { /* Internet Explorer 10-11 */
	   color:    #fff;
	}




	#mobile{
		display: inline-block;
	}

	header.open #mobile .line{
		background: black;
	}




	section#intro{
		margin-bottom: 0px;
		height: 95vh;
		min-height: 365px;
	}

	section#intro .image {
  		position: absolute;
  		top: 0px;
		right: 0px;
		bottom: 0px;
		left: 0px;
		width: auto;
		height: 100%;
		background-position-x: 0px;
		mask: linear-gradient(transparent, black);
		--webkit-mask: linear-gradient(transparent, black,black,black);
	}

	section#intro .caption{
		width: 100%;
	}

	section#intro .caption .title{
		color: #fff;
	}

	section#intro .caption .text{
		color: #fff;
	}

	section#slideshow{
		background: none;
		height: calc(100vw * 0.8);
		min-height: 460px;
	}

	section#slideshow .container{
		margin-left: 0px;
	}

	section#slideshow .caption {
		position: relative;
		top: auto;
		right: auto;
		bottom: auto;
		left: auto;
		height: 250px;
		padding: 20px 0;
		background: #222222;
	}

	section#slideshow .caption .h1{
		font-size: 24px !important;
	}



	.highlights .highlight{
		display: block !important;
		width: auto !important;
		margin-bottom: 20px;
		height: 260px;
	}

	.highlights .wrapper{
		padding-right: 20px;
	}

	.highlights .highlight .title {
		transform: none;
		top: 160px;
		left: 10px;
		font-size: 14pt;
	}

	.highlights .highlight .bigtitle {
		width: 0px !important;
	}

	.wp-block-columns .wp-block-column {
	  display: block;
	  padding-right: 0px;
	  width: auto;
	  margin-bottom: 50px;
	}

	.wp-block-columns .wp-block-column:nth-child(1){
		display: block;
		width: auto;
	}

	.kalender .event{
		display: block;
		width: auto;
		padding-right: 0px;
	}

	.kalender .date{
		display: block;
		width: auto;
		padding-top: 20px;
	}

	.kalender .date .month{
		margin-top: 0px;
	}

	.kalender .details {
	  display: block;
	  width: auto;
	  padding-left: 0px;
	  margin-top: 20px;
	}

	.wp-block-columns .wp-block-column p {
  		max-width: 100%;
  	}

  	section.dienstleistungen .dienste{
  		margin-left: 0px;
  	}

  	section.dienstleistungen .preview{
  		display: block;
  		width: auto;
  		padding-left: 0px;
  	}


  	section.soziale-projekte .projekte{
  		margin-left: 0px;
  	}

  	section.soziale-projekte .tile{
  		display: block;
  		width: auto;
		height: 130px;
  		padding-left: 0px;
  		margin-bottom: 20px;
  	}

	section.soziale-projekte .more { top: 80px; }

  	.aktuelles .onefith{
  		width: 100vw;
  		max-width: 240px;
  		padding-top: 100%;
  	}

  	.post .image {
  		display: block;
		width: auto;
		height: auto;
		padding-top: 25%;
	}

	.post .details{
		display: block;
		width: auto;
		padding-bottom: 50px;
	}

	.post .details .overlay{
		left: 0px;
	}





  	section#spenden .inner:after{
  		top: 20px;
  		left: 20px;
  		width: 30px;
  		height: 30px;
  	}

  	section#spenden .inner .bottom{
  		padding: 20px;
  	}

  	section#spenden .inner .bottom .title{
  		font-size: 24px;
  	}

  	section#spenden .inner .bottom .text{
  		font-size: 15px;
  	}



  	#kontakt .wp-block-column{
  		display: inline-block;
  		vertical-align: top;
  		width: 33.33%;
  		margin-bottom: 0px;
  	}

  	#kontakt .wp-block-column h2{
  		font-size: 13px;
  	}



  	.post .details .overlay div,
  	.highlights .highlight .overlay.more div,
  	section.dienstleistungen .preview .inner .overlay .more,
  	section.soziale-projekte .tile .overlay.more div{
  		height: 50px;
  	}





  	.locations{
  		margin-top: 0px;
  	}

  	.location{
  		display: block;
  		width: auto;
  	}


  	.partners{
  		display: block !important;
  	}

  	.partners .wp-block-image{
  		height: 50px !important;
  		width: auto !important;
  	}


  	#subpage .intro .title{
  		font-size: 24px;
  	}

	#subpage .intro .text {
		background-color: rgba(0,0,0,60%);
	}

  	#subpage .content p{
  		font-size: 15px;
  	}

  	#subpage .wp-block-hs-indent span{
  		font-size: 15px;
  	}

  	#subpage .content ul li{
  		font-size: 15px;
  	}

  	#subpage .content ul li:before{
  		width: 6px;
  		height: 6px;
  		top: 10px;
  	}

  	#subpage .content blockquote.wp-block-quote p{
  		font-size: 32px;
  	}

  	.external .title{
  		margin-bottom: 3px !important;
  	}

  	.external .url{
  		font-size: 15px;
  	}


	section#partner .partners .wp-block-image img {
		height: 60px;
	}

  	footer .onethird{
  		display: block;
  		width: auto !important;
  	}

  	footer .onethird.second,
  	footer .onethird.third{
  		padding-left: 70px;
  	}

  	footer .onethird.first{
  		margin-bottom: 40px;
  	}
  	footer .onethird.second{
  		margin-bottom: 30px;
  	}

  	footer .content{
  	}

  	footer .content p{
  		font-size: 15px;
  	}

  	footer nav a{
  		font-size: 15px;
  	}

  	.wp-block-hs-space{
  		height: 100px;
  	}



  	.kal-wrapper{
  		display: block;
  	}


  	.btn.more{
  		margin-top: 20px;
  	}

}


@media (max-width:761px) {




}

@media (max-width:640px) {



}

@media (max-width:321px) {


}

.nf-form-fields-required { padding-bottom: 16px; } 
