/* cf-page core.css —— Claude Code Docs 文档站气质。
   三栏布局 + 米白底 + Inter 正文 + 衬线 H1。
   主题颜色由 themes/<name>.css 通过 CSS variables 覆盖；
   左侧导航 / 右侧 TOC 故意硬编码 Docs 米白板，不跟随主题变化（保持阅读骨架稳定）。 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,500;8..60,600&family=JetBrains+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Claude Docs 米白基线 */
  --c-bg:#FAF9F6;
  --c-ink:#34302A;
  --c-ink-soft:#6F685F;
  --c-mute:#928A80;
  --c-line:#E8E1D6;
  --c-line-soft:#EFEAE0;
  --c-card:#FFFFFF;
  --c-surface-muted:#F0EEE9;

  --c-accent:#D16A4B;
  --c-accent-soft:#F4E8DC;
  --c-accent-ink:#A94F2B;

  --c-warn:#B97A1F; --c-warn-bg:#FAECD4;
  --c-danger:#B13E35; --c-danger-bg:#F7DCD6;
  --c-info:#3A679C; --c-info-bg:#E4ECF6;
  --c-tip:#3D7A5A; --c-tip-bg:#DFEEE4;

  --c-code-inline-bg:#F1EDE7;
  --c-code-inline-border:#E3D8CB;
  --c-code-bg:#F4F1EB;
  --c-code-ink:#2A2620;

  --f-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  --f-serif:"Source Serif 4",Georgia,Charter,"Songti SC","Source Han Serif SC",serif;
  --f-mono:"JetBrains Mono","SF Mono","Consolas",ui-monospace,monospace;

  --w-text:780px;
  --w-sidenav:272px;
  --w-toc:208px;

  --radius:8px;
  --radius-lg:12px;
  --topbar-h:64px;
}

html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-sans);
  color:var(--c-ink);
  background:var(--c-bg);
  font-size:16px;line-height:1.75;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"kern","liga","calt";
  text-rendering:optimizeLegibility;
  min-height:100vh;
}

/* ====== 布局：顶栏 + 左目录 + 正文 + 右 TOC + 底栏 ====== */
.layout{
  display:grid;
  grid-template-columns:var(--w-sidenav) minmax(0,1fr) var(--w-toc);
  grid-template-rows:var(--topbar-h) 1fr auto;
  grid-template-areas:
    "topbar topbar topbar"
    "sidenav main toc"
    "footer footer footer";
  min-height:100vh;
}
.layout--blog{grid-template-columns:1fr;grid-template-areas:"topbar" "main" "footer"}

.topbar{grid-area:topbar}
.sidenav-wrap{grid-area:sidenav}
.main{grid-area:main}
.toc-wrap{grid-area:toc}
.site-footer{grid-area:footer}

