/* ===== JsVmp Protect · 精密保险库 · 商业浅色主题 ===== */
:root {
  /* 暖白纸感背景 — 非纯白,非通用 SaaS 灰 */
  --paper: #F5F1E7;
  --paper-deep: #ECE4D0;
  --surface: #FFFFFF;
  --surface-sunk: #FAF7EF;
  --line: #E3DAC2;
  --line-strong: #D2C5A3;

  /* 墨色文字阶(第二轮独立评审发现 --ink-2 对比度仅 4.04:1,未达 WCAG AA 正文 4.5:1 门槛,
     已下修到 6.5:1+) */
  --ink: #1B190F;
  --ink-1: #46422F;
  --ink-2: #55503A;
  --ink-3: #8C8467;

  /* 主强调 — 保险库深绿(精密、信任、非蓝紫) */
  --vault: #16402E;
  --vault-bright: #1F5A40;
  --vault-dim: rgba(22, 64, 46, 0.08);
  --vault-line: rgba(22, 64, 46, 0.32);
  --vault-ink: #0E2A1E;

  /* 次强调 — 黄铜(印章、警示、贵重感)。--brass 用于图标/大字/装饰性描边;
     --brass-text 专供小号正文文字,比 --brass 更深,避免 11~12.5px 小字对比度不足 */
  --brass: #96631E;
  --brass-text: #7A4F16;
  --brass-dim: rgba(150, 99, 30, 0.1);
  --brass-line: rgba(150, 99, 30, 0.32);

  --danger: #96392B;
  --danger-dim: rgba(150, 57, 43, 0.08);
  --danger-line: rgba(150, 57, 43, 0.3);

  --sans: 'Public Sans', 'Noto Sans SC', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif;
  --serif: var(--sans);
  --mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* 字号阶梯(第二轮独立评审发现此前近 20 个字号值挤在一起,缺乏节奏,收敛到 8 档) */
  --fs-2xs: 11px;
  --fs-xs: 12.5px;
  --fs-sm: 13.5px;
  --fs-base: 15px;
  --fs-md: 17px;
  --fs-lg: 19px;
  --fs-xl: 24px;
  --fs-2xl: 32px;
  --fs-hero: 50px;

  --r: 10px;
  --r-sm: 6px;
  /* 阴影只保留给工作区面板与主 CTA(第二轮独立评审发现:此前全站容器统一套用同一套阴影,
     阴影失去了"这是重点"的信号意义)。次要容器(能力条目/管线卡片/演示区/规范说明)一律
     改为纯描边,不再叠加阴影。 */
  --shadow-card: 0 1px 2px rgba(27, 25, 15, 0.04), 0 10px 28px -18px rgba(27, 25, 15, 0.22);
  --shadow-lift: 0 1px 2px rgba(27, 25, 15, 0.05), 0 18px 40px -20px rgba(27, 25, 15, 0.28);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--paper);
  color: var(--ink-1);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.001em;
  position: relative;
  min-height: 100vh;
}

