/* =========================================================================
   ServiceHub — Odoo-Skin · Komponente "status-pills"
   -------------------------------------------------------------------------
   ADDITIVE Politur-Schicht. Bildet die Mockup-.sho-pill (weiche Farbfläche +
   führender Farbpunkt, randlos, Pill-Radius) auf die ECHTEN Status-Badges der
   App ab: <span class="status-badge status-badge--<mod>"> aus internal.js +
   order-editor-integration.js (ORDER_STATUS_MAP cls).

   Quelle Mockup: public/_odoo-target-mockup.html  Sektion 1 (.sho-pill, Z.96-101).
   Echte Anker (verifiziert):
     - internal.css           Z.1758 (.status-badge Basis), 1788-1816 (--mod), 4799 (--info), 1818-1840 (legacy .status-ok/.status-warning/.status-failed/.status-running)
     - internal-modern.css    Z.790  (.status-badge Basis), 805-833 (--mod Sammel-Selektoren)
     - internal.js            durchgängig: --neutral/--active/--warning/--success/--danger/--info + legacy status-ok/status-warning/status-failed
     - order-editor-integration.js  ORDER_STATUS_MAP → cls active|neutral|success|danger

   LADEREIHENFOLGE: dieses File MUSS als LETZTES <link> nach internal.css +
   internal-modern.css (und nach den sh-odoo-*.css) geladen werden.
   SPEZIFITÄT: Container-Prefix #mainContent (id 1 + class 1) schlägt die
   Basis-/Modifier-Regeln (reine Single-Class) sicher per Kaskade — kein
   globales !important nötig. Nichts wird versteckt, kein Layout-Teardown.
   Tokens: sh-odoo-tokens.css (+ sh-tokens-brand.css) liefern die --sh-o-*-Skala;
   alle Farb-Tokens mit Hard-Fallback.
   ========================================================================= */

/* ── Form & Typografie der Pille (Mockup .sho-pill Z.96) ──────────────────
   Vereinheitlicht die zwei widersprüchlichen Basis-Definitionen
   (internal.css 4px/10px/r6/inline-block  vs  internal-modern.css 3px/9px/r12)
   auf den Mockup-Wert. Rahmen transparent (Mockup = randlos), Box bleibt stabil. */
#mainContent .status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 9px;
  border-radius: var(--sh-o-radius-pill, 999px);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0;
  border: 1px solid transparent;
  vertical-align: middle;
  white-space: nowrap;
}

/* ── Der führende Farbpunkt (Mockup .sho-pill::before Z.97) ───────────────
   nimmt die Vordergrundfarbe der jeweiligen Pille (currentColor). */
#mainContent .status-badge::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: .9;
  flex: 0 0 auto;
}

/* Punkt-Unterdrückung für leere/Platzhalter-Badges ("—", "–"),
   damit ein nackter Strich nicht wie ein Status aussieht. */
#mainContent .status-badge:empty::before { content: none; }

/* ── Farbpaare: weiche Fläche + Vollton-Text (Mockup Z.98-101) ────────────
   --ok / --warn / --info / --neutral  +  Danger (App-Erweiterung). */

/* ok (grün) — success + alias ok + legacy status-ok */
#mainContent .status-badge--success,
#mainContent .status-badge--ok,
#mainContent .status-badge.status-ok {
  background: var(--sh-o-ok-soft, #ecfdf5);
  color: var(--sh-o-ok, #2f855a);
}

/* warn (amber) — warning + alias warn + legacy status-warning/status-running */
#mainContent .status-badge--warning,
#mainContent .status-badge--warn,
#mainContent .status-badge.status-warning,
#mainContent .status-badge.status-running {
  background: var(--sh-o-warn-soft, #fff7e6);
  color: var(--sh-o-warn, #b7791f);
}

/* info (blau) — active + info (Alias von active im Render-Code) */
#mainContent .status-badge--active,
#mainContent .status-badge--info {
  background: var(--sh-o-info-soft, #eef4ff);
  color: var(--sh-o-info, #2b6cb0);
}

/* neutral (grau) — Standard-/Entwurf-Status */
#mainContent .status-badge--neutral {
  background: var(--sh-o-surface-soft, #f7f8fa);
  color: var(--sh-o-text-muted, #6b7280);
}

/* danger (rot) — Storniert/Fehlgeschlagen (App-Status, nicht Marken-Rot:
   semantisches Gefahr-Rot --sh-o-danger, klar getrennt von var(--sh-brand)). */
#mainContent .status-badge--danger,
#mainContent .status-badge.status-failed {
  background: var(--sh-o-danger-soft, #fdecec);
  color: var(--sh-o-danger, #c53030);
}

/* ── DARK-MODE ───────────────────────────────────────────────────────────
   Die -soft-Flächen werden bereits in sh-odoo-tokens.css zu tonalen
   rgba(...,.16)-Werten auf dunklem Grund invertiert; --sh-o-text-muted
   invertiert ebenfalls (→ #b3a99e), neutral ist also lesbar.
   Die saturierten VORDERGRUND-Töne (ok #2f855a / info #2b6cb0 / danger
   #c53030 / warn #b7791f) invertieren NICHT und wirken auf near-black etwas
   dunkel → gezielt aufhellen (nur Vordergrund, Fläche bleibt tonal). */
[data-theme="dark"] #mainContent .status-badge--success,
[data-theme="dark"] #mainContent .status-badge--ok,
[data-theme="dark"] #mainContent .status-badge.status-ok {
  color: #6ee7a8;
}
[data-theme="dark"] #mainContent .status-badge--warning,
[data-theme="dark"] #mainContent .status-badge--warn,
[data-theme="dark"] #mainContent .status-badge.status-warning,
[data-theme="dark"] #mainContent .status-badge.status-running {
  color: #f0c674;
}
[data-theme="dark"] #mainContent .status-badge--active,
[data-theme="dark"] #mainContent .status-badge--info {
  color: #8ab4f8;
}
[data-theme="dark"] #mainContent .status-badge--danger,
[data-theme="dark"] #mainContent .status-badge.status-failed {
  color: #f6a6a6;
}
/* neutral im Dark: --sh-o-text-muted (#b3a99e) genügt — keine Sonderregel. */
