/* Hallmark · pre-emit critique: P5 H5 E5 S5 R5 V5
 * genre: atmospheric · macrostructure: Bento Grid · theme: Bloom
 * tokens · paper-band: dark · display-style: weighty-sans · accent-hue: warm-amber
 */

:root {
  color-scheme: dark;

  /* === Color: Bloom (atmospheric) ============================== */
  --color-paper:        oklch(13% 0.018 35);
  --color-paper-2:      oklch(17% 0.022 35);
  --color-paper-3:      oklch(22% 0.024 35);
  --color-paper-4:      oklch(27% 0.022 35);
  --color-ink:          oklch(95% 0.010 70);
  --color-ink-2:        oklch(76% 0.014 60);
  --color-ink-3:        oklch(56% 0.014 50);
  --color-ink-4:        oklch(42% 0.014 50);
  --color-rule:         oklch(28% 0.018 40);
  --color-rule-strong:  oklch(40% 0.025 40);
  --color-accent:       oklch(74% 0.180 55);
  --color-accent-2:     oklch(68% 0.200 18);
  --color-accent-soft:  oklch(74% 0.060 55);
  --color-accent-ink:   oklch(15% 0.040 50);
  --color-focus:        oklch(82% 0.180 55);
  --color-error:        oklch(70% 0.220 25);
  --color-success:      oklch(74% 0.160 145);
  --color-bloom-1:      oklch(74% 0.220 50);
  --color-bloom-2:      oklch(60% 0.220 15);

  /* === Typography ============================================== */
  --font-display: "Fraunces", "Georgia", "PingFang SC", "Hiragino Sans GB", sans-serif;
  --font-body:    "Inter Tight", -apple-system, "PingFang SC", "Hiragino Sans GB", sans-serif;
  --font-mono:    "JetBrains Mono", "PingFang SC", "Hiragino Sans GB", sans-serif, ui-monospace, monospace;

  --text-xs:      0.75rem;
  --text-sm:      0.875rem;
  --text-base:    1rem;
  --text-md:      1.0625rem;
  --text-lg:      1.25rem;
  --text-xl:      1.5rem;
  --text-2xl:     2rem;
  --text-3xl:     2.75rem;
  --text-4xl:     clamp(2.25rem, 4.5vw + 0.5rem, 4rem);
  --text-display: clamp(3.25rem, 10.5vw + 0.25rem, 8rem);
  --text-display-s: clamp(2.5rem, 6vw + 0.5rem, 5rem);

  --leading-display: 0.92;
  --leading-tight:   1.05;
  --leading-snug:    1.25;
  --leading-body:    1.55;
  --leading-loose:   1.7;

  /* === Spacing (4 pt) ========================================== */
  --space-3xs: 0.125rem;
  --space-2xs: 0.25rem;
  --space-xs:  0.5rem;
  --space-sm:  0.75rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2.5rem;
  --space-2xl: 4rem;
  --space-3xl: 6rem;
  --space-4xl: 9rem;
  --space-5xl: 12rem;

  /* === Motion ================================================== */
  --ease-out:    cubic-bezier(0.20, 0.80, 0.20, 1.00);
  --ease-in:     cubic-bezier(0.40, 0.00, 1.00, 1.00);
  --ease-in-out: cubic-bezier(0.40, 0.00, 0.20, 1.00);
  --dur-fast:    120ms;
  --dur-base:    220ms;
  --dur-slow:    400ms;

  /* === Rules / radii =========================================== */
  --rule-hair:   1px;
  --rule-bold:   2px;
  --radius-xs:   3px;
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-pill: 999px;

  /* === Layout ================================================== */
  --page-gutter: clamp(1rem, 4vw, 3rem);
  --max-width:   80rem;
  --measure:     60ch;
}
