/*
Theme Name: MEC Eferding
Theme URI: http://192.168.1.115:8089/
Author: MEC Eferding / mann und mouse
Description: Warmes, modernes Theme für den Modelleisenbahnclub Eferding — Foto-Hero mit ÖBB-Anzeigetafel (zeigt den nächsten Termin), warme Creme/Sand-Palette, Marken-Rot, Mehrseiten-Struktur. Basiert auf Design-Entwurf 16.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: mec-eferding
*/

  /* ---------- THEME TOKENS (warm: Creme/Sand + Marken-Rot + Messing-Amber) ---------- */
  html[data-theme="dark"]{
    --bg:#15110b; --bg-2:#1c1710; --panel:#211b13; --panel-2:#28211a;
    --line:#352c20; --txt:#f3ede2; --muted:#a99a85;
    --red:#e8503f; --red-d:#d23f30;          /* Hauptakzent: Marken-Rot (warm) */
    --steel:#e0a94a; --steel-soft:#5a4622;   /* Zweitfarbe: Messing/Amber (warm statt Stahlblau) */
    --ok:#6bbf7a; --warn:#d6a93f;
    --nav-bg:rgba(21,17,11,.97); --menu-bg:rgba(21,17,11,.96);
    --dotgrid:rgba(255,240,220,.06);
    --icon-bg:rgba(232,80,63,.13);
    --eyebrow-bg:rgba(224,169,74,.13); --eyebrow-bd:rgba(224,169,74,.30);
    --shadow-lg:0 28px 64px rgba(0,0,0,.5);
    --shadow-card:0 14px 32px rgba(0,0,0,.4);
    --hero-glow-r:rgba(232,80,63,.16); --hero-glow-s:rgba(224,169,74,.14);
    /* "Besuch planen"-Panel */
    --visit-bg:linear-gradient(135deg,#221a12,#171009); --visit-bd:#352c20;
    --visit-txt:#fdf7ee; --visit-muted:#d8c9b4; --visit-small:#b6a78f;
    --visit-tile-bg:rgba(255,240,220,.05); --visit-tile-bd:rgba(255,235,205,.11); --visit-icbg:rgba(255,235,205,.07);
    --visit-eb-c:#e0bd84; --visit-eb-bg:rgba(224,169,74,.16); --visit-eb-bd:rgba(224,169,74,.32);
    --visit-ghost-bg:rgba(255,240,220,.07); --visit-ghost-bd:rgba(255,235,205,.20);
    /* Beitrags-Karte (immer dunkel & warm) */
    --beitrag-bg:linear-gradient(155deg,#2e2317,#1d150e); --beitrag-line:rgba(255,235,205,.14);
    --beitrag-txt:#f5ede0; --beitrag-muted:#c8b59a;
    /* Schienen-Motiv */
    --rail:#5a4d3a; --tie:#473c2c;
  }
  :root, [data-theme="light"]{
    --bg:#f8f3ea; --bg-2:#f0e8da; --panel:#fffdf8; --panel-2:#f6efe3;
    --line:#e7dcc9; --txt:#2a2117; --muted:#6e6151;
    --red:#cf3a2b; --red-d:#b32f24;
    --steel:#b3741a; --steel-soft:#e6d2a6;
    --ok:#2f9d5f; --warn:#b0791a;
    --nav-bg:rgba(248,243,234,.97); --menu-bg:rgba(248,243,234,.96);
    --dotgrid:rgba(60,45,20,.06);
    --icon-bg:rgba(207,58,43,.10);
    --eyebrow-bg:rgba(179,116,26,.12); --eyebrow-bd:rgba(179,116,26,.30);
    --shadow-lg:0 24px 56px rgba(80,60,30,.14);
    --shadow-card:0 12px 30px rgba(80,60,30,.10);
    --hero-glow-r:rgba(207,58,43,.10); --hero-glow-s:rgba(179,116,26,.10);
    /* "Besuch planen"-Panel — im Light-Mode hell & warm */
    --visit-bg:linear-gradient(135deg,#fffdf8,#f1e7d6); --visit-bd:#e7dcc9;
    --visit-txt:#2a2117; --visit-muted:#544938; --visit-small:#6e6151;
    --visit-tile-bg:#f6efe3; --visit-tile-bd:#e7dcc9; --visit-icbg:#efe6d6;
    --visit-eb-c:#8a6a2a; --visit-eb-bg:rgba(138,106,42,.12); --visit-eb-bd:rgba(138,106,42,.30);
    --visit-ghost-bg:#fffdf8; --visit-ghost-bd:#e2d6c2;
    /* Beitrags-Karte (immer dunkel & warm) */
    --beitrag-bg:linear-gradient(155deg,#2c2117,#1d160f); --beitrag-line:rgba(255,235,205,.12);
    --beitrag-txt:#f5ede0; --beitrag-muted:#c8b59a;
    /* Schienen-Motiv */
    --rail:#c9b894; --tie:#d9cdb2;
  }
  :root{ --r:14px; --maxw:1200px; }

  /* ---------- Schienen-Trennlinie (Eisenbahn-Motiv) ---------- */
  .rail{position:relative;height:18px;margin:0 auto;max-width:760px}
  .rail::before{content:"";position:absolute;left:0;right:0;top:4px;height:10px;
    background:repeating-linear-gradient(90deg,var(--tie) 0 3px,transparent 3px 20px)}
  .rail::after{content:"";position:absolute;left:0;right:0;top:3px;height:12px;
    border-top:2px solid var(--rail);border-bottom:2px solid var(--rail)}
  .rail.full{max-width:var(--maxw)}

  /* Hintergrund-Band für ruhigen Rhythmus (verbindet die Sektionen) */
  .band{background:var(--bg-2)}

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{background:var(--bg);color:var(--txt);font-family:'Inter',system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s}
  h1,h2,h3,.display{font-family:'Space Grotesk',sans-serif;letter-spacing:-0.02em;line-height:1.08}
  .mono{font-family:'JetBrains Mono',monospace;letter-spacing:0.03em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .accent{color:var(--red)} .steel{color:var(--steel)}

  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.5)}70%{box-shadow:0 0 0 8px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
  .dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 2s infinite}

  /* Ticker — schlicht, Marken-Rot */
  .ticker{background:var(--red);color:#fff;font-size:13.5px;font-weight:600;padding:8px 0}
  .ticker .wrap{display:flex;gap:16px;align-items:center;justify-content:center;flex-wrap:wrap}
  .ticker .chip{background:rgba(255,255,255,.18);padding:2px 12px;border-radius:6px;font-family:'JetBrains Mono'}

  /* Nav */
  /* Hinweis: KEIN backdrop-filter auf dem sticky Header – in einigen Browsern
     (GPU-Compositing) führt blur() + position:sticky zu unzuverlässigen Klick-
     Trefferzonen. Der Hintergrund ist nahezu deckend, der Blur ist daher
     optisch entbehrlich. */
  header.nav{position:sticky;top:0;z-index:50;background:var(--nav-bg);border-bottom:1px solid var(--line)}
  .nav .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;position:relative;z-index:1}
  .brand{display:flex;align-items:center;gap:13px}
  .brand img{height:46px;width:46px;object-fit:cover;border-radius:11px;border:1px solid var(--line);background:#fff}
  .brand b{font-family:'Space Grotesk';font-size:18px;font-weight:700;display:block;line-height:1}
  .brand span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
  nav ul{display:flex;gap:4px;list-style:none;font-size:14.5px;font-weight:600}
  nav a{color:var(--muted);transition:.2s;padding:8px 14px;border-radius:8px;white-space:nowrap}
  nav a:hover{color:var(--txt);background:var(--panel)}
  /* Untermenüs – Pfeil-Button (universell, beide Layouts).
     Der Pfeil dreht sich AUSSCHLIESSLICH über die Klasse .submenu-open,
     damit Pfeil und Untermenü nie auseinanderlaufen. */
  nav .submenu-toggle{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;margin-left:-7px;padding:8px;background:none;border:0;color:var(--muted);cursor:pointer;border-radius:8px}
  /* Nur transform animieren (kein margin-Wechsel) -> kein Layout-Versatz beim Öffnen */
  nav .submenu-toggle .chev{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-1px) rotate(45deg);transition:transform .2s}
  nav .menu-item-has-children.submenu-open > .submenu-toggle .chev{transform:translateY(1px) rotate(-135deg)}
  /* Desktop-Dropdown: NUR im horizontalen Layout (>1080px) – sonst leckt das
     Hover-Verhalten in das mobile Overlay (≤1080px) und Pfeil/Untermenü driften. */
  @media(min-width:1081px){
    /* Untermenü-Hinweis (Desktop): kleiner Pfeil als ::after direkt am Menüpunkt.
       Rein per CSS -> IMMER sichtbar, auch wenn das JS nicht lädt. Der per JS
       injizierte Umschalt-Button wird hier ausgeblendet (geöffnet wird per Hover). */
    nav .menu-item-has-children > a::after{content:"";display:inline-block;vertical-align:middle;margin-left:7px;width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-2px) rotate(45deg);transition:transform .2s}
    nav .submenu-toggle{display:none}
    /* Dropdown am Unterrand der Leiste verankern: .wrap ist position:relative und
       74px hoch -> top:100% landet exakt unter der Leiste (robust, keine Magic-Number).
       left:auto behält die statische Position des Eintrags (horizontal unter dem Punkt).
       Das Eltern-<li> bleibt UN-positioniert, damit sich das Dropdown auf .wrap bezieht. */
    nav .sub-menu{position:absolute;top:100%;left:auto;margin-top:1px;z-index:60;min-width:210px;display:none;flex-direction:column;gap:2px;list-style:none;padding:7px;background:var(--panel);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow-card)}
    nav .menu-item-has-children.submenu-open > .sub-menu{display:flex}
    nav .sub-menu li{width:100%}
    nav .sub-menu a{display:block;width:100%;color:var(--txt)}
    nav .sub-menu a:hover{background:var(--panel-2)}
    /* Hover über den GANZEN Menüpunkt öffnet das Untermenü; der Pfeil dreht mit.
       Die unsichtbare Brücke (::before) füllt den Spalt zwischen Eintrag und
       Dropdown, damit der Hover beim Runterfahren der Maus nicht abreißt. */
    nav .menu-item-has-children:hover > .sub-menu{display:flex}
    nav .menu-item-has-children:hover > a::after,
    nav .menu-item-has-children.submenu-open > a::after{transform:translateY(1px) rotate(-135deg)}
    nav .sub-menu::before{content:"";position:absolute;left:0;right:0;top:-24px;height:24px}
  }
  .btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:11px 21px;border-radius:9px;font-weight:600;font-size:14.5px;transition:.18s;border:0;cursor:pointer;white-space:nowrap}
  .btn:hover{background:var(--red-d);transform:translateY(-1px)}
  .btn.ghost{background:var(--panel);color:var(--txt);box-shadow:inset 0 0 0 1px var(--line)}
  .btn.ghost:hover{background:var(--panel-2)}
  .nav-cta{display:flex;gap:10px;align-items:center}
  .themetoggle{width:44px;height:44px;border-radius:9px;border:1px solid var(--line);background:var(--panel);color:var(--txt);font-size:18px;cursor:pointer;display:grid;place-items:center;transition:.2s}
  .themetoggle:hover{background:var(--panel-2)}

  /* Hero — großes Hintergrundbild */
  .hero{position:relative;padding:108px 0 100px;min-height:640px;overflow:hidden;display:flex;align-items:center;
    background-image:
      linear-gradient(102deg,rgba(24,14,7,.90) 0%,rgba(24,14,7,.66) 44%,rgba(24,14,7,.32) 100%),
      url('assets/hero-loks.jpg');
    background-size:cover;background-position:center 42%;background-repeat:no-repeat}
  /* sanfter Übergang vom Bild in die warme Seitenfläche darunter */
  .hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:140px;z-index:1;pointer-events:none;
    background:linear-gradient(to bottom,transparent,var(--bg))}
  .hero .wrap{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
  .hero-col{display:flex;flex-direction:column;justify-content:center;color:#fff}
  .tag{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.12);backdrop-filter:blur(6px);border-radius:8px;padding:8px 15px;font-size:13px;color:#f3ece1;margin-bottom:24px}
  .tag b{color:#ffcf8a;font-family:'JetBrains Mono';font-weight:600}
  .hero h1{font-size:clamp(42px,5.8vw,66px);font-weight:700;margin-bottom:18px;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.35)}
  .hero h1 .hl{position:relative;color:#ff7a63}
  .hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:8px;background:#ff7a63;opacity:.26;border-radius:4px;z-index:-1}
  .hero p.lead{font-size:18px;color:rgba(255,247,238,.88);max-width:540px;margin:30px 0 44px;text-shadow:0 1px 14px rgba(0,0,0,.3)}
  .hero-cta{display:flex;gap:13px;flex-wrap:wrap;align-items:center}
  .hero .btn.ghost{background:rgba(255,255,255,.14);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.32);backdrop-filter:blur(6px)}
  .hero .btn.ghost:hover{background:rgba(255,255,255,.22)}
  .hero-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:34px}
  .chip2{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.20);backdrop-filter:blur(6px);border-radius:8px;padding:9px 15px;font-size:13.5px;font-weight:600;color:#f0e8dc}
  .chip2::before{content:"";width:7px;height:7px;border-radius:50%;background:#ffcf8a}

  /* Hero visual + countdown */
  .hero-visual{position:relative;display:flex;flex-direction:column;justify-content:flex-start}
  /* ÖBB-Bahnsteiganzeiger — eine authentische blaue Tafel als Akzent (bewusst beibehalten) */
  .nextcard{position:relative;width:100%;margin:0 0 16px;background:linear-gradient(180deg,rgba(46,102,228,.37) 0%,rgba(35,88,207,.37) 55%,rgba(31,78,194,.37) 100%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(120,160,240,.45);border-radius:9px;padding:0;box-shadow:var(--shadow-card);overflow:hidden;font-family:'Inter',sans-serif;color:#f2f5ff}
  .zza-clock{position:absolute;top:0;right:0;z-index:3;background:#0f2c74;color:#fff;font-weight:700;font-size:17px;letter-spacing:.02em;padding:9px 13px 11px;border-bottom-left-radius:16px;font-variant-numeric:tabular-nums;white-space:nowrap;box-shadow:-1px 1px 0 rgba(0,0,0,.15)}
  .zza-main{padding:13px 15px 10px}
  .zza-line{display:flex;align-items:center;gap:9px;margin-bottom:1px}
  .zza-logo{background:#fff;color:#e1231e;font-weight:800;font-size:13px;letter-spacing:.01em;padding:2px 6px;border-radius:3px;line-height:1.18}
  .zza-badge{display:inline-flex;align-items:center;gap:5px;color:#fff;font-weight:700;font-size:15px}
  .zza-badge .s{display:grid;place-items:center;width:19px;height:19px;border:2px solid #fff;border-radius:50%;font-size:11px;font-weight:800;line-height:1}
  .zza-dest{font-weight:800;font-size:42px;line-height:1.14;letter-spacing:-.02em;text-shadow:0 0 7px rgba(200,218,255,.35);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 120px 3px 0}
  .zza-via{font-size:15px;color:#cfdaf8;margin-top:2px}
  .zza-via i{font-style:normal}
  .zza-icons{position:absolute;right:14px;bottom:56px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:#e3eaff}
  .zza-icons .star{font-size:16px;line-height:1}
  .zza-icons .wagon{width:26px;height:16px;display:flex;flex-direction:column;gap:2.5px}
  .zza-icons .wagon i{flex:1;background:#d3dcff;border-radius:2px}
  .zza-second{display:flex;align-items:center;gap:9px;padding:5px 15px 9px}
  .zza-second .zza-2dest{font-weight:700;font-size:16px;flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:baseline;gap:0 9px}
  .zza-second .zza-2date{white-space:nowrap}
  /* Adresse/Hinweis: rutscht bei Platzmangel unter das Datum */
  .zza-second .zza-2note{font-weight:600;font-size:14.5px;color:#cfdaf8}
  .zza-second .zza-logo{font-size:11px;padding:1px 5px}
  .zza-second .zza-badge{font-size:13px}
  .zza-second .zza-badge .s{width:16px;height:16px;font-size:9px;border-width:1.5px}
  .zza-plat{font-weight:800;font-size:23px;min-width:28px;text-align:right;font-variant-numeric:tabular-nums}

  /* Sections */
  section{padding:64px 0;position:relative}
  .sec-head{margin-bottom:44px;max-width:660px}
  .sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
  .eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:12.5px;color:var(--steel);text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px;background:var(--eyebrow-bg);border:1px solid var(--eyebrow-bd);padding:5px 13px;border-radius:6px}
  .sec-head h2{font-size:clamp(28px,3.8vw,42px);font-weight:700;margin-bottom:12px}
  .sec-head p{color:var(--muted);font-size:16.5px}

  /* Anlagen H0 / N */
  .anlagen{display:grid;grid-template-columns:1fr 1fr;gap:26px}
  .anlage{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.22s;position:relative}
  .anlage:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
  .anlage .im{position:relative;height:262px;overflow:hidden}
  .anlage .im img{width:100%;height:100%;object-fit:cover;transition:.5s}
  .anlage:hover .im img{transform:scale(1.04)}
  .anlage .gauge{position:absolute;top:16px;left:16px;display:flex;align-items:center;gap:8px;background:rgba(20,15,8,.62);backdrop-filter:blur(6px);border:1px solid rgba(255,240,220,.18);color:#fff;padding:7px 14px;border-radius:8px;font-family:'Space Grotesk';font-weight:700;font-size:15px}
  .anlage.h0 .gauge .ring{background:var(--red)}
  .anlage.n .gauge .ring{background:var(--steel)}
  .gauge .ring{width:10px;height:10px;border-radius:50%}
  .anlage .status{position:absolute;top:16px;right:16px;padding:7px 13px;border-radius:8px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:7px;backdrop-filter:blur(6px);color:#fff;background:rgba(20,15,8,.58);border:1px solid rgba(255,240,220,.18)}
  .anlage .status .sd{width:8px;height:8px;border-radius:50%}
  .anlage .bd{padding:25px}
  .anlage h3{font-size:23px;margin-bottom:8px}
  .anlage p{color:var(--muted);font-size:15px;margin-bottom:17px}
  /* Ganze Karte klickbar: der „Mehr →"-Link spannt sich per ::after über die
     gesamte Karte. Da der Link nur bei gesetztem Ziel existiert (siehe Template),
     ist die Karte automatisch NUR dann klickbar, wenn ein Link hinterlegt ist. */
  .anlage .more{position:static}
  .anlage .more::after{content:"";position:absolute;inset:0;z-index:2}
  .specs{display:flex;flex-wrap:wrap;gap:8px}
  .spec{font-family:'JetBrains Mono';font-size:11.5px;background:var(--bg-2);border:1px solid var(--line);padding:6px 11px;border-radius:7px}

  /* Features */
  .features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .feat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:24px 20px;transition:.2s}
  .feat:hover{transform:translateY(-3px);background:var(--panel-2)}
  .feat .ic{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-size:21px;margin-bottom:15px;background:var(--icon-bg)}
  .feat h3{font-size:17px;margin-bottom:6px}
  .feat p{color:var(--muted);font-size:14px}

  /* Termine — die nächsten Fahrtage */
  .termine{display:grid;grid-template-columns:1fr;gap:16px;max-width:680px}
  .termin{display:flex;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.22s}
  .termin:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
  .t-date{flex:0 0 94px;background:var(--bg-2);border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px 0;text-align:center}
  .t-date .d{font-family:'Space Grotesk';font-size:36px;font-weight:700;line-height:1;color:var(--steel)}
  .t-date .m{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-top:4px}
  .t-date .y{font-size:11px;color:var(--muted);margin-top:2px}
  .t-body{padding:18px 20px;display:flex;flex-direction:column;justify-content:center}
  .t-flag{align-self:flex-start;font-family:'JetBrains Mono';font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:#fff;background:var(--red);padding:3px 9px;border-radius:5px;margin-bottom:9px}
  .t-body h3{font-size:19px;margin-bottom:6px}
  .t-meta{font-family:'JetBrains Mono';font-size:13px;color:var(--steel);font-weight:600;display:flex;align-items:center;gap:7px}
  .t-meta::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--steel)}
  .t-desc{font-size:14px;color:var(--muted);margin-top:8px}
  .termin.is-next{border-color:transparent;box-shadow:0 0 0 2px var(--red)}
  .termin.is-next .t-date{background:var(--red);border-right-color:transparent}
  .termin.is-next .t-date .d,.termin.is-next .t-date .m{color:#fff}
  .termin.is-next .t-date .y{color:rgba(255,255,255,.82)}

  /* About */
  .about{position:relative}
  .about .grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
  .about img{width:100%;border-radius:var(--r);border:1px solid var(--line)}
  .about blockquote{font-family:'Space Grotesk';font-size:23px;font-weight:600;line-height:1.4;margin:20px 0;padding-left:20px;border-left:3px solid var(--red);color:var(--txt)}
  .about .lead{color:var(--muted);font-size:16.5px}
  .factbar{display:flex;flex-wrap:wrap;gap:26px;margin-top:24px}
  .factbar .f b{font-family:'Space Grotesk';font-size:28px;display:block;line-height:1;color:var(--red)}
  .factbar .f span{font-size:13px;color:var(--muted)}

  /* News */
  .news{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.22s}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card)}
  .card .im{height:180px;overflow:hidden}
  .card .im img{width:100%;height:100%;object-fit:cover;transition:.4s}
  .card:hover .im img{transform:scale(1.04)}
  .card .bd{padding:21px}
  .card .when{display:inline-block;font-family:'JetBrains Mono';font-size:11px;color:var(--steel);background:var(--eyebrow-bg);border:1px solid var(--eyebrow-bd);padding:3px 10px;border-radius:6px;margin-bottom:11px}
  .card .when.pinned{color:var(--red);background:var(--icon-bg);border-color:rgba(207,58,43,.3)}
  .card h3{font-size:18px;margin-bottom:8px;line-height:1.25}
  .card p{color:var(--muted);font-size:14px;margin-bottom:13px}
  .more{font-size:14px;font-weight:600;color:var(--red);display:inline-flex;gap:6px;align-items:center;transition:.2s}
  .card:hover .more{gap:10px}

  /* ---------- MITGLIED WERDEN ---------- */
  /* Schritte auf der Strecke */
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;margin-top:6px}
  .steps::before{content:"";position:absolute;top:31px;left:14%;right:14%;height:10px;z-index:0;
    background:repeating-linear-gradient(90deg,var(--tie) 0 3px,transparent 3px 18px);
    border-top:2px solid var(--rail);border-bottom:2px solid var(--rail)}
  .step{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center}
  .step .num{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;font-family:'Space Grotesk';font-weight:700;font-size:25px;background:var(--red);color:#fff;box-shadow:0 0 0 7px var(--bg),var(--shadow-card)}
  .step.todo .num{background:var(--panel);color:var(--red);border:2px solid var(--red);box-shadow:0 0 0 7px var(--bg)}
  .step h3{font-size:18px;margin:17px 0 6px}
  .step p{color:var(--muted);font-size:14.5px;max-width:250px}

  /* Leistungen + Beitrag */
  .member-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:start}
  .benefits{display:grid;gap:14px}
  .benefit{display:flex;gap:15px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px 20px;transition:.2s}
  .benefit:hover{transform:translateX(3px);box-shadow:var(--shadow-card)}
  .benefit .ic{flex:0 0 42px;height:42px;border-radius:11px;background:var(--icon-bg);display:grid;place-items:center;font-size:20px}
  .benefit h3{font-size:16.5px;margin-bottom:3px}
  .benefit p{color:var(--muted);font-size:14px}
  .beitrag{background:var(--beitrag-bg);border:1px solid var(--beitrag-line);border-radius:16px;padding:30px;color:var(--beitrag-txt);box-shadow:var(--shadow-card);position:relative;overflow:hidden}
  .beitrag::after{content:"";position:absolute;right:-60px;top:-60px;width:210px;height:210px;border-radius:50%;background:radial-gradient(circle,rgba(232,80,63,.24),transparent 70%)}
  .beitrag>*{position:relative;z-index:1}
  .beitrag .eyebrow{color:#e7c389;background:rgba(224,169,74,.16);border-color:rgba(224,169,74,.32)}
  .beitrag .price{display:flex;align-items:baseline;gap:9px;font-family:'Space Grotesk';margin:8px 0 4px}
  .beitrag .price .amt{font-size:46px;font-weight:700;letter-spacing:-.02em}
  .beitrag .price .per{color:var(--beitrag-muted);font-size:15px}
  .beitrag .sub{color:var(--beitrag-muted);font-size:14.5px;margin-bottom:20px}
  .beitrag ul{list-style:none;display:grid;gap:12px;margin-bottom:24px}
  .beitrag li{display:flex;gap:11px;align-items:center;font-size:14.5px}
  .beitrag li .c{flex:0 0 20px;height:20px;border-radius:50%;background:rgba(224,169,74,.18);color:var(--steel);display:grid;place-items:center;font-size:12px;font-weight:700}
  .beitrag .btn{width:100%;justify-content:center}

  /* Schreib uns — Kontaktformular */
  .mform{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:32px;max-width:840px;margin:0 auto}
  .mform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
  .mform label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
  .mform input,.mform textarea{width:100%;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:12px 14px;font:inherit;color:var(--txt);transition:.18s}
  .mform input:focus,.mform textarea:focus{outline:none;border-color:var(--red);background:var(--panel)}
  .mform textarea{min-height:128px;resize:vertical}
  .mform .actions{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
  .mform small{color:var(--muted);font-size:12.5px}

  /* FAQ */
  .faq{display:grid;gap:12px;max-width:840px;margin:0 auto}
  .faq details{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.2s}
  .faq details[open]{box-shadow:var(--shadow-card)}
  .faq summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:600;font-size:16px;display:flex;justify-content:space-between;align-items:center;gap:16px}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary::after{content:"+";font-family:'Space Grotesk';font-size:24px;color:var(--red);transition:.2s;line-height:1}
  .faq details[open] summary::after{transform:rotate(45deg)}
  .faq .a{padding:0 22px 20px;color:var(--muted);font-size:14.5px;line-height:1.7}

  /* Visit — Akzent-Panel, passt sich Light/Dark an */
  .visit{background:var(--visit-bg);border:1px solid var(--visit-bd);border-radius:18px;padding:52px;position:relative;overflow:hidden;color:var(--visit-txt)}
  .visit::after{content:"";position:absolute;right:-70px;top:-70px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(232,80,63,.18),transparent 70%)}
  .visit .railtop{position:absolute;left:0;right:0;top:0;height:14px;opacity:.5}
  .visit .railtop::before{content:"";position:absolute;left:0;right:0;top:4px;height:7px;background:repeating-linear-gradient(90deg,var(--visit-txt) 0 3px,transparent 3px 20px);opacity:.25}
  .visit .grid{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;position:relative;z-index:1}
  .visit .eyebrow{color:var(--visit-eb-c);background:var(--visit-eb-bg);border-color:var(--visit-eb-bd)}
  .visit h2{font-size:33px;margin-bottom:12px}
  .visit p{color:var(--visit-muted);font-size:16px;margin-bottom:20px}
  .visit .btn.ghost{background:var(--visit-ghost-bg);color:var(--visit-txt);box-shadow:inset 0 0 0 1px var(--visit-ghost-bd)}
  .info-list{list-style:none;display:grid;gap:12px}
  .info-list li{display:flex;gap:14px;align-items:center;background:var(--visit-tile-bg);border:1px solid var(--visit-tile-bd);border-radius:11px;padding:15px 17px}
  .info-list .ic{flex:0 0 42px;height:42px;border-radius:10px;background:var(--visit-icbg);display:grid;place-items:center;font-size:18px}
  .info-list b{display:block;font-size:15px}
  .info-list small{color:var(--visit-small);font-size:12.5px}

  /* Footer */
  footer{background:var(--bg-2);border-top:1px solid var(--line);padding:58px 0 28px}
  .fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:34px;margin-bottom:42px}
  footer h4{font-size:12.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:15px}
  footer ul{list-style:none;display:grid;gap:9px;font-size:14.5px;color:var(--muted)}
  footer a:hover{color:var(--txt)}
  .fbrand b{font-family:'Space Grotesk';font-size:20px;display:block;margin-bottom:8px}
  .fbrand p{color:var(--muted);font-size:14px;max-width:290px}
  .socials{display:flex;gap:10px;margin-top:17px}
  .socials a{width:42px;height:42px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.2s}
  .socials a:hover{border-color:var(--red);color:var(--txt)}
  .copy{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;color:var(--muted);font-size:13px;flex-wrap:wrap;gap:10px}

  @media(max-width:900px){
    .hero .wrap,.about .grid,.visit .grid,.member-grid{grid-template-columns:1fr}
    .anlagen,.news,.features,.fgrid,.termine{grid-template-columns:1fr}
    .features{grid-template-columns:1fr 1fr}
    .steps{grid-template-columns:1fr;gap:28px}
    .steps::before{display:none}
    .mform .row{grid-template-columns:1fr}
    nav ul{display:none}
    .hero{min-height:0;padding:0 0 44px;align-items:flex-start}
    .hero .wrap{gap:22px}
    .hero-visual{order:-1;margin-bottom:0}
    .zza-dest{font-size:38px;padding-right:104px}
    /* Mobil: Anzeigetafel randlos über die volle Breite (bricht aus der 24px-Polsterung der .wrap aus) */
    .hero-visual .nextcard{margin-left:-24px;margin-right:-24px;width:calc(100% + 48px);border-radius:0;border-left:none;border-right:none}
  }
  @media(max-width:560px){
    .features{grid-template-columns:1fr}.visit{padding:32px 22px}
    .zza-dest{font-size:30px;padding-right:84px}
    .zza-clock{font-size:16px;padding:7px 10px 9px}
    .zza-second .zza-2dest{font-size:14px}
    /* Mobil: Hero entschlacken — den Spur-Pill ausblenden */
    .hero .tag{display:none}
    /* Mobil (Hochformat): "Mitglied werden"-Button aufräumen — einzeilig, kompakter,
       und den Brand-Untertitel ausblenden, damit der Button neben Logo + Toggle passt */
    .nav .btn{white-space:nowrap;padding:9px 15px;font-size:13.5px}
    .brand span span{display:none}
    .brand img{height:40px;width:40px}
  }

/* ============================================================
   Inhaltsseiten (page.php / single.php / index.php)
   — ergänzt das sektionsbasierte Design um Fließtext-Typografie
   ============================================================ */
/* Kompaktes Titel-Band (alle Unterseiten) */
.page-head{position:relative;overflow:hidden;padding:38px 0 34px;
  background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%);border-bottom:1px solid var(--line)}
.page-head .wrap{position:relative;z-index:1}
.page-head::after{content:"";position:absolute;left:0;right:0;bottom:0;height:7px;z-index:0;
  background:repeating-linear-gradient(90deg,var(--tie) 0 3px,transparent 3px 18px);opacity:.5}
.page-head .crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-family:'JetBrains Mono';
  font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:11px}
.page-head .crumbs a{color:var(--steel)}
.page-head .crumbs a:hover{color:var(--red)}
.page-head .crumbs .sep{opacity:.55}
.page-head h1{font-family:'Space Grotesk';font-size:clamp(30px,4.6vw,46px);font-weight:700;letter-spacing:-.02em;line-height:1.12}
.page-head .page-meta{margin-top:9px;font-size:14px;color:var(--muted)}
.page-body{padding-top:32px}
.wrap.narrow{max-width:820px}
.entry-thumb{margin-bottom:28px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.entry-thumb img{display:block;width:100%;height:auto}
.entry-content{font-size:17px;line-height:1.75;color:var(--txt)}
.entry-content > * + *{margin-top:18px}
.entry-content h2{font-family:'Space Grotesk';font-size:28px;margin-top:38px;line-height:1.2}
.entry-content h3{font-family:'Space Grotesk';font-size:22px;margin-top:30px}
.entry-content h4{font-family:'Space Grotesk';font-size:18px;margin-top:24px}
.entry-content a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
.entry-content img{max-width:100%;height:auto;border-radius:10px}
.entry-content ul,.entry-content ol{padding-left:1.3em}
.entry-content li{margin-top:8px}
.entry-content blockquote{border-left:3px solid var(--steel);padding:6px 0 6px 18px;color:var(--muted);font-style:italic}
.entry-content table{width:100%;border-collapse:collapse;font-size:15.5px}
.entry-content td,.entry-content th{border:1px solid var(--line);padding:9px 11px;text-align:left}
.entry-content figure{margin:20px 0}
.entry-content figcaption{font-size:13.5px;color:var(--muted);margin-top:6px}
.back-link{margin-top:36px}

/* Formularfelder (z. B. Contact Form 7) im warmen Stil */
.entry-content input[type=text],.entry-content input[type=email],
.entry-content input[type=tel],.entry-content input[type=url],
.entry-content input[type=number],.entry-content input[type=date],
.entry-content textarea,.entry-content select{
  width:100%;max-width:560px;padding:12px 14px;border:1px solid var(--line);
  border-radius:9px;background:var(--panel);color:var(--txt);font:inherit;margin-top:6px}
.entry-content textarea{min-height:150px}
.entry-content label{display:block;font-weight:600;margin-top:16px}
.entry-content .wpcf7-submit,.entry-content button[type=submit],
.entry-content input[type=submit]{
  background:var(--red);color:#fff;border:0;border-radius:9px;padding:13px 24px;
  font-weight:600;font-size:14.5px;cursor:pointer;width:auto;margin-top:18px;transition:.18s}
.entry-content .wpcf7-submit:hover,.entry-content button[type=submit]:hover{background:var(--red-d)}

/* Pagination (Blog/Archiv) */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:42px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;min-width:40px;justify-content:center;
  padding:9px 13px;border:1px solid var(--line);border-radius:8px;color:var(--txt);text-decoration:none}
.pagination .page-numbers.current{background:var(--red);color:#fff;border-color:var(--red)}
.pagination a.page-numbers:hover{border-color:var(--red)}

/* Beitrags-Stufen (Einzel / mit Partner) */
.beitrag .tiers{display:grid;gap:14px;margin:14px 0 18px}
.beitrag .tier{display:flex;align-items:baseline;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--beitrag-line)}
.beitrag .tier:last-child{border-bottom:0;padding-bottom:0}
.beitrag .tlabel{font-size:15px;font-weight:600;color:var(--beitrag-txt)}
.beitrag .tamt{font-family:'Space Grotesk';font-size:30px;font-weight:700;letter-spacing:-.02em;margin-left:auto}
.beitrag .tper{color:var(--beitrag-muted);font-size:14px}
.beitrag .tlabel small{display:block;font-weight:400;font-size:12px;color:var(--beitrag-muted);margin-top:2px}

/* ============================================================
   Footer – mobil ansprechender (statt karger Einzelspalte)
   ============================================================ */
@media(max-width:900px){
  footer{padding:46px 0 26px}
  /* Link-Gruppen 2-spaltig, Marke oben über volle Breite */
  .fgrid{grid-template-columns:1fr 1fr;gap:26px 22px;margin-bottom:30px}
  .fbrand{grid-column:1 / -1}
  .fbrand p{max-width:48ch}
  .socials{margin-top:14px}
  .copy{justify-content:center;text-align:center}
}
@media(max-width:560px){
  .fgrid{gap:22px 16px}
  footer h4{margin-bottom:11px}
  footer ul{gap:8px}
  .copy{flex-direction:column;gap:8px}
}

/* ============================================================
   Contact Form 7 – gepflegtes Formular-Layout
   ============================================================ */
.entry-content .wpcf7{background:var(--panel-2);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow-card)}
.entry-content .wpcf7 p{margin:0 0 16px}
.entry-content .cf7-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 22px}
.entry-content .wpcf7 label{display:block;font-weight:400}
.entry-content .wpcf7 label strong{display:block;font-weight:600;font-size:14px;margin:0 0 6px}
.entry-content .wpcf7 .req{color:var(--red)}
.entry-content .wpcf7 .opt{color:var(--muted);font-weight:400;font-size:12.5px}
.entry-content .wpcf7 input[type=text],
.entry-content .wpcf7 input[type=email],
.entry-content .wpcf7 input[type=tel],
.entry-content .wpcf7 textarea{max-width:none;margin-top:0;background:var(--panel)}
.entry-content .wpcf7 textarea{min-height:150px}

/* Zustimmungs-Box */
.cf7-consent label{display:flex;gap:11px;align-items:flex-start;font-size:13px;line-height:1.55;
  color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-weight:400}
.cf7-consent label strong{display:inline}
.cf7-consent input[type=checkbox]{margin:3px 0 0;flex:0 0 auto;width:18px;height:18px}
.cf7-consent a{color:var(--red)}

/* Submit */
.entry-content .wpcf7 .wpcf7-submit{margin-top:4px}

/* Status-/Validierungsmeldungen */
.entry-content .wpcf7-response-output{border-radius:10px;padding:12px 16px!important;margin:18px 0 0!important;font-size:14px}
.wpcf7-form.sent .wpcf7-response-output{border-color:var(--ok)!important;background:rgba(47,157,95,.12)}
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output,
.wpcf7-form.failed .wpcf7-response-output{border-color:var(--red)!important;background:rgba(207,58,43,.09)}
.wpcf7-not-valid-tip{color:var(--red);font-size:12.5px;margin-top:5px}
.entry-content .wpcf7 .wpcf7-not-valid{border-color:var(--red)!important;background:rgba(207,58,43,.05)}
@media(max-width:560px){
  .entry-content .cf7-grid{grid-template-columns:1fr}
  .entry-content .wpcf7{padding:20px}
}

/* ============================================================
   Cookie-Banner (Peadig EU Cookie Law) ans warme Design angleichen
   ============================================================ */
.pea_cook_wrapper{border-radius:12px!important;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  box-shadow:var(--shadow-card)!important;border:1px solid var(--line)!important;font-size:13.5px!important}
#pea_cook_btn,.pea_cook_btn{background:var(--red)!important;color:#fff!important;border:0!important;
  border-radius:8px!important;padding:9px 18px!important;font-weight:600!important;
  box-shadow:none!important;text-shadow:none!important;transition:.18s}
#pea_cook_btn:hover,.pea_cook_btn:hover{background:var(--red-d)!important}
.pea_cook_wrapper a#fom,.pea_cook_wrapper a{text-decoration:underline;opacity:.85}
.pea_cook_wrapper a:hover{opacity:1}

/* ============================================================
   Navigation: Desktop-Leiste + mobiles Hamburger-Menü
   ============================================================ */
.nav-toggle{display:none}
.nav-menu{display:flex;align-items:center;justify-content:space-between;flex:1;gap:18px;margin-left:28px}

@media(max-width:1080px){
  /* Logo + Hamburger über dem Overlay halten (Overlay liegt im selben
     Stacking-Context und hätte sonst die Leiste verdeckt) */
  .brand,.nav-toggle{position:relative;z-index:41}
  /* Hamburger-Button (ersetzt in der Leiste den Helligkeits-Button) */
  .nav-toggle{display:grid;place-items:center;width:46px;height:46px;padding:0;cursor:pointer;
    border:1px solid var(--line);background:var(--panel);border-radius:9px}
  .nav-toggle span{display:block;width:20px;height:2px;background:var(--txt);border-radius:2px;transition:transform .25s,opacity .2s}
  .nav-toggle span + span{margin-top:4px}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  /* Vollhöhen-Overlay-Menü (berücksichtigt mobile Adressleiste via dvh) */
  .nav-menu{position:fixed;top:0;left:0;right:0;height:100vh;height:100dvh;z-index:40;
    flex:none;margin:0;gap:0;flex-direction:column;align-items:stretch;justify-content:flex-start;
    overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;
    background:var(--menu-bg);
    padding:88px 0 32px;
    opacity:0;visibility:hidden;transform:translateY(-10px);
    transition:opacity .28s ease,transform .28s ease,visibility 0s linear .28s}
  .nav.open .nav-menu{opacity:1;visibility:visible;transform:none;
    transition:opacity .28s ease,transform .28s ease}
  .nav-menu nav{width:100%}
  .nav-menu nav ul{display:flex!important;flex-direction:column;gap:0;padding:4px 14px 0;font-size:19px}
  .nav-menu nav li + li{border-top:1px solid var(--line)}
  .nav-menu nav a{display:flex;align-items:center;justify-content:space-between;gap:12px;
    font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:-.01em;color:var(--txt);
    padding:15px 12px;border-radius:10px;transition:background .18s,padding .18s,color .18s}
  .nav-menu nav a::after{content:"→";font-size:15px;color:var(--steel);opacity:0;transform:translateX(-8px);transition:opacity .2s,transform .2s}
  .nav-menu nav a:hover,.nav-menu nav a:focus-visible{background:var(--panel);padding-left:18px}
  .nav-menu nav a:hover::after,.nav-menu nav a:focus-visible::after{opacity:.9;transform:none}
  .nav-menu nav .current-menu-item > a,.nav-menu nav .current_page_item > a{color:var(--red)}
  .nav-menu nav .current-menu-item > a::after,.nav-menu nav .current_page_item > a::after{content:"●";color:var(--red);opacity:1;transform:none;font-size:11px}

  /* Untermenüs – mobil (Accordion, per Pfeil-Button aufklappbar) */
  .nav-menu .menu-item-has-children{position:relative;display:block}
  .nav-menu .menu-item-has-children > a{padding-right:60px}
  .nav-menu .menu-item-has-children > a::after{content:none}
  .nav-menu .submenu-toggle{position:absolute;top:0;right:0;width:58px;height:56px;display:grid;place-items:center;background:none;border:0;color:var(--txt);cursor:pointer;z-index:1}
  .nav-menu .submenu-toggle .chev{width:10px;height:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-2px) rotate(45deg);transition:transform .2s}
  .nav-menu .menu-item-has-children.submenu-open > .submenu-toggle .chev{transform:translateY(2px) rotate(-135deg)}
  /* Basis-Dropdown-Styles zurücksetzen -> sauberes In-Flow-Accordion */
  .nav-menu .sub-menu{display:none!important;position:static;min-width:0;margin:0;padding:0 0 8px;background:none;border:0;border-radius:0;box-shadow:none;z-index:auto;flex-direction:column}
  .nav-menu .menu-item-has-children.submenu-open > .sub-menu{display:flex!important}
  .nav-menu .sub-menu a{font-size:16px;padding-left:26px;color:var(--muted)}

  /* CTA-Zeile: Umschalter links, „Mitglied werden" rechts (direkt unter den Links) */
  .nav-cta{flex-direction:row;align-items:center;gap:12px;margin-top:12px;padding:18px 16px 0;border-top:1px solid var(--line)}
  .nav-cta .themetoggle{flex:0 0 auto;width:50px;height:50px}
  .nav-cta .btn{flex:1;justify-content:center;padding:14px}
}
/* Bei offenem Menü: Seite nicht scrollbar (nur das Menü selbst) */
body.menu-open{overflow:hidden}

/* ============================================================
   Anfahrt-Seite (page-anfahrt.php)
   ============================================================ */
.anfahrt-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:32px;align-items:start}
.anfahrt-info{display:flex;flex-direction:column;gap:22px}
.anfahrt-info .info-list{gap:12px}
.anfahrt-info .info-list b a{color:inherit;text-decoration:none}
.anfahrt-info .btn{align-self:flex-start}
.anfahrt-map{display:block;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-card);transition:.18s}
.anfahrt-map:hover{border-color:var(--red)}
.anfahrt-map img{display:block;width:100%;height:auto}
.anfahrt-photo{margin:36px 0 0;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-card)}
.anfahrt-photo img{display:block;width:100%;height:auto}
.anfahrt-photo figcaption{padding:12px 16px;font-size:13.5px;color:var(--muted);background:var(--panel)}
@media(max-width:780px){
  .anfahrt-grid{grid-template-columns:1fr}
}

