:root {
  /* ── 品牌色：Coresite / Badi Labs 自己的蓝（保留身份，不照搬 McKinsey 蓝）── */
  --brand: #2a52ff;        /* Coresite 蓝 */
  --brand-ink: #1c3bc4;
  --brand-soft: #eef1ff;

  /* ── 深蓝分量：McKinsey 气质的沉稳底色（hero / 视觉带）──────────────── */
  --navy: #051C2C;         /* 真 McKinsey 深蓝，做暗底白字区块 */
  --navy-2: #0a2a40;       /* 深蓝上的细分隔 / 卡片描边 */
  --navy-line: rgba(255, 255, 255, .14);
  --navy-soft: rgba(255, 255, 255, .66);

  --bg: #ffffff;
  --surface: #f7f8fb;
  --surface-2: #f0f2f7;
  --text: #14161c;
  --muted: #5b606e;
  --faint: #8a8f9c;
  --border: #e4e7ef;
  --border-strong: #d2d6e2;
  --radius: 12px;
  --radius-sm: 8px;

  /* ── 宽容器（McKinsey contentWidths 主值 1200px）+ 窄 prose ───────── */
  --maxw: 1200px;
  --prose: 760px;

  /* ── 字体栈：商业字体不嵌入，用 system / Inter / Helvetica Neue 近似 ──
     McKinsey Sans 是细体无衬线；这里用近似栈 + font-weight 300/400 还原气质。 */
  --font: "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", Roboto, Helvetica, Arial, sans-serif;
  --mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;

  /* ── design-language tokens (v2) ─ McKinsey 抽离值覆盖默认 ──────────── */

  /* layout-rhythm：大量留白、宽松节奏 */
  --section-pad: 96px;
  --hero-pad-top: 124px;
  --hero-pad-bottom: 108px;
  --container-pad: 32px;
  --grid-gap: 40px;        /* McKinsey grids gap 偏大 */
  --grid-cols: 3;          /* 三层架构走 3 列 */
  --footer-cols: 1.6fr 1fr;

  /* typography-scale：细体大标题、宽松行高、克制字距（McKinsey 300 字重）
     H1 大号 display；H2/H3 细体；正文 400。 */
  --fs-display: clamp(44px, 8vw, 92px);   /* hero 巨标题 */
  --fs-h1: clamp(36px, 6.4vw, 68px);
  --fs-h2: clamp(28px, 4.2vw, 44px);
  --fs-h3: clamp(20px, 2.4vw, 26px);
  --fs-body: 17px;
  --lh-body: 1.62;
  --lh-display: 1.1;
  --lh-heading: 1.16;
  --ls-tight: -.018em;     /* 克制字距，不收太紧 */
  --ls-display: -.022em;
  --fw-display: 300;       /* 细体大标题 = McKinsey 命脉 */
  --fw-heading: 300;
  --fw-body: 400;
  --fw-strong: 500;

  /* motion：克制、慢（McKinsey reveal 550–750ms；缓动柔和）────────────── */
  --ease-out: cubic-bezier(.22, .61, .36, 1);
  --ease-in-out: cubic-bezier(.4, 0, .2, 1);
  --dur-fast: 200ms;
  --dur-base: 650ms;       /* reveal 主时长，落在 550–750ms 区间 */
  --dur-page: 700ms;
  --reveal-distance: 22px;
  --hover-lift: -1px;

  /* imagery：CORE 图像约定。 */
  --img-radius: var(--radius);
  --img-ratio: 16/9;
  --img-filter: none;
  --img-overlay: 0;
}

@media (prefers-color-scheme: dark) {
  :root {
    --brand: #6f88ff;
    --brand-ink: #aab9ff;
    --brand-soft: #1a1f3a;

    /* 暗色下深蓝区块改用更深的近黑蓝，保持白字对比 */
    --navy: #03131e;
    --navy-2: #0a2233;
    --navy-line: rgba(255, 255, 255, .12);
    --navy-soft: rgba(255, 255, 255, .62);

    --bg: #0b0d12;
    --surface: #11141b;
    --surface-2: #171a23;
    --text: #eef0f6;
    --muted: #a3a9b8;
    --faint: #767c8c;
    --border: #222734;
    --border-strong: #2f3645;
  }
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  font-weight: var(--fw-body);
  color: var(--text);
  background: var(--bg);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); }
