/* @override 
	https://owv.buero-wilhelm.de/typo3conf/ext/se_v12/Resources/Public/Css/layout.css?* */

:root {
	--color-black: rgba(0, 0, 0, 1);
	--color-white: rgba(255, 255, 255, 1);
	--color-grey: rgba(123, 123, 123, 1);
	
	--color-page: #E6F2EB;
	--color-master1: #00783B;
	--color-master2: #B7CE03;
	
	--color-boxshadow: rgba(0, 0, 0, .3);
	--color-subnav-selected: rgba(255, 255, 255, .85);
	--color-mmenu-selected: rgba(255, 255, 255, .15);
	--color-slickdot: rgba(0, 0, 0, 1);
	
	--gradient-slidercaption: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0.4) 100%);

	--letterspacing-s: .03em;
	--letterspacing-m: .08em;
	--letterspacing-l: .12em;	
	
	--framespace-xs: calc(var(--padd-section-tb) * .25);
	--framespace-s: calc(var(--padd-section-tb) * .5);
	--framespace-m: calc(var(--padd-section-tb) * .75);
	--framespace-l: calc(var(--padd-section-tb) * 1);
	--framespace-xl: calc(var(--padd-section-tb) * 1.25);
	
	--padd-b-h: 30px;
	--padd-b-p: 15px;
	
	--padd-page-lr: 15%;
	--marg-page-lr: 5%;
	
	--padd-btn: 15px 30px 15px 30px;
	--padd-btn-news: 10px 20px 10px 20px;
	
	--padd-section-tb: 80px;
	--padd-header-tb: 20px;
	--padd-topnav-lr: 20px;
	--padd-mainnav-lr: 20px;
	--padd-subnav-tb: 10px;
	--padd-subnav-lr: 20px;
	--padd-footernav-lr: 20px;
	--padd-footer-tb: calc(var(--padd-section-tb) * .25);
	--padd-slidercaption: 25px 15px 15px 15px;
	--padd-news-l: 18px;
	
	--gridgap-col: 40px;
	--gridgap-row: 40px;	
	
	--size-ulbullet: 4px;
	--size-accordionicon: 40px;
	--size-backtop: 30px;
	--size-sliderarrow: 40px;
	--size-sliderdot: 40px;
	--size-socialicon: 20px;
	
	--height-mainnav: 86px;
	--height-footerbg: 140px;
	
	--width-logo: 216px;
	
	--font-standard: 'Source Sans 3';
	--font-special: 'Bebas Neue';
	
	/* nav /p / bu / btn / cookie */
	--fontsize-1: 18px;
	--fontsize-2: 24px;
	--fontsize-3: 28px; /* nicht in Verwendung */
	--fontsize-4: 32px;
	--fontsize-5: 40px;
	--fontsize-6: 60px;
	
	--lineheight-p: 140%;
	--lineheight-h: 110%;
	--lineheight-nav: 100%;
	
	--fontweight-regular: 400;
	--fontweight-medium: 600;

	--font-hI: normal var(--fontweight-regular) var(--fontsize-6)/var(--lineheight-h) var(--font-special);
	--font-hII: normal var(--fontweight-regular) var(--fontsize-5)/var(--lineheight-h) var(--font-special);
	--font-hIII: normal var(--fontweight-regular) var(--fontsize-5)/var(--lineheight-h) var(--font-special);
	--font-footer-h: normal var(--fontweight-regular) var(--fontsize-4)/var(--lineheight-p) var(--font-special);
	--font-footernav: normal var(--fontweight-medium) var(--fontsize-1)/var(--lineheight-nav) var(--font-special);
	--font-btn: normal var(--fontweight-medium) var(--fontsize-2)/var(--lineheight-nav) var(--font-special);
	--font-btn-news: normal var(--fontweight-medium) var(--fontsize-1)/var(--lineheight-nav) var(--font-special);
	
	--font-bodytext: normal var(--fontweight-regular) var(--fontsize-2)/var(--lineheight-p) var(--font-standard);
	--font-caption: normal var(--fontweight-regular) var(--fontsize-1)/var(--lineheight-p) var(--font-standard);
	--font-slidercaption: normal var(--fontweight-regular) var(--fontsize-1)/var(--lineheight-p) var(--font-standard);
	--font-footer-p: normal var(--fontweight-regular) var(--fontsize-1)/var(--lineheight-p) var(--font-standard);
}

