/*
Theme Name: FF Otzberg-Lengfeld
Theme URI: https://ff-lengfeld.de
Author: Feuerwehr Otzberg-Lengfeld
Author URI: https://ff-lengfeld.de
Description: Responsives Theme der Freiwilligen Feuerwehr Otzberg-Lengfeld. Dunkles Layout mit rotem Akzent, Einsatz-CPT, sechs Abteilungs-Seiten, Fahrzeuge-Seite, Mitglied-werden-Flow und Mobile-Nav. Mit Umlaut-Slug-Erkennung.
Version: 2.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ffotzberg
Tags: feuerwehr, dark, custom-menu, custom-post-type, responsive
*/

:root{
    --bg-0:#0b0f14;
    --bg-1:#0e141b;
    --bg-2:#131a23;
    --card:#161d27;
    --card-border:rgba(255,255,255,0.06);
    --text:#eef1f5;
    --text-muted:#a3adba;
    --text-dim:#6b7585;
    --red:#e23535;
    --red-2:#c81f1f;
    --red-glow:rgba(226,53,53,0.35);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{background:var(--bg-0);color:var(--text);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
  body{overflow-x:hidden}
  a{color:inherit;text-decoration:none}
  button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
  img{display:block;max-width:100%}
  ::selection{background:var(--red);color:#fff}

  /* ============ App shell ============ */
  .app{position:relative;width:100%;min-height:100vh;overflow:hidden}

  /* ============ Hero background ============ */
  .hero-bg{
    position:absolute;inset:0;height:920px;z-index:0;
    background:#0a0e13;
    overflow:hidden;
  }
  .hero-photo{
    position:absolute;inset:0;width:100%;height:100%;
    background-image:url('images/mural.jpg');
    background-size:cover;
    background-position:65% 45%;
    filter:saturate(1.05) contrast(1.02);
    transform:scale(1.02);
    transition:transform 8s ease-out;
  }
  .hero-bg.loaded .hero-photo{transform:scale(1.08)}
  /* Left-side darken so text stays readable over the wings */
  .hero-bg::before{
    content:"";position:absolute;inset:0;z-index:1;
    background:
      linear-gradient(90deg, rgba(8,11,15,0.95) 0%, rgba(8,11,15,0.85) 22%, rgba(8,11,15,0.55) 40%, rgba(8,11,15,0.15) 60%, transparent 80%);
  }
  /* Bottom fade into page */
  .hero-bg::after{
    content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg, rgba(8,11,15,0.4) 0%, transparent 18%, transparent 55%, rgba(11,15,20,0.85) 82%, var(--bg-0) 100%);
  }
  /* Subtle film grain for warmth */
  .hero-grain{
    position:absolute;inset:0;z-index:2;pointer-events:none;mix-blend-mode:overlay;opacity:0.4;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  }

  /* ============ Top bar ============ */
  .topbar{
    position:relative;z-index:10;
    display:flex;align-items:stretch;
    padding:28px 0 28px 56px;
  }
  .brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
  .brand-mark{
    width:54px;height:54px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
  }
  .brand-mark.v-flame{
    width:54px;height:54px;border-radius:10px;
    background:linear-gradient(180deg, #e94343, #b91d1d);
    box-shadow:0 6px 20px rgba(226,53,53,0.4), inset 0 1px 0 rgba(255,255,255,0.2);
  }
  .brand-mark.v-flame svg{width:30px;height:30px;color:#fff}
  .brand-mark.v-crest{
    width:54px;height:64px;
    filter:drop-shadow(0 6px 16px rgba(226,53,53,0.35));
  }
  .brand-mark.v-crest svg{width:100%;height:100%}
  .brand-mark.v-badge{
    width:60px;height:60px;
    filter:drop-shadow(0 6px 16px rgba(226,53,53,0.35));
  }
  .brand-mark.v-badge svg{width:100%;height:100%}
  .brand-mark.v-mono{
    width:56px;height:56px;
    filter:drop-shadow(0 6px 16px rgba(226,53,53,0.35));
  }
  .brand-mark.v-mono svg{width:100%;height:100%}
  .brand-text{line-height:1}
  .brand-name{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:28px;letter-spacing:0.06em;color:#fff;
  }
  .brand-sub{
    font-family:'Barlow Condensed',sans-serif;font-weight:500;
    font-size:14px;letter-spacing:0.18em;color:var(--text-muted);
    margin-top:4px;
  }
  .brand-sub b{color:var(--red);font-weight:700}

  .nav{
    flex:1;display:flex;align-items:center;justify-content:center;gap:42px;
  }
  .nav a{
    font-family:'Barlow Condensed',sans-serif;font-weight:600;
    font-size:15px;letter-spacing:0.22em;color:var(--text-muted);
    padding:8px 0;position:relative;transition:color .2s ease;
  }
  .nav a:hover{color:#fff}
  .nav a.active{color:var(--red)}
  .nav a.active::after{
    content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);
    width:24px;height:2px;background:var(--red);
  }
  .nav-item.has-menu{position:relative;display:flex;align-items:center}
  .nav-item.has-menu > a{display:inline-flex;align-items:center;gap:8px}
  .chev{
    display:inline-block;width:6px;height:6px;
    border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
    transform:rotate(45deg) translate(-2px,-2px);
    transition:transform .2s ease;
  }
  .nav-item.has-menu:hover .chev{transform:rotate(225deg) translate(-2px,-2px)}
  .nav-menu{
    position:absolute;top:100%;left:50%;transform:translate(-50%, 8px);
    min-width:340px;
    background:linear-gradient(180deg, #131a23, #0e141b);
    border:1px solid rgba(255,255,255,0.08);
    border-top:2px solid var(--red);
    border-radius:0 0 4px 4px;
    box-shadow:0 24px 50px rgba(0,0,0,0.5);
    padding:8px;
    opacity:0;pointer-events:none;visibility:hidden;
    transition:opacity .18s ease, transform .18s ease, visibility .18s;
    z-index:50;
  }
  .nav-menu.open{opacity:1;pointer-events:auto;visibility:visible;transform:translate(-50%, 0)}
  .nav-menu-inner{display:flex;flex-direction:column}
  .nav-menu a{
    display:flex;flex-direction:column;gap:4px;
    padding:14px 18px;
    text-align:left;
    border-radius:2px;transition:background .15s, color .15s;
    letter-spacing:0;
  }
  .nav-menu a:hover{background:rgba(226,53,53,0.08);color:#fff}
  .nav-menu a.active{background:rgba(226,53,53,0.12)}
  .nav-menu a.active .nav-menu-label{color:var(--red)}
  .nav-menu a::after{display:none}
  .nav-menu-label{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:15px;letter-spacing:0.14em;color:#fff;text-transform:uppercase;
  }
  .nav-menu-sub{
    font-family:'Inter',sans-serif;font-weight:400;
    font-size:12px;letter-spacing:0.02em;color:var(--text-dim);text-transform:none;
  }

  /* Notruf — angled red panel */
  .join-btn{
    align-self:center;
    display:inline-flex;align-items:center;gap:10px;
    padding:13px 20px;
    border:1.5px solid rgba(255,255,255,0.18);
    border-radius:2px;
    background:transparent;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:13px;letter-spacing:0.18em;color:#fff;text-transform:uppercase;
    flex-shrink:0;
    margin-right:8px;
    transition: all .2s ease;
    position:relative;
  }
  .join-btn:hover{
    background:var(--red);border-color:var(--red);
    box-shadow:0 8px 20px rgba(226,53,53,0.3);
  }
  .join-btn-arrow{
    width:18px;height:10px;position:relative;display:inline-block;
    transition:transform .2s ease;
  }
  .join-btn:hover .join-btn-arrow{transform:translateX(3px)}
  .join-btn-arrow::before{content:"";position:absolute;top:50%;left:0;right:0;height:1.5px;background:currentColor;transform:translateY(-50%)}
  .join-btn-arrow::after{content:"";position:absolute;top:50%;right:0;width:6px;height:6px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:translate(0,-50%) rotate(45deg)}

  .notruf{
    position:relative;flex-shrink:0;
    width:200px;height:106px;
    background:linear-gradient(135deg, #e94545 0%, #b41818 100%);
    color:#fff;
    clip-path:polygon(28px 0, 100% 0, 100% 100%, 0 100%);
    margin-top:-28px;margin-bottom:-28px;
    display:flex;align-items:center;gap:14px;
    padding:0 32px 0 44px;
    box-shadow: -8px 8px 30px rgba(226,53,53,0.25);
    cursor:pointer;
    transition: transform .2s ease;
  }
  .notruf:hover{transform:translateX(-3px)}
  .notruf-icon{
    width:42px;height:42px;border-radius:50%;
    border:1.5px solid rgba(255,255,255,0.55);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
    animation: ring 2.4s ease-in-out infinite;
  }
  .notruf-icon svg{width:18px;height:18px}
  .notruf-label{font-size:11px;letter-spacing:0.25em;opacity:0.9}
  .notruf-num{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:38px;line-height:1;letter-spacing:0.04em;margin-top:2px;
  }
  @keyframes ring{
    0%, 70%, 100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}
    35%{box-shadow:0 0 0 8px rgba(255,255,255,0.15)}
  }

  /* ============ Hero ============ */
  .hero{
    position:relative;z-index:5;
    padding:90px 0 0 96px;
    max-width:840px;
  }
  .hero h1, .hero p, .eyebrow, .cta-row{
    text-shadow:0 2px 30px rgba(0,0,0,0.5);
  }
  .eyebrow{
    display:flex;align-items:center;gap:18px;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:14px;letter-spacing:0.28em;color:var(--red);
    margin-bottom:34px;
  }
  .eyebrow::before{
    content:"";display:block;width:36px;height:2px;background:var(--red);
  }
  .hero h1{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:96px;line-height:0.96;letter-spacing:0.005em;
    color:#fff;margin-bottom:18px;
    text-transform:uppercase;
  }
  .hero h1 .red{color:var(--red);display:inline-block}
  .hero-line{display:block}
  .hero p{
    font-size:16px;line-height:1.7;color:var(--text-muted);
    max-width:380px;margin:28px 0 36px;font-weight:400;
  }
  .cta-row{display:flex;gap:14px;align-items:center}
  .btn{
    display:inline-flex;align-items:center;gap:12px;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:14px;letter-spacing:0.22em;text-transform:uppercase;
    padding:18px 26px;border-radius:2px;
    transition: all .2s ease;
  }
  .btn-primary{background:var(--red);color:#fff}
  .btn-primary:hover{background:var(--red-2);transform:translateY(-1px);box-shadow:0 10px 24px rgba(226,53,53,0.35)}
  .btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.18)}
  .btn-ghost:hover{border-color:var(--red);color:#fff;background:rgba(226,53,53,0.06)}
  .btn .arrow{
    width:22px;height:14px;position:relative;display:inline-block;
    transition:transform .2s ease;
  }
  .btn:hover .arrow{transform:translateX(4px)}
  .btn .arrow::before{
    content:"";position:absolute;top:50%;left:0;right:0;height:1.5px;background:currentColor;transform:translateY(-50%);
  }
  .btn .arrow::after{
    content:"";position:absolute;top:50%;right:0;width:8px;height:8px;
    border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;
    transform:translate(0,-50%) rotate(45deg);
  }

  /* Scroll indicator */
  .scroll-ind{
    position:absolute;left:46px;top:540px;
    writing-mode:vertical-rl;transform:rotate(180deg);
    font-family:'Barlow Condensed',sans-serif;font-weight:600;
    font-size:11px;letter-spacing:0.4em;color:var(--text-dim);
    display:flex;align-items:center;gap:18px;
  }
  .scroll-ind::after{
    content:"";display:block;width:1px;height:84px;background:rgba(255,255,255,0.2);
  }

  /* ============ Feature cards ============ */
  .cards{
    position:relative;z-index:5;
    margin-top:72px;padding:0 56px;
    display:grid;grid-template-columns:repeat(4, 1fr);gap:18px;
  }
  .card{
    position:relative;
    background:linear-gradient(180deg, rgba(20,26,35,0.92) 0%, rgba(15,20,28,0.96) 100%);
    border:1px solid var(--card-border);
    border-radius:4px;
    padding:32px 28px 28px;
    min-height:220px;
    overflow:hidden;
    cursor:pointer;
    transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  }
  .card::before{
    content:"";position:absolute;inset:0;opacity:0.12;
    background-position:center;background-size:cover;
    transition:opacity .3s ease;
  }
  .card:nth-child(1)::before{background-image:radial-gradient(ellipse at 30% 40%, rgba(255,120,40,0.25), transparent 55%), linear-gradient(135deg,#1a1410,#0a0a0a)}
  .card:nth-child(2)::before{background-image:radial-gradient(ellipse at 70% 60%, rgba(226,53,53,0.15), transparent 60%), linear-gradient(135deg,#181818,#0e0e0e)}
  .card:nth-child(3)::before{background-image:radial-gradient(ellipse at 50% 30%, rgba(255,180,40,0.12), transparent 55%), linear-gradient(135deg,#181410,#0c0c0c)}
  .card:nth-child(4)::before{background-image:radial-gradient(ellipse at 40% 70%, rgba(120,140,180,0.1), transparent 55%), linear-gradient(135deg,#15171c,#0a0c10)}
  .card > *{position:relative;z-index:1}
  .card:hover{
    transform:translateY(-4px);
    border-color:rgba(226,53,53,0.4);
    box-shadow:0 16px 40px rgba(0,0,0,0.4);
  }
  .card:hover::before{opacity:0.22}
  .card-icon{
    width:56px;height:56px;color:#fff;margin-bottom:22px;
    display:flex;align-items:center;justify-content:flex-start;
  }
  .card-icon svg{width:46px;height:46px}
  .card h3{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:22px;letter-spacing:0.14em;color:#fff;
    margin-bottom:12px;
  }
  .card p{
    font-size:13.5px;line-height:1.55;color:var(--text-muted);
    margin-bottom:20px;font-weight:400;
  }
  .card-arrow{
    width:28px;height:14px;position:relative;color:var(--red);
    transition:transform .2s ease;
  }
  .card:hover .card-arrow{transform:translateX(6px)}
  .card-arrow::before{
    content:"";position:absolute;top:50%;left:0;right:0;height:1.5px;background:currentColor;transform:translateY(-50%);
  }
  .card-arrow::after{
    content:"";position:absolute;top:50%;right:0;width:9px;height:9px;
    border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;
    transform:translate(0,-50%) rotate(45deg);
  }

  /* ============ Stats bar ============ */
  .stats-wrap{
    position:relative;z-index:5;margin-top:42px;padding:0 56px;
  }
  .stats{
    background:linear-gradient(180deg, rgba(13,17,23,0.95), rgba(8,11,15,1));
    border:1px solid rgba(255,255,255,0.04);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 0px), 60px 100%, 0 calc(100% - 60px));
    display:grid;grid-template-columns:repeat(4, 1fr);
    padding:38px 60px;gap:24px;
  }
  .stat{
    display:flex;align-items:center;gap:22px;
    padding:0 8px;
    position:relative;
  }
  .stat + .stat::before{
    content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:1px;
    background:rgba(255,255,255,0.06);
  }
  .stat-icon{
    width:54px;height:54px;color:var(--red);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
  }
  .stat-icon svg{width:46px;height:46px;stroke-width:1.5}
  .stat-num{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:42px;line-height:1;color:#fff;letter-spacing:0.02em;
  }
  .stat-label{
    font-size:13px;color:var(--text-muted);margin-top:6px;font-weight:400;
  }

  /* ============ Über uns page ============ */
  .ueber-hero{
    position:relative;height:720px;overflow:hidden;
    border-bottom:1px solid rgba(255,255,255,0.05);
  }
  .ueber-hero-photo{
    position:absolute;inset:0;
    background:url('images/geraetehaus-tag.jpg') center/cover no-repeat;
    filter:brightness(0.55) saturate(0.85) contrast(1.05);
    transform:scale(1.05);
  }
  .ueber-hero::before{
    content:"";position:absolute;inset:0;z-index:1;
    background:
      linear-gradient(90deg, rgba(8,11,15,0.92) 0%, rgba(8,11,15,0.55) 45%, rgba(8,11,15,0.2) 70%, transparent 100%),
      linear-gradient(180deg, rgba(8,11,15,0.4) 0%, transparent 30%, transparent 60%, var(--bg-0) 100%);
  }
  .ueber-hero-content{
    position:relative;z-index:2;padding:200px 96px 0;max-width:900px;
  }
  .ueber-hero-content h1{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:96px;line-height:0.95;color:#fff;text-transform:uppercase;
    margin-top:14px;text-shadow:0 2px 30px rgba(0,0,0,0.6);
  }
  .ueber-hero-content h1 .red{color:var(--red)}
  .ueber-hero-meta{
    display:flex;gap:60px;margin-top:48px;
  }
  .ueber-hero-meta > div{
    display:flex;flex-direction:column;gap:6px;
    padding-left:18px;border-left:2px solid var(--red);
  }
  .ueber-hero-meta span{
    font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:0.26em;
    color:var(--text-muted);text-transform:uppercase;
  }
  .ueber-hero-meta b{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:26px;color:#fff;letter-spacing:0.02em;
  }

  .ueber-intro{
    display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:start;
  }
  .ueber-intro-text p{
    font-size:15.5px;line-height:1.85;color:var(--text-muted);margin-bottom:18px;
  }
  .ueber-intro-text p:first-child::first-letter{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;color:var(--red);
    font-size:64px;line-height:0.85;float:left;padding:6px 14px 0 0;
  }

  /* Values */
  .values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .value-card{
    background:linear-gradient(180deg, rgba(20,26,35,0.9), rgba(13,17,23,1));
    border:1px solid var(--card-border);border-radius:4px;
    padding:36px 28px 32px;min-height:260px;
    position:relative;overflow:hidden;
  }
  .value-card::before{
    content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);
    transform:scaleY(0.2);transform-origin:bottom;transition:transform .3s;
  }
  .value-card:hover::before{transform:scaleY(1)}
  .value-num{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:13px;letter-spacing:0.3em;color:var(--red);margin-bottom:24px;
  }
  .value-card h3{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:38px;color:#fff;letter-spacing:0.01em;margin-bottom:14px;
    text-transform:uppercase;
  }
  .value-card p{font-size:14px;color:var(--text-muted);line-height:1.65}

  /* Timeline */
  .timeline{position:relative;padding-left:60px;max-width:980px}
  .timeline-line{
    position:absolute;left:24px;top:8px;bottom:8px;width:1px;
    background:linear-gradient(180deg, transparent, rgba(226,53,53,0.5) 10%, rgba(226,53,53,0.5) 90%, transparent);
  }
  .timeline-item{
    position:relative;padding:24px 0 24px 60px;
    border-bottom:1px solid rgba(255,255,255,0.05);
  }
  .timeline-item:last-child{border-bottom:none}
  .timeline-dot{
    position:absolute;left:-42px;top:36px;width:14px;height:14px;border-radius:50%;
    background:var(--red);box-shadow:0 0 0 6px rgba(226,53,53,0.15), 0 0 0 1px rgba(0,0,0,0.4);
  }
  .timeline-year{
    position:absolute;left:60px;top:24px;
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:48px;color:#fff;letter-spacing:0.02em;line-height:1;
  }
  .timeline-body{margin-left:160px}
  .timeline-body h4{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:22px;color:#fff;letter-spacing:0.04em;text-transform:uppercase;
    margin-bottom:10px;
  }
  .timeline-body p{color:var(--text-muted);line-height:1.7;font-size:14.5px;max-width:560px}

  /* Wehrführung */
  .wehr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .wehr-card{
    background:var(--card);border:1px solid var(--card-border);border-radius:4px;
    padding:24px;
  }
  .wehr-portrait{
    aspect-ratio:4/5;background:#0b0f14;border-radius:2px;overflow:hidden;margin-bottom:20px;
  }
  .wehr-portrait image-slot{
    width:100%;height:100%;--is-bg:#161d27;--is-border:transparent;--is-fg:rgba(255,255,255,0.3);--is-radius:0;
  }
  .wehr-role{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:12px;letter-spacing:0.24em;color:var(--red);text-transform:uppercase;margin-bottom:8px;
  }
  .wehr-name{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:22px;color:#fff;letter-spacing:0.02em;
  }
  .wehr-detail{font-size:13px;color:var(--text-dim);margin-top:6px}

  /* CTA band */
  .cta-band{
    display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center;
    padding:60px;background:linear-gradient(135deg, rgba(226,53,53,0.08), rgba(20,26,35,0.95));
    border:1px solid rgba(226,53,53,0.2);border-radius:4px;
    position:relative;overflow:hidden;
  }
  .cta-band::before{
    content:"";position:absolute;top:-40%;right:-10%;width:400px;height:400px;
    background:radial-gradient(circle, rgba(226,53,53,0.15), transparent 70%);
  }
  .cta-band > *{position:relative;z-index:1}

  /* ============ Fahrzeuge / Fuhrpark page ============ */
  .fleet{display:flex;flex-direction:column;gap:60px}
  .fleet-card{
    display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;
  }
  .fleet-card.reverse{grid-template-columns:1fr 1.1fr}
  .fleet-card.reverse .fleet-image{order:2}
  .fleet-image{
    position:relative;aspect-ratio:16/10;
    background:#0b0f14;border-radius:4px;overflow:hidden;
    border:1px solid var(--card-border);
  }
  .fleet-image image-slot{
    width:100%;height:100%;
    --is-bg:#161d27;--is-border:transparent;--is-fg:rgba(255,255,255,0.3);--is-radius:0;
  }
  .fleet-kennung{
    position:absolute;top:18px;left:18px;
    background:rgba(8,11,15,0.85);
    border:1px solid rgba(226,53,53,0.45);
    color:#fff;
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:24px;letter-spacing:0.06em;
    padding:6px 14px;border-radius:2px;
    backdrop-filter:blur(6px);
  }
  .fleet-title{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:48px;line-height:0.98;color:#fff;letter-spacing:0.01em;
    text-transform:uppercase;margin:14px 0 18px;
  }
  .fleet-lead{
    color:var(--text-muted);line-height:1.7;font-size:15px;
    max-width:520px;margin-bottom:24px;
  }
  .fleet-specs{
    display:grid;grid-template-columns:repeat(2,1fr);gap:0;
    border-top:1px solid rgba(255,255,255,0.08);
    margin-bottom:24px;
  }
  .fleet-spec{
    display:flex;justify-content:space-between;align-items:baseline;
    padding:11px 0;border-bottom:1px solid rgba(255,255,255,0.05);
    gap:14px;
  }
  .fleet-spec:nth-child(odd){padding-right:18px;border-right:1px solid rgba(255,255,255,0.05)}
  .fleet-spec:nth-child(even){padding-left:18px}
  .fleet-spec span{
    font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:0.24em;
    color:var(--text-dim);text-transform:uppercase;
  }
  .fleet-spec b{
    font-size:13.5px;color:#fff;font-weight:500;text-align:right;
  }
  .fleet-load{
    background:rgba(255,255,255,0.025);
    border:1px solid rgba(255,255,255,0.06);
    border-radius:2px;padding:0;
  }
  .fleet-load summary{
    cursor:pointer;
    padding:14px 18px;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:12px;letter-spacing:0.22em;color:var(--text-muted);
    text-transform:uppercase;
    display:flex;align-items:center;justify-content:space-between;
    list-style:none;
    transition:color .2s;
  }
  .fleet-load summary::after{
    content:"";width:8px;height:8px;
    border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
    transform:rotate(45deg);transition:transform .2s;
  }
  .fleet-load[open] summary::after{transform:rotate(225deg)}
  .fleet-load summary::-webkit-details-marker{display:none}
  .fleet-load:hover summary{color:#fff}
  .fleet-load ul{
    list-style:none;padding:6px 18px 18px;margin:0;
    display:flex;flex-direction:column;gap:8px;
  }
  .fleet-load li{
    padding-left:22px;position:relative;
    color:var(--text-muted);font-size:13.5px;line-height:1.55;
  }
  .fleet-load li::before{
    content:"";position:absolute;left:0;top:9px;width:10px;height:1.5px;background:var(--red);
  }

  .extras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .extra-card{
    background:var(--card);border:1px solid var(--card-border);border-radius:4px;
    padding:24px 26px;
  }
  .extra-label{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:15px;letter-spacing:0.16em;color:#fff;text-transform:uppercase;
    margin-bottom:10px;
  }
  .extra-detail{color:var(--text-muted);font-size:13.5px;line-height:1.6}

  /* ============ Mitglied werden page ============ */
  .steps-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:20px}
  .step-card{
    background:linear-gradient(180deg, rgba(20,26,35,0.95), rgba(13,17,23,1));
    border:1px solid var(--card-border);border-radius:4px;
    padding:36px 32px 32px;position:relative;overflow:hidden;
  }
  .step-card::before{
    content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);
  }
  .step-num{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:14px;letter-spacing:0.32em;color:var(--red);
    margin-bottom:20px;
  }
  .step-card h3{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:32px;color:#fff;letter-spacing:0.01em;
    margin-bottom:14px;text-transform:uppercase;
  }
  .step-card p{
    color:var(--text-muted);font-size:14.5px;line-height:1.7;margin-bottom:24px;
  }
  .step-detail{
    display:grid;grid-template-columns:auto 1fr;gap:8px 16px;
    padding-top:20px;border-top:1px solid rgba(255,255,255,0.06);
  }
  .step-detail span{
    font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:0.22em;
    color:var(--text-dim);text-transform:uppercase;padding-top:2px;
  }
  .step-detail b{
    font-size:13.5px;color:#fff;text-align:right;font-weight:500;
  }

  .join-cols{
    display:grid;grid-template-columns:1fr 1fr;gap:60px;
    padding:48px;
    background:var(--card);border:1px solid var(--card-border);border-radius:4px;
  }
  .join-col h3{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:34px;color:#fff;letter-spacing:0.01em;margin:14px 0 24px;
    text-transform:uppercase;
  }

  .join-form{
    display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;
    padding:60px;
    background:linear-gradient(135deg, rgba(226,53,53,0.07), rgba(20,26,35,0.95));
    border:1px solid rgba(226,53,53,0.2);border-radius:4px;
    position:relative;overflow:hidden;
  }
  .join-form::before{
    content:"";position:absolute;top:-30%;right:-10%;width:500px;height:500px;
    background:radial-gradient(circle, rgba(226,53,53,0.12), transparent 70%);
  }
  .join-form > *{position:relative;z-index:1}
  .join-form-right{
    position:relative;
    background:rgba(8,11,15,0.6);border:1px solid rgba(255,255,255,0.08);
    border-radius:4px;padding:32px;
  }
  .join-soon-badge{
    position:absolute;top:-14px;right:24px;
    background:var(--red);color:#fff;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
    padding:6px 14px;border-radius:2px;
  }
  .join-form-mockup{
    display:flex;flex-direction:column;gap:14px;
    filter:saturate(0.7);opacity:0.85;
  }
  .form-row{display:flex;flex-direction:column;gap:6px}
  .form-row label{
    font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:0.2em;
    color:var(--text-dim);text-transform:uppercase;
  }
  .fake-input{
    height:36px;background:rgba(255,255,255,0.04);
    border:1px solid rgba(255,255,255,0.08);border-radius:2px;
  }
  .fake-input.narrow{max-width:50%}
  .fake-input.tall{height:64px}
  .fake-select{
    height:36px;background:rgba(255,255,255,0.04);
    border:1px solid rgba(255,255,255,0.08);border-radius:2px;
    display:flex;align-items:center;justify-content:space-between;
    padding:0 12px;
    font-size:13px;color:var(--text-muted);
    position:relative;
  }
  .fake-select::after{
    content:"";width:8px;height:8px;
    border-right:1.5px solid var(--text-dim);border-bottom:1.5px solid var(--text-dim);
    transform:rotate(45deg) translate(-2px,-2px);
  }
  .fake-submit{
    margin-top:8px;
    padding:13px 20px;background:var(--red);color:#fff;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:13px;letter-spacing:0.22em;text-transform:uppercase;
    text-align:center;border-radius:2px;
  }

  /* ============ Abteilungen overview ============ */
  .abt-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:20px}
  .abt-card{
    display:flex;flex-direction:column;
    background:linear-gradient(180deg, rgba(20,26,35,0.95), rgba(13,17,23,1));
    border:1px solid var(--card-border);border-radius:4px;
    padding:36px 36px 32px;min-height:300px;
    transition:transform .25s, border-color .25s, box-shadow .25s;
    cursor:pointer;
  }
  .abt-card:hover{transform:translateY(-4px);border-color:rgba(226,53,53,0.4);box-shadow:0 16px 40px rgba(0,0,0,0.4)}
  .abt-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px}
  .abt-card-icon{width:56px;height:56px;color:var(--red)}
  .abt-card-icon svg{width:56px;height:56px}
  .abt-card-arrow{
    width:32px;height:14px;position:relative;color:var(--text-dim);
    transition:color .2s, transform .2s;
  }
  .abt-card:hover .abt-card-arrow{color:var(--red);transform:translateX(6px)}
  .abt-card-arrow::before{content:"";position:absolute;top:50%;left:0;right:0;height:1.5px;background:currentColor;transform:translateY(-50%)}
  .abt-card-arrow::after{content:"";position:absolute;top:50%;right:0;width:9px;height:9px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:translate(0,-50%) rotate(45deg)}
  .abt-card h3{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:34px;color:#fff;text-transform:uppercase;letter-spacing:0.01em;
    margin-bottom:6px;
  }
  .abt-card-sub{
    font-family:'Barlow Condensed',sans-serif;font-weight:600;
    font-size:13px;letter-spacing:0.2em;color:var(--red);
    text-transform:uppercase;margin-bottom:16px;
  }
  .abt-card p{
    color:var(--text-muted);line-height:1.65;font-size:14.5px;
    flex:1;margin-bottom:24px;
  }
  .abt-card-meta{
    display:flex;gap:32px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.06);
  }
  .abt-card-meta span{
    display:flex;flex-direction:column;gap:4px;
    font-size:12px;color:var(--text-dim);letter-spacing:0.02em;
  }
  .abt-card-meta b{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:22px;color:#fff;letter-spacing:0.02em;line-height:1;
  }

  /* Abteilung detail */
  .abt-detail{
    display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:start;
  }
  .abt-detail-main{display:flex;flex-direction:column;gap:56px}
  .abt-block .section-title{font-size:42px !important;line-height:1}
  .abt-p{font-size:15.5px;line-height:1.8;color:var(--text-muted);margin-bottom:14px;max-width:680px}
  .abt-list{list-style:none;padding:0;margin-top:14px;display:flex;flex-direction:column;gap:10px}
  .abt-list li{
    padding-left:24px;position:relative;
    color:var(--text-muted);line-height:1.6;font-size:14.5px;
  }
  .abt-list li::before{
    content:"";position:absolute;left:0;top:10px;width:10px;height:2px;background:var(--red);
  }
  .abt-side{
    position:sticky;top:32px;
    background:var(--card);border:1px solid var(--card-border);border-radius:4px;
    padding:28px;
  }
  .abt-fact{display:flex;flex-direction:column}
  .abt-fact-row{
    display:flex;justify-content:space-between;align-items:flex-start;gap:18px;
    padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.05);
  }
  .abt-fact-row:last-child{border-bottom:none}
  .abt-fact-row span{
    font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:0.22em;
    color:var(--text-dim);text-transform:uppercase;padding-top:3px;
  }
  .abt-fact-row b{
    font-family:'Inter',sans-serif;font-weight:500;
    font-size:14px;color:#fff;text-align:right;line-height:1.5;
  }

  /* ============ Below-fold sections ============ */
  .section{padding:120px 96px;position:relative;z-index:2}
  .section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:54px;gap:40px}
  .section-eyebrow{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:13px;letter-spacing:0.32em;color:var(--red);margin-bottom:18px;
    display:flex;align-items:center;gap:14px;
  }
  .section-eyebrow::before{content:"";display:block;width:28px;height:2px;background:var(--red)}
  .section-title{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:64px;line-height:1;text-transform:uppercase;color:#fff;letter-spacing:0.005em;
    max-width:720px;
  }
  .section-link{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:13px;letter-spacing:0.22em;color:var(--text-muted);
    display:inline-flex;align-items:center;gap:14px;text-transform:uppercase;
  }
  .section-link:hover{color:var(--red)}
  .section-link .arrow{width:22px;height:14px;position:relative}
  .section-link .arrow::before{content:"";position:absolute;top:50%;left:0;right:0;height:1.5px;background:currentColor;transform:translateY(-50%)}
  .section-link .arrow::after{content:"";position:absolute;top:50%;right:0;width:8px;height:8px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:translate(0,-50%) rotate(45deg)}

  /* News */
  .news-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
  .news-card{
    background:var(--card);border:1px solid var(--card-border);
    border-radius:4px;overflow:hidden;cursor:pointer;
    transition:transform .25s, border-color .25s;
    display:flex;flex-direction:column;
  }
  .news-card:hover{transform:translateY(-4px);border-color:rgba(226,53,53,0.4)}
  .news-img{
    aspect-ratio:16/10;background:#0b0f14;position:relative;overflow:hidden;
  }
  .news-img image-slot{
    width:100%;height:100%;
    --is-bg:#1a2230;--is-border:transparent;--is-fg:rgba(255,255,255,0.35);--is-radius:0;
  }
  .news-img.featured{aspect-ratio:16/12}
  .news-body{padding:26px 28px 28px;flex:1;display:flex;flex-direction:column}
  .news-meta{
    display:flex;gap:14px;align-items:center;margin-bottom:14px;
    font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:0.18em;color:var(--text-dim);text-transform:uppercase;
  }
  .news-tag{color:var(--red);font-weight:700}
  .news-card h4{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:24px;line-height:1.15;color:#fff;margin-bottom:10px;letter-spacing:0.01em;
  }
  .news-card.featured h4{font-size:32px}
  .news-card p{font-size:14px;color:var(--text-muted);line-height:1.6}

  /* Section divider with photo backdrop */
  .photo-section{
    position:relative;padding:120px 96px;overflow:hidden;
    border-top:1px solid rgba(255,255,255,0.05);
  }
  .photo-section::before{
    content:"";position:absolute;inset:0;z-index:0;
    background-image:url('images/lf-abend.png');
    background-size:cover;background-position:center;
    filter:brightness(0.45) saturate(0.9);
  }
  .photo-section::after{
    content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(90deg, rgba(8,11,15,0.85) 0%, rgba(8,11,15,0.45) 60%, rgba(8,11,15,0.2) 100%);
  }
  .photo-section > *{position:relative;z-index:2}
  .photo-section .quote{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:72px;line-height:1;text-transform:uppercase;color:#fff;
    max-width:780px;margin-top:14px;
  }
  .photo-section .quote .red{color:var(--red)}
  .photo-section .author{
    margin-top:38px;font-family:'Barlow Condensed',sans-serif;font-size:14px;
    letter-spacing:0.24em;color:var(--text-muted);text-transform:uppercase;
  }

  /* Einsätze list */
  .einsatz-wrap{
    background:linear-gradient(180deg, #0c1117 0%, #0a0e13 100%);
    position:relative;
  }
  .einsatz-wrap::before{
    content:"";position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg, transparent, rgba(226,53,53,0.4), transparent);
  }
  .einsatz-list{display:flex;flex-direction:column;gap:2px;background:rgba(255,255,255,0.04)}
  .einsatz{
    display:grid;grid-template-columns:120px 1fr 140px 200px 40px;gap:32px;align-items:center;
    padding:24px 32px;background:var(--bg-1);
    cursor:pointer;transition:background .2s, padding .2s;
  }
  .einsatz:hover{background:#161e28;padding-left:38px}
  .einsatz-num{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:13px;letter-spacing:0.18em;color:var(--red);
  }
  .einsatz-title{
    font-family:'Barlow Condensed',sans-serif;font-weight:600;
    font-size:20px;color:#fff;letter-spacing:0.01em;
  }
  .einsatz-type{
    display:inline-flex;padding:6px 12px;border-radius:2px;
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  }
  .einsatz-type.feuer{background:rgba(226,53,53,0.15);color:#ff6a6a}
  .einsatz-type.thl{background:rgba(255,180,40,0.12);color:#ffc56a}
  .einsatz-type.brand{background:rgba(226,53,53,0.15);color:#ff6a6a}
  .einsatz-meta{font-size:13px;color:var(--text-muted)}
  .einsatz-arrow{width:18px;height:12px;position:relative;color:var(--text-dim);justify-self:end;transition:color .2s, transform .2s}
  .einsatz:hover .einsatz-arrow{color:var(--red);transform:translateX(4px)}
  .einsatz-arrow::before{content:"";position:absolute;top:50%;left:0;right:0;height:1.5px;background:currentColor;transform:translateY(-50%)}
  .einsatz-arrow::after{content:"";position:absolute;top:50%;right:0;width:7px;height:7px;border-top:1.5px solid currentColor;border-right:1.5px solid currentColor;transform:translate(0,-50%) rotate(45deg)}

  /* Footer */
  .footer{
    background:#070a0e;padding:80px 96px 36px;border-top:1px solid rgba(255,255,255,0.04);
  }
  .footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
  .footer h5{
    font-family:'Barlow Condensed',sans-serif;font-weight:700;
    font-size:14px;letter-spacing:0.24em;color:#fff;margin-bottom:22px;text-transform:uppercase;
  }
  .footer p, .footer a{font-size:14px;color:var(--text-muted);line-height:1.8}
  .footer a:hover{color:#fff}
  .footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
  .footer-brand p{margin-top:18px;max-width:340px;font-size:13.5px;color:var(--text-dim)}
  .footer-bottom{
    display:flex;justify-content:space-between;align-items:center;
    padding-top:28px;border-top:1px solid rgba(255,255,255,0.05);
    font-size:12px;color:var(--text-dim);letter-spacing:0.1em;
  }
  .footer-bottom .links{display:flex;gap:28px}

  /* Number counter helper class */
  .count{display:inline-block}

  /* Hidden sections */
  .page{display:none}
  .page.active{display:block;animation:fade .4s ease both}
  @keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

  /* Sub-page hero */
  .subhero{
    padding:140px 96px 80px;position:relative;
    background:linear-gradient(180deg, #0c1218 0%, #0a0e13 100%);
    border-bottom:1px solid rgba(255,255,255,0.05);
  }
  .subhero h1{
    font-family:'Barlow Condensed',sans-serif;font-weight:800;
    font-size:80px;line-height:1;color:#fff;text-transform:uppercase;letter-spacing:0.005em;
    margin-top:14px;
  }
  .subhero h1 .red{color:var(--red)}
  .subhero p{color:var(--text-muted);max-width:560px;margin-top:22px;line-height:1.7}

  /* ============================================================
     RESPONSIVE — Tablet & Mobile
     ============================================================ */

  /* Hamburger button (hidden on desktop) */
  .hamburger{
    display:none;
    width:44px;height:44px;
    background:transparent;border:1px solid rgba(255,255,255,0.18);border-radius:2px;
    cursor:pointer;color:#fff;padding:0;
    align-items:center;justify-content:center;flex-direction:column;gap:5px;
    flex-shrink:0;margin-right:12px;
  }
  .hamburger span{
    display:block;width:18px;height:2px;background:currentColor;
    transition: transform .25s, opacity .2s;
  }
  .hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* ===== Tablet: <= 1280px ===== */
  @media (max-width: 1280px){
    .topbar{padding:24px 0 24px 32px}
    .nav{gap:30px}
    .nav a{font-size:14px;letter-spacing:0.14em}
    .hero{padding:80px 0 0 56px;max-width:760px}
    .hero h1{font-size:80px}
    .scroll-ind{display:none}
    .cards{margin-top:60px;padding:0 32px;gap:14px}
    .stats-wrap{padding:0 32px}
    .stats{padding:32px;gap:18px}
    .stat{gap:16px}
    .photo-section{padding:80px 56px}
    .photo-section .quote{font-size:56px}
    .section{padding:80px 56px}
    .section-title{font-size:52px}
    .footer{padding:64px 56px 32px}
    .ueber-hero-content{padding:160px 56px 0}
    .ueber-hero-content h1{font-size:72px}
    .ueber-intro{grid-template-columns:1fr;gap:32px}
    .values-grid{grid-template-columns:repeat(2,1fr)}
    .wehr-grid{grid-template-columns:repeat(3,1fr);gap:16px}
    .fleet-card, .fleet-card.reverse{grid-template-columns:1fr;gap:24px}
    .fleet-card.reverse .fleet-image{order:0}
    .fleet-title{font-size:38px}
    .abt-detail{grid-template-columns:1fr 320px;gap:48px}
    .extras-grid{grid-template-columns:repeat(2,1fr)}
    .steps-grid{grid-template-columns:1fr;gap:16px}
    .join-form{grid-template-columns:1fr;gap:40px}
    .news-grid{grid-template-columns:1fr 1fr;gap:18px}
    .news-card.featured{grid-column:1/-1}
    .einsatz{padding:20px 24px;grid-template-columns:110px 1fr 130px 180px 28px;gap:24px}
  }

  /* ===== Below 960px: hamburger nav, single-column hero ===== */
  @media (max-width: 960px){
    .topbar{padding:18px 0 18px 20px;gap:0}
    .brand-name{font-size:24px}
    .brand-sub{font-size:12px;letter-spacing:0.14em}
    .brand-mark.v-flame{width:44px;height:44px}
    .brand-mark.v-mono, .brand-mark.v-badge{width:48px;height:48px}
    .brand-mark.v-crest{width:44px;height:52px}

    .hamburger{display:flex}
    .nav, .join-btn{display:none}

    /* Mobile drawer when .nav-open on .app */
    .app.nav-open .nav{
      display:flex;flex-direction:column;
      position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;
      background:linear-gradient(180deg, #0b1017, #0a0e13);
      padding:90px 32px 32px;gap:6px;align-items:stretch;justify-content:flex-start;
      overflow-y:auto;
      animation: drawerIn .25s ease both;
    }
    .app.nav-open .nav a{
      padding:18px 0;font-size:18px;letter-spacing:0.1em;
      border-bottom:1px solid rgba(255,255,255,0.05);
      text-align:left;
    }
    .app.nav-open .nav a.active::after{display:none}
    .app.nav-open .nav a.active{color:var(--red)}
    .app.nav-open .nav-item.has-menu{flex-direction:column;align-items:stretch}
    .app.nav-open .nav-item.has-menu .chev{margin-left:auto}
    .app.nav-open .nav-menu{
      position:static;transform:none;
      opacity:1;pointer-events:auto;visibility:visible;
      background:transparent;border:none;box-shadow:none;
      padding:0 0 8px 16px;min-width:0;
    }
    .app.nav-open .nav-menu a{
      padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.04);
    }
    .app.nav-open .nav-menu-label{font-size:14px}
    .app.nav-open .nav-menu-sub{font-size:11px}
    .app.nav-open .join-btn{
      display:inline-flex;align-self:flex-start;margin-top:20px;
      background:var(--red);border-color:var(--red);
    }
    @keyframes drawerIn{
      from{opacity:0;transform:translateY(-8px)}
      to{opacity:1;transform:none}
    }

    /* Notruf becomes compact at this size */
    .notruf{
      width:auto;height:74px;padding:0 18px 0 24px;
      clip-path:polygon(16px 0, 100% 0, 100% 100%, 0 100%);
      margin-top:-18px;margin-bottom:-18px;gap:10px;
    }
    .notruf-icon{width:36px;height:36px}
    .notruf-label{font-size:9px;letter-spacing:0.2em}
    .notruf-num{font-size:28px}

    /* Hero — image moves behind, text overlays full width */
    .hero-bg{height:auto;min-height:780px}
    .hero-photo{background-position:70% 45%}
    .hero-bg::before{
      background:linear-gradient(180deg, rgba(8,11,15,0.6) 0%, rgba(8,11,15,0.4) 30%, rgba(8,11,15,0.85) 75%, var(--bg-0) 100%),
                 linear-gradient(90deg, rgba(8,11,15,0.7) 0%, rgba(8,11,15,0.3) 100%);
    }
    .hero{padding:60px 24px 0;max-width:100%}
    .hero h1{font-size:56px;line-height:0.98}
    .hero p{font-size:15px;max-width:none}
    .eyebrow{font-size:12px;letter-spacing:0.22em;margin-bottom:22px}
    .cta-row{flex-direction:column;align-items:flex-start;gap:10px}
    .btn{width:100%;justify-content:space-between;max-width:340px}

    /* Cards 4 → 2 */
    .cards{padding:0 24px;grid-template-columns:repeat(2,1fr);margin-top:40px}
    .card{min-height:200px;padding:24px 22px 22px}
    .card-icon{width:46px;height:46px;margin-bottom:16px}
    .card-icon svg{width:38px;height:38px}
    .card h3{font-size:18px}

    /* Stats 4 → 2 (and remove skew for readability) */
    .stats-wrap{padding:0 24px}
    .stats{
      grid-template-columns:repeat(2,1fr);
      padding:28px 24px;gap:18px;
      clip-path:none;border-radius:4px;
    }
    .stat{padding:0;gap:16px}
    .stat + .stat::before{display:none}
    .stat-icon{width:40px;height:40px}
    .stat-icon svg{width:36px;height:36px}
    .stat-num{font-size:32px}
    .stat-label{font-size:11.5px;line-height:1.35}

    .photo-section{padding:64px 24px}
    .photo-section .quote{font-size:42px}

    /* Section paddings + titles */
    .section{padding:60px 24px}
    .section-head{flex-direction:column;align-items:flex-start;gap:18px;margin-bottom:36px}
    .section-title{font-size:42px}
    .section-link{font-size:12px}

    /* News stays at 2 col → 1 col */
    .news-grid{grid-template-columns:1fr;gap:16px}
    .news-card.featured{grid-column:auto}
    .news-card.featured h4{font-size:24px}

    /* Footer */
    .footer{padding:48px 24px 24px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:32px;margin-bottom:40px}
    .footer-brand{grid-column:1/-1}
    .footer-bottom{flex-direction:column;gap:14px;align-items:flex-start}

    /* Subhero (Über uns, Einsätze, Mitglied werden, Fahrzeuge etc.) */
    .subhero{padding:100px 24px 56px}
    .subhero h1{font-size:48px}

    /* Über uns hero */
    .ueber-hero{height:auto;min-height:560px}
    .ueber-hero-content{padding:130px 24px 60px}
    .ueber-hero-content h1{font-size:56px}
    .ueber-hero-meta{flex-wrap:wrap;gap:24px}
    .ueber-hero-meta b{font-size:22px}

    /* Values 4 → 2 */
    .values-grid{grid-template-columns:repeat(2,1fr);gap:12px}
    .value-card{padding:24px 20px;min-height:0}
    .value-card h3{font-size:30px}

    /* Timeline */
    .timeline{padding-left:30px}
    .timeline-line{left:8px}
    .timeline-dot{left:-26px;width:11px;height:11px}
    .timeline-item{padding:18px 0 18px 0}
    .timeline-year{position:static;font-size:32px;margin-bottom:6px}
    .timeline-body{margin-left:0}
    .timeline-body h4{font-size:18px}

    /* Wehrführung 3 → 2 */
    .wehr-grid{grid-template-columns:repeat(2,1fr);gap:14px}
    .wehr-card{padding:18px}

    /* CTA band stack */
    .cta-band{grid-template-columns:1fr;padding:36px 28px;gap:28px}
    .cta-band h3{font-size:38px !important}

    /* Abteilungen overview — single column */
    .abt-grid{grid-template-columns:1fr;gap:14px}
    .abt-grid .abt-card-featured{grid-column:auto}
    .abt-grid .abt-card-featured h3{font-size:34px}
    .abt-card{padding:28px 24px;min-height:0}
    .abt-card h3{font-size:28px}
    .abt-card-meta{flex-wrap:wrap;gap:18px}
    .abt-card-meta b{font-size:20px}

    /* Abteilung detail — drop sidebar */
    .abt-detail{grid-template-columns:1fr;gap:32px}
    .abt-side{position:static}
    .abt-block .section-title{font-size:30px !important}

    /* Fleet cards (already stacked from 1280px) */
    .fleet-card{gap:20px}
    .fleet-title{font-size:30px;margin-top:10px}
    .fleet-specs{grid-template-columns:1fr}
    .fleet-spec{padding:9px 0 !important;border-right:none !important;padding-right:0 !important;padding-left:0 !important}
    .fleet-image{aspect-ratio:16/9}
    .fleet-kennung{font-size:18px;padding:4px 10px}

    /* Extras 3 → 2 */
    .extras-grid{grid-template-columns:repeat(2,1fr);gap:14px}

    /* Mitglied werden */
    .step-card{padding:24px 22px}
    .step-card h3{font-size:26px}
    .join-cols{grid-template-columns:1fr;padding:32px 24px;gap:32px}
    .join-form{padding:36px 24px;gap:32px}
    .join-form-right{padding:24px}

    /* Einsatz list — switch to card style on mobile */
    .einsatz{
      grid-template-columns:1fr;
      gap:6px;
      padding:18px 22px;
      border-left:3px solid transparent;
    }
    .einsatz:hover{padding-left:22px;border-left-color:var(--red)}
    .einsatz-num{font-size:11px;letter-spacing:0.16em}
    .einsatz-title{font-size:17px}
    .einsatz-meta{font-size:12px}
    .einsatz-arrow{display:none}
  }

  /* ===== Below 640px: small phone tweaks ===== */
  @media (max-width: 640px){
    .topbar{padding:14px 0 14px 16px}
    .brand{gap:10px}
    .brand-name{font-size:20px;letter-spacing:0.04em}
    .brand-sub{font-size:10.5px}
    .brand-mark.v-flame{width:38px;height:38px;border-radius:8px}
    .brand-mark.v-flame svg{width:22px;height:22px}
    .brand-mark.v-mono, .brand-mark.v-badge{width:42px;height:42px}
    .brand-mark.v-crest{width:38px;height:46px}

    .notruf{
      width:auto;height:62px;padding:0 16px 0 22px;
      clip-path:polygon(14px 0, 100% 0, 100% 100%, 0 100%);
      margin-top:-14px;margin-bottom:-14px;gap:8px;
    }
    .notruf-icon{width:30px;height:30px;border-width:1px}
    .notruf-icon svg{width:14px;height:14px}
    .notruf-label{font-size:8px}
    .notruf-num{font-size:22px;margin-top:1px}

    .hero{padding:48px 20px 0}
    .hero h1{font-size:44px}
    .eyebrow{font-size:11px}

    .cards{grid-template-columns:1fr;padding:0 20px}

    .photo-section{padding:48px 20px}
    .photo-section .quote{font-size:34px}

    .section{padding:48px 20px}
    .section-title{font-size:34px}

    .ueber-hero-content{padding:110px 20px 48px}
    .ueber-hero-content h1{font-size:44px}
    .ueber-hero-meta{gap:18px}
    .ueber-hero-meta > div{padding-left:14px}

    .values-grid{grid-template-columns:1fr}
    .wehr-grid{grid-template-columns:1fr}
    .extras-grid{grid-template-columns:1fr}

    .footer{padding:36px 20px 20px}
    .footer-grid{grid-template-columns:1fr;gap:24px;margin-bottom:24px}
    .footer-brand{grid-column:auto}

    .subhero{padding:84px 20px 40px}
    .subhero h1{font-size:38px}
    .subhero p{font-size:14px}

    .timeline-year{font-size:28px}

    .step-num{margin-bottom:14px}
    .step-card h3{font-size:24px}

    .fleet-title{font-size:26px}

    .btn{padding:14px 20px;font-size:13px;letter-spacing:0.18em}
  }

/* ============ WordPress-specific additions ============ */
.nav-item.has-menu:hover .nav-menu,
.nav-item.has-menu:focus-within .nav-menu{
  opacity:1; pointer-events:auto; visibility:visible; transform:translate(-50%, 0);
}
.nav-item.has-menu:hover > a .chev,
.nav-item.has-menu:focus-within > a .chev{
  transform:rotate(225deg) translate(-2px,-2px);
}

.generic-content{ max-width:760px; color:var(--text-muted); font-size:16px; line-height:1.85; }
.generic-content h2{ font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:36px; color:#fff; margin:48px 0 18px; letter-spacing:0.01em; }
.generic-content h3{ font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:26px; color:#fff; margin:36px 0 14px; letter-spacing:0.01em; }
.generic-content p{ margin-bottom:18px; }
.generic-content a{ color:var(--red); text-decoration:underline; text-underline-offset:3px; }
.generic-content a:hover{ color:#fff; }
.generic-content ul, .generic-content ol{ margin:0 0 18px 1.2em; }
.generic-content li{ margin-bottom:6px; }
.generic-content blockquote{ border-left:3px solid var(--red); padding-left:24px; margin:32px 0; font-family:'Barlow Condensed',sans-serif; font-size:24px; color:#fff; line-height:1.4; }
.generic-content img{ max-width:100%; height:auto; border-radius:4px; margin:18px 0; }

.page-numbers{ display:inline-flex; align-items:center; justify-content:center; min-width:42px; height:42px; padding:0 12px; border:1px solid rgba(255,255,255,0.08); font-family:'Barlow Condensed',sans-serif; font-weight:600; font-size:14px; letter-spacing:0.12em; color:var(--text-muted); text-decoration:none; transition: all .2s ease; }
.page-numbers:hover{ border-color:var(--red); color:#fff; }
.page-numbers.current{ background:var(--red); border-color:var(--red); color:#fff; }
.nav-links{ display:flex; gap:8px; flex-wrap:wrap; justify-content:center; }

body.admin-bar .topbar{ padding-top:60px; }
body.admin-bar .topbar .notruf{ margin-top:-60px; }

a.einsatz{ display:grid; }

.abt-grid .abt-card-featured{
  grid-column: 1 / -1;
  background: linear-gradient(135deg, rgba(226,53,53,0.10), rgba(20,26,35,0.98));
  border-color: rgba(226,53,53,0.25);
}
.abt-grid .abt-card-featured h3{ font-size: 44px; }
.abt-grid .abt-card-featured .abt-card-icon{ color: var(--red); }
.abt-grid .abt-card-featured p{ max-width: 720px; font-size: 16px; }

/* Mobile: when admin bar is shown, reduce its mobile offset */
@media (max-width: 782px){
  body.admin-bar .topbar{ padding-top: 46px; }
}

/* Mobile: featured abt card no longer spans full row */
@media (max-width: 960px){
  .abt-grid .abt-card-featured{ grid-column: auto; }
}