/* ====== 顶栏 ====== */
.topbar{
  position:sticky;top:0;z-index:30;
  height:var(--topbar-h);
  display:flex;align-items:center;gap:14px;
  padding:0 28px;
  background:rgba(250,249,246,.88);
  border-bottom:1px solid var(--c-line);
  backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
}
.topbar__brand{
  font-family:var(--f-sans);
  font-size:19px;font-weight:700;letter-spacing:.01em;
  color:var(--c-accent);text-decoration:none;
}
.topbar__sep{color:var(--c-line);font-size:18px;line-height:1}
.topbar__site{
  font-size:18px;font-weight:500;color:#3F3A35;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.topbar__spacer{flex:1}

/* 顶栏内的搜索 */
.search{position:relative}
.search input{
  width:220px;padding:7px 12px;font-size:14px;
  border:1px solid var(--c-line);border-radius:999px;
  background:#fff;color:var(--c-ink);font-family:inherit;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.search input::placeholder{color:var(--c-mute)}
.search input:focus{
  outline:none;border-color:var(--c-accent);
  box-shadow:0 0 0 3px var(--c-accent-soft);
}
.search__results{
  position:absolute;top:calc(100% + 6px);right:0;
  width:340px;max-height:60vh;overflow:auto;
  background:var(--c-card);border:1px solid var(--c-line);border-radius:var(--radius);
  list-style:none;padding:6px;z-index:40;
  box-shadow:0 8px 24px rgba(60,40,20,.08);
}
.search__results li{padding:0}
.search__results a{
  display:block;padding:8px 10px;text-decoration:none;
  color:var(--c-ink);border-radius:6px;font-size:14px;
}
.search__results a:hover{background:var(--c-surface-muted)}
.search__results .hit-title{font-weight:500}
.search__results .hit-sub{color:var(--c-mute);font-size:12px;display:block;margin-top:2px}

/* 主题切换 select */
.theme-switcher{position:relative;display:inline-flex;align-items:center}
.theme-switcher__select{
  appearance:none;-webkit-appearance:none;
  background:#fff;border:1px solid var(--c-line);
  border-radius:999px;padding:6px 30px 6px 14px;
  font-family:inherit;font-size:13px;color:#5F5A53;
  cursor:pointer;letter-spacing:.01em;
  transition:border-color .15s ease,color .15s ease;
}
.theme-switcher__select:hover{color:var(--c-ink);border-color:var(--c-mute)}
.theme-switcher__select:focus{outline:none;border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-soft)}
.theme-switcher::after{
  content:"";position:absolute;right:12px;top:50%;
  width:6px;height:6px;border-right:1.5px solid #5F5A53;
  border-bottom:1.5px solid #5F5A53;
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
}

/* ====== 左侧目录 —— Claude Docs 阅读感 ====== */
.sidenav-wrap{
  border-right:1px solid var(--c-line);
  background:var(--c-bg);
  padding:28px 24px 80px;
  overflow-y:auto;
  position:sticky;top:var(--topbar-h);align-self:start;
  height:calc(100vh - var(--topbar-h));
  font-family:var(--f-sans);
}
.sidenav__group{margin-top:28px}
.sidenav__group:first-child{margin-top:4px}
.sidenav__group-title{
  margin:0 0 8px;padding:0 10px;
  font-size:13px;line-height:1.4;font-weight:600;
  letter-spacing:0;text-transform:none;
  color:#3F3A35;
}
.sidenav__list{list-style:none;display:flex;flex-direction:column;gap:2px}
.sidenav__item{position:relative}
.sidenav__item a{
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  padding:6px 10px;border-radius:8px;
  font-size:14px;line-height:1.45;font-weight:400;
  color:#5F5A53;text-decoration:none;
  transition:background-color .12s ease,color .12s ease;
}
.sidenav__item a:hover{background:#F0EEE9;color:#2F2B26}
.sidenav__item.is-current a{
  background:#EDEBE6;color:#2F2B26;font-weight:500;
}
.sidenav__item.is-current::before{
  content:"";position:absolute;left:0;top:8px;bottom:8px;width:2px;
  border-radius:999px;background:var(--c-accent);
}

.sidenav-toggle{
  display:none;
  position:fixed;bottom:16px;right:16px;z-index:40;
  border:1px solid var(--c-line);background:var(--c-card);color:var(--c-ink);
  padding:10px 16px;border-radius:999px;font-family:inherit;font-size:14px;
  box-shadow:0 4px 12px rgba(60,40,20,.1);cursor:pointer;
}

/* ====== 主区域 ====== */
.main{
  padding:64px clamp(28px,5vw,72px) 120px;
  max-width:calc(var(--w-text) + 144px);
  margin:0;
  width:100%;
}

.crumbs{font-size:14px;color:var(--c-mute);margin-bottom:32px}
.crumbs__sep{margin:0 6px;color:var(--c-line)}

.article-header{margin-bottom:40px;max-width:var(--w-text)}
.chapter{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.18em;
  color:var(--c-accent);text-transform:uppercase;font-weight:700;
  margin-bottom:18px;
}
.article-title{
  font-family:var(--f-serif);
  font-size:clamp(2rem,3.6vw,2.75rem);
  line-height:1.18;font-weight:600;letter-spacing:-.02em;
  color:var(--c-ink);
  font-feature-settings:"kern","liga","ss01";
}
.subtitle{
  margin-top:16px;color:var(--c-ink-soft);
  font-family:var(--f-sans);
  font-size:19px;line-height:1.6;font-weight:400;
}
.meta-line{
  margin-top:18px;font-size:14px;color:var(--c-mute);
  display:flex;gap:8px;align-items:center;
}

/* ====== 信息卡 ====== */
.info-card{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--c-line);
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  margin-bottom:48px;overflow:hidden;
  max-width:var(--w-text);
}
.info-card__col{background:var(--c-card);padding:18px 20px 20px}
.info-card__label{
  font-size:12px;letter-spacing:.04em;color:var(--c-mute);
  font-weight:600;margin-bottom:10px;
}
.info-card__col ul{list-style:none}
.info-card__col li{
  font-size:14px;line-height:1.55;color:var(--c-ink);
  padding:3px 0 3px 14px;position:relative;
}
.info-card__col li::before{
  content:"";position:absolute;left:0;top:11px;width:5px;height:5px;
  background:var(--c-accent);border-radius:50%;
}

/* ====== 正文 ====== */
.article-body{max-width:var(--w-text);font-size:16.5px;line-height:1.78;color:var(--c-ink)}
.article-body > * + *{margin-top:1.1em}

.article-body p{font-size:16.5px;line-height:1.78;color:var(--c-ink)}
.article-body p code,.article-body li code,.article-body td code{
  font-family:var(--f-mono);font-size:.92em;
  background:var(--c-code-inline-bg);
  border:1px solid var(--c-code-inline-border);
  border-radius:4px;padding:1px 6px;color:#5A4A36;
}
.article-body a{
  color:var(--c-accent-ink);
  text-decoration:underline;text-decoration-color:rgba(169,79,43,.4);
  text-underline-offset:3px;text-decoration-thickness:1px;
  transition:color .12s ease,text-decoration-color .12s ease;
}
.article-body a:hover{color:#7E3B1F;text-decoration-color:var(--c-accent-ink)}
.article-body mark{
  background:linear-gradient(transparent 60%,var(--c-accent-soft) 60%);
  color:inherit;padding:0 1px;
}

/* 标题：H2/H3 sans，仅 H1 + article-title 用 serif */
.b-heading{
  font-family:var(--f-sans);
  font-size:1.625rem;line-height:1.3;font-weight:600;letter-spacing:-.01em;
  margin-top:2.4em !important;margin-bottom:.55em;
  color:var(--c-ink);
}
h3.b-heading{font-size:1.3125rem;margin-top:2em !important;font-weight:600;letter-spacing:-.005em}
h4.b-heading{font-size:1.05rem;margin-top:1.6em !important;color:var(--c-ink-soft);font-weight:600}

/* 摘要块 */
.b-summary{
  font-size:16.5px;line-height:1.75;
  padding:16px 20px 16px 22px;
  background:var(--c-accent-soft);
  border-left:3px solid var(--c-accent);
  border-radius:0 var(--radius) var(--radius) 0;
  color:var(--c-ink);
}

/* 核心观点 */
.b-principle{
  font-family:var(--f-serif);
  font-size:1.2rem;line-height:1.55;
  padding:24px 28px;margin:1.6em 0;
  background:var(--c-card);
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  position:relative;
}
.b-principle::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--c-accent);border-radius:var(--radius-lg) 0 0 var(--radius-lg);
}
.b-principle p{font-size:inherit;line-height:inherit;font-family:inherit}

