/* 针灸大成 · 共用样式 ——————————————————————————— */
:root{
  --paper:#F2E9D6; --paper-2:#EDE2CB; --card:#FBF6EA; --card-edge:#E1D3B3;
  --ink:#2B2520; --ink-soft:#6B5F4F; --ink-faint:#9C8E76;
  --zhu:#A8322A; --zhu-deep:#8A271F; --zhu-soft:rgba(168,50,42,.10);
  --line:#DBCCAC; --line-soft:#E7DCC4;
  --sel:#3F6E66; --yang:#9C6B2E; --yin:#3F6E66; --qi:#A8322A;
  --shadow:0 1px 2px rgba(60,40,20,.06),0 6px 24px rgba(60,40,20,.06);
  --serif:"Songti SC","STSong","Source Han Serif SC","Noto Serif SC","SimSun",serif;
  --sans:"PingFang SC","Microsoft YaHei","Source Han Sans SC","Hiragino Sans GB","Segoe UI",sans-serif;
  --fs:17px; --lh:1.95; --maxw:740px;
}
html[data-theme="dark"]{
  --paper:#1C1A17; --paper-2:#211E1A; --card:#26221C; --card-edge:#383127;
  --ink:#E7DDCB; --ink-soft:#B3A78F; --ink-faint:#7E725C;
  --zhu:#D2675C; --zhu-deep:#C0584D; --zhu-soft:rgba(210,103,92,.14);
  --line:#3A3329; --line-soft:#2F2A22;
  --sel:#6FA59B; --yang:#C79A5A; --yin:#6FA59B; --qi:#D2675C;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 6px 24px rgba(0,0,0,.3);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--paper); color:var(--ink); font-family:var(--sans);
  font-size:var(--fs); line-height:var(--lh);
  background-image:radial-gradient(rgba(160,130,80,.05) 1px,transparent 1px);
  background-size:22px 22px;
}
@media (prefers-reduced-motion:no-preference){
  *{transition:background-color .25s ease,color .25s ease,border-color .25s ease}
}
a{color:inherit;text-decoration:none}
.app{display:flex;min-height:100vh}

/* ============ 侧栏 ============ */
.sidebar{width:300px;flex:none;background:var(--paper-2);border-right:1px solid var(--line);
  height:100vh;position:sticky;top:0;display:flex;flex-direction:column}
.brand{padding:18px 22px 13px;border-bottom:1px solid var(--line-soft)}
.brand a.bk{font-family:var(--serif);font-size:22px;font-weight:700;letter-spacing:2px;color:var(--ink);display:block}
.brand a.bk em{font-style:normal;color:var(--zhu)}
.brand .sub{font-size:12px;color:var(--ink-faint);margin-top:5px;letter-spacing:.5px}
.search-wrap{padding:12px 16px;border-bottom:1px solid var(--line-soft)}
.search-wrap input{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:8px;
  background:var(--card);color:var(--ink);font-size:14px;font-family:var(--sans);outline:none}
.search-wrap input:focus{border-color:var(--zhu);box-shadow:0 0 0 3px var(--zhu-soft)}
.tree{flex:1;overflow-y:auto;padding:8px 8px 40px;scrollbar-width:thin}
.tree::-webkit-scrollbar{width:7px}.tree::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}
.m-group{margin:1px 0}
.m-head{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;cursor:pointer;
  font-family:var(--serif);font-size:15px;color:var(--ink);user-select:none}
