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}
header,footer,nav,section,aside,main,article,figure,figcaption{display:block}body,div,h1,h2,h3,h4,h5,h6,p,blockquote,pre,code,ol,ul,li,dl,dt,dd,figure,table,th,td,form,fieldset,legend,input,textarea{margin:0;padding:0}table{border-spacing:0;border-collapse:collapse}caption,th,td{text-align:left;text-align:start;vertical-align:top}abbr,acronym{font-variant:normal;border-bottom:1px dotted #666;cursor:help}blockquote,q{quotes:none}fieldset,img,iframe{border:0}ul{list-style-type:none}sup{vertical-align:text-top}sub{vertical-align:text-bottom}del{text-decoration:line-through}ins{text-decoration:none}body{font:12px/1 "Lucida Grande","Lucida Sans Unicode",Verdana,sans-serif;color:#000}input,button,textarea,select{font-family:inherit;font-size:99%;font-weight:inherit}pre,code{font-family:Monaco,monospace}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:400}h1{font-size:1.8333em}h2{font-size:1.6667em}h3{font-size:1.5em}h4{font-size:1.3333em}table{font-size:inherit}caption,th{font-weight:700}a{color:#00f}h1,h2,h3,h4,h5,h6{margin-top:1em}h1,h2,h3,h4,h5,h6,p,pre,blockquote,table,ol,ul,form{margin-bottom:12px}
/* =========================
   Overlay Navigation - Complete Styles
   ========================= */
/* --- Variablen / Basis --- */
:root{
  --bg: #f6f7fb;
  --surface: #ffffff;
  --text: #1f2937;
  --muted: #6b7280;
  --border: #e5e7eb;
  --primary: #0a5bd3;
  --primary-600: #0a57c5;
  --shadow: 0 6px 30px rgba(15,20,30,.18);
  --panel-shadow: 0 6px 30px rgba(0,0,0,.35);
  --radius: 12px;
  --transition-speed: 240ms;
  --max-menu-height: 1200px;
}
/* --- Grundreset / Typografie --- */
* { box-sizing: border-box; }
html, body { height: 100%; margin: 0; background: var(--bg); color: var(--text); font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; line-height: 1.45; }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }
:focus { outline-offset: 2px; }
:focus-visible { outline: 3px solid rgba(122,166,255,.95); border-radius: 6px; }
/* --- Container / Page layout helpers --- */
.inside, .container { width: min(1100px, 92%); margin: 0 auto; }
/* --- Skip-Link (Contao .invisible) --- */
a.invisible, .invisible { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
a.invisible:focus, a.invisible:focus-visible,
#skipNavigation2:focus, #skipNavigation2:focus-visible {
  position: static; left: 0; width: auto; height: auto; padding: 8px 12px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 6px; z-index: 12010;
}
/* =========================
   Overlay Navigation / Backdrop
   ========================= */
/* nav as full viewport panel on small screens, but left-side narrow panel on larger viewports */
nav.mod_navigation.block,
#main-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;                    /* full width on small screens */
  height: 100vh;
  max-height: none;
  background: var(--surface);
  transform: translateY(-100%);           /* hidden above viewport by default (small screens) */
  transition: transform var(--transition-speed) ease;
  z-index: 10010;                         /* above page, below burger (burger has higher z-index) */
  box-shadow: var(--panel-shadow);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 18px 0;
  will-change: transform;
}

/* visible state (JS toggles .is-open) */
nav.mod_navigation.block.is-open,
#main-nav.is-open {
  transform: translateY(0);
}

/* On wider viewports, show nav as left-side panel (max 25% wide) and slide in from left */
@media (min-width: 900px) {
  nav.mod_navigation.block,
  #main-nav {
    right: auto;                       /* unset right so width controls panel */
    width: 25vw;                       /* 25% of viewport width */
    max-width: 420px;                  /* optional max width to keep it usable on very large screens */
    min-width: 220px;                  /* optional min width for usability */
    transform: translateX(-100%);      /* hide left of viewport on wide screens */
    transition: transform var(--transition-speed) ease;
    box-shadow: var(--panel-shadow);
  }
  /* visible state on wide viewports */
  nav.mod_navigation.block.is-open,
  #main-nav.is-open {
    transform: translateX(0);
  }
}