/* ============================================================
   Inhaltsseiten – WordPress-Ausrichtung, Bildunterschriften,
   Bilder, Lead-Absatz (gilt für alle Seiten/Beiträge)
   ============================================================ */
.entry-content::after{content:"";display:table;clear:both}
.entry-content > p:first-of-type{font-size:18.5px;line-height:1.7}

/* WP-Ausrichtungsklassen */
.entry-content .alignright{float:right;margin:6px 0 18px 26px;max-width:50%}
.entry-content .alignleft{float:left;margin:6px 26px 18px 0;max-width:50%}
.entry-content .aligncenter{display:block;margin:22px auto;text-align:center}
.entry-content img.aligncenter{margin-left:auto;margin-right:auto}
.entry-content .alignnone{margin:18px 0}

/* Bilder: gerahmt, responsiv */
.entry-content img{max-width:100%;height:auto;border-radius:12px}
.entry-content a img{display:block}
.entry-content figure{margin:22px 0}

/* [caption] / wp-caption (z. B. Sponsoren-Logos) */
.entry-content .wp-caption{max-width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:10px;box-shadow:var(--shadow-card);margin:18px auto}
.entry-content .wp-caption img{border-radius:9px;margin:0;width:100%;height:auto}
.entry-content .wp-caption-text{font-size:13px;color:var(--muted);text-align:center;margin:8px 4px 2px}

