@import url(https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap);
/**
 * shadcn/UI CSS Variables
 * 
 * This file defines CSS variables following shadcn/UI conventions,
 * allowing for easier migration or compatibility with shadcn/UI components.
 */

/* Define variables in :root with importance to override any global styles */
:root {
  /* Base colors — semantic grayscale system */
  --background: var(--chakra-colors-gray-50) !important;
  --foreground: var(--ui-text-primary) !important;

  --muted: var(--ui-surface-muted) !important;
  --muted-foreground: var(--ui-text-tertiary) !important;

  --popover: var(--ui-surface-elevated) !important;
  --popover-foreground: var(--ui-text-primary) !important;

  --card: var(--ui-surface-panel) !important;
  --card-foreground: var(--ui-text-primary) !important;

  --border: var(--ui-border) !important;
  --input: var(--ui-border) !important;

  --primary: var(--ui-surface-inverse) !important;
  --primary-foreground: var(--ui-text-inverse) !important;
  --primary-hover: var(--ui-surface-inverse-hover) !important;

  --secondary: var(--ui-surface-muted) !important;
  --secondary-foreground: var(--ui-text-primary) !important;
  --secondary-hover: var(--ui-surface-inset) !important;
  
  --accent: var(--ui-accent) !important;
  --accent-foreground: var(--ui-accent-text) !important;
  --accent-hover: var(--ui-accent-hover) !important;
  
  --destructive: var(--ui-status-error-solid) !important;
  --destructive-foreground: var(--ui-status-error-solid-text) !important;
  --destructive-hover: color-mix(in srgb, var(--destructive) 88%, var(--background)) !important;

  --success: var(--ui-status-success-solid) !important;
  --success-foreground: var(--ui-status-success-solid-text) !important;
  --warning: var(--ui-status-warning-solid) !important;
  --warning-foreground: var(--ui-status-warning-solid-text) !important;
  --info: var(--ui-status-info-solid) !important;
  --info-foreground: var(--ui-status-info-solid-text) !important;

  --ring: var(--ui-focus-ring-strong) !important;

  /* shadcn/UI specific variables */
  --radius: 5px !important;

  /* Override any existing button hover styles in global CSS */
  --btn-bg-color-hover: var(--primary-hover) !important;
  --button-primary-background-hover: #404040 !important;
  --button-secondary-background-hover: #e5e5e5 !important;
  --button-tertiary-background-hover: #404040 !important;
  --button-tertiary-border-hover: var(--ui-border-strong) !important;
  --button-destructive-hover: var(--destructive-hover) !important;
  
  /* BlackAlpha scale */
  --chakra-colors-blackAlpha-50: rgba(0, 0, 0, 0.04) !important;
  --chakra-colors-blackAlpha-100: rgba(0, 0, 0, 0.06) !important;
  --chakra-colors-blackAlpha-200: rgba(0, 0, 0, 0.08) !important;
  --chakra-colors-blackAlpha-300: rgba(0, 0, 0, 0.16) !important;
  --chakra-colors-blackAlpha-400: rgba(0, 0, 0, 0.24) !important;
  --chakra-colors-blackAlpha-500: rgba(0, 0, 0, 0.36) !important;
  --chakra-colors-blackAlpha-600: rgba(0, 0, 0, 0.48) !important;
  --chakra-colors-blackAlpha-700: rgba(0, 0, 0, 0.64) !important;
  --chakra-colors-blackAlpha-800: rgba(0, 0, 0, 0.80) !important;
  --chakra-colors-blackAlpha-900: rgba(0, 0, 0, 0.92) !important;

  /* WhiteAlpha scale */
  --chakra-colors-whiteAlpha-50: rgba(255, 255, 255, 0.04) !important;
  --chakra-colors-whiteAlpha-100: rgba(255, 255, 255, 0.06) !important;
  --chakra-colors-whiteAlpha-200: rgba(255, 255, 255, 0.08) !important;
  --chakra-colors-whiteAlpha-300: rgba(255, 255, 255, 0.16) !important;
  --chakra-colors-whiteAlpha-400: rgba(255, 255, 255, 0.24) !important;
  --chakra-colors-whiteAlpha-500: rgba(255, 255, 255, 0.36) !important;
  --chakra-colors-whiteAlpha-600: rgba(255, 255, 255, 0.48) !important;
  --chakra-colors-whiteAlpha-700: rgba(255, 255, 255, 0.64) !important;
  --chakra-colors-whiteAlpha-800: rgba(255, 255, 255, 0.80) !important;
  --chakra-colors-whiteAlpha-900: rgba(255, 255, 255, 0.92) !important;

  /* Override Chakra UI color scales - zinc-based grays */
  --chakra-colors-gray-50: #fafafa !important;
  --chakra-colors-gray-100: #f4f4f5 !important;
  --chakra-colors-gray-200: #e4e4e7 !important;
  --chakra-colors-gray-300: #d4d4d8 !important;
  --chakra-colors-gray-400: #a1a1aa !important;
  --chakra-colors-gray-500: #71717a !important;
  --chakra-colors-gray-600: #52525b !important;
  --chakra-colors-gray-700: #3f3f46 !important;
  --chakra-colors-gray-800: #27272a !important;
  --chakra-colors-gray-900: #18181b !important;
  --chakra-colors-blue-50: var(--gray-50) !important;
  --chakra-colors-blue-100: var(--gray-100) !important;
  --chakra-colors-blue-200: var(--gray-200) !important;
  --chakra-colors-blue-300: var(--gray-300) !important;
  --chakra-colors-blue-400: var(--gray-400) !important;
  --chakra-colors-blue-500: var(--gray-500) !important;
  --chakra-colors-blue-600: var(--gray-600) !important;
  --chakra-colors-blue-700: var(--gray-700) !important;
  --chakra-colors-blue-800: var(--gray-800) !important;
  --chakra-colors-blue-900: var(--gray-900) !important;
  --chakra-colors-brand-500: var(--ui-accent) !important;
  --chakra-colors-brand-600: var(--ui-accent-hover) !important;
  --chakra-colors-brand-hover: var(--ui-accent-hover) !important;
  --chakra-colors-red-500: var(--ui-status-error-solid) !important;
  --chakra-colors-red-600: var(--destructive-hover) !important;

  /* Green scale — desaturated sage */
  --chakra-colors-green-50: #f3f6f1 !important;
  --chakra-colors-green-100: #e3eadc !important;
  --chakra-colors-green-200: #d0dbc8 !important;
  --chakra-colors-green-300: #b8c8ae !important;
  --chakra-colors-green-400: #9fb493 !important;
  --chakra-colors-green-500: #849778 !important;
  --chakra-colors-green-600: #6b7a61 !important;
  --chakra-colors-green-700: #53604c !important;
  --chakra-colors-green-800: #3c4638 !important;
  --chakra-colors-green-900: #252b24 !important;

  /* Orange scale — restrained amber */
  --chakra-colors-orange-50: #faf6ed !important;
  --chakra-colors-orange-100: #f3ead8 !important;
  --chakra-colors-orange-200: #e7d5b3 !important;
  --chakra-colors-orange-300: #d8bc87 !important;
  --chakra-colors-orange-400: #c59f61 !important;
  --chakra-colors-orange-500: #ad8346 !important;
  --chakra-colors-orange-600: #8d6736 !important;
  --chakra-colors-orange-700: #6c4e29 !important;
  --chakra-colors-orange-800: #4f391f !important;
  --chakra-colors-orange-900: #312313 !important;

  /* Brand button specifics */
  --chakra-colors-blue-hover: #4c667d !important;
}

/* Dark mode is activated when the .dark class is applied to html */
html.dark {
  --background: var(--chakra-colors-gray-50) !important;
  --foreground: var(--ui-text-primary) !important;

  --muted: var(--ui-surface-muted) !important;
  --muted-foreground: var(--ui-text-tertiary) !important;

  --popover: var(--ui-surface-elevated) !important;
  --popover-foreground: var(--ui-text-primary) !important;

  --card: var(--ui-surface-panel) !important;
  --card-foreground: var(--ui-text-primary) !important;

  --border: var(--ui-border) !important;
  --input: var(--ui-border) !important;

  --primary: var(--ui-surface-inverse) !important;
  --primary-foreground: var(--ui-text-inverse) !important;
  --primary-hover: var(--ui-surface-inverse-hover) !important;

  --secondary: var(--ui-surface-muted) !important;
  --secondary-foreground: var(--ui-text-primary) !important;
  --secondary-hover: var(--ui-surface-inset) !important;
  
  --accent: var(--ui-accent) !important;
  --accent-foreground: var(--ui-accent-text) !important;
  --accent-hover: var(--ui-accent-hover) !important;
  
  --destructive: var(--ui-status-error-solid) !important;
  --destructive-foreground: var(--ui-status-error-solid-text) !important;
  --destructive-hover: color-mix(in srgb, var(--destructive) 88%, var(--background)) !important;

  --success: var(--ui-status-success-solid) !important;
  --success-foreground: var(--ui-status-success-solid-text) !important;
  --warning: var(--ui-status-warning-solid) !important;
  --warning-foreground: var(--ui-status-warning-solid-text) !important;
  --info: var(--ui-status-info-solid) !important;
  --info-foreground: var(--ui-status-info-solid-text) !important;

  --ring: var(--ui-focus-ring-strong) !important;

  /* Override any existing button hover styles in global CSS */
  --btn-bg-color-hover: var(--primary-hover) !important;
  --button-primary-background-hover: #e5e5e5 !important;
  --button-secondary-background-hover: #737373 !important;
  --button-tertiary-background-hover: #e5e5e5 !important;
  --button-tertiary-border-hover: var(--ui-border-strong) !important;
  --button-destructive-hover: var(--destructive-hover) !important;

  /* Invert blackAlpha for dark mode */
  --chakra-colors-blackAlpha-50: rgba(255, 255, 255, 0.04) !important;
  --chakra-colors-blackAlpha-100: rgba(255, 255, 255, 0.06) !important;
  --chakra-colors-blackAlpha-200: rgba(255, 255, 255, 0.08) !important;
  --chakra-colors-blackAlpha-300: rgba(255, 255, 255, 0.16) !important;
  --chakra-colors-blackAlpha-400: rgba(255, 255, 255, 0.24) !important;
  --chakra-colors-blackAlpha-500: rgba(255, 255, 255, 0.36) !important;
  --chakra-colors-blackAlpha-600: rgba(255, 255, 255, 0.48) !important;
  --chakra-colors-blackAlpha-700: rgba(255, 255, 255, 0.64) !important;
  --chakra-colors-blackAlpha-800: rgba(255, 255, 255, 0.80) !important;
  --chakra-colors-blackAlpha-900: rgba(255, 255, 255, 0.92) !important;

  /* Invert whiteAlpha for dark mode */
  --chakra-colors-whiteAlpha-50: rgba(0, 0, 0, 0.04) !important;
  --chakra-colors-whiteAlpha-100: rgba(0, 0, 0, 0.06) !important;
  --chakra-colors-whiteAlpha-200: rgba(0, 0, 0, 0.08) !important;
  --chakra-colors-whiteAlpha-300: rgba(0, 0, 0, 0.16) !important;
  --chakra-colors-whiteAlpha-400: rgba(0, 0, 0, 0.24) !important;
  --chakra-colors-whiteAlpha-500: rgba(0, 0, 0, 0.36) !important;
  --chakra-colors-whiteAlpha-600: rgba(0, 0, 0, 0.48) !important;
  --chakra-colors-whiteAlpha-700: rgba(0, 0, 0, 0.64) !important;
  --chakra-colors-whiteAlpha-800: rgba(0, 0, 0, 0.80) !important;
  --chakra-colors-whiteAlpha-900: rgba(0, 0, 0, 0.92) !important;

  /* Invert Chakra color tokens for dark mode (zinc-based) */
  --chakra-colors-white: #0a0a0a !important;
  --chakra-colors-black: #fafafa !important;
  --chakra-colors-gray-50: #18181b !important;
  --chakra-colors-gray-100: #1c1c1f !important;
  --chakra-colors-gray-200: #27272a !important;
  --chakra-colors-gray-300: #3f3f46 !important;
  --chakra-colors-gray-400: #52525b !important;
  --chakra-colors-gray-500: #71717a !important;
  --chakra-colors-gray-600: #a1a1aa !important;
  --chakra-colors-gray-700: #d4d4d8 !important;
  --chakra-colors-gray-800: #e4e4e7 !important;
  --chakra-colors-gray-900: #fafafa !important;

  /* Blue aliases stay grayscale in dark mode. */
  --chakra-colors-blue-50: var(--gray-900) !important;
  --chakra-colors-blue-100: var(--gray-800) !important;
  --chakra-colors-blue-200: var(--gray-700) !important;
  --chakra-colors-blue-300: var(--gray-600) !important;
  --chakra-colors-blue-400: var(--gray-500) !important;
  --chakra-colors-blue-500: var(--gray-400) !important;
  --chakra-colors-blue-600: var(--gray-300) !important;
  --chakra-colors-blue-700: var(--gray-200) !important;
  --chakra-colors-blue-800: var(--gray-100) !important;
  --chakra-colors-blue-900: var(--gray-50) !important;

  --chakra-colors-brand-500: var(--ui-accent) !important;
  --chakra-colors-brand-600: var(--ui-accent-hover) !important;
  --chakra-colors-brand-hover: var(--ui-accent-hover) !important;
  --chakra-colors-red-500: var(--ui-status-error-solid) !important;
  --chakra-colors-red-600: var(--destructive-hover) !important;

  /* Green scale inverted for dark mode */
  --chakra-colors-green-50: #252b24 !important;
  --chakra-colors-green-100: #3c4638 !important;
  --chakra-colors-green-200: #53604c !important;
  --chakra-colors-green-300: #6b7a61 !important;
  --chakra-colors-green-400: #849778 !important;
  --chakra-colors-green-500: #9fb493 !important;
  --chakra-colors-green-600: #b8c8ae !important;
  --chakra-colors-green-700: #d0dbc8 !important;
  --chakra-colors-green-800: #e3eadc !important;
  --chakra-colors-green-900: #f3f6f1 !important;

  /* Orange scale inverted for dark mode */
  --chakra-colors-orange-50: #312313 !important;
  --chakra-colors-orange-100: #4f391f !important;
  --chakra-colors-orange-200: #6c4e29 !important;
  --chakra-colors-orange-300: #8d6736 !important;
  --chakra-colors-orange-400: #ad8346 !important;
  --chakra-colors-orange-500: #c59f61 !important;
  --chakra-colors-orange-600: #d8bc87 !important;
  --chakra-colors-orange-700: #e7d5b3 !important;
  --chakra-colors-orange-800: #f3ead8 !important;
  --chakra-colors-orange-900: #faf6ed !important;

  /* Brand button specifics */
  --chakra-colors-blue-hover: #4c667d !important;
}

