/*
Theme Name: FF Appen
Theme URI: https://ff-appen.de
Author: Freiwillige Feuerwehr Appen
Description: Modernes Theme für die Freiwillige Feuerwehr Appen. Farben angelehnt an das Wappen und die Landesdachmarke Schleswig-Holstein. Kompatibel mit Elementor (Free). Eigene Inhaltstypen für Einsätze und Fahrzeuge.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ff-appen
*/

/* ============ Grundlagen ============ */
:root {
  --ffa-blau: #262b5f;
  --ffa-blau-dunkel: #1c2049;
  --ffa-rot: #c8102e;
  --ffa-rot-dunkel: #a90d26;
  --ffa-text: #22243a;
  --ffa-grau: #5c5f78;
  --ffa-grau-hell: #8a8da5;
  --ffa-bg: #f4f4f1;
  --ffa-linie: rgba(30, 35, 80, .12);
  --ffa-radius: 10px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--ffa-bg);
  font-family: 'Barlow', system-ui, sans-serif;
  color: var(--ffa-text);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; }

a { color: var(--ffa-rot); }

h1, h2, h3, h4 {
  font-family: 'Barlow Condensed', sans-serif;
  color: var(--ffa-blau);
  line-height: 1.15;
  margin: 0 0 .4em;
}

h1 { font-size: 46px; font-weight: 700; }
h2 { font-size: 38px; font-weight: 700; }
h3 { font-size: 23px; font-weight: 600; }

.ffa-container {
  max-width: 1180px;
  margin: 0 auto;
  padding-left: 32px;
  padding-right: 32px;
}

/* ============ Notruf-Leiste ============ */
.ffa-notruf {
  background: var(--ffa-rot);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .02em;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24px;
  padding: 8px 32px;
  text-align: center;
}
.ffa-notruf .sep { opacity: .55; }
.ffa-notruf .hint { font-weight: 400; opacity: .9; }

/* ============ Warnbanner ============ */
.ffa-warn {
  background: #fff3e0;
  border-bottom: 1px solid rgba(180, 110, 0, .25);
  color: #7a4a00;
  font-size: 14px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 9px 32px;
}
.ffa-warn .dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: #e08700; flex: none;
  animation: ffa-pulse 2s infinite;
}
@keyframes ffa-pulse { 0%, 100% { opacity: 1; } 50% { opacity: .55; } }

/* ============ Header ============ */
.ffa-header {
  background: #fff;
  border-bottom: 1px solid var(--ffa-linie);
  position: sticky;
  top: 0;
  z-index: 50;
}
.ffa-header-inner {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-top: 14px;
  padding-bottom: 14px;
}
.ffa-brand {
  display: flex; align-items: center; gap: 14px;
  text-decoration: none; color: inherit;
}
.ffa-brand img { width: 52px; height: 52px; object-fit: contain; }
.ffa-brand-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 22px; line-height: 1;
  letter-spacing: .02em; color: var(--ffa-blau);
  display: block;
}
.ffa-brand-sub { font-size: 12.5px; color: var(--ffa-grau); display: block; margin-top: 2px; }

.ffa-nav { margin-left: auto; }
.ffa-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center; gap: 28px;
}
.ffa-nav a {
  font-size: 15px; font-weight: 500;
  color: var(--ffa-text); text-decoration: none;
}
.ffa-nav a:hover { color: var(--ffa-rot); }
.ffa-nav .ffa-cta > a {
  background: var(--ffa-rot); color: #fff; font-weight: 600;
  padding: 10px 20px; border-radius: 6px; display: inline-block;
}
.ffa-nav .ffa-cta > a:hover { background: var(--ffa-rot-dunkel); }
.ffa-nav .sub-menu { display: none; position: absolute; }
.ffa-nav li { position: relative; }
.ffa-nav li:hover > .sub-menu, .ffa-nav li:focus-within > .sub-menu {
  display: flex; flex-direction: column; gap: 0;
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: 8px; padding: 8px 0; min-width: 210px;
  top: 100%; left: -12px; box-shadow: 0 8px 24px rgba(30,35,80,.12);
}
.ffa-nav .sub-menu a { display: block; padding: 8px 18px; }

