origine.css 30 KB

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