:root {
  color-scheme: light;
  --bg: #fff9fd;
  --bg-soft: #fff3fb;
  --surface: rgba(255, 255, 255, 0.84);
  --surface-strong: #ffffff;
  --text-main: #2c2742;
  --text-muted: #706987;
  --line: #ecdef1;
  --brand: #8f62f8;
  --brand-soft: #f4ebff;
  --accent: #f07db3;
  --accent-soft: #ffe8f4;
  --brand-gradient: linear-gradient(135deg, #8f62f8 0%, #f07db3 100%);
  --success: #38a57a;
  --radius-xs: 8px;
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --shadow-sm: 0 8px 22px rgba(112, 76, 164, 0.08);
  --shadow-md: 0 16px 38px rgba(112, 76, 164, 0.14);
  --shadow-lg: 0 26px 62px rgba(112, 76, 164, 0.2);
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --container: 1180px;
  --reading: 860px;
  --font-main: "PingFang SC", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;
  --font-serif: "Noto Serif SC", "Songti SC", "STSong", serif;
  --h1: clamp(2.1rem, 2vw + 1rem, 3.2rem);
  --h2: clamp(1.45rem, 1vw + 1rem, 2.1rem);
  --h3: clamp(1.15rem, 0.6vw + 1rem, 1.5rem);
  --body: 16px;
  --small: 14px;
  --line-height: 1.8;
  --motion-fast: 0.2s ease;
  --motion-medium: 0.35s ease;
}
