origine.css 28 KB

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