
:root{
  --ink:#1f2933; --ink-soft:#3e4c59; --muted:#7b8794;
  --bg:#faf9f6; --panel:#ffffff; --line:#e4e0d7;
  --accent:#1f6f6b; --accent-soft:#2a8f8a; --accent-bg:#e6f2f1;
  --warn:#b45309; --danger:#b91c1c;
  --sidebar:#1d2b2a; --sidebar-ink:#cdd9d8; --sidebar-active:#2dd4bf;
  --serif:"Noto Serif SC","Songti SC",Georgia,"Times New Roman",serif;
  --sans:"Noto Sans SC","PingFang SC","Hiragino Sans GB","Microsoft YaHei",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-size:16.5px;line-height:1.75;-webkit-font-smoothing:antialiased}

/* 侧边栏 */
#sidebar{position:fixed;top:0;left:0;width:264px;height:100vh;overflow-y:auto;
  background:var(--sidebar);color:var(--sidebar-ink);padding:22px 16px;z-index:50}
#sidebar .brand{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid #33403f}
#sidebar .brand a{display:block;color:#fff;font-weight:700;font-size:18px;text-decoration:none}
#sidebar .brand span{display:block;color:#7fa7a3;font-size:12px;margin-top:4px;letter-spacing:.04em}
.nav-item{display:block;color:var(--sidebar-ink);text-decoration:none;padding:9px 12px;
  border-radius:8px;font-size:14.5px;margin:2px 0;line-height:1.45;transition:background .15s}
.nav-item:hover{background:#26393800;background:#283a39;color:#fff}
.nav-item.active{background:var(--accent);color:#fff;font-weight:600}
.nav-foot{margin-top:20px;padding-top:14px;border-top:1px solid #33403f;
  color:#6b827f;font-size:12px;line-height:1.6}

#menu-toggle{display:none;position:fixed;top:12px;left:12px;z-index:60;
  background:var(--sidebar);color:#fff;border:none;border-radius:8px;
  width:42px;height:42px;font-size:20px;cursor:pointer}

/* 正文 */
main{margin-left:264px;padding:48px 40px 96px}
.content{max-width:840px;margin:0 auto}
.page-title{font-family:var(--sans);font-size:30px;line-height:1.3;margin:0 0 6px;
  letter-spacing:-.01em;font-weight:800;color:#16201f}
.page-subtitle{color:var(--muted);font-size:14.5px;margin:0 0 28px;
  padding-bottom:18px;border-bottom:2px solid var(--line)}
.lead{font-size:17px;color:var(--ink-soft)}

.content h2{font-family:var(--sans);font-size:23px;font-weight:750;margin:44px 0 14px;
  padding-top:10px;color:#16201f;border-top:1px solid var(--line)}
.content h3{font-family:var(--sans);font-size:19px;font-weight:700;margin:30px 0 10px;color:#1b2a29}
.content h4{font-size:16.5px;font-weight:700;margin:22px 0 8px;color:var(--accent)}
.content p{margin:13px 0}
.content a{color:var(--accent);text-decoration:none;border-bottom:1px solid #bcdcd9}
.content a:hover{color:var(--accent-soft);border-bottom-color:var(--accent-soft)}
.content ul,.content ol{padding-left:24px;margin:12px 0}
.content li{margin:6px 0}
.content blockquote{margin:16px 0;padding:12px 18px;background:var(--accent-bg);
  border-left:4px solid var(--accent);border-radius:0 8px 8px 0;color:var(--ink-soft)}
.content blockquote p{margin:6px 0}
.content hr{border:none;border-top:1px solid var(--line);margin:32px 0}
.content code{background:#eef1ee;padding:2px 6px;border-radius:5px;font-size:.9em;
  font-family:"SF Mono",ui-monospace,Menlo,Consolas,monospace}
.content pre{background:#1d2b2a;color:#d6e6e4;padding:16px 18px;border-radius:10px;
  overflow-x:auto;line-height:1.55;font-size:13.5px}
.content pre code{background:none;color:inherit;padding:0}

/* 表格 */
.content table{border-collapse:collapse;width:100%;margin:18px 0;font-size:14.5px;
  display:block;overflow-x:auto}
.content th,.content td{border:1px solid var(--line);padding:9px 12px;text-align:left;
  vertical-align:top}
.content thead th{background:#eef3f2;font-weight:700;color:#16201f}
.content tbody tr:nth-child(even){background:#f6f4ef}

/* 引用上标 */
sup.cite{font-size:.72em;line-height:0;vertical-align:super;white-space:nowrap}
sup.cite a,sup.cite span{color:var(--accent-soft);font-weight:700;text-decoration:none;
  border:none;padding:0 1px;cursor:pointer;position:relative}
sup.cite a:hover{color:#fff;background:var(--accent);border-radius:4px}
sup.cite a::after{content:attr(data-title);position:absolute;left:50%;bottom:160%;
  transform:translateX(-50%);background:#16201f;color:#fff;font-size:12.5px;font-weight:500;
  line-height:1.4;white-space:normal;width:max-content;max-width:280px;padding:7px 10px;
  border-radius:8px;box-shadow:0 6px 22px rgba(0,0,0,.25);opacity:0;pointer-events:none;
  transition:opacity .15s;z-index:30}
sup.cite a:hover::after{opacity:1}

/* 来源区 */
#来源 + ol,h2[id="来源"] + ol{font-size:14.5px}

/* 设计启示高亮块（用 blockquote 起始 “设计启示” 时不特殊处理；用 .impl class 由 md attr_list） */
.impl{background:#fff8ec;border:1px solid #f0d9a8;border-left:5px solid var(--warn);
  border-radius:0 10px 10px 0;padding:14px 18px;margin:18px 0}

/* 首页卡片 */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:16px;margin:26px 0}
.card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;text-decoration:none;color:var(--ink);transition:.18s;border-bottom:1px solid var(--line)}
.card:hover{border-color:var(--accent);box-shadow:0 8px 26px rgba(31,111,107,.12);transform:translateY(-2px)}
.card h3{margin:0 0 8px;font-size:17px;color:#16201f}
.card p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.6}
.card.disabled{opacity:.5;pointer-events:none}

.src-index{margin:18px 0}
.src-index summary{cursor:pointer;font-weight:600;color:var(--accent);padding:8px 0}
.src-list{columns:2;column-gap:32px}
.src-list li{break-inside:avoid;font-size:13.5px;margin:4px 0}
.src-list a{color:var(--ink-soft);border:none}
.src-list a:hover{color:var(--accent)}
.rid{display:inline-block;min-width:30px;color:var(--accent-soft);font-weight:700;
  font-family:ui-monospace,monospace;font-size:12px}

.src-back{font-size:13.5px;color:var(--muted);background:#f0ede6;padding:8px 14px;
  border-radius:8px;margin:0 0 18px}

/* TOC */
.toc{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px 20px 14px 8px;margin:0 0 28px;font-size:14px}
.toc::before{content:"本页目录";display:block;font-weight:700;color:var(--muted);
  font-size:12px;letter-spacing:.08em;margin:0 0 6px 16px}
.toc ul{list-style:none;padding-left:16px;margin:4px 0}
.toc>ul{padding-left:0}
.toc a{color:var(--ink-soft);border:none}
.toc a:hover{color:var(--accent)}
.toc>ul>li{margin:3px 0}

@media(max-width:880px){
  #sidebar{transform:translateX(-100%);transition:transform .25s}
  #sidebar.open{transform:translateX(0)}
  #menu-toggle{display:block}
  main{margin-left:0;padding:64px 18px 80px}
  .src-list{columns:1}
}
