/* CFO Dashboard CSS — Phase 2-B B2.
 *
 * Visual-Stil: Landing v8 (helle Akten-DNA, Italic-Akzente).
 * Layout-Pattern: Mockup-01 KPI-Row + Trend-Card + Quick-Actions.
 * Tokens: ausschliesslich var(--token), keine Hex-Codes.
 */

.cockpit-main {
  padding: var(--space-5) var(--space-7) var(--space-7);
  max-width: 1200px;
  margin: 0 auto;
  font-family: var(--font-sans);
  color: var(--ink);
}

.cockpit-header {
  margin-bottom: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  align-items: flex-start;
}

.cockpit-crumb {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--light-slate);
  font-weight: 600;
}

.cockpit-title {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--navy);
  margin: var(--space-1) 0 var(--space-2) 0;
  line-height: 1.15;
}

/* === Phase 2-F Block G.4: Drei-Dimensionen-Tiles ==========================
 * 3 Top-Level-Tiles ueber der bestehenden KPI-Row. Sven-Direktive 13.05.:
 * Customer-Cockpit zeigt Recovery / Preventive / Compliance als
 * Top-Level-Klassifikation; lever_class bleibt Sub-Filter in Werkbench.
 *
 * Brand-Akzentfarben (gespiegelt in services/finding_category_mapping.py
 * CATEGORY_COLORS):
 *   recovery   → FIP-Navy (#1A2744) — primary value, dominantes Tile
 *   preventive → FIP-Gold (#D4A843) — Einsparung-Akzent
 *   compliance → gedaempftes Rot (#B23A48) — Risiko-Akzent
 */
.kpi-grid--three-categories {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
@media (max-width: 1024px) {
  .kpi-grid--three-categories {
    grid-template-columns: 1fr;
  }
}
.kpi-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-4);
  text-decoration: none;
  color: inherit;
  border-left: 4px solid transparent;
  transition: transform .12s ease, box-shadow .12s ease;
}
.kpi-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(26, 39, 68, 0.08);
}
.kpi-card .kpi-label {
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--light-slate);
}
.kpi-card .kpi-value {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.1;
}
.kpi-card .kpi-value .fip-kpi-currency {
  font-family: var(--font-sans);
  font-size: 0.65em;
  color: var(--light-slate);
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-left: 4px;
}
.kpi-card .kpi-subline {
  font-size: 13px;
  color: var(--slate);
  line-height: 1.35;
}
.kpi-card .kpi-meta {
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--light-slate);
  margin-top: auto;
}
.kpi-card--recovery   { border-left-color: var(--category-recovery); }
.kpi-card--preventive { border-left-color: var(--category-preventive); }
.kpi-card--compliance { border-left-color: var(--category-compliance); }

/* === Finding-Category-Pill ================================================
 * Subtle Pill auf jeder Card in Werkbench + Beweis-Akte fuer Drei-Dim-
 * Transparenz. Klein, Brand-Akzentfarbe als linker Strich + Hintergrund.
 * Farben via Design-Tokens (var(--category-*)), keine inline-Hex-Literals
 * (Smoke 150 FAIL-mode auf Component-CSS).
 */
.finding-category-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 2px 8px 2px 6px;
  border-radius: 99px;
  border-left: 3px solid currentColor;
  background: rgba(26, 39, 68, 0.05);
  color: var(--navy);
  white-space: nowrap;
}
.finding-category-pill--recovery   { color: var(--category-recovery-text);   background: rgba(26, 39, 68, 0.08); }
.finding-category-pill--preventive { color: var(--category-preventive-text); background: rgba(212, 168, 67, 0.18); }
/* Phase 2-F-Followup-3 Block C: Sand-Tint statt Rust-Rot (Sven-Decision 15.05.,
   Brand-konsistent — Rot reserviert fuer Severity-Stamps). */
.finding-category-pill--compliance { color: var(--category-compliance-text); background: rgba(197, 181, 131, 0.22); }


/* === KPI-Row =============================================================
 * 4 Cards, Hero-KPI 1.4× breit (Mockup-01 Pattern).
 * Auf <1024px wraps das Grid auf 2x2.
 */
