/* ============================================================================
   sh-dashboard-friendly — modernes, ruhiges Dashboard-Layer.
   Additive Schicht; MUSS NACH sh-odoo-theme.css laden.
   Betrifft NUR Dashboard-Kacheln/-Karten (dw-* Widget-Dashboard + db-* Fallback).
   Keine globalen Token-Änderungen → restliches ERP bleibt unberührt.

   STIL „Ruhig & edel", entdichtet (2026-05-31): mehr Weißraum zwischen den
   Karten, leichtere/„entkastete" KPI-Kacheln (sanfter, einheitlicher Fill +
   Haarlinie; Status v. a. über den linken Akzentstreifen, farbige Zahl nur
   bei warn/danger). Ziel: weniger „überfüllt", mehr Luft.

   KLASSEN-KONTRAKT: Renderer erzeugen `.dw-kpi-item` + `.dw-kpi--{ok|warn|
   danger|highlight|info}` + `.dw-kpi-meta` (NICHT `.dw-kpi-card`). Dieses Layer
   deckt beide Systeme ab, damit die real gerenderten KPI-Kacheln greifen.
   ============================================================================ */

:root {
  --dbf-radius: 16px;
  --dbf-radius-sm: 12px;
  --dbf-border: #eef1f5;
  --dbf-border-hover: #e4e8ee;
  --dbf-shadow: 0 1px 2px rgba(16, 24, 40, .03), 0 6px 18px rgba(16, 24, 40, .045);
  --dbf-shadow-hover: 0 12px 30px rgba(16, 24, 40, .10), 0 2px 6px rgba(16, 24, 40, .045);
  --dbf-tile-bg: #f8fafc;
  --dbf-ink: #111827;
  --dbf-muted: #6b7280;
  --dbf-faint: #9aa3af;
}

/* ── viel Luft im Widget-Raster ───────────────────────────────────────────── */
.dw-grid { gap: 22px; grid-auto-rows: 178px; }

/* ── Widget-Karten + Sektionskarten: weich, „schwebend", luftig ───────────── */
.dw-card,
.db-card {
  border-radius: var(--dbf-radius);
  border: 1px solid var(--dbf-border);
  box-shadow: var(--dbf-shadow);
  background: #fff;
  transition: box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.dw-card { display: flex; flex-direction: column; }
.dw-card:hover,
.db-card:hover {
  box-shadow: var(--dbf-shadow-hover);
  transform: translateY(-2px);
  border-color: var(--dbf-border-hover);
}
.dw-card-header {
  padding: 14px 18px;
  border-bottom: 1px solid #f3f5f8;
  background: transparent;
  flex: 0 0 auto;
}
.dw-card-title { font-size: .92rem; font-weight: 700; color: var(--dbf-ink); letter-spacing: -.01em; }
.dw-card-body { padding: 16px 18px; }

/* ════════════════════════════════════════════════════════════════════════
   KPI-KACHELN — leicht & luftig (deckt .dw-kpi-card UND .dw-kpi-item + .db-kpi)
   ════════════════════════════════════════════════════════════════════════ */
.dw-kpi-row {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
  align-items: stretch;
}
.dw-kpi-row--4 { display: flex; }

.db-kpi,
.dw-kpi-card,
.dw-kpi-item {
  flex: 1 1 138px;
  min-width: 126px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 3px;
  padding: 15px 17px;
  background: var(--dbf-tile-bg);
  border: 1px solid var(--dbf-border);
  border-left: 3px solid #dfe3e9;          /* Status färbt nur diesen Streifen */
  border-radius: var(--dbf-radius-sm);
  box-shadow: none;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .16s ease, transform .16s ease, border-color .16s ease, background .16s ease;
}
.db-kpi:hover,
.dw-kpi-card:hover,
.dw-kpi-item:hover {
  box-shadow: var(--dbf-shadow-hover);
  transform: translateY(-2px);
}

.db-kpi-value,
.dw-kpi-value {
  font-size: 1.42rem;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.15;
  color: var(--dbf-ink);
  font-variant-numeric: tabular-nums;
  max-width: 100%;
}
.db-kpi-label,
.dw-kpi-label {
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--dbf-muted);
  line-height: 1.25;
}
.db-kpi-sub,
.dw-kpi-sub,
.dw-kpi-meta {
  display: block;
  font-size: .68rem;
  font-style: normal;
  line-height: 1.3;
  color: var(--dbf-faint);
}

