body,form,figure{margin:0;padding:0}img{border:0}header,footer,nav,section,aside,article,figure,figcaption{display:block}body{font-size:100.01%}select,input,textarea{font-size:99%}#container,.inside{position:relative}#main,#left,#right{float:left;position:relative}#main{width:100%}#left{margin-left:-100%}#right{margin-right:-100%}#footer{clear:both}#main .inside{min-height:1px}.ce_gallery>ul,.content-gallery>ul{margin:0;padding:0;overflow:hidden;list-style:none}.ce_gallery>ul li,.content-gallery>ul li{float:left}.ce_gallery>ul li.col_first,.content-gallery>ul li.col_first{clear:left}.float_left,.media--left>figure{float:left}.float_right,.media--right>figure{float:right}.block{overflow:hidden}.media{display:flow-root}.clear,#clear{height:.1px;font-size:.1px;line-height:.1px;clear:both}.invisible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.custom{display:block}#container:after,.custom:after{content:"";display:table;clear:both}
@media (max-width:767px){#wrapper{margin:0;width:auto}#container{padding-left:0;padding-right:0}#main,#left,#right{float:none;width:auto}#left{right:0;margin-left:0}#right{margin-right:0}}img{max-width:100%;height:auto}.audio_container audio{max-width:100%}.video_container video{max-width:100%;height:auto}.aspect,.responsive{position:relative;height:0}.aspect iframe,.responsive iframe{position:absolute;top:0;left:0;width:100%;height:100%}.aspect--16\:9,.responsive.ratio-169{padding-bottom:56.25%}.aspect--16\:10,.responsive.ratio-1610{padding-bottom:62.5%}.aspect--21\:9,.responsive.ratio-219{padding-bottom:42.8571%}.aspect--4\:3,.responsive.ratio-43{padding-bottom:75%}.aspect--3\:2,.responsive.ratio-32{padding-bottom:66.6666%}
.mod_customnav.gluid.block ul {
    font-size: 120%;
	position: fixed;
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	transform: rotate(270deg) translate(100%);
	transform-origin: bottom right;
	bottom: 15.5rem;
	right: 1px;
	gap: 0.5rem;
	align-items: flex-end;
	z-index: -99999;
 }
.mod_customnav.gluid.block li a{
	display: block;
	background-color: #b3171b;
	padding: 10px 10px 10px 10px;
	color: #fff;
	border-radius: 5px 5px 0 0;
	transition: all linear 100ms;
 }
.mod_customnav.gluid.block li a:hover {
     background-color: #920307;
	 padding: 10px 10px 20px 10px;
	}
.mod_article.block {
  margin-right: 37px;
}

/* neue Symboliste rechts */

.fixedButton.block ul {
	position: fixed;
	list-style: none;
	display: flow-root;
	top: 33%;
	right: 1px;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	align-items: flex-end;
	margin: 0;
	padding: 0;
}
.fixedButton.block ul li a {
	margin: 0;
	padding: 0;
}
.fixedButton.block ul li a {
	display: block;
	width: 1em;
	height: 1em;
	background-color: #b3171b;
	color: #fff;
	padding: 0.5em;
	margin: 0;
	border-radius: 5px 0 0 5px;
	transition: all linear 100ms;
	text-align: center;
	border: 1px solid #fff;
}
.fixedButton.block ul li a:hover {
	padding-right: 1em;
}
.fa-solid{
	font-size: 150%;
	color: #fff;
	line-height: 200%;
	text-decoration: none;
}
.fa-solid.fa-arrow-up a {
	scroll-behavior: smooth;
}

/* jost-100 - latin */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 100;
  src: url('../../files/css/fonts/jost-v14-latin-100.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/jost-v14-latin-100.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/jost-v14-latin-100.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-100.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-100.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/jost-v14-latin-100.svg#Jost') format('svg'); /* Legacy iOS */
}

/* jost-300 - latin */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 300;
  src: url('../../files/css/fonts/jost-v14-latin-300.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/jost-v14-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/jost-v14-latin-300.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-300.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/jost-v14-latin-300.svg#Jost') format('svg'); /* Legacy iOS */
}

/* jost-regular - latin */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  src: url('../../files/css/fonts/jost-v14-latin-regular.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/jost-v14-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/jost-v14-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-regular.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/jost-v14-latin-regular.svg#Jost') format('svg'); /* Legacy iOS */
}

/* jost-600 - latin */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 600;
  src: url('../../files/css/fonts/jost-v14-latin-600.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/jost-v14-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/jost-v14-latin-600.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-600.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/jost-v14-latin-600.svg#Jost') format('svg'); /* Legacy iOS */
}

