/* ============================================================
   Luv(sic) Notes — shared stylesheet
   Dual-theme (light/dark), Obsidian-friendly typography
   ============================================================ */

:root,
[data-theme="light"] {
  --bg: #F8F4ED;
  --bg-soft: #F2EDE4;
  --bg-gradient-1: rgba(122, 142, 154, 0.12);
  --bg-gradient-2: rgba(169, 142, 102, 0.10);
  --bg-gradient-start: #f5f1ea;
  --bg-gradient-end: #f0ebe4;

  --paper: rgba(250, 246, 238, 0.72);
  --card: rgba(248, 242, 232, 0.78);
  --card-hover: rgba(248, 242, 232, 0.94);

  --line: rgba(28, 24, 21, 0.12);
  --line-soft: rgba(28, 24, 21, 0.06);
  --line-strong: rgba(28, 24, 21, 0.18);

  --text: #1C1815;
  --text-soft: #4A433E;
  --muted: #6B6258;
  --muted-2: #9C9287;

  --accent: #7A9BAE;
  --accent-soft: rgba(88, 112, 125, 0.10);
  --accent-border: rgba(88, 112, 125, 0.22);
  --amber: #C4825A;
  --amber-soft: rgba(139, 109, 73, 0.12);
  --amber-border: rgba(139, 109, 73, 0.26);

  --shadow: 0 10px 30px rgba(58, 60, 62, 0.06);
  --shadow-hover: 0 14px 34px rgba(58, 60, 62, 0.08);

  --grid-line: rgba(0, 0, 0, 0.04);
  --grid-opacity: 0.04;

  --code-bg: rgba(255, 252, 247, 0.42);
  --code-border: rgba(74, 84, 93, 0.16);
  --code-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5), 0 10px 30px rgba(58, 60, 62, 0.06);
  --code-header-bg: rgba(255, 250, 243, 0.58);

  --callout-note-bg: rgba(63, 80, 96, 0.09);
  --callout-note-border: rgba(63, 80, 96, 0.14);
  --callout-note-title: #496273;
  --callout-warn-bg: rgba(129, 95, 49, 0.10);
  --callout-warn-border: rgba(129, 95, 49, 0.14);
  --callout-warn-title: #7c603c;

  --selection-bg: rgba(88, 112, 125, 0.28);
  --selection-fg: #1b2226;
}

[data-theme="dark"] {
  --bg: #1A1412;
  --bg-soft: #1F1815;
  --bg-gradient-1: rgba(217, 122, 86, 0.10);
  --bg-gradient-2: rgba(243, 167, 56, 0.06);
  --bg-gradient-start: #121212;
  --bg-gradient-end: #0D0D0D;

  --paper: rgba(38, 31, 26, 0.56);
  --card: rgba(38, 31, 26, 0.62);
  --card-hover: rgba(30, 30, 30, 0.78);

  --line: rgba(255, 255, 255, 0.08);
  --line-soft: rgba(255, 255, 255, 0.04);
  --line-strong: rgba(255, 255, 255, 0.16);

  --text: #EDE3D5;
  --text-soft: rgba(229, 229, 229, 0.88);
  --muted: #A3A3A3;
  --muted-2: #737373;

  --accent: #D4946E;
  --accent-soft: rgba(217, 122, 86, 0.12);
  --accent-border: rgba(217, 122, 86, 0.36);
  --amber: #D4B454;
  --amber-soft: rgba(243, 167, 56, 0.12);
  --amber-border: rgba(243, 167, 56, 0.36);

  --shadow: 0 12px 40px rgba(0, 0, 0, 0.42);
  --shadow-hover: 0 18px 52px rgba(0, 0, 0, 0.55);

  --grid-line: rgba(255, 255, 255, 0.025);
  --grid-opacity: 0.16;

  --code-bg: rgba(20, 20, 22, 0.48);
  --code-border: rgba(255, 255, 255, 0.08);
  --code-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), 0 14px 42px rgba(0, 0, 0, 0.5);
  --code-header-bg: rgba(15, 15, 17, 0.62);

  --callout-note-bg: rgba(57, 76, 90, 0.24);
  --callout-note-border: rgba(139, 164, 184, 0.32);
  --callout-note-title: #8ba4b8;
  --callout-warn-bg: rgba(109, 75, 37, 0.22);
  --callout-warn-border: rgba(243, 167, 56, 0.32);
  --callout-warn-title: #e3b36a;

  --selection-bg: rgba(243, 167, 56, 0.78);
  --selection-fg: #16110f;
}

