/* =========================
   Über-uns Layout (Text & Bild nebeneinander)
   ========================= */
section.about {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: start;
  margin: 2rem auto;
  max-width: 1100px;
  padding: 1rem;
}
section.about .text { line-height: 1.6; }
section.about .media { align-self: start; }
section.about .media img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: .5rem;
}
/* Bild links, Text rechts für den 2. Abschnitt */
section.about.about--reverse .text { order: 2; }
section.about.about--reverse .media { order: 1; }
/* Mobil: untereinander */
@media (max-width: 800px) {
  section.about { grid-template-columns: 1fr; }
  section.about .text, section.about .media { order: initial; }
}
/* Optional: dezente Trennung zwischen Abschnitten */
.divider { max-width: 1100px; margin: 0 auto; padding: 0 1rem; }
.divider hr { border: 0; border-top: 1px solid #e5e7eb; margin: 1rem 0 0; }

/* =========================
   Variablen
   ========================= */
:root{
  --bg: #f4f4f4;
  --text: #111;
  --primary: #0077cc;
  --primary-dark: #005fa3;
  --danger: #cc0000;
  --danger-dark: #a50000;
  --muted: #6b7280;
  --card: #ffffff;
  --shadow: 0 2px 8px rgba(0,0,0,0.1);

  --header-bg: #6F0000;
  --header-text: #fff;

  /* Kalender-Farben */
  --mec: #0077cc;        /* Blau */
  --eisenbahn: #cc0000;  /* Rot */

  /* MEC-Layout */
  --page-max: 1100px;
  --ring:#e5e7eb;

  /* Ticker: Standarddauer – kann per Inline-Style überschrieben werden */
  --ticker-duration: 60s;
}

/* =========================
   Basislayout
   ========================= */
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  font-family: Arial, sans-serif;
  margin: 0;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* =========================
   Header
   ========================= */
header {
  background: var(--header-bg);
  color: var(--header-text);
  text-align: center;
  padding: 20px;
}
header h1, header h2, header h3 { margin: 0; }

/* =========================
   Navigation (public & admin)
   ========================= */

/* Gemeinsame Basis für .nav und .navigation (Desktop-Stil bleibt erhalten) */
.nav, .navigation {
  background: #333;
  margin: 0; /* KEINE Lücke nach unten */
  color: #fff;
}
.nav > ul, .navigation > ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.nav > ul > li, .navigation > ul > li { margin: 0; }
.nav > ul > li > a, .navigation > ul > li > a {
  display: inline-block;
  padding: 12px 20px;
  color: #fff;
  text-decoration: none;
  transition: background .15s ease;
}
.nav > ul > li > a:hover,
.navigation > ul > li > a:hover { background: #555; }
.nav > ul > li > a.active,
.navigation > ul > li > a.active { background: #0066b2; }

/* Admin-Variante */
.nav.nav-admin { background: #2b2b2b; }
.nav.nav-admin > ul > li > a:hover { background: #444; }

/* Responsive Nav (Schrift/Polsterung kleiner) */
@media (max-width: 640px) {
  .nav > ul > li > a, .navigation > ul > li > a {
    padding: 10px 14px; font-size: 15px;
  }
}

/* ==== Mobile Burger-Navigation (ohne Farbüberschreibung) ==== */
.site-nav{                /* diese Klasse kommt zusätzlich zur .nav/.navigation */
  background: inherit;    /* übernimmt vorhandene Nav-Farbe (#333) */
  color: inherit;
  border-bottom: 1px solid rgba(255,255,255,.15);
  position: relative; z-index: 200;
}
.site-nav a{ color: inherit; text-decoration:none; }
.nav-bar{
  max-width:1100px; margin:0 auto; padding:8px 16px;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{ font-weight:800; letter-spacing:.2px; font-size:1.05rem; }

/* Burger-Button */
.nav-toggle{
  width:42px; height:42px; border:0; border-radius:10px; background:transparent;
  display:flex; align-items:center; justify-content:center; cursor:pointer;
}
.nav-toggle:hover{ background: rgba(255,255,255,.10); }
.nav-toggle .bar{
  width:22px; height:2px; background: currentColor; display:block; border-radius:2px;
  transition: transform .2s ease, opacity .2s ease;
}
.nav-toggle .bar + .bar{ margin-top:5px; }
/* X-Animation */
.nav-toggle.is-open .bar:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open .bar:nth-child(2){ opacity:0; }
.nav-toggle.is-open .bar:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* Menü */
.nav-menu{ max-width:1100px; margin:0 auto; }
.nav-menu ul{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.nav-menu a{ display:block; padding:8px 10px; border-radius:8px; }
.nav-menu a:hover{ background: rgba(255,255,255,.12); }

/* Mobile: Dropdown nur mit JS-Klasse aktiv */
@media (max-width: 900px){
  .nav-bar{ padding:8px 12px; }
  .nav-toggle{ display:flex; }
  html.js .nav-menu{
    display:none; position:absolute; left:0; right:0; top:100%;
    background: inherit; /* behält die Nav-Farbe */
    border-top:1px solid rgba(255,255,255,.15);
    padding:8px 12px 10px;
  }
  html.js .nav-menu[data-open="true"]{ display:block; }
  .nav-menu ul{ flex-direction:column; align-items:stretch; gap:4px; }
  .nav-menu a{ padding:10px 12px; }
  body.nav-noscroll{ overflow:hidden; }
}
/* Desktop */
@media (min-width: 901px){
  .nav-toggle{ display:none; }
  .nav-menu{ display:block; position:static; padding: 0 16px 10px; }
}

/* =========================
   Ticker (direkt unter Navigation)
   ========================= */
.ticker {
  margin: 0;
  background: #333;            /* gleiche Farbe wie .nav */
  color: #d1d5db;              /* lichtgrauer Text */
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(0,0,0,0.2);
}
.nav + .ticker,
.navigation + .ticker { margin-top: 0; }

.ticker__inner{
  display: flex;
  gap: 2rem;
  align-items: center;
  padding: .5rem 1rem;
  will-change: transform;
  animation: ticker-scroll var(--ticker-duration, 60s) linear infinite; /* Dauer per CSS-Var steuerbar */
}
.ticker:hover .ticker__inner{ animation-play-state: paused; }

.ticker__item{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .95rem;
}
.ticker__item .badge{
  display: inline-block;
  font-size: .75rem;
  padding: .1rem .45rem;
  border-radius: .35rem;
  background: var(--primary);
  color: #fff;
}

/* Endloslauf von rechts → links.
   Wichtig: In ticker.php die Liste duplizieren (A—B—A—B), dann -100% für nahtlose Schleife. */
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

/* Bewegtbild abschalten, wenn Nutzer reduzierte Bewegungen wünscht */
@media (prefers-reduced-motion: reduce){
  .ticker__inner{ animation: none; }
}

/* =========================
   Container/Card/Typo
   ========================= */
.container, .wrap, .calendar {
  max-width: 900px;
  margin: 20px auto;
  background: var(--card);
  border-radius: .5rem;
  box-shadow: var(--shadow);
  padding: 1rem;
}
.card {
  background: var(--card);
  border-radius: .5rem;
  box-shadow: var(--shadow);
  padding: 1rem;
}
.muted { color: var(--muted); }

/* Tabellen */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td {
  padding: .6rem .75rem;
  border-bottom: 1px solid #e5e7eb;
  text-align: left;
}
.table th { background: #f8fafc; }

/* Buttons */
.btn{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .6rem 1rem;
  border-radius: .5rem;
  border: 1px solid transparent;
  background: var(--primary);
  color: #fff;
  cursor: pointer;
  transition: transform .05s ease, background .15s ease;
}
.btn:hover { background: var(--primary-dark); }
.btn:active { transform: translateY(1px); }
.btn--danger { background: var(--danger); }
.btn--danger:hover { background: var(--danger-dark); }
.btn--ghost { background: #fff; color: var(--primary); border-color: var(--primary); }
.btn--ghost:hover { background: #eef6ff; }

/* =========================
   Kalender (Beispiel)
   ========================= */
.calendar .legend{
  display: flex; gap: .75rem; flex-wrap: wrap; margin-bottom: .75rem;
}
.calendar .legend .dot{
  width: .75rem; height: .75rem; border-radius: 50%; display: inline-block; margin-right: .35rem;
}
.dot--mec { background: var(--mec); }
.dot--eisenbahn { background: var(--eisenbahn); }
.calendar .event{
  padding: .75rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: .5rem;
  display: grid; grid-template-columns: 120px 1fr; gap: 1rem;
  margin-bottom: .75rem;
}
.calendar .event .when { color: var(--muted); }
@media (max-width: 640px){ .calendar .event { grid-template-columns: 1fr; } }

/* =========================
   Medien & Bilder
   ========================= */
img.responsive, .media img { max-width: 100%; height: auto; display: block; }

/* =========================
   Utility
   ========================= */
.mt-0{ margin-top:0 !important; }
.mb-0{ margin-bottom:0 !important; }
.mt-1{ margin-top:.25rem !important; }
.mt-2{ margin-top:.5rem !important; }
.mt-3{ margin-top:1rem !important; }
.mb-1{ margin-bottom:.25rem !important; }
.mb-2{ margin-bottom:.5rem !important; }
.mb-3{ margin-bottom:1rem !important; }
.p-0{ padding:0 !important; }
.p-1{ padding:.25rem !important; }
.p-2{ padding:.5rem !important; }
.p-3{ padding:1rem !important; }
.text-center{ text-align:center; }
.mt-8{ margin-top:8px; }

/* =========================
   Footer
   ========================= */
footer {
  max-width: 1100px;
  margin: 2rem auto;
  padding: 1rem;
  color: var(--muted);
}

/* =========================
   Hilfen gegen Margin-Collapsing
   ========================= */
.flow-root { display: flow-root; }

/* ======= MEC – Grundlayout (Header/Container) ======= */
body{
  background: linear-gradient(180deg,#f8fafc 0%, #ffffff 160px) no-repeat;
}
.container{ max-width: var(--page-max); margin: 16px auto; padding: 0 16px; }
.stack > * + *{ margin-top: 16px; }
.card{
  background:#fff; border:1px solid var(--ring);
  border-radius: 14px; padding:16px; box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.card h2{ margin:0 0 8px; }
.section-title{ text-align:center; margin: 10px 0 4px; }

/* Kill-Switch: alte Counter-Elemente sicher ausblenden */
#counter, .counter, .visitor-counter, .besucher, .zaehler,
img[src*="counter"], img[src*="zaehler"], img[src*="visitor"],
[data-old-counter], .old-counter { display:none !important; visibility:hidden !important; }

/* ======= Spezieller MEC-Header ======= */
.mec-header{
  background: linear-gradient(135deg, #6F0000 0%, #9a1b1b 100%);
  color:#fff; padding:24px 16px; text-align:center;
  border-bottom: 1px solid rgba(255,255,255,.15);
}
.mec-header h1{ margin:0; font-size:clamp(1.6rem,2.8vw,2.2rem); letter-spacing:.3px; }

/* ======= Countdown – responsiv, zentriert + Fallback ======= */
#mec-countdown{ position: relative; overflow: hidden; padding: 6px 2px; text-align: center; }
#mec-countdown .cd-scale{ display: inline-block; transform-origin: top left; will-change: transform, margin-left; }
#mec-countdown .cd-auto{ display:none; }
#mec-countdown.cd-fallback .cd-scale{ display:none !important; }
#mec-countdown.cd-fallback .cd-auto{ display:grid; }
.cd-auto{
  grid-template-columns: repeat(4, minmax(80px, 1fr));
  gap: 10px; max-width: 100%; margin: 0 auto;
  align-items: stretch; justify-items: center;
}
.cd-box{
  background:#fff; border:1px solid var(--ring);
  border-radius:12px; padding:10px 8px; min-width:80px;
  box-shadow: var(--shadow);
}
.cd-val{ font-size: clamp(1.25rem, 6vw, 1.8rem); font-weight:800; line-height:1.1; }
.cd-lbl{ margin-top:4px; font-size:.9rem; color:var(--muted); }
@media (max-width: 520px){ .cd-auto{ grid-template-columns: repeat(2, minmax(120px, 1fr)); } }
/* generische Verbesserungen für eingebettete Countdowns */
#mec-countdown :where(.countdown, .cd, .timer, .event-list, ul, ol){
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px; align-items: stretch;
}
#mec-countdown :where(.countdown *, .cd *, .timer *, .event-list *, li, .unit){
  font-size: clamp(0.9rem, 1.6vw, 1.05rem); line-height: 1.25; word-break: break-word;
}
#mec-countdown :where(h3, h4){ font-size: clamp(1.05rem, 2.4vw, 1.25rem); margin: 4px 0 6px; }
#mec-countdown :where(table){ width: 100%; border-collapse: collapse; }
#mec-countdown :where(th, td){ padding: .35rem .5rem; border-bottom: 1px solid #e5e7eb; font-size: clamp(0.9rem, 1.6vw, 1rem); }

/* ======= Slideshow (1 Bild, mittig) ======= */
.slideshow-section{ margin: 10px auto 20px; }
.slideshow-scroller{
  --frame-h: clamp(260px, 55vh, 520px);
  overflow: hidden; -webkit-overflow-scrolling: auto;
  border:1px solid var(--ring); border-radius:14px; background:#fff; box-shadow: var(--shadow);
  padding:0;
}
.slideshow-inner{
  display:flex; align-items:center; justify-content:center;
  height: var(--frame-h);
  padding:10px; width: 100%; cursor: zoom-in;
}
.slideshow-inner > style,
.slideshow-inner > script,
.slideshow-inner > link,
.slideshow-inner > template,
.slideshow-inner > noscript { display:none !important; }
.slideshow-inner > figure,
.slideshow-inner > a,
.slideshow-inner > div,
.slideshow-inner > picture,
.slideshow-inner > img{
  flex: 0 1 auto; max-width: 100%; height: 100%;
  display:flex; align-items:center; justify-content:center;
  background:#0b0b0b; border-radius:12px; box-shadow: var(--shadow); padding:0;
}
.slideshow-inner > figure ~ *,
.slideshow-inner > a ~ *,
.slideshow-inner > div ~ *,
.slideshow-inner > picture ~ *,
.slideshow-inner > img ~ * { display:none !important; }
.slideshow-inner img{
  max-height: 100%; max-width: 100%; width: auto; height: auto;
  object-fit: contain; display: block; border-radius:12px;
  background: transparent; -webkit-user-drag: none; user-select: none;
  pointer-events: auto !important;
}
/* Slider-Killer */
.slideshow-inner .slick-track,
.slideshow-inner .swiper-wrapper,
.slideshow-inner .owl-stage,
.slideshow-inner .glide__slides,
.slideshow-inner .tns-inner,
.slideshow-inner .tns-slider {
  transform: none !important; transition: none !important; left: auto !important; width: 100% !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  gap: 0 !important; height: 100% !important; margin: 0 auto !important;
}
.slideshow-inner .slick-slide,
.slideshow-inner .swiper-slide,
.slideshow-inner .owl-item,
.slideshow-inner .glide__slide,
.slideshow-inner .tns-item {
  width: auto !important; float: none !important; display: flex !important;
  align-items: center !important; justify-content: center !important; height: 100% !important;
  opacity: 1 !important; visibility: visible !important;
}
.slideshow-inner .slick-list,
.slideshow-inner .swiper,
.slideshow-inner .owl-stage-outer,
.slideshow-inner .glide__track,
.slideshow-inner .tns-outer { overflow: visible !important; height: 100% !important; }
.slideshow-inner .slick-arrow,
.slideshow-inner .slick-dots,
.slideshow-inner .swiper-button-next,
.slideshow-inner .swiper-button-prev,
.slideshow-inner .swiper-pagination,
.slideshow-inner .glide__arrows,
.slideshow-inner .glide__bullets,
.slideshow-inner .owl-nav,
.slideshow-inner .owl-dots { display: none !important; }

/* ======= Lightbox ======= */
.lightbox[hidden]{ display:none !important; }
.lightbox{
  position:fixed; inset:0; z-index:10000;
  background: rgba(0,0,0,.92);
  display:flex; align-items:center; justify-content:center;
  touch-action: pan-y;
}
.lb-stage{
  position:relative; width:100%; height:100%;
  background-position:center; background-repeat:no-repeat; background-size:contain;
  cursor:zoom-out;
}
.lb-close, .lb-arrow, .lb-play{
  position:fixed; z-index:10001;
  width:42px; height:42px; border:0; border-radius:999px;
  background: rgba(255,255,255,.12);
  color:#fff; font-size:26px; line-height:1; cursor:pointer;
  backdrop-filter: blur(4px);
  display:flex; align-items:center; justify-content:center;
  user-select:none;
}
.lb-close:hover, .lb-arrow:hover, .lb-play:hover{ background: rgba(255,255,255,.22); }
.lb-close{ top:14px; right:14px; }
.lb-play{ top:14px; left:14px; font-size:20px; width:40px; height:40px; }
.lb-arrow{ top:50%; transform:translateY(-50%); font-size:28px; }
.lb-prev{ left:16px; }
.lb-next{ right:16px; }
.lb-counter{
  position:fixed; bottom:14px; left:50%; transform:translateX(-50%);
  color:#fff; background: rgba(0,0,0,.35);
  padding:6px 10px; border-radius:999px; font: 600 14px/1 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  z-index:10002; user-select:none;
}
.no-download, .no-download *{ -webkit-user-select:none; user-select:none; -webkit-touch-callout:none; }

/* ======= Besucher-Panel (Fallback) ======= */
#mec-statboard, #mec-statboard * { box-sizing: border-box; }
#mec-statboard {
  --tile-bg:#0f172a; --ring:#1f2937; --txt:#e5e7eb; --muted:#9ca3af;
  --grad1: linear-gradient(135deg,#6366f1 0%,#22d3ee 100%);
  --grad2: linear-gradient(135deg,#f59e0b 0%,#ef4444 100%);
  --grad3: linear-gradient(135deg,#10b981 0%,#06b6d4 100%);
  --grad4: linear-gradient(135deg,#8b5cf6 0%,#ec4899 100%);
  color: var(--txt); margin: 24px auto 16px; padding: 0 12px; max-width: var(--page-max);
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
#mec-statboard .grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
#mec-statboard .tile {
  position:relative; background:var(--tile-bg); border:1px solid var(--ring);
  border-radius:16px; padding:16px 14px; min-height:110px; overflow:hidden;
  box-shadow:0 10px 24px rgba(2,6,23,.25), inset 0 1px 0 rgba(255,255,255,.05);
}
#mec-statboard .badge { position:absolute; top:-18px; right:-18px; width:90px; height:90px; border-radius:50%;
  filter: blur(10px) opacity(.35); pointer-events:none; }
#mec-statboard .t1 .badge { background:var(--grad1) } .t2 .badge { background:var(--grad2) }
#mec-statboard .t3 .badge { background:var(--grad3) } #mec-statboard .t4 .badge { background:var(--grad4) }
#mec-statboard .label { font-size:.9rem; color:var(--muted); letter-spacing:.02em; margin-bottom:6px; display:flex; gap:8px; align-items:center; }
#mec-statboard .num { font-size:2rem; font-weight:800; line-height:1.1; font-variant-numeric:tabular-nums; letter-spacing:.02em; }
#mec-statboard .sub { margin-top:6px; font-size:.9rem; color:var(--muted); }
#mec-statboard .dot { width:10px; height:10px; border-radius:999px; display:inline-block; }
#mec-statboard .t1 .dot { background:#818cf8 } .t2 .dot { background:#fbbf24 }
#mec-statboard .t3 .dot { background:#34d399 } #mec-statboard .t4 .dot { background:#a78bfa }
@media (max-width: 900px){ #mec-statboard .grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width: 460px){ #mec-statboard .grid{ grid-template-columns:1fr; } }

/* === MEC Countdown – hübsches Theme (übersteuert Basisregeln) === */
#mec-countdown .cd-wrap { transition: opacity .6s ease; }
#mec-countdown .cd-wrap.fade-out { opacity: 0; }
/* Überschrift */
#mec-countdown .cd-title{
  margin: 0 0 8px;
  color: #6F0000;
  font-weight: 800;
  font-size: clamp(1.1rem, 2.5vw, 1.5rem);
  text-align: center;
  letter-spacing: .2px;
}
/* Chip */
#mec-countdown .cd{
  display: inline-flex;
  align-items: flex-end;
  gap: clamp(10px, 3vw, 18px);
  padding: clamp(8px, 2vw, 12px) clamp(14px, 3vw, 22px);
  border-radius: 9999px;
  background: linear-gradient(135deg, #6F0000 0%, #9a1b1b 100%);
  color: #fff;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 12px 28px rgba(111,0,0,.35), inset 0 1px 0 rgba(255,255,255,.15);
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
}
/* Ziffernspalten */
#mec-countdown .cd span:not(.sep){
  display: flex; flex-direction: column; align-items: center; line-height: 1.05;
  min-width: clamp(44px, 9vw, 66px);
}
#mec-countdown .cd #d,
#mec-countdown .cd #h,
#mec-countdown .cd #m,
#mec-countdown .cd #s{
  font-weight: 800; font-size: clamp(26px, 8vw, 42px); letter-spacing: .5px;
  text-shadow: 0 2px 8px rgba(0,0,0,.25);
}
/* Beschriftungen */
#mec-countdown .cd #d::after{ content: "Tage"; }
#mec-countdown .cd #h::after{ content: "Stunden"; }
#mec-countdown .cd #m::after{ content: "Minuten"; }
#mec-countdown .cd #s::after{ content: "Sekunden"; }
#mec-countdown .cd #d::after,
#mec-countdown .cd #h::after,
#mec-countdown .cd #m::after,
#mec-countdown .cd #s::after{
  margin-top: 4px; font-weight: 600; font-size: clamp(10px, 2.8vw, 12px); opacity: .9;
}
/* Doppelpunkte schlank … */
#mec-countdown .cd .sep{
  align-self: center; font-weight: 800; opacity: .7;
  padding: 0 clamp(4px, 1.8vw, 8px); font-size: clamp(20px, 6vw, 30px);
  text-shadow: 0 1px 4px rgba(0,0,0,.25);
}
/* … erstes „d“ nach Tagen ausblenden (wir nutzen Labels) */
#mec-countdown #countdown > .sep:first-of-type{ display:none; }
/* Sehr kleine Displays: Doppelpunkte ausblenden */
@media (max-width: 420px){
  #mec-countdown .cd .sep{ display:none; }
  #mec-countdown .cd{ gap: clamp(8px, 3.2vw, 12px); padding: 8px 10px; }
}
/* Fallback-Kacheln angleichen */
#mec-countdown.cd-fallback .cd-auto .cd-box{
  background: linear-gradient(135deg, #0f172a 0%, #1f2937 100%);
  color: #e5e7eb;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 24px rgba(2,6,23,.35), inset 0 1px 0 rgba(255,255,255,.06);
}
#mec-countdown.cd-fallback .cd-auto .cd-val{
  font-weight: 800; text-shadow: 0 2px 8px rgba(0,0,0,.25);
}

/* ---- Nächste Termine (Preview über dem Countdown) ---- */
.next-events{ margin: 8px 0 12px; }
.next-events-list{
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: 1fr; gap: 10px;
}
@media (min-width: 720px){ .next-events-list{ grid-template-columns: repeat(3, 1fr); } }
.next-event{
  background: #fff; border:1px solid var(--ring); border-left-width:6px;
  border-radius: 12px; padding: 10px 12px; box-shadow: var(--shadow);
}
.next-event.mec{       border-left-color:#6F0000; }
.next-event.eisenbahn{ border-left-color:#0f172a; }
.ne-line1{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:6px; }
.ne-badge{
  display:inline-block; font-weight:700; font-size:.75rem; letter-spacing:.02em;
  padding:4px 8px; border-radius:999px; color:#fff; background:#6F0000;
}
.next-event.eisenbahn .ne-badge{ background:#0f172a; }
.ne-date{ color:#475569; font-size:.95rem; white-space:nowrap; }
.ne-title{ font-weight:800; font-size:1.05rem; line-height:1.2; }
.ne-title a{ color:inherit; text-decoration:none; }
.ne-title a:hover{ text-decoration:underline; }
.ne-place{ color:#64748b; margin-top:2px; font-size:.95rem; }
.next-events-more{ margin-top:6px; text-align:right; }
.ne-more{ color:#0b5cab; text-decoration:underline; }
.next-events-empty{ color:#64748b; }

/* === NAV + TICKER: einheitlich #3e3e3e === */
.nav,
.navigation,
.site-nav{
  background: #3e3e3e !important;
  color: #fff; /* gute Lesbarkeit */
}

/* Desktop-Menü-Links (Hover etwas heller) */
.nav > ul > li > a,
.navigation > ul > li > a{
  color: #fff;
}
.nav > ul > li > a:hover,
.navigation > ul > li > a:hover{
  background: #575757;
}

/* Mobiles Dropdown im Burger-Menü */
@media (max-width: 900px){
  html.js .nav-menu{
    background: #3e3e3e !important;
  }
}

/* Ticker passend zur Navigation */
.ticker{
  background: #3e3e3e !important;
  color: #d1d5db; /* lichtgrau, gut lesbar auf #3e3e3e */
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(0,0,0,0.25);
}

/* Badge im Ticker bleibt akzentuiert */
.ticker__item .badge{
  background: var(--primary);
  color: #fff;
}
/* ==== Burger-Button optisch sauber + links, Brand mittig ==== */

/* Mobile Kopfzeile als 3er-Grid:
   [Burger][Brand][Spacer]  → Brand bleibt mittig, Burger links */
@media (max-width: 900px){
  .site-nav .nav-bar{
    display: grid;
    grid-template-columns: 42px 1fr 42px;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
  }
  .site-nav .nav-toggle{ grid-column: 1; justify-self: start; }
  .site-nav .brand{ grid-column: 2; justify-self: center; }
  .site-nav .nav-spacer{ grid-column: 3; justify-self: end; }
}

/* Button-Optik: runder, gut sichtbarer Tap-Target auf dunklem Grund */
.nav-toggle{
  width: 42px; height: 42px;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  box-shadow: 0 2px 6px rgba(0,0,0,.25), inset 0 0 0 1px rgba(0,0,0,.15);
  color: #fff; cursor: pointer;
  display:flex; align-items:center; justify-content:center;
  transition: background .15s ease, transform .05s ease, border-color .15s ease;
}
.nav-toggle:hover{ background: rgba(255,255,255,.16); }
.nav-toggle:active{ transform: translateY(1px); }
.nav-toggle:focus-visible{
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* Burger-Striche: gleichmäßig, sauber animiert */
.nav-toggle .bar{
  width: 22px; height: 2px; background: currentColor;
  display: block; border-radius: 2px;
  transition: transform .2s ease, opacity .2s ease;
}
.nav-toggle .bar + .bar{ margin-top: 5px; }

/* X-Animation */
.nav-toggle.is-open .bar:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open .bar:nth-child(2){ opacity: 0; }
.nav-toggle.is-open .bar:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* Desktop: klassische Leiste, Button ausgeblendet */
@media (min-width: 901px){
  .site-nav .nav-bar{
    max-width: 1100px; margin: 0 auto; padding: 8px 16px;
    display:flex; align-items:center; justify-content: center;
  }
  .nav-toggle{ display: none; }
  .brand{ margin-right: auto; } /* optional: Brand links auf Desktop */
}

/* Mobiles Dropdown übernimmt #3e3e3e Hintergrund (falls nicht schon gesetzt) */
@media (max-width: 900px){
  html.js .nav-menu{
    background: #3e3e3e;
    border-top: 1px solid rgba(255,255,255,.15);
  }
}