/* jost-italic - latin */
@font-face {
  font-family: 'Jost';
  font-style: italic;
  font-weight: 400;
  src: url('../../files/css/fonts/jost-v14-latin-italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/jost-v14-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/jost-v14-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-italic.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/jost-v14-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/jost-v14-latin-italic.svg#Jost') format('svg'); /* Legacy iOS */
}
/* arimo-regular - latin */
@font-face {
  font-family: 'Arimo';
  font-style: normal;
  font-weight: 400;
  src: url('../../files/css/fonts/arimo-v27-latin-regular.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-regular.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-regular.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-500 - latin */
@font-face {
  font-family: 'Arimo';
  font-style: normal;
  font-weight: 500;
  src: url('../../files/css/fonts/arimo-v27-latin-500.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-500.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-500.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-500.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-600 - latin */
@font-face {
  font-family: 'Arimo';
  font-style: normal;
  font-weight: 600;
  src: url('../../files/css/fonts/arimo-v27-latin-600.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-600.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-600.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-600.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-700 - latin */
@font-face {
  font-family: 'Arimo';
  font-style: normal;
  font-weight: 700;
  src: url('../../files/css/fonts/arimo-v27-latin-700.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-700.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-700.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-italic - latin */
@font-face {
  font-family: 'Arimo';
  font-style: italic;
  font-weight: 400;
  src: url('../../files/css/fonts/arimo-v27-latin-italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-italic.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-italic.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-500italic - latin */
@font-face {
  font-family: 'Arimo';
  font-style: italic;
  font-weight: 500;
  src: url('../../files/css/fonts/arimo-v27-latin-500italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-500italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-500italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-500italic.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-500italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-500italic.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-600italic - latin */
@font-face {
  font-family: 'Arimo';
  font-style: italic;
  font-weight: 600;
  src: url('../../files/css/fonts/arimo-v27-latin-600italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-600italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-600italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-600italic.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-600italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-600italic.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* arimo-700italic - latin */
@font-face {
  font-family: 'Arimo';
  font-style: italic;
  font-weight: 700;
  src: url('../../files/css/fonts/arimo-v27-latin-700italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../files/css/fonts/arimo-v27-latin-700italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../files/css/fonts/arimo-v27-latin-700italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-700italic.woff') format('woff'), /* Modern Browsers */
       url('../../files/css/fonts/arimo-v27-latin-700italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../files/css/fonts/arimo-v27-latin-700italic.svg#Arimo') format('svg'); /* Legacy iOS */
}

/* ===========================
   1. ALLGEMEINE AUSBLENDUNGEN
   =========================== */
.mobile-check, .button-nav-search {display: none;    opacity: 0;}
.rotesband {
  display: none;
}

/* ===========================
   2. DESKTOP NAVIGATION
   =========================== */
.mod_navigation {
    color: #ffffff;
    font-size: 16px;
    height: 52px;
    letter-spacing: 2px;
    line-height: 51px;
    text-align: center;
    overflow: visible;
    font-weight: normal;
    background-color: #b3171b;
}
.mod_navigation li a, 
strong.trail,
strong.active {
    color: #fff;
    margin: 0;
    overflow: visible;
    padding: 0 15px;
    text-decoration: none;
}
.mod_navigation a.trail,
.mod_navigation a.active,
.mod_navigation strong.trail,
.mod_navigation strong.active {
	display: block;
	color: #fff !important;
	background-color: #215a31 !important;
	text-align: left;
}
.mod_navigation a:hover {
    background-color: #fff;
    text-decoration: none;
	color: #b3171b;
}
.active.startseite {
  max-height: 50px;
}
.mod_navigation li > ul {
    background-color: #fff;
    padding: 0;
    white-space: nowrap;
}
.mod_navigation li, .mod_navigation a {
    display: block;
}
.mod_navigation li > ul > li {
    float: none;
}
.mod_navigation li, .mod_customnav li {
    float: left;
    position: relative;
}
.mod_navigation li > ul {
    display: none;
    left: 0;
    position: absolute;
    top: 100%;
    z-index: 100;
}
.mod_navigation .level_2 {
	text-align: left;
}
.mod_navigation .level_2 li {
    border-top: 1px solid #846d71;
	background-color: #b3171b;
}
.mod_navigation li > .active {
    color: #fff;
	background-color: #215a31;
}
.nav_main .level_2 li.first, .nav_main .level_2 li.first a {
    padding-left: -4px;
}
.nav_main .level_1 {
    display: inline-block;
    margin: 1px auto;
    padding: 0 ;
}
.mod_customnav.ebene3.block{
	display: none;
	opacity: 0;
}
#innerwrapper .mod_pageimage.block {
  margin-top: 40px;
}

/* ===========================
   3. NAVIGATION EBENE 2 + LEISTE
   =========================== */
#navi-level2{
	width: 100%;
	background-color: #000;
	padding-top: 20px;
	padding-bottom: 20px;
	overflow: visible;
	display: flex;
	margin-bottom: 20px;
}
#navi-level2 .inside{
	max-width: 813px;
	margin: auto;
	padding: 0px;
	z-index: 0;
}
.mod_navigation.level-2 ul, .leiste ul{
	padding: 0px;
}
.mod_navigation.level-2 li, .leiste li {
	background-color: white;
	height: 50px;
	width:250px;
    margin-right:21px;
	margin-left:0px;
    margin-bottom:10px;
	list-style-type: none;
}
.mod_navigation.level-2 li{
	width:250px;
    }
.leiste li {
	width:792px;
}
.leiste li::after { 
	content: "Produkte anzeigen";
	top: -40px;
	position: relative;
	left: 20px; 
}
.mod_navigation.level-2 a, .leiste  {
	margin: auto;
	display: block;
	text-align: center;
	font-weight: 500;
}

/* ===========================
   4. SUCHE ICON
   =========================== */
.search.sibling.last{
	background-position: center center;
	background-repeat: no-repeat;
	width: 29px;
	height: 34px;
}
li.search.sibling.last{
	background-color: #b3171b;
	padding: 9px;
	margin-right: 18px;
	margin-left: 1px;
	font-family: 'Font Awesome 6 Free';
	display: var(--fa-display, inline-block);
	font-style: normal;
	font-variant: normal;
	line-height: 2;
	text-rendering: auto;
	font-weight: 900;
	font-size: 130%;
}
a.search.sibling.last {
	z-index: 1;
	position: relative;
	width: 20px;
	height: 48px;
	padding-top: 4px;
	margin-top: -9px;
	border: none;
}
a.search.sibling.last::before {
	content: "\f002";
}

/* ===========================
   5. BREAKPOINT: DESKTOP
   =========================== */
@media (min-width: 992px){
	.mod_navigation li:hover > ul {
		border-left: 1px solid #846d71;
		border-right: 1px solid #846d71;
	}
	.mod_navigation .level_3 {
		left: 100% !important;
		top: -0px !important;
	}
	nav.nav_main li.submenu:hover > ul {
		display: block;
	}
}

/* ===========================
   6. BREAKPOINT: MOBIL
   =========================== */
@media (max-width: 991px){
	body {
		font-size: 16px;
		line-height: 24px;
	}	
	iframe {
		width: 100%;
	}
	.ce_inside, .nav_main .level_1, .ce_table, h1, .suche,.mod_newslist, .mod_artikelblock, .mod_artikelblock_3{
		max-width: 991px;
		padding: 0;
	}
	.leiste{
		max: 50%;
	}
	.margin10{
		margin-bottom: 10px;
	}
	#container, .inside{
		position: sticky;
	}
	#header{
		height: 75px;
	}
	#header .inside{
		z-index: 10000;
	}
	.head h2, .head-klein h2, .video h2, .head2 h1 {
		letter-spacing: 0;
	}
	#header img {
		height: 60%;
		width: 60%;
	}
	#header .ce_image {
		padding-top: 20px;
		padding-bottom: 20px;
		max-width: 296px;
	}
	.head .image_container.float_left img {
		max-height: 300px
	}
	span.blind{
		display: none;
	}
	.nav_main{	
		display: none;
		opacity: 0;
	}
	input:checked ~ .nav_main {
		display: block;
		z-index: 9999;
		opacity: 100;
		background-color: #b3171b;
	}
	.rotesband {
		background-color: #b3171b;
		height: 52px;
		z-index: 99;
		position: relative;
		top: 185px;
		margin-top: -52px;
		display: flex;
		align-items: center;
		padding: 0 1rem;
		justify-content: flex-end; 
	}
	.rotesband label {
		padding: 5px;
		font-size: 110%;
	}
	.rotesband .fa-solid.fa-bars{
		font-size: 160%;
	}
	#main {
		margin-top: 35px;
	}
	.button-nav-mobile {
		background-image:url("../../files/css/icon/Burgerbuttons_SM_XS.svg");
		display: block;
		width: 5rem;
		height: 3rem;
		background-repeat: no-repeat;
		background-position: 50% 50%;
		background-size: 1.5rem 2rem;
		position: absolute;
		right: 0;
		top: 0;
		z-index: 99;
	}
	.button-nav-mobile:visited,
	.button-nav-mobile:hover,
	.button-nav-mobile:active {
		background-image:url("../../files/css/icon/Burgerbuttons_SM_XS.svg");
		background-repeat:no-repeat;
		cursor: pointer;
		background-size: 1.5rem 2rem;
	}
	input:checked + .button-nav-mobile {
		background-image: url("../../files/css/icon/nav-close.svg");
		background-position: 90% 50%;
		background-repeat: no-repeat;
		background-size: 1.5rem 2rem;
		position: absolute;
		display: block;
	}
	.button-nav-search{
		background-color: red;
	}
	.nav_main li.search.last{
		display: none;
		opacity: 0;
	}
	.nav_main li{
		border-top: 1px solid #846d71;	
	}
	.nav-wrapper {
		position: fixed;
		right: 0;
		top: 100px;
		width: 25rem;
		height: 100%;
		box-sizing: border-box;
		opacity: 0;
		z-index: -1;
		overflow-y: scroll;
	}
	.mod_navigation {
		height: 44px;
		line-height: 44px;
	}
	.nav_main {
		height: auto;
		box-sizing: border-box;
		opacity: 1;
		z-index: 100;
		background-color: #fff;
	}
	.nav_main .submenu.open > ul {
		display: none;
		opacity: 1;
	}
	.nav_main .level_1{
		padding: 0;
	}
	.nav_main .active{
		text-align: left;
	}
	.nav_main .level_1, .nav_main .level_2, .nav_main .level_3 {
		width: 105%;
	}
	.nav_main .level_1 li, .nav_main .level_2 li, .nav_main .level_3 li {
		display: block;
		float: none;
	}
	.nav_main .level_1 li a, .nav_main .level_1 li a:link, .nav_main .level_1 li a:visited, .nav_main .level_2 li a, .nav_main .level_2 li a:link, .nav_main .level_2 li a:visited, .nav_main .level_3 li a, .nav_main .level_3 li a:link, .nav_main .level_3 li a:visited {
		text-align: left;
		line-height: 3rem;
	}
	.nav_main .level_1 li .active, .nav_main .level_2 li .active, .nav_main .level_3 li .active {
		text-align: left;
		line-height: 3rem;
	}
	.nav_main .level_1 li:hover .level_2,
	.nav_main .level_2 li:hover .level_3 {
		width: auto;
		text-align: left;
		opacity: 1;
	}
	.nav_main li .submenu-toggle, .nav_main ul.level_1 > li .submenu-toggle {
		content: "+";
		cursor: pointer;
		display: block;
		position: absolute;
		left: 0;
		top: 0;
		width: 1rem;
		box-sizing: border-box;
		font-size: 3.5rem;
		line-height: 3rem;
		text-align: center;
		font-weight: 300;
		font-style: normal;
	}
	.nav_main li .submenu-toggle:before, .nav_main ul.level_1 > li .submenu-toggle:before {
		content: "+";
	}
	.nav_main li.open > .submenu .submenu-toggle {
		transform: rotate(45deg);
		transition: transform 0.5s;
	}
	.nav_main .level_2, .nav_main .level_3 {
		position: relative;
		display: none;
		top: 0;
	}
	.nav_main .level_2 li > span.active, 
	.nav_main .level_2 li > .active, 
	.nav_main .level_2 li > .trail, 
	.nav_main .level_3 li > span.active, 
	.nav_main .level_3 li > .active, 
	.nav_main .level_3 li > .trail,
	.nav_main .level_2 li a, 
	.nav_main .level_2 li a:link, 
	.nav_main .level_2 li a:visited, 
	.nav_main .level_3 li a, 
	.nav_main .level_3 li a:link, 
	.nav_main .level_3 li a:visited {
		display: block;
		line-height: 3rem !important;
		padding: 0 0 0 2.5rem; 
	}
	.nav_main .level_3 li > span.active, 
	.nav_main .level_3 li > .active, 
	.nav_main .level_3 li > .trail,
	.nav_main .level_3 li a, 
	.nav_main .level_3 li a:link, 
	.nav_main .level_3 li a:visited {
		padding: 0 0 0 5rem; 
	}
	.nav_main .level_3 {
		left: auto; 
	}
	nav.nav_main li.submenu.open > ul {
		display: block;
	}
	.active.startseite.first {
		border-bottom: 1px solid #846d71;
	}
	.mod_navigation a:hover {
		background-color: #b3171b;
		color: #fff;
	}
	.mod_customnav.ebene3.block{
		display: block;
		opacity: 0;
	}
	nav.nav_main li.submenu > a:before,
	nav.nav_main li.submenu > strong:before {
		content: '▼';
	}
	nav.nav_main li.submenu.open > a:before,
	nav.nav_main li.submenu.open > strong:before {
		content: '▲';
	}
	.active.startseite {
		margin-top: -1px;
	}
}

/* ============================================================
   8) BUTTON-STILE (kannst du überall verwenden)
============================================================ */
.btn, .button{
  display:inline-block; text-decoration:none; cursor:pointer;
  font-weight:800; border:0; border-radius:12px;
  padding:12px 18px; /* Button-Größe */
}

/* Gefüllter roter Button */
.btn--primary{ background:var(--rot); color:#fff; }
.btn--primary:hover{ filter:brightness(.95); } /* Leichte Abdunklung */

/* Umrahmter Button (transparent) */
.btn--ghost{ background:transparent; color:var(--rot); border:2px solid var(--rot); }
.btn--ghost:hover{ background:rgba(179,23,27,.08); }


/* ============================================================
   10) FEINSCHLIFF / KONSISTENZ
============================================================ */

/* Einheitliche Rundung für Bilder, wenn Contao sie „kantig“ ausgibt */
.ce_image img, .image_container img{ border-radius:12px; }

/* Formulare freundlicher gestalten */
form input, form select, form textarea{
  border:1px solid #ddd; border-radius:10px; padding:10px 12px; width:100%;
}
form input:focus, form select:focus, form textarea:focus{
  border-color:var(--rot); 
  box-shadow:0 0 0 3px rgba(179,23,27,.15); /* Roter Fokusring */
}

/* Links im Fließtext (RTE) – Standard grün, Hover rot */
.rte a{ color:var(--gruen); text-decoration:underline; text-underline-offset:2px; }
.rte a:hover{ color:var(--rot); }


/* =========================
   MEDIA QUERIES: MOD_PAGEIMAGE
========================= */
@media screen and (max-width: 1199px) and (min-width: 992px) {
  .mod_pageimage.block {
    top: -15px;
    margin-top: 15px;
  }
}

@media screen and (max-width: 991px) and (min-width: 601px) {
  .mod_pageimage.block {
    top: -10px;
    margin-top: 20px;
  }
}

@media screen and (max-width: 600px) {
  .mod_pageimage.block {
    top: 0;
    margin-top: 40px;
  }
}
/* =========================
   GLOBAL & GRUNDLAYOUT
========================= */
body {
	font-family: 'Arimo';
	font-weight: 500;
	color:#333;
	background-color: #feecc4;
	line-height: 1.6rem;
}
#wrapper {
	max-width: 1170px;
	margin: auto;
	margin-bottom: 120px;
}
#innerwrapper .inside {
  text-align: center;
}
.mod_pageimage.block {
  margin-top: -1px;
}
#innerwrapper .mod_pageimage.block {
 margin-top: 0px; 
 text-align: center;
}
.center {
	text-align: center;
}

/* ===============================
   LINKS & BUTTONS ALLGEMEIN
=============================== */
.ce_text a, .ce_download a {
	color: #215a31;
	font-size: 120%;
    text-decoration: none;
	padding: 5px;
}
.ce_text a:hover, .ce_download a:hover {
  color: #fff;
  font-size: 120%;
  text-decoration: none;
  background-color: #215a31;
  padding: 5px;
}

/* ===============================
   KASTEN / BOXEN STIL
=============================== */
.beige {
  background-color: #fff;
  padding-top: 5px;
}
.um, .location {
  margin-left: 10px;
  display: inline-block;
  line-height: 1.6rem;
}
.um, .ort {
  font-weight: bold;
  display: inline-block;
  min-width: 80px;
}
.ical, .ical a {
  background: #215a31;
  color: #ffffff !important;
  display: inline-block;
  text-decoration: none;
  padding: 0 5px;
  margin-bottom: 10px;
}

/* ===============================
   STARTSEITE: INFOKÄSTCHEN
=============================== */

.infoboxen {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  margin: 40px auto;
  max-width: 1140px;
  padding: 0 10px;
}

/* Standard-Styling für alle Kästchen */
.infobox {
  flex: 1 1 240px;
  max-width: 260px;
  min-height: 240px;
  background-color: #fff;
  border: 2px solid #b3171b;
  border-radius: 15px;
  padding: 20px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-align: center;
}

/* Titel im Kästchen */
.infobox h3 {
  color: #215a31;
  font-size: 1.3rem;
  margin-bottom: 10px;
}

/* Text im Kästchen */
.infobox p {
  flex-grow: 1;
  font-size: 1rem;
  color: #333;
  margin-bottom: 15px;
}

/* Button im Kästchen */
.infobox a.button {
  display: inline-block;
  background-color: #215a31;
  color: #fff;
  padding: 8px 14px;
  border-radius: 5px;
  text-decoration: none;
  font-weight: bold;
  transition: background-color 0.3s ease;
}

.infobox a.button:hover {
  background-color: #b3171b;
}
/* Bilder & Icons in den Infoboxen */
.infobox-img {
  max-width: 160px;   /* maximale Breite */
  max-height: 160px;  /* maximale Höhe */
  margin: 10px auto; /* zentriert mit etwas Abstand */
  display: block;
}


/* ===============================
   REIHENFOLGE: NÄCHSTER TERMIN
=============================== */
/* Dieses Kästchen rutscht ganz nach vorne */
.infobox.termin {
  order: -1;
}

/* ===============================
   STARTSEITE: TEXT ÜBER BILD
=============================== */
.hero-overlay {
  position: absolute;
  top: -15% !important;
  left: 50%;
  transform: translateX(-50%);
  background-color: rgba(255, 255, 255, 0.7);
  padding: 20px 30px;
  border-radius: 10px;
  text-align: center;
  z-index: 10;
  max-width: 90%;
}

.hero-overlay h1 {
  font-size: 1.8rem;
  color: #215a31;
  margin-bottom: 10px;
}

.hero-overlay a.hero-button {
  display: inline-block;
  background-color: #215a31;
  color: #fff;
  padding: 8px 16px;
  text-decoration: none;
  border-radius: 5px;
  font-weight: bold;
  transition: background-color 0.3s ease;
}

.hero-overlay a.hero-button:hover {
  background-color: #b3171b;
}


/* ========================
   Bereich: Letzte drei Berichte (untereinander)
=========================== */
.container-gschichten {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  max-width: 800px;
  margin: 40px auto;
}

.container-gschichten .bericht-container {
  background-color: #fff;
  border: 1px solid #ccc;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: 1rem;
  width: 100%;
  max-width: 600px;
}

.container-gschichten .bericht-container h3 {
  margin-top: 0;
  color: #215a31;
  font-size: 1.2rem;
}

.container-gschichten .bericht-container p {
  margin: 0.5rem 0 0 0;
}
/* Container: 3 gleich breite Spalten (auto-responsiv) */
.news-zickzack .mod_news {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)); /* gleiche Breiten */
  gap: 24px;
}

/* Grid-Items: Karte füllt Spalte vollständig */
.news-zickzack .layout_latest,
.news-zickzack .layout_short {
  width: 100%;
  box-sizing: border-box; /* Rahmen/Padding sauber einrechnen */
}

/* Falls Contao zusätzliche Wrapper erzeugt (z. B. <article>), diese als Grid-Item behandeln */
.news-zickzack .mod_news > * {
  width: 100%;
}

/* Responsive: 2 Spalten / 1 Spalte */
@media (max-width: 991px) {
  .news-zickzack .mod_news { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .news-zickzack .mod_news { grid-template-columns: 1fr; }
}
/* ===============================
   Einzelne G’schichten im Kasten
=============================== */

/* Container */
.news-zickzack {
  margin: 40px auto;
  max-width: 1140px;
  padding: 0 10px;
}

/* Jede einzelne G’schicht */
.news-zickzack .layout_latest,
.news-zickzack .layout_short {
  background-color: #fff;
  border: 2px solid #b3171b;   /* Vereinsrot als Rahmen */
  border-radius: 12px;         /* abgerundete Ecken */
  padding: 20px;
  margin-bottom: 25px;         /* Abstand zwischen den Kästen */
  box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}

/* Überschrift der G’schicht */
.news-zickzack .layout_latest h2,
.news-zickzack .layout_short h2 {
  color: #215a31;              /* Vereinsgrün */
  font-size: 1.4rem;
  margin-bottom: 10px;
  font-weight: bold;
}

/* Text/Teaser */
.news-zickzack .layout_latest p,
.news-zickzack .layout_short p {
  font-size: 1rem;
  color: #333;
  line-height: 1.5;
}

/* ========================
   Verlinkungen
=========================== */
.ce_text a,
.ce_download a {
  color: #215a31;
  font-size: 120%;
  text-decoration: none;
  padding: 5px;
}

.ce_text a:hover,
.ce_download a:hover {
  color: #fff;
  background-color: #215a31;
}

/* ========================
   Container-Layout & Artikel
=========================== */
.mod_article {
  padding: 20px 0;
  width: 100%;
  text-align: left;
}

.zwei_an,
.drei_an,
.mod_newslist,
.bericht_an,
.mod_eventlist.block {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 1130px;
  margin-top: 10px;
  width: 100%;
}

.zwei_an > div,
.drei_an > div,
.bericht_an > div {
  margin-left: auto;
  margin-right: auto;
}
/* ===============================
   STARTSEITE: INFO-CONTAINER OBEN
=============================== */
.info-container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  max-width: 1170px;
  width: 100%;
  margin: 40px auto 20px auto;
  padding: 0 15px;
}

.info-box {
  background-color: #fff;
  border: 2px solid #215a31;
  border-radius: 12px;
  padding: 20px;
  text-align: center;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

.info-box h3 {
  color: #215a31;
  font-size: 1.2rem;
  margin-bottom: 10px;
}

.info-box p {
  font-size: 0.95rem;
  margin: 0 0 15px 0;
  color: #333;
}

.info-box a.button {
  background-color: #215a31;
  color: #fff;
  padding: 8px 16px;
  border-radius: 5px;
  text-decoration: none;
  display: inline-block;
  font-size: 0.95rem;
  transition: background-color 0.3s ease;
}

.info-box a.button:hover {
  background-color: #b3171b;
}

/* ===============================
   RESPONSIV: Container-Anpassung mobil
=============================== */
@media (max-width: 991px) {
  .info-container {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .info-container {
    grid-template-columns: 1fr;
  }
}

/* ========================
   Bilder & Layout Blöcke
=========================== */
.image_container {
  max-width: 100%;
  text-align: center;
  padding: 0;
}

.block.even .image_container {
  float: left;
  padding-right: 1rem;
}

.block.odd .image_container {
  float: right;
  padding-left: 20px;
}

/* ========================
   Newslisten / Berichte
=========================== */
.mod_newslist.start .layout_latest,
.event.layout_teaser {
  background-color: #fff;
  width: 100%;
  max-width: 369px;
  margin-left: auto;
  margin-right: auto;
}

.mod_newslist.start.block .ce_text.block,
.berichte-start2 .ce_text.block,
.bericht_an .layout_latest {
  background-color: #fff;
  padding: 1rem;
}

.layout_latest h2,
.event.layout_teaser h2,
.mod_newslist.berichte-start2.block h2 {
  color: #215a31;
  padding: 5px;
  font-size: 1.2rem;
  line-height: 1.8rem;
  margin: 0;
  text-decoration: none;
}

.event.layout_teaser h2 a,
.layout_latest h2 a {
  color: #215a31;
  text-decoration: none;
}

/* ===============================
   LINKS & BUTTONS ALLGEMEIN
=============================== */
.ce_text a, .ce_download a {
	color: #215a31;
	font-size: 120%;
    text-decoration: none;
	padding: 5px;
}
.ce_text a:hover, .ce_download a:hover {
  color: #fff;
  font-size: 120%;
  text-decoration: none;
  background-color: #215a31;
  padding: 5px;
}
/* ========================
   Buttons & Links (mehr/zurück)
=========================== */
.more,
.more a,
.back,
.back a {
  background: #215a31;
  color: #fff;
  display: block;
  padding: 5px;
  margin: 0 auto;
  text-decoration: none;
  width: fit-content;
}

.more a:hover,
.back a:hover {
  background-color: #fff;
  color: #215a31;
}

.footer-icons {
  display: flex;
  gap: 20px;
  margin-top: 10px;
}

.footer-icons a {
  color: #fff;
  font-size: 1.5rem;
  text-decoration: none;
}

.footer-icons a:hover {
  color: #b3b3b3;
}

#footer2 {
  background-color: #215a31;
  color: #fff;
  font-size: 0.9rem;
  padding: 10px 0;
  margin-top: 60px;
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
}
#footer2::after {
  content: "2025 - Trachtenverein Alt Rosenheim e. V.";
  display: block;
  margin-top: 5px;
}

.mod_customnav.fuss.block {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding: 10px 0;
}

.mod_customnav.fuss.block li,
.mod_customnav.fuss.block a {
  list-style: none;
  margin: 0 5px;
  text-transform: uppercase;
  text-decoration: none;
  color: #fff;
}

nav.sozial.block {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
}

nav.sozial.block ul {
  padding: 0;
  margin: 0;
  display: flex;
  list-style: none;
}

nav.sozial.block ul li a {
  display: block;
  width: 1em;
  height: 1em;
  color: #fff;
  font-size: 250%;
  text-decoration: none;
  transition: all 0.3s ease;
}

nav.sozial.block ul li a:hover {
  background-color: #fff;
  color: #215a31;
  border-radius: 5px;
  padding: 0.2em;
}

/* ===============================
   KASTEN / BOXEN STIL
=============================== */
.beige {
  background-color: #fff;
  padding-top: 5px;
}
.um, .location {
  margin-left: 10px;
  display: inline-block;
  line-height: 1.6rem;
}
.um, .ort {
  font-weight: bold;
  display: inline-block;
  min-width: 80px;
}
.ical, .ical a {
  background: #215a31;
  color: #ffffff !important;
  display: inline-block;
  text-decoration: none;
  padding: 0 5px;
  margin-bottom: 10px;
}

/* ===============================
   RESPONSIVE – Mobil: untereinander
=============================== */

@media (max-width: 1024px) {
  .startseiten-kaestchen {
    flex: 1 1 calc(50% - 30px); /* Zwei nebeneinander */
  }
}

@media (max-width: 600px) {
  .startseiten-kaestchen {
    flex: 1 1 100%; /* Untereinander */
    max-width: 90%;
  }
}

/* ===============================
   KURSANGEBOT – KACHELLAYOUT
=============================== */
.kurs-angebot {
  padding: 60px 20px;
  background-color: #fff8e1; /* helles Beige */
}

.kurs-angebot h1 {
  text-align: center;
  color: #215a31; /* Vereinsgrün */
  font-size: 2.5rem;
  margin-bottom: 2rem;
  line-height: 1.3;
}

.kurs-kacheln {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
}

.kurs-box {
  background-color: #fff;
  border: 2px solid #215a31;
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
  text-align: center;
}

.kurs-box h3 {
  font-size: 1.2rem;
  margin-bottom: 1rem;
  color: #215a31;
}

.kurs-box p {
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
}

.kurs-box a.button {
  display: inline-block;
  background-color: #b3171b;
  color: #fff;
  padding: 8px 16px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: bold;
  transition: background-color 0.3s ease;
}

.kurs-box a.button:hover {
  background-color: #891216;
}

/* =========================
   FOOTER SICHTBAR MACHEN
========================= */
#footer2 {
  background-color: #215a31;
  color: #fff;
  font-size: 0.9rem;
  padding: 20px 0;
  margin-top: 60px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  position: relative;
  z-index: 10;
}

