2
0

wiki.css 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. /* resources/css/wiki.css */
  2. /* WikiPāli — 布局、导航、组件样式 */
  3. /* ── 字体 ── */
  4. @import url("https://fonts.googleapis.com/css2?family=Noto+Serif:ital,wght@0,400;0,600;1,400&display=swap");
  5. /* ── 三栏布局 ── */
  6. .wiki-layout {
  7. display: grid;
  8. grid-template-columns: 200px 1fr 200px;
  9. grid-template-areas: "left main right";
  10. gap: 1.5rem;
  11. align-items: start;
  12. padding-top: 1.5rem;
  13. padding-bottom: 3rem;
  14. }
  15. .wiki-sidebar-left {
  16. grid-area: left;
  17. }
  18. .wiki-main {
  19. grid-area: main;
  20. min-width: 0;
  21. display: flex;
  22. flex-direction: column;
  23. gap: 1rem;
  24. }
  25. .wiki-sidebar-right {
  26. grid-area: right;
  27. }
  28. /* ── 通用卡片 ── */
  29. .wiki-card {
  30. background: var(--tblr-bg-surface);
  31. border: 1px solid var(--tblr-border-color);
  32. border-radius: var(--tblr-border-radius-lg);
  33. padding: 1.5rem;
  34. }
  35. /* ── 侧边栏 ── */
  36. .wiki-sidebar-section {
  37. background: var(--tblr-bg-surface);
  38. border: 1px solid var(--tblr-border-color);
  39. border-radius: var(--tblr-border-radius-lg);
  40. padding: 1rem 1.125rem;
  41. margin-bottom: 1rem;
  42. }
  43. .wiki-sidebar-title {
  44. font-size: 0.6875rem;
  45. font-weight: 500;
  46. letter-spacing: 0.05em;
  47. text-transform: uppercase;
  48. color: var(--tblr-secondary);
  49. margin-bottom: 0.75rem;
  50. }
  51. .wiki-cat-list {
  52. list-style: none;
  53. padding: 0;
  54. margin: 0;
  55. }
  56. .wiki-cat-list li {
  57. margin-bottom: 2px;
  58. }
  59. .wiki-cat-list a {
  60. display: block;
  61. font-size: 0.8125rem;
  62. color: var(--tblr-body-color);
  63. text-decoration: none;
  64. padding: 5px 8px;
  65. border-radius: var(--tblr-border-radius);
  66. transition: background 0.12s;
  67. }
  68. .wiki-cat-list a:hover {
  69. background: var(--tblr-bg-surface-secondary);
  70. }
  71. .wiki-cat-list a.active {
  72. background: var(--tblr-bg-surface-secondary);
  73. font-weight: 500;
  74. color: var(--tblr-primary);
  75. }
  76. /* ── 目录 ── */
  77. .wiki-toc-list {
  78. list-style: none;
  79. padding: 0;
  80. margin: 0;
  81. }
  82. .wiki-toc-list li {
  83. border-bottom: 1px solid var(--tblr-border-color);
  84. }
  85. .wiki-toc-list li:last-child {
  86. border-bottom: none;
  87. }
  88. .wiki-toc-list a {
  89. display: block;
  90. font-size: 0.8125rem;
  91. color: var(--tblr-secondary);
  92. text-decoration: none;
  93. padding: 5px 0;
  94. transition: color 0.12s;
  95. }
  96. .wiki-toc-list a:hover {
  97. color: var(--tblr-body-color);
  98. }
  99. .wiki-toc-list a.active {
  100. color: var(--tblr-body-color);
  101. font-weight: 500;
  102. }
  103. .wiki-toc-list .toc-level-2 a {
  104. padding-left: 0.5rem;
  105. }
  106. .wiki-toc-list .toc-level-3 a {
  107. padding-left: 1rem;
  108. }
  109. .wiki-toc-num {
  110. color: var(--tblr-secondary);
  111. margin-right: 5px;
  112. font-size: 0.75rem;
  113. }
  114. /* ── 相关条目 ── */
  115. .wiki-related-list {
  116. list-style: none;
  117. padding: 0;
  118. margin: 0;
  119. }
  120. .wiki-related-list li {
  121. border-bottom: 1px solid var(--tblr-border-color);
  122. }
  123. .wiki-related-list li:last-child {
  124. border-bottom: none;
  125. }
  126. .wiki-related-list a {
  127. display: flex;
  128. justify-content: space-between;
  129. align-items: center;
  130. font-size: 0.8125rem;
  131. color: var(--tblr-primary);
  132. text-decoration: none;
  133. padding: 6px 0;
  134. }
  135. .wiki-related-zh {
  136. font-size: 0.75rem;
  137. color: var(--tblr-secondary);
  138. }
  139. /* ── 元信息表格 ── */
  140. .wiki-meta-table {
  141. width: 100%;
  142. font-size: 0.8125rem;
  143. border-collapse: collapse;
  144. }
  145. .wiki-meta-table td {
  146. padding: 3px 0;
  147. }
  148. .wiki-meta-table td:last-child {
  149. text-align: right;
  150. color: var(--tblr-secondary);
  151. }
  152. /* ── 条目头部 ── */
  153. .wiki-entry-header {
  154. margin-bottom: 1.25rem;
  155. }
  156. .wiki-entry-title {
  157. font-family: "Noto Serif", Georgia, serif;
  158. font-size: 1.75rem;
  159. font-weight: 600;
  160. line-height: 1.25;
  161. margin: 0.375rem 0 0.75rem;
  162. color: var(--tblr-body-color);
  163. }
  164. .wiki-entry-langs-inline {
  165. display: flex;
  166. flex-wrap: wrap;
  167. gap: 6px;
  168. margin-bottom: 0.5rem;
  169. }
  170. .wiki-lang-pill {
  171. font-size: 0.75rem;
  172. padding: 3px 10px;
  173. border-radius: 20px;
  174. border: 1px solid var(--tblr-border-color);
  175. color: var(--tblr-secondary);
  176. }
  177. .wiki-lang-pill strong {
  178. font-weight: 500;
  179. color: var(--tblr-body-color);
  180. margin-right: 3px;
  181. }
  182. /* ── 语言版本切换 ── */
  183. .wiki-entry-lang-switcher {
  184. display: flex;
  185. flex-wrap: wrap;
  186. align-items: center;
  187. gap: 6px;
  188. padding: 0.625rem 0.875rem;
  189. background: var(--tblr-bg-surface-secondary);
  190. border-radius: var(--tblr-border-radius);
  191. margin-bottom: 1.25rem;
  192. font-size: 0.8125rem;
  193. }
  194. .wiki-entry-lang-label {
  195. color: var(--tblr-secondary);
  196. }
  197. .wiki-entry-lang-btn {
  198. font-size: 0.75rem;
  199. padding: 3px 10px;
  200. border-radius: 20px;
  201. border: 1px solid var(--tblr-border-color);
  202. color: var(--tblr-primary);
  203. text-decoration: none;
  204. transition: background 0.12s;
  205. }
  206. .wiki-entry-lang-btn:hover {
  207. background: var(--tblr-bg-surface);
  208. }
  209. /* ── 质量标签 ── */
  210. .wiki-quality-badge {
  211. display: inline-flex;
  212. align-items: center;
  213. gap: 5px;
  214. font-size: 0.6875rem;
  215. padding: 3px 10px;
  216. border-radius: 20px;
  217. font-weight: 500;
  218. margin-bottom: 4px;
  219. }
  220. .wiki-quality-dot {
  221. width: 6px;
  222. height: 6px;
  223. border-radius: 50%;
  224. flex-shrink: 0;
  225. }
  226. .wiki-badge--featured {
  227. background: #eaf3de;
  228. color: #3b6d11;
  229. border: 1px solid #c0dd97;
  230. }
  231. .wiki-badge--featured .wiki-quality-dot {
  232. background: #639922;
  233. }
  234. .wiki-badge--review {
  235. background: #faeeda;
  236. color: #854f0b;
  237. border: 1px solid #fac775;
  238. }
  239. .wiki-badge--review .wiki-quality-dot {
  240. background: #ba7517;
  241. }
  242. .wiki-badge--stub {
  243. background: #f1efe8;
  244. color: #5f5e5a;
  245. border: 1px solid #d3d1c7;
  246. }
  247. .wiki-badge--stub .wiki-quality-dot {
  248. background: #888780;
  249. }
  250. /* ── 标签 ── */
  251. .wiki-tags {
  252. display: flex;
  253. flex-wrap: wrap;
  254. gap: 6px;
  255. padding-top: 1rem;
  256. border-top: 1px solid var(--tblr-border-color);
  257. margin-top: 1.5rem;
  258. }
  259. .wiki-tag {
  260. font-size: 0.75rem;
  261. padding: 3px 10px;
  262. border-radius: 20px;
  263. border: 1px solid var(--tblr-border-color);
  264. color: var(--tblr-secondary);
  265. text-decoration: none;
  266. transition: background 0.12s;
  267. }
  268. .wiki-tag:hover {
  269. background: var(--tblr-bg-surface-secondary);
  270. color: var(--tblr-body-color);
  271. }
  272. /* ── 首页今日条目 ── */
  273. .wiki-today-banner {
  274. background: var(--tblr-bg-surface-secondary);
  275. border: 1px solid var(--tblr-border-color);
  276. border-radius: var(--tblr-border-radius-lg);
  277. padding: 1.25rem 1.5rem;
  278. display: flex;
  279. gap: 1.25rem;
  280. align-items: flex-start;
  281. }
  282. .wiki-today-icon {
  283. width: 48px;
  284. height: 48px;
  285. border-radius: var(--tblr-border-radius);
  286. background: #e1f5ee;
  287. display: flex;
  288. align-items: center;
  289. justify-content: center;
  290. font-size: 1.375rem;
  291. flex-shrink: 0;
  292. }
  293. .wiki-today-label {
  294. font-size: 0.6875rem;
  295. text-transform: uppercase;
  296. letter-spacing: 0.05em;
  297. color: var(--tblr-secondary);
  298. margin-bottom: 4px;
  299. }
  300. .wiki-today-title {
  301. font-family: "Noto Serif", Georgia, serif;
  302. font-size: 1.125rem;
  303. font-weight: 600;
  304. margin-bottom: 6px;
  305. color: var(--tblr-body-color);
  306. }
  307. .wiki-today-snippet {
  308. font-size: 0.875rem;
  309. color: var(--tblr-secondary);
  310. line-height: 1.6;
  311. }
  312. .wiki-today-link {
  313. font-size: 0.8125rem;
  314. color: var(--tblr-primary);
  315. text-decoration: none;
  316. margin-top: 10px;
  317. display: inline-block;
  318. }
  319. /* ── 首页精选网格 ── */
  320. .wiki-featured-grid {
  321. display: grid;
  322. grid-template-columns: repeat(3, minmax(0, 1fr));
  323. gap: 8px;
  324. }
  325. .wiki-featured-card {
  326. border: 1px solid var(--tblr-border-color);
  327. border-radius: var(--tblr-border-radius);
  328. padding: 10px 12px;
  329. cursor: pointer;
  330. text-decoration: none;
  331. display: block;
  332. transition: background 0.12s;
  333. color: var(--tblr-body-color);
  334. }
  335. .wiki-featured-card:hover {
  336. background: var(--tblr-bg-surface-secondary);
  337. }
  338. .wiki-featured-label {
  339. font-size: 0.6875rem;
  340. font-weight: 500;
  341. text-transform: uppercase;
  342. letter-spacing: 0.05em;
  343. color: var(--tblr-secondary);
  344. margin-bottom: 5px;
  345. }
  346. .wiki-featured-title {
  347. font-size: 0.875rem;
  348. font-weight: 500;
  349. margin-bottom: 2px;
  350. }
  351. .wiki-featured-pali {
  352. font-size: 0.75rem;
  353. font-style: italic;
  354. color: var(--tblr-secondary);
  355. }
  356. /* ── term-ref 行内术语标记 ── */
  357. .term-ref {
  358. font-style: italic;
  359. color: var(--tblr-primary);
  360. border-bottom: 1px dotted var(--tblr-primary);
  361. cursor: pointer;
  362. }
  363. /* ── Popover 覆盖样式(桌面 tooltip) ── */
  364. .wiki-term-popover.popover {
  365. max-width: 280px;
  366. font-size: 0.8125rem;
  367. border: 0.5px solid var(--tblr-border-color);
  368. border-radius: var(--tblr-border-radius-lg);
  369. box-shadow: none;
  370. }
  371. .wiki-term-popover .popover-arrow {
  372. display: none;
  373. }
  374. .wiki-term-popover .popover-body {
  375. padding: 0;
  376. }
  377. /* 巴利原文标题行 */
  378. .wiki-popover-word {
  379. font-family: "Noto Serif", Georgia, serif;
  380. font-size: 0.9375rem;
  381. font-style: italic;
  382. font-weight: 600;
  383. color: var(--tblr-primary);
  384. padding: 10px 14px 10px;
  385. border-bottom: 0.5px solid var(--tblr-border-color);
  386. }
  387. /* 释义区 */
  388. .wiki-popover-body {
  389. padding: 10px 14px 12px;
  390. }
  391. .wiki-popover-meaning {
  392. font-size: 0.875rem;
  393. font-weight: 500;
  394. color: var(--tblr-body-color);
  395. margin-bottom: 5px;
  396. }
  397. .wiki-popover-summary {
  398. font-size: 0.8125rem;
  399. color: var(--tblr-secondary);
  400. line-height: 1.55;
  401. }
  402. .wiki-popover-meaning {
  403. font-size: 0.9rem;
  404. font-weight: 500;
  405. color: var(--tblr-body-color);
  406. padding: 8px 14px 4px;
  407. }
  408. .wiki-popover-summary {
  409. font-size: 0.8125rem;
  410. color: var(--tblr-secondary);
  411. line-height: 1.55;
  412. padding: 0 14px 12px;
  413. }
  414. /* ── 移动端 Offcanvas 抽屉 ── */
  415. .wiki-term-drawer {
  416. border-radius: 1rem 1rem 0 0;
  417. max-height: 55vh;
  418. }
  419. .wiki-drawer-word {
  420. font-family: "Noto Serif", Georgia, serif;
  421. font-size: 1.125rem;
  422. font-style: italic;
  423. font-weight: 600;
  424. color: var(--tblr-primary);
  425. }
  426. .wiki-drawer-meaning {
  427. font-size: 0.9375rem;
  428. font-weight: 500;
  429. color: var(--tblr-body-color);
  430. margin-top: 2px;
  431. }
  432. .wiki-drawer-summary {
  433. font-size: 0.9375rem;
  434. color: var(--tblr-secondary);
  435. line-height: 1.65;
  436. }
  437. .wiki-drawer-link {
  438. display: inline-block;
  439. margin-top: 1rem;
  440. font-size: 0.875rem;
  441. color: var(--tblr-primary);
  442. text-decoration: none;
  443. }
  444. /* ── 响应式 ── */
  445. @media (max-width: 992px) {
  446. .wiki-layout {
  447. grid-template-columns: 180px 1fr;
  448. grid-template-areas:
  449. "left main"
  450. "left right";
  451. }
  452. .wiki-sidebar-right {
  453. grid-area: right;
  454. display: flex;
  455. flex-wrap: wrap;
  456. gap: 1rem;
  457. }
  458. .wiki-sidebar-right .wiki-sidebar-section {
  459. flex: 1 1 180px;
  460. margin-bottom: 0;
  461. }
  462. }
  463. @media (max-width: 768px) {
  464. .wiki-layout {
  465. grid-template-columns: 1fr;
  466. grid-template-areas: "main" "right" "left";
  467. }
  468. .wiki-featured-grid {
  469. grid-template-columns: repeat(2, minmax(0, 1fr));
  470. }
  471. .wiki-sidebar-left,
  472. .wiki-sidebar-right {
  473. display: none;
  474. }
  475. }
  476. /* ── term-card 共享(Popover + 抽屉复用) ── */
  477. .wiki-term-card-word {
  478. font-family: "Noto Serif", Georgia, serif;
  479. font-size: 0.9375rem;
  480. font-style: italic;
  481. font-weight: 600;
  482. color: var(--tblr-primary);
  483. padding: 8px;
  484. margin-bottom: 8px;
  485. border-bottom: 0.5px solid var(--tblr-border-color);
  486. }
  487. .wiki-term-card-meaning {
  488. font-size: 0.875rem;
  489. font-weight: 500;
  490. color: var(--tblr-body-color);
  491. margin-bottom: 5px;
  492. }
  493. .wiki-term-card-summary {
  494. font-size: 0.8125rem;
  495. color: var(--tblr-secondary);
  496. line-height: 1.55;
  497. }