a189e4be8d
- 1024–1279px: Icon-only Sidebar (64px), Logo als Akzent-Icon - ≥ 1280px: Sidebar mit Labels (200px), Logo Gradient-Text - Neumorphischer Hintergrund (--sidebar-bg), eigene Light/Dark-Schatten-Tokens - Hover: raised box-shadow (konvex gehoben) - Aktiv: inset box-shadow (konkav gedrückt) + Akzentstreifen links - Sidebar-Schatten statt Border-right für Tiefentrennung - Smooth transition bei Breakpoint-Wechsel Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
162 lines
5.2 KiB
CSS
162 lines
5.2 KiB
CSS
/**
|
||
* Modul: Design Tokens
|
||
* Zweck: CSS Custom Properties für das gesamte Design-System
|
||
* Abhängigkeiten: keine
|
||
*/
|
||
|
||
:root {
|
||
/* --------------------------------------------------------
|
||
* Farben — Neutrals
|
||
* -------------------------------------------------------- */
|
||
--color-bg: #F5F5F7;
|
||
--color-surface: #FFFFFF;
|
||
--color-surface-2: #F0F0F5;
|
||
--color-border: #E5E5EA;
|
||
--color-text-primary: #1C1C1E;
|
||
--color-text-secondary: #6C6C70; /* WCAG AA: ~5.2:1 auf weißem Hintergrund */
|
||
--color-text-disabled: #C7C7CC;
|
||
|
||
/* --------------------------------------------------------
|
||
* Farben — Akzent (konfigurierbar)
|
||
* -------------------------------------------------------- */
|
||
--color-accent: #007AFF;
|
||
--color-accent-hover: #0056CC;
|
||
--color-accent-light: #E3F2FF;
|
||
--color-btn-primary: #0066DB; /* WCAG AA: ~5.0:1 auf weiß (Buttons mit weißem Text) */
|
||
--color-btn-primary-hover: #0056CC;
|
||
|
||
/* --------------------------------------------------------
|
||
* Farben — Semantisch
|
||
* -------------------------------------------------------- */
|
||
--color-success: #34C759;
|
||
--color-success-light: #E3F9EB;
|
||
--color-warning: #FF9500;
|
||
--color-warning-light: #FFF3E0;
|
||
--color-danger: #FF3B30;
|
||
--color-danger-light: #FFE5E3;
|
||
--color-info: #5AC8FA;
|
||
--color-info-light: #E5F7FF;
|
||
|
||
/* --------------------------------------------------------
|
||
* Farben — Prioritäten
|
||
* -------------------------------------------------------- */
|
||
--color-priority-low: #8E8E93;
|
||
--color-priority-medium: #FF9500;
|
||
--color-priority-high: #FF6B35;
|
||
--color-priority-urgent: #FF3B30;
|
||
|
||
/* --------------------------------------------------------
|
||
* Schatten
|
||
* -------------------------------------------------------- */
|
||
--shadow-sm: 0 1px 2px rgba(0,0,0,0.04), 0 1px 6px rgba(0,0,0,0.04);
|
||
--shadow-md: 0 4px 12px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.04);
|
||
--shadow-lg: 0 12px 32px rgba(0,0,0,0.09), 0 2px 8px rgba(0,0,0,0.05);
|
||
|
||
/* --------------------------------------------------------
|
||
* Border-Radien
|
||
* -------------------------------------------------------- */
|
||
--radius-xs: 4px;
|
||
--radius-sm: 8px;
|
||
--radius-md: 12px;
|
||
--radius-lg: 16px;
|
||
--radius-xl: 24px;
|
||
--radius-full: 9999px;
|
||
|
||
/* --------------------------------------------------------
|
||
* Typografie
|
||
* -------------------------------------------------------- */
|
||
--font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI Variable', 'Segoe UI', system-ui, sans-serif;
|
||
--font-mono: 'SF Mono', 'Fira Code', 'Fira Mono', 'Roboto Mono', monospace;
|
||
|
||
--text-xs: 0.75rem; /* 12px */
|
||
--text-sm: 0.8125rem; /* 13px */
|
||
--text-base: 1rem; /* 16px */
|
||
--text-md: 1.0625rem; /* 17px */
|
||
--text-lg: 1.125rem; /* 18px */
|
||
--text-xl: 1.25rem; /* 20px */
|
||
--text-2xl: 1.5rem; /* 24px */
|
||
--text-3xl: 1.875rem; /* 30px */
|
||
|
||
--line-height-tight: 1.2;
|
||
--line-height-base: 1.5;
|
||
--line-height-relaxed: 1.75;
|
||
|
||
--font-weight-regular: 400;
|
||
--font-weight-medium: 500;
|
||
--font-weight-semibold: 600;
|
||
--font-weight-bold: 700;
|
||
|
||
/* --------------------------------------------------------
|
||
* Abstände
|
||
* -------------------------------------------------------- */
|
||
--space-1: 4px;
|
||
--space-2: 8px;
|
||
--space-3: 12px;
|
||
--space-4: 16px;
|
||
--space-5: 20px;
|
||
--space-6: 24px;
|
||
--space-8: 32px;
|
||
--space-10: 40px;
|
||
--space-12: 48px;
|
||
--space-16: 64px;
|
||
|
||
/* --------------------------------------------------------
|
||
* Layout
|
||
* -------------------------------------------------------- */
|
||
--nav-height-mobile: 64px;
|
||
--sidebar-width: 64px; /* collapsed icon-only (1024–1279px) */
|
||
--sidebar-width-expanded: 200px; /* full sidebar (1280px+) */
|
||
--content-max-width: 1200px;
|
||
|
||
/* Sidebar Neumorphismus */
|
||
--sidebar-bg: #E8E8EE;
|
||
--sidebar-shadow-light: rgba(255, 255, 255, 0.82);
|
||
--sidebar-shadow-dark: rgba(148, 148, 170, 0.28);
|
||
--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);
|
||
|
||
/* --------------------------------------------------------
|
||
* Übergänge
|
||
* -------------------------------------------------------- */
|
||
--transition-fast: 0.1s ease;
|
||
--transition-base: 0.2s ease;
|
||
--transition-slow: 0.3s ease;
|
||
|
||
/* --------------------------------------------------------
|
||
* Z-Indizes
|
||
* -------------------------------------------------------- */
|
||
--z-base: 0;
|
||
--z-card: 1;
|
||
--z-nav: 100;
|
||
--z-modal: 200;
|
||
--z-toast: 300;
|
||
}
|
||
|
||
/* --------------------------------------------------------
|
||
* Dark Mode
|
||
* -------------------------------------------------------- */
|
||
@media (prefers-color-scheme: dark) {
|
||
:root {
|
||
--color-bg: #1C1C1E;
|
||
--color-surface: #2C2C2E;
|
||
--color-surface-2: #3A3A3C;
|
||
--color-border: #3A3A3C;
|
||
--color-text-primary: #F5F5F7;
|
||
--color-text-secondary: #AEAEB2; /* WCAG AA: ~4.6:1 auf #2C2C2E */
|
||
--color-text-disabled: #48484A;
|
||
|
||
--sidebar-bg: #19191D;
|
||
--sidebar-shadow-light: rgba(255, 255, 255, 0.05);
|
||
--sidebar-shadow-dark: rgba(0, 0, 0, 0.55);
|
||
|
||
--color-accent-light: #1A3A5C;
|
||
--color-success-light: #1A3A26;
|
||
--color-warning-light: #3A2800;
|
||
--color-danger-light: #3A1A1A;
|
||
--color-info-light: #1A3A4A;
|
||
|
||
--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
|
||
--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
|
||
--shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
|
||
}
|
||
}
|