#footer2::after {
  content: "© 2025 – Trachtenverein Alt Rosenheim e. V.";
  display: block;
  margin-top: 10px;
  font-size: 0.85rem;
  line-height: 1.4;
}

.mod_customnav.fuss.block {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding: 10px 0;
  margin: 0;
}

.mod_customnav.fuss.block li {
  list-style: none;
}

.mod_customnav.fuss.block li a {
  margin: 0 5px;
  text-transform: uppercase;
  text-decoration: none;
  color: #fff;
}

.mod_customnav.fuss.block li a:hover {
  color: #215a31;
  background-color: #fff;
}

.footer-icons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-top: 10px;
  padding: 0;
  list-style: none;
}

.footer-icons li {
  list-style: none;
}

.footer-icons a {
  color: #fff !important;
  font-size: 1.5rem;
  text-decoration: none;
  transition: color 0.3s ease;
}

.footer-icons a:hover {
  color: #b3b3b3;
}

/* =========================
   RESPONSIVE: TABLET
========================= */
@media (max-width: 991px) {
  .infobox {
    flex: 1 1 45%;
    max-width: 48%;
  }

  .kurs-kacheln {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
}

/* =========================
   RESPONSIVE: SMARTPHONES
========================= */
@media (max-width: 600px) {
  .infoboxen {
    flex-direction: column;
    align-items: center;
  }

  .infobox {
    max-width: 90%;
    width: 100%;
  }

  .hero-overlay {
    padding: 60px 20px;
  }

  .hero-overlay h1 {
    font-size: 1.4rem;
  }

  .hero-overlay a.hero-button {
    padding: 6px 12px;
    font-size: 0.9rem;
  }

  .kurs-angebot h1 {
    font-size: 1.6rem;
    line-height: 1.3;
    padding: 0 10px;
  }

  .kurs-kacheln {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }

  .kurs-box {
    padding: 16px;
  }

  .kurs-box h2 {
    font-size: 1.3rem;
  }

  .kurs-box p {
    font-size: 0.95rem;
  }
}

/* =========================
   RESPONSIVE: KLEINE GERÄTE
========================= */
@media (max-width: 400px) {
  .infoboxen {
    gap: 16px;
  }

  .hero-overlay {
    padding: 30px 15px;
  }

  .hero-overlay h1 {
    font-size: 1.2rem;
  }

  .hero-overlay a.hero-button {
    font-size: 0.85rem;
  }

  .kurs-angebot h1 {
    font-size: 1.4rem;
  }

  .kurs-box h2 {
    font-size: 1.2rem;
  }

  .kurs-box p {
    font-size: 0.9rem;
  }
}

/* =========================
   RESPONSIVE: TABLET
========================= */
@media (max-width: 991px) {
  .infobox {
    flex: 1 1 45%;
    max-width: 48%;
  }

  .kurs-kacheln {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
}

/* =========================
   RESPONSIVE: SMARTPHONES
========================= */
@media (max-width: 600px) {
  .infoboxen {
    flex-direction: column;
    align-items: center;
  }

  .infobox {
    max-width: 90%;
    width: 100%;
  }

  .hero-overlay {
    padding: 40px 20px;
  }

  .hero-overlay h1 {
    font-size: 1.4rem;
  }

  .hero-overlay a.hero-button {
    padding: 6px 12px;
    font-size: 0.9rem;
  }

  .kurs-angebot h1 {
    font-size: 1.6rem;
    line-height: 1.3;
    padding: 0 10px;
  }

  .kurs-kacheln {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }

  .kurs-box {
    padding: 16px;
  }

  .kurs-box h2 {
    font-size: 1.3rem;
  }

  .kurs-box p {
    font-size: 0.95rem;
  }
}

/* =========================
   RESPONSIVE: KLEINE GERÄTE
========================= */
@media (max-width: 400px) {
  .infoboxen {
    gap: -500px;
  }

  .hero-overlay {
    padding: 150px 15px;
  }

  .hero-overlay h1 {
    font-size: 1.2rem;
  }

  .hero-overlay a.hero-button {
    font-size: 0.85rem;
  }

  .kurs-angebot h1 {
    font-size: 1.4rem;
  }

  .kurs-box h2 {
    font-size: 1.2rem;
  }

  .kurs-box p {
    font-size: 0.9rem;
  }
}
.kurs-grid{
  max-width:1140px;margin:24px auto 36px;padding:0 10px;
  display:grid;gap:20px;grid-template-columns:repeat(4,minmax(0,1fr));
}
.kurs-card{
  background:#fff;border:2px solid #b3171b;border-radius:12px;
  box-shadow:0 4px 8px rgba(0,0,0,.05);
  padding:18px;display:flex;flex-direction:column;gap:10px;min-height:320px;
}
.kurs-card-head{display:flex;align-items:center;gap:10px}
.kurs-card h3{color:#215a31;margin:0}
.kurs-icon{width:36px;height:36px}
.kurs-meta{margin:0;padding-left:18px}
.kurs-meta li{margin-bottom:4px}
.kurs-cta{margin-top:auto;display:flex;justify-content:flex-start}
.button{display:inline-block;background:#215a31;color:#fff;padding:8px 14px;border-radius:6px;text-decoration:none;font-weight:600;transition:.2s}
.button:hover{background:#b3171b}
.button-outline{background:transparent;color:#215a31;border:2px solid #215a31}
.button-outline:hover{background:#215a31;color:#fff}
.kurs-termlink{text-align:center;margin:10px 0 30px}

/* Responsiv: 2x2 auf Tablet, 1x4 auf Handy */
@media (max-width: 991px){
  .kurs-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 600px){
  .kurs-grid{grid-template-columns:1fr}
}
/********************************************************
BERICHTE = Gschichtn-Skin (pixelgleich)
- 3/4 Berichte (links), 1/4 Archiv-Menü (rechts, sticky)
- Kachelrahmen, Schatten, Hover, 4:3-Bilder, runder Button
********************************************************/

/* Farben wie Startseite */
:root{
  --verein-gruen:#215a31;
  --verein-rot:#b3171b;
  --bg-beige:#feecc4;
  --text:#333;
  --card-bg:#fff;
  --card-brd:rgba(0,0,0,.06);
  --shadow:0 10px 22px rgba(0,0,0,.07);
  --shadow-hover:0 14px 28px rgba(0,0,0,.09);
  --r-xl:20px;       /* Kartenradius */
  --r-lg:16px;       /* Bildradius */
  --pill:999px;
}
body{ background:var(--bg-beige); color:var(--text); }

/* ===== Layout 3/4 – 1/4 ===== */
.bericht_an{
  display:grid;
  grid-template-columns: 3fr 1fr; /* 3/4 : 1/4 */
  gap:24px;
  align-items:start;
}

/* Absicherung gegen Theme-Floats/Breiten */
#module-106,#mod106,
#module-108,#mod108{
  float:none !important; width:auto !important; clear:none !important; margin:0;
}
#module-106,#mod106{ grid-column:1; }
#module-108,#mod108{ grid-column:2; }

/* ===== Archiv-Menü rechts (wie gewünscht) ===== */
.archive-menu{
  position:sticky; top:20px;
  background:var(--verein-gruen); color:#fff;
  border-radius:14px; padding:18px; box-shadow:0 8px 18px rgba(0,0,0,.08);
}
.archive-menu h2{ color:#fff; margin:0 0 10px; font-weight:700; }
.archive-menu ul,.archive-menu li{ list-style:none; margin:0; padding:0; }
.archive-menu > ul > li{ border-bottom:1px solid rgba(255,255,255,.18); padding:8px 0; }
.archive-menu > ul > li:last-child{ border-bottom:none; }
.archive-menu a{ color:#fff; text-decoration:none; display:inline-block; padding:2px 0; transition:opacity .2s,transform .1s; }
.archive-menu a:hover{ opacity:.9; transform:translateX(2px); text-decoration:underline; }
.archive-menu .active > a{ font-weight:700; text-decoration:underline; }

/* =========================================================
   1:1 Gschichten-Optik auf Berichte „mappen“
   - Wir stylen die standardmäßigen Contao-News-Teaser so,
     wie die Startseiten-Gschichtn-Kacheln aussehen.
   - Falls deine Startseite eigene Klassen hat (z.B. .gschichten-card),
     füge sie einfach in die Gruppen unten hinzu.
========================================================= */

/* Kachel */
.gschichten-skin .news,
.mod_newslist.gschichten-skin .news{
  display:grid;
  grid-template-columns: 260px 1fr;   /* Bild links, Inhalt rechts */
  gap:18px;
  align-items:start;
 background-color: #fff;
  border: 2px solid #b3171b;   /* Vereinsrot als Rahmen */
  border-radius: 12px;         /* abgerundete Ecken */
  padding: 20px;
  margin-bottom: 25px;         /* Abstand zwischen den Kästen */
  box-shadow: 0 4px 8px rgba(0,0,0,0.05);
  padding:18px;
  margin:0 0 18px 0;
  transition:transform .15s ease, box-shadow .2s ease;
}
.gschichten-skin .news:hover{ transform:translateY(-2px); box-shadow:var(--shadow-hover); }

/* Bildcontainer (ruhig, 4:3 – wie Startseite) */
.gschichten-skin .news .image_container,
.gschichten-skin .news figure{
  margin:0; border-radius:var(--r-lg); overflow:hidden; background:#f3f3f3;
  aspect-ratio: 4 / 3;
}

.gschichten-skin .news .image_container img,
.gschichten-skin .news figure img{
  width:100%; height:100%; object-fit:cover; display:block;
}

/* Titel, Meta, Teaser */
.gschichten-skin .news h2{
  margin:0 0 6px; font-size:1.25rem; line-height:1.2; color:var(--text);
}
.gschichten-skin .news .info{
  font-size:.9rem; color:#666; margin:0 0 10px;
  display:flex; gap:10px; flex-wrap:wrap;
}
.gschichten-skin .news .teaser,
.gschichten-skin .news p{ margin:0 0 12px; }

/* „Weiterlesen“-Button (rot, rund) */
.gschichten-skin .news a.more,
.gschichten-skin .news .read-more a{
  display:inline-block; background:var(--verein-rot);
  color:#fff !important; text-decoration:none; font-weight:700;
  padding:10px 16px; border-radius:var(--pill);
  box-shadow:0 8px 18px rgba(179,23,27,.28);
  transition:transform .12s, filter .2s, box-shadow .2s;
}
.gschichten-skin .news a.more:hover,
.gschichten-skin .news .read-more a:hover{
  transform:translateY(-1px); filter:brightness(1.05);
  box-shadow:0 10px 22px rgba(179,23,27,.32);
}

/* Paginierung passend einfärben */
.gschichten-skin .pagination{
  display:flex; gap:8px; flex-wrap:wrap; margin-top:18px;
}
.gschichten-skin .pagination a,
.gschichten-skin .pagination strong{
  padding:8px 12px; border-radius:var(--pill);
  background:#fff; border:1px solid rgba(0,0,0,.08);
  text-decoration:none; color:var(--text);
}
.gschichten-skin .pagination strong,
.gschichten-skin .pagination a:hover{
  background:var(--verein-gruen); color:#fff; border-color:var(--verein-gruen);
}

/* ===== Responsive ===== */
@media (max-width:1100px){
  .bericht_an{ grid-template-columns: 1fr 320px; }
}
@media (max-width:991px){
  .bericht_an{ grid-template-columns: 1fr; }
  #module-106{ grid-column:1; grid-row:1; }
  #module-108{ grid-column:1; grid-row:2; position:static; }
  .gschichten-skin .news{ grid-template-columns: 1fr; } /* Bild oben */
  .gschichten-skin .news .image_container,
  .gschichten-skin .news figure{ aspect-ratio: 16 / 9; }
}
/* =========================================
   FIX: Hero-Schriftzug ohne Bild-Verschiebung
   (wir ändern NUR .hero-overlay)
========================================= */
:root{
  /* ggf. anpassen, das sind nur Startwerte */
  --nav-h-mobile: -190px;
  --nav-h-tablet: -250px;
  --overlay-offset: 8px; /* kleiner Zusatzabstand unter der Navi */
}

/* Basis: absolut über dem Bild, verschiebt nichts im Layout */
.hero-overlay{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;                /* über dem Bild, unter dem geöffneten Menü ok */
}

/* Handy */
@media (max-width: 600px){
  .hero-overlay{
    /* statt -15% verwenden wir einen festen Abstand zur Navihöhe */
    top: calc(var(--nav-h-mobile) + var(--overlay-offset)) !important;
    padding: 14px 16px;      /* kompakt, damit nichts raussteht */
  }
}

/* Tablet */
@media (min-width: 601px) and (max-width: 991px){
  .hero-overlay{
    top: calc(var(--nav-h-tablet) + var(--overlay-offset)) !important;
    padding: 18px 22px;
  }
}

/* Desktop (optional dezenter Offset) */
@media (min-width: 992px){
  .hero-overlay{
    top: -316px !important;    /* kein Prozentwert -> Bild bleibt unverändert */
    padding: 20px 30px;
  }
}

/* Falls dein Burger-Button drüberliegen muss, gib ihm höheren z-index */
@media (max-width: 991px){
  .mobile-menu-toggle,
  .nav-toggle,
  .hamburger{
    position: relative;
    z-index: 10;
  }
}
/* ===== Abstand Bild unter der Menüleiste ===== */
.mod_pageimage.block {
  margin-top: 80px;   /* Abstand in Pixel – anpassen bis es passt */
}
/* Handy */
@media (max-width: 600px){
  .mod_pageimage.block {
    margin-top: 100px; /* Menü ist oft höher mobil */
  }
}

/* Tablet */
@media (min-width: 601px) and (max-width: 991px){
  .mod_pageimage.block {
    margin-top: 120px;
  }
}
/*****************************************************
  BERICHETE-SEITE • Layout, Farben & Bild-Optik
  Ziel:
  - Navigation (Jahre/Monate) rechts als Sidebar
  - Farben wie Startseite (Grün/Rot/Beige)
  - Bilder einheitlich & responsive (16:9, cover)
  - Mobile wieder untereinander
*****************************************************/

/* === Farb-Variablen (wie Startseite) ================= */
:root {
  --verein-gruen: #215a31;   /* Homepage-Grün für Navigation */
  --verein-rot:   #b3171b;   /* Buttons/Akzente */
  --bg-beige:     #feecc4;   /* Seitenhintergrund */
  --text:         #333333;
}

/* === Seite "Berichte" scopen =========================
   Tipp: Falls ihr der Seite im Contao-Layout die Body-Klasse
   "page-berichte" gegeben habt, greifen die Regeln perfekt.
   Ohne Klasse wirken viele Regeln auch so, sind aber bewusst
   auf News-Module eingegrenzt. */
body.page-berichte,
body {
  /* keine generelle Änderung hier; dient nur als Scope */
}

/* === Grundlayout: Content links, Navigation rechts =====
   Wir arbeiten ohne HTML-Änderung:
   - Navigation (.mod_newsmenu) wird rechts "angedockt"
   - News-Liste bekommt rechts Platz (margin-right) */
#main .mod_newsmenu {
  float: right;
  width: 320px;                 /* Sidebar-Breite */
  max-width: 100%;
  margin-left: 24px;
}

/* Content-Spalte bekommt Platz rechts für die Sidebar */
#main .mod_newslist,
#main .mod_newsarchive,
#main .mod_article .news-list {
  margin-right: 344px;          /* 320 + 24 Abstand */
}

/* === Mobile: untereinander ============================ */
@media (max-width: 991px) {
  #main .mod_newsmenu {
    float: none;
    width: 100%;
    margin: 0 0 20px 0;
  }
  #main .mod_newslist,
  #main .mod_newsarchive,
  #main .mod_article .news-list {
    margin-right: 0;
  }
}

/* === Navigation (Jahre/Monate) optisch aufwerten ====== */
#main .mod_newsmenu {
  background: var(--verein-gruen);
  color: #ffffff;
  border-radius: 14px;
  padding: 18px;
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
  position: sticky;
  top: 20px;                    /* bleibt beim Scrollen sichtbar */
}

/* Überschrift der Navigation (falls vorhanden) */
#main .mod_newsmenu h2,
#main .mod_newsmenu .headline,
#main .mod_newsmenu .widget-label {
  color: #ffffff;
  font-weight: 700;
  margin: 0 0 10px 0;
}

/* Jahres-/Monatslisten in Contao (.level_1/.level_2 etc.) */
#main .mod_newsmenu ul,
#main .mod_newsmenu li {
  list-style: none;
  margin: 0;
  padding: 0;
}

#main .mod_newsmenu ul > li {
  border-bottom: 1px solid rgba(255,255,255,.18);
  padding: 8px 0;
}