.kpi-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

@media (max-width: 1024px) {
  .kpi-row {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .kpi-row {
    grid-template-columns: 1fr;
  }
}

.kpi-row .fip-kpi {
  position: relative;
  overflow: hidden;
}

/* Hero-KPI (Mockup-01 Pattern + Italic-Akzent aus Landing v8) */
.kpi-row .fip-kpi.fip-kpi--hero {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-soft) 100%);
  color: var(--card);
  border: none;
  padding: var(--space-5);
}

.kpi-row .fip-kpi.fip-kpi--hero::after {
  content: "";
  position: absolute;
  right: -40px;
  top: -40px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  border: 1px solid rgba(184, 136, 74, 0.18);
  pointer-events: none;
}

.kpi-row .fip-kpi.fip-kpi--hero .fip-kpi-label {
  color: var(--gold-bright);
}

.kpi-row .fip-kpi.fip-kpi--hero .fip-kpi-value {
  color: var(--card);
  font-size: 2.25rem;
}

.kpi-row .fip-kpi.fip-kpi--hero .fip-kpi-value em {
  font-style: italic;
  color: var(--card);
}

.kpi-row .fip-kpi.fip-kpi--hero .fip-kpi-sub {
  color: rgba(255, 255, 255, 0.65);
}

.kpi-row .fip-kpi.fip-kpi--hero .fip-kpi-delta {
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.10);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-2);
  font-size: 11px;
  font-weight: 600;
}

.fip-kpi-currency {
  font-family: var(--font-mono);
  font-size: 0.55em;
  font-weight: 500;
  color: var(--ink-soft);
  margin-left: 2px;
  letter-spacing: 0.06em;
}

/* === Content-Grid: Trend + Quick-Actions =================================
 * Trend nimmt 1fr, Quick-Actions 340px fest (Mockup-01 Pattern).
 */
.cockpit-content-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-5);
}

@media (max-width: 1024px) {
  .cockpit-content-grid {
    grid-template-columns: 1fr;
  }
}

.cockpit-trend-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-5);
}

.cockpit-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-4);
  gap: var(--space-3);
}

.cockpit-card-head h3 {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0;
}

.cockpit-card-sub {
  font-size: 11px;
  color: var(--ink-soft);
  display: block;
  margin-top: 2px;
}

/* View-Toggle Trend ↔ Treemap */
.view-toggle {
  display: inline-flex;
  background: var(--off-white);
  border-radius: var(--radius-pill);
  padding: 3px;
  gap: 2px;
}

.view-toggle-btn {
  padding: 5px 14px;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  background: transparent;
  color: var(--ink-soft);
  border: none;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}

.view-toggle-btn:hover {
  color: var(--ink);
}

.view-toggle-btn--active {
  background: var(--card);
  color: var(--navy);
  box-shadow: 0 1px 3px rgba(31, 26, 20, 0.12);
}

.cockpit-trend-svg {
  flex: 1;
  min-height: 240px;
  position: relative;
}

.cockpit-treemap-svg {
  flex: 1;
  min-height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-soft);
  font-size: 12px;
}

/* === Quick-Actions ======================================================= */
.cockpit-quick-actions {
  padding: var(--space-5);
}

.cockpit-quick-actions h3 {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 2px 0;
}

.quick-action-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-3);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--ink);
  margin: var(--space-3) 0 0 0;
  border: 1px solid transparent;
  transition: background var(--transition), border-color var(--transition);
}

.quick-action-item:hover {
  background: var(--off-white);
  border-color: var(--border);
}

.qa-icon {
  font-size: 18px;
  width: 32px;
  flex-shrink: 0;
  text-align: center;
  color: var(--gold);
}

.qa-info {
  flex: 1;
  min-width: 0;
}

.qa-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}

.qa-sub {
  font-size: 11px;
  color: var(--ink-soft);
  margin-top: 2px;
}

.qa-count {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--gold);
  flex-shrink: 0;
}


/* ============================================================================
   2-Bxy Bxy2 — Bars-Grid (Findings nach Hebel + nach Status)
   ============================================================================ */

