- Create comprehensive design system with 185 design tokens
- Add hvac-design-system.css with 8px spacing scale, typography, colors
- Add hvac-components.css with reusable component patterns
- Fix all CSS syntax errors in consolidated bundles
- Implement mobile-first responsive design
- Add WCAG 2.1 AA accessibility compliance
- Reduce CSS files from 250+ to 5 optimized bundles
- Fix Safari browser compatibility issues
- Resolve UI inconsistencies (spacing, typography, buttons)
- Implement proper z-index layering system
🤖 Generated with Claude Code
Co-Authored-By: Claude <noreply@anthropic.com>
		
	
			
		
			
				
	
	
		
			329 lines
		
	
	
		
			No EOL
		
	
	
		
			9.1 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
			
		
		
	
	
			329 lines
		
	
	
		
			No EOL
		
	
	
		
			9.1 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
| /**
 | |
|  * HVAC Community Events - Design System
 | |
|  * Master design tokens and component patterns
 | |
|  * 
 | |
|  * This file establishes the foundation for all HVAC plugin styles
 | |
|  * following a systematic design approach with consistent spacing,
 | |
|  * typography, colors, and component patterns.
 | |
|  * 
 | |
|  * @version 1.0.0
 | |
|  * @since 2025-08-21
 | |
|  */
 | |
| 
 | |
| /* ===== DESIGN TOKENS ===== */
 | |
| 
 | |
