/* Auto-generated: 2025-11-21T08:51:57+00:00 (UTC) */

/* ---- Source: accessibility-switcher.css ---- */
/* Accessibility Switcher Styles */
.accessibility-switcher {
	position: fixed;
	top: 25px;
	right: 50px;
	z-index: 9999;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.accessibility-toggle {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: #000;
	color: white;
	border: none;
	cursor: pointer;
	box-shadow: 0 2px 10px rgba(0,0,0,0.2);
	transition: all 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
}

.accessibility-toggle:hover,
.accessibility-toggle:focus {
	background: #222;
	transform: scale(1.1);
}

.accessibility-panel {
	position: absolute;
	top: 60px;
	right: 0;
	width: 320px;
	background: white;
	border-radius: 8px;
	box-shadow: 0 4px 20px rgba(0,0,0,0.15);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: all 0.3s ease;
	border: 1px solid #ddd;
}

.accessibility-panel.active {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.accessibility-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 15px 20px;
	border-bottom: 1px solid #eee;
	background: #f8f9fa;
	border-radius: 8px 8px 0 0;
}

.accessibility-header h3 {
	margin: 0;
	font-size: 16px;
	color: #333;
}

.accessibility-close {
	background: none;
	border: none;
	font-size: 24px;
	cursor: pointer;
	color: #666;
	padding: 0;
	width: 30px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.accessibility-options {
	padding: 20px;
	max-height: 400px;
	overflow-y: auto;
}

.accessibility-group {
	margin-bottom: 20px;
}

.accessibility-group:last-child {
	margin-bottom: 0;
}

.accessibility-group h4 {
	margin: 0 0 10px 0;
	font-size: 14px;
	color: #333;
	font-weight: 600;
}

.accessibility-buttons {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.accessibility-btn {
	padding: 8px 12px;
	border: 1px solid #ddd;
	background: white;
	border-radius: 4px;
	cursor: pointer;
	font-size: 12px;
	transition: all 0.2s ease;
	color: #333;
}

.accessibility-btn:hover,
.accessibility-btn:focus {
	background: #f0f0f0;
	border-color: #0073aa;
}

.accessibility-btn.active {
	background: #0073aa;
	color: white;
	border-color: #0073aa;
}

.accessibility-reset {
	width: 100%;
	background: #dc3545 !important;
	color: white !important;
	border-color: #dc3545 !important;
}

.accessibility-reset:hover {
	background: #c82333 !important;
}

.accessibility-toggles {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.accessibility-toggle-item {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-size: 14px;
}

.accessibility-toggle-item input {
	margin: 0;
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

/* Accessibility Classes */
body.font-small { font-size: 14px !important; }
body.font-normal { font-size: 16px !important; }
body.font-large { font-size: 18px !important; }
body.font-xlarge { font-size: 22px !important; }

body.contrast-high {
	filter: contrast(150%) !important;
}

body.contrast-invert {
	filter: invert(1) hue-rotate(180deg) !important;
}

body.underline-links a {
	text-decoration: underline !important;
}

body.highlight-focus *:focus {
	outline: 3px solid #ff6b35 !important;
	outline-offset: 2px !important;
}

body.disable-animations *,
body.disable-animations *:before,
body.disable-animations *:after {
	animation-duration: 0.01ms !important;
	animation-iteration-count: 1 !important;
	transition-duration: 0.01ms !important;
}

body.reading-guide {
	position: relative;
}

body.reading-guide:before {
	content: "";
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: #ff6b35;
	z-index: 10000;
	pointer-events: none;
}

.contrast-high #menu-footer-menue li a, .contrast-high #menu-footer-menue li:first-child a {
	color: #fff !important;
}

@media (max-width: 1024px) {
	.accessibility-switcher {
		top: 25px;
		right: 100px;
	}

	.accessibility-toggle {
		width: 45px;
		height: 45px;
	}

	.accessibility-panel {
		width: 280px;
		top: 55px;
	}
}


/* ---- Source: custom.css ---- */
#content .wp-block-group {
	padding-top:2rem;
}
@media (max-width: 1024px) {
	#content .wp-block-group .wp-block-columns.alignwide {
		padding:2rem;
	}

	#content .wp-block-group h2 {
		padding:0 2rem;
	}
	#content .primary-menu > li > a {
		color: #000;
	}
	#content .wp-block-columns .wp-block-image img {
			aspect-ratio: 3 / 4;
			object-fit: cover;
			width: 100% !important;
			height: auto;
	}
}
.wp-block-columns {
    margin-bottom: 2em;
	}