/* ===== 背景纹理:暖纸纹 + 蓝图细网格 ===== */
.noise {
  position: fixed; inset: 0; z-index: -2; pointer-events: none; opacity: 0.035; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' /%3E%3C/svg%3E");
}
.grid-bg {
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background-image:
    linear-gradient(rgba(22,64,46,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(22,64,46,0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 85% 60% at 50% 0%, #000 25%, transparent 78%);
}
body::before {
  content: ''; position: fixed; top: -260px; left: 50%; transform: translateX(-50%);
  width: 1000px; height: 520px; z-index: -1; pointer-events: none;
  background: radial-gradient(ellipse, rgba(22,64,46,0.06), transparent 62%);
  filter: blur(30px);
}

/* ===== 导航 ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(245, 241, 231, 0.82);
  backdrop-filter: blur(14px) saturate(1.1);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  max-width: 1520px; margin: 0 auto; padding: 0 48px; height: 64px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: 11px; text-decoration: none; color: var(--ink); }
.logo-mark {
  color: var(--paper); display: grid; place-items: center;
  width: 32px; height: 32px; border-radius: 7px;
  background: var(--vault); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12);
}
.logo-text { font-family: var(--serif); font-weight: 600; font-size: 17px; letter-spacing: -0.01em; }
.logo-text i { color: var(--vault); font-style: normal; font-weight: 700; }
.nav-links { display: flex; gap: 30px; }
.nav-links a {
  color: var(--ink-2); text-decoration: none; font-size: 13.5px; font-weight: 500;
  transition: color .15s;
}
.nav-links a:hover { color: var(--ink); }
.nav-meta { display: flex; align-items: center; gap: 10px; }
.lang-toggle {
  height: 30px; padding: 0 12px; border-radius: 999px;
  border: 1px solid var(--line-strong); background: var(--surface);
  color: var(--ink-1); font-family: var(--mono); font-size: 11px; cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
.lang-toggle:hover, .lang-toggle:focus-visible {
  color: var(--vault); border-color: var(--vault-line); background: var(--vault-dim); outline: none;
}
.ver {
  font-family: var(--mono); font-size: 11px; color: var(--ink-3);
  padding: 3px 8px; border: 1px solid var(--line); border-radius: 4px;
}
.status-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--vault-bright);
  box-shadow: 0 0 0 3px var(--vault-dim);
}

/* ===== 容器 ===== */
.container { max-width: 1520px; margin: 0 auto; padding: 0 48px; }

/* ===== HERO =====
   第二轮独立评审发现:"居中大标题 + 副标题 + 统计条"是最通用的 SaaS/AI 落地页公式,换任何
   配色都长一个样。改为非对称构图——左侧文案,右侧一个真实的"加密前 / 加密后"代码对比展示,
   用产品本身的能力(而不是空洞的统计数字)作为视觉锚点。 */
.hero { padding: 76px 0 64px; position: relative; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 60px; align-items: center; }
.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: var(--fs-2xs); font-weight: 500;
  color: var(--vault); padding: 6px 14px;
  background: var(--surface); border: 1px solid var(--vault-line);
  border-radius: 999px; margin-bottom: 28px; text-transform: uppercase; letter-spacing: 0.06em;
}
.tag-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--vault); }
.hero-title {
  font-family: var(--serif); font-size: var(--fs-hero); font-weight: 700; line-height: 1.12;
  letter-spacing: -0.025em; color: var(--ink);
}
.hero-accent { color: var(--vault); font-weight: 700; }
.hero-lead {
  max-width: 480px; margin: 22px 0 0;
  color: var(--ink-2); font-size: var(--fs-md); line-height: 1.7;
}
.hero-metrics { display: flex; gap: 36px; margin-top: 40px; }
.metric { text-align: left; }
.metric b {
  display: block; font-family: var(--serif); font-size: var(--fs-2xl); font-weight: 700;
  color: var(--vault); letter-spacing: -0.01em; line-height: 1;
}
.metric span { font-size: var(--fs-2xs); color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.05em; }

/* 加密前后代码对比展示(取代原来空洞的统计条,用真实能力做视觉锚点) */
.hero-showcase { display: flex; flex-direction: column; gap: 12px; }
.showcase-panel {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  overflow: hidden;
}
.showcase-label {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: var(--fs-2xs); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.07em; color: var(--ink-3);
}
.showcase-label b { color: var(--ink-1); font-weight: 600; text-transform: none; letter-spacing: 0; }
.showcase-after .showcase-label { background: var(--vault-dim); }
.showcase-after .showcase-label b { color: var(--vault); }
.showcase-code {
  margin: 0; padding: 16px; font-family: var(--mono); font-size: 12px; line-height: 1.65;
  color: var(--ink-1); white-space: pre-wrap; word-break: break-all;
}
.showcase-after { background: linear-gradient(165deg, rgba(22,64,46,0.035), rgba(150,99,30,0.02)); }
.showcase-after .showcase-code { color: var(--ink-2); font-size: 10.5px; letter-spacing: -0.01em; opacity: 0.9; }
.showcase-arrow {
  align-self: center; display: flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: var(--fs-2xs); color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.06em;
}
.showcase-arrow svg { color: var(--vault); }