/* Trennlinie */
.entry-content hr{border:0;border-top:1px solid var(--line);margin:32px 0}

/* Links im Fließtext etwas dezenter */
.entry-content ul li a{text-decoration:none}
.entry-content ul li a:hover{text-decoration:underline}

@media(max-width:560px){
  .entry-content .alignright,.entry-content .alignleft{float:none;display:block;margin:20px auto;max-width:100%}
}

/* ============================================================
   Videos-Seite – Karten-Raster (lokale Vorschaubilder, YouTube nur als Link)
   ============================================================ */
.entry-content .video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;margin:14px 0 32px}
.entry-content .video-card{position:relative;display:block;border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-card);aspect-ratio:16/9;background:var(--panel-2);transition:.18s}
.entry-content .video-card:hover{border-color:var(--red);transform:translateY(-2px)}
.entry-content .video-thumb{display:block;width:100%;height:100%}
.entry-content .video-thumb img{width:100%;height:100%;object-fit:cover;border-radius:0;margin:0;display:block}
.entry-content .video-play{position:absolute;inset:0;margin:auto;width:54px;height:54px;display:grid;place-items:center;
  background:rgba(207,58,43,.92);color:#fff;border-radius:50%;font-size:19px;box-shadow:0 6px 18px rgba(0,0,0,.32);transition:.2s}
.entry-content .video-card:hover .video-play{transform:scale(1.08);background:var(--red)}

/* ============================================================
   Gestaltete Inhaltsseiten (Verein, Anlagen Oberrudling …)
   ============================================================ */
.page-intro{font-size:19px;line-height:1.7;color:var(--txt);margin-bottom:18px;max-width:760px}
.page-quote{font-family:'Space Grotesk';font-size:22px;line-height:1.4;color:var(--steel);
  border-left:3px solid var(--steel);padding:4px 0 4px 20px;margin:8px 0 30px;font-style:italic;max-width:760px}
/* begrenzte, linksbündige Textbreite für konsistente Kanten */
.prose{max-width:760px}
ul.info-list.prose{max-width:560px}

/* Text + Foto nebeneinander */
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:center}
.split-photo{margin:0;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-card)}
.split-photo img{display:block;width:100%;height:auto}