/* Force body & #root background in dark mode —
   Chakra uses gray.800 as its default dark-mode body bg,
   but our gray-scale inversion turns gray.800 into a light color. */
html.dark body,
html.dark #root {
  background: var(--background) !important;
  color: var(--foreground) !important;
}

/* Sonner-style toast rich-color tokens */
:root {
  --toast-success-bg: var(--ui-status-success-surface);
  --toast-success-border: var(--ui-status-success-border);
  --toast-success-text: var(--ui-status-success-text);
  --toast-error-bg: var(--ui-status-error-surface);
  --toast-error-border: var(--ui-status-error-border);
  --toast-error-text: var(--ui-status-error-text);
  --toast-warning-bg: var(--ui-status-warning-surface);
  --toast-warning-border: var(--ui-status-warning-border);
  --toast-warning-text: var(--ui-status-warning-text);
  --toast-info-bg: var(--ui-status-info-surface);
  --toast-info-border: var(--ui-status-info-border);
  --toast-info-text: var(--ui-status-info-text);
}

html.dark {
  --toast-success-bg: var(--ui-status-success-surface);
  --toast-success-border: var(--ui-status-success-border);
  --toast-success-text: var(--ui-status-success-text);
  --toast-error-bg: var(--ui-status-error-surface);
  --toast-error-border: var(--ui-status-error-border);
  --toast-error-text: var(--ui-status-error-text);
  --toast-warning-bg: var(--ui-status-warning-surface);
  --toast-warning-border: var(--ui-status-warning-border);
  --toast-warning-text: var(--ui-status-warning-text);
  --toast-info-bg: var(--ui-status-info-surface);
  --toast-info-border: var(--ui-status-info-border);
  --toast-info-text: var(--ui-status-info-text);
}

/* Animation variables */
:root {
  --transition-duration: 0.12s !important;
  --transition-timing-function: cubic-bezier(0.2, 0, 0, 1) !important;
}

/* Typography variables - using shadcn/UI system */
:root {
  --font-sans: Inter, 'Avenir Next', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  --font-mono: 'IBM Plex Mono', 'SFMono-Regular', Menlo, Monaco, Consolas, monospace !important;
  
  /* Letter spacing */
  --letter-spacing-md: 0 !important;

  /* Font sizes (with proper line-heights as used in shadcn/UI) */
  --font-size-xs: 0.75rem !important;
  --line-height-xs: 1rem !important;
  --font-size-sm: 0.8125rem !important;
  --line-height-sm: 1.1rem !important;
  --font-size-base: 1rem !important;
  --line-height-base: 1.5rem !important;
  --font-size-lg: 1.125rem !important;
  --line-height-lg: 1.75rem !important;
  --font-size-xl: 1.25rem !important;
  --line-height-xl: 1.75rem !important;
  --font-size-2xl: 1.5rem !important;
  --line-height-2xl: 2rem !important;
  --font-size-3xl: 1.875rem !important;
  --line-height-3xl: 2.25rem !important;
  --font-size-4xl: 2.25rem !important;
  --line-height-4xl: 2.5rem !important;
  
  /* Font weights */
  --font-weight-normal: 400 !important;
  --font-weight-medium: 500 !important;
  --font-weight-semibold: 600 !important;
  --font-weight-bold: 700 !important;
}

/* Border radius variables - using more precise shadcn/UI values */
:root {
  --radius-xs: 2px !important;
  --radius-sm: 3px !important;
  --radius-md: 4px !important;
  --radius-lg: 5px !important;
  --radius-xl: 7px !important;
  --radius-2xl: 9px !important;
  --radius-full: 9999px !important;
}

/* shadcn/UI specific spacing variables */
:root {
  --spacing-1: 0.25rem !important;
  --spacing-2: 0.5rem !important;
  --spacing-3: 0.75rem !important;
  --spacing-4: 1rem !important;
  --spacing-5: 1.25rem !important;
  --spacing-6: 1.5rem !important;
  --spacing-8: 2rem !important;
  --spacing-10: 2.5rem !important;
  --spacing-12: 3rem !important;
  --spacing-16: 4rem !important;
}

/* 
 * Inline styles with high specificity to override any global styles 
 */
.shadcn-ui.chakra-button,
.shadcn-ui.chakra-button[data-hover],
.shadcn-ui.chakra-button:hover {
  transition: background-color var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function), color var(--transition-duration) var(--transition-timing-function), box-shadow var(--transition-duration) var(--transition-timing-function) !important;
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-sm) !important;
  line-height: var(--line-height-sm) !important;
  height: 1.875rem !important;
  border-radius: calc(var(--radius) - 2px) !important;
}

.shadcn-ui.chakra-button.button-size-xs {
  height: 1.375rem !important;
  min-width: 1.375rem !important;
  padding-left: var(--spacing-2) !important;
  padding-right: var(--spacing-2) !important;
  font-size: var(--font-size-xs) !important;
}

.shadcn-ui.chakra-button.button-size-sm {
  height: 1.75rem !important;
  padding-left: var(--spacing-3) !important;
  padding-right: var(--spacing-3) !important;
  font-size: var(--font-size-xs) !important;
}

.shadcn-ui.chakra-button.button-size-lg {
  height: 2.125rem !important;
  padding-left: var(--spacing-4) !important;
  padding-right: var(--spacing-4) !important;
}

.shadcn-ui.chakra-button.button-size-icon {
  width: 1.875rem !important;
  min-width: 1.875rem !important;
  height: 1.875rem !important;
  padding: 0 !important;
}

/* Primary Button */
.shadcn-ui.chakra-button.button-primary {
  background-color: var(--primary) !important;
  color: var(--primary-foreground) !important;
}

.shadcn-ui.chakra-button.button-primary:hover,
.shadcn-ui.chakra-button.button-primary[data-hover] {
  background-color: var(--primary-hover) !important;
  color: var(--primary-foreground) !important;
}

/* Secondary Button */
.shadcn-ui.chakra-button.button-secondary {
  background-color: var(--secondary) !important;
  color: var(--secondary-foreground) !important;
}

.shadcn-ui.chakra-button.button-secondary:hover,
.shadcn-ui.chakra-button.button-secondary[data-hover] {
  background-color: var(--secondary-hover) !important;
  color: var(--secondary-foreground) !important;
}

/* Accent Button */
.shadcn-ui.chakra-button.button-accent {
  background-color: var(--accent) !important;
  color: var(--accent-foreground) !important;
}

.shadcn-ui.chakra-button.button-accent:hover,
.shadcn-ui.chakra-button.button-accent[data-hover] {
  background-color: var(--accent-hover) !important;
  color: var(--accent-foreground) !important;
}

/* Destructive Button */
.shadcn-ui.chakra-button.button-destructive {
  background-color: var(--destructive) !important;
  color: var(--destructive-foreground) !important;
}

.shadcn-ui.chakra-button.button-destructive:hover,
.shadcn-ui.chakra-button.button-destructive[data-hover] {
  background-color: var(--destructive-hover) !important;
  color: var(--destructive-foreground) !important;
}

/* Outline Button */
.shadcn-ui.chakra-button.button-outline {
  background-color: transparent !important;
  color: var(--foreground) !important;
  border: 1px solid var(--border) !important;
}

.shadcn-ui.chakra-button.button-outline:hover,
.shadcn-ui.chakra-button.button-outline[data-hover] {
  background-color: var(--muted) !important;
  color: var(--foreground) !important;
}

/* Ghost Button */
.shadcn-ui.chakra-button.button-ghost {
  background-color: transparent !important;
  color: var(--foreground) !important;
}

.shadcn-ui.chakra-button.button-ghost:hover,
.shadcn-ui.chakra-button.button-ghost[data-hover] {
  background-color: var(--muted) !important;
  color: var(--foreground) !important;
}

/* Link Button */
.shadcn-ui.chakra-button.button-link {
  background-color: transparent !important;
  color: var(--primary) !important;
  height: auto !important;
  padding: 0 !important;
}

.shadcn-ui.chakra-button.button-link:hover,
.shadcn-ui.chakra-button.button-link[data-hover] {
  text-decoration: underline !important;
  background-color: transparent !important;
}

/* Focus styles */
.shadcn-ui.chakra-button:focus,
.shadcn-ui.chakra-button[data-focus] {
  box-shadow: 0 0 0 2px var(--background), 0 0 0 4px var(--ring) !important;
  outline: none !important;
}

/* Active styles */
.shadcn-ui.chakra-button:active,
.shadcn-ui.chakra-button[data-active] {
  transform: none !important;
}

/* Disabled styles */
.shadcn-ui.chakra-button:disabled,
.shadcn-ui.chakra-button[aria-disabled=true] {
  opacity: 0.5 !important;
  pointer-events: none !important;
}

/* Input styles */
.shadcn-ui.chakra-input {
  height: 1.875rem !important;
  border-radius: calc(var(--radius) - 2px) !important;
  border-color: var(--input) !important;
  background-color: var(--background) !important;
  color: var(--foreground) !important;
  font-size: var(--font-size-sm) !important;
}

.shadcn-ui.chakra-input:focus,
.shadcn-ui.chakra-input[data-focus] {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 1px var(--ring) !important;
}

.shadcn-ui.chakra-input.field-size-xs,
.shadcn-ui.chakra-select.field-size-xs {
  height: 1.375rem !important;
  font-size: var(--font-size-xs) !important;
}

.shadcn-ui.chakra-input.field-size-sm,
.shadcn-ui.chakra-select.field-size-sm {
  height: 1.75rem !important;
}

.shadcn-ui.chakra-input.field-size-lg,
.shadcn-ui.chakra-select.field-size-lg {
  height: 2.125rem !important;
}

/* Checkbox styles */
.shadcn-ui.chakra-checkbox__control {
  border-radius: var(--radius-sm) !important;
  border-color: var(--input) !important;
}

.shadcn-ui.chakra-checkbox__control[data-checked] {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

/* Select styles */
.shadcn-ui.chakra-select {
  height: 1.875rem !important;
  border-radius: calc(var(--radius) - 2px) !important;
  border-color: var(--input) !important;
  background-color: var(--background) !important;
  color: var(--foreground) !important;
  font-size: var(--font-size-sm) !important;
}

.shadcn-ui.chakra-select:focus,
.shadcn-ui.chakra-select[data-focus] {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 1px var(--ring) !important;
}

.shadcn-ui.chakra-select option {
  background-color: var(--popover) !important;
  color: var(--popover-foreground) !important;
}

@media (max-width: 767px) {
  .shadcn-ui.chakra-button:not(.button-link) {
    min-height: 2.75rem !important;
    height: auto !important;
    max-width: 100% !important;
    padding-top: 0.625rem !important;
    padding-bottom: 0.625rem !important;
    font-size: 0.875rem !important;
    line-height: 1.2 !important;
    text-align: center !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    touch-action: manipulation;
  }

  .shadcn-ui.chakra-button.button-size-xs,
  .shadcn-ui.chakra-button.button-size-sm {
    min-height: 2.5rem !important;
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
    font-size: 0.875rem !important;
  }

  .shadcn-ui.chakra-button.button-size-lg {
    min-height: 3rem !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .shadcn-ui.chakra-button.button-size-icon {
    width: 2.5rem !important;
    min-width: 2.5rem !important;
    height: 2.5rem !important;
    min-height: 2.5rem !important;
    padding: 0 !important;
  }

  .shadcn-ui.chakra-button .chakra-button__icon {
    flex-shrink: 0;
  }

  .shadcn-ui.chakra-button.button-link {
    min-height: 2.5rem !important;
    display: inline-flex !important;
    align-items: center !important;
    touch-action: manipulation;
  }

  .shadcn-ui.chakra-input,
  .shadcn-ui.chakra-select,
  .shadcn-ui.chakra-input.field-size-xs,
  .shadcn-ui.chakra-select.field-size-xs,
  .shadcn-ui.chakra-input.field-size-sm,
  .shadcn-ui.chakra-select.field-size-sm,
  .shadcn-ui.chakra-input.field-size-lg,
  .shadcn-ui.chakra-select.field-size-lg {
    height: 2.75rem !important;
    min-height: 2.75rem !important;
    font-size: 16px !important;
    line-height: 1.35 !important;
  }

  .shadcn-ui.chakra-input[type="color"] {
    min-width: 2.75rem !important;
    padding: 0.375rem !important;
  }

  .shadcn-ui.chakra-input[type="range"] {
    height: 2.75rem !important;
    min-height: 2.75rem !important;
  }

  .shadcn-ui.chakra-input[type="range"]::-webkit-slider-thumb {
    width: 1.25rem !important;
    height: 1.25rem !important;
    margin-top: calc((0.375rem - 1.25rem) / 2) !important;
  }

  .shadcn-ui.chakra-input[type="range"]::-moz-range-thumb {
    width: 1.25rem !important;
    height: 1.25rem !important;
  }

  .shadcn-ui.chakra-textarea {
    min-height: 5.5rem !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
  }

  .shadcn-ui.chakra-switch,
  .shadcn-ui.chakra-checkbox {
    min-height: 2.75rem !important;
    align-items: center !important;
    touch-action: manipulation;
  }
}

/* Card styles - Cursor-inspired flat shadows */
.shadcn-ui.card {
  background-color: var(--card) !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--ui-shadow-card) !important;
  overflow: hidden !important;
  transition: box-shadow var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function) !important;
}

.shadcn-ui.card:hover {
  border-color: var(--ui-border-strong) !important;
  box-shadow: var(--ui-shadow-card) !important;
}

.shadcn-ui.card-header {
  padding: var(--spacing-3) !important;
  border-bottom: 1px solid var(--border) !important;
}

.shadcn-ui.card-footer {
  padding: var(--spacing-3) !important;
  border-top: 1px solid var(--border) !important;
}

.shadcn-ui.card-body {
  padding: var(--spacing-3) !important;
}

/* Table styles */
.shadcn-ui.chakra-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