/* 列表 */
.b-list{padding-left:1.4em}
.b-list li{margin:.3em 0}
.b-list li::marker{color:var(--c-accent)}

/* 问题卡片网格 */
.b-grid{display:grid;gap:14px;margin:1.6em 0}
.b-grid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.b-grid--3{grid-template-columns:1fr}}

.b-card{
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  padding:18px 20px;background:var(--c-card);
  transition:border-color .15s ease;
}
.b-card:hover{border-color:var(--c-mute)}
.b-card__name{
  font-size:14px;font-weight:600;color:var(--c-ink);
  margin-bottom:12px;padding-bottom:10px;
  border-bottom:1px solid var(--c-line-soft);
}
.b-card__fields{font-size:13.5px;line-height:1.6}
.b-card__fields dt{
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--c-mute);font-weight:600;margin-top:10px;
}
.b-card__fields dt:first-child{margin-top:0}
.b-card__fields dd{color:var(--c-ink-soft);margin-top:3px}

/* 决策表 */
.b-table{margin:1.6em 0;max-width:none}
.b-table table{
  width:100%;border-collapse:collapse;font-size:14.5px;line-height:1.6;
  border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;
  background:var(--c-card);
}
.b-table th{
  text-align:left;padding:11px 14px;
  background:var(--c-surface-muted);color:var(--c-ink-soft);
  font-weight:600;font-size:13px;letter-spacing:.02em;
  border-bottom:1px solid var(--c-line);
}
.b-table td{padding:13px 14px;color:var(--c-ink);border-bottom:1px solid var(--c-line-soft);vertical-align:top}
.b-table tr:last-child td{border-bottom:0}
.b-table__mnemonic{
  margin-top:12px;padding:12px 16px;
  background:var(--c-accent-soft);border-radius:var(--radius);
  font-size:14px;line-height:1.6;color:var(--c-ink);
  display:flex;gap:10px;align-items:flex-start;
}
.b-table__mnemonic-label{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;
  color:var(--c-accent-ink);font-weight:700;padding-top:3px;
  flex-shrink:0;text-transform:uppercase;
}

