_wiki.css 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942
  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: background 0.12s, color 0.12s;
  524. }
  525. .wiki-hot-tag:hover {
  526. background: var(--wp-brand-light);
  527. border-color: var(--wp-brand);
  528. color: var(--wp-brand-dark);
  529. }
  530. .wiki-home-languages {
  531. width: 100%;
  532. max-width: 800px;
  533. margin: 0 auto 2rem;
  534. }
  535. .wiki-home-divider {
  536. display: flex;
  537. align-items: center;
  538. text-align: center;
  539. margin-bottom: 1.5rem;
  540. gap: 1.5rem;
  541. color: var(--tblr-secondary);
  542. font-size: 0.875rem;
  543. }
  544. .wiki-home-divider::before,
  545. .wiki-home-divider::after {
  546. content: "";
  547. flex: 1;
  548. border-bottom: 1px solid var(--tblr-border-color);
  549. }
  550. .wiki-language-tags {
  551. display: flex;
  552. flex-wrap: wrap;
  553. justify-content: center;
  554. gap: 0.75rem;
  555. }
  556. .wiki-language-tag {
  557. display: inline-block;
  558. padding: 0.4rem 1.125rem;
  559. background: var(--tblr-bg-surface-secondary);
  560. border: 1px solid var(--tblr-border-color);
  561. border-radius: 30px;
  562. color: var(--tblr-body-color);
  563. font-size: 0.875rem;
  564. text-decoration: none;
  565. transition: background 0.12s, border-color 0.12s;
  566. }
  567. .wiki-language-tag:hover {
  568. background: var(--wp-brand-light);
  569. border-color: var(--wp-brand);
  570. color: var(--wp-brand-dark);
  571. }
  572. .wiki-language-tag.active {
  573. background: var(--wp-brand);
  574. border-color: var(--wp-brand);
  575. color: #fff;
  576. }
  577. .wiki-language-tag.active:hover {
  578. background: var(--wp-brand-dark);
  579. border-color: var(--wp-brand-dark);
  580. }
  581. .wiki-home-stats {
  582. text-align: center;
  583. font-size: 0.875rem;
  584. padding-top: 1.5rem;
  585. border-top: 1px solid var(--tblr-border-color);
  586. width: 100%;
  587. max-width: 640px;
  588. }
  589. @media (max-width: 768px) {
  590. .wiki-home-container {
  591. min-height: calc(100vh - 200px);
  592. padding: 2rem 1rem;
  593. }
  594. .wiki-home-wheel-img {
  595. width: 90px;
  596. }
  597. .wiki-home-title h1 {
  598. font-size: 1.75rem;
  599. }
  600. .wiki-language-tag {
  601. padding: 0.35rem 0.875rem;
  602. font-size: 0.8125rem;
  603. }
  604. }
  605. /* ── 追加到 resources/css/wiki.css 末尾 ── */
  606. /* ── 二级分类大块容器 ── */
  607. .wiki-subcat-block {
  608. padding: 0;
  609. }
  610. .wiki-subcat-block-header {
  611. display: flex;
  612. align-items: center;
  613. justify-content: space-between;
  614. padding: 1rem 1.5rem 0.875rem;
  615. border-bottom: 1px solid var(--tblr-border-color);
  616. }
  617. .wiki-subcat-block-title {
  618. font-size: 0.9375rem;
  619. font-weight: 600;
  620. color: var(--tblr-body-color);
  621. }
  622. .wiki-subcat-block-more {
  623. font-size: 0.8125rem;
  624. color: var(--tblr-primary);
  625. text-decoration: none;
  626. }
  627. .wiki-subcat-block-more:hover {
  628. text-decoration: underline;
  629. }
  630. /* ── 单个二级分类 ── */
  631. .wiki-subcat {
  632. padding: 1rem 1.5rem;
  633. border-bottom: 1px solid var(--tblr-border-color);
  634. }
  635. .wiki-subcat:last-child {
  636. border-bottom: none;
  637. }
  638. .wiki-subcat-header {
  639. display: flex;
  640. align-items: center;
  641. gap: 8px;
  642. margin-bottom: 0.625rem;
  643. }
  644. .wiki-subcat-title {
  645. font-size: 0.8125rem;
  646. font-weight: 500;
  647. color: var(--tblr-secondary);
  648. text-transform: uppercase;
  649. letter-spacing: 0.04em;
  650. }
  651. .wiki-subcat-count {
  652. font-size: 0.6875rem;
  653. color: var(--tblr-secondary);
  654. background: var(--tblr-bg-surface-secondary);
  655. border: 1px solid var(--tblr-border-color);
  656. border-radius: 20px;
  657. padding: 1px 7px;
  658. }
  659. /* ── 词条列表 (flex wrap) ── */
  660. .wiki-subcat-entries {
  661. display: flex;
  662. flex-wrap: wrap;
  663. gap: 4px 0;
  664. }
  665. /* ── 单个术语链接 ── */
  666. .wiki-term-link {
  667. display: inline-flex;
  668. align-items: baseline;
  669. gap: 4px;
  670. padding: 3px 8px;
  671. border-radius: var(--tblr-border-radius);
  672. text-decoration: none;
  673. font-size: 0.875rem;
  674. transition: background 0.1s;
  675. color: var(--tblr-primary);
  676. }
  677. .wiki-term-link:hover {
  678. background: var(--tblr-bg-surface-secondary);
  679. text-decoration: none;
  680. color: var(--tblr-primary);
  681. }
  682. .wiki-term-link-word {
  683. font-style: italic;
  684. color: var(--tblr-secondary);
  685. }
  686. .wiki-term-link-zh {
  687. font-size: 0.8125rem;
  688. }
  689. /* =========================
  690. Wiki Term Link States
  691. 典范条目 featured(蓝色 + 星标)
  692. 规范条目 standard(蓝色)
  693. 草稿 draft(橙色)
  694. 待定 pending(灰色 + 删除线)
  695. ========================= */
  696. /* 通用链接颜色继承 */
  697. .wiki-term-link--featured,
  698. .wiki-term-link--standard,
  699. .wiki-term-link--draft,
  700. .wiki-term-link--pending {
  701. position: relative;
  702. }
  703. .wiki-term-link--featured:hover,
  704. .wiki-term-link--standard:hover,
  705. .wiki-term-link--draft:hover,
  706. .wiki-term-link--pending:hover {
  707. color: inherit;
  708. }
  709. /* =========================
  710. 典范条目 Featured
  711. ========================= */
  712. .wiki-term-link--featured {
  713. color: var(--tblr-green);
  714. }
  715. .wiki-term-link--featured::before {
  716. content: "★";
  717. display: inline-block;
  718. margin-right: 0.2em;
  719. font-size: 0.75em;
  720. vertical-align: middle;
  721. opacity: 0.9;
  722. }
  723. /* 若想改圆点可用:
  724. content: "●";
  725. */
  726. /* =========================
  727. 规范条目 Standard
  728. ========================= */
  729. .wiki-term-link--standard {
  730. color: var(--tblr-primary);
  731. }
  732. /* =========================
  733. 草稿 Draft
  734. ========================= */
  735. .wiki-term-link--draft {
  736. color: var(--tblr-orange);
  737. }
  738. /* =========================
  739. 待定 Pending
  740. (保持原有效果)
  741. ========================= */
  742. .wiki-term-link--pending {
  743. color: var(--tblr-secondary);
  744. }
  745. .wiki-term-link--pending .wiki-term-link-word {
  746. text-decoration: line-through;
  747. text-decoration-color: var(--tblr-border-color-dark, #adb5bd);
  748. }
  749. .wiki-quality-filter-item {
  750. display: flex;
  751. justify-content: space-between;
  752. align-items: center;
  753. gap: 8px;
  754. }
  755. .wiki-quality-filter-item span:last-child {
  756. font-size: 0.75rem;
  757. color: var(--tblr-secondary);
  758. margin-left: auto;
  759. flex-shrink: 0;
  760. }
  761. /* ── 条目操作按钮 ── */
  762. .wiki-entry-card {
  763. position: relative;
  764. }
  765. .wiki-entry-actions {
  766. position: absolute;
  767. top: 1.25rem;
  768. right: 1.5rem;
  769. display: flex;
  770. gap: 4px;
  771. }
  772. .wiki-action-btn {
  773. display: inline-flex;
  774. align-items: center;
  775. justify-content: center;
  776. width: 32px;
  777. height: 32px;
  778. border-radius: var(--tblr-border-radius);
  779. border: 1px solid var(--tblr-border-color);
  780. background: var(--tblr-bg-surface);
  781. color: var(--tblr-secondary);
  782. cursor: pointer;
  783. text-decoration: none;
  784. transition: background 0.12s, color 0.12s;
  785. }
  786. .wiki-action-btn:hover {
  787. background: var(--tblr-bg-surface-secondary);
  788. color: var(--tblr-body-color);
  789. }
  790. /* ── 微信二维码弹窗 ── */
  791. .wiki-wechat-modal {
  792. position: fixed;
  793. inset: 0;
  794. z-index: 1050;
  795. display: flex;
  796. align-items: center;
  797. justify-content: center;
  798. }
  799. .wiki-wechat-modal-backdrop {
  800. position: absolute;
  801. inset: 0;
  802. background: rgba(0, 0, 0, 0.45);
  803. }
  804. .wiki-wechat-modal-box {
  805. position: relative;
  806. background: var(--tblr-bg-surface);
  807. border-radius: var(--tblr-border-radius-lg);
  808. padding: 1.5rem;
  809. text-align: center;
  810. width: 220px;
  811. box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  812. }
  813. .wiki-wechat-modal-title {
  814. font-weight: 600;
  815. margin-bottom: 4px;
  816. }
  817. .wiki-wechat-modal-desc {
  818. font-size: 0.8125rem;
  819. color: var(--tblr-secondary);
  820. margin-bottom: 1rem;
  821. }
  822. .wiki-wechat-qr img {
  823. border-radius: var(--tblr-border-radius);
  824. }
  825. .wiki-wechat-modal-close {
  826. margin-top: 1rem;
  827. font-size: 0.8125rem;
  828. color: var(--tblr-secondary);
  829. background: none;
  830. border: none;
  831. cursor: pointer;
  832. text-decoration: underline;
  833. }