.shadcn-ui.chakra-table thead tr th {
  background-color: var(--muted) !important;
  color: var(--muted-foreground) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: var(--font-weight-medium) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  padding: var(--spacing-2) !important;
  text-align: left !important;
  height: 2rem !important;
}

.shadcn-ui.chakra-table tbody tr {
  border-bottom: 1px solid var(--border) !important;
}

.shadcn-ui.chakra-table tbody tr:last-child {
  border-bottom: none !important;
}

.shadcn-ui.chakra-table tbody tr td {
  padding: var(--spacing-2) !important;
  font-size: var(--font-size-sm) !important;
}

/* Dialog/Modal styles - Cursor-inspired blur overlay */
.shadcn-ui.chakra-modal__content {
  background-color: var(--background) !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--ui-shadow-floating) !important;
}

.shadcn-ui.chakra-modal__header {
  padding: var(--spacing-4) !important;
  border-bottom: 1px solid var(--border) !important;
  font-weight: var(--font-weight-semibold) !important;
}

.shadcn-ui.chakra-modal__body {
  padding: var(--spacing-4) !important;
}

.shadcn-ui.chakra-modal__footer {
  padding: var(--spacing-4) !important;
  border-top: 1px solid var(--border) !important;
}

/* ─── GLOBAL shadcn/UI OVERRIDES ─────────────────────────────────────
 * These rules apply shadcn appearance to ALL Chakra components globally,
 * without requiring the .shadcn-ui class. This makes every element in
 * the app default to shadcn styling.
 * ──────────────────────────────────────────────────────────────────── */

/* Skeleton pulse animation */
@keyframes shadcn-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* ─── Global Form Elements ─── */

/* All inputs */
.chakra-input,
.chakra-numberinput__field,
.chakra-pinput {
  height: 1.875rem !important;
  border-radius: calc(var(--radius) - 2px) !important;
  border-color: var(--input) !important;
  background-color: var(--background) !important;
  color: var(--foreground) !important;
  font-size: var(--font-size-sm) !important;
  transition: border-color var(--transition-duration) var(--transition-timing-function), box-shadow var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-input:hover,
.chakra-numberinput__field:hover {
  border-color: var(--ring) !important;
}

.chakra-input:focus,
.chakra-input[data-focus],
.chakra-numberinput__field:focus {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 1px var(--ring) !important;
  outline: none !important;
}

.chakra-input::placeholder,
.chakra-numberinput__field::placeholder,
.chakra-textarea::placeholder {
  color: var(--muted-foreground) !important;
}

/* Textarea */
.chakra-textarea {
  border-radius: calc(var(--radius) - 2px) !important;
  min-height: 52px !important;
  padding: 0.5rem 0.75rem !important;
  border-color: var(--input) !important;
  background-color: var(--background) !important;
  color: var(--foreground) !important;
  font-size: var(--font-size-sm) !important;
  transition: border-color var(--transition-duration) var(--transition-timing-function), box-shadow var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-textarea:hover {
  border-color: var(--ring) !important;
}

.chakra-textarea:focus,
.chakra-textarea[data-focus] {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 1px var(--ring) !important;
  outline: none !important;
}

/* Select */
.chakra-select {
  height: 1.875rem !important;
  border-radius: calc(var(--radius) - 2px) !important;
  border-color: var(--input) !important;
  background-color: var(--background) !important;
  color: var(--foreground) !important;
  font-size: var(--font-size-sm) !important;
  transition: border-color var(--transition-duration) var(--transition-timing-function), box-shadow var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-select:hover {
  border-color: var(--ring) !important;
}

.chakra-select:focus,
.chakra-select[data-focus] {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 1px var(--ring) !important;
  outline: none !important;
}

/* Checkbox */
.chakra-checkbox__control {
  border-radius: var(--radius-sm) !important;
  border-color: var(--input) !important;
  transition: background-color var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-checkbox__control[data-checked],
.chakra-checkbox__control[data-checked]:hover {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--primary-foreground) !important;
}

.chakra-checkbox__label {
  font-size: var(--font-size-sm) !important;
}

/* Radio */
.chakra-radio__control {
  border-color: var(--input) !important;
  transition: background-color var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-radio__control[data-checked],
.chakra-radio__control[data-checked]:hover {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--primary-foreground) !important;
}

/* Switch */
.chakra-switch__track {
  background-color: var(--input) !important;
  transition: background-color var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-switch__track[data-checked] {
  background-color: var(--primary) !important;
}

.chakra-switch__thumb {
  background-color: var(--background) !important;
  box-shadow: var(--ui-shadow-card) !important;
}

/* ─── Global Button Enhancement ─── */

.chakra-button {
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-sm) !important;
  border-radius: calc(var(--radius) - 2px) !important;
  transition: background-color var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function), color var(--transition-duration) var(--transition-timing-function), box-shadow var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-button:active {
  transform: scale(0.97) !important;
}

.chakra-button:disabled,
.chakra-button[aria-disabled="true"] {
  opacity: 0.5 !important;
  pointer-events: none !important;
}

/* ─── Global Badge / Tag ─── */

.chakra-badge {
  border-radius: var(--radius-full) !important;
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-xs) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.chakra-tag {
  border-radius: var(--radius-md) !important;
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-xs) !important;
  transition: background-color var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function), color var(--transition-duration) var(--transition-timing-function) !important;
}

/* ─── Global Modal / Drawer ─── */

.chakra-modal__overlay {
  backdrop-filter: blur(4px) !important;
}

.chakra-modal__content {
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border) !important;
  background-color: var(--background) !important;
  box-shadow: var(--ui-shadow-floating) !important;
}

.chakra-modal__close-btn {
  border-radius: var(--radius-sm) !important;
  color: var(--muted-foreground) !important;
  transition: color var(--transition-duration) var(--transition-timing-function), background-color var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-modal__close-btn:hover {
  color: var(--foreground) !important;
  background-color: var(--muted) !important;
}

.chakra-modal__header {
  font-weight: var(--font-weight-semibold) !important;
  color: var(--foreground) !important;
}

/* ─── Global Divider ─── */

.chakra-divider {
  border-color: var(--border) !important;
  opacity: 1 !important;
}

/* ─── Global Heading & Text defaults ─── */

.chakra-heading {
  letter-spacing: 0 !important;
  font-weight: var(--font-weight-semibold) !important;
  color: var(--foreground) !important;
}


/* ─── Global Menu / Popover ─── */

.chakra-menu__menu-list {
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border) !important;
  background-color: var(--background) !important;
  box-shadow: var(--ui-shadow-card) !important;
  padding: var(--spacing-1) !important;
  overflow: hidden !important;
}

.chakra-menu__menuitem {
  font-size: var(--font-size-sm) !important;
  border-radius: var(--radius-sm) !important;
  padding: var(--spacing-2) var(--spacing-3) !important;
  transition: background-color var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-menu__menuitem:hover,
.chakra-menu__menuitem[data-focus] {
  background-color: var(--muted) !important;
}

.chakra-popover__content {
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border) !important;
  background-color: var(--background) !important;
  box-shadow: var(--ui-shadow-card) !important;
}

/* ─── Global Tooltip ─── */

.chakra-tooltip {
  background-color: var(--foreground) !important;
  color: var(--background) !important;
  border-radius: calc(var(--radius) - 4px) !important;
  font-size: var(--font-size-xs) !important;
  font-weight: var(--font-weight-medium) !important;
  padding: 4px 10px !important;
  box-shadow: var(--ui-shadow-card) !important;
}

/* ─── Global Tabs ─── */

.chakra-tabs__tab {
  font-weight: var(--font-weight-medium) !important;
  font-size: var(--font-size-sm) !important;
  color: var(--muted-foreground) !important;
  transition: color var(--transition-duration) var(--transition-timing-function), border-color var(--transition-duration) var(--transition-timing-function) !important;
}

.chakra-tabs__tab[aria-selected="true"],
.chakra-tabs__tab[data-selected] {
  color: var(--foreground) !important;
  border-color: var(--foreground) !important;
}

.chakra-tabs__tab:hover {
  color: var(--foreground) !important;
}

.chakra-tabs__tablist {
  border-color: var(--border) !important;
}

/* ─── Global Alert ─── */

.chakra-alert {
  border-radius: var(--radius) !important;
  border-width: 1px !important;
  font-size: var(--font-size-sm) !important;
}

/* ─── Global Table ─── */

.chakra-table {
  font-size: var(--font-size-sm) !important;
}

.chakra-table thead th {
  font-size: var(--font-size-xs) !important;
  font-weight: var(--font-weight-medium) !important;
  color: var(--muted-foreground) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  background-color: var(--muted) !important;
  border-bottom: 1px solid var(--border) !important;
  height: 2rem !important;
  padding: var(--spacing-2) !important;
}

.chakra-table tbody tr {
  transition: background-color var(--transition-duration) var(--transition-timing-function) !important;
  border-bottom: 1px solid var(--border) !important;
}

.chakra-table tbody tr:last-child {
  border-bottom: none !important;
}

.chakra-table tbody tr:hover {
  background-color: var(--muted) !important;
}

.chakra-table tbody td {
  border-bottom: none !important;
  color: var(--foreground) !important;
  padding: var(--spacing-2) !important;
}

/* ─── Global Skeleton ─── */

.chakra-skeleton {
  border-radius: var(--radius-md) !important;
}

/* ─── Global Drawer ─── */

.chakra-modal__content-container .chakra-modal__content[class*="drawer"] {
  background-color: var(--background) !important;
}

/* ─── Link hover ─── */

a:not(.chakra-button):not(.chakra-link):not([class*="menu"]) {
  transition: color var(--transition-duration) var(--transition-timing-function) !important;
}

/* ─── Scrollbar styling (subtle, shadcn-like) ─── */

::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  background-clip: content-box;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--muted-foreground);
  border: 2px solid transparent;
  background-clip: content-box;
}

/* ─── Global Compact Spacing ─── */

/* Tighten form control groups */
.chakra-form-control {
  margin-bottom: 0.75rem !important;
}

.chakra-form__label {
  margin-bottom: 0.25rem !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-medium) !important;
}

.chakra-form__error-message {
  margin-top: 0.25rem !important;
  font-size: var(--font-size-xs) !important;
}

.chakra-form__helper-text {
  margin-top: 0.25rem !important;
  font-size: var(--font-size-xs) !important;
  color: var(--muted-foreground) !important;
}

/* Tighten alert padding */
.chakra-alert {
  border-radius: calc(var(--radius) - 2px) !important;
  padding: 0.625rem 0.75rem !important;
  font-size: var(--font-size-sm) !important;
}

/* Tighten accordion */
.chakra-accordion__button {
  padding: 0.625rem 0 !important;
  font-size: var(--font-size-sm) !important;
}

.chakra-accordion__panel {
  padding: 0 0 0.75rem 0 !important;
  font-size: var(--font-size-sm) !important;
}

/* Compact popover */
.chakra-popover__header {
  padding: 0.5rem 0.75rem !important;
  font-size: var(--font-size-sm) !important;
}

.chakra-popover__body {
  padding: 0.5rem 0.75rem !important;
}

.chakra-popover__footer {
  padding: 0.5rem 0.75rem !important;
}

/* ─── Focus-visible ring (shadcn standard) ─── */

*:focus-visible {
  outline: 2px solid var(--ring) !important;
  outline-offset: 2px !important;
}

.chakra-button:focus-visible,
.chakra-input:focus-visible,
.chakra-textarea:focus-visible,
.chakra-select:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 2px var(--background), 0 0 0 4px var(--ring) !important;
}

/* Import Inter font from Google Fonts (variable weight 100-900) */

/* Import shadcn/UI variables for consistent theming */

html, :host {
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
  line-height: 1.5;
  font-family: var(--default-font-family);
  font-feature-settings: var(--default-font-feature-settings, normal);
  font-variation-settings: var(--default-font-variation-settings, normal);
  -webkit-tap-highlight-color: transparent;
}

html, body {
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
}

:root {
--foreground-rgb: 0, 0, 0;
--background-start-rgb: 214, 219, 220;
--background-end-rgb: 255, 255, 255;
--announcement-bar-height: 0px;
}

@media (prefers-color-scheme: dark) {
:root {
  --foreground-rgb: 255, 255, 255;
  --background-start-rgb: 0, 0, 0;
  --background-end-rgb: 0, 0, 0;
}
}