#main .mod_newsmenu ul > li:last-child {
  border-bottom: none;
}

/* Links in der Navigation */
#main .mod_newsmenu a {
  color: #ffffff;
  text-decoration: none;
  display: inline-block;
  padding: 2px 0;
  transition: opacity .2s ease, transform .1s ease;
}

#main .mod_newsmenu a:hover,
#main .mod_newsmenu a:focus {
  opacity: .9;
  transform: translateX(2px);
  text-decoration: underline;
}

/* Aktiver Monat/Jahr (Contao gibt oft .active o.ä. Klassen aus) */
#main .mod_newsmenu li.active > a,
#main .mod_newsmenu a.active {
  font-weight: 700;
  text-decoration: underline;
}

/* === News-Listen-Optik (Karten) ======================= */
#main .mod_newslist .news,
#main .mod_newsarchive .news,
#main .news-list .news {
  display: grid;
  grid-template-columns: 240px 1fr;   /* Bild links, Text rechts */
  gap: 16px;
  align-items: start;
  background: #ffffff;
  border-radius: 18px;
  padding: 16px;
  margin: 0 0 16px 0;
  box-shadow: 0 6px 14px rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.05);
}

@media (max-width: 700px) {
  #main .mod_newslist .news,
  #main .mod_newsarchive .news,
  #main .news-list .news {
    grid-template-columns: 1fr; /* mobil: Bild oben */
  }
}