/* Backdrop (semi-transparent layer behind panel) */
.nav-backdrop {
  position: fixed;
  inset: 0;                        /* top:0; right:0; bottom:0; left:0 */
  background: rgba(0,0,0,.45);
  z-index: 10000;                  /* behind panel, above page */
  opacity: 1;
  will-change: opacity;
}

/* Prevent page scroll when nav open (JS should toggle body.nav-open) */
body.nav-open {
  overflow: hidden;
  touch-action: none;
}

/* Place burger above everything so user can always toggle/close */
.icon-btn, #mobile-menu {
  position: relative;
  z-index: 10020;
}

/* Adjust nav inner padding and list layout */
nav.mod_navigation.block ul,
#main-nav ul {
  list-style: none;
  margin: 0;
  padding: 0 12px;
}
nav.mod_navigation.block li,
#main-nav li {
  border-bottom: 1px solid var(--border);
  position: relative;
}

/* --- Level 1 (Hauptpunkte) --- */
/* Ensure top-level items (a/strong/span/button/current) share same layout */
nav.mod_navigation.block > ul.level_1 > li > a,
nav.mod_navigation.block > ul.level_1 > li > strong,
nav.mod_navigation.block > ul.level_1 > li > span,
nav.mod_navigation.block > ul.level_1 > li > button,
nav.mod_navigation.block > ul.level_1 > li > [aria-current="page"],
#main-nav > ul.level_1 > li > a,
#main-nav > ul.level_1 > li > strong,
#main-nav > ul.level_1 > li > span,
#main-nav > ul.level_1 > li > button,
#main-nav > ul.level_1 > li > [aria-current="page"],
nav.mod_navigation.block > ul > li > a,
#main-nav > ul > li > a {
  display: block;
  padding: 14px 16px;
  color: var(--text);
  background: transparent;
  border-radius: 8px;
  font-weight: 700;
  font-size: 1rem;
}

/* Hover / Fokus */
nav.mod_navigation.block a:hover,
#main-nav a:hover { background: #f1f5f9; }

/* Active / current page indicators for level-1 (make them look like links) */
nav.mod_navigation.block > ul.level_1 > li > .active,
nav.mod_navigation.block > ul.level_1 > li > [aria-current="page"],
nav.mod_navigation.block > ul.level_1 > li.open > a,
nav.mod_navigation.block > ul.level_1 > li.open > strong,
#main-nav > ul.level_1 > li > .active,
#main-nav > ul.level_1 > li > [aria-current="page"],
#main-nav > ul.level_1 > li.open > a,
#main-nav > ul.level_1 > li.open > strong {
  background: #e6f0ff;
  color: var(--primary);
}

/* --- Submenu levels (closed by default) --- */
nav.mod_navigation.block ul.level_2,
nav.mod_navigation.block ul.level_3,
#main-nav ul.level_2,
#main-nav ul.level_3 {
  padding-left: 1.4rem;
  margin: 0;
  overflow: hidden;
  max-height: 0;
  transition: max-height var(--transition-speed) ease;
}

/* Open states controlled via li.open (JS toggles class) */
nav.mod_navigation.block li.open > ul.level_2,
nav.mod_navigation.block li.open > ul.level_3,
#main-nav li.open > ul.level_2,
#main-nav li.open > ul.level_3 {
  max-height: 600px;
}

/* =========================
   Einheitliche Level-2 Gestaltung
   ========================= */

/* Make li elements block-level to ensure full-width stacking */
nav.mod_navigation.block ul.level_2 li,
#main-nav ul.level_2 li {
  display: block;
  margin: 0;
  padding: 0; /* padding applied to inner element for consistent sizing */
}

