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, initially hidden above viewport */
nav.mod_navigation.block,
#main-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  max-height: none;
  background: var(--surface);
  transform: translateY(-100%);           /* hidden above viewport */
  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;
}

/* visible state (JS toggles .is-open) */
nav.mod_navigation.block.is-open,
#main-nav.is-open {
  transform: translateY(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) --- */
nav.mod_navigation.block > ul.level_1 > li > a,
#main-nav > ul.level_1 > li > a,
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; }

/* --- 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;
}

/* Submenu links */
nav.mod_navigation.block ul.level_2 li a,
nav.mod_navigation.block ul.level_3 li a,
#main-nav ul.level_2 li a,
#main-nav ul.level_3 li a {
  display: block;
  padding: 10px 16px;
  color: var(--text);
  border-radius: 6px;
  font-weight: 600;
}
nav.mod_navigation.block ul.level_2 li a:hover,
#main-nav ul.level_2 li a:hover { background: #f8fafc; }

/* 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)
   ========================= */
.submenu-toggle {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 6px;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  color: var(--muted);
  padding: 0;
}
.submenu-toggle svg { width: 12px; height: 12px; fill: currentColor; transition: transform var(--transition-speed) ease, color var(--transition-speed) ease; }

/* rotate chevron when expanded */
.submenu-toggle[aria-expanded="true"] svg { transform: rotate(90deg); color: var(--primary); }

/* focus styles */
.submenu-toggle:focus, .submenu-toggle:focus-visible { outline: 3px solid #cfe1ff; outline-offset: 2px; border-color: var(--border); }

/* =========================
   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; }
}
