:root {
  /* Brand — maritime trust palette */
  --color-navy: #0a2540;
  --color-navy-light: #123a5c;
  --color-teal: #0d7c8c;
  --color-teal-light: #14a3b8;
  --color-gold: #c9a227;
  --color-gold-light: #e4bc4a;
  --color-white: #ffffff;
  --color-off-white: #f6f8fa;
  --color-gray-100: #eef2f6;
  --color-gray-300: #c5cdd6;
  --color-gray-500: #6b7c8f;
  --color-gray-700: #3d4f63;
  --color-success: #1a7f4b;
  --color-danger: #c0392b;
  --color-warning: #d68910;

  --font-sans: "DM Sans", system-ui, sans-serif;
  --font-display: "Libre Baskerville", Georgia, serif;

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 2rem;
  --text-4xl: 2.75rem;
  --text-hero: clamp(2rem, 5vw, 3.5rem);

  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --shadow-sm: 0 1px 3px rgba(10, 37, 64, 0.08);
  --shadow-md: 0 4px 20px rgba(10, 37, 64, 0.12);
  --shadow-lg: 0 12px 40px rgba(10, 37, 64, 0.15);

  --header-height: 72px;
  --container-max: 1200px;
  --transition: 0.2s ease;
}