/* === Color Aliases === */
:root {
  --color-accent-primary: var(--accent);
  --color-accent-secondary: var(--amber);
  --color-bg-page: var(--bg);
  --color-bg-card: var(--card);
  --color-text-primary: var(--text);
  --color-text-secondary: var(--text-soft);
  --color-text-muted: var(--muted);

  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --content-w: 760px;
  --transition: 260ms cubic-bezier(0.4, 0, 0.2, 1);

  /* === Design Token Scales === */
  /* Space scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 2.5rem;
  --space-8: 3rem;
  --space-9: 3.5rem;
  --space-10: 4rem;
  --space-11: 5rem;
  --space-12: 6rem;
  --space-13: 8rem;
  --space-14: 10rem;
  --space-15: 12rem;
  --space-16: 16rem;

  /* Type scale */
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1.0625rem;
  --text-lg: 1.25rem;
  --text-xl: 1.5rem;
  --text-2xl: 2rem;
  --text-3xl: 2.5rem;
  --text-4xl: 3.25rem;
  --text-5xl: 4.5rem;

  /* Animation tokens */
  --ease-breath: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-float: cubic-bezier(0.34, 1.56, 0.64, 1);
  --duration-slow: 600ms;
  --duration-medium: 400ms;
  --duration-fast: 250ms;

  /* Border tokens */
  --border-subtle: var(--line-soft);
  --border-strong: var(--line-strong);

   /* ===== 字体栈 — 中文优先 =====
     想换风格？只改 --font-serif 那一行：
       A. 楷体 / 笔记本感（默认）：LXGW WenKai Screen 在前
       B. 宋体 / 书页感：把 "Noto Serif SC" 提到最前
   */
  --font-serif:
  "Noto Serif SC", Lora,
  "LXGW WenKai Screen", "LXGW WenKai",
  "Source Han Serif SC", Georgia, serif;

  --font-display:
    "EB Garamond", "Noto Serif SC", "Lora", "LXGW WenKai Screen",
    Georgia, serif;

  --font-sans:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", "Noto Sans SC", "PingFang SC", "Microsoft YaHei",
    "Hiragino Sans GB", sans-serif;

  --font-mono:
    "JetBrains Mono", "SFMono-Regular", Consolas, Menlo, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--text);
  background:
    radial-gradient(circle at top left, var(--bg-gradient-1), transparent 28%),
    radial-gradient(circle at 85% 12%, var(--bg-gradient-2), transparent 22%),
    linear-gradient(180deg, var(--bg-gradient-start) 0%, var(--bg-gradient-end) 100%);
  background-attachment: fixed;
  line-height: 1.8;
  letter-spacing: 0.01em;
  min-height: 100vh;
  transition: background var(--transition), color var(--transition);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: var(--grid-opacity);
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 120px 120px;
  mask-image: radial-gradient(circle at center, black 35%, transparent 90%);
  -webkit-mask-image: radial-gradient(circle at center, black 35%, transparent 90%);
  transition: opacity var(--transition);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  will-change: opacity;
  opacity: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.15' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  mix-blend-mode: soft-light;
  transition: opacity var(--transition);
}
[data-theme="light"] body::after { opacity: 0.03; }
[data-theme="dark"] body::after { opacity: 0.035; }

::selection { background: var(--selection-bg); color: var(--selection-fg); }

a {
  color: var(--accent);
  text-decoration: none;
  transition: color var(--transition), opacity var(--transition), border-color var(--transition);
}
a:hover { opacity: 0.82; }

.site-shell {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

/* ============================================================
   顶部栏
   ============================================================ */
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) 0 var(--space-3);
  position: sticky;
  top: 0;
  z-index: 30;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  background: linear-gradient(to bottom,
    color-mix(in srgb, var(--bg) 72%, transparent),
    color-mix(in srgb, var(--bg) 35%, transparent));
  transition: background var(--transition);
}