.m-head:hover{background:var(--zhu-soft)}
.m-head .cnum{font-size:11px;color:#fff;background:var(--ink-faint);border-radius:5px;padding:1px 6px;flex:none;font-family:var(--sans)}
.m-group.cur .m-head .cnum{background:var(--zhu)}
.m-head .ct{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-head .caret{color:var(--ink-faint);font-size:10px;transition:transform .2s}
.m-group.open .caret{transform:rotate(90deg)}
.p-list{display:none;padding:2px 0 8px 12px;margin-left:10px;border-left:1px solid var(--line-soft)}
.m-group.open .p-list{display:block}
.p-item{display:flex;align-items:center;gap:7px;padding:5px 10px;border-radius:6px;cursor:pointer;
  font-size:13.5px;color:var(--ink-soft)}
.p-item.lv1{font-family:var(--serif);color:var(--ink)}
.p-item.lv2{padding-left:18px;font-size:13px}
.p-item:hover{background:var(--zhu-soft);color:var(--ink)}
.p-item.active{background:var(--zhu);color:#fff}
.p-item .chip{font-size:9px;padding:1px 5px;border-radius:10px;color:#fff;flex:none;font-family:var(--sans)}
.chip.yin{background:var(--yin)}.chip.yang{background:var(--yang)}.chip.qi{background:var(--qi)}
.p-item .star{margin-left:auto;color:var(--zhu);font-size:12px;opacity:0}
.p-item.fav .star{opacity:1}
.p-item.learned::after{content:"✓";color:var(--sel);font-size:11px;margin-left:auto}
.p-item.fav.learned::after{margin-left:6px}

/* ============ 主区 ============ */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;padding:12px 26px;
  background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:7px;width:36px;height:34px;font-size:17px;color:var(--ink);cursor:pointer}
.crumb{font-size:13px;color:var(--ink-faint);font-family:var(--serif);letter-spacing:.5px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.crumb b{color:var(--zhu);font-weight:600}
.progress{font-size:12.5px;color:var(--ink-soft);white-space:nowrap}
.progress b{color:var(--sel)}
.tools{display:flex;gap:6px}
.tbtn{background:none;border:1px solid var(--line);border-radius:7px;height:34px;min-width:36px;padding:0 9px;
  color:var(--ink-soft);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;font-family:var(--sans)}
.tbtn:hover{border-color:var(--zhu);color:var(--zhu)}
.tbtn.on{background:var(--zhu);border-color:var(--zhu);color:#fff}

.content{flex:1;padding:34px 26px 120px;overflow-x:hidden}
.reader{max-width:var(--maxw);margin:0 auto}

/* 章/经络 头 */
.banner{margin-bottom:6px}
.banner .kicker{font-size:12px;color:var(--zhu);letter-spacing:3px;margin-bottom:6px}
.banner h1{font-family:var(--serif);font-size:33px;font-weight:700;letter-spacing:3px;line-height:1.3}
.banner .meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.tag{font-size:12px;padding:3px 10px;border-radius:20px;font-family:var(--sans)}
.tag.cat{color:#fff}.tag.cat.yin{background:var(--yin)}.tag.cat.yang{background:var(--yang)}.tag.cat.qi{background:var(--qi)}
.tag.ts{background:var(--zhu-soft);color:var(--zhu);border:1px solid color-mix(in srgb,var(--zhu) 30%,transparent)}
.tag.ghost{background:transparent;color:var(--ink-faint);border:1px solid var(--line)}

.intro-box{margin:22px 0 8px;padding:20px 22px;background:var(--card);border:1px solid var(--card-edge);
  border-left:3px solid var(--zhu);border-radius:10px;box-shadow:var(--shadow)}
.intro-box .lab{font-family:var(--serif);font-size:13px;color:var(--zhu);letter-spacing:2px;margin-bottom:10px}
.body p{margin:0 0 .9em;text-align:justify}.body p:last-child{margin-bottom:0}
.body mark{background:var(--zhu-soft);color:var(--zhu);padding:0 2px;border-radius:3px}

/* 节（无穴位的章节，作为一个阅读单元） */
.sec{margin:30px 0;scroll-margin-top:80px}
.sec .sechead{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;padding-bottom:13px;border-bottom:1px solid var(--line)}
.sec .snum{font-family:var(--serif);font-size:14px;color:var(--zhu);background:var(--zhu-soft);border:1px solid color-mix(in srgb,var(--zhu) 30%,transparent);
  border-radius:7px;padding:3px 9px;flex:none;margin-top:5px}
.sec .stitle{flex:1;min-width:0}
.sec .sname{font-family:var(--serif);font-size:23px;font-weight:700;letter-spacing:1.5px;line-height:1.4}
.sec .pacts{display:flex;gap:6px;flex:none;margin-top:5px}
.ptbadge{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--zhu);background:var(--zhu-soft);
  padding:2px 9px;border-radius:6px;margin-bottom:12px;font-family:var(--sans)}
.outline{list-style:none;margin:6px 0 0;padding:0;columns:2;column-gap:26px}
.outline li{padding:6px 0;font-family:var(--serif);color:var(--ink-soft);font-size:14px;break-inside:avoid;border-bottom:1px dotted var(--line-soft)}

/* 穴位卡（第四章） */
.divider{display:flex;align-items:center;gap:14px;margin:36px 0 4px;color:var(--ink-faint)}
.divider::before,.divider::after{content:"";height:1px;background:var(--line);flex:1}
.divider span{font-family:var(--serif);font-size:13px;letter-spacing:3px}
.point{margin:28px 0;scroll-margin-top:80px}
.point .phead{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px;padding-bottom:13px;border-bottom:1px dashed var(--line)}
.point .pnum{font-family:var(--serif);font-size:15px;color:#fff;background:var(--zhu);width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex:none;margin-top:4px;box-shadow:0 2px 6px var(--zhu-soft)}
.point .ptitle{flex:1;min-width:0}
.point .pname{font-family:var(--serif);font-size:24px;font-weight:700;letter-spacing:2px;line-height:1.4}
.point .pfull{font-size:13px;color:var(--ink-faint);margin-top:3px;font-family:var(--serif);letter-spacing:1px}
.pacts .pact,.sec .pact{background:none;border:1px solid var(--line);border-radius:7px;height:30px;padding:0 11px;cursor:pointer;
  font-size:12.5px;color:var(--ink-soft);display:flex;align-items:center;gap:4px;font-family:var(--sans);white-space:nowrap}
.pact:hover{border-color:var(--zhu);color:var(--zhu)}
.pact.on{background:var(--zhu);border-color:var(--zhu);color:#fff}
.pact.learn.on{background:var(--sel);border-color:var(--sel)}

/* 翻页 */
.pager{display:flex;justify-content:space-between;gap:12px;margin-top:60px;border-top:1px solid var(--line);padding-top:22px}
.pager a{flex:1;background:var(--card);border:1px solid var(--card-edge);border-radius:10px;padding:14px 16px;color:var(--ink);box-shadow:var(--shadow)}
.pager a:hover{border-color:var(--zhu)}
.pager a.disabled{opacity:.35;pointer-events:none}
.pager .dir{font-size:12px;color:var(--ink-faint);margin-bottom:3px}
.pager .nm{font-family:var(--serif);font-size:15px;color:var(--zhu);letter-spacing:1px}
.pager .next{text-align:right}

/* 搜索 / 收藏结果 */
.results .rhead{font-family:var(--serif);font-size:20px;letter-spacing:2px;margin-bottom:4px}
.results .rsub{color:var(--ink-faint);font-size:13px;margin-bottom:20px}
.rcard{display:block;background:var(--card);border:1px solid var(--card-edge);border-radius:10px;padding:15px 18px;margin-bottom:11px;cursor:pointer;box-shadow:var(--shadow)}
.rcard:hover{border-color:var(--zhu)}
.rcard .rt{font-family:var(--serif);font-size:18px;letter-spacing:1px}
.rcard .rt mark,.rcard .rx mark{background:var(--zhu-soft);color:var(--zhu)}
.rcard .rt .where{font-size:12px;color:var(--ink-faint);font-family:var(--sans)}
.rcard .rm{font-size:12px;color:var(--ink-faint);margin-top:3px}
.rcard .rx{font-size:13.5px;color:var(--ink-soft);margin-top:8px;line-height:1.7}
.empty{text-align:center;color:var(--ink-faint);padding:70px 20px;font-family:var(--serif);letter-spacing:1px}

/* ============ 首页 ============ */
.home{max-width:920px;margin:0 auto;padding:10px 4px}
.hero{text-align:center;padding:40px 0 30px;border-bottom:1px solid var(--line)}
.hero .seal{display:inline-block;font-family:var(--serif);color:#fff;background:var(--zhu);width:64px;height:64px;line-height:64px;
  border-radius:12px;font-size:30px;font-weight:700;box-shadow:0 6px 20px var(--zhu-soft);margin-bottom:18px}
.hero h1{font-family:var(--serif);font-size:42px;font-weight:700;letter-spacing:8px}
.hero h1 em{font-style:normal;color:var(--zhu)}
.hero .by{margin-top:12px;color:var(--ink-soft);letter-spacing:2px;font-family:var(--serif)}
.hero .stat{margin-top:18px;display:inline-flex;gap:22px;color:var(--ink-faint);font-size:13.5px}
.hero .stat b{color:var(--sel);font-size:18px;font-family:var(--serif)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:34px}
.ccard{display:block;background:var(--card);border:1px solid var(--card-edge);border-radius:14px;padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.ccard:hover{border-color:var(--zhu);transform:translateY(-2px)}
.ccard .cn{font-family:var(--serif);font-size:54px;font-weight:700;color:var(--zhu-soft);position:absolute;right:14px;top:2px;line-height:1}
html[data-theme=dark] .ccard .cn{color:rgba(210,103,92,.18)}
.ccard .ck{font-size:12px;color:var(--zhu);letter-spacing:2px}
.ccard .ctit{font-family:var(--serif);font-size:21px;font-weight:700;margin-top:8px;letter-spacing:1px;line-height:1.4;position:relative}
.ccard .cmeta{margin-top:14px;font-size:12.5px;color:var(--ink-faint)}
.ccard .cbar{margin-top:12px;height:5px;border-radius:3px;background:var(--line-soft);overflow:hidden}
.ccard .cbar i{display:block;height:100%;background:var(--sel);width:0}

.overlay{display:none;position:fixed;inset:0;background:rgba(20,15,8,.4);z-index:30}
@media(max-width:880px){
  .sidebar{position:fixed;left:0;top:0;z-index:40;transform:translateX(-100%);transition:transform .25s ease;box-shadow:8px 0 30px rgba(40,25,10,.18)}
  .sidebar.open{transform:translateX(0)} .overlay.show{display:block}
  .menu-btn{display:flex;align-items:center;justify-content:center}
  .content{padding:24px 16px 110px}
  .banner h1{font-size:26px}.point .pname{font-size:21px}.sec .sname{font-size:20px}
  .topbar{padding:10px 14px;gap:10px}.progress{display:none}
  .outline{columns:1}.hero h1{font-size:31px;letter-spacing:4px}
}

/* ============ 学习笔记组件 ============ */
.note{margin:4px 0 6px}
.nf{display:grid;grid-template-columns:78px 1fr;gap:14px;padding:11px 0;border-bottom:1px solid var(--line-soft);align-items:start}
.nf:last-child{border-bottom:0}
.nfk{font-family:var(--serif);font-size:13.5px;color:var(--zhu);letter-spacing:1px;padding-top:2px;font-weight:600}
.nfv{font-size:15.5px;line-height:1.75}
.tags{display:flex;flex-wrap:wrap;gap:7px}
.tags .t{font-size:13px;background:var(--zhu-soft);color:var(--zhu-deep);border:1px solid color-mix(in srgb,var(--zhu) 22%,transparent);
  padding:3px 11px;border-radius:20px;font-family:var(--sans)}
html[data-theme=dark] .tags .t{color:var(--zhu)}
.pearls{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.pearls li{position:relative;padding-left:20px;line-height:1.75;font-size:15px}
.pearls li::before{content:"";position:absolute;left:4px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--zhu)}
.ncaution{margin-top:12px;background:color-mix(in srgb,var(--yang) 12%,transparent);color:var(--yang);
  border:1px solid color-mix(in srgb,var(--yang) 30%,transparent);border-radius:8px;padding:9px 14px;font-size:14px}
.nlead{font-size:16px;line-height:1.85;margin-bottom:16px;color:var(--ink)}
.nnote{margin-top:14px;font-size:13px;color:var(--ink-faint);border-left:2px solid var(--line);padding-left:12px;line-height:1.7}

/* 概念卡 */
.ncards{display:grid;gap:12px}
.ncard{background:var(--card);border:1px solid var(--card-edge);border-left:3px solid var(--zhu);border-radius:9px;padding:14px 16px;box-shadow:var(--shadow)}
.nct{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--zhu-deep);margin-bottom:6px;letter-spacing:1px}
html[data-theme=dark] .nct{color:var(--zhu)}
.ncd{font-size:14.5px;line-height:1.8;color:var(--ink-soft)}

/* 歌诀 */
.mnemonic{font-family:var(--serif);font-size:17px;line-height:2;letter-spacing:1.5px;text-align:center;color:var(--ink);
  background:var(--card);border:1px dashed color-mix(in srgb,var(--zhu) 40%,transparent);border-radius:10px;padding:16px 20px;margin:6px 0 16px}
.mnemonic::before,.mnemonic::after{content:"『";color:var(--zhu);font-family:var(--serif)}
.mnemonic::after{content:"』"}

/* 速查表 */
.ntwrap{overflow-x:auto;border-radius:10px;border:1px solid var(--card-edge);box-shadow:var(--shadow)}
.ntable{width:100%;border-collapse:collapse;font-size:14.5px;background:var(--card)}
.ntable th,.ntable td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--line-soft)}
.ntable thead th{background:var(--zhu-soft);color:var(--zhu-deep);font-family:var(--serif);letter-spacing:1px;font-weight:700;border-bottom:1px solid color-mix(in srgb,var(--zhu) 25%,transparent)}
html[data-theme=dark] .ntable thead th{color:var(--zhu)}
.ntable tbody th{font-family:var(--serif);color:var(--zhu);font-weight:700;width:1%;white-space:nowrap}
.ntable tbody tr:last-child th,.ntable tbody tr:last-child td{border-bottom:0}
.ntable tbody tr:hover{background:var(--zhu-soft)}

/* 对比卡 */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ccol{background:var(--card);border:1px solid var(--card-edge);border-radius:11px;overflow:hidden;box-shadow:var(--shadow)}
.cch{padding:13px 16px;border-bottom:1px solid var(--line);text-align:center}
.cct{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--zhu);letter-spacing:2px;display:block}
.ccg{font-size:12px;color:var(--ink-faint);margin-top:3px;display:block}
.ccr{padding:11px 16px;border-bottom:1px solid var(--line-soft)}
.ccr:last-child{border-bottom:0}
.cck{font-size:12px;color:var(--zhu);font-family:var(--serif);letter-spacing:1px;margin-bottom:4px}
.ccv{font-size:14px;line-height:1.7;color:var(--ink-soft)}

/* 治症 */
.symlist{display:flex;flex-direction:column;gap:10px}
.symrow{display:grid;grid-template-columns:140px 1fr;gap:14px;background:var(--card);border:1px solid var(--card-edge);
  border-radius:9px;padding:13px 16px;box-shadow:var(--shadow)}
.symc{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--zhu-deep);letter-spacing:.5px}
html[data-theme=dark] .symc{color:var(--zhu)}
.syma{font-size:14px;line-height:1.75;color:var(--ink-soft)}

/* 原文对照（折叠）/ 待整理 */
.src{margin-top:16px;border-top:1px dashed var(--line)}
.src>summary{cursor:pointer;font-size:13px;color:var(--ink-faint);padding:10px 0 2px;list-style:none;user-select:none;font-family:var(--sans)}
.src>summary::-webkit-details-marker{display:none}
.src>summary::before{content:"▸ ";color:var(--zhu)}
.src[open]>summary::before{content:"▾ "}
.src .body{margin-top:8px;font-size:14.5px;color:var(--ink-soft);background:var(--paper-2);border-radius:9px;padding:14px 16px}
.todo{display:inline-block;margin-top:6px;font-size:12px;color:var(--ink-faint);background:var(--paper-2);border:1px solid var(--line-soft);border-radius:6px;padding:3px 10px}

/* 侧栏/首页 笔记标记 */
.p-item .lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.p-item .pen{color:var(--zhu);font-size:11px;opacity:.85;flex:none}
.p-item.active .pen{color:#fff}
.nbadge{color:var(--zhu);font-weight:600}

@media(max-width:880px){
  .compare{grid-template-columns:1fr}
  .nf{grid-template-columns:64px 1fr;gap:10px}
  .symrow{grid-template-columns:1fr;gap:6px}
  .symc{font-size:14px}
}
