.ikiss_norel, .ikiss_norel :not(.btn, .btn *) {
	color: #c20000 !important;
}
.inputs .row{
	margin-bottom: 2px;
}
.inputs input:not(.btn), .inputs select, .inputs textarea {
	width: 100%;
	padding: 8px 5px;
	border: 1px solid #949494; /* Mindestkontrast 3:1 */
	margin-bottom: 8px;
	background-color: #fff; /* kein grauer Select-Hintergrund in Firefox */
	border-radius: 0px; /* keine abgerundeten Felder auf iOS */
}
.inputs input:not(.btn):focus, .inputs select:focus, .inputs textarea:focus {
	border: 1px solid #484848; /* Mindestkontrast 3:1 gegen #949494 */
}
.inputs input:not(.btn).tab-focus, .inputs select.tab-focus, .inputs textarea.tab-focus {
	border-radius: 0.125rem; /* noetig aufgrund obigem Radius fuer iOS */
}
.inputs input, .inputs select, .inputs .btn > a {
	height: 2.5em;
	display: inline-block;
}
.inputs select[multiple="multiple"], .inputs input[type="file"] {
	height: auto;
}
.inputs input[type="checkbox"] {
	width: auto;
	height: auto;
	margin: 5px 5px 5px 0;
}
.inputs input[type="radio"] {
	width: auto;
	height: auto;
	margin: 5px 5px 5px 0;
}
.inputs input[type="date"] {
	-webkit-appearance: textfield;
	-moz-appearance: textfield;
}
@supports (-webkit-touch-callout: none) { /* iOS */
	.inputs input[type="date"] {
		-webkit-min-logical-width: calc(100% - 18px); /* Breite des Feldes */
		-webkit-max-logical-height: calc(2.5em - 2px); /* Hoehe des Feldes */
	}
	.inputs input[type="date"]::-webkit-date-and-time-value { /* Ausrichtung des Wertes */
		padding: 0.5em 0;
		text-align: left;
	}
}
.inputs textarea {
	resize: vertical;
	min-height: 2.5em;
}
.inputs label {
	display: inline-block;
	margin-bottom: 3px;
}
.inputs .flex-row,
.flex-row.inputs {
	--flex-gap-row: 1em; /* Abstand nach oben/unten */
	--flex-gap-col: 1em; /* Abstand nach links/rechts */
}
@media screen and (max-width: 680px) {
	#NFm .inputs .flex-col-3 + .flex-col-2x3 { /* Abstand zwischen Label und Feld in Neudialogen */
		margin-top: -0.5em;
	}
}
#SFm .inputs [class*="flex-col-"]:has(.btn) { /* Ausrichtung des Buttons auf Hoehe des Suchfeldes */
	align-self: flex-end;
}
@-moz-document url-prefix() { /* Firefox kennt kein :has() */
	#SFm .inputs [class*="flex-col-"]:last-child { /* das letzte Element einer Suchmaske beinhaltet den Button */
		align-self: flex-end;
	}
}
#SFm .inputs [class*="flex-col-"] label {
	margin-bottom: 0.25em;
}
.inputs [class*="flex-col-"] input:not(.btn),
.inputs [class*="flex-col-"] select,
.inputs [class*="flex-col-"] textarea {
	margin-bottom: 0;
	padding: 0.5em;
}
.inputs .btn-row {
	margin: -0.5em;
	width: 100%;
}
.inputs .btn-row .btn {
	margin: 0.5em;
}
.volltextsuche .inputs input[type="radio"] {
	margin: 0.25em;
}
#SFm + p, .volltextsuche + p, .solr-results > p:first-child {
	margin-top: 1em;
	display: block;
}
.more {
	font-weight: bold;
}
.altering-list li {
	padding: 10px;
	display: inline-block;
	width: 100%;
	background-color: #eee;
}
.altering-list li:nth-child(even) {
	background-color: #f9f9f9;
}
.altering-list .date, .altering-list .file {
	font-size: 0.7em;
}

/* Bildeinbindungen ohne Template */
img.mt_left {
	float: left;
	margin-right: 15px;
	margin-bottom: 15px;
}
img.mt_left.mt_autowidth {
	width: calc(50% - 15px) !important;
}
img.mt_right {
	float: right;
	margin-left: 15px;
	margin-bottom: 15px;
}
img.mt_right.mt_autowidth {
	width: calc(50% - 15px) !important;
}
img.mt_middle {
	display: block !important;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 15px !important;
}
img.mt_middle.mt_autowidth {
	width: 66.666% !important;
}
img.mt_none {
	margin-bottom: 15px;
	vertical-align: bottom;
}
.mt_ac {
	position: relative;
	max-width: 100%;
}
.mt_ac img[class*="mt_"] {
	float: none;
	margin: 0 !important;
	vertical-align: bottom;
	width: 100% !important;
}
.mt_ac.mt_left { 
	float: left;
	margin-right: 15px;
	margin-bottom: 15px;
}
.mt_ac.mt_left.mt_autowidth {
	width: calc(50% - 15px) !important;
}
.mt_ac.mt_right {
	float: right;
	margin-left: 15px;
	margin-bottom: 15px;
}
.mt_ac.mt_right.mt_autowidth {
	width: calc(50% - 15px) !important;
}
.mt_ac.mt_middle {
	display: block !important;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 15px !important;
}
.mt_ac.mt_middle.mt_autowidth {
	width: 66.666% !important;
}
.mt_ac.mt_noalign {
	margin-bottom: 15px;
}
.mt_ac .mc2_ac {
	background-color: #eee;
	background-color: rgba(255,255,255,0.75);
	color: #444;
	display: inline-block;
	position: absolute;
	right: 0;
	bottom: 0;
	padding: 0.25em 0.375em;
	font-size: 0.75rem;
	line-height: normal;
	max-width: calc(100% - 30px);
	max-height: 100%;
}
@media screen and (max-width: 960px) {
	img.mt_left, img.mt_right, .mt_ac.mt_left, .mt_ac.mt_right {
		max-width: calc(66.666% - 15px);
	}
	.mt_ac img[class*="mt_"] {
		max-width: none;
	}
}
@media screen and (max-width: 680px) {
	img.mt_left, img.mt_right, .mt_ac.mt_left, .mt_ac.mt_right {
		max-width: calc(50% - 15px);
	}
	.mt_ac img[class*="mt_"] {
		max-width: none;
	}
	.mt_ac .mc2_ac {
		font-size: 0.5rem;
	}
}