/* @group RESET */

p,
.container p,
.ce-bodytext p,
figure.image,
h1, h2, h3, h4, h5,
.ce-bodytext ul,
ul,
figure.video,
.frame-type-textmedia div.ce-gallery {
	margin: 0;
	padding: 0;
}

button, input[type="submit"], input[type="reset"] {
	background: none;
	color: inherit;
	border: none;
	padding: 0;
	font: inherit;
	cursor: pointer;
	outline: inherit;
}

* {
	box-sizing: border-box;
}

html,
body {
	width: 100%;
	height: 100%;
    padding: 0;
    margin: 0;
}

/* @group Table reset */

.ce-table, .ce-table th, .ce-table td,
.ce-bodytext figure.table,
.ce-bodytext figure.table table {
    border: none;
    padding: 0;
    margin: 0;
    background: none;
    font: inherit;
    color: inherit;
}

.ce-table,
.ce-bodytext figure.table table {
    border-collapse: collapse; /* Verhindert doppelte Rahmen */
    border-spacing: 0; /* Setzt den Abstand zwischen Zellen auf 0 */
    width: auto;
    height: auto;
}

.ce-table th, .ce-table td,
.ce-bodytext figure.table table th,
.ce-bodytext figure.table table td {
    text-align: left;
    vertical-align: top;
    border: none; /* Stellt sicher, dass auch einzelne Zellen keine Rahmen haben */
	padding: 0;
}

/* @end */

/* @end */

/* @group GENERAL */

/* @group Frames */

.frame-nopaddt {
	padding-top: 0;
}

.frame-nopaddb {
	padding-bottom: 0;
}

.frame-nopaddtb {
	padding-top: 0;
	padding-bottom: 0;
}

.frame-nopaddlr {
	margin-left: 0;
	margin-right: 0;
}

.frame-nopadd {
	padding: 0;
}

.frame-smallwidth {
	margin-left: auto;
	margin-right: auto;
	width: 70%;
	max-width: 990px;
}

/* @end */

/* @group Margins */

.frame-space-before-extra-small {
	margin-top: var(--framespace-xs);
}

.frame-space-after-extra-small {
	margin-bottom: var(--framespace-xs);
}

.frame-space-before-small {
	margin-top: var(--framespace-s);
}

.frame-space-after-small {
	margin-bottom: var(--framespace-s);
}

.frame-space-before-medium {
	margin-top: var(--framespace-m);
}

.frame-space-after-medium {
	margin-bottom: var(--framespace-m);
}

.frame-space-before-large {
	margin-top: var(--framespace-l);
}

.frame-space-after-large {
	margin-bottom: var(--framespace-l);
}

.frame-space-before-extra-large {
	margin-top: var(--framespace-xl);
}

.frame-space-after-extra-large {
	margin-bottom: var(--framespace-xl);
}

/* @end */

/* @group Images */

.frame-type-image img,
.frame-type-textmedia img,
.news img,
.grid-item-image img {
	width: 100%;
	height: auto;
	float: left;
}

.frame .ce-gallery {
	margin-bottom: 0;
}

.frame figure {
	overflow: hidden;
}

/* @end */

/* @group Text */

html {
	-webkit-font-smoothing: antialiased; /* Bugfix Browser Font display */
	-moz-osx-font-smoothing: grayscale; /* Bugfix Browser Font display */
}

body, p, h2, h3, h4, h5, h6 {
	color: var(--color-black);
	font: var(--font-bodytext);
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	-ms-hyphens: auto;
	-o-hyphens: auto;
	hyphens: auto;
}

h1, h2, h3, h4, h5, h6 {
	padding: 0;
	-webkit-hyphens: none;
	-moz-hyphens: none;
	-ms-hyphens: none;
	-o-hyphens: none;
	hyphens: none;
}

.ce-bodytext p,
.ce-bodytext figure.table {
	padding-bottom: var(--padd-b-p);
}

.ce-bodytext p:last-child {
	padding-bottom: 0;
}

.ce-bodytext p em,
.ce-bodytext p i {
	font-style: italic;
}

.ce-bodytext p strong {
	font-weight: var(--fontweight-medium);
}

.ce-bodytext p strong em,
.ce-bodytext p em strong,
.ce-bodytext p strong i,
.ce-bodytext p i strong {
	font-style: italic;
	font-weight: 700;
}

.ce-bodytext ol {
	padding: 0 0 0 24px;
}