.uebersicht-bars-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.uebersicht-bars-card h3 {
  font-family: var(--font-serif);
  font-size: 1.04rem;
  margin-bottom: var(--space-3);
  color: var(--ink);
}

.uebersicht-bar-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.uebersicht-bar-row {
  display: grid;
  grid-template-columns: minmax(140px, 30%) 1fr auto;
  align-items: center;
  gap: var(--space-3);
  font-size: 0.84rem;
}

.uebersicht-bar-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}

.uebersicht-bar-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--light-slate);
}

.uebersicht-bar-dot--status-neu             { background: var(--light-slate); }
.uebersicht-bar-dot--status-in_klaerung     { background: var(--gold); }
.uebersicht-bar-dot--status-validiert       { background: var(--lever-strategic); }
.uebersicht-bar-dot--status-in_umsetzung    { background: var(--lever-recovery); }
.uebersicht-bar-dot--status-abgeschlossen   { background: var(--sage); }

.uebersicht-bar-name {
  font-weight: 500;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.uebersicht-bar-count {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  color: var(--ink-soft);
  margin-left: auto;
}

.uebersicht-bar-track {
  height: 8px;
  background: var(--off-white);
  border-radius: var(--radius-pill);
  overflow: hidden;
  border: 1px solid var(--border);
}

.uebersicht-bar-fill {
  height: 100%;
  border-radius: var(--radius-pill);
  background: var(--gold);
  transition: width 0.3s ease;
}

.uebersicht-bar-fill--status-neu             { background: var(--light-slate); }
.uebersicht-bar-fill--status-in_klaerung     { background: var(--gold); }
.uebersicht-bar-fill--status-validiert       { background: var(--lever-strategic); }
.uebersicht-bar-fill--status-in_umsetzung    { background: var(--lever-recovery); }
.uebersicht-bar-fill--status-abgeschlossen   { background: var(--sage); }

.uebersicht-bar-value {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--ink);
  font-weight: 500;
  text-align: right;
  white-space: nowrap;
}


/* ============================================================================
   2-Bxy Bxy2 — Top-3-Cards
   ============================================================================ */

.uebersicht-top3-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.uebersicht-top3-card h3 {
  font-family: var(--font-serif);
  font-size: 1.04rem;
  margin-bottom: var(--space-3);
  color: var(--ink);
}

.uebersicht-top3-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.uebersicht-top3-item {
  border-top: 1px dashed var(--paper-line);
  padding-top: var(--space-3);
}

.uebersicht-top3-item:first-child {
  border-top: none;
  padding-top: 0;
}

.uebersicht-top3-amount {
  font-family: var(--font-serif);
  font-size: 1.18rem;
  font-weight: 700;
  font-style: italic;
  color: var(--ink);
}

.uebersicht-top3-amount-small {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--ink-soft);
  margin-top: 2px;
}

.uebersicht-top3-title {
  font-size: 0.92rem;
  color: var(--ink);
  line-height: 1.35;
  margin: 4px 0 4px 0;
}

.uebersicht-top3-meta {
  font-size: 0.76rem;
  color: var(--ink-soft);
}

.uebersicht-top3-sev-pill {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  background: var(--off-white);
  color: var(--ink-soft);
  text-transform: uppercase;
}

.uebersicht-top3-sev-pill--critical { background: var(--stamp-red); color: var(--card); }
.uebersicht-top3-sev-pill--high     { background: var(--rust); color: var(--card); }
.uebersicht-top3-sev-pill--medium   { background: var(--gold); color: var(--card); }
.uebersicht-top3-sev-pill--low      { background: var(--slate); color: var(--card); }
.uebersicht-top3-sev-pill--info     { background: var(--off-white); color: var(--ink-soft); }

.uebersicht-empty {
  font-size: 0.84rem;
  color: var(--light-slate);
  font-style: italic;
}


/* ============================================================================
   2-Bxy Bxy2 — Prüfbereiche-Footer
   ============================================================================ */

.uebersicht-pruefbereiche {
  margin-top: var(--space-4);
}