/* Suchergebnis/Listengenerator */
.result-list:not(.flex-row) {
	margin-bottom: 15px;
}
.result-list.flex-row {
	margin-bottom: calc(-15px + 15px);
	margin-bottom: calc(-1 * var(--flex-gap-row, 30px) / 2 + 15px);
}
.result-list:not(.flex-row) > li {
	margin-bottom: 15px;
}
.result-list > li:not(:last-child), .result-list > dd:not(:last-child), .result-list > div > dd:not(:last-child),
.result-list.flex-row > li, .result-list.flex-row > dd, .result-list.flex-row > div > dd {
	padding-bottom: 15px;
	border-bottom: 1px solid #eee;
}
.result-list.flex-row > li.flex-col-1:last-child,
.result-list.flex-row > li.flex-col-2:nth-last-child(-n+2),
.result-list.flex-row > li.flex-col-3:nth-last-child(-n+3),
.result-list.flex-row > li.flex-col-4:nth-last-child(-n+4),
.result-list.flex-row > li.flex-col-5:nth-last-child(-n+5),
.result-list.flex-row > li.flex-col-6:nth-last-child(-n+6) {
	padding-bottom: 0;
	border-bottom: none;
}
.widget .result-list > li:not(:last-child), .widget .result-list > dd:not(:last-child), .widget .result-list > div > dd:not(:last-child) {
	border-bottom-color: #e0e0e0;
}
.result-list > li.with-background {
	background-color: #eee;
	padding: 0;
	border: none;
}
li.with-background .order-0 .list-text {
	padding: 15px 0 15px 15px;
}
li.with-background .order-1 .list-text {
	padding: 15px 15px 15px 0;
}
li.with-background .flex-col-1.order-0 .list-text {
	padding: 15px 15px 0 15px;
}
li.with-background .flex-col-1.order-1 .list-text {
	padding: 0 15px 15px 15px;
}
.result-list .row { /* wird ab 7.3p5 schrittweise auf .flex-row umgestellt */
	margin-left: -7.5px;
	margin-right: -7.5px;
}
.result-list [class^="column-"] { /* wird ab 7.3p5 schrittweise auf .flex-col-* umgestellt */
	padding-left: 7.5px;
	padding-right: 7.5px;
}
.result-list .flex-row { /* Abstaende nur fuer .flex-row innerhab von .result-list - gilt nicht fuer .result-list.flex-row */
	--flex-gap-row: 15px;
	--flex-gap-col: 15px;
}
.result-list .order-0 {
	order: 0;
}
.result-list .order-1 {
	order: 1;
}
.result-list > li > a, .result-list .overlay > a {
	color: #404040;
	display: block;
	overflow: hidden;
}
.result-list.flex-row > li > a,
.result-list.flex-row .overlay > a { /* Hoehe von nebeneinanderstehenden Links angleichen */
	height: 100%;
}
.result-list .list-img, .accordion .list-img {
	position: relative;
	overflow: hidden;
}
.list-img img {
	width: 100%;
	vertical-align: bottom;
}
.list-img [class^="img-"] {
	background: center center/cover no-repeat;
	position: relative;
	width: 100%;
}
.list-img [class^="img-"].contain {
	background-color: #eee;
	background-size: contain;
}
.list-img [class^="img-"].stretch {
	background-size: 100% 100%;
}
.list-img .img-1x1 {
	padding-top: 100%;
}
.list-img .img-3x2 {
	padding-top: 66.666%;
}
.list-img .img-4x3 {
	padding-top: 75%;
}
.list-img .img-16x9 {
	padding-top: 56.25%;
}
.list-img .mc2_ac {
	background-color: #eee;
	background-color: rgba(255,255,255,0.75);
	color: #444;
	display: inline-block;
	position: absolute;
	right: 0;
	bottom: 0;
	padding: 0.25em 0.375em;
	font-size: 0.75rem;
	line-height: normal;
	max-width: calc(100% - 30px);
	max-height: 100%;
}
.list-img.ikiss_norel {
	background-color: #c20000;
}
.list-img.ikiss_norel img, .list-img.ikiss_norel [class^="img-"] {
	-webkit-opacity: 0.666;
	-moz-opacity: 0.666;
	-ms-opacity: 0.666;
	opacity: 0.666;
}
.column-1 + .column-1 .list-text { /* schrittweise nicht mehr verwendet ab 7.3p5 */
	padding-top: 15px; /* zusaetzlicher Abstand bei Bild und Text untereinander */
}
.list-text small { /* schrittweise nicht mehr verwendet ab 7.3p3 */
	font-size: 0.75rem;
}
.list-text small + small { /* schrittweise nicht mehr verwendet ab 7.3p3 */
	margin-left: 10px;
}
.list-text small > [class*="fa-"],
.list-text small > a > [class*="fa-"] { /* schrittweise nicht mehr verwendet ab 7.3p3 */
	font-size: 1rem;
	line-height: 1;
	margin-right: 0.25em;
	-webkit-opacity: 0.7;
	-moz-opacity: 0.7;
	-ms-opacity: 0.7;
	opacity: 0.7;
	vertical-align: unset;
}
.list-text p, .list-text ol, .list-text ul {
	margin-bottom: 0.5rem;
}
.list-text > :last-child, .list-text blockquote > :last-child {
	margin-bottom: 0;
}
.page-topic, 
.result-list .list-topic { /* neu ab 7.3p3 */
	display: block;
	font-size: 0.8125rem;
}
.result-list .list-title { /* angepasst in 7.3p3 */
	display: block;
	margin: 0 0 0.5rem;
	font-size: 1.3125rem;
	font-weight: 700;
}
.widget .result-list .list-title {
	border: 0;
	padding: 0;
	margin: 0 0 0.5rem;
	font-size: 1rem;
	font-weight: 700;
}
.page-icons,
.result-list .list-icons { /* neu ab 7.3p3 */
	display: block;
	color:#606060;
	font-size: 0.8125rem;
	font-weight: normal;
	line-height: 1.5;
	padding-left: 1px; /* sonst wird das Icon wegen overflow: hidden in einigen Ansichten angeschnitten */
}
.page-title + .page-icons {
	margin-top: -1rem;
	margin-bottom: 1.5rem;
}
.page-icons > span, .page-icons > time,
.list-icons > span, .list-icons > time {
	display: inline-block;
}
.page-icons > span:not(:last-child), .page-icons > time:not(:last-child),
.list-icons > span:not(:last-child), .list-icons > time:not(:last-child) {
	margin-right: 0.5em;
}
.page-icons [class*="fa-"],
.list-icons [class*="fa-"] {
	margin-right: 0.25em;
	font-size: 1rem;
	vertical-align: -5%;
}
.result-list .overlay {
	position: relative;
}
.overlay a.overlay-link {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	right: 0;
}
.overlay .overlay-content {
	position: relative;
	pointer-events: none;
	z-index: 40;
}
.overlay-content a, .overlay-content [ikissedit] {
	pointer-events: all;
	position: relative;
}

/* Paginierung */
.ikiss_pagenav ul, ul.ikiss_pagenav {
	padding-left: 0;
	margin: 0.75rem -0.25rem; /* Angaben in rem wegen font-size:0 bei vor/zurueck */
}
.ikiss_pagenav li {
	display: inline-block;
}
.ikiss_pagenav a, .ikiss_pagenav span {
	width: 2rem;
	height: 2rem;
	line-height: 1.666;
	text-align: center;
	vertical-align: middle;
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
	border: 1px solid #ddd;
	display: inline-block;
	color: #666;
	font-weight: 400;
	font-size: 18px;
	margin: 0.25rem;
}
.ikiss_pagenav .pn_active {
	background-color: #ddd;
	color: #616161; /* Mindestkontrast 4,5:1*/
	font-weight: 600;
}
.ikiss_pagenav .pn_step_l, .ikiss_pagenav .pn_page_l, .ikiss_pagenav .pn_step_r, .ikiss_pagenav .pn_page_r {
	font-size: 0;
}
.ikiss_pagenav .pn_step_l::before, .ikiss_pagenav .pn_page_l::before, .ikiss_pagenav .pn_step_r::before, .ikiss_pagenav .pn_page_r::before {
	font-family: "Font Awesome 6 Pro";
	font-weight: 900;
	font-size: 12px;
	line-height: 2.5em;
	width: 2rem;
	display: inline-block;
}
.ikiss_pagenav .pn_step_l::before {
	content: '\f323';
}
.ikiss_pagenav .pn_page_l::before {
	content: '\f053';
}
.ikiss_pagenav .pn_step_r::before {
	content: '\f324';
}
.ikiss_pagenav .pn_page_r::before {
	content: '\f054';
}

/* Medien */
audio, video {
	display: block;
	width: 100%;
}
.medien audio, .medien video {
	margin-bottom: 0.75em;
}
.pdf-preview {
	background: center center/contain no-repeat;
	background-color: #eee;
	padding-top: 66.666%;
}

/* Dienstleistungen */
.location-form {
	background-color: #eee;
	padding: 1em;
	margin: 1em 0;
}
.location-form > :first-child {
	margin-top: 0;
}
.location-form > :last-child:not(.flex-row) {
	margin-bottom: 0;
}
.location-form.flex > * {
	margin: 0;
}
.location-form.flex > :last-child {
	flex-grow: 1;
}

/* Veranstaltungen */
.veranstaltungen .column-2x3 .adressen {
	margin-bottom: 0.75em;
}