/*.primary-menu > li > a:hover {border: 1px solid var(--primary-color);}*/

.after-footer-container {
  background-color: var(--footer-bg-color);
}

.relative {
  position: relative;
}

.green-box div,
.green-box .has-text-color {
  color: #fff !important;
}

/*** Top Menu ***/
.top-menu {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  flex-wrap: nowrap;           /* typo "flew-wrap" korrigiert */
  align-items: center;
  gap: 10px;
}
.top-menu span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  line-height: 1.2;
  border-radius: 6px;
  background: rgba(30,144,255,.10);
}
.top-menu span a {
  font-size: .85rem;
  text-decoration: none;
  color: inherit;
}
.top-menu span a:hover {
  text-decoration: none;
}

/*** Responsive Layout ***/
@media (max-width:640px) {
  .posts-grid-container {
    display: grid;
    grid-template-columns: repeat(1, 1fr) !important;
    gap: 20px;
  }
  .after-footer-right {
    display: inline-block;
  }
  .footer-widget-second,
  .footer-widget-third {
    width: 50%;
  }
  .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
    flex-basis: unset !important;
  }
}

@media (max-width: 768px) {
  .site-branding.logo-position-left {
    width: unset !important;
  }
  .content-area {
    background-color: #fff;
    padding: 0em;
  }
  .yellow-box,
  .green-box {
    padding: .5em;
  }
  .site-branding img {
    width: 150px;
    margin-top: 20px;
  }
}

/*** Typography ***/
html {
  font-size: clamp(1.125rem, 1.5vw, 1.3rem) !important;
  word-break: normal;
  hyphens: auto;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-kerning: normal;
  font-variant-ligatures: common-ligatures;
}
body {
  font-family: 'Overpass', sans-serif;
  font-size: 1em;
  line-height: 1.6;
  color: #111;
}
h1 {
  font-size: 2.5em;
  line-height: 1.2;
  letter-spacing: -.035em;
}
@media (min-width: 1024px) {
  h1,
  h2,
  h3 {
    hyphens: none !important;
    word-break: normal;
    overflow-wrap: normal;
    white-space: normal;
  }
}
h2 {
  font-size: 1.85em !important;
  line-height: 1.25;
	margin-top:3em !important;
}
h3 {
  font-size: 1.5em !important;
  line-height: 1.3;
}
h4 {
  font-size: 1.3em !important;
  line-height: 1.35;
}
h5 {
  font-size: 1.1em !important;
  line-height: 1.4;
}
h6 {
  font-size: 1.0em !important;
  line-height: 1.45;
}
h3 {
  hyphens: auto;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  overflow-wrap: break-word;
  word-break: normal;
}
p,
li,
blockquote,
.wp-block-file,
.wp-block-file a {
  font-size: 1em !important;
}
p {
  hyphens: auto;
  word-break: normal;
  overflow-wrap: break-word;
  text-wrap: pretty;
}
small {
  font-size: 0.85em;
}

/*** Read more Button + Buttons ***/
:root {
  --bar-h: 6px;
  --bar-anim: 400ms ease;
  --bar-yellow: #ffeb00;
  --bar-img: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='6' viewBox='0 0 120 6'%3E%3Crect width='12' height='6' x='0' fill='%23004892'/%3E%3Crect width='18' height='6' x='12' fill='%23e4007d'/%3E%3Crect width='18' height='6' x='30' fill='%23ed7c00'/%3E%3Crect width='24' height='6' x='48' fill='%23009440'/%3E%3Crect width='48' height='6' x='72' fill='%23ffeb00'/%3E%3C/svg%3E");
}
.content-area a,
.entry-content a {
  text-decoration: none;
  position: relative;
  transition: color .2s ease;
}
.content-area a::after,
.entry-content a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.05em;
  width: 100%;
  height: 2px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}