.brand {
  font-size: var(--text-base);
  color: var(--muted);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
}
.brand a { color: inherit; }
[data-theme="dark"] .brand { color: var(--accent); font-weight: 600; }

.nav-wrap { display: flex; align-items: center; gap: var(--space-3); }
.nav { display: flex; gap: var(--space-4); flex-wrap: wrap; }

.nav a {
  color: var(--muted);
  font-size: var(--text-base);
  padding: var(--space-2) 0;
  position: relative;
}
.nav a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 2px;
  width: 100%; height: 1px;
  background: var(--color-accent-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
  opacity: 0.5;
}
.nav a:hover { color: var(--text); }
.nav a:hover::after { transform: scaleX(1); }

/* 主题切换按钮 */
.theme-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  height: 38px;
  padding: 0 var(--space-3);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  background: var(--paper);
  color: var(--muted);
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: color var(--transition), border-color var(--transition),
              background var(--transition), transform var(--transition);
}
.theme-toggle:hover {
  color: var(--text);
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.theme-toggle .icon { width: 16px; height: 16px; position: relative; display: inline-block; }
.theme-toggle .sun, .theme-toggle .moon {
  position: absolute; inset: 0;
  transition: opacity var(--transition), transform var(--transition);
}
[data-theme="light"] .theme-toggle .sun  { opacity: 1; transform: rotate(0); }
[data-theme="light"] .theme-toggle .moon { opacity: 0; transform: rotate(-40deg); }
[data-theme="dark"]  .theme-toggle .sun  { opacity: 0; transform: rotate(40deg); }
[data-theme="dark"]  .theme-toggle .moon { opacity: 1; transform: rotate(0); }
[data-theme="light"] .theme-toggle .label-dark,
[data-theme="dark"]  .theme-toggle .label-light { display: none; }

/* ============================================================
   Hero
   ============================================================ */
.hero {
  padding: var(--space-12) 0 var(--space-16);
  will-change: opacity, transform;
  animation: breathe-in var(--duration-slow) var(--ease-breath) both;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: end;
}

.eyebrow {
  display: inline-block;
  color: var(--accent);
  font-size: var(--text-sm);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: var(--space-4);
}
.hero .eyebrow {
  animation: breathe-in var(--duration-slow) var(--ease-breath) both;
  animation-delay: 0ms;
}

.hero h1 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  line-height: 1.06;
  letter-spacing: -0.03em;
  max-width: 12ch;
  color: var(--text);
  animation: breathe-in var(--duration-slow) var(--ease-breath) both;
  animation-delay: 100ms;
}
[data-theme="dark"] .hero h1 { font-weight: 600; letter-spacing: -0.04em; }

.hero p {
  margin: var(--space-5) 0 0;
  max-width: 62ch;
  color: var(--muted);
  font-size: var(--text-base);
  font-family: var(--font-serif);
  animation: breathe-in var(--duration-slow) var(--ease-breath) both;
  animation-delay: 200ms;
}


.hero-note {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-5) var(--space-4);
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  animation: breathe-in var(--duration-slow) var(--ease-breath) both;
  animation-delay: 400ms;
}
.hero-note .label {
  color: var(--muted-2);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: var(--text-xs);
  font-weight: 600;
  margin-bottom: var(--space-2);
}
.hero-note p {
  margin: 0;
  color: var(--text-soft);
  font-size: var(--text-base);
  line-height: 1.85;
  font-family: var(--font-serif);
}

.hero-note-link {
  display: block;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.hero-note-link:hover {
  opacity: 0.82;
}

.hero-note-link.no-link {
  cursor: default;
}

.hero-note-link.no-link:hover {
  opacity: 1;
}

.ambient-line {
  height: 1px;
  background: linear-gradient(90deg,
    transparent,
    var(--border-subtle),
    transparent);
  margin: var(--space-3) 0 var(--space-6);
}

/* ============================================================
   区段标题
   ============================================================ */
.section-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-5);
  margin: 0 0 var(--space-5);
}
.section-title h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(var(--text-xl), 2.2vw, var(--text-2xl));
  font-weight: 500;
  letter-spacing: -0.02em;
}
.section-title span { color: var(--muted); font-size: var(--text-base); }

/* ============================================================
   分类筛选胶囊栏
   ============================================================ */
.category-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: var(--space-1) 0 var(--space-6);
  padding: var(--space-1) 0;
}