/* Cookie-Hinweis und Tracking-Hinweis */
body {
	--cookie-note-height: 0px;
}
a, button, input, select, textarea, [id], [tabindex] {
	scroll-margin-bottom: calc(var(--cookie-note-height) + 15px); /* damit per Tastatur angesteuerte Links bei automatischem Scrollen nicht vom Cookie-Hinweis verdeckt werden */
}
.cookie-note, .tracking-note {
	width: 100%;
	background-color: #eee;
	padding: 1.5em;
	-webkit-box-shadow: 0 5px 15px #000;
	-moz-box-shadow: 0 5px 15px #000;
	box-shadow: 0 5px 15px #000;
	-webkit-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	-moz-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	box-shadow: 0 5px 15px rgba(0,0,0,0.25);
}
.cookie-note {
	-ms-hyphens: auto;
	-webkit-hyphens: auto;
	hyphens: auto;
	z-index: 90;
}
#cookie-note {
	display: none;
}
.cookie-note .btn-row {
	margin: -0.375em;
}
.cookie-note .btn-row .btn {
	margin: 0.375em;
}
.tracking-note .btn {
	margin: 0;
}
.cookie-note.bottom-left {
	position: fixed;
	bottom: 0;
	left: 0;
	max-width: 31.25em;
	margin: 0 0 30px 30px;
}
.cookie-note.bottom-right {
	position: fixed;
	bottom: 0;
	right: 0;
	max-width: 31.25em;
	margin: 0 30px 30px 0;
}
.cookie-note.bottom {
	position: fixed;
	bottom: 0;
}
@media screen and (max-width: 960px) {
	.cookie-note.bottom-left, .cookie-note.bottom-right, .cookie-note.bottom {
		font-size: 0.9em;
	}
}
@media screen and (max-width: 680px) {
	.cookie-note.bottom-left, .cookie-note.bottom-right, .cookie-note.bottom {
		font-size: 0.8em;
		bottom: 0;
		left: 0;
		right: 0;
		max-width: none;
		margin: 0;
		padding: 15px;
		-webkit-box-shadow: 0 0 15px #000;
		-moz-box-shadow: 0 0 15px #000;
		box-shadow: 0 0 15px #000;
		-webkit-box-shadow: 0 0 15px rgba(0,0,0,0.25);
		-moz-box-shadow: 0 0 15px rgba(0,0,0,0.25);
		box-shadow: 0 0 15px rgba(0,0,0,0.25); 
	}
}

/* Zusatzmodul: Formulareditor */
fieldset.ikiss-form-fieldset,
legend.ikiss-form-legend,
.ikiss-form-element label,
.ikiss-form-element input,
.ikiss-form-element select,
.ikiss-form-element textarea {
	margin: 0;
	padding: 0;
	font-size: 100%;
	text-align: left;
	vertical-align: baseline;
	width: auto;
	float: none;
}
.ikiss-mailform-infolabel {
	font-size: 0.75em;
}
fieldset.ikiss-form-fieldset p::after,
fieldset.ikiss-form-fieldset div::after,
div.ikiss-form-fieldgroup p::after {
	content: '';
	display: block;
	clear: both;
	visibility: hidden;
	line-height: 0;
	height: 0;
}
span.ikiss-form-element {
	display: inline-table;
	width: 60%;
	float: none;
}
span.ikiss-form-element input,
span.ikiss-form-element select,
span.ikiss-form-element textarea,
span.ikiss-form-element label {
	display: inline-block;
	margin-bottom: 3px;
}
span.ikiss-field-radio label {
	display: inline;
}
span.ikiss-field-checkbox label {
	display: inline;
}
fieldset.ikiss-form-fieldset {
	border: 1px solid #ccc;
	padding: 1em;
	margin: 1em 0 0.75em 0;
}
legend.ikiss-form-legend {
	font-weight: bold;
	font-size: 1.3125rem;
	padding: 0 0.25em;
}
span.ikiss-field-label {
	width: 30%;
	float: left;
	margin-right: 6%;
}
span.ikiss-field-textfield input {
	width: 100%;
	padding: 1%;
}
span.ikiss-field-textarea textarea {
	width: 100%;
	padding: 1%;
	resize: vertical;
	min-height: 30px;
}
span.ikiss-field-select select {
	width: 100%;
}
span.ikiss-field-checkbox input {
	margin-right: 2%;
}
span.ikiss-field-checkbox label {
	padding-right: 3%;
}
span.ikiss-field-radio input {
	margin-right: 2%;
}
span.ikiss-field-radio label {
	padding-right: 3%;
}
span.ikiss-field-file input {
	width: 100%;
}
span.ikiss-field-button input, span.ikiss-field-button {
	float: left;
	width: auto;
}
.ikiss-mailform-infolabel {}
.ikiss-mailform-req-marker-text {
	padding: 0.75em 0;
}
.ikiss-form-fieldset input,
.ikiss-form-fieldset select,
.ikiss-form-fieldset textarea,
.ikiss-form-element input,
.ikiss-form-element select,
.ikiss-form-element textarea {
	width: 100%;
	padding: 8px 5px;
	border: 1px solid #949494; /* Mindestkontrast 3:1 */
	margin-bottom: 8px;
	background-color: #fff; /* kein grauer Select-Hintergrund in Firefox */
	border-radius: 0px; /* keine abgerundeten Felder auf iOS */
}
.ikiss-form-fieldset input:focus,
.ikiss-form-fieldset select:focus,
.ikiss-form-fieldset textarea:focus,
.ikiss-form-element input:focus,
.ikiss-form-element select:focus,
.ikiss-form-element textarea:focus {
	border: 1px solid #484848; /* Mindestkontrast 3:1 gegen #949494*/
}
.ikiss-form-fieldset input.tab-focus,
.ikiss-form-fieldset select.tab-focus,
.ikiss-form-fieldset textarea.tab-focus,
.ikiss-form-element input.tab-focus,
.ikiss-form-element select.tab-focus,
.ikiss-form-element textarea.tab-focus {
	border-radius: 0.125rem; /* noetig aufgrund obigem Radius fuer iOS */
}
.ikiss-form-fieldset input,
.ikiss-form-fieldset select,
.ikiss-form-fieldset .btn > a,
.ikiss-form-element input,
.ikiss-form-element select,
.ikiss-form-element .btn > a {
	height: 2.5em;
	display: inline-block;
}
.ikiss-form-fieldset select[multiple="multiple"],
.ikiss-form-fieldset input[type="file"],
.ikiss-form-element select[multiple="multiple"],
.ikiss-form-element input[type="file"] {
	height: auto;
}
.ikiss-form-fieldset input[type="checkbox"],
.ikiss-form-element input[type="checkbox"] {
	width: auto;
	height: auto;
	margin: 5px 5px 5px 0;
}
.ikiss-form-fieldset input[type="radio"],
.ikiss-form-element input[type="radio"] {
	width: auto;
	height: auto;
	margin: 5px 5px 5px 0;
}
.ikiss-form-fieldset select[multiple],
.ikiss-form-element select[multiple] {
	height: auto;
}
.ikiss-form-fieldset input[type="reset"],
.ikiss-form-element input[type="reset"] {
	color: #555 !important;
	background-color: #eaeaea !important;
}
@media screen and (max-width: 680px) {
	.ikiss-form-element {
		width: 100% !important;
	}
}

/* Zusatzmodul: Newsletter */
.newsletter-error {
	color:#b00000;
	font-weight: bold;
}
.newsletter-categories {
	padding: 0 0 11px 0;
}
.newsletter-categories label {
	display: block;
}

/* Zusatzmodul: Tag Clouds */
.tc-item {
	margin: 2px;
	display: inline-block;
}