.content-area a:hover::after,
.content-area a:focus::after,
.entry-content a:hover::after,
.entry-content a:focus::after {
  transform: scaleX(1);
}
/*a.read-more-link,*/
a.wp-block-button__link,
p.wp-block-button__link a,
div.posts-grid-more-news a.more-news-link {
  position: relative;
  display: inline-block;
  text-decoration: none;
  padding-bottom: calc(var(--bar-h) + 10px);
}
/* Unterbalken */
/*a.read-more-link::after,*/
a.wp-block-button__link::after,
p.wp-block-button__link a::after,
div.posts-grid-more-news a.more-news-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--bar-h);
  background: var(--bar-img) no-repeat 0 100% / cover;
  transition: opacity var(--bar-anim);
}
/* gelber Overlay-Balken */
/*a.read-more-link::before,*/
a.wp-block-button__link::before,
p.wp-block-button__link a::before,
div.posts-grid-more-news a.more-news-link::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--bar-h);
  background: var(--bar-yellow);
  opacity: 0;
  transition: opacity var(--bar-anim);
  pointer-events: none;
}
/* Hover / Fokus */
/*a.read-more-link:hover::before,*/
a.wp-block-button__link:hover::before,
p.wp-block-button__link a:hover::before,
div.posts-grid-more-news a.more-news-link:hover::before,
a.wp-block-file__button:hover::before {
  opacity: 1;
}
/*a.read-more-link:hover::after,*/
a.wp-block-button__link:hover::after,
p.wp-block-button__link a:hover::after,
div.posts-grid-more-news a.more-news-link:hover::after {
  opacity: .2;
}
@media (prefers-reduced-motion: reduce) {
  /*a.read-more-link::before,
  a.read-more-link::after,*/
  p.wp-block-button__link a::before,
  p.wp-block-button__link a::after,
  a.wp-block-button__link::before,
  a.wp-block-button__link::after,
  div.posts-grid-more-news a.more-news-link::before,
  div.posts-grid-more-news a.more-news-link::after,
  a.wp-block-file__button::before,
  a.wp-block-file__button::after {
    transition: none;
  }
}

/*** Insta Feed ***/
#sbi_load {
  display: none;
}

/*** Hero Image ***/
.hero-image {
  height: 80vh;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}

/*** Blocks ***/
.posts-grid-block {
  margin: 3em 0;
  font-size: 0.9em;
}
.posts-grid-block .post-item-image {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  margin: 1.5em 0;
}
.posts-grid-block .post-item-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.posts-grid-block {
  display: grid;
  align-items: stretch;
}
.posts-grid-block h3 {
  min-height: 3.9em;
}

/*** Partner Slider ***/
.green-box {
  overflow: visible;
}

/*** Layout fixings ***/
.blog .entry-meta,
.archive .entry-meta,
.home .entry-meta,
.posts-grid .entry-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 .6rem;
  font-size: .95em;
  line-height: 1.4;
}
.entry-meta .posted-on,
.entry-meta .byline,
.entry-meta .comments-link {
  display: inline-flex;
}
.entry-meta .byline::before {
  content: "von ";
}
.entry-meta .comments-link::before {
  content: " · ";
}
.entry-meta .byline[data-has-text="true"]::before {
  content: "";
}
.entry-meta .comments-link[data-has-sep="true"]::before {
  content: "";
}
.blog .entry-title,
.archive .entry-title,
.home .entry-title,
.posts-grid .entry-title {
  margin-bottom: .35rem;
}
ul.entry-meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0 .6rem;
}
ul.entry-meta li.byline::before {
  content: "von ";
}
ul.entry-meta li.comments-link::before {
  content: " · ";
}
.entry-content :where(.wp-block-image,
                      .wp-block-gallery,
                      .wp-block-video,
                      .wp-block-embed,
                      .wp-block-cover,
                      .wp-block-media-text,
                      figure) + * {
  margin-top: clamp(0.8rem, 1.8vw, 1.2rem);
}
.page-featured-image,
.post-thumbnail {
  margin-bottom: clamp(1rem, 3vw, 2rem);
}
.entry-content > .page-featured-image,
.entry-content > figure.page-featured-image {
  margin-bottom: clamp(1rem, 3vw, 2rem);
}
.site-content .page-featured-image + .entry-content,
.layout-wrapper .page-featured-image + .entry-content {
  margin-top: clamp(0.8rem, 2vw, 1.5rem);
}