/* Ensure children inside li (a, strong, span, button, current) fill width and share padding */
nav.mod_navigation.block ul.level_2 li > a,
nav.mod_navigation.block ul.level_2 li > strong,
nav.mod_navigation.block ul.level_2 li > span,
nav.mod_navigation.block ul.level_2 li > button,
nav.mod_navigation.block ul.level_2 li > [aria-current="page"],
#main-nav ul.level_2 li > a,
#main-nav ul.level_2 li > strong,
#main-nav ul.level_2 li > span,
#main-nav ul.level_2 li > button,
#main-nav ul.level_2 li > [aria-current="page"] {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 10px 16px;       /* einheitliche Innenabstände für alle Level-2 Einträge */
  color: var(--text);
  border-radius: 6px;
  text-decoration: none;
  line-height: 1.25;
  font-weight: 600;         /* Standardgewicht für Level-2 items with link */
}

/* Hover / Fokus für Level-2 Einträge (egal ob Link oder Nicht-Link-Wrap) */
nav.mod_navigation.block ul.level_2 li:hover > a,
nav.mod_navigation.block ul.level_2 li:hover > strong,
nav.mod_navigation.block ul.level_2 li:hover > span,
#main-nav ul.level_2 li:hover > a,
#main-nav ul.level_2 li:hover > strong,
#main-nav ul.level_2 li:hover > span {
  background: #f8fafc;
}

/* Wenn ein Level-2 <li> kein <a> hat: mache den sichtbaren Text fett und sorge dafür, dass er
   dieselbe Block-Darstellung und Hervorhebung wie Links erhält. */

/* modern browsers: :has() fallback */
@supports (selector(:has(*))) {
  nav.mod_navigation.block ul.level_2 li:not(:has(a)) > *,
  #main-nav ul.level_2 li:not(:has(a)) > * {
    font-weight: 700;
    color: var(--text);
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 10px 16px;
    border-radius: 6px;
    line-height: 1.25;
    background: transparent;
  }
}

/* Fallback für Browser ohne :has() — style häufig verwendete Markups (strong, span) */
nav.mod_navigation.block ul.level_2 li > strong,
#main-nav ul.level_2 li > strong,
nav.mod_navigation.block ul.level_2 li > span.no-link,
#main-nav ul.level_2 li > span.no-link {
  font-weight: 700;
  color: var(--text);
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 10px 16px;
  border-radius: 6px;
  line-height: 1.25;
  background: transparent;
}

/* Aktiver (aktuelle Seite) Level-2 Einträge sollen genauso aussehen wie aktive Links */
nav.mod_navigation.block ul.level_2 li > .active,
nav.mod_navigation.block ul.level_2 li > [aria-current="page"],
nav.mod_navigation.block ul.level_2 li.open > a,
nav.mod_navigation.block ul.level_2 li.open > strong,
#main-nav ul.level_2 li > .active,
#main-nav ul.level_2 li > [aria-current="page"],
#main-nav ul.level_2 li.open > a,
#main-nav ul.level_2 li.open > strong {
  background: #e6f0ff;
  color: var(--primary);
  font-weight: 700;
}

/* Ensure li.open parents keep consistent styles for their children */
nav.mod_navigation.block li.open > ul.level_2 > li > a,
nav.mod_navigation.block li.open > ul.level_2 > li > strong,
#main-nav li.open > ul.level_2 > li > a,
#main-nav li.open > ul.level_2 > li > strong {
  /* no override needed beyond above, kept for specificity if required */
}

/* Highlight open top items */
nav.mod_navigation.block.is-open > ul > li.open > a,
#main-nav.is-open > ul > li.open > a {
  background: #e6f0ff;
  color: var(--primary);
}

/* =========================
   Burger button (icon-btn)
   ========================= */
.icon-btn,
#mobile-menu {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
  cursor: pointer;
  padding: 0;
  font-size: 1rem;
}
.icon-btn svg { display: block; width: 20px; height: 14px; fill: currentColor; color: var(--text); }

/* =========================
   Submenu toggle (chevron)
   ========================= */
/* wir blenden die automatisch erzeugten Pfeil-Buttons aus (keine sichtbare Pfeile) */
nav.mod_navigation.block .submenu-toggle,
#main-nav .submenu-toggle {
  display: none !important;
}