/* Vorstands-Karten */
.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.board-card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:16px 18px;transition:.18s}
.board-card:hover{border-color:var(--steel);transform:translateY(-2px)}
.board-card .role{display:block;font-family:'JetBrains Mono';font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--steel);margin-bottom:6px}
.board-card b{font-family:'Space Grotesk';font-size:17px;font-weight:600}
.board-note{color:var(--muted);font-size:14.5px;margin-top:20px;max-width:760px}

@media(max-width:780px){
  .split{grid-template-columns:1fr;gap:22px}
}

/* Jahres-Marker in Geschichts-Kacheln (Verein) */
.feat .feat-year{display:block;font-family:'JetBrains Mono';font-size:12px;font-weight:600;
  color:var(--steel);letter-spacing:.06em;margin:2px 0 4px}

/* ============================================================
   Mittlere Breiten – Navigation kompakter (kein Button-Umbruch)
   ============================================================ */
@media(min-width:1081px) and (max-width:1200px){
  .nav-menu{margin-left:16px;gap:10px}
  nav ul{gap:2px}
  nav a{padding:8px 10px;font-size:14px}
  .nav-cta{gap:8px}
  .nav-cta .btn{padding:10px 16px}
}

/* ============================================================
   Hero im Bereich 901–1000px einspaltig stapeln (sonst Text gestaucht)
   ============================================================ */