/* ===== 工作区 =====
   第二轮独立评审发现:严格 1fr/1fr 对称两栏是最标准的"左表单右预览"工具模板结构,且两栏用
   完全相同的白色卡片,没有制造"输入安静/输出有技术感"的对比。改为不对称比例,输出面板换一种
   表面处理(暖调更深的底色 + 顶部细线强调),与输入面板形成区分。 */
.workspace {
  display: grid; grid-template-columns: 0.86fr 1.14fr; gap: 20px;
  margin: 48px 0 24px;
}
.panel {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r); padding: 24px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  min-height: 460px;
  position: relative;
}
/* 输出面板(第二个 panel):偏暖的更深底色 + 顶部保险库绿细线,和输入面板的纯白形成区分 */
.workspace .panel:nth-child(2) {
  background: var(--surface-sunk); border-top: 2px solid var(--vault);
}
.panel-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 16px; margin-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.panel-title {
  font-family: var(--serif); font-size: 14.5px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.005em;
}
.panel-sub { font-size: 11.5px; color: var(--ink-3); font-family: var(--mono); }
.panel-sub.mono { color: var(--vault); }

/* 免费/付费分级说明 + 激活码输入 */
.tier-banner {
  margin-bottom: 18px; padding: 14px 16px; border-radius: var(--r-sm);
  background: var(--brass-dim); border: 1px solid var(--brass-line);
}
.tier-banner-text { font-size: var(--fs-xs); color: var(--ink-1); line-height: 1.6; }
.tier-banner-text b { color: var(--ink); font-weight: 700; }
.lock-icon { color: var(--brass-text); vertical-align: -1px; margin: 0 1px; }
.tier-code-row { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
.tier-code-input {
  flex: 1; padding: 8px 11px; border-radius: var(--r-sm);
  background: var(--surface); border: 1px solid var(--line-strong);
  color: var(--ink); font-family: var(--mono); font-size: var(--fs-xs); outline: none;
  letter-spacing: 0.03em; transition: border-color .15s;
}
.tier-code-input::placeholder { color: var(--ink-3); letter-spacing: normal; }
.tier-code-input:focus { border-color: var(--vault-line); }
.tier-code-status { font-family: var(--mono); font-size: var(--fs-2xs); white-space: nowrap; }
.tier-code-status.ok { color: var(--vault); }
.tier-code-status.err { color: var(--danger); }
.tier-code-status.checking { color: var(--ink-3); }
.tier-buy-hint { margin-top: 9px; font-size: var(--fs-2xs); color: var(--ink-2); }
/* 限时免费促销条——用黄铜色而不是保险库绿,和下方的功能说明拉开视觉层级,读起来像"活动公告"
   而不是常规功能说明的延续。 */
.tier-promo-note {
  margin-top: 10px; padding: 8px 12px; border-radius: var(--r-sm);
  background: var(--brass-dim); border: 1px solid var(--brass-line);
  font-size: var(--fs-2xs); color: var(--brass-text); line-height: 1.6;
}
.tier-promo-note b { color: var(--ink); }
/* 锁定标记出现在下拉选项/字段标签里,视觉上跟随文字颜色即可,不需要单独样式 */
.field label .lock-icon { color: var(--brass-text); }

/* 拖拽区 */
.dropzone {
  border: 1.5px dashed var(--line-strong); border-radius: var(--r);
  padding: 34px; cursor: pointer; transition: all .18s ease;
  background: var(--surface-sunk); outline: none;
}
.dropzone:hover, .dropzone:focus-visible {
  border-color: var(--vault-line); background: var(--vault-dim);
}
.dropzone.dragover {
  border-color: var(--vault); border-style: solid;
  background: var(--vault-dim);
}
.dz-grid { display: flex; align-items: center; gap: 18px; }
.dz-icon { color: var(--vault); flex-shrink: 0; }
.dz-title { font-size: 14.5px; font-weight: 500; color: var(--ink); }
.dz-or { color: var(--ink-3); font-size: 13px; margin: 0 4px; }
.dz-link { color: var(--vault); text-decoration: underline; text-underline-offset: 3px; font-weight: 600; }
.dz-hint { font-size: 12px; color: var(--ink-3); margin-top: 3px; }

/* 选项 */
.opts { margin-top: 22px; display: flex; flex-direction: column; gap: 18px; }
.opt-row { display: flex; flex-wrap: wrap; gap: 20px; }
.toggle { display: flex; align-items: center; gap: 9px; cursor: pointer; }
.toggle input { position: absolute; opacity: 0; pointer-events: none; }
.toggle-track {
  width: 32px; height: 18px; border-radius: 999px; background: var(--paper-deep);
  border: 1px solid var(--line-strong); position: relative; transition: all .18s;
  flex-shrink: 0;
}
.toggle-track::after {
  content: ''; position: absolute; top: 1px; left: 1px;
  width: 14px; height: 14px; border-radius: 50%; background: var(--surface);
  box-shadow: 0 1px 2px rgba(27,25,15,0.25);
  transition: all .18s;
}
.toggle input:checked + .toggle-track { background: var(--vault); border-color: var(--vault); }
.toggle input:checked + .toggle-track::after { left: 15px; }
.toggle-text { font-size: 13.5px; color: var(--ink-1); }
.opt-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 11px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.field input, .field select {
  padding: 9px 12px; border-radius: var(--r-sm);
  background: var(--surface-sunk); border: 1px solid var(--line);
  color: var(--ink); font-family: var(--mono); font-size: 12.5px; outline: none;
  transition: border-color .15s, background .15s;
}
.field input::placeholder { color: var(--ink-3); }
.field input:focus, .field select:focus { border-color: var(--vault-line); background: var(--surface); }
.field-hint { font-size: 11.5px; color: var(--ink-3); line-height: 1.5; }
.profile-warn {
  padding: 9px 12px; border-radius: var(--r-sm);
  background: var(--brass-dim); border: 1px solid var(--brass-line);
  color: var(--brass-text); font-size: var(--fs-xs); line-height: 1.5;
}
.advanced-options {
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  background: var(--surface-sunk);
}
.advanced-options summary {
  cursor: pointer;
  color: var(--ink-2);
  font-size: 12.5px;
  font-weight: 500;
  user-select: none;
}
.advanced-grid { margin-top: 12px; }
.field-toggle { align-self: end; padding-bottom: 6px; }

/* 执行按钮 */
.btn-run {
  margin-top: auto; padding-top: 22px;
}
.btn-run button, .btn-run {
  width: 100%; height: 46px; border: none; border-radius: var(--r-sm);
  background: var(--vault); color: #F3EFE2; font-family: var(--sans);
  font-size: 14.5px; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 9px;
  transition: all .15s; letter-spacing: 0.005em;
  box-shadow: 0 1px 2px rgba(22,64,46,0.15), 0 8px 20px -8px rgba(22,64,46,0.45);
}
.btn-run:hover:not(:disabled) { background: var(--vault-bright); box-shadow: 0 1px 2px rgba(22,64,46,0.2), 0 10px 24px -8px rgba(22,64,46,0.55); transform: translateY(-1px); }
.btn-run:disabled { background: var(--line); color: var(--ink-3); cursor: not-allowed; box-shadow: none; }
.btn-run-spinner {
  width: 15px; height: 15px; border: 2px solid rgba(243,239,226,0.35);
  border-top-color: #F3EFE2; border-radius: 50%; animation: spin .65s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* mini 按钮 */
.btn-mini {
  padding: 6px 14px; font-size: 12px; font-weight: 600; cursor: pointer;
  border-radius: var(--r-sm); border: 1px solid var(--line-strong);
  background: var(--surface); color: var(--ink-1); transition: all .15s;
  font-family: var(--sans);
}
.btn-mini:hover { color: var(--ink); border-color: var(--ink-3); background: var(--paper-deep); }
.btn-mini.primary { background: var(--vault); color: #F3EFE2; border-color: var(--vault); }
.btn-mini.primary:hover { background: var(--vault-bright); }

/* 状态条 */
.status {
  margin-top: 15px; padding: 11px 14px; border-radius: var(--r-sm);
  font-size: 13px; font-family: var(--mono);
}
.status.ok { background: var(--vault-dim); border: 1px solid var(--vault-line); color: var(--vault); }
.status.err { background: var(--danger-dim); border: 1px solid var(--danger-line); color: var(--danger); }
.status.info { background: var(--surface-sunk); border: 1px solid var(--line); color: var(--ink-1); }

/* 结果区 */
.result-empty { flex: 1; display: grid; place-items: center; gap: 14px; text-align: center; }
.empty-glyph {
  font-family: var(--mono); font-size: 38px; font-weight: 600;
  color: var(--ink-3); opacity: 0.4; letter-spacing: -0.03em;
}
.empty-text { font-size: 13px; color: var(--ink-3); }
.result-content { display: flex; flex-direction: column; gap: 18px; flex: 1; }

.stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 9px;
}
.stat-cell {
  background: var(--surface-sunk); border: 1px solid var(--line);
  border-radius: var(--r-sm); padding: 10px 12px;
}
.stat-k { font-size: var(--fs-2xs); color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; }
.stat-v { font-family: var(--mono); font-size: var(--fs-base); font-weight: 600; color: var(--ink); margin-top: 3px; }
.stat-v.acc { color: var(--vault); }
.stat-v.warn { color: var(--brass-text); }
.result-warnings {
  border: 1px solid var(--brass-line);
  background: var(--brass-dim);
  color: var(--brass-text);
  border-radius: var(--r-sm);
  padding: 11px 13px;
  font-size: 12px;
  line-height: 1.55;
}

.code-wrap { display: flex; flex-direction: column; gap: 10px; flex: 1; min-height: 0; }
.code-bar { display: flex; align-items: center; justify-content: space-between; }
.code-name { font-family: var(--mono); font-size: 12px; color: var(--ink-2); }
.code-actions { display: flex; gap: 8px; }
.code-view {
  flex: 1; max-height: 380px; overflow: auto; margin: 0;
  background: var(--surface-sunk); border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: 15px; font-family: var(--mono); font-size: 11.5px; line-height: 1.65;
  color: var(--ink-1); white-space: pre-wrap; word-break: break-all;
}
.code-view::-webkit-scrollbar { width: 8px; height: 8px; }
.code-view::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 4px; }
.code-view::-webkit-scrollbar-track { background: transparent; }

/* ===== 管线 / Engine ===== */
.engine, .caps, .html-demo { padding: 80px 0 36px; }
.section-head { margin-bottom: 44px; max-width: 680px; }
.section-kicker {
  display: inline-block; font-family: var(--mono); font-size: 11.5px;
  color: var(--vault); text-transform: uppercase; letter-spacing: 0.09em;
  margin-bottom: 14px; font-weight: 600;
}
.section-title {
  font-family: var(--serif); font-size: 32px; font-weight: 700; color: var(--ink);
  letter-spacing: -0.015em; line-height: 1.22;
}
.section-desc { margin-top: 16px; color: var(--ink-2); font-size: 15px; line-height: 1.7; }
.section-desc code { font-family: var(--mono); background: var(--surface-sunk); padding: 1.5px 7px; border-radius: 4px; font-size: 12.5px; color: var(--vault); border: 1px solid var(--line); }

.pipeline { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pipe-step {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  padding: 28px 26px; position: relative; transition: border-color .2s, transform .2s;
}
.pipe-step:hover { border-color: var(--vault-line); transform: translateY(-2px); }
.pipe-num {
  font-family: var(--mono); font-size: var(--fs-xl); font-weight: 700;
  color: var(--vault); margin-bottom: 16px; letter-spacing: -0.01em;
}
.pipe-step h3 { font-family: var(--serif); font-size: var(--fs-lg); font-weight: 600; color: var(--ink); margin-bottom: 11px; letter-spacing: -0.01em; }
.pipe-step p { color: var(--ink-2); font-size: var(--fs-sm); line-height: 1.65; }
.pipe-step code { font-family: var(--mono); background: var(--surface-sunk); padding: 1px 6px; border-radius: 3px; font-size: var(--fs-xs); color: var(--vault); }

/* ===== Capabilities =====
   第二轮独立评审发现:四张视觉雷同的图标卡片连续排列是最典型的"AI 卡片阵"。改为横向规格表
   (左列图标+标题,右列说明,行间细线分隔),呼应产品本身"技术规格文档"的调性,而不是营销
   落地页常见的功能卡片墙。 */
.caps-grid {
  display: flex; flex-direction: column;
  border: 1px solid var(--line); border-radius: var(--r); background: var(--surface);
  overflow: hidden;
}
.cap {
  display: grid; grid-template-columns: 240px 1fr; gap: 28px; align-items: center;
  padding: 22px 26px; border-bottom: 1px solid var(--line);
}
.cap:last-child { border-bottom: none; }
.cap-head { display: flex; align-items: center; gap: 14px; }
.cap-icon {
  color: var(--vault); flex-shrink: 0;
  width: 34px; height: 34px; display: grid; place-items: center;
  background: var(--vault-dim); border-radius: var(--r-sm); border: 1px solid var(--vault-line);
}
.cap h4 { font-family: var(--serif); font-size: var(--fs-md); font-weight: 600; color: var(--ink); }
.cap p { font-size: var(--fs-sm); color: var(--ink-2); line-height: 1.6; }

/* ===== HTML Demo ===== */
.demo-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.demo-layout-single { grid-template-columns: 1fr; }
.demo-col { display: flex; flex-direction: column; gap: 10px; min-height: 0; }
.demo-tip {
  font-size: 12.5px; color: var(--ink-2); line-height: 1.6; padding: 12px 15px;
  background: var(--surface-sunk); border: 1px solid var(--line); border-radius: var(--r-sm);
}
.demo-tip code { font-family: var(--mono); background: var(--surface); padding: 1px 6px; border-radius: 4px; font-size: 11.5px; color: var(--vault); border: 1px solid var(--line); }

/* 编辑器工具栏 */
.demo-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 15px; background: var(--surface-sunk); border: 1px solid var(--line);
  border-bottom: none; border-radius: var(--r) var(--r) 0 0;
}
.demo-tabs { display: flex; gap: 4px; }
.demo-tab {
  font-family: var(--mono); font-size: 11.5px; color: var(--ink-2);
  padding: 3px 9px; border-radius: 4px;
}
.demo-tab.active { color: var(--vault); background: var(--vault-dim); font-weight: 600; }
.demo-lang {
  font-family: var(--mono); font-size: 10.5px; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.06em;
}

/* CodeMirror 代码编辑器(浅色) */
.editor-wrap {
  position: relative; border: 1px solid var(--line);
  border-radius: 0 0 var(--r) var(--r); overflow: hidden; background: var(--surface);
}
.cm-host { width: 100%; }
.editor-wrap:focus-within { border-color: var(--vault-line); }
.CodeMirror {
  height: auto !important; background: var(--surface) !important; color: var(--ink-1) !important;
  font-family: var(--mono) !important; font-size: 12.5px !important; line-height: 1.7 !important;
}
.CodeMirror-vscrollbar, .CodeMirror-hscrollbar { display: none !important; }
.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { display: none !important; }
.CodeMirror-scroll { overflow: hidden !important; }
.CodeMirror-sizer { border-right-width: 0 !important; padding-bottom: 0 !important; margin-bottom: 0 !important; }
.CodeMirror-gutters { background: var(--surface-sunk) !important; border-right: 1px solid var(--line) !important; }
.CodeMirror-linenumber { color: var(--ink-3) !important; font-size: 11px !important; padding: 0 8px 0 6px !important; }
.CodeMirror-cursor { border-left: 1.5px solid var(--vault) !important; }
.CodeMirror-selected { background: rgba(22,64,46,0.12) !important; }
.CodeMirror-focused .CodeMirror-selected { background: rgba(22,64,46,0.16) !important; }
.CodeMirror-activeline-background { background: rgba(22,64,46,0.035) !important; }
.CodeMirror-matchingbracket { color: var(--vault) !important; text-decoration: underline; text-decoration-color: var(--vault); }
/* 语法高亮配色(与暖色板一致的浅色方案) */
.cm-s-default .cm-keyword { color: #8A3B7A !important; font-weight: 600; }
.cm-s-default .cm-string { color: #1F6B45 !important; }
.cm-s-default .cm-comment { color: var(--ink-3) !important; font-style: italic; }
.cm-s-default .cm-tag { color: #96392B !important; }
.cm-s-default .cm-attribute { color: var(--brass-text) !important; }
.cm-s-default .cm-number { color: #B15A1F !important; }
.cm-s-default .cm-variable { color: var(--ink) !important; }
.cm-s-default .cm-def { color: #2A5D8C !important; }
.cm-s-default .cm-property { color: #2A5D8C !important; }
.cm-s-default .cm-atom { color: #B15A1F !important; }
.cm-s-default .cm-meta { color: var(--ink-3) !important; }

/* highlight.js(静态代码示例)浅色配色,呼应整体暖色板 */
.hljs { background: transparent !important; color: var(--ink-1) !important; }
.hljs-keyword, .hljs-built_in { color: #8A3B7A; font-weight: 600; }
.hljs-string { color: #1F6B45; }
.hljs-comment { color: var(--ink-3); font-style: italic; }
.hljs-tag, .hljs-name { color: #96392B; }
.hljs-attr, .hljs-attribute { color: var(--brass-text); }
.hljs-number, .hljs-literal { color: #B15A1F; }
.hljs-title, .hljs-function .hljs-title { color: #2A5D8C; }
.hljs-params { color: var(--ink-1); }
.hljs-punctuation { color: var(--ink-2); }

/* ===== Footer ===== */
.footer {
  margin-top: 88px; border-top: 1px solid var(--line); background: var(--paper-deep);
}
.footer-inner {
  max-width: 1520px; margin: 0 auto; padding: 28px 48px;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12.5px; color: var(--ink-3);
}
.footer-warn { font-family: var(--mono); }

/* ===== 响应式 ===== */
@media (max-width: 900px) {
  .nav-inner { padding: 0 20px; }
  .nav-links { display: none; }
  .container { padding: 0 20px; }
  .hero { padding: 60px 0 40px; }
  .hero-title { font-size: 38px; }
  .hero-metrics { flex-wrap: wrap; }
  .metric { padding: 16px 22px; }
  .workspace { grid-template-columns: 1fr; }
  .pipeline { grid-template-columns: 1fr; }
  .caps-grid { grid-template-columns: 1fr 1fr; }
  .demo-layout { grid-template-columns: 1fr; }
  .opt-fields { grid-template-columns: 1fr; }
  .spec-grid { grid-template-columns: 1fr; }
  .usage-doc { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { flex-direction: column; gap: 8px; padding: 22px 20px; text-align: center; }
}
@media (max-width: 560px) {
  .caps-grid { grid-template-columns: 1fr; }
  .hero-title { font-size: 30px; }
}

/* ===== 规范说明区 ===== */
.demo-help {
  margin-top: 22px; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r); padding: 20px 24px;
}
.demo-help summary { cursor: pointer; font-size: 14px; color: var(--ink-1); font-weight: 600; letter-spacing: -0.005em; }
.demo-help summary:hover { color: var(--ink); }
.spec-grid {
  margin-top: 20px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.spec-item { display: flex; flex-direction: column; gap: 10px; }
.spec-label {
  display: inline-block; width: fit-content; font-family: var(--mono); font-size: 11.5px;
  font-weight: 600; padding: 4px 11px; border-radius: 999px;
  color: var(--vault); background: var(--vault-dim); border: 1px solid var(--vault-line);
}
.spec-label.spec-private { color: var(--brass-text); background: var(--brass-dim); border-color: var(--brass-line); }
.spec-label.spec-default { color: var(--ink-2); background: var(--surface-sunk); border-color: var(--line-strong); }
.spec-label.spec-vm { color: #2A5D8C; background: rgba(42,93,140,0.08); border-color: rgba(42,93,140,0.3); }
.spec-label.spec-combo { color: var(--vault); background: linear-gradient(135deg, rgba(22,64,46,0.1), rgba(42,93,140,0.08)); border-color: var(--vault-line); }
.spec-code {
  background: var(--surface-sunk); border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: 13px 15px; margin: 0; overflow-x: auto;
  font-family: var(--mono); font-size: 11.5px; line-height: 1.65;
  scrollbar-width: none; -ms-overflow-style: none;
}
.spec-code::-webkit-scrollbar { display: none; }
.spec-code code { background: none !important; padding: 0 !important; font-family: inherit !important; }
.spec-item p { font-size: 12px; color: var(--ink-2); line-height: 1.6; }
.spec-item p code { font-family: var(--mono); background: var(--surface-sunk); padding: 1px 5px; border-radius: 3px; font-size: 11px; color: var(--vault); border: 1px solid var(--line); }
.usage-doc { margin-top: 20px; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.usage-block {
  border: 1px solid var(--line); border-radius: var(--r-sm);
  background: var(--surface-sunk); padding: 15px; display: flex; flex-direction: column; gap: 11px;
}
.usage-block h4 { font-family: var(--serif); color: var(--ink); font-size: 14px; letter-spacing: -0.005em; }
.usage-block p { font-size: 12px; color: var(--ink-2); line-height: 1.6; }
.usage-block p code { font-family: var(--mono); background: var(--surface); padding: 1px 5px; border-radius: 3px; font-size: 11px; color: var(--vault); border: 1px solid var(--line); }
.usage-note { grid-column: 1 / -1; border-color: var(--brass-line); background: var(--brass-dim); }

/* ===== 加载渐显 ===== */
@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.hero, .workspace, .engine, .caps, .html-demo { animation: fadeUp .7s cubic-bezier(.16,1,.3,1) both; }
.workspace { animation-delay: .08s; }
.engine { animation-delay: .14s; }
.caps { animation-delay: .18s; }
.html-demo { animation-delay: .22s; }

/* ===== 中文排版修正(第二轮独立评审发现)=====
   负字距(letter-spacing 负值)是给拉丁字重标题收紧用的排版技巧,中文字符是等宽方块,套用
   负字距在加粗大字标题上只会显得拥挤甚至互相碰边,没有意义。中文页面(<body class="lang-zh">)
   的大标题一律还原为正常字距。 */
.lang-zh .hero-title,
.lang-zh .section-title,
.lang-zh .logo-text,
.lang-zh .panel-title,
.lang-zh .pipe-step h3,
.lang-zh .metric b {
  letter-spacing: normal;
}
/* 中英文导航词长差异较大("Engine/Features/HTML Guide" vs "引擎/特性/HTML 指南"),固定
   30px 间距会让中文导航明显偏空,视觉重量与英文版不一致,中文页适当收紧。 */
.lang-zh .nav-links { gap: 22px; }