/* Zusatzmodul: Tourismus */
.page-icons .dehoga-letter,
.list-icons .dehoga-letter {
	margin-right: 0.25em;
}
.dehoga-stars [class*="fa-"]:last-child {
	margin-right: 0;
}
.dehoga-stars.yellow [class*="fa-"] {
	color: #f1c40f;
}
.dehoga-stars.green [class*="fa-"] {
	color: #1fa67a;
}
.dtv-options [class*="opt-"]::before {
	display: inline-block;
	content: '\f00c';
	width: 1.25em;
	font-family: "Font Awesome 5 Pro";
	font-size: 1.25rem;
	font-weight: 400;
	text-align: center;
	vertical-align: -5%;
	margin-right: 0.25em;
}
.dtv-options .opt-1::before {
	content: '\f206';
}
.dtv-options .opt-3::before {
	content: '\f000';
}
.dtv-options .opt-4::before {
	content: '\f561';
}
/*.dtv-options .opt-5::before {
	content: '\e00d';
}*/
.dtv-options .opt-7::before {
	content: '\f26c';
}
.dtv-options .opt-8::before {
	content: '\f578';
}
.dtv-options .opt-9::before {
	content: '\f5e2';
}
.dtv-options .opt-10::before {
	content: '\f7f6';
}
.dtv-options .opt-11::before {
	content: '\f400';
}
.dtv-options .opt-13::before {
	content: '\f5c5';
}
.dtv-options .opt-14::before {
	content: '\f6d3';
}
.dtv-options .opt-16::before {
	content: '\f8da';
}
.dtv-options .opt-17::before {
	content: '\f522';
}
.dtv-options .opt-18::before {
	content: '\f1ae';
}
.dtv-options .opt-19::before {
	content: '\f8f4';
}
.dtv-options .opt-20::before {
	content: '\f2cd';
}
.dtv-options .opt-22::before {
	content: '\f0dc';
}
.dtv-options .opt-24::before {
	content: '\f724';
}
.dtv-options .opt-25::before {
	content: '\f540';
}
.dtv-options .opt-26::before {
	content: '\f8d7';
}
.dtv-options .opt-27::before {
	content: '\f073';
}
.dtv-options .opt-28::before {
	content: '\f2e7';
}
.dtv-options .opt-29::before {
	content: '\f193';
}
.dtv-options .opt-32::before {
	content: '\f8e0';
}
/*.dtv-options .opt-33::before {
	content: '\f8eb';
}*/
.dtv-options .opt-34::before {
	content: '\f70c';
}
.dtv-options .opt-35::before {
	content: '\f5ca';
}
.dtv-options .opt-36::before {
	content: '\f680';
}
.dtv-options .opt-37::before {
	content: '\f095';
}
.dtv-options .opt-38::before {
	content: '\f787';
}
.dtv-options .opt-39::before {
	content: '\f630';
}
.dtv-options .opt-40::before {
	content: '\f898';
}
.dtv-options .opt-41::before {
	content: '\f861';
}
.dtv-options .opt-42::before {
	content: '\f64f';
}
.dtv-options .opt-44::before {
	content: '\f236';
}
.dtv-options .opt-45::before {
	content: '\f77d';
}
.dtv-options .opt-46::before {
	content: '\f437';
}
.dtv-options .opt-47::before {
	content: '\f8c3';
}
.dtv-options .opt-48::before {
	content: '\f45e';
}
.dtv-options .opt-49::before {
	content: '\f2cc';
}
.dtv-options .opt-50::before {
	content: '\f5bb';
}
.dtv-options .opt-51::before {
	content: '\f562';
}
.dtv-options .opt-52::before {
	content: '\f59d';
}
.dtv-options .opt-54::before {
	content: '\f1ac';
}
.dtv-options .opt-55::before {
	content: '\f8ec';
}
.dtv-options .opt-56::before {
	content: '\f72f';
}
.dtv-options .opt-57::before {
	content: '\f4d3';
}
.dtv-options .opt-58::before {
	content: '\f09d';
}
.dtv-options .opt-59::before {
	content: '\f44b';
}
.dtv-options .opt-60::before {
	content: '\f0fc';
}
.dtv-options .opt-61::before {
	content: '\e01b';
}
.dtv-options .opt-62::before {
	content: '\f1eb';
}
.dtv-options .opt-63::before {
	content: '\f34e';
}
.dtv-options .opt-64::before {
	content: '\fe6c';
}
.dtv-options .opt-65::before {
	content: '\f7c9';
}

/* Zusatzmodul: Veranstaltungs- und Terminbuchung */
.booking-vacant,
.booking-short,
.booking-reserved,
.booking-expired {
	display: inline-block;
	padding: 5px 15px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
}
.booking-vacant, .booking-vacant a {
	background-color: #b2f2bb;
	color: #444;
}
.booking-short, .booking-short a {
	background-color: #ffec99;
	color: #444;
}
.booking-expired, .booking-reserved {
	background-color: #f8f9fa;
	color: #555;
}
.booking-time, .booking-info {
	margin: 0;
}
.booking-time [class*="fa-"] {
	margin-right: 0.25em;
}
.booking-info {
	font-size: 0.8125rem
}
.booking-list .list-title {
	margin: 0 0 0.25em;
}
.booking-list ul {
	list-style: none;
	padding-left: 0;
	margin-bottom: 0;
}
.booking-list li {
	margin-bottom: 0;
}
.booking-list a, div.booking-reserved, div.booking-expired {
	margin: 5px 0 5px;
	width: 100%;
}
.booking-form table {
	border-collapse: collapse;
	width: 100%;
}
.booking-form tr:nth-child(even) {
	background-color: #eee;
}
.booking-form th, .booking-form td {
	padding: 5px 15px;
}
.booking-form th {
	vertical-align: bottom;
	font-weight: bold;
	text-align: left;
}
.booking-form td {
	vertical-align: middle;
}
.booking-form table input, .booking-form table select {
	margin-bottom: 0;
}
.booking-form .ikiss-mailform-req-marker {
	color: #b00000;
	cursor: help;
	padding: 0 3px;
	position: absolute;
}
.booking-form input[type="checkbox"] + label {
	display: inline;
}
@media screen and (max-width: 680px) {
	.booking-form th, .booking-form td {
		padding: 5px 5px;
		font-size: 0.875em;
	}
	.booking-form .booking-vacant,
	.booking-form .booking-short,
	.booking-form .booking-reserved {
		padding: 5px 7.5px;
	}
}

/* Zusatzmodul: Volltextsuchmaschine SOLR */
.solr-results em {
	background-color: #ff0;
	font-style: italic;
	padding: 0 0.25em 0 0.125em;
}
.solr-results a {
	text-decoration: none;
}

/* Zusatzfunktion: Aufklapp-Effekt */
.accordion {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	clear: both;
}
.accordion-title {
	display: block;
	font-size: 1.3125rem;
	font-weight: 300;
	text-align: left;
	color: #202020;
	background-color: #eee;
	margin: 0 0 10px;
	cursor: pointer;
}
.accordion-title.smaller-title {
	font-size: 1.125rem;
}
.accordion-title.bigger-title {
	font-size: 1.5rem;
}
.accordion-title button {
	position: relative;
	width: 100%;
	font-size: inherit;
	font-weight: inherit;
	text-align: left;
	color: inherit;
	background: transparent;
	padding: 5px 10px;
	margin: 0;
	cursor: inherit;
	-webkit-user-select: none !important;
	-moz-user-select: none !important;
	-ms-user-select: none !important;
	user-select: none !important;
}
.accordion-title button::after {
	content: '';
	clear: both;
	display: block;
	visibility: hidden;
	height: 0px;
}
.accordion-title span {
	display: inline-block;
	text-align: left;
	line-height: 1.33;
	color: inherit;
	margin-right: 20px;
}
.accordion-title,
.accordion-title span {
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	hyphens: auto;
}
.accordion-title [class*="fa-"] {
	position: absolute;
	top: 50%;
	right: 10px;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	font-size: 1.25rem;
	color: inherit;
	margin-right: 0 !important;
	-webkit-transition: all .2s ease-in;
	-moz-transition: all .2s ease-in;
	transition: all .2s ease-in;
}
.accordion-title [class*="fa-"].flip-x {
	-moz-transform: rotateX(180deg);
	-o-transform: rotateX(180deg);
	-webkit-transform: rotateX(180deg);
	transform: rotateX(180deg);
	transform-origin: 25% 25%;
}
.accordion-container {
	padding: 10px;
	margin-bottom: 10px;
	overflow: hidden;
}
.accordion-title.as-link {
	font-size: 1rem;
	font-weight: normal;
	color: #006080;
	background: none;
	margin: 0 0 0.75em;
}
.accordion-title.as-link button {
	width: unset;
	color: inherit;
	background: transparent;
	padding: 0 0.5em 0 0;
}
.accordion-title.as-link span {
	color: inherit;
	margin-right: calc(20px + 0.25em);
}
.accordion-title.as-link [class*="fa-"] {
	font-size: 1rem;
	font-weight: 400;
	color: inherit;
}
.accordion-container.with-background {
	background-color: #eee;
	padding: 1em; 
	margin-bottom: 1em;
}
.rs_active .accordion-container {
	display: block !important;
}
.rs_active .accordion-title {
	cursor: auto;
}
.rs_active .accordion-title [class*="fa-"] {
	display: none;
}