.ce-bodytext ul {
    list-style: none;
    padding: 0;
}

.ce-bodytext ol li {
    padding: 0;
}

.ce-bodytext ul li {
    position: relative;
    padding: 0 0 0 24px; /* Adjust based on the size of your SVG */
}

.ce-bodytext ul li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 50%;
    transform: translateY(-50%);
    width: var(--size-ulbullet); /* Adjust width based on the size of your SVG */
    height: var(--size-ulbullet); /* Adjust height based on the size of your SVG */
    background: url('/typo3conf/ext/se_v12/Resources/Public/Images/ul_bullet.svg') no-repeat center center;
    background-size: contain; /* Ensure the SVG scales correctly */
}

.ce-bodytext ul li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 50%;
    transform: translateY(-50%);
    width: var(--size-ulbullet); /* Adjust width based on the size of your SVG */
    height: var(--size-ulbullet); /* Adjust height based on the size of your SVG */
    background: url('/typo3conf/ext/se_v12/Resources/Public/Images/ul_bullet.svg') no-repeat center center;
    background-size: contain; /* Ensure the SVG scales correctly */
}

footer .ce-bodytext ul li::before {
	-webkit-filter: invert(1); /* safari 6.0 - 9.0 */
    filter: invert(1);
}

figcaption.image-caption {
	padding-top: 10px;
	font: var(--font-caption);
	display: block;
}

.ce-table {
	width: 100%;
	border-top: 1px solid var(--color-black);
}

.ce-table tr {
	border-bottom: 1px solid var(--color-black);
}

.ce-table td {
	padding-top: 10px;
	padding-bottom: 10px;
}

.ce-table td:first-child {
	padding-right: 20px;
	width: auto;
}

.text-center,
.ce-headline-center {
	text-align: center;
}

.text-right,
.ce-headline-right {
	text-align: right;
}

h1,
header h1 {
	font: var(--font-hI);
	padding-bottom: var(--padd-b-h);
	text-transform: uppercase;
	letter-spacing: var(--letterspacing-s);
}

p.welcome {
	color: var(--color-master1);
	font: var(--font-hI);
	text-transform: uppercase;
	letter-spacing: var(--letterspacing-s);
	padding-bottom: 0;
}

h2,
header h2 {
	font: var(--font-hII);
	padding-bottom: calc(var(--padd-b-h) * 1);
	text-transform: uppercase;
	letter-spacing: var(--letterspacing-s);
}

h3,
header h3 {
	font: var(--font-hIII);
	text-transform: uppercase;
	letter-spacing: var(--letterspacing-s);	
}

.text-center,
.ce-headline-center {
	text-align: center;
}

.text-right,
.ce-headline-right {
	text-align: right;
}

/* @end */

/* @group Links */

a,
.ce-bodytext p a,
.ce-bodytext ul li a
#header #headerbottom,
#header #headerlogo a img,
.cd-top {
	text-decoration: none;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-ms-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

a,
p a,
.ce-bodytext a,
.ce-bodytext p a,
.ce-bodytext ul li a {
	color: var(--color-black);
}

.ce-bodytext p em strong a,
.ce-bodytext p strong em a,
.ce-bodytext p strong a {
	font-style: italic;
}

a:hover,
p a:hover,
.ce-bodytext a:hover {
	color: var(--color-black);
}

.ce-bodytext p a,
.ce-bodytext ul li a {
}

.ce-bodytext p a:hover,
.ce-bodytext ul li a:hover {
	color: var(--color-master1);
}

footer .ce-bodytext p a {
	color: var(--color-black);
	text-decoration: none;
	opacity: 1;
}

footer .ce-bodytext p a:hover {
	color: var(--color-white);
}

.ce-bodytext p a.shortlink,
.ce-bodytext ul li a.shortlink,
.news-backlink a {
	text-decoration: none;
	font: var(--font-btn);
	color: var(--color-white);	
	padding: var(--padd-btn);
	background-color: var(--color-master1);
	border-radius: 50px;
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: var(--letterspacing-m);
}

.ce-bodytext p a.shortlink:hover,
.ce-bodytext ul li a.shortlink:hover,
.news-backlink a:hover {
	color: var(--color-white);
	background-color: var(--color-black);
}

/* @end */

/* @end */

/* @group BASE FRAMEWORK */

/* @group Page */

/* @group structure */

/* Stile für das gesamte Dokument */
body, html {
    margin: 0;
    padding: 0;
	/* IMPORTANT! kein overflow=hidden, sonst funktionieren keine Skripte */
}

/* Fixierter Header */
#header {
    position: sticky;
    top: 0;
    width: 100%;
    z-index: 3;
	background: var(--color-white);
	background: white;
	will-change: transform;
	transform: translateZ(0);	
}