@media(min-width:901px) and (max-width:1000px){
  .hero{min-height:0;padding:30px 0 60px;align-items:flex-start}
  .hero .wrap{grid-template-columns:1fr;gap:26px}
  .hero-visual{order:-1;margin-bottom:0}
  .hero-col{max-width:680px}
}

/* News-Karten: "Weiterlesen" einheitlich am unteren Kartenrand */
.news .card{display:flex;flex-direction:column}
.news .card .bd{display:flex;flex-direction:column;flex:1}
.news .card .more{margin-top:auto;padding-top:10px;align-self:flex-start}

/* Ganze News-Karte klickbar (Stretched-Link auf dem Titel) */
.news .card{position:relative}
.news .card .card-link{color:inherit;text-decoration:none}
.news .card .card-link::after{content:"";position:absolute;inset:0;z-index:1}
.news .card .more{position:relative;z-index:0}
.news .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--red)}
.news .card:hover h3{color:var(--red)}
.news .card:hover .more{color:var(--red-d)}

/* ============================================================
   Termine-Übersicht: Abschnitte + vergangene Termine abgesetzt
   ============================================================ */
.termine-head{font-family:'Space Grotesk';font-size:22px;font-weight:700;margin:4px 0 16px}
.termine-head-past{margin-top:46px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted)}
.termine-none{color:var(--muted);max-width:680px}
.termine-past .termin{opacity:.68;background:var(--bg-2);transition:opacity .18s}
.termine-past .termin:hover{opacity:1;transform:none;box-shadow:none}
