:root {
  /* ─── Colors ─────────────────────────────────── */
  --color-bg:             #FFFFFF;
  --color-bg-alt:         #F8F8F8;
  --color-surface:        #FFFFFF;

  --color-text-primary:   #1A1A1A;
  --color-text-secondary: #555555;
  --color-text-muted:     #999999;
  --color-text-light:     #BBBBBB;

  --color-border:         #E0E0E0;
  --color-border-dark:    #CCCCCC;

  --color-accent:         #886F4A;

  --color-danger:         #C0392B;
  --color-success:        #27AE60;

  /* ─── Typography ─────────────────────────────── */
  --font-display: 'Pretendard', 'Apple SD Gothic Neo', sans-serif;
  --font-serif:   'Pretendard', 'Apple SD Gothic Neo', sans-serif;
  --font-sans:    'Pretendard', 'Apple SD Gothic Neo', 'Malgun Gothic', sans-serif;

  --text-xs:   0.8rem;
  --text-sm:   0.95rem;
  --text-base: 1.05rem;
  --text-md:   1.2rem;
  --text-lg:   1.45rem;
  --text-xl:   1.9rem;
  --text-2xl:  2.7rem;
  --text-hero: clamp(2.2rem, 5vw, 4.2rem);

  --leading-tight:  1.2;
  --leading-snug:   1.45;
  --leading-normal: 1.65;
  --leading-loose:  1.9;

  --tracking-tight:  -0.02em;
  --tracking-normal: 0;
  --tracking-wide:   0.06em;
  --tracking-wider:  0.12em;
  --tracking-ko:     0.04em;

  /* ─── 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 ─────────────────────────────────── */
  --max-width:   1440px;
  --gutter:      clamp(1rem, 2.5vw, 2rem);
  --header-height: 0px; /* not fixed */

  /* ─── Misc ───────────────────────────────────── */
  --radius-sm: 2px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.10);

  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast:    150ms;
  --dur-normal:  280ms;
  --dur-slow:    480ms;
}