/*** Main Navigation ***/

/* Abstand der Menü-Lis auf Desktop */
@media screen and (min-width: 769px) {
  .main-navigation li {
    margin-right: 3em;
  }
}

/* Layout-Offsets für Inhalt */
body.page .site-content .layout-wrapper {
  margin-top: 10vh;
}
body.home .site-content .layout-wrapper {
  margin-top: 0;
}

/* MOBILE NAVI */
@media (max-width: 1024px) {
  .responsive-nav .primary-menu {
    display: block;
  }

  .nav-panel .menu-item-has-children {
    position: relative;
  }
  .nav-panel .menu-item-has-children > a {
    padding-right: 2.5rem; /* ggf. an dein Layout anpassen */
  }
  .nav-panel .submenu-toggle {
    position: absolute;
    right: 1rem;
    top: 0.9rem;
    transform: none;
    background: none;
    border: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;
    font: inherit;
    line-height: 1;
    width: 2rem;
    border-left: 1px solid #FFF;
    border-radius: 0;
  }
  .nav-panel .menu-item-has-children > .sub-menu {
    display: none !important;
  }
  .nav-panel .menu-item-has-children.is-open > .sub-menu {
    display: block !important;
  }
  .nav-panel .submenu-toggle::before {
    content: "+";
  }
  .nav-panel .menu-item-has-children.is-open > .submenu-toggle::before {
    content: "−";
  }
  .main-navigation li {
    text-align:left;
  }
}

/* Top-Menü-Varianten (Header / Panel Umschaltung) */
@media (min-width: 1024px) {
  .top-menu--header {
    display: flex !important;
  }
  .top-menu--panel {
    display: none !important;   /* verhindert Duplikat auf Desktop */
  }
}
@media (max-width: 1024px) {
  .top-menu--header {
    display: none !important;
  }
  .top-menu--panel {
    display: flex !important;
    padding: 12px 16px;
    border-bottom: 1px solid rgba(255,255,255,.15);
  }
  .top-menu--panel span {
    background: rgba(255,255,255,.12);
    color: #fff;
  }
  .top-menu--panel span:hover {
    background: rgba(255,255,255,.20);
  }
}

.responsive-nav .top-menu--panel .primary-menu,
.responsive-nav .top-menu--panel .menu,
.responsive-nav .top-menu--panel ul {
  display: flex !important;
  flex-wrap: wrap;
  gap: 10px 12px;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.top-menu--panel li {
  list-style: none !important;
}

@media (min-width: 1024px) {
  .main-navigation .primary-menu > .menu-item--top,
  .main-navigation .primary-menu > .top-item {
    display: none !important;
  }
}

/* DESKTOP-HOVER + CURRENT-STRICH ÜBER ::before */
@media (min-width: 1024px) {

  /* Basis-Link im Hauptmenü */
  .main-navigation .primary-menu > li > a {
    position: relative;
    text-decoration: none;
    border-top: 0 !important;      /* alte border-Tops sicher deaktivieren */
  }

  /* animierter Hover-Strich */
  .main-navigation .primary-menu > li > a::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;                        /* Basis-Position */
    width: 100%;
    height: 2px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .25s ease;
  }

  .main-navigation .primary-menu > li > a:hover::before,
  .main-navigation .primary-menu > li > a:focus::before {
    transform: scaleX(1);
  }

  /* Aktive Seite + Vorfahren: Strich dauerhaft + Versatz-Korrektur */
  .main-navigation .primary-menu > li.current-menu-item > a::before,
  .main-navigation .primary-menu > li.current_page_item > a::before,
  .main-navigation .primary-menu > li.current-menu-ancestor > a::before,
  .main-navigation .primary-menu > li.current_page_ancestor > a::before {
    transform: scaleX(1);
    top: 2px;   /* hier passt du bei Bedarf den 1–2px-Offset an */
  }

  /* alle border-top-Reste aus Theme für Sicherheit komplett killen */
  .primary-menu > li > a,
  .primary-menu > li > a:hover,
  .primary-menu > li.current-menu-item > a,
  .primary-menu > li.current_page_item > a,
  .primary-menu > li.current-menu-ancestor > a,
  .primary-menu > li.current_page_ancestor > a {
    border-top: 0 !important;
  }

  button.submenu-toggle {
    display: none !important;
  }
  li.current-page-ancestor,
  li.current_page_item {
    border-top: 0 !important;
  }
	.top-menu.top-menu--header {
		top:0 !important;
		margin-top:-10px !important;
		transform: scale(0.8);
		transform-origin: center center;
	}
	.top-menu.top-menu--header span a {
		margin-top:5px;
	}
}

