common.css 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692
  1. @media (prefers-color-scheme: dark) {
  2. html {
  3. background-color: #002b36;
  4. }
  5. html[data-theme='light'] {
  6. background-color: transparent;
  7. }
  8. }
  9. @supports (font-variation-settings: normal) {
  10. html {
  11. font-family: 'Inter var', sans-serif;
  12. }
  13. }
  14. html:not(.is-native-android) {
  15. font-family: var(--ls-font-family), sans-serif, system-ui, -apple-system,
  16. BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans',
  17. serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol !important;
  18. }
  19. /* region Reset top elements */
  20. html {
  21. overflow: hidden;
  22. }
  23. body {
  24. color: var(--lx-gray-12, var(--ls-primary-text-color, hsl(var(--foreground))));
  25. background-color: var(--lx-gray-01, var(--ls-primary-background-color, hsl(var(--background))));
  26. line-height: 1.5;
  27. min-height: 100%;
  28. word-break: break-word; /* compatible for overflow-wrap: anywhere */
  29. overflow-y: overlay;
  30. }
  31. @layer base {
  32. svg {
  33. pointer-events: none;
  34. }
  35. textarea {
  36. overflow: hidden;
  37. padding: 8px;
  38. border: 1px solid rgba(39, 41, 43, 0.15);
  39. border-radius: var(--ls-border-radius-low);
  40. font-size: 1em;
  41. line-height: 1.5;
  42. width: 100%;
  43. resize: none;
  44. outline: none;
  45. font-weight: inherit;
  46. letter-spacing: inherit;
  47. text-size-adjust: 100%;
  48. background: var(--ls-primary-background-color);
  49. }
  50. ul {
  51. list-style: circle;
  52. margin-left: 1.2em;
  53. }
  54. ol {
  55. list-style: decimal;
  56. margin-left: 1.2em;
  57. }
  58. p {
  59. line-height: 1.5;
  60. margin: 0.5rem 0;
  61. color: var(--ls-primary-text-color);
  62. }
  63. li {
  64. margin: 0.25rem 0;
  65. }
  66. pre {
  67. background: var(--ls-secondary-background-color, #f6f8fa);
  68. margin: 1rem 0;
  69. line-height: 1.45em;
  70. overflow: auto;
  71. }
  72. a {
  73. cursor: pointer;
  74. color: var(--lx-accent-11, var(--ls-link-text-color, hsl(var(--primary)/.8)));
  75. text-decoration: none;
  76. }
  77. a:hover {
  78. color: var(--lx-accent-12, var(--ls-link-text-hover-color, hsl(var(--primary))));
  79. }
  80. code {
  81. font-size: 85%;
  82. }
  83. pre.code {
  84. background: #282a36;
  85. background: var(--ls-secondary-background-color);
  86. color: var(--ls-primary-text-color, #f8f8f2);
  87. }
  88. dl {
  89. margin: 1rem 0;
  90. }
  91. dt {
  92. margin-bottom: 0.25rem;
  93. font-weight: bold;
  94. }
  95. blockquote {
  96. display: block;
  97. text-indent: 0;
  98. padding: 8px 20px;
  99. border-left: 4px solid;
  100. background-color: var(--ls-page-blockquote-bg-color, var(--lx-gray-04, hsl(var(--secondary))));
  101. color: var(--ls-page-blockquote-color, hsl(var(--secondary-foreground)));
  102. margin: 1rem 0;
  103. font-size: 1rem;
  104. }
  105. html blockquote {
  106. border-left-color: var(--ls-page-blockquote-border-color, var(--lx-gray-05-alpha, hsl(var(--primary)/.4)));
  107. }
  108. summary {
  109. outline: none;
  110. }
  111. iframe {
  112. width: 100%;
  113. margin: 1rem 0;
  114. }
  115. img,
  116. video {
  117. margin-left: auto;
  118. margin-right: auto;
  119. }
  120. ::selection {
  121. background: var(--ls-selection-background-color);
  122. color: var(--ls-primary-text-color);
  123. }
  124. ::-moz-selection {
  125. background: var(--ls-selection-background-color);
  126. color: var(--ls-primary-text-color);
  127. }
  128. }
  129. /* endregion */
  130. /** region App utilities **/
  131. .ls-center {
  132. position: absolute;
  133. top: 50%;
  134. left: 50%;
  135. transform: translate(-50%, -50%);
  136. }
  137. li p:first-child,
  138. .block-body p:first-child {
  139. margin-top: 0;
  140. }
  141. li p:last-child,
  142. .block-body p:last-child,
  143. .block-body ul:last-child,
  144. .block-body ol:last-child,
  145. .block-body dl:last-child {
  146. margin-bottom: 0;
  147. }
  148. .bg-base-2 {
  149. background-color: var(--ls-secondary-background-color, #f0f8ff);
  150. }
  151. .bg-base-3 {
  152. background-color: var(--ls-primary-background-color, #fff);
  153. }
  154. .bg-base-4 {
  155. background-color: var(--ls-tertiary-background-color);
  156. }
  157. .pre-white-space {
  158. white-space: pre;
  159. }
  160. .pre-wrap-white-space {
  161. white-space: pre-wrap;
  162. }
  163. .pre-line-white-space {
  164. white-space: pre-line;
  165. }
  166. .cursor-pointer,
  167. .cursor {
  168. cursor: pointer;
  169. }
  170. .external-link {
  171. text-decoration: none;
  172. border-bottom: 1px solid;
  173. &:hover {
  174. cursor: alias;
  175. }
  176. }
  177. .noscroll {
  178. position: fixed;
  179. overflow-y: scroll;
  180. }
  181. .canceled,
  182. .cancelled,
  183. .done {
  184. text-decoration: line-through;
  185. opacity: 0.6;
  186. }
  187. .opacity-30 {
  188. opacity: 0.3;
  189. }
  190. .opacity-70 {
  191. opacity: 0.7;
  192. }
  193. .opacity-80 {
  194. opacity: 0.8;
  195. }
  196. .done > input {
  197. opacity: 1;
  198. }
  199. .page-drop-options {
  200. width: 18em;
  201. }
  202. .fixed-width {
  203. max-width: calc(var(--ls-main-content-max-width) - 30px);
  204. }
  205. .center,
  206. .foldable-title {
  207. margin: 0 auto;
  208. }
  209. .translate-x-5 {
  210. --transform-translate-x: 1.25rem;
  211. }
  212. .done,
  213. .canceled,
  214. .cancelled {
  215. opacity: 0.7;
  216. }
  217. .tip-shadow {
  218. -webkit-filter: drop-shadow(1px 1px 2px rgba(155, 155, 0, 0.8));
  219. filter: drop-shadow(1px 1px 2px rgba(155, 155, 0, 0.8));
  220. }
  221. .admonition-icon {
  222. @apply border-r;
  223. }
  224. i.ti {
  225. /*
  226. compensates the wrong top spacing in the iconfont.
  227. See https://github.com/tabler/tabler-icons/issues/118/
  228. */
  229. transform: translateY(-1px);
  230. }
  231. .dnd-separator {
  232. border-bottom: 3px solid #ccc;
  233. }
  234. .aspect-ratio-square {
  235. padding-top: 100%;
  236. }
  237. .aspect-ratio-16\/9 {
  238. padding-top: 56.25%;
  239. }
  240. .aspect-ratio-4\/3 {
  241. padding-top: 75%;
  242. }
  243. .aspect-ratio-21\/9 {
  244. padding-top: 42.86%;
  245. }
  246. .admonitionblock {
  247. @apply my-2 p-2;
  248. }
  249. .heading-bg {
  250. @apply rounded-full w-[18px] h-[18px];
  251. &.remove {
  252. @apply border flex items-center justify-center border-gray-07 hover:border-gray-09;
  253. }
  254. }
  255. .to-heading-button {
  256. @apply px-1 text-lg;
  257. }
  258. /** endregion **/
  259. /* region FIXME: override elements (?) */
  260. h1.title, h1.title input, .ls-page-title-container {
  261. @apply font-medium;
  262. color: var(--lx-gray-12, var(--ls-title-text-color, hsl(var(--foreground))));
  263. font-size: var(--ls-page-title-size, 32px);
  264. }
  265. .block-highlight,
  266. .content .selected,
  267. .ls-dummy-block.selected {
  268. transition: background-color 0.2s cubic-bezier(0, 1, 0, 1);
  269. background-color: var(--ls-block-highlight-color, var(--rx-gray-04));
  270. }
  271. span.timestamp {
  272. margin: 0 0.25rem;
  273. }
  274. span.priority {
  275. color: #6b7280;
  276. }
  277. .form-checkbox:not(:checked):focus {
  278. box-shadow: none;
  279. }
  280. .form-checkbox:checked:focus {
  281. box-shadow: none;
  282. }
  283. a.nav-item:hover,
  284. a.star-page:hover {
  285. background-color: #00242d;
  286. }
  287. button.menu {
  288. border-right: 1px solid;
  289. border-right-color: var(--ls-secondary-background-color, #f0f8ff);
  290. color: var(--ls-link-text-color, #24292e);
  291. }
  292. .menu-link:hover,
  293. button.pull:hover,
  294. button.menu:focus {
  295. background-color: or(--lx-gray-05, --ls-menu-hover-color, --rx-gray-05);
  296. }
  297. .menu-links-wrapper,
  298. .menu-links-outer {
  299. @apply py-2 rounded-md shadow-lg overflow-y-auto border bg-popover min-w-[12rem];
  300. max-height: calc(100vh - 100px) !important;
  301. }
  302. .menu-backdrop {
  303. @apply w-full h-full fixed top-0 left-0;
  304. z-index: var(--ls-z-index-level-1);
  305. }
  306. .menu-link {
  307. @apply text-popover-foreground/75 select-none hover:text-popover-foreground/100;
  308. @apply text-sm px-2 py-1.5 hover:rounded transition-opacity duration-150;
  309. }
  310. .menu-separator {
  311. @apply my-1 opacity-50 border-t;
  312. }
  313. a.login {
  314. color: var(--ls-link-text-color, #444);
  315. }
  316. a.login:hover {
  317. color: var(--ls-link-text-hover-color, #000);
  318. }
  319. a.tooltip-priority {
  320. display: contents;
  321. position: absolute;
  322. left: 0;
  323. }
  324. a.tooltip-priority::after {
  325. content: attr(priority);
  326. margin-right: 10px;
  327. }
  328. a.chosen {
  329. background: var(--ls-a-chosen-bg);
  330. }
  331. a.warning,
  332. span.warning,
  333. div.warning:not(.admonitionblock),
  334. p.warning {
  335. @apply bg-yellow-rx-05-alpha text-yellow-rx-08 dark:bg-yellow-rx-07-alpha
  336. dark:text-yellow-rx-10 rounded px-1.5 py-[2px] leading-none;
  337. }
  338. .text-warning {
  339. @apply text-yellow-500 dark:text-yellow-500/70;
  340. }
  341. .bg-warning {
  342. @apply bg-yellow-300 dark:bg-yellow-500/50;
  343. }
  344. a.error,
  345. span.error {
  346. background: var(--ls-error-background-color);
  347. padding: 0.1em 0.4em;
  348. border-radius: var(--ls-border-radius-low);
  349. color: var(--ls-error-text-color);
  350. }
  351. .text-error {
  352. color: var(--ls-error-text-color);
  353. }
  354. .bg-error {
  355. background: var(--ls-error-background-color);
  356. }
  357. .text-success {
  358. color: var(--ls-success-text-color);
  359. }
  360. .bg-success {
  361. background: var(--ls-success-background-color);
  362. }
  363. img.small {
  364. display: inline;
  365. width: 20px;
  366. height: 20px;
  367. margin-top: 0;
  368. margin-bottom: 0;
  369. }
  370. a.tag {
  371. @apply text-sm inline-flex items-center text-center cursor-pointer rounded opacity-70;
  372. color: var(--lx-accent-11, var(--ls-tag-text-color, hsl(var(--primary))));
  373. &:hover {
  374. opacity: var(--ls-tag-text-hover-opacity, 1);
  375. text-decoration: underline;
  376. }
  377. &[data-ref] + &[data-ref] {
  378. @apply mx-[3px];
  379. }
  380. }
  381. .preview-ref-link {
  382. @apply inline-block;
  383. & + &, & + a.tag, a.tag + & {
  384. @apply mx-[3px];
  385. }
  386. .block-title-wrap.as-heading {
  387. @apply my-0 pb-0;
  388. }
  389. .page-ref {
  390. .ui__icon.ti {
  391. @apply relative left-[2px] top-[5px];
  392. }
  393. }
  394. }
  395. svg.note {
  396. color: var(--rx-yellow-08);
  397. }
  398. svg.tip {
  399. color: var(--lx-accent-08, var(--rx-blue-08));
  400. }
  401. /* endregion */
  402. /* region FIXME: CodeMirror override (?) */
  403. .CodeMirror pre.CodeMirror-line,
  404. .CodeMirror-scroll,
  405. .CodeMirror-sizer,
  406. .CodeMirror-gutter,
  407. .CodeMirror-gutters,
  408. .CodeMirror-linenumber {
  409. font-size: 14px;
  410. }
  411. /* endregion */
  412. hr {
  413. margin: 2rem 0;
  414. border-color: var(--lx-gray-05, var(--ls-border-color, var(--rx-gray-05)));
  415. }
  416. .resize {
  417. resize: both;
  418. overflow: hidden;
  419. max-width: -webkit-fill-available;
  420. }
  421. /* ideas from https://github.com/PiotrSss/logseq-bujo-theme/blob/main/main.css */
  422. /***************************************************************
  423. ***************************** TOP ******************************
  424. ***************************************************************/
  425. .cp__header-logo,
  426. .fade-link {
  427. opacity: 0.8;
  428. transition: 0.3s;
  429. color: var(--ls-primary-text-color);
  430. }
  431. a.fade-link:hover {
  432. opacity: 1;
  433. }
  434. /* import (arrows) icon */
  435. #head .refresh svg {
  436. height: 20px;
  437. }
  438. .svg-small svg {
  439. transform: scale(0.6);
  440. display: inline;
  441. }
  442. /* < > buttons */
  443. a.navigation {
  444. border-radius: 3px;
  445. transition: 0.3s;
  446. }
  447. /* text mark/highlight */
  448. mark {
  449. background: var(--ls-page-mark-bg-color, #fef3ac);
  450. color: var(--ls-page-mark-color, #262626);
  451. padding: 0 4px;
  452. border-radius: 4px;
  453. }
  454. /* inline code */
  455. :not(pre) > code {
  456. border-radius: 3px;
  457. font-size: 0.9em;
  458. font-style: normal;
  459. font-family: MonoLisa, 'Fira Code', Monaco, Menlo, Consolas, 'COURIER NEW',
  460. monospace;
  461. letter-spacing: 0;
  462. background-color: var(--lx-gray-06, var(--ls-page-inline-code-bg-color, var(--rx-gray-05)));
  463. color: var(--lx-gray-11, var(--ls-page-inline-code-color, var(--rx-gray-11)));
  464. text-rendering: optimizeSpeed;
  465. }
  466. :not(pre):not(mark) > code {
  467. line-height: 1.45;
  468. padding: 3px 5px !important;
  469. border-radius: var(--ls-border-radius-low);
  470. -webkit-border-radius: var(--ls-border-radius-low);
  471. }
  472. mark > code {
  473. padding: 0;
  474. line-height: inherit !important;
  475. background: #fef3ac !important;
  476. color: #262626 !important;
  477. }
  478. .text-link {
  479. color: var(--ls-primary-text-color);
  480. }
  481. .katex * {
  482. border-color: var(--ls-primary-text-color);
  483. }
  484. #help-latex .katex-html {
  485. text-align: right;
  486. }
  487. a.page-op svg {
  488. transform: scale(0.9);
  489. }
  490. .search-more {
  491. background: var(--ls-a-chosen-bg);
  492. }
  493. .keyboard-shortcut > code {
  494. margin: 2px;
  495. background-color: var(--ls-quaternary-background-color);
  496. padding: 2px 4px !important;
  497. border-radius: 6px;
  498. color: var(--ls-secondary-text-color);
  499. }
  500. html[data-theme='light'] .keyboard-shortcut > code {
  501. box-shadow: inset 0 -1px 0 #433f3855, 0 0 1px 1px #433f3822;
  502. }
  503. html[data-theme='dark'] .keyboard-shortcut > code {
  504. box-shadow: inset 0 -1px 0 var(--ls-primary-background-color),
  505. 0 0 1px 1px rgba(255, 255, 255, 0.2);
  506. }
  507. .ui__modal-panel {
  508. border-radius: 8px;
  509. }
  510. .overflow-y-scroll {
  511. overflow-y: scroll;
  512. }
  513. .text-ellipsis-wrapper {
  514. white-space: nowrap;
  515. overflow: hidden;
  516. text-overflow: ellipsis;
  517. }
  518. .lazy-visibility {
  519. min-width: 1px;
  520. min-height: 1px;
  521. }
  522. .katex .tag {
  523. overflow-x: clip;
  524. }
  525. html.is-mobile {
  526. h1.title {
  527. margin-bottom: 10px;
  528. }
  529. #journals .journal-item:first-child {
  530. margin-top: 5px;
  531. }
  532. main.theme-container-inner {
  533. @apply overflow-x-hidden;
  534. }
  535. }
  536. @layer base {
  537. .ls-grid-cols {
  538. @apply grid grid-flow-col auto-cols-max;
  539. place-items: center;
  540. }
  541. /* fixes an html2canvas issue */
  542. img {
  543. @apply inline-block;
  544. }
  545. }
  546. button[role="checkbox"][data-state=unchecked] {
  547. border-color: var(--lx-gray-12, var(--ls-primary-text-color, hsl(var(--foreground))));
  548. }
  549. .dark-theme button[role="checkbox"][data-state=unchecked] {
  550. border-color: var(--lx-gray-11, var(--ls-primary-text-color, hsl(var(--foreground))));
  551. }