origine.css 28 KB

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