/* Stile für den Hauptinhalt der Seite */
#page {
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* Sicherstellen, dass der Container mindestens die volle Höhe hat */
	background-color: var(--color-page);
}

/* Hauptinhalt */
main {
    flex: 1; /* Füllt den verfügbaren Platz zwischen Header und Footer */
}

/* Footer */
footer {
	padding-top: var(--height-footerbg);
	position: relative;
	margin-top: ;
}

footer::before {
	content: '';
	position: absolute;
	top: 2px;
	left: 0;
	width: 100%;
	height: var(--height-footerbg);
	background-image: url(/typo3conf/ext/se_v12/Resources/Public/Images/footer_bg.svg);	
	background-position: left;
	background-repeat: repeat-x;
	background-size: 1920px var(--height-footerbg);
	background-color: transparent;
}

/* Sicherstellen, dass der Footer am Ende des Contents bleibt */
#page::after {
    content: "";
    display: block;
    height: 0px; /* Minimaler zusätzlicher Inhalt, um den Footer an das Ende zu schieben */
}

/* @end */

/* @group header */

#headerbottom {
	padding-left: var(--padd-page-lr);
	padding-right: var(--padd-page-lr);	
	height: var(--height-mainnav);
}

#headerlogowrap {
	display: flex;
    justify-content: center; /* horizontal */
    align-items: end; /* vertikal */
	margin-top: 10px;
}

#headerlogo {
	overflow: hidden;
}

#headerlogo a {
	float: left;
	display: inline-flex;
}

#headerlogo a img {
	width: var(--width-logo);
	height: 100%;
    transition: transform 0.3s ease; /* Weiche Animation */
}

#headerlogo a img:hover {
    transform: scale(0.95); /* Verkleinern auf 90% */
}

#header.scroll #headerbottom {
	height: calc(var(--height-mainnav) * .65);
}

#header.scroll #headerlogo a img {
	width: calc(var(--width-logo) * .65);
}

/* @end */

/* @group footer */

footer header h2,
footer p,
footer .ce-bodytext p,
footer .ce-bodytext figure.table {
	font: var(--font-footer-p);
}

.footertop {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr var(--size-backtop);
	grid-column-gap: var(--gridgap-col);
	grid-row-gap: var(--gridgap-row);
	padding-top: calc(var(--padd-footer-tb) * 3.5);
	padding-left: var(--padd-page-lr);
	padding-right: var(--padd-page-lr);
	background-color: var(--color-master2);
	position: relative;
}

.footertop::before {
	content: 'KONTAKT';
	font: var(--font-footer-h);
	position: absolute;
	top: 10px;
	left: var(--padd-page-lr);
}

.footercol4 {
	display: flex;
    justify-content: flex-end; /* horizontal */
    align-items: end; /* vertikal */
}

.footertop div > img {
	max-width: 240px;
	margin-top: 30px;
}

.footertop div a img:hover {
	opacity: .7;
}

footer .ce-bodytext figure.table {
	margin: 0;
}

footer .ce-bodytext figure.table table.contenttable {
	width: 100%;
}

footer .ce-bodytext figure.table table.contenttable tbody tr td:first-child {
	width: 33%;
	min-width: 120px;
}

.footerbottom {
	padding-top: var(--padd-footer-tb);
	padding-bottom: calc(var(--padd-footer-tb) * .5);
	padding-left: var(--padd-page-lr);
	padding-right: var(--padd-page-lr);
	background-color: var(--color-master2);	
}

.footerwrap {
	display: grid;
	grid-template-columns: auto auto;
	border-top: 5px solid var(--color-black);
}

.footernav ul,
.footercopyright ul {
	display: inline-flex;
	list-style: none;
}

.footercopyright {
	text-align: right;
}

.footernav ul li,
.footernav ul li a,
.footercopyright ul li,
.footercopyright ul li a {
	font: var(--font-footernav);
	color: var(--color-black);
	letter-spacing: var(--letterspacing-m);
}

.footernav ul li {
	margin-right: var(--padd-footernav-lr);	
}