a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }
code { font-family: var(--mono); font-size: .86em; background: var(--surface-2); padding: .12em .4em; border-radius: 5px; }
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--brand); color: #fff; padding: 10px 16px; z-index: 100; }
.skip-link:focus { left: 0; }

/* Header — 极简、轻、克制 */
.site-header { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--bg) 86%, transparent); backdrop-filter: saturate(180%) blur(12px); border-bottom: 1px solid var(--border); }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; height: 72px; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); }
.brand { display: inline-flex; align-items: center; gap: 12px; color: var(--text); font-weight: 500; letter-spacing: -.01em; font-size: 18px; }
.brand:hover { text-decoration: none; }
.brand-mark { width: 16px; height: 16px; border-radius: 4px; background: var(--brand); box-shadow: inset 0 0 0 4px color-mix(in srgb, var(--brand) 35%, var(--bg)); }
.site-nav { display: flex; align-items: center; gap: 30px; font-size: 15px; }
.site-nav a { color: var(--muted); font-weight: 400; }
.site-nav a:hover { color: var(--text); text-decoration: none; }
.site-nav a.current { color: var(--text); }
.nav-llms { font-family: var(--mono); font-size: 13px; color: var(--brand) !important; }

/* Hero — 大号细体 display、巨留白 */
.hero { padding: var(--hero-pad-top) var(--container-pad) var(--hero-pad-bottom); max-width: var(--maxw); margin-inline: auto; }
.kicker { color: var(--brand); font-weight: var(--fw-strong); font-size: 14px; letter-spacing: .02em; margin: 0 0 28px; }
h1 { font-size: var(--fs-h1); line-height: var(--lh-display); letter-spacing: var(--ls-display); font-weight: var(--fw-display); margin: 0 0 28px; }
h1 em { font-style: normal; color: var(--brand); }
.lead { font-size: clamp(18px, 2.4vw, 23px); line-height: 1.5; font-weight: var(--fw-body); color: var(--muted); max-width: 62ch; margin: 0 0 16px; }
.lead strong { color: var(--text); font-weight: var(--fw-strong); }
.lead-claim { color: var(--text); }
.lead-claim strong { color: var(--brand); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 44px; }
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 28px; border-radius: 2px; font-weight: var(--fw-strong); font-size: 15px; border: 1px solid transparent; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.btn:hover { text-decoration: none; }
.btn-primary { background: var(--brand); color: #fff; }
.btn-primary:hover { background: var(--brand-ink); }
.btn-ghost { background: transparent; color: var(--text); border-color: var(--border-strong); }
.btn-ghost:hover { border-color: var(--brand); color: var(--brand); }

/* Sections — 大留白、宽容器 */
section { padding-block: var(--section-pad); }
.band { background: var(--surface); border-block: 1px solid var(--border); }
.section-head { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); }
.section-head.narrow { max-width: 900px; margin-inline: auto; }
h2 { font-size: var(--fs-h2); line-height: var(--lh-heading); letter-spacing: var(--ls-tight); font-weight: var(--fw-heading); margin: 0 0 20px; }
h2 em { font-style: normal; color: var(--brand); }
h3 { font-size: var(--fs-h3); line-height: var(--lh-heading); font-weight: 400; margin: 0 0 10px; letter-spacing: var(--ls-tight); }
.section-lead { color: var(--muted); font-size: clamp(17px, 2vw, 20px); line-height: 1.55; max-width: 62ch; margin: 0 0 12px; }
.eyebrow { font-family: var(--mono); font-size: 12.5px; color: var(--brand); letter-spacing: .12em; text-transform: uppercase; margin: 0 0 18px; }

