/* ============================================================
   记工表 官网 V3 · base（复位 / 导航 / 章节脚手架 / 编辑 masthead / 按钮 / 页脚）
   颜色字号一律 var(--*)（tokens.css 单一真相源）
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  font-family: var(--font);
  font-size: var(--t-base);
  line-height: var(--lh-body);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
:focus-visible { outline: 3px solid var(--teal); outline-offset: 3px; border-radius: var(--r-badge); }
.ch--dark :focus-visible, .stage :focus-visible { outline-color: var(--surface); }
.num { font-family: var(--num); font-variant-numeric: tabular-nums; letter-spacing: var(--ls-num); }
/* 状态/强调工具类（替代内联 style，纳入令牌闸） */
.status-pending { color: var(--amber-text); font-weight: var(--fw-med); }
.t-on-dark { color: var(--ink-on-dark); }

.skip-link { position: absolute; left: 12px; top: -64px; z-index: var(--z-toast); background: var(--surface); color: var(--teal); font-weight: var(--fw-med); padding: 0.6rem 1rem; border-radius: var(--r-btn); box-shadow: var(--shadow-md); transition: top .25s var(--ease-out-expo); }
.skip-link:focus { top: 12px; }

/* ============ 导航（编辑式细导航 + 吸顶发丝线） ============ */
.nav { position: sticky; top: 0; z-index: var(--z-nav); height: 56px; background: var(--bg-blur); backdrop-filter: saturate(180%) blur(18px); -webkit-backdrop-filter: saturate(180%) blur(18px); border-bottom: 1px solid transparent; transition: border-color var(--dur) var(--ease-out-expo), background var(--dur) var(--ease-out-expo); }
.nav.is-stuck { border-bottom-color: var(--line); }
.is-cheap .nav { backdrop-filter: none; -webkit-backdrop-filter: none; background: var(--bg-blur-strong); }
.nav-inner { max-width: var(--container-wide); height: 56px; margin-inline: auto; padding: 0 var(--pad-x); display: flex; align-items: center; gap: var(--s-5); }
.brand { display: flex; align-items: center; gap: var(--s-2); font-weight: var(--fw-bold); font-size: 1.08rem; color: var(--ink); letter-spacing: var(--ls-title); }
.brand-mark { width: 28px; height: 28px; border-radius: var(--r-sm); flex: none; background: var(--teal); display: grid; place-items: center; }
.brand-mark svg { width: 17px; height: 17px; color: var(--surface); }
.nav-links { display: flex; gap: 0.1rem; margin-inline: auto; }
.nav-links a { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.4rem 0.8rem; border-radius: var(--r-badge); font-size: var(--t-sm); color: var(--ink-2); transition: color var(--dur) , background var(--dur); }
.nav-links a .ix { font-family: var(--num); font-size: 0.72rem; color: var(--ink-3); }
.nav-links a:hover, .nav-links a.is-current { color: var(--ink); background: var(--surface-teal); }
.nav-links a.is-current .ix { color: var(--teal); }
.nav-cta { font-size: var(--t-sm); font-weight: var(--fw-med); color: var(--surface); background: var(--cta-solid); padding: 0.5rem 1rem; border-radius: var(--r-chip); transition: background var(--dur), transform var(--dur-fast); }
.nav-cta:hover { background: var(--teal-press); }
.nav-cta:active { transform: scale(var(--tap-scale)); }
.nav-toggle { display: none; margin-left: auto; width: 44px; height: 44px; align-items: center; justify-content: center; color: var(--ink); }
.nav-toggle svg { width: 24px; height: 24px; }
@media (max-width: 833px) {
  .nav-links { display: none; }
  .nav-cta { margin-left: auto; }
  .nav-toggle { display: inline-flex; margin-left: 0.4rem; }
  .nav.is-open .nav-links { display: flex; flex-direction: column; gap: 0.1rem; position: absolute; top: 56px; left: 0; right: 0; margin: 0; background: var(--bg-blur-strong); backdrop-filter: blur(18px); padding: 0.6rem var(--pad-x) 1rem; border-bottom: 1px solid var(--line); }
  .nav.is-open .nav-links a { padding: 0.85rem 0.4rem; font-size: 1.1rem; }
}

/* ============ 章节脚手架（编辑式：左对齐 + 大序号 + 发丝轨） ============ */
.ch { padding-block: var(--section-y); position: relative; overflow: clip; }
.ch--bg    { background: var(--bg); color: var(--ink); }
.ch--surface { background: var(--surface); color: var(--ink); }
.ch--sunk  { background: var(--surface-sunk); color: var(--ink); }
.ch--dark  { background: var(--ink-surface); color: var(--ink-on-dark); }
.ch-wrap { max-width: var(--container); margin-inline: auto; padding-inline: var(--pad-x); }
.ch-wrap.wide { max-width: var(--container-wide); }
.ch-wrap.narrow { max-width: var(--container-narrow); }

