origine.css 28 KB

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