/* Top-Level-Items mit Submenu als klickbar/fokusierbar markieren */
nav.mod_navigation.block > ul.level_1 > li.submenu > a,
nav.mod_navigation.block > ul.level_1 > li.submenu > strong,
#main-nav > ul.level_1 > li.submenu > a,
#main-nav > ul.level_1 > li.submenu > strong {
  cursor: pointer;
  padding-right: 20px; /* etwas Abstand rechts, da kein Pfeil mehr vorhanden */
}

/* =========================
   Login box styling (mod_login)
   ========================= */
.mod_login.block {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 4px 12px rgba(0,0,0,.06);
  max-width: 760px;
  margin: 16px auto;
}
.mod_login.block.logout .formbody { display: flex; flex-direction: column; gap: 12px; }
.mod_login .login_info { margin: 0; color: var(--muted); }
.mod_login .widget-submit .submit,
.mod_login .submit {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 8px;
  background: var(--primary);
  color: #fff;
  border: none;
  cursor: pointer;
  font-weight: 700;
}
.mod_login .widget-submit .submit:hover { background: var(--primary-600); }

/* =========================
   Accessibility helpers
   ========================= */
/* When nav is hidden, JS sets aria-hidden="true" — no extra visual change needed */
/* Hide visually helper */
.hidden-visually { position: absolute !important; left: -9999px !important; top: auto !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }

/* =========================
   Reduced motion & Dark mode
   ========================= */
@media (prefers-reduced-motion: reduce) {
  nav.mod_navigation.block, #main-nav,
  nav.mod_navigation.block ul.level_2, #main-nav ul.level_2,
  nav.mod_navigation.block ul.level_3, #main-nav ul.level_3,
  .submenu-toggle svg {
    transition: none !important;
  }
}
@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0b1020;
    --surface: #141a2a;
    --text: #e8e8f0;
    --muted: #a3a3b8;
    --border: #2a2f47;
    --primary: #6ea8ff;
    --panel-shadow: 0 8px 40px rgba(0,0,0,.5);
  }
  body { background: var(--bg); color: var(--text); }
  nav.mod_navigation.block, #main-nav, .mod_login.block { background: var(--surface); border-color: var(--border); }
  .icon-btn svg { color: var(--text); }
}

/* =========================
   Optional Desktop behavior
   =========================
   Wenn du bei großen Viewports das Menü dauerhaft offen haben willst,
   entkommentiere den folgenden Block und passe breakpoint an:
*/
/*
@media (min-width: 1100px) {
  nav.mod_navigation.block, #main-nav { transform: translateY(0); position: static; height: auto; box-shadow: none; }
  .nav-backdrop { display: none; }
  body.nav-open { overflow: visible; touch-action: auto; }
  .icon-btn { display: none; } // falls du Burger auf Desktop nicht willst
}
*/

/* Header / Brand wie im alten Design */
:root{
  --brand-logo-size: 34px;
  --brand-gap: 10px;
}
/* Sticky Topbar */
header#header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
/* Header-Innenbereich (Container) */
.container.header-inner,
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;            /* sofern inline style vorhanden, gilt trotzdem */
  padding: 14px 0;
  width: min(1100px, 92%);
  margin: 0 auto;
}
/* Brand (Logo + Name) */
.brand {
  display: flex;
  align-items: center;
  gap: var(--brand-gap);
  font-weight: 700;
  font-size: clamp(1.05rem, 0.9rem + 1vw, 1.4rem);
  line-height: 1;
}
/* Logo-Kachel */
.brand .logo {
  width: var(--brand-logo-size);
  height: var(--brand-logo-size);
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #4f46e5 0%, #06b6d4 100%);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
  font-size: 1.05rem;
}
/* Brand-Name */
.brand .brand-name {
  display: inline-block;
  vertical-align: middle;
  color: var(--text);
  white-space: nowrap;
}
/* Kleine Anpassung für das Burger-Icon rechts */
.icon-btn#mobile-menu,
button#mobile-menu {
  margin-left: 8px;
  background: #fff;
  border: 1px solid var(--border);
}
/* Mobile: etwas kompaktere Brand-Size */
@media (max-width: 420px) {
  .brand { font-size: 1rem; }
  .brand .logo { width: 30px; height: 30px; font-size: 0.95rem; }
}