.footernav ul li:last-child {
	margin-right: 0;	
}

.footernav ul li a:hover,
.footercopyright ul li a:hover {
	color: var(--color-white);
}

/* @end */

/* @end */

/* @end */

/* @group EXTENSIONS */

/* @group container */

section {
	padding-bottom: var(--padd-section-tb);
	padding-top: var(--padd-section-tb);
	padding-left: var(--padd-page-lr);
	padding-right: var(--padd-page-lr);	
}

div.container_2col_3366,
div.container_2col_6633,
div.container_2col,
div.container_2col_imgtxt,
div.container_2col_txtimg,
div.container_3col,
div.container_4col {
	margin-left: auto;
	margin-right: auto;
	display: grid;
	grid-column-gap: var(--gridgap-col);
	grid-row-gap: var(--gridgap-row);
}

div.container_2col_3366 {
	grid-template-columns: 33fr 66fr;
}

div.container_2col_6633 {
	grid-template-columns: 66fr 33fr;
}

div.container_2col {
	grid-template-columns: repeat(2, 1fr);
}

div.container_2col_imgtxt,
div.container_2col_txtimg {
	grid-template-columns: repeat(2, 1fr);
}

div.container_2col_imgtxt .container_col:nth-child(1),
div.container_2col_txtimg .container_col:nth-child(1) {
	grid-column: 1 / 2;
}

div.container_2col_imgtxt .container_col:nth-child(2),
div.container_2col_txtimg .container_col:nth-child(2) {
	grid-column: 2 / 3;
}

div.container_3col {
	grid-template-columns: repeat(3, 1fr);
}

div.container_4col {
	grid-template-columns: repeat(4, 1fr);
}

div.container_col .frame:last-child {
	margin-bottom: 0;
}

div.container_col.vcenter {
	display: flex;
    align-items: center; /* Vertikal zentriert */
}

.container_col .frame:first-child {
	padding-bottom: 50px;
}

.container_col .frame:last-child {
	padding-bottom: 0px;
}

/* @end */

/* @group backtotop */

.cd-top {
	display: inline-block;
	width: var(--size-backtop);
	height: var(--size-backtop);
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	cursor: pointer;
	opacity: .5;
	z-index: 1;
}

.cd-top {
  background-image: url(/typo3conf/ext/se_v12/Resources/Public/Images/backtotop.svg);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: var(--size-backtop) var(--size-backtop);
  background-color: transparent;
}

.cd-top:hover {
  opacity: 1;
}

/* @end */

/* @group ws_slider (flexslider) */

.flexslider .slides li {
	position: relative;
	padding-bottom: 50%; /* 16:9, for an aspect ratio of 1:1 change to this value to 100% */ 
}

