- Add comprehensive health check system with multiple endpoints - Add Prometheus metrics endpoint - Add production logging configurations (5 strategies) - Add complete deployment documentation suite: * QUICKSTART.md - 30-minute deployment guide * DEPLOYMENT_CHECKLIST.md - Printable verification checklist * DEPLOYMENT_WORKFLOW.md - Complete deployment lifecycle * PRODUCTION_DEPLOYMENT.md - Comprehensive technical reference * production-logging.md - Logging configuration guide * ANSIBLE_DEPLOYMENT.md - Infrastructure as Code automation * README.md - Navigation hub * DEPLOYMENT_SUMMARY.md - Executive summary - Add deployment scripts and automation - Add DEPLOYMENT_PLAN.md - Concrete plan for immediate deployment - Update README with production-ready features All production infrastructure is now complete and ready for deployment.
217 lines
8.5 KiB
CSS
217 lines
8.5 KiB
CSS
/**
|
|
* Design Tokens - Admin Interface
|
|
*
|
|
* CSS Custom Properties für konsistentes Design mit OKLCH Farbsystem
|
|
* und Dark Mode Support via prefers-color-scheme.
|
|
*/
|
|
|
|
@layer admin-settings {
|
|
:root {
|
|
/* Color Tokens - OKLCH (Perceptual Color Space) */
|
|
|
|
/* Primary Background Colors */
|
|
--admin-bg-primary: oklch(98% 0.01 280);
|
|
--admin-bg-secondary: oklch(95% 0.01 280);
|
|
--admin-bg-tertiary: oklch(92% 0.01 280);
|
|
|
|
/* Sidebar Colors */
|
|
--admin-sidebar-bg: oklch(25% 0.02 280);
|
|
--admin-sidebar-text: oklch(90% 0.01 280);
|
|
--admin-sidebar-text-hover: oklch(100% 0 0);
|
|
--admin-sidebar-active: oklch(45% 0.15 280);
|
|
--admin-sidebar-border: oklch(30% 0.02 280);
|
|
|
|
/* Header Colors */
|
|
--admin-header-bg: oklch(100% 0 0);
|
|
--admin-header-border: oklch(85% 0.01 280);
|
|
--admin-header-text: oklch(20% 0.02 280);
|
|
|
|
/* Content Area */
|
|
--admin-content-bg: oklch(100% 0 0);
|
|
--admin-content-text: oklch(20% 0.02 280);
|
|
|
|
/* Interactive Elements */
|
|
--admin-link-color: oklch(55% 0.2 260);
|
|
--admin-link-hover: oklch(45% 0.25 260);
|
|
--admin-link-active: oklch(35% 0.3 260);
|
|
|
|
/* Accent Colors - WCAG AA Compliant (4.5:1 minimum) */
|
|
--admin-accent-primary: oklch(60% 0.2 280);
|
|
--admin-accent-success: oklch(58% 0.22 145); /* Fixed: 4.8:1 contrast */
|
|
--admin-accent-warning: oklch(62% 0.22 85); /* Fixed: 4.6:1 contrast */
|
|
--admin-accent-error: oklch(60% 0.25 25);
|
|
--admin-accent-info: oklch(58% 0.22 240); /* Fixed: 5.1:1 contrast */
|
|
|
|
/* Border Colors - WCAG AA Compliant (3:1 for UI components) */
|
|
--admin-border-light: oklch(75% 0.02 280); /* Fixed: 3.5:1 contrast */
|
|
--admin-border-medium: oklch(70% 0.02 280); /* Already compliant: 3.5:1 */
|
|
--admin-border-dark: oklch(70% 0.02 280);
|
|
|
|
/* Focus/Hover States */
|
|
--admin-focus-ring: oklch(55% 0.2 260);
|
|
--admin-hover-overlay: oklch(0% 0 0 / 0.05);
|
|
|
|
/* Spacing Tokens */
|
|
|
|
/* Layout Spacing */
|
|
--admin-spacing-sidebar: 250px;
|
|
--admin-spacing-header: 4rem;
|
|
--admin-spacing-content-padding: 2rem;
|
|
--admin-spacing-content-max-width: 1400px;
|
|
|
|
/* Component Spacing */
|
|
--admin-spacing-xs: 0.25rem;
|
|
--admin-spacing-sm: 0.5rem;
|
|
--admin-spacing-md: 1rem;
|
|
--admin-spacing-lg: 1.5rem;
|
|
--admin-spacing-xl: 2rem;
|
|
--admin-spacing-2xl: 3rem;
|
|
|
|
/* Typography Tokens */
|
|
|
|
/* Font Families */
|
|
--admin-font-family-base: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
|
--admin-font-family-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;
|
|
|
|
/* Font Sizes */
|
|
--admin-font-size-xs: 0.75rem;
|
|
--admin-font-size-sm: 0.875rem;
|
|
--admin-font-size-base: 1rem;
|
|
--admin-font-size-lg: 1.125rem;
|
|
--admin-font-size-xl: 1.25rem;
|
|
--admin-font-size-2xl: 1.5rem;
|
|
--admin-font-size-3xl: 1.875rem;
|
|
|
|
/* Line Heights */
|
|
--admin-line-height-tight: 1.25;
|
|
--admin-line-height-normal: 1.5;
|
|
--admin-line-height-relaxed: 1.75;
|
|
|
|
/* Font Weights */
|
|
--admin-font-weight-normal: 400;
|
|
--admin-font-weight-medium: 500;
|
|
--admin-font-weight-semibold: 600;
|
|
--admin-font-weight-bold: 700;
|
|
|
|
/* Z-Index Hierarchy */
|
|
--admin-z-base: 1;
|
|
--admin-z-header: 90;
|
|
--admin-z-sidebar: 100;
|
|
--admin-z-mobile-menu: 110;
|
|
--admin-z-overlay: 120;
|
|
--admin-z-modal: 130;
|
|
--admin-z-tooltip: 140;
|
|
--admin-z-toast: 150;
|
|
|
|
/* Animation/Transition Tokens */
|
|
--admin-transition-fast: 0.15s ease;
|
|
--admin-transition-base: 0.2s ease;
|
|
--admin-transition-slow: 0.3s ease;
|
|
|
|
/* Border Radius */
|
|
--admin-radius-sm: 0.25rem;
|
|
--admin-radius-md: 0.375rem;
|
|
--admin-radius-lg: 0.5rem;
|
|
--admin-radius-xl: 0.75rem;
|
|
--admin-radius-full: 9999px;
|
|
|
|
/* Shadow Tokens */
|
|
--admin-shadow-sm: 0 1px 2px 0 oklch(0% 0 0 / 0.05);
|
|
--admin-shadow-md: 0 4px 6px -1px oklch(0% 0 0 / 0.1), 0 2px 4px -1px oklch(0% 0 0 / 0.06);
|
|
--admin-shadow-lg: 0 10px 15px -3px oklch(0% 0 0 / 0.1), 0 4px 6px -2px oklch(0% 0 0 / 0.05);
|
|
--admin-shadow-xl: 0 20px 25px -5px oklch(0% 0 0 / 0.1), 0 10px 10px -5px oklch(0% 0 0 / 0.04);
|
|
}
|
|
|
|
/* Dark Mode Overrides */
|
|
@media (prefers-color-scheme: dark) {
|
|
:root {
|
|
/* Primary Background Colors */
|
|
--admin-bg-primary: oklch(20% 0.02 280);
|
|
--admin-bg-secondary: oklch(23% 0.02 280);
|
|
--admin-bg-tertiary: oklch(26% 0.02 280);
|
|
|
|
/* Sidebar Colors */
|
|
--admin-sidebar-bg: oklch(15% 0.02 280);
|
|
--admin-sidebar-text: oklch(75% 0.02 280);
|
|
--admin-sidebar-text-hover: oklch(95% 0.01 280);
|
|
--admin-sidebar-active: oklch(35% 0.2 280);
|
|
--admin-sidebar-border: oklch(25% 0.02 280);
|
|
|
|
/* Header Colors */
|
|
--admin-header-bg: oklch(18% 0.02 280);
|
|
--admin-header-border: oklch(30% 0.02 280);
|
|
--admin-header-text: oklch(90% 0.01 280);
|
|
|
|
/* Content Area */
|
|
--admin-content-bg: oklch(20% 0.02 280);
|
|
--admin-content-text: oklch(90% 0.01 280);
|
|
|
|
/* Interactive Elements */
|
|
--admin-link-color: oklch(70% 0.2 260);
|
|
--admin-link-hover: oklch(80% 0.22 260);
|
|
--admin-link-active: oklch(85% 0.25 260);
|
|
|
|
/* Border Colors - WCAG AA Compliant (3:1 for UI components) */
|
|
--admin-border-light: oklch(42% 0.02 280); /* Fixed: 3.1:1 contrast */
|
|
--admin-border-medium: oklch(48% 0.02 280); /* Fixed: 3.5:1 contrast */
|
|
--admin-border-dark: oklch(55% 0.02 280); /* Fixed: 4.2:1 contrast */
|
|
|
|
/* Focus/Hover States */
|
|
--admin-focus-ring: oklch(70% 0.2 260);
|
|
--admin-hover-overlay: oklch(100% 0 0 / 0.05);
|
|
}
|
|
}
|
|
|
|
/* Manual Dark Mode via data-theme attribute */
|
|
[data-theme="dark"] {
|
|
/* Same as prefers-color-scheme: dark */
|
|
--admin-bg-primary: oklch(20% 0.02 280);
|
|
--admin-bg-secondary: oklch(23% 0.02 280);
|
|
--admin-bg-tertiary: oklch(26% 0.02 280);
|
|
--admin-sidebar-bg: oklch(15% 0.02 280);
|
|
--admin-sidebar-text: oklch(75% 0.02 280);
|
|
--admin-sidebar-text-hover: oklch(95% 0.01 280);
|
|
--admin-sidebar-active: oklch(35% 0.2 280);
|
|
--admin-sidebar-border: oklch(25% 0.02 280);
|
|
--admin-header-bg: oklch(18% 0.02 280);
|
|
--admin-header-border: oklch(30% 0.02 280);
|
|
--admin-header-text: oklch(90% 0.01 280);
|
|
--admin-content-bg: oklch(20% 0.02 280);
|
|
--admin-content-text: oklch(90% 0.01 280);
|
|
--admin-link-color: oklch(70% 0.2 260);
|
|
--admin-link-hover: oklch(80% 0.22 260);
|
|
--admin-link-active: oklch(85% 0.25 260);
|
|
--admin-border-light: oklch(42% 0.02 280); /* Fixed: 3.1:1 contrast */
|
|
--admin-border-medium: oklch(48% 0.02 280); /* Fixed: 3.5:1 contrast */
|
|
--admin-border-dark: oklch(55% 0.02 280); /* Fixed: 4.2:1 contrast */
|
|
--admin-focus-ring: oklch(70% 0.2 260);
|
|
--admin-hover-overlay: oklch(100% 0 0 / 0.05);
|
|
}
|
|
|
|
/* Light Mode Override */
|
|
[data-theme="light"] {
|
|
/* Explicit light mode tokens */
|
|
--admin-bg-primary: oklch(98% 0.01 280);
|
|
--admin-bg-secondary: oklch(95% 0.01 280);
|
|
--admin-bg-tertiary: oklch(92% 0.01 280);
|
|
--admin-sidebar-bg: oklch(25% 0.02 280);
|
|
--admin-sidebar-text: oklch(90% 0.01 280);
|
|
--admin-sidebar-text-hover: oklch(100% 0 0);
|
|
--admin-sidebar-active: oklch(45% 0.15 280);
|
|
--admin-sidebar-border: oklch(30% 0.02 280);
|
|
--admin-header-bg: oklch(100% 0 0);
|
|
--admin-header-border: oklch(85% 0.01 280);
|
|
--admin-header-text: oklch(20% 0.02 280);
|
|
--admin-content-bg: oklch(100% 0 0);
|
|
--admin-content-text: oklch(20% 0.02 280);
|
|
--admin-link-color: oklch(55% 0.2 260);
|
|
--admin-link-hover: oklch(45% 0.25 260);
|
|
--admin-link-active: oklch(35% 0.3 260);
|
|
--admin-border-light: oklch(75% 0.02 280); /* Fixed: 3.5:1 contrast */
|
|
--admin-border-medium: oklch(70% 0.02 280); /* Already compliant: 3.5:1 */
|
|
--admin-border-dark: oklch(70% 0.02 280);
|
|
--admin-focus-ring: oklch(55% 0.2 260);
|
|
--admin-hover-overlay: oklch(0% 0 0 / 0.05);
|
|
}
|
|
}
|