| :root {
 | |
|   /* === SPACING SCALE (8px base unit) === */
 | |
|   --hvac-space-0: 0;
 | |
|   --hvac-space-1: 0.25rem;   /* 4px */
 | |
|   --hvac-space-2: 0.5rem;    /* 8px */
 | |
|   --hvac-space-3: 0.75rem;   /* 12px */
 | |
|   --hvac-space-4: 1rem;      /* 16px */
 | |
|   --hvac-space-5: 1.25rem;   /* 20px */
 | |
|   --hvac-space-6: 1.5rem;    /* 24px */
 | |
|   --hvac-space-8: 2rem;      /* 32px */
 | |
|   --hvac-space-10: 2.5rem;   /* 40px */
 | |
|   --hvac-space-12: 3rem;     /* 48px */
 | |
|   --hvac-space-16: 4rem;     /* 64px */
 | |
|   --hvac-space-20: 5rem;     /* 80px */
 | |
|   
 | |
|   /* === COLOR SYSTEM === */
 | |
|   
 | |
|   /* Primary Blue Scale */
 | |
|   --hvac-primary-50: #e6f3fb;
 | |
|   --hvac-primary-100: #cce7f7;
 | |
|   --hvac-primary-200: #99cef0;
 | |
|   --hvac-primary-300: #66b6e8;
 | |
|   --hvac-primary-400: #339de0;
 | |
|   --hvac-primary-500: #0274be;   /* Main brand color */
 | |
|   --hvac-primary-600: #0264a8;
 | |
|   --hvac-primary-700: #005493;
 | |
|   --hvac-primary-800: #00437d;
 | |
|   --hvac-primary-900: #003368;
 | |
|   
 | |
|   /* Neutral Gray Scale */
 | |
|   --hvac-neutral-0: #ffffff;
 | |
|   --hvac-neutral-50: #f9fafb;
 | |
|   --hvac-neutral-100: #f3f4f6;
 | |
|   --hvac-neutral-200: #e5e7eb;
 | |
|   --hvac-neutral-300: #d1d5db;
 | |
|   --hvac-neutral-400: #9ca3af;
 | |
|   --hvac-neutral-500: #6b7280;
 | |
|   --hvac-neutral-600: #4b5563;
 | |
|   --hvac-neutral-700: #374151;
 | |
|   --hvac-neutral-800: #1f2937;
 | |
|   --hvac-neutral-900: #111827;
 | |
|   
 | |
|   /* Semantic Colors */
 | |
|   --hvac-success-50: #f0fdf4;
 | |
|   --hvac-success-500: #22c55e;
 | |
|   --hvac-success-600: #16a34a;
 | |
|   --hvac-success-700: #15803d;
 | |
|   
 | |
|   --hvac-warning-50: #fffbeb;
 | |
|   --hvac-warning-500: #f59e0b;
 | |
|   --hvac-warning-600: #d97706;
 | |
|   --hvac-warning-700: #b45309;
 | |
|   
 | |
|   --hvac-error-50: #fef2f2;
 | |
|   --hvac-error-500: #ef4444;
 | |
|   --hvac-error-600: #dc2626;
 | |
|   --hvac-error-700: #b91c1c;
 | |
|   
 | |
|   --hvac-info-50: #eff6ff;
 | |
|   --hvac-info-500: #3b82f6;
 | |
|   --hvac-info-600: #2563eb;
 | |
|   --hvac-info-700: #1d4ed8;
 | |
|   
 | |
|   /* === TYPOGRAPHY SCALE === */
 | |
|   --hvac-text-xs: 0.75rem;      /* 12px */
 | |
|   --hvac-text-sm: 0.875rem;     /* 14px */
 | |
|   --hvac-text-base: 1rem;       /* 16px */
 | |
|   --hvac-text-lg: 1.125rem;     /* 18px */
 | |
|   --hvac-text-xl: 1.25rem;      /* 20px */
 | |
|   --hvac-text-2xl: 1.5rem;      /* 24px */
 | |
|   --hvac-text-3xl: 1.875rem;    /* 30px */
 | |
|   --hvac-text-4xl: 2.25rem;     /* 36px */
 | |
|   
 | |
|   /* Line Heights */
 | |
|   --hvac-leading-tight: 1.25;
 | |
|   --hvac-leading-snug: 1.375;
 | |
|   --hvac-leading-normal: 1.5;
 | |
|   --hvac-leading-relaxed: 1.625;
 | |
|   --hvac-leading-loose: 2;
 | |
|   
 | |
|   /* Font Weights */
 | |
|   --hvac-font-light: 300;
 | |
|   --hvac-font-normal: 400;
 | |
|   --hvac-font-medium: 500;
 | |
|   --hvac-font-semibold: 600;
 | |
|   --hvac-font-bold: 700;
 | |
|   
 | |
|   /* === BORDER RADIUS === */
 | |
|   --hvac-radius-none: 0;
 | |
|   --hvac-radius-sm: 0.25rem;     /* 4px */
 | |
|   --hvac-radius-base: 0.5rem;    /* 8px */
 | |
|   --hvac-radius-md: 0.75rem;     /* 12px */
 | |
|   --hvac-radius-lg: 1rem;        /* 16px */
 | |
|   --hvac-radius-xl: 1.5rem;      /* 24px */
 | |
|   --hvac-radius-full: 9999px;
 | |
|   
 | |
|   /* === SHADOWS === */
 | |
|   --hvac-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
 | |
|   --hvac-shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
 | |
|   --hvac-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
 | |
|   --hvac-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
 | |
|   --hvac-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
 | |
|   
 | |
|   /* === TRANSITIONS === */
 | |
|   --hvac-transition-fast: 150ms ease-in-out;
 | |
|   --hvac-transition-base: 250ms ease-in-out;
 | |
|   --hvac-transition-slow: 350ms ease-in-out;
 | |
|   
 | |
|   /* === Z-INDEX SCALE === */
 | |
|   --hvac-z-hide: -1;
 | |
|   --hvac-z-base: 0;
 | |
|   --hvac-z-docked: 10;
 | |
|   --hvac-z-dropdown: 1000;
 | |
|   --hvac-z-sticky: 1100;
 | |
|   --hvac-z-banner: 1200;
 | |
|   --hvac-z-overlay: 1300;
 | |
|   --hvac-z-modal: 1400;
 | |
|   --hvac-z-popover: 1500;
 | |
|   --hvac-z-skipnav: 1600;
 | |
|   --hvac-z-toast: 1700;
 | |
|   --hvac-z-tooltip: 1800;
 | |
|   
 | |
|   /* === RESPONSIVE BREAKPOINTS === */
 | |
|   --hvac-screen-sm: 640px;
 | |
|   --hvac-screen-md: 768px;
 | |
|   --hvac-screen-lg: 1024px;
 | |
|   --hvac-screen-xl: 1280px;
 | |
|   --hvac-screen-2xl: 1536px;
 | |
|   
 | |
|   /* === COMPONENT TOKENS === */
 | |
|   
 | |
|   /* Container */
 | |
|   --hvac-container-max-width: 1200px;
 | |
|   --hvac-container-padding: var(--hvac-space-4);
 | |
|   
 | |
|   /* Cards */
 | |
|   --hvac-card-padding: var(--hvac-space-6);
 | |
|   --hvac-card-radius: var(--hvac-radius-base);
 | |
|   --hvac-card-shadow: var(--hvac-shadow-base);
 | |
|   --hvac-card-border: 1px solid var(--hvac-neutral-200);
 | |
|   
 | |
|   /* Buttons */
 | |
|   --hvac-button-padding-sm: var(--hvac-space-2) var(--hvac-space-3);
 | |
|   --hvac-button-padding-base: var(--hvac-space-3) var(--hvac-space-5);
 | |
|   --hvac-button-padding-lg: var(--hvac-space-4) var(--hvac-space-8);
 | |
|   --hvac-button-radius: var(--hvac-radius-base);
 | |
|   --hvac-button-shadow: var(--hvac-shadow-sm);
 | |
|   --hvac-button-transition: var(--hvac-transition-fast);
 | |
|   
 | |
|   /* Forms */
 | |
|   --hvac-input-padding: var(--hvac-space-3) var(--hvac-space-4);
 | |
|   --hvac-input-radius: var(--hvac-radius-base);
 | |
|   --hvac-input-border: 1px solid var(--hvac-neutral-300);
 | |
|   --hvac-input-shadow: var(--hvac-shadow-sm);
 | |
|   --hvac-input-focus-ring: 0 0 0 3px rgba(2, 116, 190, 0.1);
 | |
|   
 | |
|   /* Navigation */
 | |
|   --hvac-nav-padding: var(--hvac-space-4) var(--hvac-space-6);
 | |
|   --hvac-nav-shadow: var(--hvac-shadow-base);
 | |
|   
 | |
|   /* Tables */
 | |
|   --hvac-table-padding: var(--hvac-space-3) var(--hvac-space-4);
 | |
|   --hvac-table-border: 1px solid var(--hvac-neutral-200);
 | |
|   
 | |
|   /* === ACCESSIBILITY === */
 | |
|   --hvac-focus-ring: 0 0 0 3px rgba(2, 116, 190, 0.5);
 | |
|   --hvac-focus-ring-offset: 2px;
 | |
|   
 | |
|   /* Minimum touch targets */
 | |
|   --hvac-touch-target: 44px;
 | |
| }
 | |