/* === Bild-Container angleichen ======================== 
   Contao nutzt oft .image_container um Bilder zu umschließen */
#main .mod_newslist .news .image_container,
#main .mod_newsarchive .news .image_container,
#main .news-list .news .image_container {
  width: 100%;
  border-radius: 14px;
  overflow: hidden;
  background: #f3f3f3;
  /* feste Höhe proportional zur Breite via aspect-ratio */
  aspect-ratio: 16 / 9;
}

/* Bilder sauber beschneiden, einheitliche Höhe */
#main .mod_newslist .news .image_container img,
#main .mod_newsarchive .news .image_container img,
#main .news-list .news .image_container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Falls Eure Liste statt .image_container ein <figure> nutzt: */
#main .mod_newslist .news figure,
#main .mod_newsarchive .news figure,
#main .news-list .news figure {
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  background: #f3f3f3;
  aspect-ratio: 16 / 9;
}

/* === Textspalte, Überschrift, Meta ==================== */
#main .mod_newslist .news h2,
#main .mod_newsarchive .news h2,
#main .news-list .news h2 {
  margin: 0 0 6px 0;
  line-height: 1.25;
  font-size: 1.25rem;
  color: var(--text);
}

#main .mod_newslist .news .info,
#main .mod_newsarchive .news .info,
#main .news-list .news .info {
  font-size: .9rem;
  color: #666;
  margin-bottom: 8px;
}