.category-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-4);
  height: 34px;
  border: 1px solid var(--border-subtle);
  border-radius: 999px;
  background: var(--paper);
  color: var(--muted);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: color var(--transition), border-color var(--transition),
              background var(--transition);
  font-family: inherit;
  text-decoration: none;
}
.category-pill:hover {
  color: var(--text);
  border-color: var(--color-accent-primary);
  opacity: 1;
}
.category-pill .count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 18px;
  padding: 0 var(--space-2);
  border-radius: 999px;
  background: var(--line);
  color: var(--muted-2);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
}

.category-pill.active {
  background: var(--accent-soft);
  border-color: var(--accent-border);
  color: var(--accent);
}
.category-pill.active .count {
  background: var(--accent-border);
  color: var(--accent);
}
.category-pill.accent-amber.active {
  background: var(--amber-soft);
  border-color: var(--amber-border);
  color: var(--amber);
}
.category-pill.accent-amber.active .count {
  background: var(--amber-border);
  color: var(--amber);
}

/* ============================================================
   文章卡片网格
   ============================================================ */
.posts { padding: var(--space-6) 0 var(--space-12); }

.post-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-6);
}

.post-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: 0 2px 8px rgba(28, 24, 21, 0.04);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform var(--transition), box-shadow var(--transition),
              border-color var(--transition), background var(--transition);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

[data-theme="dark"] .post-card {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
}
[data-theme="dark"] .post-card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.38);
}
[data-theme="dark"] .post-card::before {
  content: "";
  position: absolute;
  left: var(--space-5); right: var(--space-5); top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent,
    rgba(217, 122, 86, 0.28), rgba(243, 167, 56, 0.14), transparent);
  opacity: 0;
  transition: opacity var(--transition);
}
[data-theme="dark"] .post-card:hover::before { opacity: 1; }

.post-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(28, 24, 21, 0.06);
  border-color: var(--border-strong);
  background: var(--card-hover);
  opacity: 1;
}

.post-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  color: var(--muted-2);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-bottom: var(--space-3);
}
.post-meta .category-chip {
  color: var(--accent);
}
.post-meta .category-chip.accent-amber { color: var(--amber); }

.post-card h3 {
  margin: 0 0 var(--space-3);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  line-height: 1.22;
  letter-spacing: -0.02em;
  color: var(--text);
  transition: color var(--transition);
}
.post-card:hover h3 { color: var(--accent); }

.post-card > p {
  margin: 0 0 var(--space-4);
  color: var(--muted);
  font-size: var(--text-base);
  font-family: var(--font-serif);
  flex: 1;
}

.formula-preview {
  background: var(--accent-soft);
  border: 1px solid var(--accent-border);
  border-radius: 14px;
  padding: var(--space-3) var(--space-3);
  overflow-x: auto;
  color: var(--text);
  font-size: var(--text-base);
  margin-top: auto;
}

.read-more {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  color: var(--accent);
  font-size: var(--text-base);
  font-weight: 500;
}
.post-card:hover .read-more { color: var(--amber); }

.tags-line {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-top: var(--space-3);
}
.tag-chip {
  color: var(--muted);
  border: 1px solid var(--line-soft);
  border-radius: 999px;
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-xs);
  font-family: var(--font-sans);
  letter-spacing: 0.04em;
  background: color-mix(in srgb, var(--paper) 60%, transparent);
}

.empty-state {
  padding: var(--space-11) var(--space-5);
  text-align: center;
  color: var(--muted);
  font-family: var(--font-serif);
  font-style: italic;
  border: 1px dashed var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper);
}

/* ============================================================
   文章详情页
   ============================================================ */
.article-shell {
  max-width: var(--content-w);
  margin: var(--space-7) auto var(--space-10);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius-lg) + 6px);
  box-shadow: var(--shadow);
  padding: var(--space-8) var(--space-6);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.article-head {
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-5);
  border-bottom: 1px solid var(--line);
}

.article-head h1 {
  margin: 0 0 var(--space-4);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(var(--text-2xl), 3vw, var(--text-3xl));
  line-height: 1.14;
  letter-spacing: -0.03em;
  color: var(--text);
}