/* Zusatzfunktion: Bildergalerie (PhotoSwipe) inkl. Bildeinbindung */
.flex-row.image-gallery {
	--flex-gap-row: 10px; /* Abstand nach oben/unten */
	--flex-gap-col: 10px; /* Abstand nach links/rechts */
}
.image-single {
	max-width: 100%;
	margin-bottom: 15px;
}
.image-single.pull-left {
	float: left;
	margin-right: 15px;
}
.image-single.pull-right {
	float: right;
	margin-left: 15px;
}
.image-single.pull-center {
	margin: 0 auto 15px;
}
.image-single.auto-width {
	width: 100%;
}
.image-single.pull-left.auto-width, .image-single.pull-right.auto-width {
	width: calc(50% - 15px);
}
.image-single.pull-center.auto-width {
	width: 66.666%;
}
.image-gallery li a, .image-single a {
	display: block;
	position: relative;
}
.image-gallery img, .image-single img {
	display: block;
	width: 100%;
	transition: all 0.2s ease-out;
}
.image-gallery a:hover img, .image-single a:hover img,
.image-gallery a:focus img, .image-single a:focus img {
	-webkit-box-shadow: 0 5px 15px #000;
	-moz-box-shadow: 0 5px 15px #000;
	box-shadow: 0 5px 15px #000;
	-webkit-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	-moz-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	box-shadow: 0 5px 15px rgba(0,0,0,0.25);
}
.image-single .img-caption {
	color: #666;
	font-size: 0.875em;
	font-style: italic;
	padding-top: 0.25em;
	text-align: left;
}
.wrap-img {
	position: relative;
	display: block; /* noetig, da fuer Bildeinbindung innerhalb eines Absatzes ein span-Element verwendet wird */
}
.wrap-img.ikiss_norel, .image-single.ikiss_norel .wrap-img {
	background-color: #c20000;
}
.wrap-img.ikiss_norel > img,
.wrap-img.ikiss_norel > .bg-img,
.image-single.ikiss_norel .wrap-img > img {
	-webkit-opacity: 0.666;
	-moz-opacity: 0.666;
	-ms-opacity: 0.666;
	opacity: 0.666;
}
.wrap-img > .img-copyright {
	background-color: #eee;
	background-color: rgba(255,255,255,0.75);
	color: #444;
	display: inline-block;
	position: absolute;
	right: 0;
	bottom: 0;
	padding: 0.25em 0.375em;
	font-size: 0.75rem;
	line-height: normal;
	max-width: calc(100% - 30px);
	max-height: 100%;
}
@media screen and (max-width: 960px) {
	.image-single.pull-left, .image-single.pull-right {
		max-width: calc(66.666% - 15px);
	}
}
@media screen and (max-width: 680px) {
	.image-single.pull-left, .image-single.pull-right {
		max-width: calc(50% - 15px);
	}
	.wrap-img > .img-copyright {
		font-size: 0.5rem;
	}
}

/* Zusatzfunktion: Dynamisches Organigramm */
.org-chart {
	font-size: 1rem;
	overflow-wrap: break-word; /* Chrome */
	word-wrap: break-word; /* Chrome */
	margin: 0 -0.5em;
}
.org-chart .flex-row {
	--flex-gap-row: 0em; /* Abstand nach oben/unten */
	--flex-gap-col: 0em; /* Abstand nach links/rechts */
}
@media only screen and (min-width: 961px) {
	.org-chart-level-1 .org-chart-main {
		order: 1;
	}
	.org-chart-level-1 .org-chart-left {
		order: 0;
	}
	.org-chart-level-1 .org-chart-right {
		order: 2;
	}
}
@media only screen and (max-width: 960px) {
	.org-chart-level-1 .flex-col-md-2 {
		margin-top: -1em;
	}
}
.org-chart-item {
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	flex-direction: column;
	align-content: center;
	justify-content: center;
	text-align: center;
	padding: 1em;
	margin: 1em 0.5em;
	-webkit-border-radius: 0.5em;
	border-radius: 0.5em;
	-webkit-transition: box-shadow 0.25s;
	transition: box-shadow 0.25s;
}
.org-chart-item:hover,
.org-chart-item:focus,
.tab-focus > .org-chart-item {
	-webkit-box-shadow: 0 5px 15px #000;
	box-shadow: 0 5px 15px #000;
	-webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.25);
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.25);
}
.org-chart-item p {
	padding: 0;
	margin: 0;
}

/* Zusatzfunktion: Mediathek */
audio, video {
	display: block;
	width: 100%;
}
.responsive-video, .flowplayer {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 0;
	height: 0;
	overflow: hidden;
	background-color: #000;
}
.responsive-video iframe, .flowplayer iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.mediathek .result-list .list-img {
	overflow: visible;
}
.mediathek .list-img video { 
	aspect-ratio: 16/9; /* alle Videos in 16:9 anzeigen, um die Hoehe von Hochkantvideos zu begrenzen */
	max-height: 80vh; /* zusaetzliche Begrenzung noetig fuer Landscape-Modus */
}

/* Zusatzfunktion: Neu/Gelesen */
.unread {
	text-transform: uppercase;
	font-weight: bold;
}
.unread [class*="fa-"]::before {
	font-weight: 700;
}

/* Zusatzfunktion: Textabschnitte in mehreren Spalten */

