:root {
  /* ── Palette ── */
  --color-navy:          #1B3A6B;
  --color-navy-dark:     #132D54;
  --color-navy-deeper:   #0D1F3C;
  --color-gold:          #C49A38;
  --color-gold-light:    #D4AA4A;
  --color-gold-pale:     #F0E6CB;
  --color-white:         #FFFFFF;
  --color-off-white:     #F8F7F4;
  --color-light:         #F0EEE9;
  --color-border:        #E5E2DB;
  --color-text:          #1A1A1A;
  --color-text-body:     #3A3530;
  --color-text-light:    #6B6560;
  --color-sidebar-text:  rgba(255, 255, 255, 0.7);

  /* ── Typography ── */
  --font-display: 'Cormorant Garamond', 'Palatino Linotype', Georgia, serif;
  --font-body:    'Lora', Georgia, 'Times New Roman', serif;
  --font-label:   'Raleway', 'Trebuchet MS', sans-serif;

  /* ── Type scale ── */
  --text-2xs:  0.625rem;   /* 10px */
  --text-xs:   0.6875rem;  /* 11px */
  --text-sm:   0.8125rem;  /* 13px */
  --text-base: 0.9375rem;  /* 15px */
  --text-md:   1rem;       /* 16px */
  --text-lg:   1.125rem;   /* 18px */
  --text-xl:   1.375rem;   /* 22px */
  --text-2xl:  1.75rem;    /* 28px */
  --text-3xl:  2.25rem;    /* 36px */
  --text-4xl:  3rem;       /* 48px */

  /* ── Spacing ── */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* ── Layout ── */
  --sidebar-width:  158px;
  --content-max:    1060px;

  /* ── Motion ── */
  --ease-fast: 150ms ease;
  --ease-med:  300ms ease;
  --ease-slow: 500ms ease;

  /* ── Elevation ── */
  --shadow-card:       0 2px 16px rgba(0, 0, 0, 0.08);
  --shadow-card-hover: 0 10px 36px rgba(0, 0, 0, 0.14);
  --shadow-gold:       0 4px 24px rgba(196, 154, 56, 0.3);
}