.article-meta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
  color: var(--muted-2);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-bottom: var(--space-3);
}
.article-meta .category-chip { color: var(--accent); }
.article-meta .category-chip.accent-amber { color: var(--amber); }
.article-meta .dot {
  display: inline-block;
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--line-strong);
}

.article-tags {
  display: flex; flex-wrap: wrap; gap: var(--space-1);
  margin-top: var(--space-3);
}

/* 上/下一篇导航 */
.post-nav {
  max-width: var(--content-w);
  margin: 0 auto var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.post-nav a {
  display: block;
  padding: var(--space-5) var(--space-5);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--card);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform var(--transition), border-color var(--transition),
              background var(--transition);
}
.post-nav a:hover {
  transform: translateY(-2px);
  border-color: var(--line-strong);
  background: var(--card-hover);
  opacity: 1;
}
.post-nav .nav-label {
  display: block;
  color: var(--muted-2);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: var(--space-1);
}
.post-nav .nav-title {
  display: block;
  color: var(--text);
  font-family: var(--font-serif);
  font-size: var(--text-base);
  line-height: 1.35;
}
.post-nav .next-post { text-align: right; }
.post-nav .placeholder {
  visibility: hidden;
}

/* ============================================================
   文章双栏布局 — 正文 + 目录侧栏
   ============================================================ */
.post-layout {
  max-width: calc(var(--content-w) + 270px);
  margin: var(--space-7) auto 0;
  display: flex;
  align-items: flex-start;
  gap: var(--space-7);
}

.article-col {
  flex: 1;
  min-width: 0;
}

.post-layout .article-shell {
  margin: 0 0 var(--space-10);
  max-width: none;
}

.post-layout .post-nav {
  margin: 0 0 var(--space-8);
  max-width: none;
}

/* TOC 目录侧栏 */
.toc-sidebar {
  width: 230px;
  flex-shrink: 0;
  position: sticky;
  top: 90px;
  max-height: calc(100vh - 140px);
  overflow-y: auto;
  padding-left: var(--space-5);
  border-left: 1px solid var(--line);
  transition: border-color var(--transition);
}

.toc-sidebar .toc-title {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 600;
  color: var(--muted-2);
  margin: 0 0 var(--space-4);
}

.toc-sidebar .toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.toc-sidebar .toc-item {
  margin-bottom: 0;
}

.toc-sidebar .toc-item a {
  display: block;
  padding: var(--space-1) 0;
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  color: var(--muted);
  text-decoration: none;
  line-height: 1.45;
  border-left: 2px solid transparent;
  padding-left: var(--space-2);
  margin-left: calc(var(--space-3) * -1);
  transition: color var(--transition), border-color var(--transition);
  overflow-wrap: break-word;
  word-break: break-word;
}

.toc-sidebar .toc-item a:hover {
  color: var(--accent);
  opacity: 1;
}

.toc-sidebar .toc-item.active a {
  color: var(--accent);
  border-left-color: var(--accent);
  font-weight: 500;
}

.toc-sidebar .toc-item.toc-h2 a {
  padding-left: var(--space-4);
  font-size: var(--text-sm);
}

.toc-sidebar .toc-item.toc-h3 a {
  padding-left: var(--space-5);
  font-size: var(--text-xs);
}

.toc-sidebar .toc-item.toc-h1 a {
  padding-left: var(--space-1);
  font-size: var(--text-sm);
}

@media (max-width: 840px) {
  .toc-sidebar {
    display: none;
  }
  .post-layout {
    display: block;
    max-width: var(--content-w);
  }
  .post-layout .article-shell {
    margin: 0 auto var(--space-10);
    max-width: var(--content-w);
  }
  .post-layout .post-nav {
    margin: 0 auto var(--space-8);
    max-width: var(--content-w);
  }
}

/* ============================================================
   Prose 正文
   ============================================================ */
.prose p,
.prose ul,
.prose ol,
.prose table,
.prose pre,
.prose blockquote {
  margin: var(--space-5) 0;
}

.prose h2, .prose h3, .prose h4 {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.25;
  margin: var(--space-6) 0 var(--space-3);
  color: var(--text);
}
.prose h2 { font-size: var(--text-xl); }
.prose h3 { font-size: var(--text-lg); }
.prose h4 { font-size: var(--text-base); }