/* 编辑式 masthead：序号 / eyebrow / 大标题 / 引文，左对齐不对称 */
.masthead { display: grid; gap: var(--s-3); }
.masthead .ix { font-family: var(--num); font-size: var(--t-index); font-weight: var(--fw-hero); line-height: 1; color: var(--line-strong); letter-spacing: var(--ls-num); }
.ch--dark .masthead .ix { color: var(--ink-surface-2); }
.eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; font-size: var(--t-sm); font-weight: var(--fw-bold); color: var(--teal); letter-spacing: 0.04em; text-transform: none; }
.eyebrow::before { content: ""; width: 22px; height: 2px; background: currentColor; }
.ch--dark .eyebrow { color: var(--teal-300); }
.act-title { font-size: var(--t-act); font-weight: var(--fw-hero); line-height: var(--lh-title); letter-spacing: var(--ls-display); text-wrap: balance; word-break: keep-all; max-width: 18ch; }
.act-title .ac { color: var(--teal); }
.ch--dark .act-title .ac { color: var(--teal-300); }
.act-title .soft { color: var(--ink-3); }
.lead { margin-top: var(--s-2); max-width: 40ch; font-size: var(--t-lead); color: var(--ink-2); line-height: 1.5; }
.ch--dark .lead { color: var(--ink-on-dark-2); }

/* 链接 / 按钮 */
.lk { display: inline-flex; align-items: center; gap: 0.2rem; font-weight: var(--fw-med); color: var(--teal); }
.ch--dark .lk { color: var(--teal-300); }
.lk::after { content: "›"; transition: transform var(--dur) var(--ease-out-expo); }
.lk:hover::after { transform: translateX(3px); }
.btn { display: inline-flex; align-items: center; gap: 0.4rem; font-weight: var(--fw-med); line-height: 1; padding: 0.85rem 1.4rem; border-radius: var(--r-chip); transition: background var(--dur), transform var(--dur-fast), box-shadow var(--dur); }
.btn-fill { background: var(--cta-solid); color: var(--surface); box-shadow: var(--shadow-sm); }
.btn-fill:hover { background: var(--teal-press); box-shadow: var(--shadow-md); }
.btn-fill:active { transform: scale(var(--tap-scale)); }
.btn-ghost { background: transparent; color: var(--teal); box-shadow: inset 0 0 0 1.5px var(--line-teal); }
.btn-ghost:hover { background: var(--surface-teal); }
.ch--dark .btn-ghost { color: var(--teal-300); box-shadow: inset 0 0 0 1.5px var(--line-on-dark); }
.btn-row { margin-top: var(--rhythm-tight); display: flex; flex-wrap: wrap; gap: var(--s-3); }

/* 肌理工具类 */
.tex-blueprint { background-image: var(--tex-blueprint); }

/* ============ 页脚（复用现有四列结构 · 令牌化） ============ */
.footer { background: var(--ink-surface); color: var(--ink-on-dark-2); padding-block: var(--rhythm-tight) 2rem; font-size: var(--t-sm); }
.footer .ft-wrap { max-width: var(--container-wide); margin-inline: auto; padding-inline: var(--pad-x); }
.footer-grid { display: grid; grid-template-columns: 1.4fr repeat(3,1fr); gap: 2rem 1.5rem; padding-bottom: 1.6rem; border-bottom: var(--hairline-dark); }
.footer .brand { color: var(--ink-on-dark); margin-bottom: 0.6rem; }
.footer .brand-mark { background: var(--teal-300); }
.footer .brand-mark svg { color: var(--ink-surface); }
.footer-about { max-width: 30ch; line-height: 1.6; }
.footer-col h4 { color: var(--ink-on-dark); font-size: var(--t-sm); font-weight: var(--fw-med); margin-bottom: 0.5rem; }
.footer-col a { display: flex; align-items: center; min-height: 40px; color: var(--ink-on-dark-2); transition: color var(--dur); }
.footer-col a:hover { color: var(--teal-300); }
.footer-bottom { margin-top: 1.4rem; display: flex; flex-wrap: wrap; gap: 0.4rem 1.4rem; align-items: center; color: var(--ink-on-dark-2); }
.footer-bottom a { color: var(--ink-on-dark-2); }
.footer-bottom a:hover { color: var(--teal-300); }
@media (max-width: 760px) { .footer-grid { grid-template-columns: 1fr 1fr; } .footer-brandcol { grid-column: 1/-1; } }
