Files
kashilo/css/variables.css
2026-01-28 07:02:55 +01:00

190 lines
4.8 KiB
CSS

:root {
/*
* Lavender Light + Deep Purple Dark
* WCAG AAA konform (Kontrast > 7:1)
*/
/* Colors - Light Mode */
--color-primary: #6B5B95;
--color-primary-hover: #574A7A;
--color-primary-light: #E8E4F0;
--color-secondary: #9B8AA6;
--color-secondary-hover: #7D6E8A;
--color-accent: #A67B9E;
--color-accent-hover: #8A6283;
--color-success: #5A8F6B;
--color-warning: #C49A3C;
--color-error: #B54747;
--color-bg: #FAF8FC;
--color-bg-secondary: #F3F0F7;
--color-bg-tertiary: #EBE6F2;
--color-text: #2A2633;
--color-text-secondary: #524A5E;
--color-text-muted: #8A8295;
--color-border: #DDD8E6;
--color-border-focus: #6B5B95;
--color-shadow: rgba(42, 38, 51, 0.1);
--color-overlay: rgba(42, 38, 51, 0.5);
/* Spacing */
--space-xs: 0.25rem;
--space-sm: 0.5rem;
--space-md: 1rem;
--space-lg: 1.5rem;
--space-xl: 2rem;
--space-2xl: 3rem;
--space-3xl: 4rem;
/* Typography */
--font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
--font-family-heading: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
--font-size-xs: 0.75rem;
--font-size-sm: 0.875rem;
--font-size-base: 1rem;
--font-size-lg: 1.125rem;
--font-size-xl: 1.25rem;
--font-size-2xl: 1.5rem;
--font-size-3xl: 2rem;
--font-weight-normal: 400;
--font-weight-medium: 500;
--font-weight-semibold: 600;
--font-weight-bold: 700;
--line-height-tight: 1.25;
--line-height-normal: 1.5;
--line-height-relaxed: 1.75;
/* Border Radius */
--radius-sm: 0.25rem;
--radius-md: 0.5rem;
--radius-lg: 0.75rem;
--radius-xl: 1rem;
--radius-full: 9999px;
/* Shadows */
--shadow-sm: 0 1px 2px var(--color-shadow);
--shadow-md: 0 4px 6px var(--color-shadow);
--shadow-lg: 0 10px 15px var(--color-shadow);
--shadow-xl: 0 20px 25px var(--color-shadow);
/* Transitions */
--transition-fast: 150ms ease;
--transition-normal: 250ms ease;
--transition-slow: 350ms ease;
/* Layout */
--header-height: 4rem;
--footer-height: 3rem;
--container-max: 1200px;
--sidebar-width: 280px;
/* Z-Index */
--z-dropdown: 100;
--z-sticky: 200;
--z-modal: 300;
--z-toast: 400;
}
/* Dark Mode - System Preference */
@media (prefers-color-scheme: dark) {
:root:not([data-theme="light"]) {
--color-primary: #B8A5D6;
--color-primary-hover: #C9BAE3;
--color-primary-light: #2D2440;
--color-secondary: #A699B8;
--color-secondary-hover: #BAAFCA;
--color-accent: #C9A5C4;
--color-accent-hover: #D9BAD5;
--color-success: #7CB88A;
--color-warning: #D4B05C;
--color-error: #D47070;
--color-bg: #1A1424;
--color-bg-secondary: #252033;
--color-bg-tertiary: #312A42;
--color-text: #F5F2FA;
--color-text-secondary: #D4CCDF;
--color-text-muted: #9A90A8;
--color-border: #3D3550;
--color-border-focus: #B8A5D6;
--color-shadow: rgba(0, 0, 0, 0.4);
--color-overlay: rgba(0, 0, 0, 0.6);
}
}
/* Dark Mode - Manual Override */
[data-theme="dark"] {
--color-primary: #B8A5D6;
--color-primary-hover: #C9BAE3;
--color-primary-light: #2D2440;
--color-secondary: #A699B8;
--color-secondary-hover: #BAAFCA;
--color-accent: #C9A5C4;
--color-accent-hover: #D9BAD5;
--color-success: #7CB88A;
--color-warning: #D4B05C;
--color-error: #D47070;
--color-bg: #1A1424;
--color-bg-secondary: #252033;
--color-bg-tertiary: #312A42;
--color-text: #F5F2FA;
--color-text-secondary: #D4CCDF;
--color-text-muted: #9A90A8;
--color-border: #3D3550;
--color-border-focus: #B8A5D6;
--color-shadow: rgba(0, 0, 0, 0.4);
--color-overlay: rgba(0, 0, 0, 0.6);
}
/* Light Mode - Manual Override */
[data-theme="light"] {
--color-primary: #6B5B95;
--color-primary-hover: #574A7A;
--color-primary-light: #E8E4F0;
--color-secondary: #9B8AA6;
--color-secondary-hover: #7D6E8A;
--color-accent: #A67B9E;
--color-accent-hover: #8A6283;
--color-success: #5A8F6B;
--color-warning: #C49A3C;
--color-error: #B54747;
--color-bg: #FAF8FC;
--color-bg-secondary: #F3F0F7;
--color-bg-tertiary: #EBE6F2;
--color-text: #2A2633;
--color-text-secondary: #524A5E;
--color-text-muted: #8A8295;
--color-border: #DDD8E6;
--color-border-focus: #6B5B95;
--color-shadow: rgba(42, 38, 51, 0.1);
--color-overlay: rgba(42, 38, 51, 0.5);
}