.prose p, .prose li {
  color: var(--text-soft);
  font-size: var(--text-base);
  font-family: var(--font-serif);
}
.prose strong { color: var(--text); }
.prose em { color: var(--text-soft); }

.prose a {
  color: var(--accent);
  background-image: linear-gradient(var(--accent), var(--accent));
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 100% 1px;
  transition: background-size var(--transition), color var(--transition);
}
.prose a:hover {
  background-size: 100% 2px;
  color: var(--amber);
  opacity: 1;
}

.wiki-link {
  color: var(--accent) !important;
  background: var(--accent-soft) !important;
  background-image: none !important;
  border: 1px solid var(--accent-border);
  border-radius: 999px;
  padding: var(--space-1) var(--space-2);
  white-space: nowrap;
  font-family: var(--font-sans);
  font-size: var(--text-base);
}
.wiki-link:hover { background-size: 0 !important; }

/* Callouts */
.callout {
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-4);
  border: 1px solid var(--border-subtle);
  margin: var(--space-5) 0;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.callout-title {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-1);
  font-weight: 700;
  font-family: var(--font-sans);
}
.callout-body > :first-child { margin-top: 0; }
.callout-body > :last-child { margin-bottom: 0; }

.callout.note, .callout.info, .callout.tip {
  background: var(--callout-note-bg);
  border-color: var(--callout-note-border);
}
.callout.note .callout-title,
.callout.info .callout-title,
.callout.tip  .callout-title { color: var(--callout-note-title); }

.callout.warning, .callout.caution {
  background: var(--callout-warn-bg);
  border-color: var(--callout-warn-border);
}
.callout.warning .callout-title,
.callout.caution .callout-title { color: var(--callout-warn-title); }

/* 表格 */
.prose table,
.article-shell table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--code-bg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: table;
}
.prose th, .prose td {
  text-align: left;
  padding: var(--space-3) var(--space-3);
  border-bottom: 1px solid var(--line);
  font-size: var(--text-base);
  font-family: var(--font-sans);
  color: var(--text-soft);
}
.prose th {
  color: var(--text);
  background: var(--accent-soft);
  font-weight: 600;
}
.prose tr:last-child td { border-bottom: none; }

/* ============================================================
   代码框 — 毛玻璃
   ============================================================ */
.block-math, .math-display-wrap {
  background: var(--code-bg);
  border: 1px solid var(--code-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  overflow-x: auto;
  backdrop-filter: blur(8px) saturate(130%);
  -webkit-backdrop-filter: blur(8px) saturate(130%);
  box-shadow: var(--code-shadow);
  position: relative;
}

.code-frame,
.code-wrap {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--code-border);
  background: var(--code-bg);
  box-shadow: var(--code-shadow);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  margin: var(--space-5) 0;
}

.code-frame::before,
.code-wrap::before {
  content: "";
  display: block;
  height: 36px;
  background: var(--code-header-bg);
  border-bottom: 1px solid var(--line-soft);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.code-frame::after,
.code-wrap::after {
  content: "";
  position: absolute;
  top: 13px; left: 14px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--muted) 40%, transparent);
  box-shadow:
    16px 0 0 color-mix(in srgb, var(--muted) 40%, transparent),
    32px 0 0 color-mix(in srgb, var(--muted) 40%, transparent);
  pointer-events: none;
}

.copy-btn, .copy-code {
  position: absolute;
  top: 6px; right: 8px;
  z-index: 2;
  height: 24px;
  padding: 0 var(--space-3);
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-family: var(--font-sans);
  transition: color var(--transition), border-color var(--transition), transform var(--transition);
}
.copy-btn:hover, .copy-code:hover {
  color: var(--accent);
  border-color: var(--accent-border);
  transform: translateY(-1px);
}

.code-frame pre,
.code-wrap pre {
  margin: 0;
  overflow: auto;
  padding: var(--space-4) var(--space-5) var(--space-5);
  font-size: 0.9rem;
  line-height: 1.7;
  background: transparent !important;
}

.code-frame code, .code-wrap code,
.code-frame pre code, .code-wrap pre code {
  font-family: var(--font-mono);
  background: transparent !important;
  color: var(--text);
}

.hljs { background: transparent !important; padding: 0 !important; }