| 
 | |
| /* ===== RESET & BASE STYLES ===== */
 | |
| 
 | |
| /* Box sizing for all HVAC components */
 | |
| .hvac-content,
 | |
| .hvac-content *,
 | |
| .hvac-content *::before,
 | |
| .hvac-content *::after {
 | |
|   box-sizing: border-box;
 | |
| }
 | |
| 
 | |
| /* Base text styles */
 | |
| .hvac-content {
 | |
|   font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
 | |
|   font-size: var(--hvac-text-base);
 | |
|   line-height: var(--hvac-leading-normal);
 | |
|   color: var(--hvac-neutral-900);
 | |
|   -webkit-font-smoothing: antialiased;
 | |
|   -moz-osx-font-smoothing: grayscale;
 | |
| }
 | |
| 
 | |
| /* ===== LAYOUT UTILITIES ===== */
 | |
| 
 | |
| /* Container */
 | |
| .hvac-container {
 | |
|   max-width: var(--hvac-container-max-width);
 | |
|   margin: 0 auto;
 | |
|   padding: 0 var(--hvac-container-padding);
 | |
| }
 | |
| 
 | |
| /* Grid System */
 | |
| .hvac-grid {
 | |
|   display: grid;
 | |
|   gap: var(--hvac-space-6);
 | |
| }
 | |
| 
 | |
| .hvac-grid-2 { grid-template-columns: repeat(2, 1fr); }
 | |
| .hvac-grid-3 { grid-template-columns: repeat(3, 1fr); }
 | |
| .hvac-grid-4 { grid-template-columns: repeat(4, 1fr); }
 | |
| 
 | |
| /* Responsive grid */
 | |