.flexslider .slides li picture {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

.flexslider .slides li picture img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.flexslider {
    margin: 0;
    border: 0px solid #fff;
	margin-bottom: calc(var(--padd-section-tb) * 1);
}

.flex-direction-nav a {
    width: var(--size-sliderarrow);
    height: var(--size-sliderarrow);
    margin: 0;
    top: calc(50% - calc(var(--size-sliderarrow) * .5));
    opacity: .7;
	z-index: 2;
}

.flex-direction-nav a:before {
    content: '';
}

.flex-direction-nav a.flex-next:before {
    content: '';
}

.flex-direction-nav .flex-prev {
    left: calc(var(--size-sliderdot) * 1);
	background-image: url(/typo3conf/ext/se_v12/Resources/Public/Images/slider_prev.svg);
	background-position: left top;
	background-repeat: no-repeat;
	background-size: var(--size-sliderarrow) var(--size-sliderarrow);
	background-color: transparent;
}

.flex-direction-nav .flex-next {
    right: calc(var(--size-sliderdot) * 1);
	background-image: url(/typo3conf/ext/se_v12/Resources/Public/Images/slider_next.svg);
	background-position: left top;
	background-repeat: no-repeat;
	background-size: var(--size-sliderarrow) var(--size-sliderarrow);
	background-color: transparent;
}

.flexslider:hover .flex-direction-nav .flex-prev {
    opacity: 0.7;
    left: calc(var(--size-sliderdot) * .75);
}

.flexslider:hover .flex-direction-nav .flex-prev:hover {
    opacity: 1;
}

.flexslider:hover .flex-direction-nav .flex-next {
    opacity: 0.7;
    right: calc(var(--size-sliderdot) * .75);
}

.flexslider:hover .flex-direction-nav .flex-next:hover {
    opacity: 1;
}

.flexslider div.caption-wrapper {
	position: absolute;
	bottom: 0;
	width: 100%;
}

.flexslider div.caption-wrapper div.caption-text {
	background: var(--gradient-slidercaption);
	color: var(--color-white);
	padding: var(--padd-slidercaption);
	font: var(--font-caption);
}

/* Control Dots */

.flex-control-nav {
    position: absolute;
    bottom: 0;              /* direkt an der Unterkante */
    left: 0;
    width: 100%;
    height: 5px;            /* Höhe der Balken */
    text-align: left;
    display: flex;          /* gleichmäßige Verteilung */
    justify-content: stretch;
    padding: 0;
    margin: 0;
	z-index: 2;
}

.flex-control-nav li {
    flex: 1 1 auto;         /* alle gleich breit */
    margin: 0;              /* kein Zwischenraum */
}

.flex-control-paging li a {
    width: 100%;
    height: 100%;
    display: block;
    background-color: var(--color-master2);
	opacity: .3;
    border-radius: 0;       /* rechteckig */
    text-indent: -9999px;   /* Text ausblenden */
    box-shadow: none;
    transition: background-color 0.3s ease, opacity 0.3s ease;
}

.flex-control-paging li a:hover {
    background-color: var(--color-master2);
	opacity: .6;
}

.flex-control-paging li a.flex-active {
    background-color: var(--color-master2);
	opacity: 1;
}


/* @end */

/* @group news */

.news {
    margin-top: calc(var(--padd-section-tb) * .75);
}

.article {
    position: relative;
    padding-top: var(--padd-b-p);
    margin-bottom: calc(var(--padd-b-h) * 1);
}

.article::before {
    position: absolute;
    content: '';
    top: 0;
    left: 0;
    width: 80px;
    height: 5px;
    background-color: var(--color-black);
    transition: width .4s ease, background-color .3s ease;
}

.article:hover::before {
    width: 100%;
}

.news-single .article:hover::before {
    width: 80px;
}

.article div.news-date {
    font-size: var(--fontsize-2);
    color: var(--color-grey);
    font-weight: var(--fontweight-medium);
    transition: color .3s ease;
}

.article div.news-title {
    padding-top: calc(var(--padd-b-p) * .5);
    padding-bottom: calc(var(--padd-b-p) * .5);
    color: var(--color-master1);
}

.article div.news-title h3 a span {
    color: var(--color-black);
    transition: color .3s ease;
}

.article div.news-title h3 a span:hover {
    color: var(--color-master1);
}

.article div.news-teaser div p a {
    font-size: var(--fontsize-2);
    font-weight: var(--fontweight-medium);
	color: var(--color-master1);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    position: relative;
}

.article div.news-teaser div p a::before {
    content: "";
    width: 25px;
    height: 34px;
    display: inline-block;
    background-image: url('/typo3conf/ext/se_v12/Resources/Public/Images/icon_maps0.svg');
    background-size: contain;
    background-repeat: no-repeat;
    transition: opacity .3s ease;
}

.article div.news-teaser div p a::after {
    content: "";
    position: absolute;
    left: 0;
    width: 25px;
    height: 34px;
    background-image: url('/typo3conf/ext/se_v12/Resources/Public/Images/icon_maps1.svg');
    background-size: contain;
    background-repeat: no-repeat;
    opacity: 0;
    transition: opacity .3s ease;
}

.article div.news-teaser div p a:hover::after {
    opacity: 1;
}

.article div.news-teaser div p a:hover {
	color: var(--color-black);
}

.news-bodytext {
    padding-top: var(--padd-b-p);
    padding-bottom: var(--padd-b-p);
}

.news-bodytext p {
	padding-bottom: var(--padd-b-p);
}

.news-imgwrap {
	overflow: hidden;
    padding-top: var(--padd-section-tb);
    padding-bottom: calc(var(--padd-section-tb) * .25);
}

p.news-img-caption {
	display: inline-block;
	width: 100%;
	font: var(--font-caption);
	padding-top: calc(var(--padd-b-p) * .5);
	text-align: center;
}

.news-imgwrap div.outer {
	margin-bottom: var(--padd-b-h);
	overflow: hidden;
}

.news-imgwrap div.outer:last-child {
	margin-bottom: 0;
}

/* @end */

/* @end */