.uebersicht-pruefbereiche h3 {
  font-family: var(--font-serif);
  font-size: 1.04rem;
  margin-bottom: var(--space-3);
  color: var(--ink);
}

.uebersicht-pruefbereiche-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-2);
}

.uebersicht-pruefbereiche-cell {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  text-align: center;
}

.uebersicht-pruefbereiche-label {
  font-size: 0.76rem;
  color: var(--ink-soft);
  margin-bottom: 4px;
  font-weight: 500;
}

.uebersicht-pruefbereiche-count {
  font-family: var(--font-serif);
  font-size: 1.42rem;
  font-weight: 700;
  color: var(--ink);
}

.uebersicht-pruefbereiche-eur {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--slate);
  margin-top: 2px;
}


/* ============================================================================
   2-Bxy Bxy3 — Pyramide-Container (drillbare Hebel→Cluster→Modul-Treemap)
   ============================================================================ */

.cockpit-pyramide {
  width: 100%;
  height: 220px;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.pyramide-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.78rem;
}

.pyramide-crumb-btn {
  background: none;
  border: none;
  padding: 4px 8px;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  color: var(--gold);
  cursor: pointer;
  border-radius: var(--radius);
}

.pyramide-crumb-btn:hover { background: var(--off-white); }

.pyramide-crumb-btn::after {
  content: '›';
  margin-left: var(--space-2);
  color: var(--light-slate);
}

.pyramide-crumb-btn:last-child::after { content: ''; }

.pyramide-svg {
  flex: 1;
  width: 100%;
  height: auto;
  min-height: 180px;
}

.pyramide-rect {
  cursor: pointer;
  transition: opacity 0.15s ease;
}

.pyramide-rect:hover { opacity: 0.85; }

.pyramide-rect-label {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  fill: var(--card);
  pointer-events: none;
  user-select: none;
}

.pyramide-rect-value {
  font-family: var(--font-mono);
  font-size: 10px;
  fill: var(--card);
  fill-opacity: 0.9;
  pointer-events: none;
  user-select: none;
}

.pyramide-legend {
  font-size: 0.72rem;
  color: var(--slate);
  text-align: center;
}

.pyramide-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 180px;
  color: var(--light-slate);
  font-style: italic;
  font-size: 0.92rem;
}

@media (max-width: 1100px) {
  .uebersicht-bars-grid,
  .uebersicht-top3-grid {
    grid-template-columns: 1fr;
  }
}


/* ============================================================================
   2-Bxy Hotfix1 H4: Treemap-Section (Vollbreite) + Volumen-Bubble-Chart
   ============================================================================ */

.cockpit-treemap-section,
.cockpit-volumen-section {
  margin-top: var(--space-5);
  padding: var(--space-4) var(--space-5);
}

.cockpit-treemap-section .cockpit-pyramide {
  height: auto;
  min-height: 280px;
}

.cockpit-treemap-section .pyramide-svg {
  min-height: 240px;
}

/* Crumb-Icon im Breadcrumb-Root */
.pyramide-crumb-icon {
  margin-right: var(--space-1);
  font-size: 14px;
  vertical-align: middle;
}

/* Hotfix1 H4: Zurueck-Button mit Icon + Label, prominent rechts in Breadcrumb */
.pyramide-back-btn {
  margin-left: auto;
  background: var(--off-white);
  border: 1px solid var(--border);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--gold);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.pyramide-back-btn:hover {
  background: var(--card);
  border-color: var(--gold);
}

