html {
	scroll-behavior: smooth;
	scroll-padding-top: 180px;
}

body {
	line-height: 1.8;
	background: #fff;
	font-family: 'Open Sans', sans-serif;
	color: #333;
}

a {
	color: #463f3a;
	text-decoration: none;
}

a:hover {
	color: #555;
	text-decoration: none;
}

main#content a {
	text-decoration: underline;
}

main#content a:hover {
	text-decoration: none;
}

.footer a:hover {
	color: #ccc;
	text-decoration: none;
}

.footer a {
	color: #fff;
}

footer .logos-footer {}

footer .logos-footer img {
	width: 200px;
	height: auto;
}

/* .lightbox img, .ce-media img {
    border: 1px solid #618237;
} */

.container-fluid {
	padding: 0;
}

.container {
	clear: both;
}

#background-video video#headervideo {
	max-width: 1400px;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/*************************** ÜBERSCHRIFTEN *************************
************************************************************************/
h1,
.h1,
h2,
.h2,
h3,
.h3 {
	clear: both;
	font-family: 'Kalam';
	font-weight: 400;
	text-align: left;
}

h1,
.h1 {
	color: #618237;
	font-size: 32px;
	padding: 5px 0;
	font-weight: 600;
}

h2,
.h2 {
	color: #333;
	font-size: 28px;
	padding: 5px 0;

}

h3,
.h3 {
	font-size: 24px;
	margin-bottom: 1px;
}

/***************************** TOP-BEREICH ***************************
************************************************************************/
.top-wrapper {
	height: auto;
	background-color: #fff;
	/* background-image: url("../Images/Template/bg02.png"), url("../Images/Template/bg02.png"), url("../Images/Template/bg01.png"); */
	background-position: left top, left top, left top;
	background-repeat: no-repeat, no-repeat, repeat;
	background-size: 100% 130px, 100% 130px, auto auto;
	clear: both;
	padding: 20px 0 20px 0;
}

.navigation-wrapper {
	height: 75px;
	z-index: 99;
	border-bottom: 8px solid #463f3a;
	clear: both;
	background-color: #618237;
	transition: all 0.5s ease-in-out;
}

#seitenheader.fixed nav {
	top: 0;
	width: 100%;
	z-index: 9;
	position: fixed;
}

.top-wrapper div.container {
	padding: 0;
}

.scroll {
	position: fixed;
	top: 0;
	width: 100%;
	clear: both;
}

.scroll-2,
.scroll-3 {
	margin-top: 70px;
	clear: both;
}

.kontakt-top {
	padding: 0;
	display: flex;
	justify-content: right;
	align-items: center;
}

.kontakt-top .row {
	width: 100%;
}

.email {
	text-align: right;
}

.telefon {
	text-align: right;
}

header#seitenheader .top-wrapper .logo span {
	color: #a98467;
	;
	font-family: 'Satisfy';
	font-size: 40px;
}

.illustration {
	position: absolute;
	background: #fff;
	border-radius: 50%;
	padding: 10px;
	top: 0;
	z-index: 99;
}

#seitenheader .top-wrapper .illustration img {
	width: 285px;
	height: auto;
	transition: all 0.5s ease-in-out;
}

#seitenheader.fixed .logo .illustration img {
	width: 95px;
	height: auto;
	position: fixed;
	background: #fff;
	border-radius: 50%;
	padding: 2px;
	top: 10px;
	z-index: 99;
}

/*************************** KOPFBILD/SLIDER *************************
************************************************************************/
.kopfslider,
.kopfbild {
	padding: 0;
	position: relative;
	clear: both;
	border-bottom: 8px solid #463f3a;
}

.kopfslider,
.kopfbild {
	max-height: 800px;
	margin-bottom: 40px;
	overflow: hidden;
	width: 100%;
}

.kopfbild>img {
	padding-bottom: 0;
}

.kopfslider img,
.kopfbild img {
	width: 100%;
	height: auto;
}

.carousel-inner {
	max-height: 800px;
}

.carousel-indicators {
	display: none;
}

.carousel-control.left {
	background-image: none;
}

.carousel-control.right {
	background-image: none;
}

.carousel-control-next i,
.carousel-control-prev i {
	font-size: 48px;
}

#carousel-slider .carousel-control-left,
#carousel-slider .carousel-control-right {
	background: url(/typo3conf/ext/template_ferienhof_assfalg/Resources/Public/Images/Template/trans-40-schwarz.png);
	bottom: 50px;
	width: 50px;
	height: 50px;
	line-height: 1;
	position: absolute;
	z-index: 99;
}

