/* ============================================================
   机械键盘行业深度调研 — 全局统一样式 (所有页面共用)
   配色: 暖中性底 + 石墨墨色 + 琥珀强调 (机械键盘键帽质感)
   ============================================================ */
:root{
  --bg:#f7f5f1;            /* 暖米底 */
  --surface:#ffffff;
  --surface-2:#f0ece5;
  --ink:#1c1a17;          /* 近黑墨 */
  --ink-2:#4a463f;
  --muted:#8a8478;
  --line:#e2dcd1;
  --accent:#c8731f;        /* 琥珀 (强调/链接) */
  --accent-soft:#f5e4cf;
  --accent-2:#2f6f6a;      /* 青绿 (次强调/正向) */
  --warn:#b0472b;          /* 砖红 (证伪/警示) */
  --good:#3d7a4e;
  --radius:14px;
  --shadow:0 1px 3px rgba(28,26,23,.06),0 8px 24px rgba(28,26,23,.05);
  --maxw:980px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  --mono:"SF Mono",ui-monospace,"JetBrains Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--font);font-size:16.5px;line-height:1.72;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- 顶部返回条 ---------- */
.topnav{
  position:sticky;top:0;z-index:50;background:rgba(247,245,241,.86);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line);
}
.topnav .wrap{display:flex;align-items:center;gap:16px;height:54px;font-size:14.5px}
.topnav a{color:var(--ink-2);text-decoration:none;font-weight:600}
.topnav a:hover{color:var(--accent)}
.topnav .home{display:inline-flex;align-items:center;gap:6px}
.topnav .crumb{color:var(--muted);font-weight:500}
.topnav .spacer{flex:1}

/* ---------- 模块头 ---------- */
.module-hero{padding:54px 0 30px}
.module-tag{display:inline-block;font-size:13px;font-weight:700;letter-spacing:.08em;
  color:var(--accent);background:var(--accent-soft);padding:4px 12px;border-radius:999px;text-transform:uppercase}
.module-hero h1{font-size:clamp(28px,4.4vw,42px);line-height:1.18;margin:16px 0 10px;letter-spacing:-.01em}
.module-hero .lede{font-size:18.5px;color:var(--ink-2);max-width:760px;margin:0}
.updated{color:var(--muted);font-size:13.5px;margin-top:14px}