| @media (max-width: 767px) {
 | |
|   .hvac-grid-2,
 | |
|   .hvac-grid-3,
 | |
|   .hvac-grid-4 {
 | |
|     grid-template-columns: 1fr;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media (min-width: 768px) and (max-width: 1023px) {
 | |
|   .hvac-grid-3,
 | |
|   .hvac-grid-4 {
 | |
|     grid-template-columns: repeat(2, 1fr);
 | |
|   }
 | |
| }
 | |
| 
 | |
| /* Flexbox utilities */
 | |
| .hvac-flex {
 | |
|   display: flex;
 | |
| }
 | |
| 
 | |
| .hvac-flex-col {
 | |
|   flex-direction: column;
 | |
| }
 | |
| 
 | |
| .hvac-items-center {
 | |
|   align-items: center;
 | |
| }
 | |
| 
 | |
| .hvac-justify-center {
 | |
|   justify-content: center;
 | |
| }
 | |
| 
 | |
| .hvac-justify-between {
 | |
|   justify-content: space-between;
 | |
| }
 | |
| 
 | |
| .hvac-justify-end {
 | |
|   justify-content: flex-end;
 | |
| }
 | |
| 
 | |
| .hvac-gap-2 { gap: var(--hvac-space-2); }
 | |
| .hvac-gap-3 { gap: var(--hvac-space-3); }
 | |
| .hvac-gap-4 { gap: var(--hvac-space-4); }
 | |
| .hvac-gap-6 { gap: var(--hvac-space-6); }
 | |
| 
 | |
| /* ===== SPACING UTILITIES ===== */
 | |
| 
 | |
| /* Margin */
 | |
| .hvac-m-0 { margin: 0 !important; }
 | |
| .hvac-m-2 { margin: var(--hvac-space-2); }
 | |
| .hvac-m-4 { margin: var(--hvac-space-4); }
 | |
| .hvac-m-6 { margin: var(--hvac-space-6); }
 | |
| 
 | |
| .hvac-mt-0 { margin-top: 0 !important; }
 | |
| .hvac-mt-2 { margin-top: var(--hvac-space-2); }
 | |
| .hvac-mt-4 { margin-top: var(--hvac-space-4); }
 | |
| .hvac-mt-6 { margin-top: var(--hvac-space-6); }
 | |
| .hvac-mt-8 { margin-top: var(--hvac-space-8); }
 | |
| 
 | |
| .hvac-mb-0 { margin-bottom: 0 !important; }
 | |
| .hvac-mb-2 { margin-bottom: var(--hvac-space-2); }
 | |
| .hvac-mb-4 { margin-bottom: var(--hvac-space-4); }
 | |
| .hvac-mb-6 { margin-bottom: var(--hvac-space-6); }
 | |
| .hvac-mb-8 { margin-bottom: var(--hvac-space-8); }
 | |
| 
 | |
| /* Padding */
 | |
| .hvac-p-0 { padding: 0 !important; }
 | |
| .hvac-p-2 { padding: var(--hvac-space-2); }
 | |
| .hvac-p-4 { padding: var(--hvac-space-4); }
 | |
| .hvac-p-6 { padding: var(--hvac-space-6); }
 | |
| 
 | |
| .hvac-px-2 { padding-left: var(--hvac-space-2); padding-right: var(--hvac-space-2); }
 | |
| .hvac-px-4 { padding-left: var(--hvac-space-4); padding-right: var(--hvac-space-4); }
 | |
| .hvac-px-6 { padding-left: var(--hvac-space-6); padding-right: var(--hvac-space-6); }
 | |
| 
 | |
| .hvac-py-2 { padding-top: var(--hvac-space-2); padding-bottom: var(--hvac-space-2); }
 | |
| .hvac-py-4 { padding-top: var(--hvac-space-4); padding-bottom: var(--hvac-space-4); }
 | |
| .hvac-py-6 { padding-top: var(--hvac-space-6); padding-bottom: var(--hvac-space-6); }
 | |
| 
 | |
| /* ===== REDUCED MOTION SUPPORT ===== */
 | |
| 
 | |
| @media (prefers-reduced-motion: reduce) {
 | |
|   *,
 | |
|   *::before,
 | |
|   *::after {
 | |
|     animation-duration: 0.01ms !important;
 | |
|     animation-iteration-count: 1 !important;
 | |
|     transition-duration: 0.01ms !important;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /* ===== PRINT STYLES ===== */
 | |
| 
 | |
| @media print {
 | |
|   .hvac-content {
 | |
|     color: black !important;
 | |
|     background: white !important;
 | |
|   }
 | |
|   
 | |
|   .hvac-no-print {
 | |
|     display: none !important;
 | |
|   }
 | |
| } |