#carousel-slider .carousel-control-left {
	left: 100px;
}

#carousel-slider .carousel-control-right {
	right: 100px;
}

#carousel-slider .carousel-control-left i,
#carousel-slider .carousel-control-right i {
	color: #fff;
	font-size: 48px;
}

/*----- Patch für Firefox v.58 --------*/
.carousel-item {
	transition: -webkit-transform 0.5s ease;
	transition: transform 0.5s ease;
	transition: transform 0.5s ease, -webkit-transform 0.5s ease;
	-webkit-backface-visibility: visible;
	backface-visibility: visible;
}

/****************************** CONTENT ******************************
************************************************************************/
body {}

main {}

/******************************* FOOTER ******************************
************************************************************************/
footer {
	color: #000;
	margin-top: 20px;
}

footer .container.footer .container .frame-standard {
	margin-top: 0;
}

.footer-wrapper {
	background-color: #f2e8cf;
	padding: 35px 0 30px 0;
	color: #000;
	border-top: 8px solid #463f3a;
	clear: both;
	z-index: 99;
}

.container.footer {
	color: #000;
	font-size: 15px;
	line-height: 1.4;
	padding-top: 30px;
	padding-bottom: 30px;
}

.footer header h3 {
	font-size: 20px;
	color: #000;
}

.footer a {
	color: #000;
	font-weight: bold;
}

.footer a:hover {
	color: #618237 !important;
	text-decoration: underline;
}

#c6,
#c6 h3 {
	text-align: right;
}

/**************************** BOOTSTRAP-ICONS *************************
************************************************************************/
i.bi {
	background-color: #618237;
	border-radius: 100%;
	box-shadow: 0 0 0 7px white, 0 0 0 8px #e0e0e0;
	color: #fff;
	cursor: default;
	display: inline-block;
	height: 2em;
	line-height: 2em;
	margin: 0 11px 0 0;
	padding: 0;
	text-align: center;
	width: 2em;
}

/********************************** TYPO3 *****************************
************************************************************************/
.lightbox>img {
	height: auto;
	width: 100%;
}

.ce-gallery {
	margin-top: 0 !important;
}

.ce-gallery img {
	display: block;
	height: auto;
	width: 100%;
	margin-bottom: 10px;
	margin-top: 8px;
}

.ce-gallery-bootstrap img {
	width: 100%;
	height: auto;
	margin-bottom: 20px;
}

.ce-intext.ce-right .ce-gallery {
	margin-left: 10px;
}

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

figcaption {
	font-size: 12px;
	height: 30px;
	margin-top: 0;
	text-align: center;
}

a.mail img {
	margin-top: -6px;
}

hr {
	background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(148, 0, 49, 0.75), rgba(0, 0, 0, 0));
	border: 0 none;
	height: 2px;
	width: 100%;
}

.bildspalte {
	margin-bottom: 30px;
}

.bildspalte p {
	margin-bottom: 25px;
}

.frame-space-before-extra-small {
	margin-top: 0;
}

.frame-space-after-extra-small {
	margin-bottom: 0;
}

.frame-space-before-small {
	margin-top: 15px;
}

.frame-space-after-small {
	margin-bottom: 15px;
}

.frame-space-before-medium {
	margin-top: 30px;
}

.frame-space-after-medium {
	margin-bottom: 30px;
}

p {
	margin-bottom: 15px;
}

.privacy-msg.privacy-calendar-msg p a.btn,
.privacy-msg.privacy-map-msg p a.btn,
.privacy-msg.privacy-video-msg p a.btn {
	background: #618237;
	border-color: #618237;
	color: #fff;
	margin-top: 15px;
	margin-bottom: 15px;
}

.privacy-msg.privacy-calendar-msg p a.btn:hover,
.privacy-msg.privacy-map-msg p a.btn:hover,
.privacy-msg.privacy-video-msg p a.btn:hover {
	background: #eee;
	border-color: #eee;
	color: #333;
	margin-top: 15px;
	margin-bottom: 15px;
}

.privacy-msg.privacy-calendar-msg p,
.privacy-msg.privacy-map-msg p,
.privacy-msg.privacy-video-msg p {
	padding: 15px;
	background: #eee;
	text-align: center;
}

.modal-dialog-scrollable {
	height: 90vh;
}

.modal-dialog {
	max-width: 1140px;
}

button.btn.btn-primary {
	background: #618237;
	border-color: #618237;
}

