:root {
  --color-bg: #ffffff;
  --color-surface: #ffffff;
  --color-card: #fdfcf7;
  --color-surface-sunken: #f2eee5;
  --color-overlay: rgba(255, 255, 255, 0.92);

  --color-text: #2a2622;
  --color-text-muted: #6e665b;
  --color-text-faint: #a39a8b;

  --color-accent: #9f8a4e;
  --color-accent-deep: #7e6c3c;
  --color-accent-soft: #e9e1cc;
  --color-spicy: #c4452f;

  --color-line: #e6e0d4;
  --color-line-strong: #d8d0c0;

  --font-display: "Cormorant Garamond", "Times New Roman", serif;
  --font-body: "Jost", "Segoe UI", system-ui, sans-serif;

  --fs-overline: 0.78rem;
  --fs-sm: 0.9rem;
  --fs-base: 1.05rem;
  --fs-lg: 1.25rem;
  --fs-xl: clamp(1.5rem, 1.2rem + 1.2vw, 2rem);
  --fs-2xl: clamp(2.1rem, 1.6rem + 2.4vw, 3rem);
  --fs-3xl: clamp(2.6rem, 2rem + 4vw, 4rem);

  --lh-tight: 1.1;
  --lh-snug: 1.3;
  --lh-normal: 1.6;
  --ls-overline: 0.22em;
  --ls-wide: 0.04em;
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-8: 3rem;
  --space-10: 4rem;
  --space-12: 6rem;

  --shell-max: 480px;
  --shell-pad: clamp(1.1rem, 5vw, 1.75rem);
  --z-nav: 30;
  --z-search: 45;
  --z-sheet: 50;

  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 8px;
  --radius-xl: 14px;
  --radius-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(42, 38, 34, 0.04);
  --shadow-card: 0 4px 16px rgba(42, 38, 34, 0.05);
  --shadow-md: 0 8px 30px rgba(42, 38, 34, 0.08);
  --shadow-lg: 0 16px 40px rgba(42, 38, 34, 0.12);
  --shadow-pill: 0 6px 18px rgba(42, 38, 34, 0.10);

  --transition-fast: 160ms ease;
  --transition-base: 280ms cubic-bezier(0.4, 0, 0.2, 1);
}