/* 内联 code */
.prose :not(pre) > code {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-1) var(--space-2);
  border-radius: 6px;
  background: var(--accent-soft);
  color: var(--text);
  border: 1px solid var(--accent-border);
}

blockquote {
  margin: var(--space-5) 0;
  padding: var(--space-1) 0 var(--space-1) var(--space-4);
  border-left: 2px solid var(--accent-border);
  color: var(--muted);
  font-family: var(--font-serif);
  font-style: italic;
}

.footnotes {
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px dashed var(--line);
  color: var(--muted);
  font-size: var(--text-base);
  font-family: var(--font-serif);
}
.footnotes ol { padding-left: var(--space-5); }
.footnotes li { margin-bottom: var(--space-2); color: var(--muted); }
.footnote-back { margin-left: var(--space-1); text-decoration: none; }

.katex-display {
  overflow-x: auto;
  overflow-y: hidden;
  padding: var(--space-2) var(--space-1);
  margin: 0 !important;
}
.katex { font-size: 1.02em; }
[data-theme="dark"] .katex,
[data-theme="dark"] .katex * { color: var(--text); }

/* ============================================================
   Loading / 状态
   ============================================================ */
.loading-state,
.error-state {
  padding: var(--space-11) var(--space-5);
  text-align: center;
  color: var(--muted);
  font-family: var(--font-serif);
  font-style: italic;
}
.error-state { color: var(--amber); }

/* ============================================================
   Footer
   ============================================================ */
footer.site-footer {
  padding: var(--space-5) 0 var(--space-8);
  margin-top: var(--space-5);
  border-top: 1px solid var(--line);
  text-align: center;
  color: var(--muted-2);
  font-size: var(--text-base);
  font-family: var(--font-serif);
  font-style: italic;
}

/* ============================================================
   Hero entrance animation
   ============================================================ */
@keyframes breathe-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   响应式
   ============================================================ */
@media (max-width: 960px) {
  .hero-grid { grid-template-columns: 1fr; }
  .post-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero { padding: var(--space-8) 0 var(--space-12); }
  .hero h1 { max-width: 14ch; }
}

@media (max-width: 720px) {
  .post-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .post-nav { grid-template-columns: 1fr; }
  .post-nav .next-post { text-align: left; }
  .hero { padding: var(--space-6) 0 var(--space-8); }
  .posts { padding: var(--space-5) 0 var(--space-8); }
  .post-layout { gap: var(--space-5); }
  .post-layout .article-shell { margin-bottom: var(--space-8); }
}

@media (max-width: 600px) {
  .site-shell { width: min(100%, calc(100% - 22px)); }
  .topbar {
    padding: var(--space-3) 0 var(--space-2);
    align-items: flex-start;
    flex-direction: column;
    gap: var(--space-2);
  }
  .nav-wrap { width: 100%; justify-content: space-between; }
  .nav { gap: var(--space-3); }
  .hero { padding: var(--space-5) 0 var(--space-4); }
  .hero p, .hero-note p, .post-card > p,
  .prose p, .prose li { font-size: var(--text-base); }
  .posts { padding: var(--space-4) 0 var(--space-6); }
  .post-card { padding: var(--space-4); }
  .article-shell {
    padding: var(--space-6) var(--space-4) var(--space-5);
    border-radius: 22px;
  }
  .article-head h1 { font-size: var(--text-2xl); }
  .section-title {
    align-items: flex-start;
    flex-direction: column;
    gap: var(--space-1);
  }
  .prose th, .prose td { padding: var(--space-2) var(--space-3); font-size: var(--text-base); }
  .formula-preview, .block-math { padding: var(--space-3) var(--space-3); }
  .theme-toggle { padding: 0 var(--space-3); font-size: var(--text-xs); }
}

/* ============================================================
    Reduced motion — no animation for vestibular / motion sensitivity
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .hero, .hero * { animation: none !important; opacity: 1; transform: none; }
  *, *::before, *::after { animation-duration: 0s !important; transition-duration: 0s !important; }
}

/* ============================================================
    Print — hide noise, nav, animations; black text on white
   ============================================================ */
@media print {
  body::after { display: none !important; }
  .topbar, .theme-toggle { display: none !important; }
  body { background: white !important; color: black !important; }
}