/*** Sticky Post Badge ***/
.post-item-image {
    position: relative;
    overflow: hidden; /* verhindert Überstand */
	}
.post-item-sticky-badge {
    position: absolute;
    top: 12px;            /* Abstand vom Rand */
    left: -40px;          /* nach links ziehen, damit die Rotation gut sitzt */
    width: 120px;         /* Länge des Balkens */
    height: 22px;         /* Dicke des Balkens */
    background: rgba(255, 100, 0, 0.9); /* Beispiel: Orangeton wie dein Branding */
    transform: rotate(-45deg);
    pointer-events: none;
    z-index: 5;
    border-radius: 3px;   /* optional */
	}

/*** Central Footer Widget ***/
.single-footer-widget {
    display: flex;
    justify-content: center;
    text-align: center;
}

.after-footer-center {
		border-top:1px solid var(--primary-color);
		padding-top:1em;
		width:100%;
}
.after-footer-center .widget {
    background: transparent;   /* statt weiß */
    box-shadow: none;          /* falls da noch Schatten drauf sind */
}


/* ---- Source: customizer.css ---- */
    /* Farbeinstellungen */
        :root {
            --primary-color: #004892;
            --secondary-color: #009440;
            --text-color: #000000;
            --body-bg-color: #ffffff;
            --content-bg-color: #ffffff;
            --header-bg-color: #ffffff;
            --footer-bg-color: #ffeb00;
            --footer-text-color: #004892;
            --logo-max-height: 40px;
            --header-padding: 50px;
        }

        body {
            background-color: var(--body-bg-color);
            color: var(--text-color);}

        .site-header {
            background-color: var(--header-bg-color);
            padding: var(--header-padding) 0;
        }

        .site-footer {
            background-color: var(--footer-bg-color);
            color: var(--footer-text-color);
        }

        .site-content {
            background-color: var(--content-bg-color);
        }

        a {
            color: var(--primary-color);
        }


        /* Header-Layout Styles */
        /* Base styles for all header layouts */
        .site-header {
            display: flex;
            align-items: center;
        }

        /* Stacked layout */
        .site-header.layout-stacked {
            flex-direction: column;
            gap: 15px;
            text-align: center;
        }

        /* Split layout */
        .site-header.layout-split {
            flex-direction: row;
            justify-content: space-between;
        }

        /* Horizontal layout */
        .site-header.layout-horizontal {
            flex-direction: row;
            justify-content: space-between;
        }

        /* Center both logo and menu in horizontal layout */
        .site-header.layout-horizontal .logo-position-center.site-branding,
        .site-header.layout-horizontal .menu-position-center.main-navigation {
            flex: 1;
            text-align: center;
        }

        /* Horizontal layout with logo right order */
        .site-header.layout-horizontal.order-logo_right {
            flex-direction: row-reverse;
        }

        /* When both logo and menu are centered in horizontal layout, stack them */
        .site-header.layout-horizontal .logo-position-center ~ .menu-position-center {
            margin-top: 15px;
        }

        /* Logo position classes */
        .site-branding.logo-position-left {
            text-align: left;
        }

        .site-branding.logo-position-center {
            text-align: center;
        }

        .site-branding.logo-position-right {
            text-align: right;
        }

        /* In stacked layout, logo is always centered regardless of position setting */
        .site-header.layout-stacked .site-branding {
            text-align: center;
            margin-bottom: 10px;
        }

        /* In split layout, logo is always on the left */
        .site-header.layout-split .site-branding {
            text-align: left;
        }

        /* Menu position classes */
        .main-navigation.menu-position-left {
            text-align: left;
        }

        .main-navigation.menu-position-center {
            text-align: center;
        }

        .main-navigation.menu-position-right {
            text-align: right;
        }

        /* In stacked layout, menu is always centered below logo */
        .site-header.layout-stacked .main-navigation {
            width: 100%;
            text-align: center;
        }

        /* In split layout, menu is always on the right */
        .site-header.layout-split .main-navigation {
            text-align: left;
        }

        /* Logo-Größe */
        .custom-logo {
            max-height: var(--logo-max-height);
            width: auto;
            height: auto;
        }

        .site-title {
            margin: 0;
            font-size: calc(var(--logo-max-height) * 0.4);
            line-height: 1.2;
        }

        /* Menü-Ausrichtung basierend auf Positionsklassen */
        /* Default menu alignment */
        .main-navigation ul {
            display: flex;
            flex-wrap: wrap;
        }

        /* Menu alignment based on position classes */
        .main-navigation.menu-position-left ul {
            justify-content: flex-start;
            text-align: left;
        }

        .main-navigation.menu-position-center ul {
            justify-content: center;
            text-align: center;
        }

        .main-navigation.menu-position-right ul {
            justify-content: flex-end;
            text-align: right;
        }

        /* Override for stacked layout - always center */
        .site-header.layout-stacked .main-navigation ul {
            justify-content: center;
            text-align: center;
        }

        /* Override for split layout - always right align */
        .site-header.layout-split .main-navigation ul {
            justify-content: flex-end;
            text-align: left;
        }

        /* Responsive Anpassungen */
        @media (max-width: 768px) {
            /* Force stacked layout on mobile */
            .site-header,
            .site-header.layout-horizontal,
            .site-header.layout-split {
                flex-direction: column !important;
                gap: 15px;
                text-align: center;
            }

            /* Reset all positioning classes on mobile */
            .site-branding.logo-position-left,
            .site-branding.logo-position-right,
            .site-branding.logo-position-center,
            .main-navigation.menu-position-left,
            .main-navigation.menu-position-right,
            .main-navigation.menu-position-center {
                order: unset;
                margin: 0;
                width: 100%;
                text-align: center;
            }

            /* Center all menu items on mobile */
            .main-navigation ul,
            .main-navigation.menu-position-left ul,
            .main-navigation.menu-position-right ul,
            .main-navigation.menu-position-center ul,
            .site-header.layout-split .main-navigation ul {
                justify-content: center;
                text-align: center;
            }

            /* Slightly reduce logo size on mobile */
            .custom-logo {
                max-height: calc(var(--logo-max-height) * 0.8);
            }

            /* Reset any order classes on mobile */
            .site-header.order-logo_left,
            .site-header.order-logo_right {
                flex-direction: column !important;
            }
        }

        /* Button-Styles mit Primärfarbe */
        .btn, .button, input[type="submit"], button {
            background-color: var(--primary-color);
            color: white;
            border: none;
            padding: 12px 24px;
            border-radius: 4px;
            cursor: pointer;
            transition: background-color 0.3s ease;
        }

        .btn:hover, .button:hover, input[type="submit"]:hover, button:hover {
            background-color: var(--secondary-color);
            color: white;
        }

        /* Weitere Theme-spezifische Styles */
        .entry-content {
            background-color: var(--content-bg-color);
        }