button.btn.btn-primary:hover {
	background: #333;
	border-color: #333;
}

.frame-beige-box {
	background: #FFF1DD;
	padding: 15px 15px 0px 15px;
}

.sl-overlay {
	background: #000;
}

.ce-intext.ce-left .ce-gallery {
	margin-right: 20px;
}

.frame-graue-box {
	background: #eee;
	padding: 5px 15px;
}

/******************************** MASK *******************************
************************************************************************/
.mask-bildergalerie div.mask-bildergalerie-wrapper {
	margin-bottom: 15px;
	-webkit-box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.5);
	-moz-box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.5);
	box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.5);
}

.mask-bildergalerie div.bildspalte img {
	width: 100%;
	height: auto;
}

/********************* LINK-BOX *********************************/
.mask-linkbox-wrap {
	background-color: #eee;
	/* background-image: linear-gradient(90deg, rgba(0, 0, 0, .05) 50%, transparent 50%),
		linear-gradient(rgba(0, 0, 0, .05) 50%, transparent 50%);
	background-size: 40px 40px; */
	border-radius: 10px;
	border: 1px solid #ccc;
	min-height: 300px;
	padding: 0 15px 15px 15px;
}

.mask-linkbox-wrap .mask-linkbox-ueberschrift {
	text-align: center;
	font-size: 24px;
	font-weight: 600;
}

.mask-linkbox-wrap .mask-linkbox-inhalt {
	text-align: center;
}

.mask-linkbox-wrap .mask-linkbox-link {
	font-weight: 600;
	text-align: center;
}

.mask-linkbox-wrap .mask-linkbox-link i {
	font-size: 28px;
	margin-left: 10px;
}

.mask-linkbox-wrap .mask-linkbox-bild img {
	width: 100%;
	height: auto;
}

/*************************** TYPO3-FORM ****************************
************************************************************************/
#anfrageformularWohnung-10 legend,
#anfrageformularWohnung-42 legend,
#anfrageformularWohnung-46 legend,
#anfrageformularWohnung-50 legend,
#kontaktformular-10 legend {
	display: none;
}

#anfrageformularWohnung-10 .form-group,
#anfrageformularWohnung-42 .form-group,
#anfrageformularWohnung-46 .form-group,
#anfrageformularWohnung-50 .form-group,
form#kontaktformular-10 .form-group {
	margin-bottom: 20px;
}

#anfrageformularWohnung-10 .submit button.btn,
#anfrageformularWohnung-42 .submit button.btn,
#anfrageformularWohnung-46 .submit button.btn,
#anfrageformularWohnung-50 .submit button.btn,
#kontaktformular-10 .submit button.btn {
	background: #618237;
	border-color: #618237;
	color: #fff;
}

#anfrageformularWohnung-10 .submit button.btn:hover,
#anfrageformularWohnung-42 .submit button.btn:hover,
#anfrageformularWohnung-46 .submit button.btn:hover,
#anfrageformularWohnung-50 .submit button.btn:hover,
#kontaktformular-10 .submit button.btn:hover {
	background: #333;
	border-color: #333;
}

#anfrageformularWohnung-10 .input.checkbox .form-check,
#anfrageformularWohnung-42 .input.checkbox .form-check,
#anfrageformularWohnung-46 .input.checkbox .form-check,
#anfrageformularWohnung-50 .input.checkbox .form-check,
#kontaktformular-10 .input.checkbox .form-check {
	padding-left: 0;
}

#anfrageformularWohnung-10 input#kontaktformular-10-checkbox-1,
#anfrageformularWohnung-42 input#kontaktformular-10-checkbox-1,
#anfrageformularWohnung-46 input#kontaktformular-10-checkbox-1,
#anfrageformularWohnung-50 input#kontaktformular-10-checkbox-1,
#kontaktformular-10 input#kontaktformular-10-checkbox-1 {
	margin-right: 5px;
}

#anfrageformularWohnung-10 textarea#kontaktformular-10-textarea-1,
#anfrageformularWohnung-42 textarea#kontaktformular-10-textarea-1,
#anfrageformularWohnung-46 textarea#kontaktformular-10-textarea-1,
#anfrageformularWohnung-50 textarea#kontaktformular-10-textarea-1,
#kontaktformular-10 textarea#kontaktformular-10-textarea-1 {
	min-height: 150px;
}

form#kontaktformular-10 #c7 {
	margin-top: 15px;
}

.anfrage-button {}

.anfrage-button a button {
	background: #618237;
	border-radius: 5px;
	border: none;
	color: #fff;
	padding: 10px 25px;
}