/* Zusatzfunktion: Textabschnitt mit speziellem Hintergrund */
.colored-container {
	position: relative;
	width: 100%;
	margin: 30px 0;
	padding: 30px;
}
.colored-container.full-width {
	width: calc(100vw - var(--scrollbar-width));
	margin: 30px 0 30px calc(50% - 50vw + calc(var(--scrollbar-width) / 2));
	padding: 30px 0;
}
.colored-container.full-width + .colored-container.full-width,
.colored-container:not(.full-width) + .colored-container:not(.full-width) { /* zwei aufeinanderfolgende Einbindungen sollen keinen Abstand halten */
	margin-top: -30px;
}
[class*="column-"]:not(.column-1) .colored-container.full-width, /* Fallbacks fuer unzulaessige Einbindungen mit voller Breite innerhalb beliebiger Spalten */
[class*="flex-col-"]:not(.flex-col-1) .colored-container.full-width,
.colored-container .colored-container.full-width, /* oder mehrfach ineinander */
.modal-window .colored-container.full-width, /* oder im modalen Fenster */
.mceContentBody .colored-container.full-width { /* auch fuer den Texteditor im Backend noetig */
	width: 100%;
	margin: 30px 0;
	padding: 30px;
}
[class*="column-"]:not(.column-1) .colored-container.full-width .wrapper, /* Fallbacks fuer den Wrapper innerhalb unzulaessiger Einbindungen mit voller Breite */
[class*="flex-col-"]:not(.flex-col-1) .colored-container.full-width .wrapper,
.colored-container .colored-container.full-width .wrapper, /* oder mehrfach ineinander */
.modal-window .colored-container.full-width .wrapper, /* oder im modalen Fenster */
.mceContentBody .colored-container.full-width .wrapper { /* auch fuer den Texteditor im Backend noetig */
	max-width: unset;
	width: unset;
	margin: unset;
	padding: unset;
	-moz-transition: unset;
	-webkit-transition: unset;
	transition: unset;
}
.colored-container_image-wrapper {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
}
.colored-container_image-wrapper.ikiss_norel {
	background-color: #c20000;
}
.colored-container_image-wrapper.ikiss_norel > img {
	opacity: 0.666;
}
.colored-container_image-copyright {
	background-color: #eee;
	background-color: rgba(255,255,255,0.75);
	color: #444;
	display: inline-block;
	position: absolute;
	right: 0;
	bottom: 0;
	padding: 0.25em 0.375em;
	font-size: 0.75rem;
	line-height: normal;
	max-width: calc(100% - 30px);
	max-height: 100%;
}
@media screen and (max-width: 680px) {
	.colored-container_image-copyright {
		font-size: 0.5rem;
	}
}
.colored-container_image {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}
.colored-container_image.fixed {
	background-attachment: fixed;
}
@supports (-webkit-touch-callout: none) { /* fixed wird auf iOS-Geraeten nicht unterstuetzt */
	.colored-container_image.fixed {
		background-attachment: scroll;
	}
}
.colored-container_image.bottom {
	background-position: bottom;
}
.colored-container_image.top {
	background-position: top;
}
.colored-container_text-wrapper {
	position: relative;
	z-index: 2;
}
.colored-container_text-container {
	position: relative;
}
@media screen and (min-width: 961px){
	.colored-container_text-container.width-33 {
		max-width: 33.333%;
	}
	.colored-container_text-container.width-50 {
		max-width: 50%;
	}
	.colored-container_text-container.width-66 {
		max-width: 66.666%;
	}
	.colored-container_text-container.left {
		margin: 0 auto 0 0 ;
	}
	.colored-container_text-container.right {
		margin: 0 0 0 auto;
	}
	.colored-container_text-container.center {
		margin: 0 auto;
	}
}
.colored-container_text-background {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
}
.colored-container_text-background + .colored-container_text {
	padding: 15px; /* zusaetzlicher Abstand nur, wenn Text mit zusaetzlichem Hintergrund erscheint */
}
.colored-container_text.text-color :not(.img-copyright):not(.mc2_ac):not(p.btn > a):not(.accordion-title):not(.cards):not(.big-date *) { /* weitere Ausnahmen, die die Schriftfarbe nicht uebernehmen sollen, muessen hier ebenfalls mit :not ergaenzt werden */
	color: inherit;
	border-color: inherit; /* erstmal ganz allgemein, siehe unten */
}
.colored-container_text.text-color * { /* die Vererbung der border-color ermoeglicht, dass Trennlinien in Suchergebnis-Listen passend gefaerbt werden. Die Farbe wird im Template auf die Textfarbe gesetzt, jedoch zu 75% durchsichtig. Wenn noetig koennen noch Ausnahmen wie oben definiert werden. Da aber nur die Farbe gesetzt wird und nicht das border-Attribut, war das bisher nicht noetig */
	border-color: inherit;
}
.colored-container_text :first-child:not(.flex-row):not([class*="flex-col-"]) {
	margin-top: 0;
}
.colored-container_text :last-child:not(.cards):not(.text-columns):not(.flex-row):not([class*="flex-col-"]) {
	margin-bottom: 0;
}
.opacity-100 {
	opacity: 1;
}
.opacity-75 {
	opacity: 0.75;
}
.opacity-50 {
	opacity: 0.5;
}
.opacity-25 {
	opacity: 0.25;
}
[style*="display:inline"]:first-child .colored-container:first-child { /* nur wenn kein Titel und keine Einleitung vorangestellt ist */
	margin-top: 0;
}
.colored-container:last-child {
	margin-bottom: 0;
}

/* Zusatzfunktion: Top-Meldungen */
.result-list > li.top-news {
	background-color: #eee;
	padding: 1em;
	border-bottom-color: #fff;
	margin-bottom: 0;
}
.result-list > li.top-news:last-of-type {
	border-bottom-color: #f00;
}
.result-list > li.top-news ~ li:not(.top-news) {
	padding-left: 1em;
	padding-right: 1em;
}
.result-list > li.top-news + li:not(.top-news) {
	margin-top: 15px;
}
span.top-news {
	font-weight: bold;
}
span.top-news > [class*="fa-"] {
	font-weight: 700;
}

/* Zusatzfunktion: Veranstaltungsliste mit grossem Datum */
.big-date {
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	list-style: none;
	padding-left: 0;
}
.big-date li {
	margin-bottom: 15px;
	position: relative;
	background-color: #eee;
}
.big-date li:last-child {
	margin-bottom: 0;
}
.big-date a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-ms-flex-direction: row;
	flex-direction: row;
	text-decoration: none;
}
.big-date a:hover,
.big-date a:focus {
	-webkit-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	-moz-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	background-color: rgba(0,0,0,0.1);
}
.big-date .list-date {
	color: #fff;
	padding: 1rem;
	min-width: calc(2.04rem + 3.75ch); /* 2.04rem ergibt sich aus padding und letter-spacing; 3.75ch = 2 x 1,875 x die Breite der Ziffer "0" - stellvertretend fuer 2 beliebige Ziffern in einer Groesse von 1.875rem; */
	white-space: nowrap; /* verhindert Umbruch der Zahlen aufgrund von hoeherem letter-spacing je nach Schriftart */
}
.big-date .list-date .day {
	display: block;
	font-size: 1.875rem;
}
.big-date .list-date .month {
	display: block;
	font-size: 1rem;
}
.big-date .list-text {
	padding: 1rem;
	color: #404040;
	width: 100%;
}
.big-date .list-title {
	display: block;
	margin: 0 0 0.5rem;
	font-size: 1.3125rem;
	font-weight: 700;
}
.big-date .list-icons {
	display: block;
	color: #505050;
	font-size: 0.8125rem;
	font-weight: normal;
	line-height: 1.5;
}
.big-date .list-text p {
	margin-bottom: 0.5rem;
}
.big-date .list-text > :last-child,
.big-date .list-text > :last-child > :last-child,
.big-date .list-text > :last-child > :last-child > :last-child {
	margin-bottom: 0;
}

/* Zusatzfunktion: Wichtige Mitteilung in einem modalen Fenster */
.modal-window {
	width: 100%;
	height: 100%;
	position: fixed;
	left: 0;
	top: 0;
	background: rgba(0, 0, 0, .75);
	z-index: 85;
	display: none;
	justify-content: center;
	align-items: center;
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	hyphens: auto;
}
.modal-window-overlay {
	background-color: #fff;
	overflow-y: auto;
	height: 100%;
	opacity: 0;
	animation-name: modal-window-open;
	animation-duration: 1s;
	animation-delay: 1s;
	animation-fill-mode: forwards;
}
@keyframes modal-window-open {
	0% {
		opacity: 0
	}
	100% {
		opacity: 1
	}
}
@media screen and (min-width: 681px) {
	.modal-window-overlay {
		max-width: 960px;
		height: calc(100% - 30px);
		width: calc(100% - 30px);
	}
}
@media screen and (min-width: 681px) and (min-height: 431px) {
	.modal-window-overlay {
		height: auto;
		max-height: 400px;
	}
}
@media screen and (min-width: 681px) and (min-height: 631px) {
	.modal-window-overlay {
		max-height: 600px;
	}
}
@media screen and (min-width: 681px) and (min-height: 831px) {
	.modal-window-overlay {
		max-height: 800px;
	}
}
.modal-window-content {
	padding: 30px;
}
.modal-window-content div[style="display:inline"]:last-of-type > :last-child { /* Designtemplate-Felder */
	margin-bottom: 0;
}
.frontend .modal-window-hide-btn {
	vertical-align: bottom;
	margin-top: 30px;
}
.frontend .modal-window-hide-x {
	cursor: pointer;
	background-color: transparent;
	float: right;
	color: #404040;
	margin: -20px -20px 30px 30px;
	line-height: 1;
}
.modal-window-hide-x [class*="fa-"] {
	margin-right: 0;
}
.modal-window-hide-x .fa-fw {
	height:1.25em;
}