/* Teasertext */
#main .mod_newslist .news .teaser,
#main .mod_newsarchive .news .teaser,
#main .news-list .news .teaser,
#main .mod_newslist .news p,
#main .mod_newsarchive .news p {
  margin: 0 0 10px 0;
}

/* === "Weiterlesen" Button einheitlich ================= */
#main .mod_newslist .news a.more,
#main .mod_newsarchive .news a.more,
#main .news-list .news a.more,
#main .mod_newslist .news .read-more a,
#main .mod_newsarchive .news .read-more a {
  display: inline-block;
  background: var(--verein-rot);     /* Rot wie Startseite */
  color: #fff;
  border-radius: 999px;
  padding: 10px 16px;
  font-weight: 700;
  text-decoration: none;
  transition: transform .12s ease, filter .2s ease, box-shadow .2s ease;
  box-shadow: 0 6px 14px rgba(179, 23, 27, .25);
}

#main .mod_newslist .news a.more:hover,
#main .mod_newsarchive .news a.more:hover,
#main .news-list .news a.more:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

/* Falls die Buttons als .btn o.ä. kommen, angleichen: */
#main .mod_newslist .news .btn,
#main .mod_newsarchive .news .btn {
  background: var(--verein-rot) !important;
  color: #fff !important;
  border-radius: 999px !important;
}