/* ---------- 章节 ---------- */
section{padding:30px 0;border-top:1px solid var(--line)}
section:first-of-type{border-top:none}
h2{font-size:25px;letter-spacing:-.01em;margin:.2em 0 .5em;scroll-margin-top:70px}
h2 .num{color:var(--accent);font-variant-numeric:tabular-nums;margin-right:10px}
h3{font-size:19px;margin:1.4em 0 .4em;color:var(--ink)}
p{margin:.6em 0}
a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
a:hover{color:#9c5814}
strong{font-weight:700}
ul,ol{padding-left:1.3em}
li{margin:.28em 0}
hr{border:none;border-top:1px solid var(--line);margin:28px 0}

/* ---------- 卡片 ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;box-shadow:var(--shadow)}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.persona-card h4{margin:.1em 0 .4em;font-size:17px}
.persona-card .role{font-size:13px;color:var(--accent-2);font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ---------- 表格 ---------- */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:16px 0;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
table{border-collapse:collapse;width:100%;font-size:14.5px;min-width:540px}
caption{caption-side:top;text-align:left;font-size:13.5px;color:var(--muted);padding:10px 14px 6px}
th,td{padding:10px 13px;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
thead th{background:var(--ink);color:#fff;font-weight:600;position:sticky;top:0;font-size:13.5px;letter-spacing:.02em}
tbody tr:nth-child(even){background:var(--surface-2)}
tbody tr:hover{background:var(--accent-soft)}
/* 可点击高亮列 (JS 加 .hl 到对应单元格) */
table.matrix td.hl,table.matrix th.hl{background:var(--accent-soft)!important;box-shadow:inset 0 0 0 1px var(--accent)}
table.matrix thead th{cursor:pointer;user-select:none}
table.matrix thead th:hover{background:#332f29}
td.rank{font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.pill{display:inline-block;padding:1px 9px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}
.pill.good{background:#e3f0e6;color:var(--good)}
.pill.mid{background:#f6ecd6;color:#9c6b1a}
.pill.bad{background:#f6dcd4;color:var(--warn)}

/* ---------- UGC 原声引用卡 ---------- */
.ugc{background:var(--surface);border-left:4px solid var(--accent);border-radius:0 12px 12px 0;
  padding:14px 18px;margin:14px 0;box-shadow:var(--shadow)}
.ugc blockquote{margin:0;font-size:15.5px;color:var(--ink);font-style:italic}
.ugc .meta{margin-top:8px;font-size:12.5px;color:var(--muted)}
.ugc .meta a{color:var(--muted)}
.ugc .meta .src{font-weight:700;color:var(--accent-2)}

/* ---------- 图与说明 ---------- */
figure{margin:18px 0;text-align:center}
figure svg,figure img{max-width:100%;height:auto;border-radius:10px}
figure.framed svg,figure.framed img{border:1px solid var(--line);background:var(--surface);padding:10px}
figcaption{font-size:12.5px;color:var(--muted);margin-top:8px;text-align:center}
figcaption .src{color:var(--accent-2)}

/* ---------- 术语词典卡 ---------- */
.term-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.term{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.term dt{font-weight:700;color:var(--accent)}
.term dd{margin:4px 0 0;font-size:14px;color:var(--ink-2)}

/* ---------- 提示/旁注 ---------- */
.callout{border-radius:12px;padding:14px 18px;margin:16px 0;font-size:15px}
.callout.info{background:#eaf2f1;border:1px solid #cfe2df}
.callout.warn{background:#fbeee8;border:1px solid #f0d2c5}
.callout .lbl{font-weight:700;display:block;margin-bottom:4px}
.callout.info .lbl{color:var(--accent-2)}
.callout.warn .lbl{color:var(--warn)}

/* ---------- Caveats & 证伪状态区块 ---------- */
.caveats{background:#fbf6ee;border:1px dashed var(--accent);border-radius:var(--radius);padding:20px 22px;margin-top:30px}
.caveats h2{font-size:20px;margin-top:0;color:var(--warn)}
.caveats .fbadge{display:inline-block;font-size:12px;font-weight:700;padding:2px 8px;border-radius:6px;margin-right:6px}
.fbadge.confirmed{background:#e3f0e6;color:var(--good)}
.fbadge.falsified{background:#f6dcd4;color:var(--warn)}
.fbadge.partial{background:#f6ecd6;color:#9c6b1a}
.fbadge.open{background:#e6e2d8;color:var(--ink-2)}

/* ---------- 来源列表 ---------- */
.sources{font-size:13px;color:var(--ink-2)}
.sources h2{font-size:18px}
.sources ol{padding-left:1.4em}
.sources li{margin:.35em 0;word-break:break-word}
.sources .ts{color:var(--muted)}

/* ---------- index 专用 ---------- */
.hero-index{padding:64px 0 36px;text-align:center}
.hero-index h1{font-size:clamp(32px,5.5vw,52px);letter-spacing:-.02em;margin:.1em 0}
.hero-index .sub{font-size:19px;color:var(--ink-2);max-width:680px;margin:12px auto 0}
.tldr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:8px 0}
.tldr-item{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent-2);
  border-radius:0 12px 12px 0;padding:14px 18px}
.tldr-item b{color:var(--accent)}
.nav-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.nav-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);text-decoration:none;color:inherit;
  transition:transform .15s ease,box-shadow .15s ease}
.nav-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(28,26,23,.12)}
.nav-card .thumb{aspect-ratio:16/9;background:var(--surface-2);display:flex;align-items:center;justify-content:center}
.nav-card .thumb svg{width:72%;height:72%}
.nav-card .body{padding:16px 18px}
.nav-card .ord{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.06em}
.nav-card h3{margin:.3em 0 .3em;font-size:18px}
.nav-card p{font-size:14px;color:var(--ink-2);margin:0}
.path-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px}
.path-box .route{font-weight:700;color:var(--accent-2)}

/* ---------- 页脚 ---------- */
footer{margin-top:40px;padding:28px 0 60px;border-top:1px solid var(--line);color:var(--muted);font-size:13.5px}

/* ---------- 响应式 ---------- */
@media(max-width:760px){
  body{font-size:16px}
  .grid-2,.grid-3,.tldr-grid{grid-template-columns:1fr}
  .module-hero{padding:36px 0 20px}
}