/* 实践 */
.b-practice{
  margin:1.6em 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  padding:18px;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  background:var(--c-card);
}
.b-practice__col h5{font-size:13px;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.b-practice__mark{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:11px}
.b-practice__col--do .b-practice__mark{background:var(--c-tip-bg);color:var(--c-tip)}
.b-practice__col--dont .b-practice__mark{background:var(--c-danger-bg);color:var(--c-danger)}
.b-practice__col--pitfall .b-practice__mark{background:var(--c-warn-bg);color:var(--c-warn)}
.b-practice__col ul{list-style:none;font-size:13.5px;line-height:1.6;color:var(--c-ink-soft)}
.b-practice__col li{padding:3px 0}
.b-practice__criterion{
  grid-column:1 / -1;margin-top:6px;padding:12px 14px;
  background:var(--c-bg);border:1px dashed var(--c-line);
  border-radius:var(--radius);font-size:14px;color:var(--c-ink);
}
@media(max-width:760px){.b-practice{grid-template-columns:1fr}}

/* Callout */
.b-callout{
  margin:1.6em 0;padding:14px 16px 14px 18px;
  border-radius:var(--radius);
  border-left:3px solid var(--c-info);background:var(--c-info-bg);
}
.b-callout--tip{border-color:var(--c-tip);background:var(--c-tip-bg)}
.b-callout--warn{border-color:var(--c-warn);background:var(--c-warn-bg)}
.b-callout--danger{border-color:var(--c-danger);background:var(--c-danger-bg)}
.b-callout__title{font-weight:600;font-size:14px;margin-bottom:4px}
.b-callout__body{font-size:14.5px;line-height:1.65}

/* 代码块：浅色 */
.b-code{
  margin:1.4em 0;
  background:var(--c-code-bg);color:var(--c-code-ink);
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);overflow-x:auto;
  padding:14px 18px;line-height:1.6;font-size:14px;
}
.b-code code{font-family:var(--f-mono);background:transparent;border:0;padding:0;color:inherit}

