_wiki.css 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954
  1. /* resources/css/modules/_wiki.css
  2. Wiki 栏目专属样式。
  3. 公共部分(布局、卡片、侧边栏、TOC、相关列表、meta表格、条目头部、精选网格)
  4. 已提取至:
  5. - layout/_grid.css → .wiki-layout 三栏布局
  6. - components/_card.css → .wiki-card / .wiki-sidebar-* / .wiki-cat-list /
  7. .wiki-toc-list / .wiki-related-list / .wiki-meta-table /
  8. .wiki-entry-header / .wiki-featured-grid / .author-avatar
  9. 本文件只保留 wiki 专属内容。
  10. */
  11. /* ══════════════════════════════════════════
  12. 一、语言版本切换
  13. ══════════════════════════════════════════ */
  14. .wiki-entry-langs-inline {
  15. display: flex;
  16. flex-wrap: wrap;
  17. gap: 6px;
  18. margin-bottom: 0.5rem;
  19. }
  20. .wiki-lang-pill {
  21. font-size: 0.75rem;
  22. padding: 3px 10px;
  23. border-radius: 20px;
  24. border: 1px solid var(--tblr-border-color);
  25. color: var(--tblr-secondary);
  26. }
  27. .wiki-lang-pill strong {
  28. font-weight: 500;
  29. color: var(--tblr-body-color);
  30. margin-right: 3px;
  31. }
  32. .wiki-entry-lang-switcher {
  33. display: flex;
  34. flex-wrap: wrap;
  35. align-items: center;
  36. gap: 6px;
  37. padding: 0.625rem 0.875rem;
  38. background: var(--tblr-bg-surface-secondary);
  39. border-radius: var(--tblr-border-radius);
  40. margin-bottom: 1.25rem;
  41. font-size: 0.8125rem;
  42. }
  43. .wiki-entry-lang-label {
  44. color: var(--tblr-secondary);
  45. }
  46. .wiki-entry-lang-btn {
  47. font-size: 0.75rem;
  48. padding: 3px 10px;
  49. border-radius: 20px;
  50. border: 1px solid var(--tblr-border-color);
  51. color: var(--tblr-primary);
  52. text-decoration: none;
  53. transition: background 0.12s;
  54. }
  55. .wiki-entry-lang-btn:hover {
  56. background: var(--tblr-bg-surface);
  57. }
  58. /* ══════════════════════════════════════════
  59. 二、质量标签
  60. ══════════════════════════════════════════ */
  61. .wiki-quality-badge {
  62. display: inline-flex;
  63. align-items: center;
  64. gap: 5px;
  65. font-size: 0.6875rem;
  66. padding: 3px 10px;
  67. border-radius: 20px;
  68. font-weight: 500;
  69. margin-bottom: 4px;
  70. }
  71. .wiki-quality-dot {
  72. width: 6px;
  73. height: 6px;
  74. border-radius: 50%;
  75. flex-shrink: 0;
  76. }
  77. .wiki-badge--featured {
  78. background: #eaf3de;
  79. color: #3b6d11;
  80. border: 1px solid #c0dd97;
  81. }
  82. .wiki-badge--featured .wiki-quality-dot {
  83. background: #639922;
  84. }
  85. .wiki-badge--standard {
  86. background: rgba(var(--tblr-primary-rgb), 0.12);
  87. color: var(--tblr-primary);
  88. border: 1px solid rgba(var(--tblr-primary-rgb), 0.32);
  89. }
  90. .wiki-badge--standard .wiki-quality-dot {
  91. background: var(--tblr-primary);
  92. }
  93. .wiki-badge--draft {
  94. background: rgba(var(--tblr-orange-rgb), 0.12);
  95. color: var(--tblr-orange);
  96. border: 1px solid rgba(var(--tblr-orange-rgb), 0.32);
  97. }
  98. .wiki-badge--draft .wiki-quality-dot {
  99. background: var(--tblr-orange);
  100. }
  101. .wiki-badge--pending {
  102. background: rgba(var(--tblr-secondary-rgb), 0.12);
  103. color: var(--tblr-secondary);
  104. border: 1px solid rgba(var(--tblr-secondary-rgb), 0.32);
  105. }
  106. .wiki-badge--pending .wiki-quality-dot {
  107. background: var(--tblr-secondary);
  108. }
  109. /* ══════════════════════════════════════════
  110. 三、标签
  111. ══════════════════════════════════════════ */
  112. .wiki-tags {
  113. display: flex;
  114. flex-wrap: wrap;
  115. gap: 6px;
  116. padding-top: 1rem;
  117. border-top: 1px solid var(--tblr-border-color);
  118. margin-top: 1.5rem;
  119. }
  120. .wiki-tag {
  121. font-size: 0.75rem;
  122. padding: 3px 10px;
  123. border-radius: 20px;
  124. border: 1px solid var(--tblr-border-color);
  125. color: var(--tblr-secondary);
  126. text-decoration: none;
  127. transition: background 0.12s;
  128. }
  129. .wiki-tag:hover {
  130. background: var(--tblr-bg-surface-secondary);
  131. color: var(--tblr-body-color);
  132. }
  133. /* ══════════════════════════════════════════
  134. 四、首页组件
  135. ══════════════════════════════════════════ */
  136. .wiki-today-banner {
  137. background: var(--tblr-bg-surface-secondary);
  138. border: 1px solid var(--tblr-border-color);
  139. border-radius: var(--tblr-border-radius-lg);
  140. padding: 1.25rem 1.5rem;
  141. display: flex;
  142. gap: 1.25rem;
  143. align-items: flex-start;
  144. }
  145. .wiki-today-icon {
  146. width: 48px;
  147. height: 48px;
  148. border-radius: var(--tblr-border-radius);
  149. background: #e1f5ee;
  150. display: flex;
  151. align-items: center;
  152. justify-content: center;
  153. font-size: 1.375rem;
  154. flex-shrink: 0;
  155. }
  156. .wiki-today-label {
  157. font-size: 0.6875rem;
  158. text-transform: uppercase;
  159. letter-spacing: 0.05em;
  160. color: var(--tblr-secondary);
  161. margin-bottom: 4px;
  162. }
  163. .wiki-today-title {
  164. font-family: 'Noto Serif', Georgia, serif;
  165. font-size: 1.125rem;
  166. font-weight: 600;
  167. margin-bottom: 6px;
  168. color: var(--tblr-body-color);
  169. }
  170. .wiki-today-snippet {
  171. font-size: 0.875rem;
  172. color: var(--tblr-secondary);
  173. line-height: 1.6;
  174. }
  175. .wiki-today-link {
  176. font-size: 0.8125rem;
  177. color: var(--tblr-primary);
  178. text-decoration: none;
  179. margin-top: 10px;
  180. display: inline-block;
  181. }
  182. /* ══════════════════════════════════════════
  183. 五、term-ref 行内术语标记
  184. ══════════════════════════════════════════ */
  185. .term-ref {
  186. font-style: italic;
  187. color: var(--tblr-primary);
  188. border-bottom: 1px dotted var(--tblr-primary);
  189. cursor: pointer;
  190. }
  191. /* ══════════════════════════════════════════
  192. 六、Term Popover(桌面)
  193. ══════════════════════════════════════════ */
  194. .wiki-term-popover.popover {
  195. max-width: 280px;
  196. font-size: 0.8125rem;
  197. border: 0.5px solid var(--tblr-border-color);
  198. border-radius: var(--tblr-border-radius-lg);
  199. box-shadow: none;
  200. }
  201. .wiki-term-popover .popover-arrow {
  202. display: none;
  203. }
  204. .wiki-term-popover .popover-body {
  205. padding: 0;
  206. }
  207. .wiki-popover-word {
  208. font-family: 'Noto Serif', Georgia, serif;
  209. font-size: 0.9375rem;
  210. font-style: italic;
  211. font-weight: 600;
  212. color: var(--tblr-primary);
  213. padding: 10px 14px;
  214. border-bottom: 0.5px solid var(--tblr-border-color);
  215. }
  216. .wiki-popover-meaning {
  217. font-size: 0.9rem;
  218. font-weight: 500;
  219. color: var(--tblr-body-color);
  220. padding: 8px 14px 4px;
  221. }
  222. .wiki-popover-summary {
  223. font-size: 0.8125rem;
  224. color: var(--tblr-secondary);
  225. line-height: 1.55;
  226. padding: 0 14px 12px;
  227. }
  228. /* ══════════════════════════════════════════
  229. 七、Term Drawer(移动端,所有阅读页公用)
  230. ══════════════════════════════════════════ */
  231. .wiki-term-drawer {
  232. border-radius: 1rem 1rem 0 0;
  233. max-height: 55vh;
  234. }
  235. .wiki-term-drawer .offcanvas-header {
  236. padding-top: 0.6rem;
  237. padding-bottom: 0.6rem;
  238. }
  239. .wiki-drawer-word {
  240. font-family: 'Noto Serif', Georgia, serif;
  241. font-size: 1.125rem;
  242. font-style: italic;
  243. font-weight: 600;
  244. color: var(--tblr-primary);
  245. }
  246. .wiki-drawer-meaning {
  247. font-size: 0.9375rem;
  248. font-weight: 500;
  249. color: var(--tblr-body-color);
  250. margin-top: 2px;
  251. }
  252. .wiki-drawer-summary {
  253. font-size: 0.9375rem;
  254. color: var(--tblr-body-color);
  255. line-height: 1.65;
  256. }
  257. .wiki-drawer-link {
  258. display: inline-block;
  259. margin-top: 1rem;
  260. font-size: 0.875rem;
  261. color: var(--tblr-primary);
  262. text-decoration: none;
  263. }
  264. .wiki-term-card-word {
  265. font-family: 'Noto Serif', Georgia, serif;
  266. font-size: 0.9375rem;
  267. font-style: italic;
  268. font-weight: 600;
  269. color: var(--tblr-primary);
  270. padding: 8px;
  271. margin-bottom: 8px;
  272. border-bottom: 0.5px solid var(--tblr-border-color);
  273. }
  274. .wiki-term-card-meaning {
  275. font-size: 0.875rem;
  276. font-weight: 500;
  277. color: var(--tblr-body-color);
  278. margin-bottom: 5px;
  279. }
  280. .wiki-term-card-summary {
  281. font-size: 0.8125rem;
  282. color: var(--tblr-secondary);
  283. line-height: 1.55;
  284. }
  285. /* Skeleton */
  286. .wiki-term-skeleton-word,
  287. .wiki-term-skeleton-line {
  288. background: linear-gradient(90deg, #e8e8e8 25%, #f5f5f5 50%, #e8e8e8 75%);
  289. background-size: 200% 100%;
  290. animation: wiki-skeleton-shimmer 1.2s infinite;
  291. border-radius: 4px;
  292. }
  293. .wiki-term-skeleton-word {
  294. height: 18px;
  295. width: 120px;
  296. margin-bottom: 8px;
  297. }
  298. .wiki-term-skeleton-line {
  299. height: 13px;
  300. width: 100%;
  301. margin-bottom: 6px;
  302. }
  303. .wiki-term-skeleton-line.short {
  304. width: 60%;
  305. }
  306. @keyframes wiki-skeleton-shimmer {
  307. 0% {
  308. background-position: 200% 0;
  309. }
  310. 100% {
  311. background-position: -200% 0;
  312. }
  313. }
  314. /* ══════════════════════════════════════════
  315. 八、正文排版(.wiki-content-body)
  316. ══════════════════════════════════════════ */
  317. .wiki-content-body {
  318. font-family: 'Noto Serif', Georgia, 'Times New Roman', serif;
  319. font-size: 1rem;
  320. line-height: 1.875;
  321. color: var(--tblr-body-color);
  322. word-break: break-word;
  323. overflow-wrap: break-word;
  324. }
  325. .wiki-content-body p {
  326. margin-top: 0;
  327. margin-bottom: 1.125em;
  328. }
  329. .wiki-content-body h1,
  330. .wiki-content-body h2,
  331. .wiki-content-body h3,
  332. .wiki-content-body h4,
  333. .wiki-content-body h5,
  334. .wiki-content-body h6 {
  335. font-family: 'Noto Serif', Georgia, serif;
  336. font-weight: 600;
  337. line-height: 1.3;
  338. color: var(--tblr-body-color);
  339. margin-top: 2em;
  340. margin-bottom: 0.6em;
  341. scroll-margin-top: 80px;
  342. }
  343. .wiki-content-body h1 {
  344. font-size: 1.375rem;
  345. padding-bottom: 0.4em;
  346. border-bottom: 2px solid var(--tblr-border-color);
  347. }
  348. .wiki-content-body h2 {
  349. font-size: 1.25rem;
  350. padding-bottom: 0.4em;
  351. border-bottom: 1px solid var(--tblr-border-color);
  352. }
  353. .wiki-content-body h3 {
  354. font-size: 1.0625rem;
  355. }
  356. .wiki-content-body h4 {
  357. font-size: 0.9375rem;
  358. font-weight: 600;
  359. color: var(--tblr-secondary);
  360. }
  361. .wiki-content-body strong,
  362. .wiki-content-body b {
  363. font-weight: 600;
  364. }
  365. .wiki-content-body em,
  366. .wiki-content-body i {
  367. font-style: italic;
  368. }
  369. .wiki-content-body a {
  370. color: var(--tblr-primary);
  371. text-decoration: none;
  372. border-bottom: 1px solid transparent;
  373. transition: border-color 0.12s;
  374. }
  375. .wiki-content-body a:hover {
  376. border-bottom-color: var(--tblr-primary);
  377. }
  378. .wiki-content-body blockquote {
  379. margin: 1.5em 0;
  380. padding: 0.875rem 1.125rem;
  381. border-left: 3px solid var(--tblr-border-color-dark, #adb5bd);
  382. background: var(--tblr-bg-surface-secondary);
  383. border-radius: 0 var(--tblr-border-radius) var(--tblr-border-radius) 0;
  384. font-size: 0.9375rem;
  385. line-height: 1.75;
  386. }
  387. .wiki-content-body blockquote p {
  388. margin-bottom: 0.5em;
  389. }
  390. .wiki-content-body blockquote p:last-child {
  391. margin-bottom: 0;
  392. }
  393. .wiki-content-body blockquote cite {
  394. display: block;
  395. margin-top: 0.625rem;
  396. font-size: 0.8125rem;
  397. font-style: normal;
  398. color: var(--tblr-secondary);
  399. }
  400. .wiki-content-body ul,
  401. .wiki-content-body ol {
  402. padding-left: 1.5em;
  403. margin-bottom: 1.125em;
  404. }
  405. .wiki-content-body li {
  406. margin-bottom: 0.375em;
  407. line-height: 1.75;
  408. }
  409. .wiki-content-body table {
  410. width: 100%;
  411. border-collapse: collapse;
  412. font-size: 0.9rem;
  413. margin-bottom: 1.5em;
  414. }
  415. .wiki-content-body th {
  416. font-family: 'Noto Serif', Georgia, serif;
  417. font-weight: 600;
  418. font-size: 0.8125rem;
  419. text-align: left;
  420. padding: 8px 12px;
  421. background: var(--tblr-bg-surface-secondary);
  422. border-bottom: 2px solid var(--tblr-border-color);
  423. color: var(--tblr-secondary);
  424. text-transform: uppercase;
  425. letter-spacing: 0.04em;
  426. }
  427. .wiki-content-body td {
  428. padding: 8px 12px;
  429. border-bottom: 1px solid var(--tblr-border-color);
  430. vertical-align: top;
  431. }
  432. .wiki-content-body tr:last-child td {
  433. border-bottom: none;
  434. }
  435. .wiki-content-body code {
  436. font-family: var(
  437. --tblr-font-monospace,
  438. 'SFMono-Regular',
  439. Consolas,
  440. monospace
  441. );
  442. font-size: 0.875em;
  443. background: var(--tblr-bg-surface-secondary);
  444. border: 1px solid var(--tblr-border-color);
  445. border-radius: 4px;
  446. padding: 1px 5px;
  447. }
  448. .wiki-content-body hr {
  449. border: none;
  450. border-top: 1px solid var(--tblr-border-color);
  451. margin: 2em 0;
  452. }
  453. .wiki-content-body img {
  454. max-width: 100%;
  455. height: auto;
  456. border-radius: var(--tblr-border-radius);
  457. margin: 0.75em 0;
  458. }
  459. .wiki-content-body figure {
  460. margin: 1.5em 0;
  461. text-align: center;
  462. }
  463. .wiki-content-body figcaption {
  464. font-size: 0.8125rem;
  465. color: var(--tblr-secondary);
  466. margin-top: 0.5em;
  467. font-style: italic;
  468. }
  469. /* ══════════════════════════════════════════
  470. 九、Wiki 首页
  471. ══════════════════════════════════════════ */
  472. .wiki-home-container {
  473. display: flex;
  474. flex-direction: column;
  475. align-items: center;
  476. justify-content: center;
  477. min-height: calc(100vh - 300px);
  478. padding: 3rem 1.5rem;
  479. }
  480. .wiki-home-wheel {
  481. margin-bottom: 1.5rem;
  482. }
  483. .wiki-home-wheel-img {
  484. width: 120px;
  485. height: auto;
  486. opacity: 0.85;
  487. transition: transform 0.3s ease;
  488. }
  489. .wiki-home-wheel-img:hover {
  490. transform: scale(1.05);
  491. }
  492. .wiki-home-title {
  493. text-align: center;
  494. margin-bottom: 2rem;
  495. }
  496. .wiki-home-title h1 {
  497. font-family: 'Noto Serif', Georgia, serif;
  498. font-size: 2.25rem;
  499. font-weight: 600;
  500. color: var(--tblr-body-color);
  501. margin-bottom: 0.5rem;
  502. }
  503. .wiki-home-search {
  504. width: 100%;
  505. max-width: 640px;
  506. margin: 0 auto 1.5rem;
  507. }
  508. .wiki-home-hot-tags {
  509. text-align: center;
  510. margin-bottom: 2.5rem;
  511. font-size: 0.9rem;
  512. }
  513. .wiki-hot-tag {
  514. display: inline-block;
  515. padding: 0.3rem 0.75rem;
  516. background: var(--tblr-bg-surface-secondary);
  517. border: 1px solid var(--tblr-border-color);
  518. border-radius: 20px;
  519. color: var(--tblr-secondary);
  520. font-size: 0.8125rem;
  521. text-decoration: none;
  522. margin: 2px;
  523. transition:
  524. background 0.12s,
  525. color 0.12s;
  526. }
  527. .wiki-hot-tag:hover {
  528. background: var(--wp-brand-light);
  529. border-color: var(--wp-brand);
  530. color: var(--wp-brand-dark);
  531. }
  532. .wiki-home-languages {
  533. width: 100%;
  534. max-width: 800px;
  535. margin: 0 auto 2rem;
  536. }
  537. .wiki-home-divider {
  538. display: flex;
  539. align-items: center;
  540. text-align: center;
  541. margin-bottom: 1.5rem;
  542. gap: 1.5rem;
  543. color: var(--tblr-secondary);
  544. font-size: 0.875rem;
  545. }
  546. .wiki-home-divider::before,
  547. .wiki-home-divider::after {
  548. content: '';
  549. flex: 1;
  550. border-bottom: 1px solid var(--tblr-border-color);
  551. }
  552. .wiki-language-tags {
  553. display: flex;
  554. flex-wrap: wrap;
  555. justify-content: center;
  556. gap: 0.75rem;
  557. }
  558. .wiki-language-tag {
  559. display: inline-block;
  560. padding: 0.4rem 1.125rem;
  561. background: var(--tblr-bg-surface-secondary);
  562. border: 1px solid var(--tblr-border-color);
  563. border-radius: 30px;
  564. color: var(--tblr-body-color);
  565. font-size: 0.875rem;
  566. text-decoration: none;
  567. transition:
  568. background 0.12s,
  569. border-color 0.12s;
  570. }
  571. .wiki-language-tag:hover {
  572. background: var(--wp-brand-light);
  573. border-color: var(--wp-brand);
  574. color: var(--wp-brand-dark);
  575. }
  576. .wiki-language-tag.active {
  577. background: var(--wp-brand);
  578. border-color: var(--wp-brand);
  579. color: #fff;
  580. }
  581. .wiki-language-tag.active:hover {
  582. background: var(--wp-brand-dark);
  583. border-color: var(--wp-brand-dark);
  584. }
  585. .wiki-home-stats {
  586. text-align: center;
  587. font-size: 0.875rem;
  588. padding-top: 1.5rem;
  589. border-top: 1px solid var(--tblr-border-color);
  590. width: 100%;
  591. max-width: 640px;
  592. }
  593. @media (max-width: 768px) {
  594. .wiki-home-container {
  595. min-height: calc(100vh - 200px);
  596. padding: 2rem 1rem;
  597. }
  598. .wiki-home-wheel-img {
  599. width: 90px;
  600. }
  601. .wiki-home-title h1 {
  602. font-size: 1.75rem;
  603. }
  604. .wiki-language-tag {
  605. padding: 0.35rem 0.875rem;
  606. font-size: 0.8125rem;
  607. }
  608. }
  609. /* ── 追加到 resources/css/wiki.css 末尾 ── */
  610. /* ── 二级分类大块容器 ── */
  611. .wiki-subcat-block {
  612. padding: 0;
  613. }
  614. .wiki-subcat-block-header {
  615. display: flex;
  616. align-items: center;
  617. justify-content: space-between;
  618. padding: 1rem 1.5rem 0.875rem;
  619. border-bottom: 1px solid var(--tblr-border-color);
  620. }
  621. .wiki-subcat-block-title {
  622. font-size: 0.9375rem;
  623. font-weight: 600;
  624. color: var(--tblr-body-color);
  625. }
  626. .wiki-subcat-block-more {
  627. font-size: 0.8125rem;
  628. color: var(--tblr-primary);
  629. text-decoration: none;
  630. }
  631. .wiki-subcat-block-more:hover {
  632. text-decoration: underline;
  633. }
  634. /* ── 单个二级分类 ── */
  635. .wiki-subcat {
  636. padding: 1rem 1.5rem;
  637. border-bottom: 1px solid var(--tblr-border-color);
  638. }
  639. .wiki-subcat:last-child {
  640. border-bottom: none;
  641. }
  642. .wiki-subcat-header {
  643. display: flex;
  644. align-items: center;
  645. gap: 8px;
  646. margin-bottom: 0.625rem;
  647. }
  648. .wiki-subcat-title {
  649. font-size: 0.8125rem;
  650. font-weight: 500;
  651. color: var(--tblr-secondary);
  652. text-transform: uppercase;
  653. letter-spacing: 0.04em;
  654. }
  655. .wiki-subcat-count {
  656. font-size: 0.6875rem;
  657. color: var(--tblr-secondary);
  658. background: var(--tblr-bg-surface-secondary);
  659. border: 1px solid var(--tblr-border-color);
  660. border-radius: 20px;
  661. padding: 1px 7px;
  662. }
  663. /* ── 词条列表 (flex wrap) ── */
  664. .wiki-subcat-entries {
  665. display: flex;
  666. flex-wrap: wrap;
  667. gap: 4px 0;
  668. }
  669. /* ── 单个术语链接 ── */
  670. .wiki-term-link {
  671. display: inline-flex;
  672. align-items: baseline;
  673. gap: 4px;
  674. padding: 3px 8px;
  675. border-radius: var(--tblr-border-radius);
  676. text-decoration: none;
  677. font-size: 0.875rem;
  678. transition: background 0.1s;
  679. color: var(--tblr-primary);
  680. }
  681. .wiki-term-link:hover {
  682. background: var(--tblr-bg-surface-secondary);
  683. text-decoration: none;
  684. color: var(--tblr-primary);
  685. }
  686. .wiki-term-link-word {
  687. font-style: italic;
  688. color: var(--tblr-secondary);
  689. }
  690. .wiki-term-link-zh {
  691. font-size: 0.8125rem;
  692. }
  693. /* =========================
  694. Wiki Term Link States
  695. 典范条目 featured(蓝色 + 星标)
  696. 规范条目 standard(蓝色)
  697. 草稿 draft(橙色)
  698. 待定 pending(灰色 + 删除线)
  699. ========================= */
  700. /* 通用链接颜色继承 */
  701. .wiki-term-link--featured,
  702. .wiki-term-link--standard,
  703. .wiki-term-link--draft,
  704. .wiki-term-link--pending {
  705. position: relative;
  706. }
  707. .wiki-term-link--featured:hover,
  708. .wiki-term-link--standard:hover,
  709. .wiki-term-link--draft:hover,
  710. .wiki-term-link--pending:hover {
  711. color: inherit;
  712. }
  713. /* =========================
  714. 典范条目 Featured
  715. ========================= */
  716. .wiki-term-link--featured {
  717. color: var(--tblr-green);
  718. }
  719. .wiki-term-link--featured::before {
  720. content: '★';
  721. display: inline-block;
  722. margin-right: 0.2em;
  723. font-size: 0.75em;
  724. vertical-align: middle;
  725. opacity: 0.9;
  726. }
  727. /* 若想改圆点可用:
  728. content: "●";
  729. */
  730. /* =========================
  731. 规范条目 Standard
  732. ========================= */
  733. .wiki-term-link--standard {
  734. color: var(--tblr-primary);
  735. }
  736. /* =========================
  737. 草稿 Draft
  738. ========================= */
  739. .wiki-term-link--draft {
  740. color: var(--tblr-orange);
  741. }
  742. /* =========================
  743. 待定 Pending
  744. (保持原有效果)
  745. ========================= */
  746. .wiki-term-link--pending {
  747. color: var(--tblr-secondary);
  748. }
  749. .wiki-term-link--pending .wiki-term-link-word {
  750. text-decoration: line-through;
  751. text-decoration-color: var(--tblr-border-color-dark, #adb5bd);
  752. }
  753. .wiki-quality-filter-item {
  754. display: flex;
  755. justify-content: space-between;
  756. align-items: center;
  757. gap: 8px;
  758. }
  759. .wiki-quality-filter-item span:last-child {
  760. font-size: 0.75rem;
  761. color: var(--tblr-secondary);
  762. margin-left: auto;
  763. flex-shrink: 0;
  764. }
  765. /* ── 条目操作按钮 ── */
  766. .wiki-entry-card {
  767. position: relative;
  768. }
  769. .wiki-entry-actions {
  770. position: absolute;
  771. top: 1.25rem;
  772. right: 1.5rem;
  773. display: flex;
  774. gap: 4px;
  775. }
  776. .wiki-action-btn {
  777. display: inline-flex;
  778. align-items: center;
  779. justify-content: center;
  780. width: 32px;
  781. height: 32px;
  782. border-radius: var(--tblr-border-radius);
  783. border: 1px solid var(--tblr-border-color);
  784. background: var(--tblr-bg-surface);
  785. color: var(--tblr-secondary);
  786. cursor: pointer;
  787. text-decoration: none;
  788. transition:
  789. background 0.12s,
  790. color 0.12s;
  791. }
  792. .wiki-action-btn:hover {
  793. background: var(--tblr-bg-surface-secondary);
  794. color: var(--tblr-body-color);
  795. }
  796. /* ── 微信二维码弹窗 ── */
  797. .wiki-wechat-modal {
  798. position: fixed;
  799. inset: 0;
  800. z-index: 1050;
  801. display: flex;
  802. align-items: center;
  803. justify-content: center;
  804. }
  805. .wiki-wechat-modal-backdrop {
  806. position: absolute;
  807. inset: 0;
  808. background: rgba(0, 0, 0, 0.45);
  809. }
  810. .wiki-wechat-modal-box {
  811. position: relative;
  812. background: var(--tblr-bg-surface);
  813. border-radius: var(--tblr-border-radius-lg);
  814. padding: 1.5rem;
  815. text-align: center;
  816. width: 220px;
  817. box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  818. }
  819. .wiki-wechat-modal-title {
  820. font-weight: 600;
  821. margin-bottom: 4px;
  822. }
  823. .wiki-wechat-modal-desc {
  824. font-size: 0.8125rem;
  825. color: var(--tblr-secondary);
  826. margin-bottom: 1rem;
  827. }
  828. .wiki-wechat-qr img {
  829. border-radius: var(--tblr-border-radius);
  830. }
  831. .wiki-wechat-modal-close {
  832. margin-top: 1rem;
  833. font-size: 0.8125rem;
  834. color: var(--tblr-secondary);
  835. background: none;
  836. border: none;
  837. cursor: pointer;
  838. text-decoration: underline;
  839. }
  840. .wiki-other-versions {
  841. padding-top: 1.25rem;
  842. margin-top: 1.25rem;
  843. border-top: 1px solid var(--tblr-border-color);
  844. }