/* === Abstand der Liste zum Seitenhintergrund ========== */
body {
  background-color: var(--bg-beige); /* wie Startseite */
}

/* === Feinschliff für Listen-Abstände ================== */
#main .mod_newslist,
#main .mod_newsarchive {
  /* sorgt für optische Luft */
  gap: 16px;
}

/* === Optional: Paginierung (falls vorhanden) ========== */
#main .pagination,
#main .mod_newslist .pagination,
#main .mod_newsarchive .pagination {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 18px;
}

#main .pagination a,
#main .pagination strong {
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  text-decoration: none;
  color: var(--text);
}

#main .pagination strong,
#main .pagination a:hover {
  background: var(--verein-gruen);
  color: #fff;
  border-color: var(--verein-gruen);
}

/********************************************************
 BERICHTE 3/4 : 1/4 LAYOUT
 - .bericht_an enthält:
   #module-106  → Nachrichtenliste (Berichte)
   #module-108  → Nachrichtenarchiv-Menü (rechts)
*********************************************************/

/* Container als Zweispalter */
.bericht_an {
  display: flex;
  align-items: flex-start;
  gap: 24px;
}

/* Reihenfolge absichern: Liste links, Menü rechts */
#module-106, #mod106 { order: 1; }
#module-108, #mod108 { order: 2; }