.anfrage-button a:hover button {
	background: #333;
}

/*------------------------------------*\
  #OPENSTREETMAP
\*------------------------------------*/
iframe.openstreetmap {
	width: 100%;
}

.map {
	width: 100%;
	overflow: hidden;
	position: relative;
}

.map .privacy-msg.privacy-map-msg {
	background-image: url(/typo3conf/ext/template_ferienhof_assfalg/Resources/Public/Images/Template/Mapdummy.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	width: 100% !important;
}

.map .privacy-msg.privacy-map-msg::after {
	content: "© OpenStreetMap contributors";
	position: absolute;
	left: 15px;
	bottom: 0;
}

.map .privacy-msg.privacy-map-msg p {
	background-image: url(/typo3conf/ext/template_ferienhof_assfalg/Resources/Public/Images/Template/trans-80-schwarz.png);
	width: 1110px;
	position: absolute;
	left: 50%;
	margin-top: 50px;
	margin-left: -555px;
	color: #fff;
	text-align: center;
}

.map iframe {
	width: 100%;
	margin-bottom: -6px;
}

.privacy-msg.privacy-script-msg a,
.privacy-msg.privacy-map-msg a {
	color: #618237;
}

.privacy-msg a.btn {
	background: #007078;
	border-color: #007078;
	color: #333;
	margin-top: 20px;
	margin-bottom: 20px;
}

.privacy-script-msg p {
	background-image: url(/typo3conf/ext/template_ferienhof_assfalg/Resources/Public/Images/Template/trans-80-schwarz.png);
	position: relative;
	margin-top: 50px;
	color: #fff;
	padding: 10px 20px;
	text-align: center;
}

.privacy-msg.privacy-video-msg {
	background-image: url(/typo3conf/ext/template_ferienhof_assfalg/Resources/Public/Images/Template/Video-Dummy.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	width: 100% !important;
}

.privacy-msg.privacy-video-msg p {
	background-image: url(/typo3conf/ext/template_ferienhof_assfalg/Resources/Public/Images/Template/trans-80-schwarz.png);
	width: 900px;
	position: absolute;
	left: 50%;
	margin-top: 50px;
	margin-left: -450px;
	color: #fff;
	padding: 10px 20px;
	text-align: center;
}

/*------------------------------------*\
  #TABELLEN
\*------------------------------------*/
table.contenttable {
	width: 100%;
	margin-bottom: 30px;
}

table.contenttable tr:last-child {
	border-bottom: none;
}

table.contenttable tr td {
	padding: 5px;
}

/*------------------------------------*\
  #BACK-TO-TOP
\*------------------------------------*/
.back-to-top {
	background: #618237;
	border-radius: 5px;
	border: 1px solid #fff;
	position: fixed;
	bottom: 20px;
	right: 20px;
	line-height: 1;
	padding: 10px;
	z-index: 100;
}

.back-to-top i {
	color: #fff;
	font-size: 36px;
}

/*-------------------- MEDIA-QUERIES ----------------------
---------------------------------------------------------------*/
@media (min-width: 1599px) {
	.carousel-caption {
		bottom: auto;
		top: 20px;
	}
}

@media (max-width: 1399px) {
	.illustration {
		top: 20px;
	}

	header#seitenheader .top-wrapper .illustration img {
		width: 125px;
		height: auto;
	}
}

@media (max-width: 1199px) {
	header#seitenheader .top-wrapper .logo span {
		font-size: 32px;
	}

	/* header#seitenheader .top-wrapper .illustration img {
        width: 65px;
        height: auto;
    } */

	.kontakt-top {
		justify-content: normal;
	}

	.mask-linkbox-wrap {
		min-height: 250px;
	}

	.modal-dialog {
		max-width: 960px;
	}
}

