/* ============================================
   PropertyParking DESIGN TOKENS v2.0
   Shared across all public pages
   Single source of truth for design variables
   ============================================ */

:root {
  /* === COLORS: Brand (PropertyParking Blue) === */
  --oz-primary-50: #eff6ff;
  --oz-primary-100: #dbeafe;
  --oz-primary-200: #bfdbfe;
  --oz-primary-300: #93c5fd;
  --oz-primary-400: #60a5fa;
  --oz-primary-500: #3b82f6;
  --oz-primary-600: #2563eb;
  --oz-primary-700: #1d4ed8;
  --oz-primary-800: #1e40af;
  --oz-primary-900: #1e3a8a;

  /* === COLORS: Neutral (PropertyParking Gray) === */
  --oz-gray-50: #f8fafc;
  --oz-gray-100: #f1f5f9;
  --oz-gray-200: #e2e8f0;
  --oz-gray-300: #cbd5e1;
  --oz-gray-400: #94a3b8;
  --oz-gray-500: #64748b;
  --oz-gray-600: #475569;
  --oz-gray-700: #334155;
  --oz-gray-800: #1e293b;
  --oz-gray-900: #0f172a;

  /* === COLORS: Semantic === */
  --oz-success: #10b981;
  --oz-success-light: #d1fae5;
  --oz-warning: #f59e0b;
  --oz-warning-light: #fef3c7;
  --oz-error: #ef4444;
  --oz-error-light: #fee2e2;
  --oz-purple: #8b5cf6;
  --oz-purple-light: #ede9fe;

  /* === SPACING === */
  --oz-space-1: 0.25rem;
  --oz-space-2: 0.5rem;
  --oz-space-3: 0.75rem;
  --oz-space-4: 1rem;
  --oz-space-5: 1.25rem;
  --oz-space-6: 1.5rem;
  --oz-space-8: 2rem;
  --oz-space-10: 2.5rem;
  --oz-space-12: 3rem;

  /* === TYPOGRAPHY === */
  --oz-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --oz-text-xs: 0.75rem;
  --oz-text-sm: 0.875rem;
  --oz-text-base: 1rem;
  --oz-text-lg: 1.125rem;
  --oz-text-xl: 1.25rem;
  --oz-text-2xl: 1.5rem;
  --oz-text-3xl: 1.875rem;
  --oz-text-4xl: 2.25rem;

  /* === BORDER RADIUS === */
  --oz-radius-sm: 6px;
  --oz-radius-md: 8px;
  --oz-radius-lg: 12px;
  --oz-radius-xl: 16px;
  --oz-radius-2xl: 24px;
  --oz-radius-full: 9999px;

  /* === SHADOWS === */
  --oz-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --oz-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  --oz-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --oz-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --oz-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --oz-shadow-glow: 0 0 20px rgba(37, 99, 235, 0.3);
  --oz-shadow-soft: 0 18px 40px rgba(15, 23, 42, 0.08);

  /* === TRANSITIONS === */
  --oz-ease-default: cubic-bezier(0.4, 0, 0.2, 1);
  --oz-ease-out: cubic-bezier(0, 0, 0.2, 1);
  --oz-ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
  --oz-duration-fast: 150ms;
  --oz-duration-normal: 200ms;
  --oz-duration-slow: 300ms;

  /* === Z-INDEX === */
  --oz-z-dropdown: 100;
  --oz-z-sticky: 200;
  --oz-z-overlay: 300;
  --oz-z-modal: 400;
  --oz-z-toast: 500;

  /* === LEGACY ALIASES ===
     Maps old variable names to new --oz-* tokens.
     Used by booking, confirmation, and older components. */
  --bg: var(--oz-gray-50);
  --bg-card: #ffffff;
  --bg-elevated: #ffffff;
  --border: var(--oz-gray-200);
  --border-subtle: var(--oz-gray-200);
  --border-focus: var(--oz-primary-600);
  --text-primary: var(--oz-gray-900);
  --text-main: var(--oz-gray-900);
  --text-secondary: var(--oz-gray-600);
  --text-muted: var(--oz-gray-600);
  --text-soft: var(--oz-gray-400);
  --accent: var(--oz-primary-600);
  --accent-hover: var(--oz-primary-700);
  --accent-light: var(--oz-primary-50);
  --success: #10b981;
  --success-light: #d1fae5;
  --error: #ef4444;
  --error-light: #fee2e2;
  --warning: #f59e0b;
  --warning-light: #fef3c7;
  --pending: #f59e0b;
  --pending-light: #fef3c7;
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-glow: 0 0 20px rgba(37, 99, 235, 0.3);
  --shadow-soft: 0 18px 40px rgba(15, 23, 42, 0.08);
  --transition: all 0.2s ease;
}