.pyramide-breadcrumb {
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* === Volumen-Bubble-Chart === */

.cockpit-volumen-svg {
  width: 100%;
  height: auto;
  min-height: 220px;
  display: block;
}

.cockpit-volumen-svg .vc-axis {
  stroke: var(--border);
  stroke-width: 1;
}

.cockpit-volumen-svg .vc-tick {
  stroke: var(--border);
  stroke-width: 0.6;
  opacity: 0.5;
}

.cockpit-volumen-svg .vc-axis-label {
  font-family: var(--font-mono);
  font-size: 10px;
  fill: var(--slate);
}

.cockpit-volumen-svg .vc-bubble {
  cursor: pointer;
  transition: opacity 0.15s ease;
}

.cockpit-volumen-svg .vc-bubble:hover {
  opacity: 0.9;
}

/* ============================================================================
   2-Bxy Hotfix1 H3: Scroll-Fix fuer cockpit-main
   ============================================================================ */

.cockpit-main {
  overflow: visible;  /* explizit, falls Cascade etwas anderes setzt */
}

body.cockpit-body,
body.has-fip-sidebar.cockpit-body {
  overflow-y: auto;
  min-height: 100vh;
  height: auto;
}


/* ============================================================================
   2-Bxy Hotfix2 H2: Scroll-Fix Followup (html+body overflow-y explizit)
   ----------------------------------------------------------------------------
   Hotfix1 H3 hatte body.cockpit-body { overflow-y: auto } gesetzt — das reichte
   nicht. portal.css Z. 1483 setzt body { ... overflow-x: auto; ... } ohne
   overflow-y, was effektiv 'visible' default bedeutet, aber wenn an html-Element
   eine height-constraint hängt (kommt von body.has-fip-sidebar?), wird der
   Page-Body nicht scrollbar.
   Fix: explizit auf html und body level overflow-y: auto + height auto. Damit
   ist der Browser-Default-Scroll wieder aktiv unabhängig von Cascade.
   ============================================================================ */

html,
body {
  overflow-y: auto !important;
  min-height: 100vh;
  height: auto;
}

/* Cockpit-Page-Container darf nicht clippen */
.cockpit-main,
.findings-page,
.lieferanten-page,
.evidence-page,
.werkbench-main {
  overflow: visible;
}


/* Hotfix2 H4c: Vendor-Name-Label auf Bubble-Chart */
.cockpit-volumen-svg .vc-bubble-label {
  font-family: var(--font-sans);
  font-size: 10px;
  fill: var(--ink);
  pointer-events: none;
  user-select: none;
}

/* === Phase 2-Z Maurice-Features (17.05.) Block A+C: Schichtendiagramm ====== */
.cockpit-schichten-section { padding: var(--space-5) var(--space-6); margin-bottom: var(--space-5); }
.cockpit-schichten-section .cockpit-card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: var(--space-4); gap: var(--space-4); flex-wrap: wrap;
}
.cockpit-schichten-svg {
  width: 100%; height: auto; max-height: 280px; display: block;
}
.cockpit-schichten-legend {
  display: flex; gap: var(--space-4); margin-top: var(--space-3);
  flex-wrap: wrap; justify-content: flex-start;
}
.schicht-legend-item {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: 12px; color: var(--slate);
}
.schicht-legend-swatch {
  width: 12px; height: 12px; border-radius: 2px; display: inline-block;
  flex-shrink: 0;
}
.schicht-legend-label { font-weight: 500; color: var(--navy); }
.schicht-legend-value { font-family: var(--font-mono); font-size: 11px; color: var(--slate); }

/* Toggle (Block C) — Tabs-Style oben rechts am Chart-Header */
.schichten-toggle {
  display: inline-flex; gap: 0; border: 1px solid var(--paper-edge);
  border-radius: var(--radius-md); overflow: hidden;
}
.schichten-tab {
  padding: var(--space-2) var(--space-4); font-size: 12px; font-weight: 500;
  background: transparent; color: var(--slate); border: none; cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast);
}
.schichten-tab:hover { background: var(--paper); color: var(--navy); }
.schichten-tab--active { background: var(--navy); color: var(--paper); }
.schichten-tab--active:hover { background: var(--navy-light, var(--navy)); color: var(--paper); }

@media (max-width: 800px) {
  .cockpit-schichten-section .cockpit-card-head { flex-direction: column; }
  .cockpit-schichten-legend { gap: var(--space-3); }
  .schicht-legend-value { display: none; }
}

/* ================================================================
 * POC Pattern-Card 1 — Zahlungs-Verhalten
 * Inbox pattern-card-zahlungsverhalten-poc-2026-05-18, Sven-Direktive
 * Pattern-Layer-Foundation. Position zwischen KPI-Tiles und Schichten-
 * Diagramm. Brand-Tokens: navy/gold/cream wie restliche Cards.
 * ================================================================ */