@media (max-width: 991px) {
	html {
		scroll-behavior: unset;
		scroll-padding-top: unset;
	}

	.illustration {
		position: relative;
		top: 0;
	}

	header#seitenheader .top-wrapper .illustration img {
		width: 175px;
		height: auto;
		margin-right: 0;
		margin-bottom: 20px;
	}

	.top-wrapper {
		height: auto;
	}

	.top-wrapper div.container {
		width: 100%;
	}

	.navigation-wrapper {
		display: none;
	}

	.container {
		min-width: 100%;
	}

	section#content section.container {
		padding-left: 30px;
		padding-right: 30px;
	}

	.row {
		margin: 0;
	}

	.mask-bildergalerie .row,
	.frame-type-gridelements_pi1 .row,
	.mask-bild-box-wrap .row,
	.frame-type-b13-2-spalten-66-33 .row {
		margin-left: -15px;
		margin-right: -15px;
	}

	footer .frame-type-gridelements_pi1 .row {
		margin: 0;
	}

	.content {
		padding: 0;
	}

	.logo {
		text-align: center;
	}

	.logo img {
		height: auto;
		padding-top: 0;
	}

	.kontakt-top {
		justify-content: center;
	}

	.footer .ce-column div.ce-media img {
		width: 140px;
	}

	.email,
	.telefon {
		text-align: center;
	}

	.icon.major {
		margin: 20px 15px 20px 0;
	}

	.scroll {
		position: relative;
		top: 0;
		width: 100%;
		clear: both;
	}

	.scroll-2,
	.scroll-3 {
		margin-top: 0;
		clear: both;
	}

	.kontakt-top {
		margin: 0 0 25px 0;
		padding: 0;
		text-align: center;
	}

	.gridelement-4-spalten div.col-md-3.col-sm-6.col-xs-12,
	.gridelement-2-spalten-50-50 div.col-sm-6.col-xs-12 {
		margin-bottom: 30px;
	}

	.logo {
		position: relative;
		z-index: 1;
	}

	.calender-scrollbar {
		width: 100%;
		padding: 0px;
		margin-bottom: 0px;
		overflow-y: hidden;
		border: 1px solid #DDD;
		overflow-x: auto;
		min-height: 0.01%;
	}

	.modal-dialog {
		margin-top: 90px;
	}

	#c64 {
		margin-top: 20px;
	}

	#c64 header h3 {
		text-align: left;
	}

	#c11 {
		float: left;
	}

	#c4 {
		margin-top: 20px;
	}

	#c4,
	#c4 h3 {
		text-align: center;
	}
}

@media (max-width: 767px) {
	.ce-intext.ce-left .ce-gallery {
		margin-right: 0;
		margin-top: 0;
		width: 100%;
	}

	.ce-gallery img {
		margin-bottom: 10px;
	}

	.ce-intext.ce-right .ce-gallery {
		margin-left: 0;
	}

	.ce-media {
		margin: 0;
	}

	.ce-row {
		margin-bottom: 0;
	}

	.top-wrapper {
		height: 270px;
	}

	.container.footer {
		font-size: 15px;
		padding: 15px;
	}

	.ce-right .ce-gallery {
		float: none;
		width: 100%;
	}

	.ce-column {
		width: 100%;
	}

	.email {
		text-align: center;
	}

	.powermail_input.form-control,
	.powermail_country.form-control,
	.powermail_date.form-control,
	.powermail_select.form-control,
	.powermail_textarea,
	.powermail_submit.btn.btn-primary {
		float: left;
		width: 100%;
	}

	.top-wrapper {
		background-image: none;
		height: auto;
	}

	.telefon {
		text-align: center;
	}

	.fa {
		margin: 30px 11px 0 0;
	}

	/* .row.mask-bildergalerie {
        margin: 0;
    } */

	#c4,
	#c4 h3 {
		text-align: left;
	}

	.footer-wrapper .gridelement-3-spalten-33-33-33-linke-spalte,
	.footer-wrapper .gridelement-3-spalten-33-33-33-mittlere-spalte,
	.footer-wrapper .gridelement-3-spalten-33-33-33-rechte-spalte {
		width: 100%;
		max-width: 100%;
		flex: 0 0 100%;
		padding: 0;
	}

	.mask-linkbox-wrap {
		min-height: auto;
		margin-bottom: 30px;
	}

	.calendarize .calendarize-item .calendarize-icon {
		padding: 10px 0;
	}

	.calendarize .calendarize-item i {
		padding: 15px 0;
	}

	footer .logos-footer {
		margin-top: 20px;
	}

	#c4 {
		margin-top: 25px;
	}

	#c4,
	#c4 h3 {
		text-align: left;
	}
}

@media (max-width: 480px) {

	.kopfslider,
	.kopfbild {
		display: none;
	}

	.ce-textpic {
		margin: 0;
	}

	.logo {
		padding: 20px 0 0 0;
	}

	.logo img {
		width: 90%;
	}

	.container.content {
		margin: 0;
		padding: 0;
	}

	.icon.major {
		margin: 10px 15px 20px 0;
	}

	.footer-logos .logo-3 {
		margin-top: 0;
	}

	.footer-logos img {
		width: 100%;
		height: auto;
	}
}