/* Hamburger */
.ffa-menu-toggle {
  display: none;
  margin-left: auto;
  background: none; border: 1px solid var(--ffa-linie);
  border-radius: 6px; padding: 9px 11px; cursor: pointer;
}
.ffa-menu-toggle span {
  display: block; width: 22px; height: 2px;
  background: var(--ffa-blau); margin: 5px 0;
  transition: transform .2s, opacity .2s;
}
.ffa-menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ffa-menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.ffa-menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============ Hero ============ */
.ffa-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: flex-end;
  background: var(--ffa-blau);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.ffa-hero::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(28,32,73,.15) 30%, rgba(28,32,73,.85) 100%);
}
.ffa-hero-inner {
  position: relative; z-index: 1; width: 100%;
  padding-top: 120px; padding-bottom: 56px;
  display: flex; flex-direction: column; gap: 18px;
}
.ffa-kicker {
  align-self: flex-start;
  background: var(--ffa-rot); color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 600; font-size: 15px; letter-spacing: .08em;
  padding: 6px 14px; border-radius: 4px;
  text-transform: uppercase;
}
.ffa-hero h1 { color: #fff; font-size: 58px; line-height: 1.05; max-width: 720px; margin: 0; }
.ffa-hero p { font-size: 18px; line-height: 1.55; color: rgba(255,255,255,.88); max-width: 560px; margin: 0; }
.ffa-hero-buttons { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 6px; }

/* ============ Buttons ============ */
.ffa-btn {
  display: inline-block;
  background: var(--ffa-rot); color: #fff !important;
  text-decoration: none; font-weight: 600; font-size: 16px;
  padding: 13px 26px; border-radius: 6px; border: 0; cursor: pointer;
}
.ffa-btn:hover { background: var(--ffa-rot-dunkel); }
.ffa-btn--ghost {
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.45);
}
.ffa-btn--ghost:hover { background: rgba(255,255,255,.26); }
.ffa-btn--outline {
  background: #fff; color: var(--ffa-blau) !important;
  border: 1px solid rgba(30,35,80,.25); font-size: 15px;
  padding: 11px 24px;
}
.ffa-btn--outline:hover { border-color: var(--ffa-rot); color: var(--ffa-rot) !important; background: #fff; }

/* ============ Sektionen ============ */
.ffa-section { padding-top: 64px; padding-bottom: 24px; }
.ffa-section-head { display: flex; align-items: flex-end; gap: 24px; margin-bottom: 28px; flex-wrap: wrap; }
.ffa-eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 600; font-size: 15px; letter-spacing: .1em;
  color: var(--ffa-rot); text-transform: uppercase;
  display: block; margin-bottom: 6px;
}
.ffa-section-head h2 { margin: 0; }
.ffa-section-head .ffa-stats { margin-left: auto; display: flex; gap: 12px; }

.ffa-stat {
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: 8px; padding: 12px 20px;
  display: flex; flex-direction: column; gap: 2px; align-items: center;
}
.ffa-stat b {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 28px; line-height: 1; color: var(--ffa-blau);
}
.ffa-stat span { font-size: 12.5px; color: var(--ffa-grau); }

/* ============ Karten-Raster ============ */
.ffa-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ffa-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.ffa-card {
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: var(--ffa-radius); padding: 22px;
  display: flex; flex-direction: column; gap: 12px;
  text-decoration: none; color: inherit;
}
a.ffa-card:hover { border-color: var(--ffa-rot); }
.ffa-card h3 { margin: 0; }
.ffa-card p { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--ffa-grau); }
.ffa-card .ffa-more { margin-top: auto; font-size: 14px; font-weight: 600; color: var(--ffa-rot); }