/* 引用 */
.b-quote{
  margin:1.6em 0;padding:14px 18px;
  border-left:3px solid var(--c-line);
  color:var(--c-ink-soft);font-style:italic;
}
.b-quote__by{display:block;margin-top:6px;font-size:13px;color:var(--c-mute);font-style:normal}

/* 图片 */
.b-image{margin:1.6em 0;text-align:center}
.b-image img{max-width:100%;border-radius:var(--radius-lg)}
.b-image figcaption{margin-top:8px;font-size:13px;color:var(--c-mute)}

.b-divider{border:0;border-top:1px solid var(--c-line);margin:2em 0}

/* 上下页 */
.footnav{
  margin-top:64px;padding-top:32px;
  border-top:1px solid var(--c-line);
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
  max-width:var(--w-text);
}
.footnav__prev,.footnav__next{
  display:flex;flex-direction:column;gap:4px;
  padding:14px 16px;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  text-decoration:none;color:var(--c-ink);background:var(--c-card);
  transition:border-color .15s ease;
}
.footnav__prev:hover,.footnav__next:hover{border-color:var(--c-accent)}
.footnav__next{text-align:right}
.footnav__dir{font-size:12px;color:var(--c-mute);letter-spacing:.06em}
.footnav__title{font-weight:500;font-size:14.5px}

/* ====== 右侧 TOC：在此页面 ====== */
.toc-wrap{
  padding:96px 28px 64px 0;
  position:sticky;top:var(--topbar-h);align-self:start;
  height:calc(100vh - var(--topbar-h));
  overflow-y:auto;
  font-family:var(--f-sans);
}
.toc-title{
  font-size:13px;font-weight:600;color:#3F3A35;
  margin-bottom:14px;
}
.toc-list{list-style:none;display:flex;flex-direction:column;gap:0}
.toc-list a{
  display:block;padding:5px 10px 5px 12px;
  font-size:13px;line-height:1.55;color:var(--c-ink-soft);
  text-decoration:none;
  border-left:2px solid transparent;
  transition:color .12s ease,border-color .12s ease;
}
.toc-list a:hover{color:var(--c-ink)}
.toc-list a.is-active{color:var(--c-accent-ink);border-left-color:var(--c-accent);font-weight:500}
.toc-list .toc-l3{padding-left:22px;font-size:12.5px}

/* 底栏 */
.site-footer{
  border-top:1px solid var(--c-line);padding:28px;
  text-align:center;font-size:13px;color:var(--c-mute);
  background:var(--c-bg);
}
.site-footer__inner{display:flex;justify-content:center;gap:12px;align-items:center}
.site-footer__brand{color:var(--c-accent);font-weight:500;text-decoration:none}

/* ====== 响应式 ====== */
@media(max-width:1180px){
  .layout{grid-template-columns:var(--w-sidenav) 1fr;grid-template-areas:"topbar topbar" "sidenav main" "footer footer"}
  .toc-wrap{display:none}
}
@media(max-width:960px){
  .layout{grid-template-columns:1fr;grid-template-areas:"topbar" "main" "footer"}
  .sidenav-wrap{
    position:fixed;top:0;left:0;bottom:0;width:84vw;max-width:320px;
    z-index:50;transform:translateX(-100%);transition:transform .25s ease;
    box-shadow:0 8px 24px rgba(60,40,20,.12);height:100vh;
  }
  .layout.is-nav-open .sidenav-wrap{transform:translateX(0)}
  body.is-nav-open .sidenav-wrap{transform:translateX(0)}
  .sidenav-toggle{display:inline-flex;align-items:center;gap:6px}
  .main{padding:40px 24px 80px}
  .search input{width:140px}
}
@media(max-width:640px){
  .info-card{grid-template-columns:1fr}
  .article-title{font-size:1.8rem}
  .topbar__site{display:none}
  .theme-switcher{display:none}
}