/* Zusatzfunktion: Zwei-Klick-Loesung fuer Iframes */
.is-ios * {
	cursor: pointer;
}
.iframe-autowidth {
	position: relative;
	height: 0;
}
.iframe-autowidth .iframe-preview, .iframe-autowidth .iframe-frame {
	position: absolute !important;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}
.iframe-preview {
	position: relative;
	background: center center/cover no-repeat;
}
.iframe-wrap, .iframe-preview, .iframe-frame {
	max-width: 100%;
}
.iframe-wrap[data-iframe-autowidth="1"] > .iframe-preview {
	max-width: none;
}
.iframe-preview .mc2_ac {
	position: absolute;
	right: 0;
	bottom: 0;
	padding: 2px 5px;
	background-color: #eee;
	background-color: rgba(255,255,255,0.75);
	max-width: 66.666%;
	text-align: left;
}
.iframe-message {
	display: none;
	position: absolute;
	width: 100%;
	width: calc(100% - 50px);
	max-width: 500px;
	padding: 25px;
	margin: 25px;
	background-color: #eee;
	-webkit-box-shadow: 0 5px 15px #000;
	-moz-box-shadow: 0 5px 15px #000;
	box-shadow: 0 5px 15px #000;
	-webkit-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	-moz-box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	box-shadow: 0 5px 15px rgba(0,0,0,0.25);
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.iframe-message.top-left {
	top: 25px;
	left: 25px;
	margin: 0;
	max-width: 500px;
}
.iframe-message.top-right {
	top: 25px;
	right: 25px;
	margin: 0;
	max-width: 500px;
}
.iframe-message.top {
	top: 25px;
	left: 25px;
	right: 25px;
	margin: 0;
	max-width:none;
}
.iframe-message.dark {
	background-color: #333;
	background-color: rgba(0,0,0,0.75);
	color: #fff;
}
.iframe-message a {
	font-weight: bold;
}
.iframe-message.dark a {
	color: #fff;
}
.iframe-message .btn {
	margin: 0;
}
@media screen and (max-width: 960px) {
	.iframe-message {
		max-width: 500px;
		width: calc(100% - 30px);
		padding: 15px;
		margin: 15px;
		font-size: 0.75em;
	}
	.iframe-message.top-left {
		top: 15px;
		left: 15px;
	}
	.iframe-message.top-right {
		top: 15px;
		right: 15px;
	}
	.iframe-message.top {
		top: 15px;
		left: 15px;
		right: 15px;
	}
}

/* Zusatzmodul: Bewertung und Kommentare (DEV) */
.buk-uebersicht li {
	display: inline-block;
	margin-right: 10px;
	padding: 10px;
	min-width: 75px;
	text-align: center;
}
.buk-uebersicht {
	margin: 0;
}
#bewertung a span {
	margin-left: 5px;
}
.thumbup::before,
.thumbdown::before,
.kommentar::before {
	font-family: "Font Awesome 5 Pro";
}
.kommentar::before {
	font-family: "Font Awesome 5 Pro";
}
.kommentar::before {
	content: '\f075';
}
.thumbup::before {
	content: '\f164';
}
.thumbdown::before {
	content: '\f165';
}
.quote::before {
	font-family: "Font Awesome 5 Pro";
}
.statsbox {
	padding: 10px;
	margin-right: 15px;
	margin-bottom: 15px;
	background-color: #eee;
	float:left;
	display: block;
}
.statsbox.comments-view {
	width: 100%;
}
.statsbox.comments-view h3 {
	margin-top: 10px;
}

/* Zusatzmodul: Karten (DEV) */
.gmc_page {
	position: relative;
	width: 100%;
	height: 550px;
	margin: 0;
	padding: 0;
}
.gmc_header {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 48;
	width: auto;
}
.gmc_control {
	float: none;
	position: absolute;
	top: 0;
	bottom: 0;
	width: 33.333%;
	min-width: 200px;
	height: 100%;
	background: #fff;
	background: rgba(255,255,255,0.75);
	padding: 10px;
	margin: 0;
	z-index: 46;
}
.gmc_control .inputs.row .column-1 {
	position: relative;
}
.gmc_control .gmc_input {
	margin-bottom: 0;
}
.gmc_control button.submit {
	font-size: 16px;
	cursor: pointer;
	position: absolute;
	right: 10px;
	top: 0;
	bottom: 0;
	color: #202020;
	background-color: transparent;
	line-height: 0.8;
	border: none;
	padding: 0 15px;
}
.gmc_control ul.fancytree-container {
	font-family: "Source Sans Pro", "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-size: 1em;
	background-color: transparent;
	border-bottom: 1px solid #ccc;
	padding: 0;
}
.gmc_control ul.fancytree-container {}
.gmc_control span.fancytree-node {
	display: block;
	position: relative;
	padding: 4px 5px;
}
.gmc_control span.fancytree-node:hover,
.gmc_control span.fancytree-node:focus,
.gmc_control span.fancytree-node.fancytree-expanded {
	color: #fff;
	background-color: #202020;
}
.gmc_control span.fancytree-checkbox {
	display: none;
}
.gmc_control span.fancytree-icon {
	display: none;
}
.gmc_control .fancytree-selected span.fancytree-icon {
	display: inline-block;
	background: none;
}
.gmc_control .fancytree-selected span.fancytree-icon::before {
	content: '\f00c';
	font-family: 'Font Awesome 5 Pro';
	font-size: 14px;
}
.gmc_control span.fancytree-custom-icon {
	width: 25px;
	height: 18px;
	font-size: 18px;
	margin: 0;
	vertical-align: middle;
}
.gmc_control .fancytree-selected span.fancytree-custom-icon::before {
	content:'\f00c';
}
.gmc_control span.fancytree-node:hover.fancytree-selected span.fancytree-custom-icon::before,
.gmc_control span.fancytree-node:focus.fancytree-selected span.fancytree-custom-icon::before {
	color: #fff;
}
.gmc_control span.fancytree-expander {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	width: 30px;
	height: 100%;
	text-align: center;
	background: none;
	margin: 0;
	z-index: 40;
}
.gmc_control span.fancytree-expander::after {
	content: '\f0d7';
	font-family: 'Font Awesome 5 Pro';
	font-size: 18px;
	font-weight: 900;
	line-height: 30px;
}
.gmc_control span.fancytree-node.fancytree-expanded .fancytree-expander::after {
	content: '\f0d8';
	opacity: 0.5;
	line-height: 30px;
}
.fancytree-exp-n span.fancytree-expander::after,
.fancytree-exp-nl span.fancytree-expander::after {
	display: none;
}
.gmc_control span.fancytree-title {
	vertical-align: middle;
	color: #202020;
}
.gmc_control .fancytree-plain span.fancytree-node:hover span.fancytree-title,
.gmc_control .fancytree-plain span.fancytree-node:focus span.fancytree-title,
.gmc_control .fancytree-plain span.fancytree-node.fancytree-expanded span.fancytree-title {
	color: #fff;
	background-color: transparent;
	border: 1px solid transparent;
	border-color: transparent;
}
.gmc_control .fancytree-plain span.fancytree-active.fancytree-partsel span.fancytree-title,
.gmc_control .fancytree-plain span.fancytree-selected.fancytree-partsel span.fancytree-title {
	font-weight: 700;
	color: #202020;
	background-color: transparent;
	border: 1px solid transparent;
	border-color: transparent;
}
.gmc_control .fancytree-plain span.fancytree-node.fancytree-partsel:hover span.fancytree-title,
.gmc_control .fancytree-plain span.fancytree-node.fancytree-partsel:focus span.fancytree-title,
.gmc_control .fancytree-plain span.fancytree-node.fancytree-expanded.fancytree-partsel span.fancytree-title {
	color: #fff;
}
.gmc_control .fancytree-plain.fancytree-container.fancytree-treefocus span.fancytree-active span.fancytree-title,
.gmc_control .fancytree-plain.fancytree-container.fancytree-treefocus span.fancytree-selected span.fancytree-title {
	background-color: transparent;
	border-color: transparent;
}
.gmc_control .fancytree-plain span.fancytree-active span.fancytree-expander,
.gmc_control .fancytree-plain span.fancytree-selected span.fancytree-expander {
	color: #202020;
}
.gmc_control .fancytree-plain span.fancytree-node:hover span.fancytree-expander,
.gmc_control .fancytree-plain span.fancytree-node:focus span.fancytree-expander,
.gmc_control .fancytree-plain span.fancytree-node.fancytree-expanded span.fancytree-expander {
	color: #fff;
}
#div_gmc_pos {
	float: right;
}
#div_gmc_pos input {
	width: 5em;
}
.gmc_cmdbar {
	width: 100%;
}
.gmc_cmdbar input {
	width: auto;
	margin: 3px;
	padding: 0 0.5em !important;
	font-size: 16px;
}	
.gmc_cmdbar input[type=button] {
	margin-left: 0px;
	border: none;
	color: #fff;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	background-color: #3d3d3d;
	font-weight: bold;
	padding: 5px 0.5em !important;
}
.gmc_cmdbar .btn {
	min-width: 0;
	margin: 0;
	-ms-user-select: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}
