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.
| Alias | Verweist auf | HEX | Verwendung |
|---|---|---|---|
--brand-light | --warm-50 | #F9F8F6 | Cremiger Surface-Hintergrund (Light-Theme Card) |
--brand-dark | --warm-800 | #3A3430 | Dunkle CTA-Buttons auf orangem Background, Footer, dunkle Akzente |
--brand-black | --warm-900 | #231F1C | Tiefster 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.
| Alias | Verweist auf | HEX | Verwendung | WCAG auf Weiß |
|---|---|---|---|---|
--text-primary | --warm-900 | #231F1C | Headlines, primärer Body-Text | AAA (16.6:1) |
--text-secondary | --warm-600 | #6B635C | Lead-Texte, sekundäre Beschreibungen | AA (5.9:1) |
--text-muted | --warm-500 | #887F78 | Captions, Metadaten, Timestamps | AA Large (3.9:1) |
--text-disabled | --warm-400 | #A69E97 | Deaktivierte Buttons, Placeholders | — (2.6:1, dekorativ) |
Background-Rollen
| Alias | Verweist auf (Light) | Verweist auf (Dark) | Verwendung |
|---|---|---|---|
--bg-primary | #FFFFFF | --warm-900 | Page-Background |
--bg-subtle | --warm-50 | --warm-800 | Card-Background, Hover-States |
--bg-muted | --warm-100 | --warm-700 | Tertiäre Surfaces, Code-Block-Background |
Border-Rollen
| Alias | Verweist auf (Light) | Verweist auf (Dark) | Verwendung |
|---|---|---|---|
--border | --warm-200 | --warm-700 | Standard-Hairline (Cards, Tables, Form-Inputs) |
--border-strong | --warm-300 | --warm-600 | Betonte Trennlinien, aktive Form-Inputs, Focus-Outlines |
Mapping-Übersicht
┌─────────────────────────┐
│ 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
: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
- Komponenten verwenden Aliase, niemals Skalen-Token direkt.
color: var(--text-primary)stattcolor: var(--warm-900). - Aliase sind Single-Source-of-Truth pro Rolle. Eine Komponente sollte für "Body-Text" immer
--text-primaryverwenden, niemals zwischen--warm-800und--warm-900schwanken. - Theme-Wechsel passiert nur am Alias. Dark-Mode ändert das Mapping
--text-primary → warm-100, nicht jede Komponente. - 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
/* 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.