:root {
--ui-page-background-solid: #f7f7f5;
--ui-page-background: #f7f7f5;
--ui-panel-gradient: linear-gradient(180deg, #fbfbfa 0%, #f8f8f6 100%);
--ui-surface-canvas: #f2f2ef;
--ui-surface-panel: #fbfbfa;
--ui-surface-elevated: #ffffff;
--ui-surface-muted: #efefec;
--ui-surface-inset: #e9e9e5;
--ui-surface-inverse: #18181b;
--ui-surface-inverse-hover: #27272a;
--ui-border: rgba(24, 24, 27, 0.09);
--ui-border-strong: rgba(24, 24, 27, 0.18);
--ui-border-contrast: rgba(255, 255, 255, 0.72);
--ui-text-primary: #18181b;
--ui-text-primary-rgb: 24, 24, 27;
--ui-text-secondary: #4f4f55;
--ui-text-tertiary: #747474;
--ui-text-inverse: #fafafa;
--ui-focus-ring: rgba(24, 24, 27, 0.08);
--ui-focus-ring-strong: rgba(24, 24, 27, 0.22);
--ui-shadow-card: 0 1px 0 rgba(24, 24, 27, 0.025);
--ui-shadow-floating: 0 10px 28px rgba(24, 24, 27, 0.08);
--ui-shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.58);
--ui-selection-bg: rgba(24, 24, 27, 0.12);
--ui-selection-fg: #18181b;
--ui-accent: var(--ui-surface-inverse);
--ui-accent-hover: var(--ui-surface-inverse-hover);
--ui-accent-text: var(--ui-text-inverse);
--ui-accent-muted: color-mix(in srgb, var(--ui-accent) 8%, transparent);
--ui-accent-soft: color-mix(in srgb, var(--ui-accent) 12%, transparent);
--ui-accent-border: color-mix(in srgb, var(--ui-accent) 18%, transparent);
--ui-accent-ring: color-mix(in srgb, var(--ui-accent) 22%, transparent);

--ui-status-neutral-surface: var(--ui-surface-muted);
--ui-status-neutral-border: var(--ui-border);
--ui-status-neutral-text: var(--ui-text-secondary);
--ui-status-neutral-solid: var(--ui-text-primary);
--ui-status-neutral-solid-text: var(--ui-text-inverse);

--ui-status-info-surface: #f1f3f5;
--ui-status-info-border: #e2e6ea;
--ui-status-info-text: #4c5965;
--ui-status-info-solid: #5f6b76;
--ui-status-info-solid-text: var(--ui-text-inverse);

--ui-status-success-surface: #f1f4f2;
--ui-status-success-border: #e1e8e3;
--ui-status-success-text: #4c6253;
--ui-status-success-solid: #607267;
--ui-status-success-solid-text: var(--ui-text-inverse);

--ui-status-warning-surface: #f7f5ef;
--ui-status-warning-border: #e8e1d0;
--ui-status-warning-text: #6f603f;
--ui-status-warning-solid: #7a6d4d;
--ui-status-warning-solid-text: var(--ui-text-inverse);

--ui-status-error-surface: #f7f2f2;
--ui-status-error-border: #e8dede;
--ui-status-error-text: #734d4d;
--ui-status-error-solid: #7f5b5b;
--ui-status-error-solid-text: var(--ui-text-inverse);

--ui-chart-primary: color-mix(in srgb, var(--color-primary, #2563eb) 42%, #2563eb);
--ui-chart-secondary: color-mix(in srgb, var(--color-secondary, #0f766e) 42%, #0f766e);
--ui-chart-tertiary: color-mix(in srgb, var(--color-tertiary, #b45309) 38%, #b45309);
--ui-chart-quaternary: color-mix(in srgb, var(--ui-chart-primary) 52%, var(--ui-chart-tertiary));
--ui-chart-activity-soft: color-mix(in srgb, var(--ui-chart-primary) 10%, transparent);
--ui-chart-activity-strong: var(--ui-chart-primary);
--ui-chart-outcome: var(--ui-chart-secondary);
--ui-chart-positive: var(--ui-chart-tertiary);
--ui-chart-grid: color-mix(in srgb, var(--ui-chart-primary) 12%, transparent);
--ui-chart-traffic-audience: var(--ui-chart-primary);
--ui-chart-traffic-visits: var(--ui-chart-secondary);
--ui-chart-traffic-page-views: var(--ui-chart-tertiary);
--ui-chart-traffic-depth: var(--ui-chart-quaternary);
--ui-chart-traffic-grid: color-mix(in srgb, var(--ui-chart-primary) 14%, transparent);

--ui-studio-accent: #14b8a6;
--ui-studio-accent-hover: #0f9488;
--ui-studio-accent-text: #042f2e;
--ui-studio-coral: #ff6b4a;
--ui-studio-amber: #f2b84b;
--ui-studio-rail: #111827;
--ui-studio-rail-muted: rgba(226, 232, 240, 0.68);
--ui-studio-workspace: #eef2f5;
--ui-studio-mat: #dfe7ec;
--ui-studio-panel: #ffffff;
--ui-studio-panel-soft: #f7faf9;
--ui-studio-panel-border: rgba(17, 24, 39, 0.1);
--ui-studio-grid: rgba(20, 184, 166, 0.16);
--ui-studio-shadow-panel: 0 16px 38px rgba(17, 24, 39, 0.08);
--ui-studio-shadow-canvas: 0 26px 60px rgba(17, 24, 39, 0.22);
}

html.dark {
--ui-page-background-solid: #080808;
--ui-page-background: #080808;
--ui-panel-gradient: linear-gradient(180deg, #101010 0%, #0d0d0d 100%);
--ui-surface-canvas: #0b0b0b;
--ui-surface-panel: #101010;
--ui-surface-elevated: #171717;
--ui-surface-muted: #181818;
--ui-surface-inset: #141414;
--ui-surface-inverse: #fafaf9;
--ui-surface-inverse-hover: #e7e5e4;
--ui-border: rgba(255, 255, 255, 0.085);
--ui-border-strong: rgba(255, 255, 255, 0.16);
--ui-border-contrast: rgba(24, 24, 27, 0.12);
--ui-text-primary: #fafaf9;
--ui-text-primary-rgb: 250, 250, 249;
--ui-text-secondary: #d7d7d7;
--ui-text-tertiary: #9f9f9f;
--ui-text-inverse: #18181b;
--ui-focus-ring: rgba(255, 255, 255, 0.1);
--ui-focus-ring-strong: rgba(255, 255, 255, 0.25);
--ui-shadow-card: 0 1px 0 rgba(255, 255, 255, 0.03);
--ui-shadow-floating: 0 16px 36px rgba(0, 0, 0, 0.28);
--ui-shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.04);
--ui-selection-bg: rgba(255, 255, 255, 0.18);
--ui-selection-fg: #fafaf9;
--ui-accent: var(--ui-surface-inverse);
--ui-accent-hover: var(--ui-surface-inverse-hover);
--ui-accent-text: var(--ui-text-inverse);
--ui-accent-muted: color-mix(in srgb, var(--ui-accent) 14%, transparent);
--ui-accent-soft: color-mix(in srgb, var(--ui-accent) 18%, transparent);
--ui-accent-border: color-mix(in srgb, var(--ui-accent) 24%, transparent);
--ui-accent-ring: color-mix(in srgb, var(--ui-accent) 28%, transparent);

--ui-status-neutral-surface: var(--ui-surface-muted);
--ui-status-neutral-border: var(--ui-border);
--ui-status-neutral-text: var(--ui-text-secondary);
--ui-status-neutral-solid: var(--ui-text-primary);
--ui-status-neutral-solid-text: var(--ui-text-inverse);

--ui-status-info-surface: #12171b;
--ui-status-info-border: #202a32;
--ui-status-info-text: #aab6bf;
--ui-status-info-solid: #b8c2ca;
--ui-status-info-solid-text: var(--ui-text-inverse);

--ui-status-success-surface: #121812;
--ui-status-success-border: #223025;
--ui-status-success-text: #afc0b2;
--ui-status-success-solid: #c1cec4;
--ui-status-success-solid-text: var(--ui-text-inverse);

--ui-status-warning-surface: #1b1811;
--ui-status-warning-border: #302a1c;
--ui-status-warning-text: #d0c09f;
--ui-status-warning-solid: #dacdb2;
--ui-status-warning-solid-text: var(--ui-text-inverse);

--ui-status-error-surface: #1f1515;
--ui-status-error-border: #332323;
--ui-status-error-text: #d5bcbc;
--ui-status-error-solid: #decaca;
--ui-status-error-solid-text: var(--ui-text-inverse);

--ui-studio-accent: #2dd4bf;
--ui-studio-accent-hover: #5eead4;
--ui-studio-accent-text: #052e2b;
--ui-studio-coral: #fb8268;
--ui-studio-amber: #facc6b;
--ui-studio-rail: #050816;
--ui-studio-rail-muted: rgba(226, 232, 240, 0.66);
--ui-studio-workspace: #0f1218;
--ui-studio-mat: #171b22;
--ui-studio-panel: #12161d;
--ui-studio-panel-soft: #171c24;
--ui-studio-panel-border: rgba(255, 255, 255, 0.1);
--ui-studio-grid: rgba(45, 212, 191, 0.16);
--ui-studio-shadow-panel: 0 18px 40px rgba(0, 0, 0, 0.38);
--ui-studio-shadow-canvas: 0 30px 68px rgba(0, 0, 0, 0.56);

--ui-chart-primary: color-mix(in srgb, var(--color-primary, #93c5fd) 28%, #93c5fd);
--ui-chart-secondary: color-mix(in srgb, var(--color-secondary, #5eead4) 24%, #5eead4);
--ui-chart-tertiary: color-mix(in srgb, var(--color-tertiary, #fbbf24) 30%, #fbbf24);
--ui-chart-quaternary: color-mix(in srgb, var(--ui-chart-primary) 52%, var(--ui-chart-tertiary));
--ui-chart-activity-soft: color-mix(in srgb, var(--ui-chart-primary) 16%, transparent);
--ui-chart-activity-strong: var(--ui-chart-primary);
--ui-chart-outcome: var(--ui-chart-secondary);
--ui-chart-positive: var(--ui-chart-tertiary);
--ui-chart-grid: color-mix(in srgb, var(--ui-chart-primary) 18%, transparent);
--ui-chart-traffic-audience: var(--ui-chart-primary);
--ui-chart-traffic-visits: var(--ui-chart-secondary);
--ui-chart-traffic-page-views: var(--ui-chart-tertiary);
--ui-chart-traffic-depth: var(--ui-chart-quaternary);
--ui-chart-traffic-grid: color-mix(in srgb, var(--ui-chart-primary) 20%, transparent);
}

body {
color: var(--ui-text-primary);
background: var(--ui-page-background);
min-height: 100vh;
transition: background-color 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}

#root {
min-height: 100vh;
isolation: isolate;
}

a {
color: var(--link-color);
transition: color var(--transition-duration, 0.12s) var(--transition-timing-function, ease);
}

a:hover {
color: var(--link-color-hover);
}

button,
input,
textarea,
select {
transition: background-color var(--transition-duration, 0.12s) var(--transition-timing-function, ease), border-color var(--transition-duration, 0.12s) var(--transition-timing-function, ease), box-shadow var(--transition-duration, 0.12s) var(--transition-timing-function, ease), color var(--transition-duration, 0.12s) var(--transition-timing-function, ease);
}

::selection {
background: var(--ui-selection-bg);
color: var(--ui-selection-fg);
}

:root {
--black: #000;
--white: #fff;

--font-sans: "Inter", "Segoe UI Variable", "SF Pro Text", -apple-system, BlinkMacSystemFont, sans-serif;
--font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
--font-mono: "IBM Plex Mono", "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
--default-font-family: var(--font-sans);
--default-mono-font-family: var(--font-mono);
--default-font-feature-settings: normal;
--default-font-variation-settings: normal;

--hover-brightness: 1.2;

/* Brand color tokens */
--brand-500: var(--ui-accent);
--brand-600: var(--ui-accent-hover);

/* Link colors - shadcn/UI compatible */
--link-color: var(--ui-text-primary);
--link-color-hover: var(--ui-text-secondary);

/* Rose Colors */
--rose-50: var(--gray-50);
--rose-100: var(--gray-100);
--rose-200: var(--gray-200);
--rose-300: var(--gray-300);
--rose-400: var(--gray-400);
--rose-500: var(--gray-500);
--rose-600: var(--gray-600);
--rose-700: var(--gray-700);
--rose-800: var(--gray-800);
--rose-900: var(--gray-900);

/* Pink Colors */
--pink-50: #fdf2f8;
--pink-100: #fce7f3;
--pink-200: #fbcfe8;
--pink-300: #f9a8d4;
--pink-400: #f472b6;
--pink-500: #ec4899;
--pink-600: #db2777;
--pink-700: #be185d;
--pink-800: #9d174d;
--pink-900: #831843;

/* Fuchsia Colors */
--fuchsia-50: #fdf4ff;
--fuchsia-100: #fae8ff;
--fuchsia-200: #f5d0fe;
--fuchsia-300: #f0abfc;
--fuchsia-400: #e879f9;
--fuchsia-500: #d946ef;
--fuchsia-600: #c026d3;
--fuchsia-700: #a21caf;
--fuchsia-800: #86198f;
--fuchsia-900: #701a75;

/* Purple Colors */
--purple-50: #faf5ff;
--purple-100: #f3e8ff;
--purple-200: #e9d5ff;
--purple-300: #d8b4fe;
--purple-400: #c07eff;
--purple-500: #a855f7;
--purple-600: #9333ea;
--purple-700: #7e22ce;
--purple-800: #6b21a8;
--purple-900: #581c87;

/* Violet Colors */
--violet-50: #f5f3ff;
--violet-100: #ede9fe;
--violet-200: #ddd6fe;
--violet-300: #c4b5fd;
--violet-400: #a78bfa;
--violet-500: #8b5cf6;
--violet-600: #7c3aed;
--violet-700: #6d28d9;
--violet-800: #5b21b6;
--violet-900: #4c1d95;

/* Indigo Colors */
--indigo-50: #eef2ff;
--indigo-100: #e0e7ff;
--indigo-200: #c7d2fe;
--indigo-300: #a5b4fc;
--indigo-400: #818cf8;
--indigo-500: #6366f1;
--indigo-600: #4f46e5;
--indigo-700: #4338ca;
--indigo-800: #3730a3;
--indigo-900: #312e81;

/* Blue Colors - Muted steel blue for professional UI */
--blue-50: #f3f6fa;
--blue-100: #e1e8f0;
--blue-200: #c5d2e0;
--blue-300: #a3b4c8;
--blue-400: #8198af;
--blue-500: var(--gray-500);
--blue-600: #4c667d;
--blue-700: #3a5065;
--blue-800: #2b3d4e;
--blue-900: #1d2d3b;

/* Light Blue / Sky Colors - Muted steel-blue derived */
--light-blue-50: #f4f7fb;
--light-blue-100: #e3ecf4;
--light-blue-200: #c8d8e8;
--light-blue-300: #a6c0d6;
--light-blue-400: #83a7c2;
--light-blue-500: #6690ae;
--light-blue-600: #527a97;
--light-blue-700: #3f6280;
--light-blue-800: #2f4c64;
--light-blue-900: #21384a;

/* Cyan Colors */
--cyan-50: #ecfeff;
--cyan-100: #cffafe;
--cyan-200: #a5f3fc;
--cyan-300: #67e8f9;
--cyan-400: #22d3ee;
--cyan-500: #06b6d4;
--cyan-600: #0891b2;
--cyan-700: #0e7490;
--cyan-800: #155e75;
--cyan-900: #164e63;

/* Teal Colors */
--teal-50: #f0fdfa;
--teal-100: #ccfbf1;
--teal-200: #99f6e4;
--teal-300: #5eead4;
--teal-400: #2dd4bf;
--teal-500: #14b8a6;
--teal-600: #0d9488;
--teal-700: #0f766e;
--teal-800: #115e59;
--teal-900: #134e4a;

/* Emerald Colors */
--emerald-50: #ecfdf5;
--emerald-100: #d1fae5;
--emerald-200: #a7f3d0;
--emerald-300: #6ee7b7;
--emerald-400: #34d399;
--emerald-500: #10b981;
--emerald-600: #059669;
--emerald-700: #047857;
--emerald-800: #065f46;
--emerald-900: #064e3b;

/* Green Colors - Muted sage green for professional UI */
--green-50: #f4f7f2;
--green-100: #e4ebdf;
--green-200: #cdd8c5;
--green-300: #b5c5ab;
--green-400: var(--gray-400);
--green-500: #7a9a68;
--green-600: #5f7d50;
--green-700: #47613c;
--green-800: #344a2d;
--green-900: #243620;

/* Lime Colors */
--lime-50: #f7fee7;
--lime-100: #ecfccb;
--lime-200: #d9f99d;
--lime-300: #bef264;
--lime-400: #a3e635;
--lime-500: #84cc16;
--lime-600: #65a30d;
--lime-700: #4d7c0f;
--lime-800: #3f6212;
--lime-900: #365314;

/* Yellow Colors */
--yellow-50: #fefce8;
--yellow-100: #fef9c3;
--yellow-200: #fef08a;
--yellow-300: #fde047;
--yellow-400: #facc15;
--yellow-500: #eab308;
--yellow-600: #ca8a04;
--yellow-700: #a16207;
--yellow-800: #854d0e;
--yellow-900: #713f12;

/* Amber Colors */
--amber-50: #fffbeb;
--amber-100: #fef3c7;
--amber-200: #fde68a;
--amber-300: #fcd34d;
--amber-400: #fbbf24;
--amber-500: #f59e0b;
--amber-600: #d97706;
--amber-700: #b45309;
--amber-800: #92400e;
--amber-900: #78350f;

/* Orange Colors */
--orange-50: #fff7ed;
--orange-100: #ffedd5;
--orange-200: #fed7aa;
--orange-300: #fdba74;
--orange-400: #fb923c;
--orange-500: #f97316;
--orange-600: #ea580c;
--orange-700: #c2410c;
--orange-800: #9a3412;
--orange-900: #7c2d12;

/* Red Colors - Nord aurora aligned */
--red-50: var(--gray-50);
--red-100: var(--gray-100);
--red-200: var(--gray-200);
--red-300: var(--gray-300);
--red-400: var(--gray-400);
--red-500: var(--gray-500);
--red-600: var(--gray-600);
--red-700: var(--gray-700);
--red-800: var(--gray-800);
--red-900: var(--gray-900);

/* Warm Gray Colors */
--warm-gray-50: #fafaf9;
--warm-gray-100: #f5f5f4;
--warm-gray-200: #e7e5e4;
--warm-gray-300: #d6d3d1;
--warm-gray-400: #a8a29e;
--warm-gray-500: #78716c;
--warm-gray-600: #57534e;
--warm-gray-700: #44403c;
--warm-gray-800: #292524;
--warm-gray-900: #1c1917;

/* True Gray Colors */
--true-gray-50: #fafafa;
--true-gray-100: #f5f5f5;
--true-gray-200: #e5e5e5;
--true-gray-300: #d4d4d4;
--true-gray-400: #a3a3a3;
--true-gray-500: #737373;
--true-gray-600: #525252;
--true-gray-700: #404040;
--true-gray-800: #262626;
--true-gray-900: #171717;

/* Gray Colors - Pure neutral (Cursor-style, no blue tint) */
--gray-50: #fafafa;
--gray-100: #f5f5f5;
--gray-200: #e5e5e5;
--gray-300: #d4d4d4;
--gray-400: #a3a3a3;
--gray-500: #737373;
--gray-600: #525252;
--gray-700: #404040;
--gray-800: #262626;
--gray-900: #171717;

/* Cool Gray Colors */
--cool-gray-50: #f9fafb;
--cool-gray-100: #f3f4f6;
--cool-gray-200: #e5e7eb;
--cool-gray-300: #d1d5db;
--cool-gray-400: #9ca3af;
--cool-gray-500: #6b7280;
--cool-gray-600: #4b5563;
--cool-gray-700: #374151;
--cool-gray-800: #1f2937;
--cool-gray-900: #111827;

--blue-gray-50: #f8fafc;
--blue-gray-100: #f1f5f9;
--blue-gray-200: #e2e8f0;
--blue-gray-300: #cbd5e1;
--blue-gray-400: #94a3b8;
--blue-gray-500: #64748b;
--blue-gray-600: #475569;
--blue-gray-700: #334155;
--blue-gray-800: #1e293b;
--blue-gray-900: #0f172a;

/* Chromatic palette aliases: keep existing token names, resolve to grayscale. */
--rose-50: var(--gray-50);
--rose-100: var(--gray-100);
--rose-200: var(--gray-200);
--rose-300: var(--gray-300);
--rose-400: var(--gray-400);
--rose-500: var(--gray-500);
--rose-600: var(--gray-600);
--rose-700: var(--gray-700);
--rose-800: var(--gray-800);
--rose-900: var(--gray-900);
--pink-50: var(--gray-50);
--pink-100: var(--gray-100);
--pink-200: var(--gray-200);
--pink-300: var(--gray-300);
--pink-400: var(--gray-400);
--pink-500: var(--gray-500);
--pink-600: var(--gray-600);
--pink-700: var(--gray-700);
--pink-800: var(--gray-800);
--pink-900: var(--gray-900);
--fuchsia-50: var(--gray-50);
--fuchsia-100: var(--gray-100);
--fuchsia-200: var(--gray-200);
--fuchsia-300: var(--gray-300);
--fuchsia-400: var(--gray-400);
--fuchsia-500: var(--gray-500);
--fuchsia-600: var(--gray-600);
--fuchsia-700: var(--gray-700);
--fuchsia-800: var(--gray-800);
--fuchsia-900: var(--gray-900);
--purple-50: var(--gray-50);
--purple-100: var(--gray-100);
--purple-200: var(--gray-200);
--purple-300: var(--gray-300);
--purple-400: var(--gray-400);
--purple-500: var(--gray-500);
--purple-600: var(--gray-600);
--purple-700: var(--gray-700);
--purple-800: var(--gray-800);
--purple-900: var(--gray-900);
--violet-50: var(--gray-50);
--violet-100: var(--gray-100);
--violet-200: var(--gray-200);
--violet-300: var(--gray-300);
--violet-400: var(--gray-400);
--violet-500: var(--gray-500);
--violet-600: var(--gray-600);
--violet-700: var(--gray-700);
--violet-800: var(--gray-800);
--violet-900: var(--gray-900);
--indigo-50: var(--gray-50);
--indigo-100: var(--gray-100);
--indigo-200: var(--gray-200);
--indigo-300: var(--gray-300);
--indigo-400: var(--gray-400);
--indigo-500: var(--gray-500);
--indigo-600: var(--gray-600);
--indigo-700: var(--gray-700);
--indigo-800: var(--gray-800);
--indigo-900: var(--gray-900);
--blue-50: var(--gray-50);
--blue-100: var(--gray-100);
--blue-200: var(--gray-200);
--blue-300: var(--gray-300);
--blue-400: var(--gray-400);
--blue-500: var(--gray-500);
--blue-600: var(--gray-600);
--blue-700: var(--gray-700);
--blue-800: var(--gray-800);
--blue-900: var(--gray-900);
--light-blue-50: var(--gray-50);
--light-blue-100: var(--gray-100);
--light-blue-200: var(--gray-200);
--light-blue-300: var(--gray-300);
--light-blue-400: var(--gray-400);
--light-blue-500: var(--gray-500);
--light-blue-600: var(--gray-600);
--light-blue-700: var(--gray-700);
--light-blue-800: var(--gray-800);
--light-blue-900: var(--gray-900);
--cyan-50: var(--gray-50);
--cyan-100: var(--gray-100);
--cyan-200: var(--gray-200);
--cyan-300: var(--gray-300);
--cyan-400: var(--gray-400);
--cyan-500: var(--gray-500);
--cyan-600: var(--gray-600);
--cyan-700: var(--gray-700);
--cyan-800: var(--gray-800);
--cyan-900: var(--gray-900);
--teal-50: var(--gray-50);
--teal-100: var(--gray-100);
--teal-200: var(--gray-200);
--teal-300: var(--gray-300);
--teal-400: var(--gray-400);
--teal-500: var(--gray-500);
--teal-600: var(--gray-600);
--teal-700: var(--gray-700);
--teal-800: var(--gray-800);
--teal-900: var(--gray-900);
--emerald-50: var(--gray-50);
--emerald-100: var(--gray-100);
--emerald-200: var(--gray-200);
--emerald-300: var(--gray-300);
--emerald-400: var(--gray-400);
--emerald-500: var(--gray-500);
--emerald-600: var(--gray-600);
--emerald-700: var(--gray-700);
--emerald-800: var(--gray-800);
--emerald-900: var(--gray-900);
--green-50: var(--gray-50);
--green-100: var(--gray-100);
--green-200: var(--gray-200);
--green-300: var(--gray-300);
--green-400: var(--gray-400);
--green-500: var(--gray-500);
--green-600: var(--gray-600);
--green-700: var(--gray-700);
--green-800: var(--gray-800);
--green-900: var(--gray-900);
--lime-50: var(--gray-50);
--lime-100: var(--gray-100);
--lime-200: var(--gray-200);
--lime-300: var(--gray-300);
--lime-400: var(--gray-400);
--lime-500: var(--gray-500);
--lime-600: var(--gray-600);
--lime-700: var(--gray-700);
--lime-800: var(--gray-800);
--lime-900: var(--gray-900);
--yellow-50: var(--gray-50);
--yellow-100: var(--gray-100);
--yellow-200: var(--gray-200);
--yellow-300: var(--gray-300);
--yellow-400: var(--gray-400);
--yellow-500: var(--gray-500);
--yellow-600: var(--gray-600);
--yellow-700: var(--gray-700);
--yellow-800: var(--gray-800);
--yellow-900: var(--gray-900);
--amber-50: var(--gray-50);
--amber-100: var(--gray-100);
--amber-200: var(--gray-200);
--amber-300: var(--gray-300);
--amber-400: var(--gray-400);
--amber-500: var(--gray-500);
--amber-600: var(--gray-600);
--amber-700: var(--gray-700);
--amber-800: var(--gray-800);
--amber-900: var(--gray-900);
--orange-50: var(--gray-50);
--orange-100: var(--gray-100);
--orange-200: var(--gray-200);
--orange-300: var(--gray-300);
--orange-400: var(--gray-400);
--orange-500: var(--gray-500);
--orange-600: var(--gray-600);
--orange-700: var(--gray-700);
--orange-800: var(--gray-800);
--orange-900: var(--gray-900);
--red-50: var(--gray-50);
--red-100: var(--gray-100);
--red-200: var(--gray-200);
--red-300: var(--gray-300);
--red-400: var(--gray-400);
--red-500: var(--gray-500);
--red-600: var(--gray-600);
--red-700: var(--gray-700);
--red-800: var(--gray-800);
--red-900: var(--gray-900);
}

:root {
--zindex-20: 20;
--zindex-10: 10;
--zindex-9: 9;
--zindex-8: 8;
--zindex-7: 7;
--zindex-6: 6;
--zindex-5: 5;
--zindex-4: 4;
--zindex-3: 3;
--zindex-2: 2;
--zindex-1: 1;
--zindex-0: 0;
--opacity-100: 1;
--opacity-95: 0.95;
--opacity-90: 0.9;
--opacity-85: 0.85;
--opacity-80: 0.8;
--opacity-75: 0.75;
--opacity-70: 0.7;
--opacity-65: 0.65;
--opacity-60: 0.6;
--opacity-55: 0.55;
--opacity-50: 0.5;
--opacity-45: 0.45;
--opacity-40: 0.4;
--opacity-35: 0.35;
--opacity-30: 0.3;
--opacity-25: 0.25;
--opacity-20: 0.2;
--opacity-15: 0.15;
--opacity-10: 0.1;
--opacity-5: 0.05;
--gutters-xxxl: 128px;
--gutters-xxl: 112px;
--gutters-xl: 48px;
--gutters-lg: 32px;
--gutters-md: 16px;
--gutters-sm: 4px;
--gutters-xs: 0px;
--font-family-default-secondary: "Bower",Georgia,"Times New Roman",serif;
--font-family-default-primary: "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif !important;
--font-weight-bold: 700;
--font-weight-medium: 500;
--font-weight-regular: 400;
--font-weight-light: 300;
--elevation-16: 0px 16px 32px -1px rgba(5,28,44,.2),0px 0px 1px 0px rgba(5,28,44,.15);
--elevation-8: 0px 8px 16px -1px rgba(5,28,44,.2),0px 0px 1px 0px rgba(5,28,44,.15);
--elevation-4: 0px 4px 8px -1px rgba(5,28,44,.2),0px 0px 1px 0px rgba(5,28,44,.15);
--elevation-2: 0px 2px 4px -1px rgba(5,28,44,.2),0px 0px 1px 0px rgba(5,28,44,.2);
--elevation-light-16: 0px 16px 16px -1px rgba(117, 117, 117, 0.15);
--elevation-light-8: 0px 8px 8px -1px rgba(117, 117, 117, 0.12);
--elevation-light-4: 0px 4px 4px -1px rgba(117, 117, 117, 0.10);
--elevation-light-2: 0px 2px 2px -1px rgba(117, 117, 117, 0.08);
--elevation-dark-16: 0px 16px 16px -1px rgba(0, 0, 0, 0.25);
--elevation-dark-8: 0px 8px 8px -1px rgba(0, 0, 0, 0.20);
--elevation-dark-4: 0px 4px 4px -1px rgba(0, 0, 0, 0.15);
--elevation-dark-2: 0px 2px 2px -1px rgba(0, 0, 0, 0.10);
--color-status-dark-neutral: var(--gray-900);
--color-status-light-neutral: var(--gray-100);
--color-status-dark-blue: var(--gray-700);
--color-status-light-blue: var(--gray-100);
--color-status-dark-yellow: var(--gray-700);
--color-status-yellow: var(--gray-500);
--color-status-light-yellow: var(--gray-100);
--color-status-dark-red: var(--gray-700);
--color-status-red: var(--gray-500);
--color-status-light-red: var(--gray-100);
--color-status-dark-green: var(--gray-700);
--color-status-green: var(--gray-500);
--color-status-light-green: var(--gray-100);
--color-neutral-black: #000;
--color-neutral-dark-neutral: #1b1b19;
--color-neutral-gray-80: #404040;
--color-neutral-gray-70: #525252;
--color-neutral-gray-60: #737373;
--color-neutral-gray-54: #737373;
--color-neutral-gray-30: #a3a3a3;
--color-neutral-gray-18: #d4d4d4;
--color-neutral-gray-10: #e5e5e5;
--color-neutral-gray-06: #f5f5f5;
--color-neutral-gray-04: #f5f5f5;
--color-neutral-gray-03: #fafafa;
--color-neutral-gray-02: #fafafa;
--color-neutral-hover-gray: #f5f5f5;
--color-neutral-active-gray: #e5e5e5;
--color-neutral-white: #fff;
--color-functional-orange: var(--gray-500);
--color-functional-red: var(--gray-500);
--color-functional-pink: var(--gray-500);
--color-functional-purple: var(--gray-500);
--color-functional-turquoise: var(--gray-500);
--color-functional-pale-blue: var(--gray-200);
--color-functional-blue-transition-4: var(--gray-300);
--color-functional-blue-transition-3: var(--gray-400);
--color-functional-blue-transition-2: var(--gray-600);
--color-functional-blue-transition-1: var(--gray-800);
--color-palette-cyan: var(--gray-500);
--color-palette-deep-blue: #171717;
--color-palette-electric-blue: #171717;
--color-electric-blue-200: #e5e5e5;
--color-electric-blue-900: #171717;
--breakpoint-xxxl: 1920px;
--breakpoint-xxl: 1440px;
--breakpoint-xl: 1180px;
--breakpoint-lg: 768px;
--breakpoint-md: 480px;
--breakpoint-sm: 375px;
--breakpoint-xs: 320px;
--size-page-wrapper-1312: 82rem;
--size-page-wrapper-1216: 76rem;
--size-page-wrapper-928: 58rem;
--size-page-wrapper-768: 48rem;
--size-spacing-base-unit: 0.5rem;
--size-spacing-80: 5rem;
--size-spacing-72: 4.5rem;
--size-spacing-64: 4rem;
--size-spacing-56: 3.5rem;
--size-spacing-48: 3rem;
--size-spacing-40: 2.5rem;
--size-spacing-32: 2rem;
--size-spacing-24: 1.5rem;
--size-spacing-16: 1rem;
--size-spacing-8: 0.5rem;
--size-spacing-4: 0.25rem;
--size-line-height-136: 8.5rem;
--size-line-height-96: 6rem;
--size-line-height-92: 5.75rem;
--size-line-height-76: 4.75rem;
--size-line-height-64: 4rem;
--size-line-height-52: 3.25rem;
--size-line-height-44: 2.75rem;
--size-line-height-40: 2.5rem;
--size-line-height-36: 2.25rem;
--size-line-height-32: 2rem;
--size-line-height-28: 1.75rem;
--size-line-height-24: 1.5rem;
--size-line-height-20: 1.25rem;
--size-line-height-16: 1rem;
--size-icon-200: 12.5rem;
--size-icon-128: 8rem;
--size-icon-96: 6rem;
--size-icon-64: 4rem;
--size-icon-48: 3rem;
--size-icon-40: 2.5rem;
--size-icon-32: 2rem;
--size-icon-24: 1.5rem;
--size-icon-16: 1rem;
--size-icon-12: 0.75rem;
--size-icon-10: 0.625rem;
--size-font-120: 7.5rem;
--size-font-92: 5.75rem;
--size-font-76: 4.75rem;
--size-font-64: 4rem;
--size-font-52: 3.25rem;
--size-font-44: 2.75rem;
--size-font-36: 2.25rem;
--size-font-28: 1.75rem;
--size-font-26: 1.625rem;
--size-font-24: 1.5rem;
--size-font-20: 1.25rem;
--size-font-18: 1.125rem;
--size-font-16: 1rem;
--size-font-14: 0.875rem;
--size-font-12: 0.75rem;
--size-font-10: 0.625rem;
--size-border-width-4: 0.25rem;
--size-border-width-3: 0.1875rem;
--size-border-width-2: 0.125rem;
--size-border-width-1: 0.0625rem;
--size-border-radius-20: 1.25rem;
--size-border-radius-10: 0.625rem;
--size-border-radius-8: 0.5rem;
--size-border-radius-4: 0.25rem;
--size-border-radius-2: 0.125rem;
--typography-color-body: var(--color-neutral-gray-80);
--typography-color-heading: var(--color-neutral-black);
--color-status-neutral: var(--color-neutral-gray-80);
--color-status-blue: var(--color-palette-electric-blue);
--color-functional-pale-electric-blue: var(--color-palette-electric-blue);
--color-tertiary: var(--color-palette-cyan);
--color-secondary: var(--color-palette-deep-blue);
--color-primary: var(--color-palette-electric-blue);
}

:root {
--button-primary-background: var(--color-palette-electric-blue);
--button-primary-text: var(--color-neutral-white);
--button-primary-background-hover: var(--color-neutral-white);
--button-primary-text-hover: var(--color-palette-electric-blue);
--button-primary-border-hover: var(--color-palette-electric-blue);
--button-secondary-text: var(--color-status-dark-blue);
--button-secondary-border: var(--color-palette-electric-blue);
--button-secondary-border-hover: var(--color-palette-electric-blue);
--button-secondary-background: transparent;
--button-secondary-background-hover: var(--color-palette-electric-blue);
--button-secondary-text-hover: var(--color-neutral-white);
--button-tertiary-background-hover: var(--color-palette-electric-blue);
--button-tertiary-text: var(--color-neutral-black);
--button-tertiary-text-hover: var(--color-neutral-white);
--button-tertiary-border: var(--color-neutral-black);
--button-tertiary-border-hover: var(--color-palette-electric-blue);
--button-minimal-primary: var(--color-palette-electric-blue);
--button-minimal-secondary: var(--color-neutral-black);
--button-minimal-tertiary: var(--color-neutral-black);
--button-minimal-tertiary-hover: var(--color-palette-electric-blue);
--inline-link-text: var(--color-neutral-gray-80);
--inline-link-border: var(--color-palette-electric-blue);
--inline-link-text-hover: var(--color-neutral-white);
--inline-link-border-hover: transparent;
--inlike-link-background-hover: var(--color-palette-electric-blue);
--hero-text: var(--color-neutral-black);
--text-shadow: none;
--heading-link-default-border-color: var(--color-palette-electric-blue);
--heading-link-default-hover-color: var(--color-palette-electric-blue);
--root-share-icon-color: var(--color-neutral-black);
--root-share-icon-color-hover: var(--color-palette-electric-blue);
--text-color-default: var(--color-neutral-black);
--loader-border-top: var(--color-palette-deep-blue);
--loader-border: var(--color-neutral-gray-06);
--link-color-icon-default: var(--color-palette-electric-blue);
--link-color-icon-default-hover: var(--color-primary);
--link-color-default: var(--color-palette-electric-blue);
--link-color-default-hover: var(--color-palette-electric-blue);
--link-color-secondary-default: var(--color-neutral-gray-80);
--link-color-secondary-default-hover: var(--color-neutral-gray-80);
--link-inline-default-color: var(--color-neutral-gray-80);
--link-inline-default-hover-color: var(--color-neutral-white);
--link-inline-default-border-color: var(--color-primary);
--link-inline-default-border-hover-color: var(--color-primary);
--link-inline-default-background-hover-color: var(--color-primary);
--link-inline-secondary-hover-color: var(--color-neutral-white);
--link-inline-secondary-background-hover-color: var(--color-neutral-gray-80);
--link-color-text-default: var(--color-neutral-black);
--link-color-text-default-hover: var(--color-primary);
--link-cta-icon-color: var(--color-palette-electric-blue);
--link-icon-color: var(--color-neutral-gray-80);
--link-icon-hover-color: var(--color-palette-electric-blue);
--link-icon-radial-hover-color: var(--color-neutral-white);
--link-heading-color: var(--color-neutral-black);
--link-heading-hover-color: var(--color-palette-electric-blue);
}

html.dark {
/* background */
--bg-emphasis: #2b2b2b;
--bg: #101010;
--bg-subtle: #2b2b2b;
--bg-muted: #1c1c1c;
--bg-inverted: #f5f5f5;

/* background -> components*/
--bg-info: #1e2d3b;
--bg-success: #2a3d27;
--bg-attention: #3d2e22;
--bg-error: #3d2226;
--bg-dark-error: #331c20;

/* Borders */
--border-emphasis: #575757;
--border: #d8dee4;
--border-subtle: #2b2b2b;
--border-booker: #2b2b2b;
--border-muted: #1c1c1c;
--border-error: #aa2e26;

/* Content/Text */
--base: #fff;
--text-emphasis: color-mix(in oklab, var(--base) 94%, transparent);
--text: color-mix(in oklab, var(--base) 70%, transparent);
--text-subtle: color-mix(in oklab, var(--base) 58%, transparent);
--text-muted: color-mix(in oklab, var(--base) 48%, transparent);
--text-inverted: #101010;

/* Content/Text -> components */
--text-info: #dee9fc;
--text-success: #e2fbe8;
--text-attention: #fceed8;
--text-error: #f9e3e2;

/* Brand shenanigans
    -> These will be computed for the users theme at runtime.
    */
--brand: #292929;
--brand-emphasis: #696969;
--brand-text: black;

/* Typography — critical for dark mode text visibility */
--typography-color-body: var(--text);
--typography-color-heading: var(--text-emphasis);
--text-color-default: var(--text-emphasis);
--hero-text: var(--text-emphasis);

/* Neutral palette inversion */
--color-neutral-black: var(--text-emphasis);
--color-neutral-white: var(--bg);
--color-neutral-gray-80: var(--text);
--color-neutral-gray-70: var(--text-subtle);
--color-neutral-gray-60: var(--text-muted);
--color-neutral-gray-30: #525252;
--color-neutral-gray-18: #404040;
--color-neutral-gray-10: #2b2b2b;
--color-neutral-gray-06: #1c1c1c;
--color-neutral-gray-04: #1c1c1c;
--color-neutral-gray-03: #171717;
--color-neutral-gray-02: #171717;
--color-neutral-hover-gray: #2b2b2b;
--color-neutral-active-gray: #404040;

/* Center channel */
--center-channel-bg: var(--bg);
--center-channel-color: var(--text);
--center-channel-text: var(--text);
--sys-center-channel-bg: var(--bg);
--sys-center-channel-color: var(--text);
--center-channel-color-rgb: 212, 212, 212;
--sys-center-channel-color-rgb-new: 212, 212, 212;

/* Misc backgrounds */
--white: var(--bg);
--mention-bg: var(--bg-subtle);
--mention-color: var(--text);
--background--50: var(--bg);
--background--100: #2b2b2b;
--background--200: #171717;
--background--300: #1c1c1c;
--off-white: #171717;
--bg-card: #1c1c1c;
--bg-cream: #171717;

/* Buttons */
--button-color: var(--bg);
--button-background: rgba(255,255,255,.08);
--button-primary-background: var(--text-emphasis);
--button-primary-text: var(--bg);
--button-primary-background-hover: var(--text);
--button-primary-text-hover: var(--bg);
--button-primary-border-hover: var(--text);
--button-secondary-text: var(--text);
--button-secondary-border: var(--border-emphasis);
--button-secondary-background: transparent;
--button-secondary-text-hover: var(--bg);
--button-tertiary-text: var(--text-emphasis);
--button-tertiary-text-hover: var(--bg);
--button-tertiary-border: var(--text-emphasis);
--button-minimal-primary: var(--text-emphasis);
--button-minimal-secondary: var(--text-emphasis);
--button-minimal-tertiary: var(--text-emphasis);
--btn-bg-color: var(--text-emphasis);
--btn-text-color: var(--bg);
--btn-border-color: var(--text-emphasis);
--btn-bg-color-hover: var(--text);
--btn-text-color-hover: var(--bg);
--btn-border-color-hover: var(--text);

/* Links */
--link-color-text-default: var(--text-emphasis);
--link-color-text-default-hover: var(--text);
--link-color-secondary-default: var(--text-subtle);
--link-heading-color: var(--text-emphasis);
--inline-link-text: var(--text);
--link-icon-color: var(--text-subtle);

/* Status & loader */
--loader-border-top: var(--text-emphasis);
--loader-border: #2b2b2b;

/* Shadows */
--shadow-small: 0 2px 5px 0 rgba(0,0,0,.3), 0 1px 1px 0 rgba(0,0,0,.4);
--shadow-medium: 0 7px 14px 0 rgba(0,0,0,.3), 0 3px 6px 0 rgba(0,0,0,.4);
--shadow-large: 0 15px 35px 0 rgba(0,0,0,.3), 0 5px 15px 0 rgba(0,0,0,.4);

/* Misc tokens */
--primary--50: #171717;
--primary--100: #1c1c1c;
--primary--200: #262626;
--primary--300: #404040;
--primary--400: #737373;
--primary--500: #a3a3a3;
--neutrals--100: #404040;
--neutrals--200: #525252;
--neutrals--300: #737373;
--neutrals--400: #a3a3a3;
--neutrals--500: #a3a3a3;
--neutrals--600: #d4d4d4;
--neutrals--700: #e5e5e5;
--neutrals--800: #f5f5f5;
--neutrals--900: #fafafa;

/* Chakra color scale inversions (fallback layer — shadcn-variables.css has !important) */
--chakra-colors-white: #0a0a0a;
--chakra-colors-black: #fafafa;

--chakra-colors-blackAlpha-50: rgba(255, 255, 255, 0.04);
--chakra-colors-blackAlpha-100: rgba(255, 255, 255, 0.06);
--chakra-colors-blackAlpha-200: rgba(255, 255, 255, 0.08);
--chakra-colors-blackAlpha-300: rgba(255, 255, 255, 0.16);
--chakra-colors-blackAlpha-400: rgba(255, 255, 255, 0.24);
--chakra-colors-blackAlpha-500: rgba(255, 255, 255, 0.36);
--chakra-colors-blackAlpha-600: rgba(255, 255, 255, 0.48);
--chakra-colors-blackAlpha-700: rgba(255, 255, 255, 0.64);
--chakra-colors-blackAlpha-800: rgba(255, 255, 255, 0.80);
--chakra-colors-blackAlpha-900: rgba(255, 255, 255, 0.92);

--chakra-colors-whiteAlpha-50: rgba(0, 0, 0, 0.04);
--chakra-colors-whiteAlpha-100: rgba(0, 0, 0, 0.06);
--chakra-colors-whiteAlpha-200: rgba(0, 0, 0, 0.08);
--chakra-colors-whiteAlpha-300: rgba(0, 0, 0, 0.16);
--chakra-colors-whiteAlpha-400: rgba(0, 0, 0, 0.24);
--chakra-colors-whiteAlpha-500: rgba(0, 0, 0, 0.36);
--chakra-colors-whiteAlpha-600: rgba(0, 0, 0, 0.48);
--chakra-colors-whiteAlpha-700: rgba(0, 0, 0, 0.64);
--chakra-colors-whiteAlpha-800: rgba(0, 0, 0, 0.80);
--chakra-colors-whiteAlpha-900: rgba(0, 0, 0, 0.92);

--chakra-colors-gray-50: #18181b;
--chakra-colors-gray-100: #1c1c1f;
--chakra-colors-gray-200: #27272a;
--chakra-colors-gray-300: #3f3f46;
--chakra-colors-gray-400: #52525b;
--chakra-colors-gray-500: #71717a;
--chakra-colors-gray-600: #a1a1aa;
--chakra-colors-gray-700: #d4d4d8;
--chakra-colors-gray-800: #e4e4e7;
--chakra-colors-gray-900: #fafafa;

--chakra-colors-blue-50: #1d2d3b;
--chakra-colors-blue-100: #2b3d4e;
--chakra-colors-blue-200: #3a5065;
--chakra-colors-blue-300: #4c667d;
--chakra-colors-blue-400: var(--gray-500);
--chakra-colors-blue-500: #8198af;
--chakra-colors-blue-600: #a3b4c8;
--chakra-colors-blue-700: #c5d2e0;
--chakra-colors-blue-800: #e1e8f0;
--chakra-colors-blue-900: #f3f6fa;

}

/*
@font-face {
font-family: "Inter var";
font-weight: 100 900;
font-display: swap;
font-style: normal;
font-named-instance: "Regular";
src: url("/fonts/Inter-roman.var.woff2") format("woff2");
}*/

:root {
/* colors */
--primary: #171717;
--secondary: #f5f5f5;
--tertiary: var(--gray-500);
--quaternary: var(--gray-500);

--green: var(--gray-500);
--coral: var(--gray-500);
--gold: var(--gray-500);

--secondary-darker: var(--gray-600);
--primary-darker: var(--brand-emphasis);
--chakra-colors-blue-500: var(--blue-500);

/* classification colors */
--light-green: var(--gray-100);
--light-red: var(--gray-100);

--color-normal: #166434;
--color-murmur: #8e2534;
--color-pending: #52525b;
--color-noise: #262626;

/* buttons */
--btn-bg-color: var(--primary);
--btn-bg-color-hover: #565564;
--btn-text-color: var(--white);
--btn-text-color-hover: var(--white);
--btn-border-color: #0d0c22;
--btn-border-color-hover: #565564;

/* background */
--bg-emphasis: #e5e7eb;
--bg: white;
--bg-subtle: #fafafc;
--bg-muted: #f9fafb;
--bg-inverted: #111827;
--bg-cream: #f7f5f2;
--bg-card: #f6f9fc;

/* background -> components*/
--bg-info: #dee9fc;
--bg-success: #e2fbe8;
--bg-attention: #fceed8;
--bg-error: #f9e3e2;
--bg-dark-error: #752522;

/* Borders */
--border-emphasis: #9ca3af;
--border: #d8dee4;
--border-subtle: #e5e7eb;
--border-booker: #e5e7eb;
--border-muted: #f3f4f6;
--border-error: #aa2e26;

/* Content/Text */
--text-emphasis: #111827;
--text: #414552;
--text-subtle: #6b7280;
--text-muted: #9ca3af;
--text-inverted: white;

/* Content/Text -> components */
--text-info: #253985;
--text-success: #285231;
--text-attention: #73321b;
--text-error: #752522;
--red: var(--text-error);

/* Brand shinanigans
  */
--brand: #171717;
--brand-emphasis: hsla(0, 0%, 6%, 1);
--brand-text: hsla(0, 0%, 100%, 1);

--shadow-small:  0 2px  5px  0 rgba( 60, 66,87 , .08 ), 0 1px 1px  0 rgba( 0,0,0 , .12 );
--shadow-medium: 0 7px  14px 0 rgba( 60,66,87 , .08 ),  0 3px 6px  0 rgba( 0,0,0 , .12 );
--shadow-large:  0 15px 35px 0 rgba( 60,66,87 , .08 ),  0 5px 15px 0 rgba( 0,0,0 , .12 );

--mention-bg: #ffffff;
--mention-color: #3a5065;
--sidebar-text: #ffffff;
--sidebar-text-rgb: 255, 255, 255;
--sidebar-header-text-color: #ffffff;
--sidebar-bg: #262626;
--sys-sidebar-bg: #262626;
--sys-sidebar-bg-rgb: 38, 38, 38;
--sidebar-text-active-border: var(--ui-border-strong);
--away-indicator-rgb: 113, 113, 122;
--center-channel-color-rgb: 64, 64, 64;
--sys-error-text: var(--ui-status-error-solid);
--sys-sidebar-text-active-border: var(--ui-border-strong);
--sys-center-channel-color: var(--text);
--sys-center-channel-bg: var(--bg);
--sys-center-channel-color-rgb: #d4d4d4;
--sys-center-channel-color-rgb-new: 64, 64, 64;
--sys-online-indicator: var(--ui-status-success-solid);
--center-channel-bg: var(--bg);
--center-channel-text: var(--text);
--center-channel-color: var(--text);
--button-color: var(--bg);
--away-indicator-dark: var(--ui-status-warning-solid);
--online-indicator: var(--ui-status-success-solid);
--sys-button-bg: var(--primary);
--away-indicator: var(--ui-status-warning-solid);
--sys-error-text-color-rgb: var(--ui-text-primary-rgb);
--error-text: var(--ui-status-error-solid);


--black: #000;
--background--50: var(--bg);
--off-white: #fefdf9;
--pastel-red: var(--ui-status-error-surface);
--pastel-blue: var(--ui-status-info-surface);
--pastel-yellow: var(--ui-status-warning-surface);
--pastel-orange: var(--ui-status-warning-surface);
--gray-2: #737373;
--background--300: #f5f5f5;
--purple: var(--gray-500);
--blue: var(--gray-500);
--gray: rgba(0,0,0,.5);
--neutrals--100: #e5e5e5;
--neutrals--300: #a3a3a3;
--primary--50: #fafafa;
--primary--400: #737373;
--border-radius--m: 0.5rem;
--neutrals--900: #171717;
--primary--200: #e5e5e5;
--900: #171717;
--background--100: #e5e5e5;
--border-radius--l: 0.75rem;
--error: var(--ui-status-error-solid);
--neutrals--600: #525252;
--primary--300: #d4d4d4;
--primary--500: #404040;
--button-background: rgba(255,255,255,.15);
--background--200: #fafafa;
--neutrals--400: #a3a3a3;
--neutrals--200: #d4d4d4;
--neutrals--500: #737373;
--border-radius--s: 0.25rem;
--neutrals--800: #262626;
--neutrals--700: #404040;
--primary--100: #f5f5f5;
}

body {
margin: 0;
padding: 0;
line-height: 1.2;
font-family: var(--font-family-default-primary);
text-rendering: optimizeLegibility;
font-smoothing: antialiased;
-moz-font-smoothing: antialiased;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
-moz-font-feature-settings: "liga" on;
margin: 0 auto;
overflow-x: hidden;
color: var(--typography-color-body);
background: var(--bg);
}

::-moz-selection {
color: var(--brand-text);
background: var(--brand);
}

::selection {
color: var(--brand-text);
background: var(--brand);
}

body  {
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
}

html {
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
font-size: 100%;
}

html, body {
height: 100%;
}

[type="text"]:focus,
[type="email"]:focus,
[type="url"]:focus,
[type="password"]:focus,
[type="number"]:focus,
[type="date"]:focus,
[type="datetime-local"]:focus,
[type="month"]:focus,
[type="search"]:focus,
[type="tel"]:focus,
[type="checkbox"]:focus,
[type="radio"]:focus,
[type="time"]:focus,
[type="week"]:focus,
[multiple]:focus,
textarea:focus,
select:focus {
--tw-ring-color: var(--primary);
border-color: var(--primary);
}

canvas {
display: unset !important;
}

h1.xxlarge {
  font-weight: 400;
  font-size: 80px;
  line-height: 1.1em;
}

a {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

.ordered-list li:before {
  content: counter(item);
  display: flex;
  min-height: 48px;
  min-width: 48px;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  --tw-border-opacity: 1;
  border: 1px solid rgb(41 54 83/var(--tw-border-opacity));
  font-size: 1.875rem;
  line-height: 2.25rem;
  font-weight: 700;
}

.ordered-list li:not(:last-child) {
  margin-bottom: 1.5rem;
}

.items-center {
  align-items: center;
}

.flex {
  display: flex;
}

:after, :before {
--tw-content: "";
}

*, :after, :before {
box-sizing: border-box;
border: 0 solid;
}

.overflow-x-hidden {
overflow-x: hidden;
}

.justify-center {
justify-content: center;
}

.items-center {
align-items: center;
}

.flex-col {
flex-direction: column;
}

.w-full {
width: 100%;
}

.relative {
position: relative;
}

.bg-gradient-green {
background: linear-gradient(0deg,#051c37 0%,#0b2c54 100%);
color: var(--white);
}

.white-wave-not-inverted {
top: -135px;
}

@media (min-width: 1024px) {
.section-wave {
    left: 0 !important;
}
}

@media (min-width: 640px) {
.section-wave {
    left: -336px;
}
}

@media (min-width: 640px) {
.sm\:pt-36 {
  padding-top: 9rem !important
}
}

.gap-4 {
gap: 1rem;
}


.section-wave {
left: -532px;
line-height: 0;
min-width: 1440px;
overflow: hidden;
position: absolute;
width: 100%;
}

.section-wave svg {
position: relative;
display: block;
height: 192px;
width: 100%;
}

@media (min-width: 640px) {
.sm\:max-w-none {
  max-width: none;
}
}

@media (min-width: 640px) {
.sm\:pb-20 {
  padding-bottom: 5rem;
}
}

@media (min-width: 1280px) {
.container {
  max-width: 1000px;
}
}

.max-w-\[200px\] {
max-width: 200px;
}

.mx-auto {
margin-left: auto;
margin-right: auto;
}


audio, canvas, embed, iframe, img, object, svg, video {
display: block;
vertical-align: middle;
}


menu, ol, ul {
list-style: none;
margin: 0;
padding: 0;
}

.ordered-list li {
counter-increment: item;
}


.MuiAppBar-colorPrimary {
color: var(--black);
background-color: var(--white) !important;
}

.MuiPaper-elevation4 {
box-shadow: 0px 2px 4px -1px rgb(255 255 255 / 20%), 0px 4px 5px 0px rgb(217 217 217 / 14%), 0px 1px 10px 0px rgb(255 255 255 / 12%) !important;
}

.MuiSvgIcon-root {
fill: var(--text-emphasis) !important;
}

/* Keep Lucide icons stroke-only across the app. */
.lucide,
.lucide * {
fill: none !important;
}

.MuiTypography-colorInherit {
color: var(--text-emphasis) !important
}

.btn-primary, .btn-primary:active, .btn-primary.active, .open > .dropdown-toggle.btn-primary, .btn-primary:active:hover, .btn-primary.active:hover, .open > .dropdown-toggle.btn-primary:hover, .btn-primary:active:focus, .btn-primary.active:focus, .open > .dropdown-toggle.btn-primary:focus, .btn-primary:active.focus, .btn-primary.active.focus, .open > .dropdown-toggle.btn-primary.focus {
outline: none;
box-shadow: none;
}

.page-item.active .page-link {
z-index: 3;
color: var(--black);
background-color: var(--gray-200) !important;
border-color: var(--gray-300) !important;
}

.pagination > li > a, .pagination > li > span {
color: var(--black);
}

.bg-white {
background: var(--white);
}


.pt-4 {
padding-top: 40px;
}

.mt-4 {
margin-top:40px;
}

.mt-3 {
margin-top:30px;
}

.mt-2 {
margin-top:20px;
}

.mt-1 {
margin-top: 10px;
}

.mb-2 {
margin-bottom: 20px;
}

.mb-3 {
margin-bottom: 30px;
}

.mb-4 {
margin-bottom: 40px;
}

.ml-2 {
margin-left: 20px;
}

.mb-1 {
margin-bottom: 10px;
}

.inline {
display: inline-block;
}

.center, .align-center {
text-align: center;
}

.pb-4 {
padding-bottom: 40px;
}

.navbar-default .navbar-toggle {
  border-color: var(--white) !important;
}

.navbar-default .navbar-toggle .icon-bar {
  background-color: var(--white) !important;
}

.navbar-default .navbar-toggle:hover, .navbar-default .navbar-toggle:focus {
  background-color: var(--primary) !important;
}

.btn {
outline: none;
}

.btn.disabled, .btn[disabled], fieldset[disabled] .btn {
background: var(--bg-muted);
}

.btn-primary.disabled.focus, .btn-primary.disabled:focus, .btn-primary.disabled:hover, .btn-primary[disabled].focus, .btn-primary[disabled]:focus, .btn-primary[disabled]:hover, fieldset[disabled] .btn-primary.focus, fieldset[disabled] .btn-primary:focus, fieldset[disabled] .btn-primary:hover {
background-color: var(--bg-error);
border-color: var(--border-error)
}


.bi::before {
display: inline-block;
content: "";
background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='%23333' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M5 14l6-6-6-6'/></svg>");
background-repeat: no-repeat;
background-size: 1rem 1rem;
}

.grecaptcha-badge {
visibility: collapse !important;
}

.btn-shadow {
box-shadow: none;
}

/*Create ripple effec*/

.ripple {
position: relative;
overflow: hidden;
transform: translate3d(0, 0, 0);
}

.ripple:after {
content: "";
display: block;
position: absolute;
width: 100%;
height: 100%;
top: 0;
left: 0;
pointer-events: none;
background-image: radial-gradient(circle, #fff 10%, transparent 10.01%);
background-repeat: no-repeat;
background-position: 50%;
transform: scale(10, 10);
opacity: 0;
transition: transform .5s, opacity 1s;
}

.ripple:active:after {
transform: scale(0, 0);
opacity: .3;
transition: 0s;
}


/* background-color: var(--blue-gray-500); */
/*
MARK: Todo:
- primary color =  var(--cal-brand,#111827);
- text color: var(--cal-text,#374151);
- bold color: var(--cal-text-emphasis,#111827)
- grey background: var(--cal-bg-muted);
- grey background emphasis: var(--cal-bg-emphasis);
- grey hover bg: var(--cal-bg-muted);
- green success:  --cal-text-success: #285231;
- info bg: var(--cal-bg-info);


btn btn-primary
.admin-sidebar .sidebar-section-title--active, .admin-sidebar .sidebar-subsection-title--active 

*/

/* Admin sidebar active styles moved to containers/admin_sidebar.css */

.btn-secondary {
color: var(--black) !important;
background-color: var(--secondary) !important;
box-shadow: rgb(0, 0, 0) 0px 0px 0px;
font-weight: 600;
}

.btn-primary {
color: var(--white) !important;
background-color: var(--primary) !important;
}

.btn-primary:active, .btn-primary.active, .open > .dropdown-toggle.btn-primary,
.btn-primary:active:hover, .btn-primary.active:hover, .open > .dropdown-toggle.btn-primary:hover, .btn-primary:active:focus, .btn-primary.active:focus, .open > .dropdown-toggle.btn-primary:focus, .btn-primary:active.focus, .btn-primary.active.focus, .open > .dropdown-toggle.btn-primary.focus {
color: #fff;
background-color: var(--brand-emphasis);
outline: none;
box-shadow: none;
}

.btn-primary.is-active, .btn-primary:focus, .btn-primary:hover {
background: var(--brand-emphasis);
}

.btn-danger.btn-outline {
color: var(--border-error);
}

.btn-danger {
color: #fff;
background: var(--bg-danger);
border: 1px solid var(--border-error)
}

@keyframes spin {
from {
  transform: rotate(-90deg);
}

to {
  transform: rotate(270deg);
}
}

@keyframes heartbeat {
0% {
  transform: scale(1);
}
12% {
  transform: scale(1.1);
}
24% {
  transform: scale(1);
}
36% {
  transform: scale(1.1);
}
48% {
  transform: scale(1);
}
}

@keyframes pulse {
0% {
  transform: scale(.95);
}
50% {
  transform: scale(1);
}
100% {
  transform: scale(.95);
}
}

.walkthrough-backdrop {
top: 0;
right: 0;
left: 0;
bottom: 0;
position: fixed;
z-index: 1000;
background: transparent;
z-index: 99999999999;
}

.walkthrough-backdrop.show {
background: rgba(0, 0, 0, 0.5);
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
}

.walkthrough-backdrop * {
box-sizing: border-box; 
}

.walkthrough-modal {
margin-left: auto;
margin-right: auto;
position: relative;
text-align: center;
overflow-y: auto;
overflow-x: hidden;
border-radius: 12px;
box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
border: 1px solid rgba(255, 255, 255, 0.1);
z-index: 99999999999;
}

.walkthrough-content-box {
overflow-y: auto;
}

.walkthrough-modal .walkthrough-content-box {
float: left;
}

.walkthrough-modal .walkthrough-content-box img {
margin-top: 0px;
}

.walkthrough-modal .walkthrough-content {
width: 100%;
text-align: center;
overflow-y: auto;
}

.walkthrough-modal .walkthrough-container {
position: absolute;
top: 0;
left: 0;
}

.walkthrough-modal .walkthrough-footer {
height: 100px;
position: fixed;
padding: 0 35px;
width: -webkit-fill-available;
bottom: 0;
display: flex;
justify-content: space-between;
align-items: center;
background: transparent;
z-index: 999999999999999999999
}


@media (max-width: 768px) {
.walkthrough-modal .walkthrough-footer {
  padding: 0 15px; 
}
}

.walkthrough-modal .btn {
border: 0;
padding: 0;
box-shadow: none;
}

.walkthrough-modal .btn:active, .walkthrough-modal .btn:focus {
background: none;
outline: none;
}

.walkthrough-modal .btn-footer {
border: 0;
background: rgba(20, 23, 27, 0.52);
padding: 0;
box-shadow: none;
width: 95px;
height: 40px;
line-height: normal;
font-size: 18px;
border-radius: 50px;
cursor: pointer;
border: none;
color: #fff;
display: flex;
align-items: center;
justify-content: center;
-webkit-transition: all 0.3s linear;
-moz-transition: all 0.3s ease;
-ms-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all 0.3s ease;
}

.walkthrough-modal .btn-footer span {
vertical-align: top;
}

.walkthrough-modal .btn-footer:active, .walkthrough-modal .btn-footer:focus {
outline: none;
}

.walkthrough-modal .btn-back.first-page {
opacity: 0;
pointer-events: none;
}

.walkthrough-modal .walkthrough-page-indicator {
  text-align: center;
  opacity: 0;
}

.walkthrough-modal .walkthrough-page-indicator.show {
  opacity: 1; 
}

.walkthrough-modal .walkthrough-page-indicator > button {
  border: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
  width: 17px;
  height: 17px;
  cursor: pointer;
  display: inline;
}

.walkthrough-modal .walkthrough-page-indicator > button:active, .walkthrough-modal .walkthrough-page-indicator > button:focus {
  background: none;
  outline: none;
}

.walkthrough-modal .walkthrough-page-indicator > button .walkthrough-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  background: rgba(20, 23, 27, 0.52);
  border-radius: 3.5px; 
}

.walkthrough-modal .walkthrough-page-indicator > button .walkthrough-dot.selected {
  background: #000000;
}

.walkthrough {
  font-family: inherit;
  text-align: center;
  color: #4a4a4a;
}

.walkthrough-title {
  width: 100%;
  padding-top: 20px;
  padding-left: 20px;
  font-size: 36px;
  font-size: 20px;
  font-weight: 500;
  text-align: left;
}

.walkthrough-desc {
  font-size: 16px;
  padding: 0 20px;
  line-height: 1.6;
  text-align: left;
}

/* Button content centering fix */
.btn-content {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

/* Content Styling */
.walkthrough-title {
  color: #171717 !important;
  font-weight: 600 !important;
  font-size: 28px !important;
  letter-spacing: -0.025em !important;
}

.walkthrough-desc {
  color: #737373 !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
}

.button.is-outline {
  border: 1px solid var(--gray-900);
  color: var(--gray-900);
  background-color: transparent;
  padding-top: 0.9375rem;
  padding-bottom: 0.9375rem;
  transition: border-color .2s,color .2s,background-color .2s;
}

.button {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  background-color: var(--gray-900);
  color: #fff;
  border-radius: 99rem;
  align-items: center;
  padding: 1rem 1.625rem;
  font-weight: 500;
  transition: background-color .2s;
  display: flex;
}

.button-icon {
  width: 2.5rem;
  height: 2.5rem;
  margin-top: -0.5rem;
  margin-bottom: -0.5rem;
  margin-right: -1rem;
}

.button.is-outline-light {
  border: 1px solid rgba(255,255,255,.20);
  background-color: rgba(255,255,255,.20);
  color: #ffffff;
  padding-top: 0.9375rem;
  padding-bottom: 0.9375rem;
  transition: border-color .2s,color .2s,background-color .2s;
}


.announcement-bar {
 position: fixed;
 z-index: 999;
 top: 0;
 display: flex;
 overflow: hidden;
 width: 100%;
 min-height: 40px;
 max-height: 40px;
 align-items: center;
 justify-content: center;
 background-color: var(--text-muted);
 color: var(--bg);
 text-align: center;
}

.announcement-bar .announcement-bar__text {
 display: flex;
 overflow: hidden;
 width: 100%;
 align-items: center;
 justify-content: center;
 white-space: nowrap;
 position: relative;
}

.announcement-bar .announcement-bar__text--auto-slide {
 justify-content: flex-start;
 padding-right: 32px;
}

.announcement-bar .announcement-bar__auto-slide-icon {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 flex: 0 0 auto;
}

.announcement-bar .announcement-bar__marquee {
 overflow: hidden;
 flex: 1 1 auto;
 min-width: 0;
}

.announcement-bar .announcement-bar__marquee-track {
 display: -webkit-flex;
 display: flex;
 white-space: nowrap;
 -webkit-animation: announcement-bar-marquee 40s linear infinite;
 animation: announcement-bar-marquee 40s linear infinite;
 -webkit-backface-visibility: hidden;
 backface-visibility: hidden;
}

.announcement-bar .announcement-bar__marquee-segment {
 display: -webkit-flex;
 display: flex;
 -webkit-flex-shrink: 0;
 flex-shrink: 0;
 -webkit-align-items: center;
 align-items: center;
 min-width: 100%;
 -webkit-justify-content: center;
 justify-content: center;
 padding: 0 48px;
}

.announcement-bar .announcement-bar__marquee-item {
 white-space: nowrap;
 font-size: 14px;
 font-style: normal;
 font-weight: 600;
 line-height: 20px;
}

@-webkit-keyframes announcement-bar-marquee {
 from {
  -webkit-transform: translate3d(0, 0, 0);
 }
 to {
  -webkit-transform: translate3d(-50%, 0, 0);
 }
}

@keyframes announcement-bar-marquee {
 from {
  transform: translate3d(0, 0, 0);
 }
 to {
  transform: translate3d(-50%, 0, 0);
 }
}

.announcement-bar .announcement-bar__marquee-item a {
 color: inherit;
 text-decoration: underline;
 cursor: pointer;
}

.announcement-bar .announcement-bar__marquee-item a:hover {
 opacity: 0.8;
}

.announcement-bar .announcement-bar__text > p {
 overflow: hidden;
 margin: 0;
 text-overflow: ellipsis;
}

.announcement-bar .announcement-bar__text > span {
 font-size: 14px;
 font-style: normal;
 font-weight: 600;
 line-height: 20px;
}

@media (prefers-reduced-motion: reduce) {
 .announcement-bar .announcement-bar__marquee-track {
  -webkit-animation: none !important;
  animation: none !important;
 }
}

.announcement-bar .announcement-bar__text .annnouncementBar__purchaseNow, .announcement-bar .announcement-bar__text .annnouncementBar__renewLicense {
 margin-top: 0;
}

.announcement-bar .announcement-bar__text .annnouncementBar__renewLicense {
 border-color: var(--bg);
}

.announcement-bar a {
 color: inherit !important;
 text-decoration: underline;
}

.announcement-bar a:hover, .announcement-bar a:active, .announcement-bar a:focus {
 color: inherit !important;
}

.announcement-bar a.announcement-bar__close {
 position: absolute;
 top: 5px;
 right: 0;
 padding: 0 10px;
 color: #fff;
 font-size: 20px;
 font-weight: 600;
 text-decoration: none;
}

.announcement-bar a.announcement-bar__close:hover {
 color: #fff;
 text-decoration: none;
}

.announcement-bar .fa-wrapper {
 margin: 0 5px;
}

.announcement-bar .resend-verification-wrapper::before {
 content: "\00a0 ";
}

.announcement-bar .content__icon, .announcement-bar i {
 margin-right: 4px;
 color: #fff;
 font-family: 'compass-icons';
 font-size: 16px;
}

.announcement-bar button {
 height: 24px;
 box-sizing: border-box;
 padding: 4px 8px;
 border: 1px solid var(--bg);
 margin-left: 8px;
 background-color: inherit !important;
 border-radius: 4px;
 font-size: 12px;
 font-style: normal;
 font-weight: 600;
 line-height: 16px;
}

.announcement-bar button:hover {
 background-color: rgba(255, 255, 255, 0.08);
}

.announcement-bar-critical {
 background-color: var(--ui-status-error-solid);
}

.announcement-bar-success {
 background-color: var(--ui-status-success-solid);
}

.announcement-bar-advisor {
 background-color: var(--ui-status-info-solid);
}

.announcement-bar-advisor-ack {
 background-color: var(--ui-status-success-solid);
}

.announcement-bar-general {
 background-color: #3d3c40;
}

.announcement-bar__link {
 margin-left: 4px;
}

.advisor-icon {
 width: 16px;
 height: 16px;
 margin-right: 8px;
 margin-bottom: 2px;
 margin-left: 8px;
}

@media (max-width: 768px) {
 .announcement-bar {
  min-height: 44px;
  max-height: 44px;
 }

 .announcement-bar .announcement-bar__text {
  min-width: 0;
 }

 .announcement-bar .announcement-bar__text--auto-slide {
  padding-left: 6px;
  padding-right: 40px;
 }

 .announcement-bar .announcement-bar__marquee-item,
 .announcement-bar .announcement-bar__text > span {
  font-size: 12px;
  line-height: 18px;
 }

 .announcement-bar .announcement-bar__marquee-segment {
  padding: 0 28px;
 }

 .announcement-bar a.announcement-bar__close {
  top: 7px;
  right: 2px;
  padding: 0 8px;
  font-size: 18px;
 }

 .advisor-icon {
  width: 14px;
  height: 14px;
  margin-right: 6px;
  margin-left: 6px;
  margin-bottom: 1px;
 }

}

body.announcement-bar--fixed {
padding-top: 40px;
padding-top: var(--announcement-bar-height, 40px);
}

@media (max-width: 768px) {
 body.announcement-bar--fixed {
  padding-top: 44px;
  padding-top: var(--announcement-bar-height, 44px);
 }
}

body.announcement-bar--fixed .navbar-fixed-top {
 top: 40px;
 top: var(--announcement-bar-height, 40px);
}


/* Admin console styles moved to containers/admin_sidebar.css for lazy loading */

#root {
background: var(--background);
}

.no-hover-underline, .no-hover-underline:hover {
text-decoration: none;
}

.card {
padding: var(--chakra-space-3) !important;
}


/* Subtle links (for navigation, secondary actions) */
.link-subtle {
  color: var(--foreground);
  text-decoration: none;
}

.link-subtle:hover,
.link-subtle:focus {
  color: var(--brand-600) !important;
  text-decoration: underline !important;
}

/* Muted links (for footers, less important text) */
.link-muted {
  color: var(--muted-foreground);
  text-decoration: none;
}

.link-muted:hover,
.link-muted:focus {
  color: var(--foreground) !important;
  text-decoration: underline !important;
}

/* Brand links - explicit brand styling */
.link-brand {
  color: var(--brand-500);
  text-decoration: none;
}

.link-brand:hover,
.link-brand:focus {
  color: var(--brand-600) !important;
  text-decoration: underline !important;
}