.gmc_cmdbar .btn > i {
	margin-right: 0;
}
.gmc_cmdbar .btn:hover,
.gmc_cmdbar .btn:focus {
	color: #fff;
	background-color: #202020;
}
.gmc_cmdbar .btn.active > i::before {
	content:'\f0c9';
}
.gmc_map {
	float: none;
	width: 100%;
	height: 100%;
	padding: 0;
	margin: 0;
}
.gmc_map .gmc_input {
	z-index: 42;
	float: left;
	width: 250px;
	left: 200px;
	top: 10px;
	position: relative;
}
.gmc_page .gm-style-moc { /* GMC-Zoomhinweis */
	padding: 1em 1em 1em calc(33.333% + 1em) !important;
	text-align: center;
}
.gmc_page .leaflet-container:after { /* OSM-Zoomhinweis */
	padding: 1em 1em 1em calc(33.333% + 1em);
	text-align: center;
}
.gm-style-iw .adr { /* GMC-Infowindow */
	float: left;
	margin: 5px;
}
.gm-style-iw .gm-footer {
	margin: 5px 0;
	padding: 4px;
	background: #eee;
}
.gm-style-iw img {
	float: right;
	margin: 5px;
	width: 150px;
}
.gmc_tooltip { /* GMC-Tooltip */
	min-width: 150px;
	max-width: 200px;
}
.mwl_label {
	background: #eee;
	border: 1px solid #19252f;
	width: 24px;
	font-size: 10px;
	text-align: center;
}
.gmc_adrlist_link {
	cursor: pointer;
	padding: 1em 15px 1em 15px;
	border: none;
	-webkit-transition: all 0.25s ease-out;
	-moz-transition: all 0.25s ease-out;
	-o-transition: all 0.25s ease-out;
	transition: all 0.25s ease-out;
}
.gmc_adrlist_link:hover,
.gmc_adrlist_link:focus {
	background-color: #eee;
	-webkit-transition: all 0.25s ease-out;
	-moz-transition: all 0.25s ease-out;
	-o-transition: all 0.25s ease-out;
	transition: all 0.25s ease-out;
}
.gmc_adrlist_link a,
.gmc_adrlist_link a:link,
.gmc_adrlist_link a:visited {
	display: block;
	min-height: 120px;
	color: #202020;
	text-decoration: none !important;
	border-bottom: 1px solid #ccc;
	-webkit-transition: all 0.25s ease-out;
	-moz-transition: all 0.25s ease-out;
	-o-transition: all 0.25s ease-out;
	transition: all 0.25s ease-out;
}
.gmc_adrlist_link a:hover,
.gmc_adrlist_link a:focus {
	display: block;
	min-height: 120px;
	color: #202020;
	text-decoration: none !important;
	border-bottom: 1px solid #202020;
	-webkit-transition: all 0.25s ease-out;
	-moz-transition: all 0.25s ease-out;
	-o-transition: all 0.25s ease-out;
	transition: all 0.25s ease-out;
}
.gmc_adrlist_link a small {
	opacity: 0.5;
}
.gmc_adrlist_link a small .fa {
	vertical-align: baseline;
}
#ikiss_gmc_tree_wrapper {
	clear: both;
	height: 100%;
	height: calc(100% - 75px);
	padding-top: 25px;
	overflow: auto;
}
.ikiss_cattree ul li {
	padding: 0;
	margin: 0;
}
.ikiss_cattree ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.ikiss_cattree input {
	display: none;
}
.ikiss_cattree span label img { /* PNG-Icons */
	display: inline;
	vertical-align: middle;
	margin-right: 10px;
}
.ikiss_cattree span label [class*="fa-"] { /* Font-Awesome-Icons */
	display: inline;
	vertical-align: middle;
	margin-right: 10px;
	font-size: 20px;
}
.ikiss_cattree span label {
	padding: 10px;
	background-color: #e7e8eb;
	border-bottom: 1px solid #fff;
	margin: 0;
	display: block;
	cursor: pointer;
	position: relative;
}
.ikiss_cattree span label:hover,
.ikiss_cattree span label:focus,
#ikiss_gmc_tree_wrapper ul li.active span label {
	background-color: #eee;
}
.ikiss_cattree ul li.active span label::after {
	content: '\f00c';
	font-family: 'Font Awesome 5 Pro';
	font-weight: 900;
	position: absolute;
	display: inline-block;
	right: 10px;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
img.fancytree-icon {
	width: 25px !important;
	height: 29px !important;
	margin-top: 0 !important;
	margin-left: 0 !important;
	vertical-align: middle !important;
}
.gmc_map > div {
	z-index: 44;
}
#gmc_cookie_msg {
	float: right;
	width: 66.666%;
	text-align: center;
}						  
.randspalte .widget.kartenmodul  {
	padding: 0;
}
.randspalte .widget.kartenmodul h3 {
	margin: 0;
}
.randspalte .widget.kartenmodul .leaflet-pane {
	z-index: 44;
}
.randspalte .widget.kartenmodul .leaflet-control {
	z-index: 46;
}
@media screen and (min-width: 961px) {
	.gmc_adrlist_link:nth-child(3n+1) {
		clear: both;
	}
}
@media screen and (max-width: 960px) {
	.gmc_adrlist_link:nth-child(2n+1) {
		clear: both;
	}
}
@media screen and (max-width: 680px) {
	div.gmc_page {
		height: auto;
	}
	div.gmc_control {
		width: 100% !important;
		height: auto;
	}
	div.gmc_header {
		position: relative;
		top: auto;
		right: auto;
		width: 100%;
	}
	div.gmc_control {
		position: relative;
		top: auto;
		bottom: auto;
		width: 100%;
	}
	div.gmc_map {
		height: 400px;
	}
	.gmc_page .gm-style-moc { 
		padding-left: 1em !important;
	}
	.gmc_page .leaflet-container:after {
		padding-left: 1em;
	}
	#gmc_cookie_msg {
		float: none;
		width: 100%;
		text-align: center;
	}
}