adark.css 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188
  1. @charset "UTF-8";
  2. /*=== GENERAL */
  3. /*============*/
  4. :root {
  5. --background-color-dark: #171717;
  6. --background-color-dark-transparent: #171717aa;
  7. --background-color-middle: #1f1f1f;
  8. --background-color-light: #262626;
  9. --background-color-hover: #1d242f;
  10. --background-color-active: #333;
  11. --background-color-slider-shadow: rgba(0, 0, 0, 0.5);
  12. --contrast-background-color: #0062b7;
  13. --contrast-background-color-hover: #0078e0;
  14. --contrast-background-color-active: #003461;
  15. --contrast-background-font-color: #eee;
  16. --contrast-border-color-hover: #0078e0;
  17. --contrast-attention-background-color: #912621;
  18. --contrast-attention-background-color-hover: #be342c;
  19. --contrast-attention-font-color: #eee;
  20. --font-color-dark: #666;
  21. --font-color-middle: #999;
  22. --font-color-light: #ccc;
  23. --font-color-contrast: #0062b7;
  24. --font-color-error: #912621;
  25. --border-color-dark: #333;
  26. --border-color-middle: #666;
  27. --frss-border-color: var(--border-color-dark);
  28. --border-color-favorite: #ffc300;
  29. --border-color-unread: #e74c3c;
  30. --empty-feed-color: #e67e22;
  31. --alert-warn-border-color: #615f20;
  32. --alert-success-border-color: #18521d;
  33. --alert-error-border-color: #912621;
  34. --notification-border-color: #eeb;
  35. --notification-good-border-color: #0062b7;
  36. --notification-good-background-color: #0062b7;
  37. --notification-bad-background-color: #fdd;
  38. --notification-bad-font-color: #912621;
  39. --notification-bad-border-color: #ecc;
  40. --frss-box-shadow-color-transparent: #bbb3;
  41. }
  42. html, body {
  43. background-color: var(--background-color-dark);
  44. color: var(--font-color-middle);
  45. font-family: "OpenSans", "Cantarell", "Helvetica", "Arial", sans-serif;
  46. }
  47. /*=== Links */
  48. a, button.as-link {
  49. color: var(--font-color-light);
  50. outline: none;
  51. }
  52. a:hover .icon {
  53. filter: brightness(2);
  54. }
  55. /*=== Forms */
  56. legend {
  57. margin: 20px 0 5px;
  58. padding: 5px 0;
  59. font-size: 1.4em;
  60. border-bottom: 1px solid var(--border-color-dark);
  61. }
  62. label {
  63. min-height: 25px;
  64. padding: 5px 0;
  65. cursor: pointer;
  66. }
  67. input, select, textarea {
  68. background: var(--background-color-light);
  69. color: var(--font-color-middle);
  70. border: 1px solid var(--border-color-middle);
  71. border-radius: 3px;
  72. }
  73. input:hover,
  74. select:hover,
  75. textarea:hover,
  76. label:hover {
  77. color: var(--font-color-light);
  78. }
  79. option {
  80. padding: 0 .5em;
  81. }
  82. input[type="checkbox"],
  83. input[type="radio"] {
  84. accent-color: var(--contrast-background-color);
  85. }
  86. input[type="checkbox"]:hover,
  87. input[type="radio"]:hover {
  88. accent-color: var(--contrast-background-color-hover);
  89. }
  90. input:disabled, select:disabled {
  91. color: var(--font-color-dark);
  92. border-color: var(--border-color-dark);
  93. }
  94. /*=== Tables */
  95. table {
  96. border-collapse: collapse;
  97. }
  98. th, td {
  99. border: 1px solid var(--border-color-dark);
  100. }
  101. th {
  102. background: var(--background-color-light);
  103. }
  104. .config-articleicons td,
  105. .config-articleicons th {
  106. font-weight: normal;
  107. text-align: center;
  108. }
  109. /*=== COMPONENTS */
  110. /*===============*/
  111. /*=== Forms */
  112. .form-group.form-actions {
  113. padding: 5px 0;
  114. background-color: var(--background-color-dark-transparent);
  115. border-top: 1px solid var(--border-color-dark);
  116. }
  117. .form-group.form-actions .btn {
  118. margin: 0 10px;
  119. }
  120. .form-group .group-name {
  121. padding: 10px 0;
  122. }
  123. .form-group .group-controls {
  124. min-height: 25px;
  125. padding: 5px 0;
  126. }
  127. /*=== Buttons */
  128. .stick input,
  129. .group .btn,
  130. .stick .btn {
  131. border-radius: 0;
  132. }
  133. .stick .btn:first-child,
  134. .group .btn:first-child,
  135. .stick input:first-child,
  136. .group input:first-child {
  137. border-radius: 3px 0 0 3px;
  138. }
  139. .stick .btn-important:first-child {
  140. border-right: 1px solid var(--contrast-background-color-hover);
  141. }
  142. .stick .btn:last-child,
  143. .group .btn:last-child,
  144. .stick input:last-child,
  145. .group input:last-child {
  146. border-radius: 0 3px 3px 0;
  147. }
  148. .stick .btn + .btn,
  149. .group .btn + .btn,
  150. .stick .btn + input,
  151. .stick .btn + .dropdown > .btn,
  152. .group .btn + .dropdown > .btn,
  153. .stick input + .btn,
  154. .stick input + input,
  155. .stick input + .dropdown > .btn,
  156. .stick .dropdown + .btn,
  157. .group .dropdown + .btn,
  158. .stick .dropdown + input,
  159. .stick .dropdown + .dropdown > .btn,
  160. .group .dropdown + .dropdown > .btn {
  161. border-left: none;
  162. }
  163. .stick .btn + .dropdown > .btn,
  164. .group .dropdown + .dropdown > .btn {
  165. border-left: none;
  166. border-radius: 0 3px 3px 0;
  167. }
  168. .btn {
  169. margin: 0;
  170. padding: 0.25rem 0.5rem;
  171. background: var(--background-color-dark);
  172. color: var(--font-color-middle);
  173. font-size: 0.9rem;
  174. border: 1px solid var(--border-color-middle);
  175. border-radius: 3px;
  176. min-height: 25px;
  177. min-width: 15px;
  178. line-height: 1.7;
  179. vertical-align: middle;
  180. }
  181. .btn:hover {
  182. background: var(--background-color-hover);
  183. text-decoration: none;
  184. color: var(--font-color-light);
  185. border: 1px solid var(--contrast-border-color-hover);
  186. }
  187. .btn:hover .icon {
  188. filter: brightness(2);
  189. }
  190. .btn.active,
  191. .btn:active,
  192. .dropdown-target:target ~ .btn.dropdown-toggle {
  193. background: var(--background-color-light);
  194. }
  195. .btn-important {
  196. background: var(--contrast-background-color);
  197. color: var(--contrast-background-font-color);
  198. border: 1px solid var(--contrast-border-color-hover);
  199. font-weight: normal;
  200. }
  201. .btn-important:hover {
  202. background: var(--contrast-background-color-hover);
  203. color: var(--contrast-background-font-color);
  204. }
  205. .btn-important .icon {
  206. filter: brightness(3);
  207. }
  208. .btn-important:active {
  209. background: var(--contrast-background-color-active);
  210. box-shadow: none;
  211. }
  212. .btn-attention {
  213. background-color: var(--contrast-attention-background-color);
  214. color: var(--contrast-attention-font-color);
  215. }
  216. .btn-attention:hover {
  217. background-color: var(--contrast-attention-background-color-hover);
  218. color: var(--contrast-attention-font-color);
  219. }
  220. .btn-attention:active {
  221. background: var(--contrast-attention-background-color);
  222. box-shadow: none;
  223. }
  224. .spinner {
  225. filter: invert(1);
  226. }
  227. a:hover > .spinner {
  228. filter: invert(1) brightness(2);
  229. }
  230. .flux .item.manage .read:hover .icon.spinner {
  231. filter: invert(1) grayscale(0.8) brightness(1.7);
  232. }
  233. /*=== switches */
  234. .switch.active {
  235. background-color: var(--contrast-background-color);
  236. }
  237. .switch.active:hover {
  238. background-image: url('./icons/disabled-light.svg');
  239. }
  240. /*=== Navigation */
  241. .nav-list {
  242. color: var(--font-color-light);
  243. font-size: 0.9rem;
  244. }
  245. .nav-list .item,
  246. .nav-list .item.nav-header {
  247. min-height: 2.5em;
  248. line-height: 2.5;
  249. }
  250. .nav-list .item a,
  251. .nav-list .item .as-link {
  252. color: var(--font-color-middle);
  253. }
  254. .nav-list .item a:hover,
  255. .nav-list .item .as-link:hover {
  256. background-color: var(--background-color-hover);
  257. color: var(--font-color-light);
  258. }
  259. .nav-list .item.active a,
  260. .nav-list .item.active .as-link {
  261. background-color: var(--background-color-dark);
  262. color: var(--font-color-light);
  263. }
  264. .nav-list .item > a,
  265. .nav-list .item > .as-link {
  266. padding: 0 1rem;
  267. }
  268. .nav-list a:hover,
  269. .nav-list .as-link:hover {
  270. text-decoration: none;
  271. }
  272. .nav-list .nav-header {
  273. padding: 0 1rem;
  274. color: var(--font-color-middle);
  275. font-weight: bold;
  276. }
  277. .nav-list .nav-form {
  278. padding: 3px;
  279. text-align: center;
  280. }
  281. /*=== Dropdown */
  282. .dropdown-menu {
  283. margin: 5px 0 0;
  284. padding: 0.5rem 0 0.25rem 0;
  285. background: var(--background-color-active);
  286. font-size: 0.8rem;
  287. border: 2px solid var(--background-color-light);
  288. border-radius: 5px;
  289. text-align: left;
  290. }
  291. .dropdown-menu::after {
  292. border-color: var(--border-color-dark);
  293. }
  294. .dropdown-header,
  295. .dropdown-section .dropdown-section-title {
  296. padding: 0.25rem 0.5rem 0.25rem 1rem;
  297. color: var(--font-color-middle);
  298. font-weight: bold;
  299. text-align: left;
  300. }
  301. .dropdown-menu .item > a,
  302. .dropdown-menu .item > span,
  303. .dropdown-menu .item > .as-link {
  304. padding: 0 22px;
  305. line-height: 2.5;
  306. font-size: inherit;
  307. }
  308. .dropdown-menu .dropdown-section .item > a,
  309. .dropdown-menu .dropdown-section .item > span,
  310. .dropdown-menu .dropdown-section .item > .as-link {
  311. padding-left: 2rem;
  312. }
  313. .dropdown-menu .dropdown-section .item:last-child {
  314. margin-bottom: 0.5rem;
  315. }
  316. .dropdown-menu .item > a:focus,
  317. .dropdown-menu .item > a:hover,
  318. .dropdown-menu .item > button:focus:not([disabled]),
  319. .dropdown-menu .item > button:hover:not([disabled]),
  320. .dropdown-menu .item > label:focus:not(.noHover),
  321. .dropdown-menu .item > label:hover:not(.noHover) {
  322. background: var(--background-color-hover);
  323. color: var(--font-color-light);
  324. }
  325. .dropdown-menu > .item[aria-checked="true"] > a::before {
  326. font-weight: bold;
  327. margin: 0 0 0 -14px;
  328. }
  329. .dropdown-menu .input select,
  330. .dropdown-menu .input input {
  331. margin: 0 auto 5px;
  332. padding: 2px 5px;
  333. border-radius: 3px;
  334. }
  335. .dropdown-menu input[type="checkbox"] {
  336. margin-left: 1rem;
  337. }
  338. .dropdown-menu .item .emptyLabels {
  339. padding-left: 1rem;
  340. padding-right: 1rem;
  341. }
  342. .item ~ .dropdown-header,
  343. .dropdown-section ~ .dropdown-section,
  344. .item.separator {
  345. border-top-color: var(--border-color-dark);
  346. }
  347. /*=== Alerts */
  348. .alert {
  349. background-color: var(--background-color-dark);
  350. color: var(--font-color-middle);
  351. font-size: 0.9em;
  352. border-width: 2px;
  353. border-style: solid;
  354. border-radius: 5px;
  355. }
  356. .alert-head {
  357. font-size: 1.15em;
  358. }
  359. .alert a {
  360. color: var(--font-color-middle);
  361. text-decoration: underline;
  362. }
  363. .alert a:hover {
  364. color: var(--font-color-light);
  365. }
  366. .alert-warn {
  367. border-color: var(--alert-warn-border-color);
  368. }
  369. .alert-success {
  370. border-color: var(--alert-success-border-color);
  371. }
  372. .alert-error {
  373. border-color: var(--alert-error-border-color);
  374. }
  375. kbd {
  376. background-color: var(--background-color-middle);
  377. color: var(--font-color-middle);
  378. border-color: var(--border-color-middle);
  379. }
  380. /*=== Pagination */
  381. .pagination {
  382. color: var(--font-color-middle);
  383. border-top: 1px solid var(--border-color-dark);
  384. border-bottom: 1px solid var(--border-color-dark);
  385. }
  386. /*=== Boxes */
  387. .box {
  388. background: var(--background-color-middle);
  389. border-width: 0;
  390. border-radius: 3px;
  391. }
  392. .box .box-title {
  393. background: var(--background-color-light);
  394. border-radius: 5px 5px 0 0;
  395. }
  396. .box .box-title .configure {
  397. margin-right: 4px;
  398. }
  399. .box .box-content {
  400. padding-left: 30px;
  401. min-height: 2.5em;
  402. max-height: 260px;
  403. }
  404. .box .box-content .item {
  405. font-size: 0.9rem;
  406. }
  407. /*=== Tree */
  408. .tree {
  409. margin: 10px 0;
  410. }
  411. .tree-folder-title {
  412. position: relative;
  413. padding: 0 10px;
  414. background: var(--background-color-light);
  415. line-height: 2.5;
  416. font-size: 1rem;
  417. }
  418. .tree-folder-title:hover {
  419. background: var(--background-color-hover);
  420. }
  421. .tree-folder-title:hover .title {
  422. color: var(--font-color-light);
  423. }
  424. .tree-folder-title:hover .dropdown-toggle .icon {
  425. filter: brightness(2);
  426. }
  427. .tree-folder-title:hover button.dropdown-toggle .icon {
  428. filter: inherit;
  429. }
  430. .tree-folder-title button.dropdown-toggle:hover .icon {
  431. filter: brightness(2);
  432. }
  433. .tree-folder-title .title {
  434. background: inherit;
  435. color: var(--font-color-middle);
  436. }
  437. .tree-folder-title .title:hover {
  438. text-decoration: none;
  439. }
  440. .tree-folder.active .tree-folder-title {
  441. background: var(--background-color-dark);
  442. font-weight: bold;
  443. }
  444. .tree-folder.active .tree-folder-title .title {
  445. color: var(--font-color-light);
  446. }
  447. .tree-folder-items {
  448. background: var(--background-color-light);
  449. }
  450. .tree-folder-items:hover {
  451. background: var(--background-color-middle);
  452. }
  453. .tree-folder-items > .item {
  454. font-size: 0.8rem;
  455. }
  456. .tree-folder-items > .item.active {
  457. background: var(--background-color-dark);
  458. }
  459. .tree-folder-items > .item > a {
  460. text-decoration: none;
  461. }
  462. .tree-folder-items > .item.active > a {
  463. color: var(--font-color-middle);
  464. }
  465. /*=== STRUCTURE */
  466. /*===============*/
  467. /*=== Header */
  468. .header {
  469. background: var(--background-color-dark);
  470. }
  471. .header > .item {
  472. border-bottom: 1px solid var(--border-color-dark);
  473. vertical-align: middle;
  474. text-align: center;
  475. }
  476. .header > .item.title .logo {
  477. filter: grayscale(100%) brightness(2.5);
  478. }
  479. .header > .item.title a:hover .logo {
  480. filter: grayscale(100%) brightness(2.8);
  481. }
  482. .header > .item.search input {
  483. width: 350px;
  484. }
  485. /*=== Body */
  486. .aside {
  487. background: var(--background-color-light);
  488. }
  489. .aside.aside_feed {
  490. padding: 10px 0;
  491. text-align: center;
  492. background: var(--background-color-light);
  493. }
  494. .aside.aside_feed .tree {
  495. margin: 10px 0 50px;
  496. }
  497. /*=== Aside main page (categories) */
  498. .aside_feed .category .title:not([data-unread="0"])::after {
  499. padding: 0 10px;
  500. line-height: 1.5;
  501. }
  502. .aside.aside_feed .category .title:not([data-unread="0"])::after,
  503. .aside.aside_feed .feed .item-title:not([data-unread="0"])::after,
  504. .global .box.category .title:not([data-unread="0"])::after,
  505. .global .feed .item-title:not([data-unread="0"])::after {
  506. background-color: var(--background-color-dark);
  507. color: var(--font-color-middle);
  508. }
  509. .aside.aside_feed .category:hover .title:not([data-unread="0"])::after,
  510. .aside.aside_feed .feed:hover .item-title:not([data-unread="0"])::after {
  511. color: var(--font-color-light);
  512. }
  513. .aside_feed .tree-folder-title button.dropdown-toggle {
  514. margin: -0.75rem 0 -0.75rem -0.75rem;
  515. padding: 0.75rem 0 0.75rem 0.75rem;
  516. }
  517. /*=== Aside main page (feeds) */
  518. .feed.item.empty.active,
  519. .feed.item.empty.active > a {
  520. background: var(--empty-feed-color);
  521. color: var(--font-color-dark);
  522. }
  523. .feed.item.error.active {
  524. background: var(--contrast-attention-background-color);
  525. }
  526. .feed.item.empty,
  527. .feed.item.empty > a {
  528. color: var(--empty-feed-color);
  529. }
  530. .feed.item.error,
  531. .feed.item.error > a {
  532. color: var(--font-color-error);
  533. }
  534. .feed.item.error.active,
  535. .feed.item.error.active > a {
  536. color: var(--font-color-light);
  537. }
  538. .aside_feed .tree-folder-items .dropdown-menu::after {
  539. left: 2px;
  540. }
  541. .theme-preview-list {
  542. border-color: var(--border-color-middle);
  543. }
  544. .theme-preview-list .properties {
  545. background-color: var(--background-color-light);
  546. color: var(--font-color-middle);
  547. border-color: var(--border-color-middle);
  548. }
  549. /*=== Prompt (centered) */
  550. .prompt .form-group {
  551. margin-bottom: 1rem;
  552. }
  553. .prompt .form-group::after {
  554. display: none;
  555. }
  556. .prompt .form-group.form-group-actions {
  557. display: flex;
  558. margin-top: 2rem;
  559. align-items: center;
  560. justify-content: space-between;
  561. }
  562. .prompt .btn.btn-important {
  563. padding-left: 1.5rem;
  564. padding-right: 1.5rem;
  565. font-size: 1.1rem;
  566. }
  567. /*=== New article notification */
  568. #new-article {
  569. background: var(--contrast-background-color);
  570. text-align: center;
  571. font-size: 0.9em;
  572. }
  573. #new-article > a {
  574. padding: 0.75rem;
  575. color: var(--font-color-light);
  576. font-weight: bold;
  577. }
  578. #new-article > a:hover {
  579. text-decoration: none;
  580. background: var(--contrast-background-color-hover);
  581. }
  582. /*=== Transition indication, e.g. day */
  583. .transition {
  584. padding: 0 10px;
  585. font-weight: bold;
  586. line-height: 3;
  587. background: var(--background-color-dark);
  588. color: var(--font-color-light);
  589. border-top: 1px solid var(--border-color-dark);
  590. }
  591. .transition span {
  592. line-height: 1.5;
  593. }
  594. #new-article + .transition {
  595. border-top: none;
  596. }
  597. .transition .name {
  598. padding: 0 10px 0 0;
  599. color: var(--font-color-light);
  600. font-size: 1.8em;
  601. opacity: 0.3;
  602. text-shadow: 0px -1px 0px var(--font-color-dark);
  603. font-style: italic;
  604. text-align: right;
  605. }
  606. /*=== Index menu */
  607. .nav_menu {
  608. padding: 5px 0;
  609. background: var(--background-color-dark);
  610. text-align: center;
  611. }
  612. /*=== Feed articles */
  613. .flux {
  614. background: var(--background-color-dark);
  615. border-left-color: var(--border-color-dark);
  616. border-left-width: 2px;
  617. border-left-style: solid;
  618. }
  619. .flux .flux_header:hover {
  620. background: var(--background-color-hover);
  621. }
  622. .flux.current {
  623. background: var(--background-color-middle);
  624. border-left: 2px solid var(--contrast-border-color-hover);
  625. }
  626. .flux.current.active {
  627. background: var(--background-color-middle);
  628. }
  629. .flux.not_read {
  630. border-left: 2px solid var(--border-color-unread);
  631. }
  632. .flux.not_read:not(.current) {
  633. background: var(--background-color-dark);
  634. }
  635. .flux.not_read:not(.current):hover .item .title {
  636. background: var(--background-color-hover);
  637. }
  638. .flux:not(.current):hover .item .title {
  639. background: var(--background-color-hover);
  640. }
  641. .flux.current:not(.active) {
  642. background: var(--background-color-hover);
  643. }
  644. .flux .flux_header .item .title {
  645. color: var(--font-color-light);
  646. }
  647. .flux .flux_header .item .title .author {
  648. color: var(--font-color-dark);
  649. }
  650. .flux.favorite {
  651. border-left: 2px solid var(--border-color-favorite);
  652. }
  653. .flux.favorite:not(.current) {
  654. background: var(--background-color-dark);
  655. }
  656. /* stylelint-disable-next-line no-duplicate-selectors */
  657. .flux.current {
  658. border-left-width: 5px;
  659. border-left-style: double;
  660. }
  661. .flux.current > .flux_header,
  662. .flux.not_read.current > .flux_header, .flux.not_read.current > .flux_header:hover,
  663. .flux.favorite.current > .flux_header, .flux.favorite.current > .flux_header:hover {
  664. background: linear-gradient(to right, transparent 0, transparent 3px, var(--background-color-hover) 3px);
  665. margin-left: -3px; /* Compensate increased border-left-width */
  666. }
  667. .flux_header {
  668. font-size: 0.8rem;
  669. border-top: 1px solid var(--border-color-dark);
  670. cursor: pointer;
  671. }
  672. .flux_header .title {
  673. font-size: 0.9rem;
  674. }
  675. .flux .website a:hover .favicon,
  676. .flux a.website:hover .favicon {
  677. filter: grayscale(50%);
  678. }
  679. .flux .item.manage .read:hover .icon {
  680. filter: grayscale(0.8) brightness(1.7);
  681. }
  682. .flux .flux_header .date,
  683. .flux .flux_content .bottom .date {
  684. color: var(--font-color-light);
  685. }
  686. .flux .bottom {
  687. font-size: 0.8rem;
  688. text-align: center;
  689. }
  690. /*=== Content of feed articles */
  691. .content {
  692. padding: 20px 10px;
  693. color: var(--font-color-middle);
  694. }
  695. .content h1,
  696. .content h2,
  697. .content h3 {
  698. color: var(--font-color-light);
  699. }
  700. .content hr {
  701. margin: 30px 10px;
  702. background: var(--font-color-middle);
  703. height: 1px;
  704. border: 0;
  705. }
  706. .content pre {
  707. background: var(--background-color-dark);
  708. color: var(--font-color-light);
  709. border-radius: 3px;
  710. }
  711. .content code {
  712. background: var(--background-color-light);
  713. border-color: var(--background-color-light);
  714. border-radius: 3px;
  715. }
  716. .content pre code {
  717. background: transparent;
  718. color: var(--font-color-light);
  719. border: none;
  720. }
  721. .content blockquote {
  722. margin: 0;
  723. padding: 25px;
  724. background: var(--background-color-light);
  725. display: block;
  726. color: var(--font-color-middle);
  727. }
  728. .content blockquote p {
  729. margin: 0;
  730. }
  731. .content > footer {
  732. border-color: var(--border-color-middle);
  733. }
  734. .content > header a,
  735. .content > header .subtitle,
  736. .content > footer a,
  737. .content > footer .subtitle {
  738. color: var(--font-color-middle);
  739. }
  740. .content > header h1 a {
  741. color: var(--font-color-light);
  742. }
  743. /*=== Notification and actualize notification */
  744. .notification {
  745. font-size: 0.9em;
  746. border: 2px solid var(--notification-border-color);
  747. border-radius: 5px;
  748. text-align: center;
  749. font-weight: bold;
  750. vertical-align: middle;
  751. }
  752. .notification.good {
  753. background-color: var(--background-color-light);
  754. color: var(--font-color-middle);
  755. border-color: var(--notification-good-border-color);
  756. }
  757. .notification.good .close:hover {
  758. background: var(--notification-good-background-color);
  759. }
  760. .notification.bad {
  761. background-color: var(--notification-bad-background-color);
  762. color: var(--notification-bad-font-color);
  763. border-color: var(--notification-bad-border-color);
  764. }
  765. .notification.bad .close:hover {
  766. background: var(--notification-bad-background-color);
  767. }
  768. .notification .close .icon {
  769. filter: brightness(1);
  770. }
  771. .notification .close:hover .icon {
  772. filter: brightness(2);
  773. }
  774. .notification a {
  775. color: var(--font-color-contrast);
  776. }
  777. /*=== "Load more" part */
  778. #bigMarkAsRead.big {
  779. background: var(--background-color-dark);
  780. color: var(--font-color-contrast);
  781. text-align: center;
  782. text-decoration: none;
  783. }
  784. #bigMarkAsRead:hover {
  785. background-color: var(--background-color-hover);
  786. color: var(--font-color-light);
  787. }
  788. .bigTick {
  789. display: none!important;
  790. }
  791. /*=== Navigation menu (for articles) */
  792. #nav_entries {
  793. background: var(--background-color-light);
  794. }
  795. /*=== READER VIEW */
  796. /*================*/
  797. #stream.reader .flux {
  798. color: var(--font-color-dark);
  799. background-color: var(--background-color-dark);
  800. border-bottom: 10px solid var(--background-color-dark);
  801. }
  802. #stream.reader .flux:hover {
  803. background: inherit !important;
  804. }
  805. #stream.reader .flux .flux_content {
  806. background-color: var(--background-color-middle);
  807. border-color: var(--border-color-dark);
  808. }
  809. #stream.reader .flux.current.active {
  810. background: var(--background-color-middle);
  811. }
  812. #stream.reader .flux .author {
  813. color: var(--font-color-dark);
  814. }
  815. #stream-footer {
  816. border-top-color: var(--border-color-dark);
  817. }
  818. /*=== GLOBAL VIEW */
  819. /*================*/
  820. .box.category .box-title .title {
  821. font-weight: normal;
  822. text-decoration: none;
  823. text-align: left;
  824. }
  825. .box.category:not([data-unread="0"]) .box-title {
  826. background: var(--background-color-light);
  827. }
  828. .box.category:not([data-unread="0"]) .box-title:active {
  829. background: var(--background-color-dark);
  830. }
  831. .box.category:not([data-unread="0"]) .box-title .title {
  832. color: var(--font-color-middle);
  833. font-weight: bold;
  834. }
  835. .box.category .title:not([data-unread="0"])::after {
  836. background: none;
  837. color: var(--font-color-light);
  838. border: 0;
  839. box-shadow: none;
  840. position: absolute;
  841. top: 5px; right: 10px;
  842. font-weight: bold;
  843. text-shadow: none;
  844. }
  845. #stream.global .feed .item-title:not([data-unread="0"])::after {
  846. margin: 1rem 0px 0px;
  847. }
  848. /*=== Slider */
  849. #slider {
  850. background: var(--background-color-dark);
  851. border-left: 1px solid var(--border-color-dark);
  852. }
  853. #slider.active:target + #close-slider {
  854. background-color: var(--background-color-slider-shadow);
  855. }
  856. /*=== SLIDESHOW */
  857. /*==============*/
  858. .nav label {
  859. color: var(--font-color-light);
  860. }
  861. .nav label:hover {
  862. color: var(--font-color-contrast);
  863. }
  864. /*=== DIVERS */
  865. /*===========*/
  866. .aside.aside_feed .nav-form input,
  867. .aside.aside_feed .nav-form select {
  868. width: 140px;
  869. }
  870. .aside.aside_feed .nav-form .dropdown .dropdown-menu {
  871. right: -20px;
  872. }
  873. .aside.aside_feed .nav-form .dropdown .dropdown-menu::after {
  874. right: 33px;
  875. }
  876. /*=== STATISTICS */
  877. /*===============*/
  878. .stat {
  879. margin: 10px 0 20px;
  880. }
  881. .stat th,
  882. .stat td,
  883. .stat tr {
  884. border: none;
  885. }
  886. .stat > table td,
  887. .stat > table th {
  888. border-bottom: 1px solid var(--border-color-dark);
  889. }
  890. /*=== MOBILE */
  891. /*===========*/
  892. @media (max-width: 840px) {
  893. .form-group .group-name {
  894. padding-bottom: 0;
  895. }
  896. .aside {
  897. box-shadow: 3px 0 3px var(--background-color-active);
  898. transition: width 200ms linear;
  899. }
  900. .aside .toggle_aside,
  901. #overlay .close,
  902. .dropdown-menu .toggle_aside,
  903. #slider .toggle_aside {
  904. background: var(--background-color-light);
  905. border-bottom-color: var(--border-color-dark);
  906. }
  907. .aside .toggle_aside:hover,
  908. #overlay .close:hover,
  909. .dropdown-menu .toggle_aside:hover,
  910. #slider .toggle_aside:hover {
  911. background-color: var(--background-color-hover);
  912. }
  913. .aside .toggle_aside:hover .icon,
  914. #overlay .close:hover .icon,
  915. .dropdown-menu .toggle_aside:hover .icon {
  916. filter: brightness(2);
  917. }
  918. .aside:target + .close-aside, .configure .dropdown-target:target ~ .dropdown-close {
  919. background-color: var(--background-color-slider-shadow);
  920. }
  921. .aside.aside_feed {
  922. padding: 0;
  923. }
  924. .configure .dropdown .dropdown-menu {
  925. border-width: 0;
  926. box-shadow: -3px 0 3px var(--background-color-active);
  927. }
  928. .nav_menu .btn {
  929. margin: 5px 10px;
  930. padding: 3px 5px;
  931. min-height: 0;
  932. }
  933. .nav_menu .stick,
  934. .nav_menu .group {
  935. margin: 0 10px;
  936. }
  937. .nav_menu .stick .btn,
  938. .nav_menu .group .btn {
  939. margin: 5px 0;
  940. }
  941. .dropdown-target:target ~ .dropdown-toggle::after {
  942. background-color: var(--background-color-active);
  943. border-top: 2px solid var(--background-color-light);
  944. border-left: 2px solid var(--background-color-light);
  945. }
  946. .transition .name {
  947. display: none!important;
  948. font-size: 1.1rem;
  949. text-shadow: none;
  950. }
  951. .flux:not(.current):hover .item.title {
  952. background: var(--background-color-hover);
  953. }
  954. .notification .close {
  955. background: transparent;
  956. display: block;
  957. left: 0;
  958. }
  959. .notification .close:hover {
  960. opacity: 0.5;
  961. }
  962. .notification .close .icon {
  963. display: none;
  964. }
  965. .post {
  966. padding-left: 15px;
  967. padding-right: 15px;
  968. }
  969. }