/* ── Status: ruhig — gleicher Fill, nur Akzentstreifen; Farbe-Zahl nur warn/danger ── */
.db-kpi--ok,        .dw-kpi-card--ok,        .dw-kpi--ok        { border-left-color: #1f9d57; }
.db-kpi--info,      .dw-kpi-card--info,      .dw-kpi--info      { border-left-color: #2563eb; }
.db-kpi--highlight, .dw-kpi-card--highlight, .dw-kpi--highlight { border-left-color: var(--elmetic-red, #e73d25); }
.db-kpi--warn,      .dw-kpi-card--warn,      .dw-kpi--warn      { background: linear-gradient(180deg, #fffdf6, var(--dbf-tile-bg) 58%); border-color: #f1e6c9; border-left-color: #e08a14; }
.db-kpi--danger,    .dw-kpi-card--danger,    .dw-kpi--danger    { background: linear-gradient(180deg, #fff7f7, var(--dbf-tile-bg) 58%); border-color: #f3d4d4; border-left-color: #dc2626; }

.db-kpi--warn .db-kpi-value,   .dw-kpi-card--warn .dw-kpi-value,   .dw-kpi--warn .dw-kpi-value   { color: #b45309; }
.db-kpi--danger .db-kpi-value, .dw-kpi-card--danger .dw-kpi-value, .dw-kpi--danger .dw-kpi-value { color: #dc2626; }
/* ok/info/highlight: dunkler Wert; Status erkennt man am Akzentstreifen */

/* ── Quick-Action-Buttons ─────────────────────────────────────────────────── */
.db-qa-btn, .dw-quick-btn { border-radius: 11px; padding: 8px 15px; font-weight: 600; }
.db-qa-btn:hover, .dw-quick-btn:hover {
  background: var(--elmetic-red-glow, rgba(231, 61, 37, .10));
  border-color: var(--elmetic-red, #e73d25);
  color: var(--elmetic-red, #e73d25);
}

/* ── Header ───────────────────────────────────────────────────────────────── */
.db-header,
.dw-header.page-header {
  border-radius: var(--dbf-radius);
  box-shadow: var(--dbf-shadow);
  border: 1px solid var(--dbf-border);
  background: linear-gradient(180deg, #ffffff, #fafbfc);
}

/* ── Tabellen: luftiger ───────────────────────────────────────────────────── */
.dw-table th,
.db-table thead th { color: var(--dbf-muted); }
.dw-table td { padding: 9px 10px; }
.dw-table tbody tr:hover,
.db-table tbody tr:hover { background: #f6f9ff; }
.db-row-btn { border-radius: 8px; }

/* ── Listen (alle Render-Varianten vereinheitlichen), mehr Zeilenluft ──────── */
.dw-list-item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 2px 10px;
  padding: 10px 0;
  border-bottom: 1px solid #f3f5f8;
}
.dw-list-item:last-child { border-bottom: none; }
.dw-list-main { font-weight: 600; flex: 1 1 auto; min-width: 0; color: var(--dbf-ink); }
.dw-list-main a, .dw-list-primary a { color: inherit; text-decoration: none; }
.dw-list-main a:hover, .dw-list-primary a:hover { color: var(--elmetic-red, #e73d25); }
.dw-list-rank { flex: 0 0 auto; font-weight: 800; color: var(--elmetic-red, #e73d25); }
.dw-list-meta { margin-left: auto; flex: 0 0 auto; color: var(--dbf-muted); font-size: .72rem; white-space: nowrap; }
.dw-list-sub { flex-basis: 100%; color: var(--dbf-faint); font-size: .72rem; line-height: 1.35; }
.dw-list-primary { flex-basis: 100%; font-weight: 600; color: var(--dbf-ink); }
.dw-list-secondary { flex-basis: 100%; color: var(--dbf-muted); font-size: .72rem; line-height: 1.35; }

/* ── Badges: weiche Pillen ────────────────────────────────────────────────── */
.dw-badge { border-radius: 999px; padding: 2px 9px; font-size: .68rem; font-weight: 600; background: #eef1f5; color: #4a5568; }
.dw-badge--warn { background: #fff3e0; color: #b45309; }
.dw-badge--ok { background: #e9f9ef; color: #15803d; }
.dw-badge--danger { background: #fdecec; color: #dc2626; }
.dw-badge--info { background: #eaf2ff; color: #1d4ed8; }

/* ── Mehr-/Sektionslinks ──────────────────────────────────────────────────── */
.db-more-link, .dw-link { font-weight: 700; color: var(--elmetic-red, #e73d25); }
.dw-link:hover, .db-more-link:hover { text-decoration: underline; }

/* ── KI-Analyse-Widget: aufgeräumte Sektionen ─────────────────────────────── */
.dw-ai-section { margin-top: 14px; }
.dw-ai-section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 5px; }
.dw-section-title { margin: 0; font-size: .74rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--dbf-muted); }
.dw-ai-system-hint { margin-top: 14px; padding: 10px 13px; border-radius: 10px; background: #f5f7fa; border: 1px solid #eceef2; font-size: .74rem; color: #4a5568; }
.dw-action-row { display: flex; gap: 16px; margin-top: 10px; flex-wrap: wrap; }

/* ── CRM-Pipeline-Mini ────────────────────────────────────────────────────── */
.dw-pipeline { display: flex; flex-wrap: wrap; gap: 10px; }
.dw-pipeline-stage { flex: 1 1 88px; padding: 11px 13px; border: 1px solid var(--dbf-border); border-radius: var(--dbf-radius-sm); background: var(--dbf-tile-bg); }
.dw-pipeline-label { font-size: .68rem; color: var(--dbf-muted); font-weight: 600; }
.dw-pipeline-value { font-size: 1.2rem; font-weight: 800; color: var(--dbf-ink); line-height: 1.2; }
.dw-pipeline-amount { font-size: .68rem; color: var(--dbf-faint); }

/* ── Empty-States ─────────────────────────────────────────────────────────── */
.dw-empty { text-align: center; padding: 20px 12px; color: var(--dbf-faint); font-size: .8rem; }
.dw-empty--error { color: #dc2626; }

/* ── Responsive Feinschliff ───────────────────────────────────────────────── */
@media (max-width: 680px) {
  .dw-grid { gap: 16px; }
  .db-kpi, .dw-kpi-card, .dw-kpi-item { flex: 1 1 calc(50% - 13px); }
  .dw-card-body { padding: 13px 14px; }
}
