Skip to content

Semantische Aliase

Semantische Aliase trennen die physische Farbe (z. B. --warm-800) von ihrer semantischen Rolle (z. B. --text-primary). Diese Indirektion ist zentral für die Wartbarkeit des Designsystems: ein Theme-Refactor ändert nur das Mapping an einer Stelle — nicht jede Komponente einzeln.

Warum Aliase?

Wenn das Theme in 3 Jahren wärmer oder kühler werden soll, reicht es, das Mapping --text-primary → warm-X an einer Stelle zu ändern. Würde stattdessen jede Komponente direkt var(--warm-900) verwenden, wäre ein Theme-Refactor ein Find-And-Replace über die gesamte Codebase. Aliase machen das Designsystem langfristig wartbar.

Brand-Farb-Aliase

Die Brand-Neutrals als feste Referenzpunkte — abgeleitet aus der Warm-Gray-Skala.

AliasVerweist aufHEXVerwendung
--brand-light--warm-50#F9F8F6Cremiger Surface-Hintergrund (Light-Theme Card)
--brand-dark--warm-800#3A3430Dunkle CTA-Buttons auf orangem Background, Footer, dunkle Akzente
--brand-black--warm-900#231F1CTiefster Brand-Neutral, Print-Schwarz, Hover-States für --brand-dark

→ Vollständige Spezifikation: Brand-Neutrals

Text-Rollen

Hierarchie der Text-Sichtbarkeit. Alle Aliase sind WCAG-validiert auf Brand-White und Brand-Light.

AliasVerweist aufHEXVerwendungWCAG auf Weiß
--text-primary--warm-900#231F1CHeadlines, primärer Body-TextAAA (16.6:1)
--text-secondary--warm-600#6B635CLead-Texte, sekundäre BeschreibungenAA (5.9:1)
--text-muted--warm-500#887F78Captions, Metadaten, TimestampsAA Large (3.9:1)
--text-disabled--warm-400#A69E97Deaktivierte Buttons, Placeholders— (2.6:1, dekorativ)
Headline (text-primary)
Lead-Text mit etwas mehr Kontext (text-secondary).
Caption mit Metadaten · 06.05.2026 · 3 Min Lesedauer (text-muted)
Deaktivierter Button-Text oder Placeholder (text-disabled)

Background-Rollen

AliasVerweist auf (Light)Verweist auf (Dark)Verwendung
--bg-primary#FFFFFF--warm-900Page-Background
--bg-subtle--warm-50--warm-800Card-Background, Hover-States
--bg-muted--warm-100--warm-700Tertiäre Surfaces, Code-Block-Background
bg-primary (#FFFFFF)
Standard Page-Background
bg-subtle (Warm 50)
Card-Background, Hover-States, sekundäre Sektionen
bg-muted (Warm 100)
Tertiäre Surfaces, Code-Blocks, eingedrückte Bereiche

Border-Rollen

AliasVerweist auf (Light)Verweist auf (Dark)Verwendung
--border--warm-200--warm-700Standard-Hairline (Cards, Tables, Form-Inputs)
--border-strong--warm-300--warm-600Betonte Trennlinien, aktive Form-Inputs, Focus-Outlines
Standard-Card
border (Warm 200) — die Standard-Hairline
Aktive Card
border-strong (Warm 300) — betonte Trennung

Mapping-Übersicht

text
                    ┌─────────────────────────┐
                    │   Physische Skala       │
                    │   (Warm-Gray)           │
                    └─────────────────────────┘

                    ┌──────────┴──────────────┐
                    │                         │
                    ▼                         ▼
         ┌────────────────────┐   ┌────────────────────┐
         │  Brand-Aliase      │   │  Rollen-Aliase     │
         │  --brand-light     │   │  --text-primary    │
         │  --brand-dark      │   │  --bg-subtle       │
         │  --brand-black     │   │  --border          │
         └────────────────────┘   └────────────────────┘
                    │                         │
                    └──────────┬──────────────┘

                    ┌─────────────────────────┐
                    │   UI-Komponenten        │
                    │   (verwenden Aliase,    │
                    │    nie Skalen direkt)   │
                    └─────────────────────────┘

CSS Custom Properties

css
:root {
  /* Brand-Aliase */
  --brand-light: var(--warm-50);
  --brand-dark:  var(--warm-800);
  --brand-black: var(--warm-900);

  /* Text-Rollen */
  --text-primary:   var(--warm-900);
  --text-secondary: var(--warm-600);
  --text-muted:     var(--warm-500);
  --text-disabled:  var(--warm-400);

  /* Background-Rollen — Light Theme */
  --bg-primary: #FFFFFF;
  --bg-subtle:  var(--warm-50);
  --bg-muted:   var(--warm-100);

  /* Border-Rollen */
  --border:        var(--warm-200);
  --border-strong: var(--warm-300);
}

[data-theme="dark"] {
  --bg-primary: var(--warm-900);
  --bg-subtle:  var(--warm-800);
  --bg-muted:   var(--warm-700);

  --border:        var(--warm-700);
  --border-strong: var(--warm-600);
}

Anwendungsregeln

  1. Komponenten verwenden Aliase, niemals Skalen-Token direkt.color: var(--text-primary) statt color: var(--warm-900).
  2. Aliase sind Single-Source-of-Truth pro Rolle. Eine Komponente sollte für "Body-Text" immer --text-primary verwenden, niemals zwischen --warm-800 und --warm-900 schwanken.
  3. Theme-Wechsel passiert nur am Alias. Dark-Mode ändert das Mapping --text-primary → warm-100, nicht jede Komponente.
  4. Skalen-Token sind erlaubt für Spezialfälle, in denen die semantische Rolle nicht klar ist (z. B. dekorative Verläufe, Datenvisualisierungen mit eigener Hierarchie).

Anti-Pattern

css
/* FALSCH — koppelt Komponente direkt an die Skala */
.card-title { color: var(--warm-900); }

/* RICHTIG — verwendet die semantische Rolle */
.card-title { color: var(--text-primary); }

Beim Theme-Refactor muss der zweite Code nicht angefasst werden — beim ersten schon.

Dokumentation lizenziert unter CC BY-NC 4.0 · Code lizenziert unter MIT