.ffa-badge {
  display: inline-block;
  background: var(--ffa-grau); color: #fff;
  font-size: 12px; font-weight: 700; letter-spacing: .05em;
  padding: 4px 10px; border-radius: 4px; text-transform: uppercase;
}
.ffa-badge--brand { background: var(--ffa-rot); }
.ffa-badge--th { background: var(--ffa-blau); }
.ffa-meta { font-size: 13px; color: var(--ffa-grau); }
.ffa-card-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

/* Bild-Karte (Fahrzeuge) */
.ffa-card--img { padding: 0; overflow: hidden; }
.ffa-card--img .ffa-card-body { padding: 18px 20px; display: flex; flex-direction: column; gap: 4px; }
.ffa-card--img img, .ffa-card--img .ffa-placeholder { width: 100%; height: 170px; object-fit: cover; display: block; }
.ffa-card--img .ffa-card-body span { font-size: 13.5px; color: var(--ffa-grau); }

.ffa-placeholder {
  background: repeating-linear-gradient(45deg, #e7e8ee 0 12px, #dfe0e8 12px 24px);
  display: flex; align-items: center; justify-content: center;
  font-family: ui-monospace, Menlo, monospace; font-size: 12px; color: var(--ffa-grau-hell);
}

.ffa-center { display: flex; justify-content: center; margin-top: 24px; }

/* ============ Dunkles Band (Mitmachen) ============ */
.ffa-band { background: var(--ffa-blau); margin-top: 24px; }
.ffa-band-inner { padding-top: 64px; padding-bottom: 64px; display: flex; flex-direction: column; gap: 36px; }
.ffa-band-head { display: flex; align-items: flex-end; gap: 24px; flex-wrap: wrap; }
.ffa-band-head .text { max-width: 640px; }
.ffa-band .ffa-eyebrow { color: #ff6b7d; }
.ffa-band h2 { color: #fff; }
.ffa-band-head p { margin: 0; font-size: 16.5px; color: rgba(255,255,255,.8); }
.ffa-band-head .ffa-btn { margin-left: auto; flex: none; }
.ffa-band .ffa-card {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.14);
}
.ffa-band .ffa-card:hover { border-color: rgba(255,255,255,.4); }
.ffa-band .ffa-card h3 { color: #fff; }
.ffa-band .ffa-card p { color: rgba(255,255,255,.75); }
.ffa-band .ffa-card .ffa-more { color: #ff6b7d; }

/* ============ Seitenkopf (Unterseiten) ============ */
.ffa-pagehead { background: var(--ffa-blau); }
.ffa-pagehead-inner { padding-top: 40px; padding-bottom: 44px; display: flex; flex-direction: column; gap: 14px; }
.ffa-pagehead h1 { color: #fff; margin: 0; }
.ffa-pagehead .ffa-sub { font-size: 15px; color: rgba(255,255,255,.75); }
.ffa-breadcrumb { display: flex; gap: 8px; font-size: 13.5px; color: rgba(255,255,255,.65); flex-wrap: wrap; }
.ffa-breadcrumb a { color: rgba(255,255,255,.65); text-decoration: none; }
.ffa-breadcrumb a:hover { color: #fff; }
.ffa-pagehead .ffa-badge-row { display: flex; align-items: center; gap: 12px; }
.ffa-pagehead .ffa-meta { color: rgba(255,255,255,.75); font-size: 14px; }

/* Jahresfilter */
.ffa-years { display: flex; gap: 10px; flex-wrap: wrap; }
.ffa-years a {
  background: rgba(255,255,255,.1); color: rgba(255,255,255,.85);
  font-weight: 500; font-size: 14.5px; padding: 8px 18px;
  border-radius: 6px; text-decoration: none;
}
.ffa-years a:hover { background: rgba(255,255,255,.2); }
.ffa-years a.aktiv { background: var(--ffa-rot); color: #fff; font-weight: 600; }

/* ============ Layout mit Sidebar ============ */
.ffa-layout {
  padding-top: 48px; padding-bottom: 48px;
  display: grid; grid-template-columns: 1fr 320px; gap: 36px;
  align-items: start;
}
.ffa-main { min-width: 0; display: flex; flex-direction: column; gap: 24px; }
.ffa-sidebar { display: flex; flex-direction: column; gap: 20px; }

.ffa-box {
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: var(--ffa-radius); padding: 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.ffa-box h3 { font-size: 24px; font-weight: 700; margin: 0; }
.ffa-box--dark { background: var(--ffa-blau); border: 0; }
.ffa-box--dark h3, .ffa-box--dark strong { color: #fff; }
.ffa-box--dark, .ffa-box--dark p { color: rgba(255,255,255,.85); }
.ffa-box--warn {
  background: #fff3e0; border-color: rgba(180,110,0,.25);
}
.ffa-box--warn h3 { color: #7a4a00; font-size: 20px; }
.ffa-box--warn p { margin: 0; font-size: 13.5px; color: #7a4a00; }

.ffa-datenliste { display: grid; grid-template-columns: auto 1fr; gap: 8px 16px; font-size: 14px; }
.ffa-datenliste dt { color: var(--ffa-grau); margin: 0; }
.ffa-datenliste dd { font-weight: 500; margin: 0; }

.ffa-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.ffa-chips a {
  background: #eceef2; color: var(--ffa-blau);
  font-size: 13px; font-weight: 600; padding: 6px 12px;
  border-radius: 5px; text-decoration: none;
}
.ffa-chips a:hover { background: var(--ffa-blau); color: #fff; }

/* Statistik-Balken */
.ffa-bar-row { display: flex; flex-direction: column; gap: 5px; }
.ffa-bar-label { display: flex; justify-content: space-between; font-size: 13.5px; }
.ffa-bar-label span:first-child { font-weight: 500; }
.ffa-bar-label span:last-child { color: var(--ffa-grau); }
.ffa-bar { height: 8px; background: #eceef2; border-radius: 4px; overflow: hidden; }
.ffa-bar i { display: block; height: 100%; background: var(--ffa-blau); }
.ffa-bar i.brand { background: var(--ffa-rot); }
.ffa-bar i.sonst { background: var(--ffa-grau-hell); }
.ffa-box-total {
  border-top: 1px solid var(--ffa-linie); padding-top: 14px;
  display: flex; justify-content: space-between; font-size: 14px; font-weight: 700;
  color: var(--ffa-blau);
}

/* ============ Einsatz-Liste ============ */
.ffa-einsatz-liste { display: flex; flex-direction: column; gap: 14px; }
.ffa-einsatz-row {
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: var(--ffa-radius); padding: 18px 22px;
  display: flex; align-items: center; gap: 20px;
  text-decoration: none; color: inherit;
}
.ffa-einsatz-row:hover { border-color: var(--ffa-rot); }
.ffa-einsatz-datum {
  flex: none; width: 76px;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  border-right: 1px solid var(--ffa-linie); padding-right: 18px;
}
.ffa-einsatz-datum b {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 24px; line-height: 1; color: var(--ffa-blau);
}
.ffa-einsatz-datum span { font-size: 12.5px; color: var(--ffa-grau); }
.ffa-einsatz-info { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.ffa-einsatz-info h3 { margin: 0; font-size: 22px; }
.ffa-einsatz-row .pfeil { margin-left: auto; flex: none; font-weight: 600; color: var(--ffa-rot); }

/* ============ Artikel / Bericht ============ */
.ffa-artikel p { font-size: 16.5px; line-height: 1.7; margin: 0 0 1em; }
.ffa-artikel img { border-radius: var(--ffa-radius); }
.ffa-artikel-hero { border-radius: var(--ffa-radius); overflow: hidden; }
.ffa-artikel-hero img { display: block; width: 100%; height: auto; }

/* ============ Termin-Karten ============ */
.ffa-termin {
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: var(--ffa-radius); padding: 20px;
  display: flex; gap: 18px; align-items: center;
}
.ffa-termin-datum {
  flex: none; width: 62px; background: var(--ffa-blau); color: #fff;
  border-radius: 8px; display: flex; flex-direction: column;
  align-items: center; padding: 10px 0;
}
.ffa-termin-datum b { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 26px; line-height: 1; }
.ffa-termin-datum span { font-size: 12px; letter-spacing: .05em; text-transform: uppercase; }
.ffa-termin h3 { margin: 0; font-size: 21px; }
.ffa-termin .ffa-meta { font-size: 13.5px; }

/* ============ Tabellen (Fahrzeug-Daten) ============ */
.ffa-tabelle {
  background: #fff; border: 1px solid var(--ffa-linie);
  border-radius: var(--ffa-radius); overflow: hidden;
  width: 100%; border-collapse: collapse; font-size: 14.5px;
}
.ffa-tabelle th, .ffa-tabelle td {
  text-align: left; padding: 13px 20px;
  border-bottom: 1px solid rgba(30,35,80,.08);
}
.ffa-tabelle tr:last-child th, .ffa-tabelle tr:last-child td { border-bottom: 0; }
.ffa-tabelle tr:nth-child(even) { background: #fafafd; }
.ffa-tabelle th { color: var(--ffa-grau); font-weight: 400; width: 40%; }
.ffa-tabelle td { font-weight: 500; }

/* ============ Inhalt (WYSIWYG / Elementor-frei) ============ */
.ffa-content { padding-top: 48px; padding-bottom: 48px; }
.ffa-content > p, .ffa-content > ul, .ffa-content > ol { font-size: 16.5px; line-height: 1.7; }
.ffa-content ul li { margin-bottom: .4em; }

/* ============ Footer ============ */
.ffa-footer { background: var(--ffa-blau-dunkel); color: #fff; margin-top: 32px; }
.ffa-footer-grid {
  padding-top: 56px; padding-bottom: 40px;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1.2fr; gap: 40px;
}
.ffa-footer-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.ffa-footer-brand img { width: 46px; height: 46px; object-fit: contain; border-radius: 4px; }
.ffa-footer-brand span {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 19px; letter-spacing: .02em;
}
.ffa-footer p { margin: 0; font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.65); max-width: 320px; }
.ffa-footer-col h4 {
  color: rgba(255,255,255,.5); font-family: 'Barlow', sans-serif;
  font-weight: 600; letter-spacing: .04em; font-size: 13px;
  text-transform: uppercase; margin: 0 0 10px;
}
.ffa-footer-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ffa-footer-col a { color: rgba(255,255,255,.85); text-decoration: none; font-size: 14px; }
.ffa-footer-col a:hover { color: #fff; }
.ffa-footer-notruf {
  background: var(--ffa-rot); border-radius: var(--ffa-radius);
  padding: 20px 22px; align-self: start;
}
.ffa-footer-notruf b {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 22px; display: block; margin-bottom: 6px;
}
.ffa-footer-notruf p { font-size: 13.5px; color: rgba(255,255,255,.85); max-width: none; }
.ffa-footer-bottom { border-top: 1px solid rgba(255,255,255,.12); }
.ffa-footer-bottom-inner {
  padding-top: 18px; padding-bottom: 18px;
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  font-size: 13px; color: rgba(255,255,255,.5);
}

/* ============ Pagination ============ */
.ffa-pagination { display: flex; gap: 8px; justify-content: center; padding: 24px 0; }
.ffa-pagination .page-numbers {
  background: #fff; border: 1px solid var(--ffa-linie);
  padding: 8px 14px; border-radius: 6px; text-decoration: none;
  color: var(--ffa-blau); font-weight: 500; font-size: 14px;
}
.ffa-pagination .page-numbers.current { background: var(--ffa-blau); color: #fff; border-color: var(--ffa-blau); }

/* ================================================= */
/* ============ RESPONSIVE ========================= */
/* ================================================= */

/* --- Tablet (bis 1024px) --- */
@media (max-width: 1024px) {
  .ffa-container { padding-left: 24px; padding-right: 24px; }
  h1 { font-size: 38px; }
  h2 { font-size: 32px; }
  .ffa-hero h1 { font-size: 44px; }
  .ffa-hero { min-height: 440px; }
  .ffa-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .ffa-layout { grid-template-columns: 1fr; }
  .ffa-sidebar { flex-direction: row; flex-wrap: wrap; }
  .ffa-sidebar > * { flex: 1 1 300px; }
  .ffa-footer-grid { grid-template-columns: 1fr 1fr; }

  /* Mobile Navigation ab Tablet */
  .ffa-menu-toggle { display: block; }
  .ffa-nav {
    display: none;
    position: absolute; left: 0; right: 0; top: 100%;
    background: #fff; border-bottom: 1px solid var(--ffa-linie);
    box-shadow: 0 12px 24px rgba(30,35,80,.12);
  }
  .ffa-nav.ist-offen { display: block; }
  .ffa-nav ul { flex-direction: column; align-items: stretch; gap: 0; padding: 8px 0; }
  .ffa-nav li { border-bottom: 1px solid rgba(30,35,80,.06); }
  .ffa-nav li:last-child { border-bottom: 0; }
  .ffa-nav a { display: block; padding: 14px 24px; font-size: 16px; }
  .ffa-nav .ffa-cta > a { margin: 10px 24px 14px; border-radius: 6px; text-align: center; }
  .ffa-nav .sub-menu, .ffa-nav li:hover > .sub-menu {
    display: block; position: static; border: 0; box-shadow: none;
    padding: 0 0 4px; background: #fafafd;
  }
  .ffa-nav .sub-menu a { padding-left: 44px; font-size: 15px; }
}

/* --- Smartphone (bis 640px) --- */
@media (max-width: 640px) {
  .ffa-container { padding-left: 18px; padding-right: 18px; }
  body { font-size: 15px; }
  h1 { font-size: 32px; }
  h2 { font-size: 27px; }
  .ffa-notruf { flex-direction: column; gap: 2px; padding: 8px 16px; }
  .ffa-notruf .sep { display: none; }
  .ffa-warn { padding: 9px 16px; font-size: 13px; }
  .ffa-brand img { width: 42px; height: 42px; }
  .ffa-brand-name { font-size: 17px; }
  .ffa-brand-sub { font-size: 11px; }
  .ffa-hero { min-height: 380px; }
  .ffa-hero-inner { padding-top: 80px; padding-bottom: 36px; }
  .ffa-hero h1 { font-size: 33px; }
  .ffa-hero p { font-size: 16px; }
  .ffa-section { padding-top: 44px; }
  .ffa-grid-3, .ffa-grid-2 { grid-template-columns: 1fr; }
  .ffa-section-head .ffa-stats { margin-left: 0; width: 100%; }
  .ffa-stat { flex: 1; }
  .ffa-band-head .ffa-btn { margin-left: 0; }
  .ffa-einsatz-row { flex-wrap: wrap; gap: 12px; padding: 16px 18px; }
  .ffa-einsatz-datum {
    flex-direction: row; width: auto; border-right: 0; padding-right: 0;
    gap: 6px; align-items: baseline;
  }
  .ffa-einsatz-row .pfeil { display: none; }
  .ffa-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .ffa-footer-bottom-inner { flex-direction: column; gap: 4px; }
  .ffa-btn { width: 100%; text-align: center; }
  .ffa-hero-buttons .ffa-btn { width: auto; flex: 1; }
  .ffa-datenliste { grid-template-columns: 1fr; gap: 2px 0; }
  .ffa-datenliste dt { margin-top: 8px; }
}