.cockpit-pattern-card {
  background: var(--cream, #fdf9f3);
  border-left: 3px solid var(--gold, #b89046);
}

.cockpit-pattern-narrative {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--slate);
  margin: var(--space-3) 0 var(--space-4);
}
.cockpit-pattern-narrative strong {
  color: var(--navy);
  font-weight: 600;
}

.cockpit-pattern-vendors {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.cockpit-pattern-vendors-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--slate);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-right: var(--space-2);
}
.cockpit-pattern-vendor-chip {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-2);
  padding: 4px 10px;
  border: 1px solid var(--paper-edge);
  border-radius: var(--radius-pill, 999px);
  background: var(--paper, #fff);
  font-size: 13px;
  color: var(--navy);
  font-weight: 500;
}
.cockpit-pattern-vendor-chip[data-direction="too_early"] {
  border-color: rgba(38, 87, 138, 0.35);
}
.cockpit-pattern-vendor-chip[data-direction="too_late"] {
  border-color: rgba(184, 144, 70, 0.45);
}
.cockpit-pattern-vendor-drift {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--slate);
  font-weight: 400;
}

.cockpit-pattern-action {
  margin-top: var(--space-3);
}
.cockpit-pattern-link {
  display: inline-block;
  color: var(--gold-bright, #c4a05a);
  font-weight: 500;
  font-size: 14px;
  text-decoration: none;
  border-bottom: 1px dotted var(--gold, #b89046);
  padding-bottom: 1px;
  transition: color var(--transition-fast);
}
.cockpit-pattern-link:hover {
  color: var(--navy);
  border-bottom-style: solid;
}

.cockpit-pattern-gold-divider {
  margin-top: var(--space-4);
  height: 1px;
  background: linear-gradient(
    to right,
    transparent 0%,
    var(--gold, #b89046) 30%,
    var(--gold, #b89046) 70%,
    transparent 100%
  );
  opacity: 0.5;
}

@media (max-width: 800px) {
  .cockpit-pattern-vendors { gap: var(--space-1); }
  .cockpit-pattern-vendor-chip { font-size: 12px; padding: 3px 8px; }
}

/* ============================================================================
 * Phase 3B Erleben + Pre-Merge-Hotfix Block C (24.05.) — Cockpit-Hero
 * Brand-Direktive feedback_brand_differenzierung_ueber_inhalt:
 *   Recovery-CHF als Primärzahl (Tatsachenbehauptung, gross),
 *   Integrity-Score als Sekundär (Qualitätsindikator, klein),
 *   Beweisstück-Zeile (Muster · Lieferanten · offene Maßnahmen).
 * ========================================================================== */
.cockpit-hero {
  background: var(--card, #fff);
  border: 1px solid var(--border, #e7e2d8);
  border-radius: var(--radius, 6px);
  padding: var(--space-6, 24px) var(--space-7, 32px);
  margin-bottom: var(--space-5, 20px);
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 12px);
  box-shadow: 0 1px 2px rgba(31, 26, 20, 0.04);
}

.cockpit-hero__primary {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cockpit-hero__primary-value {
  font-family: var(--font-serif, "Libre Baskerville", serif);
  font-size: 56px;
  font-weight: 700;
  color: var(--navy, #1A2744);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.cockpit-hero__primary-value--empty {
  color: var(--ink-soft, #6b6258);
  font-style: italic;
}

.cockpit-hero__primary-label {
  font-family: var(--font-sans, Inter, sans-serif);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft, #6b6258);
  letter-spacing: 0.02em;
}

.cockpit-hero__secondary {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-3, 12px);
  padding-top: var(--space-2, 8px);
  border-top: 1px dashed var(--border, #e7e2d8);
}

.cockpit-hero__score-value {
  font-family: var(--font-serif, "Libre Baskerville", serif);
  font-size: 32px;
  font-weight: 700;
  color: var(--navy, #1A2744);
  line-height: 1;
}

.cockpit-hero__score-label {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-soft, #6b6258);
}

.cockpit-hero__trend {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 14px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 3px;
  background: var(--off-white, #f8f5ef);
}

.cockpit-hero__trend--up { color: var(--sage, #4a7560); }
.cockpit-hero__trend--down { color: var(--red, #B23A48); }
.cockpit-hero__trend--flat { color: var(--ink-soft, #6b6258); }

.cockpit-hero__week {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 11px;
  color: var(--ink-soft, #6b6258);
  margin-left: auto;
}

.cockpit-hero__proof {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2, 8px);
  font-family: var(--font-sans, Inter, sans-serif);
  font-size: 14px;
  color: var(--sage, #4a7560);
  padding-top: var(--space-2, 8px);
  border-top: 1px dashed var(--border, #e7e2d8);
}

.cockpit-hero__proof-item { font-weight: 500; }
.cockpit-hero__proof-sep { color: var(--ink-soft, #6b6258); opacity: 0.6; }

.cockpit-hero__empty {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: left;
}

@media (max-width: 800px) {
  .cockpit-hero { padding: var(--space-4, 16px) var(--space-5, 20px); }
  .cockpit-hero__primary-value { font-size: 40px; }
  .cockpit-hero__score-value { font-size: 24px; }
  .cockpit-hero__proof { font-size: 13px; }
}

/* ============================================================================
 * Pre-Merge-Hotfix Block A (24.05.) — Pattern-Detail Pre-Filter-Banner
 * ========================================================================== */
.pattern-detail-prefilter-banner {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2, 8px);
  padding: 6px 12px;
  margin: 0 0 var(--space-3, 12px) 0;
  background: rgba(212, 168, 67, 0.10);
  border: 1px solid var(--gold, #D4A843);
  border-radius: 3px;
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
  color: var(--navy, #1A2744);
}
.pattern-detail-prefilter-icon { color: var(--gold, #D4A843); }

/* ============================================================================
 * Phase 3 Polish (27.05.) Block C.2 — Cockpit-Pattern-Extras-Toggle
 * Komprimiert restliche Pattern hinter "Weitere Pattern anzeigen (X)"-Toggle
 * für 1080p-Above-the-Fold-Garantie.
 * ========================================================================== */
.cockpit-pattern-extras {
  padding: var(--space-3, 12px) var(--space-5, 20px);
  margin-bottom: var(--space-5, 20px);
}
.cockpit-pattern-extras-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2, 8px);
  width: 100%;
  padding: var(--space-2, 8px) 0;
  background: none;
  border: none;
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft, #6b6258);
  cursor: pointer;
  text-align: left;
}
.cockpit-pattern-extras-toggle:hover { color: var(--navy, #1A2744); }
.cockpit-pattern-extras-chevron {
  margin-left: auto;
  transition: transform 0.15s;
  font-size: 18px;
}
.cockpit-pattern-extras-toggle[aria-expanded="true"] .cockpit-pattern-extras-chevron {
  transform: rotate(90deg);
}
.cockpit-pattern-extras-list {
  list-style: none;
  padding: 0;
  margin: var(--space-3, 12px) 0 0 0;
  border-top: 1px dashed var(--border, #e7e2d8);
}
.cockpit-pattern-extras-item {
  display: flex;
  align-items: center;
  gap: var(--space-3, 12px);
  padding: 10px 0;
  border-bottom: 1px solid var(--border, #e7e2d8);
}
.cockpit-pattern-extras-item:last-child { border-bottom: none; }
.cockpit-pattern-extras-main {
  display: flex;
  align-items: center;
  gap: var(--space-2, 8px);
  flex: 1;
  min-width: 0;
}
.cockpit-pattern-extras-name {
  font-family: var(--font-serif, "Libre Baskerville", serif);
  font-size: 14px;
  color: var(--navy, #1A2744);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cockpit-pattern-extras-side {
  display: flex;
  align-items: center;
  gap: var(--space-3, 12px);
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
}
.cockpit-pattern-extras-impact {
  color: var(--navy, #1A2744);
  font-weight: 600;
}

/* ============================================================================
 * Phase 3 Polish (27.05.) Block C.3 — Heatmap-Density-Badge
 * ========================================================================== */
.hm-density-badge { cursor: help; }