/* ── 深蓝区块 utility（McKinsey 沉稳分量）──────────────────────────────
   把任意 section 加 .navy 即翻成深蓝底白字；hero 用 .hero-navy 全幅铺底。 */
.navy { background: var(--navy); color: #fff; }
.navy h1, .navy h2, .navy h3 { color: #fff; }
.navy .eyebrow { color: #fff; opacity: .72; }
.navy .kicker { color: #fff; opacity: .8; }
.navy .lead, .navy .section-lead, .navy p { color: var(--navy-soft); }
.navy .lead strong, .navy .lead-claim strong { color: #fff; }
.navy a { color: #fff; }
.navy .btn-ghost { color: #fff; border-color: var(--navy-line); }
.navy .btn-ghost:hover { border-color: #fff; color: #fff; }

/* hero 全幅深蓝：拉满左右，内部用 .hero 收回容器宽 */
.hero-navy { background: var(--navy); color: #fff; }
.hero-navy .hero { max-width: var(--maxw); margin-inline: auto; }
.hero-navy h1 { color: #fff; }
.hero-navy h1 em { color: #8fa6ff; }
.hero-navy .kicker { color: #fff; opacity: .82; }
.hero-navy .lead { color: var(--navy-soft); }
.hero-navy .lead strong { color: #fff; }
.hero-navy .lead-claim { color: #fff; }
.hero-navy .lead-claim strong { color: #8fa6ff; }
.hero-navy .btn-ghost { color: #fff; border-color: var(--navy-line); }
.hero-navy .btn-ghost:hover { border-color: #fff; color: #fff; }
.hero-navy .hairline { border: none; border-top: 1px solid var(--navy-line); width: 96px; margin: 0 0 30px; }

/* Three-layer cards（保留脚手架原语，重塑成 McKinsey 克制卡片） */
.layers { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); display: grid; grid-template-columns: repeat(var(--grid-cols), 1fr); gap: var(--grid-gap); }
.layer { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 36px 32px 32px; display: flex; flex-direction: column; gap: 12px; transition: border-color var(--dur-fast) var(--ease-out); }
.layer:hover { border-color: var(--border-strong); }
.layer-no { font-family: var(--mono); font-size: 13px; color: var(--brand); letter-spacing: .06em; }
.layer h3 { margin: 0; font-size: var(--fs-h3); font-weight: var(--fw-heading); }
.layer .role { color: var(--brand); font-weight: var(--fw-strong); font-size: 14px; }
.layer p { margin: 0; color: var(--muted); font-size: 15px; line-height: 1.6; }
.layer .tech { margin-top: auto; font-size: 12.5px; color: var(--faint); font-family: var(--mono); border-top: 1px solid var(--border); padding-top: 14px; }
.layer .tech b { color: var(--text); font-weight: var(--fw-strong); }

/* Generic feature/principle grid */
.grid-3 { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); display: grid; grid-template-columns: repeat(var(--grid-cols), 1fr); gap: var(--grid-gap); }
.card { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 22px; }
.card p { margin: 0; color: var(--muted); font-size: 14.5px; }

/* Loop / chain（保留脚手架原语，重塑成 McKinsey 细线胶囊） */
.chain { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.chain span { background: var(--bg); border: 1px solid var(--border); border-radius: 2px; padding: 11px 18px; font-size: 14.5px; font-weight: var(--fw-body); color: var(--text); }
.chain span.hot { border-color: var(--brand); color: var(--brand); font-weight: var(--fw-strong); }
.chain i { color: var(--faint); font-style: normal; font-size: 18px; }

/* Status（保留脚手架原语，重塑成 McKinsey 克制卡片） */
.status-card { max-width: 820px; margin-inline: auto; margin-block: 0; }
.status-band .section-head { margin-bottom: 24px; }
.status-inner { background: var(--bg); border: 1px solid var(--border); border-left: 3px solid var(--brand); border-radius: var(--radius); padding: 36px 40px; max-width: 820px; margin-inline: auto; }
.status-badge { display: inline-block; font-size: 13px; font-weight: var(--fw-strong); color: var(--brand-ink); background: var(--brand-soft); padding: 6px 14px; border-radius: 999px; margin: 0 0 18px; }
.status-list { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 13px; }
.status-list li { display: flex; align-items: baseline; gap: 12px; font-size: 15.5px; }
.dot { width: 9px; height: 9px; border-radius: 50%; flex: none; transform: translateY(1px); }
.dot-done { background: #1d9e75; }
.dot-now { background: var(--brand); box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 22%, transparent); }
.dot-todo { background: var(--border-strong); }
.dot-gate { background: #ef9f27; }

/* Footer */
.site-footer { border-top: 1px solid var(--border); background: var(--surface); margin-top: 0; padding: 64px 0 40px; }
.footer-inner { display: grid; grid-template-columns: var(--footer-cols); gap: 40px; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--container-pad); }
.footer-brand { font-weight: var(--fw-strong); font-size: 18px; margin: 0 0 10px; }
.footer-note { color: var(--muted); font-size: 14.5px; line-height: 1.6; margin: 0; max-width: 42ch; }
.footer-h { font-weight: var(--fw-strong); font-size: 13px; color: var(--faint); margin: 0 0 14px; letter-spacing: .02em; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; font-size: 14.5px; color: var(--muted); }
.footer-fine { color: var(--faint); font-size: 13px; margin: 44px auto 0; padding-top: 26px; border-top: 1px solid var(--border); max-width: var(--maxw); padding-inline: var(--container-pad); }

/* Whitepaper hub（保留脚手架原语） */
.paper-hero { padding: 96px 32px 40px; max-width: var(--maxw); margin-inline: auto; }
.paper-list { display: grid; gap: 14px; margin-top: 8px; }
.paper-item { display: flex; align-items: center; justify-content: space-between; gap: 16px; background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 24px; transition: border-color var(--dur-fast) var(--ease-out); }
.paper-item:hover { border-color: var(--border-strong); }
.paper-item .pi-main { display: flex; flex-direction: column; gap: 4px; }
.paper-item .pi-actions { display: flex; align-items: center; gap: 12px; flex: none; }
.paper-item .pi-pdf { font-size: 13px; font-weight: var(--fw-strong); color: var(--brand); border: 1px solid var(--brand); border-radius: 999px; padding: 5px 13px; white-space: nowrap; }
.paper-item .pi-pdf:hover { background: var(--brand); color: #fff; text-decoration: none; }
.paper-item .pi-title { font-weight: var(--fw-strong); color: var(--text); font-size: 16px; }
.paper-item .pi-title:hover { color: var(--brand); }
.paper-item .pi-meta { color: var(--faint); font-size: 13px; font-family: var(--mono); }
.paper-item .pi-badge { font-size: 12px; font-weight: var(--fw-strong); padding: 4px 11px; border-radius: 999px; background: var(--brand-soft); color: var(--brand-ink); white-space: nowrap; }
.paper-item .pi-badge.old { background: var(--surface-2); color: var(--muted); }

/* Prose (rendered markdown — content layer reading)：克制字阶 + 宽松行高 */
.prose { max-width: var(--prose); margin-inline: auto; padding: 8px 32px 96px; }
.prose-head { max-width: var(--prose); margin-inline: auto; padding: 72px 32px 0; }
.prose-head .version-line { font-family: var(--mono); font-size: 13px; color: var(--faint); margin-top: 10px; }
.prose h1 { font-size: clamp(30px, 5vw, 46px); font-weight: var(--fw-heading); letter-spacing: var(--ls-tight); margin: 40px 0 16px; line-height: var(--lh-heading); }
.prose h2 { font-size: clamp(24px, 3vw, 32px); font-weight: var(--fw-heading); letter-spacing: var(--ls-tight); margin: 52px 0 16px; padding-top: 24px; border-top: 1px solid var(--border); line-height: var(--lh-heading); }
.prose h3 { font-size: 20px; font-weight: 400; margin: 32px 0 10px; }
.prose p { margin: 17px 0; line-height: 1.74; }
.prose ul, .prose ol { padding-left: 22px; margin: 17px 0; }
.prose li { margin: 8px 0; line-height: 1.7; }
.prose blockquote { margin: 26px 0; padding: 16px 24px; border-left: 3px solid var(--brand); background: var(--surface); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; color: var(--text); font-size: 16px; }
.prose blockquote p { margin: 4px 0; }
.prose table { width: 100%; border-collapse: collapse; margin: 26px 0; font-size: 14.5px; display: block; overflow-x: auto; }
.prose th, .prose td { border: 1px solid var(--border); padding: 10px 14px; text-align: left; vertical-align: top; }
.prose th { background: var(--surface-2); font-weight: var(--fw-strong); }
.prose hr { border: none; border-top: 1px solid var(--border); margin: 44px 0; }
.prose code { background: var(--surface-2); }
.back-link { display: inline-block; margin-bottom: 8px; font-size: 14px; }

/* ── motion primitive: opt-in scroll reveal ───────────────────────────
   渐进增强：默认无 .reveal class 时内容全可见、零 JS 依赖。
   <Reveal> 组件给元素加 .reveal，IntersectionObserver 命中后加 .is-in。
   时长走 --dur-base（650ms，McKinsey 区间的慢揭示）。
   位移类动效，由文件末尾 prefers-reduced-motion 守卫强制中和。 */
.reveal {
  opacity: 0;
  transform: translateY(var(--reveal-distance));
  transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.reveal.is-in { opacity: 1; transform: none; }

/* ── imagery convention utilities ─────────────────────────────────────
   CORE 图像约定承接器。缺省安全（overlay 0 / filter none）= 不影响无图页面。 */
.media { aspect-ratio: var(--img-ratio); border-radius: var(--img-radius); overflow: hidden; }
.media :is(img, picture) { width: 100%; height: 100%; object-fit: cover; display: block; }
.img-full { width: 100%; }
.img-contained { max-width: var(--maxw); margin-inline: auto; }
.img-overlay { position: relative; }
.img-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--brand) calc(var(--img-overlay) * 1%), transparent);
}
.img-grayscale { filter: grayscale(1); }

/* ── 图片前置：抽象品牌视觉（生成式「内容中枢 / 业务入口网络」）────────── */
.hero-navy { position: relative; overflow: hidden; isolation: isolate; }
.hero-art {
  position: absolute; inset: 0; z-index: 0;
  background: url('/images/hero-mesh.svg') no-repeat center right / cover;
}
/* 左侧文字区做导向性深蓝渐变遮罩，保证细体大字与 lead 高对比可读 */
.hero-art::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(100deg,
    var(--navy) 0%, var(--navy) 30%,
    color-mix(in srgb, var(--navy) 72%, transparent) 60%,
    color-mix(in srgb, var(--navy) 22%, transparent) 100%);
}
.hero-navy .hero { position: relative; z-index: 1; }

/* 全幅视觉带：分隔 section，给「图片前置」的视觉分量 */
.art-band {
  height: 300px;
  background: url('/images/band-mesh.svg') no-repeat center center / cover;
  background-color: var(--navy);
  border-block: 1px solid var(--border);
}
@media (max-width: 700px) { .art-band { height: 200px; } }

@media (max-width: 860px) {
  :root {
    --section-pad: 64px;
    --hero-pad-top: 88px;
    --hero-pad-bottom: 72px;
    --container-pad: 22px;
    --grid-gap: 20px;
  }
  .site-nav a.hide-sm { display: none; }
  .layers, .grid-3, .footer-inner { grid-template-columns: 1fr; }
}

/* ── accessibility: respect prefers-reduced-motion ────────────────────
   冻结契约：动效必须尊重 prefers-reduced-motion。
   除守 .reveal 外，中和既有 html scroll-behavior 与 hover 过渡。 */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .btn, .layer, .paper-item { transition: none; }
}