/* ---- Source: responsive-nav.css ---- */
/**
 * Responsive Navigation CSS
 * Datei: responsive-nav.css
 */

/* Navigation Container */
.responsive-nav {
    position: relative;
    background: transparent;
}

.nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* Mobile Toggle Button */
.nav-toggle {
    display: none;
    background: none;
    border: none;
    color: #fff;
    font-size: 24px;
    cursor: pointer;
    padding: 15px;
    z-index: 1001;
}

.nav-toggle:hover {
    opacity: 0.8;
}

/* Hauptmenü */
.primary-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0;
}

.primary-menu > li {
    position: relative;
}

.primary-menu > li > a {
    display: block;
    padding: 20px 20px;
    color: #000;
    text-decoration: none;
    transition: background-color 0.3s;
}

.primary-menu > li > a:hover,
.primary-menu > li.current-menu-item > a {
    border: 0;
    border-top: 2px solid var(--primary-color);
}

/* Untermenüs */
.primary-menu .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--primary-color);
    min-width: 200px;
    list-style: none;
    margin: 0;
    padding: 0;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    
}

.primary-menu li:hover > .sub-menu {
    display: block;
}

.primary-menu .sub-menu li a {
    display: block;
    padding: 12px 20px;
    text-decoration: none;
    white-space: nowrap;
    color: #fff;
}

