@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

:root {
  /* === COLORS === */
  --color-bg:            #f8f8f6;
  --color-bg-alt:        #f1f0ec;
  --color-surface:       #ffffff;
  --color-primary:       #2348e0;
  --color-primary-light: #1c3cc0;
  --color-ink:           #0f0e0c;
  --color-muted:         #55504b;
  --color-border:        #e6e4df;
  --color-white:         #FFFFFF;

  /* === TYPOGRAPHY === */
  --font-display:  'Hanken Grotesk', system-ui, sans-serif;
  --font-body:     'Hanken Grotesk', system-ui, sans-serif;

  --text-xs:   clamp(0.75rem,  1vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 1.5vw, 1rem);
  --text-base: clamp(1rem,     1.5vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 2vw,   1.25rem);
  --text-xl:   clamp(1.25rem,  2.5vw, 1.5rem);
  --text-2xl:  clamp(1.5rem,   3vw,   2rem);
  --text-3xl:  clamp(2rem,     4vw,   2.75rem);
  --text-4xl:  clamp(2.5rem,   5vw,   3.5rem);
  --text-hero: clamp(3rem,     6vw,   5rem);

  --leading-tight:  1.2;
  --leading-snug:   1.4;
  --leading-normal: 1.6;
  --leading-loose:  1.8;

  /* === 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;
  --space-32: 8rem;

  --section-padding: clamp(5rem, 10vw, 8rem);
  --container-max:   1140px;
  --container-pad:   clamp(1rem, 5vw, 3rem);

  /* === BORDERS === */
  --radius-sm:   12px;
  --radius-md:   24px;
  --radius-lg:   32px;
  --radius-full: 9999px;

  /* === SHADOWS === */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(26,31,78,0.10);
  --shadow-lg: 0 8px 32px rgba(26,31,78,0.14);

  /* === Z-INDEX === */
  --z-base:     0;
  --z-dropdown: 100;
  --z-sticky:   200;
  --z-modal:    300;
  --z-toast:    400;

  /* === TRANSITIONS === */
  --transition-fast: 150ms ease-out;
  --transition-base: 250ms ease-out;
  --transition-slow: 400ms ease-out;
}
