/* ============================================================================
   Feuerwehr-Demo 7 — Plugin-Widget-Styles (Feuerwehr Intern)
   Bildet die Frontend-Komponenten des Plugins "Feuerwehr Intern" nach
   (public/css/frontend.css), damit die Elementor-Elemente
   [fi_vehicles] · [fi_member_directory] · [fi_incidents] · [fi_incident_stats]
   im Demo authentisch dargestellt werden.
   Klassennamen 1:1 wie im Plugin. Primärfarbe an das Demo-Branding angeglichen
   (im Live-Betrieb über das Theme/Plugin steuerbar).
   ========================================================================== */

.fi-area {
  --fi-primary: #C8102E;        /* im Demo an Branding angeglichen (Plugin: #c0392b) */
  --fi-primary-dark: #930a20;
  --fi-bg: #ffffff;
  --fi-muted: #6b7280;
  --fi-border: #e5e7eb;
  --fi-radius: 12px;
  color: #1f2937;
}

/* ----- Karte ----- */
.fi-area .fi-card {
  background: var(--fi-bg);
  border: 1px solid var(--fi-border);
  border-radius: var(--fi-radius);
  padding: 18px 20px;
  margin: 0 0 18px;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
  box-sizing: border-box;
}
.fi-area .fi-card h2, .fi-area .fi-card h3 { margin-top: 0; color: var(--fi-primary); }