.primary-menu .sub-menu li a:hover {
    
}

/* Responsive: Mobile */
@media (max-width: 1024px) {
    

    .responsive-nav {
        position: absolute;
        top: 25px; 
        right: 10px;
        width: unset !important;
        padding: 0;
        margin: 0;
    }

    .nav-toggle {
        display: block;
        background: #555;
				background: var(--primary-color);
    }

    .site-header, .site-header.layout-horizontal, .site-header.layout-split {
        text-align: left !important;
        color: #fff;
    }

    .primary-menu {
        position: fixed;
        top: 0;
        right: -100%;
        width: 80%;
        max-width: 300px;
        height: 100vh;
        background: #333;
				background: var(--primary-color);
        flex-direction: column;
        padding: 60px 0 20px;
        overflow-y: auto;
        transition: right 0.3s ease;
        z-index: 1000;
        box-shadow: -2px 0 5px rgba(0,0,0,0.3);
        color: #fff;
    }

    .primary-menu.is-active {
        right: 0;
    }

    .primary-menu > li {
        width: 100%;
    }

    .primary-menu > li > a {
        padding: 15px 20px;
        border-top: 2px solid var(--primary-color);

        color: #fff !important;
    }

    /* Mobile Untermenüs */
    .primary-menu .sub-menu {
        position: static;
        display: block;
        background: #2a2a2a;
				background: color-mix(in oklab, var(--primary-color) 80%, #FFF);
        box-shadow: none;
        width: 100%;
    }

    .primary-menu li.menu-item-has-children.is-open > .sub-menu {
        display: block;
    }

    .primary-menu .sub-menu li a {
        padding-left: 40px;
        color: #fff;
    }

    /* Overlay für Mobile */
    .nav-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,0.5);
				background: var(--primary-color);
        z-index: 1;
        color: #fff;
    }

    .nav-overlay.is-active {
        display: block;
    }


    .site-header.layout-split .main-navigation ul.is-active {
        justify-content: flex-start;
        text-align: left;
        padding-top: 5em;
    }

}

/* Dynamischer Breakpoint aus Customizer */
@media (max-width: 1024px) {
    .nav-toggle {
        display: block;
    }

    .primary-menu {
        position: fixed;
        right: -100%;
    }

    .primary-menu a {
        font-size: 80%;
    }
		.nav-toggle {
			position: relative;
			width: 40px;
			height: 40px;
			border: none;
			cursor: pointer;
		}

		.nav-toggle-icon,
		.nav-toggle-icon::before,
		.nav-toggle-icon::after {
			position: absolute;
			left: 50%;
			width: 24px;
			height: 2px;
			background: #FFF;
			border-radius: 1px;
			transition: all 0.3s ease;
			content: "";
			transform: translateX(-50%);
		}

		.nav-toggle-icon::before { top: -7px; }
		.nav-toggle-icon::after  { top: 7px; }

		/* --- Animation beim Öffnen --- */
		.nav-toggle[aria-expanded="true"] .nav-toggle-icon {
			background: transparent; /* mittleren Strich ausblenden */
		}

		.nav-toggle[aria-expanded="true"] .nav-toggle-icon::before {
			top: 0;
			transform: translateX(-50%) rotate(45deg);
		}

		.nav-toggle[aria-expanded="true"] .nav-toggle-icon::after {
			top: 0;
			transform: translateX(-50%) rotate(-45deg);
		}

    .nav-toggle { display: block; }
    .primary-menu { position: fixed; right: -100%; z-index: 1000; }
    .nav-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 1; }
    .nav-overlay.is-active { display: block; }
				
		.primary-menu > li > a:hover,
		.primary-menu > li > a:focus-visible {
			background: color-mix(in oklab, #fff 12%, var(--primary-color)); 
			color: #fff;
		}
		.primary-menu .sub-menu li a:hover,
		.primary-menu .sub-menu li a:focus-visible {
			background: color-mix(in oklab, #000 18%, var(--primary-color));
			color: #fff;
		}
		.primary-menu > li.current-menu-item > a {
			background: color-mix(in oklab, #000 12%, var(--primary-color));
		}
}




/* ---- Source: z.css ---- */
.site-header {
	padding: 0;
}