/* 3/4 : 1/4 Aufteilung */
#module-106, #mod106 {
  flex: 0 1 75%;
  min-width: 0;     /* verhindert Überlaufen bei langen Überschriften */
}
#module-108, #mod108 {
  flex: 0 1 25%;
  max-width: 420px; /* optischer Rahmen, optional */
}

/* Menü optisch (wie zuvor) + sticky */
#module-108, #mod108 {
  position: sticky;
  top: 20px;
  background: #215a31;  /* Vereinsgrün */
  color: #fff;
  border-radius: 14px;
  padding: 18px;
  box-shadow: 0 8px 18px rgba(0,0,0,.08);
}

/* Sidebar-Typo & Liste */
#module-108 h2, #mod108 h2 { color: #fff; margin: 0 0 10px; font-weight: 700; }
#module-108 ul, #mod108 ul,
#module-108 li, #mod108 li { list-style: none; margin: 0; padding: 0; }
#module-108 > ul > li, #mod108 > ul > li { border-bottom: 1px solid rgba(255,255,255,.18); padding: 8px 0; }
#module-108 > ul > li:last-child, #mod108 > ul > li:last-child { border-bottom: none; }
#module-108 a, #mod108 a { color:#fff; text-decoration:none; display:inline-block; padding:2px 0; transition:opacity .2s, transform .1s; }
#module-108 a:hover, #mod108 a:hover { opacity:.9; transform:translateX(2px); text-decoration:underline; }

/* Karten-Layout & Bildangleichung der Berichte */
#module-106 .news, #mod106 .news {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 16px;
  align-items: start;
  background: #fff;
  border-radius: 18px;
  padding: 16px;
  margin: 0 0 16px 0;
  box-shadow: 0 6px 14px rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.05);
}
#module-106 .news .image_container,
#module-106 .news figure,
#mod106 .news .image_container,
#mod106 .news figure {
  margin: 0; border-radius: 14px; overflow: hidden; background:#f3f3f3;
  aspect-ratio: 16 / 9;
}
#module-106 .news .image_container img,
#module-106 .news figure img,
#mod106 .news .image_container img,
#mod106 .news figure img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* Buttons (Weiterlesen) in Vereinsrot */
#module-106 .news a.more,
#mod106 .news a.more,
#module-106 .news .read-more a,
#mod106 .news .read-more a {
  display: inline-block;
  background: #b3171b; /* Vereinsrot */
  color: #fff; border-radius: 999px; padding: 10px 16px; font-weight: 700;
  text-decoration: none; box-shadow: 0 6px 14px rgba(179,23,27,.25);
  transition: transform .12s, filter .2s;
}
#module-106 .news a.more:hover,
#mod106 .news a.more:hover { transform: translateY(-1px); filter: brightness(1.05); }

/* ====== RESPONSIVE ======
   Auf Mobil (<= 991px): untereinander,
   Menü nach unten (unter den Berichten) und sticky aus. */
@media (max-width: 991px) {
  .bericht_an {
    flex-direction: column;
  }
  /* Reihenfolge: erst Berichte, dann Menü */
  #module-106, #mod106 { order: 1; flex: 1 1 auto; }
  #module-108, #mod108 { order: 2; flex: 1 1 auto; max-width: 100%; position: static; }
  /* Karten: Bild oben */
  #module-106 .news, #mod106 .news { grid-template-columns: 1fr; }
}