/* ----- Button ----- */
.fi-area .fi-button {
  display: inline-block; background: var(--fi-primary); color: #fff !important;
  padding: 10px 18px; border-radius: 6px; border: 0; text-decoration: none;
  font-weight: 600; cursor: pointer; line-height: 1.2; font-size: 14px;
  transition: background .15s ease;
}
.fi-area .fi-button:hover, .fi-area .fi-button:focus { background: var(--fi-primary-dark); }
.fi-area .fi-button-secondary { background: #6b7280; }
.fi-area .fi-button-secondary:hover { background: #4b5563; }

.fi-area .fi-muted { color: var(--fi-muted); font-size: 13px; }
.fi-area .fi-link { color: var(--fi-primary); text-decoration: underline; }

/* ----- Filterleiste ----- */
.fi-area .fi-filter-bar {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  padding: 12px 14px; margin-bottom: 20px; background: #f9fafb;
  border: 1px solid var(--fi-border); border-radius: var(--fi-radius);
}
.fi-area .fi-filter-bar .fi-search-field,
.fi-area .fi-filter-bar .fi-select {
  padding: 8px 11px; border: 1px solid var(--fi-border); border-radius: 6px;
  background: #fff; font-size: 14px; line-height: 1.2; font-family: inherit; color: #1f2937;
}
.fi-area .fi-filter-bar .fi-select { flex: 0 1 220px; }
.fi-area .fi-filter-bar .fi-search-field { flex: 1 1 220px; min-width: 0; }

/* ----- Grids ----- */
.fi-area .fi-vehicles-grid,
.fi-area .fi-incidents-grid,
.fi-area .fi-member-list,
.fi-area .fi-meta-list { list-style: none; padding: 0; margin: 0; }
.fi-area .fi-list-cards {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 18px;
}
.fi-area .fi-list-cards > li { margin: 0; border-bottom: 0; }

/* ----- Bild-Platzhalter (im Plugin echte Fotos via has_post_thumbnail) ----- */
.fi-area .fi-photo {
  display: grid; place-items: center; aspect-ratio: 16/10; border-radius: 8px;
  background: linear-gradient(135deg, #8f1019, var(--fi-primary)); color: rgba(255,255,255,.6);
  position: relative; overflow: hidden;
}
.fi-area .fi-photo svg { width: 42px; height: 42px; opacity: .6; }
.fi-area .fi-photo::after {
  content: "Bildbereich"; position: absolute; bottom: 8px; right: 10px;
  font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.45);
}
.fi-area .fi-photo--blue { background: linear-gradient(135deg, #1e3a5f, #2f6fb0); }
.fi-area .fi-photo--slate { background: linear-gradient(135deg, #243240, #34506b); }

/* ----- Fahrzeug-Karte ----- */
.fi-area .fi-vehicle-card,
.fi-area .fi-incident-card { display: flex; flex-direction: column; gap: 8px; }
.fi-area .fi-vehicle-image, .fi-area .fi-incident-image { display: block; }
.fi-area .fi-vehicle-title { margin: 4px 0 0; font-size: 1.2rem; }
.fi-area .fi-vehicle-title a, .fi-area .fi-incident-card h3 a { color: #1f2937; text-decoration: none; }
.fi-area .fi-vehicle-title a:hover, .fi-area .fi-incident-card h3 a:hover { color: var(--fi-primary); }
.fi-area .fi-vehicle-radio-name { font-weight: 600; color: var(--fi-primary); margin: 0; }
.fi-area .fi-vehicle-excerpt, .fi-area .fi-incident-meta { margin: 0; color: #475569; font-size: .95rem; }
.fi-area .fi-vehicle-card .fi-button,
.fi-area .fi-incident-card .fi-button,
.fi-area .fi-member-card .fi-button { align-self: flex-start; margin-top: auto; }

/* ----- Einsatz-Karte ----- */
.fi-area .fi-incident-card h3 { margin: 2px 0 0; font-size: 1.18rem; color: #1f2937; }
.fi-area .fi-incident-keyword {
  display: inline-block; align-self: flex-start; padding: 3px 10px;
  background: var(--fi-primary); color: #fff; border-radius: 5px;
  font-size: 12px; text-transform: uppercase; letter-spacing: .05em; margin: 0; font-weight: 700;
}
.fi-area .fi-incident-vehicles { font-style: italic; color: var(--fi-muted); font-size: .9rem; margin: 0; }

/* ----- Mitglieder-Karte ----- */
.fi-area .fi-member-card { display: flex; flex-direction: column; gap: 6px; }
.fi-area .fi-member-card h3 { margin: 0; color: #1f2937; font-size: 1.15rem; }
.fi-area .fi-unit-badge {
  display: inline-block; padding: 3px 11px; background: var(--fi-primary);
  color: #fff !important; border-radius: 999px; font-size: 12px; letter-spacing: .02em;
}
.fi-area .fi-meta-list { margin: 4px 0 0; }
.fi-area .fi-meta-list li { padding: 6px 0; border-bottom: 1px solid var(--fi-border); font-size: .92rem; }
.fi-area .fi-meta-list li:last-child { border-bottom: 0; }
.fi-area .fi-meta-list a { color: var(--fi-primary); }

/* ----- Statistik-Karten (fi_incident_stats) ----- */
.fi-area .fi-incident-stats { margin: 0 0 24px; }
.fi-area .fi-stat-cards {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px;
}
.fi-area .fi-stat-card {
  display: flex; flex-direction: column; align-items: center; padding: 18px 14px;
  background: #fff; border: 1px solid var(--fi-border); border-radius: var(--fi-radius); text-align: center;
}
.fi-area .fi-stat-card strong { font-size: 28px; color: var(--fi-primary); line-height: 1; }
.fi-area .fi-stat-card span { font-size: 12px; color: var(--fi-muted); margin-top: 6px; }

/* ----- Balken-Statistik (Monatsverteilung) ----- */
.fi-area .fi-bars { display: flex; flex-direction: column; gap: 7px; margin-top: 8px; }
.fi-area .fi-bar-row { display: grid; grid-template-columns: 50px 1fr 40px; align-items: center; gap: 10px; }
.fi-area .fi-bar-label { font-size: 12px; color: var(--fi-muted); }
.fi-area .fi-bar-track { display: block; background: #e5e7eb; border-radius: 999px; height: 14px; overflow: hidden; }
.fi-area .fi-bar-fill { display: block; height: 100%; background: var(--fi-primary); border-radius: 999px; }
.fi-area .fi-bar-value { font-size: 12px; text-align: right; font-weight: 600; color: #1f2937; }

@media (max-width: 600px) {
  .fi-area .fi-list-cards { grid-template-columns: 1fr; }
  .fi-area .fi-card { padding: 14px 16px; }
}

/* ----- Widget-Rahmen im Demo (zeigt, dass es ein Elementor-Element ist) ----- */
.fi-widget-frame {
  border: 1px dashed var(--slate-300); border-radius: var(--r-lg);
  padding: clamp(16px, 3vw, 28px); background: #fff; position: relative;
}
.fi-widget-frame > .fi-widget-label {
  position: absolute; top: -11px; left: 20px; background: var(--ink); color: #fff;
  font-size: .7rem; font-weight: 700; letter-spacing: .06em; padding: 4px 12px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 7px;
}
.fi-widget-label svg { width: 13px; height: 13px; color: var(--flamme); }
